dissect.target 3.20.dev60__py3-none-any.whl → 3.20.dev62__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- dissect/target/plugins/apps/database/__init__.py +0 -0
- dissect/target/plugins/os/unix/linux/fortios/_os.py +8 -1
- dissect/target/plugins/os/windows/log/mssql.py +103 -0
- {dissect.target-3.20.dev60.dist-info → dissect.target-3.20.dev62.dist-info}/METADATA +1 -1
- {dissect.target-3.20.dev60.dist-info → dissect.target-3.20.dev62.dist-info}/RECORD +10 -8
- {dissect.target-3.20.dev60.dist-info → dissect.target-3.20.dev62.dist-info}/WHEEL +1 -1
- {dissect.target-3.20.dev60.dist-info → dissect.target-3.20.dev62.dist-info}/COPYRIGHT +0 -0
- {dissect.target-3.20.dev60.dist-info → dissect.target-3.20.dev62.dist-info}/LICENSE +0 -0
- {dissect.target-3.20.dev60.dist-info → dissect.target-3.20.dev62.dist-info}/entry_points.txt +0 -0
- {dissect.target-3.20.dev60.dist-info → dissect.target-3.20.dev62.dist-info}/top_level.txt +0 -0
File without changes
|
@@ -248,10 +248,16 @@ class FortiOSPlugin(LinuxPlugin):
|
|
248
248
|
self.target.log.warning("Exception while parsing FortiManager admin users")
|
249
249
|
self.target.log.debug("", exc_info=e)
|
250
250
|
|
251
|
-
if self._config.get("root-config"):
|
251
|
+
if self._config.get("root-config", {}).get("user", {}).get("local"):
|
252
252
|
# Local users
|
253
253
|
try:
|
254
254
|
local_groups = local_groups_to_users(self._config["root-config"]["user"]["group"])
|
255
|
+
except KeyError as e:
|
256
|
+
self.target.log.warning("Unable to get local user groups in root config")
|
257
|
+
self.target.log.debug("", exc_info=e)
|
258
|
+
local_groups = {}
|
259
|
+
|
260
|
+
try:
|
255
261
|
for username, entry in self._config["root-config"]["user"].get("local", {}).items():
|
256
262
|
try:
|
257
263
|
password = decrypt_password(entry["passwd"][-1])
|
@@ -269,6 +275,7 @@ class FortiOSPlugin(LinuxPlugin):
|
|
269
275
|
self.target.log.warning("Exception while parsing FortiOS local users")
|
270
276
|
self.target.log.debug("", exc_info=e)
|
271
277
|
|
278
|
+
if self._config.get("root-config", {}).get("user", {}).get("group", {}).get("guestgroup"):
|
272
279
|
# Temporary guest users
|
273
280
|
try:
|
274
281
|
for _, entry in (
|
@@ -0,0 +1,103 @@
|
|
1
|
+
import re
|
2
|
+
from datetime import datetime, timezone
|
3
|
+
from typing import Iterator
|
4
|
+
|
5
|
+
from dissect.target.exceptions import UnsupportedPluginError
|
6
|
+
from dissect.target.helpers.fsutil import TargetPath
|
7
|
+
from dissect.target.helpers.record import TargetRecordDescriptor
|
8
|
+
from dissect.target.plugin import Plugin, export
|
9
|
+
from dissect.target.target import Target
|
10
|
+
|
11
|
+
MssqlErrorlogRecord = TargetRecordDescriptor(
|
12
|
+
"microsoft/sql/errorlog",
|
13
|
+
[
|
14
|
+
("datetime", "ts"),
|
15
|
+
("string", "instance"),
|
16
|
+
("string", "process"),
|
17
|
+
("string", "message"),
|
18
|
+
("path", "path"),
|
19
|
+
],
|
20
|
+
)
|
21
|
+
|
22
|
+
RE_TIMESTAMP_PATTERN = re.compile(r"^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}.\d{2}")
|
23
|
+
|
24
|
+
|
25
|
+
class MssqlPlugin(Plugin):
|
26
|
+
"""Return information related to Microsoft SQL Server.
|
27
|
+
|
28
|
+
Currently returns ERRORLOG messages. These log files contain information such as:
|
29
|
+
- Logon failures
|
30
|
+
- Enabling/disabling of features, such as xp_cmdshell
|
31
|
+
|
32
|
+
References:
|
33
|
+
- https://learn.microsoft.com/en-us/sql/relational-databases/logs/view-offline-log-files
|
34
|
+
"""
|
35
|
+
|
36
|
+
__namespace__ = "mssql"
|
37
|
+
|
38
|
+
MSSQL_KEY = "HKLM\\SOFTWARE\\Microsoft\\Microsoft SQL Server"
|
39
|
+
FILE_GLOB = "ERRORLOG*"
|
40
|
+
|
41
|
+
def __init__(self, target: Target):
|
42
|
+
super().__init__(target)
|
43
|
+
self.instances = self._find_instances()
|
44
|
+
|
45
|
+
def check_compatible(self) -> None:
|
46
|
+
if not self.instances:
|
47
|
+
raise UnsupportedPluginError("System does not seem to be running SQL Server")
|
48
|
+
|
49
|
+
@export(record=MssqlErrorlogRecord)
|
50
|
+
def errorlog(self) -> Iterator[MssqlErrorlogRecord]:
|
51
|
+
"""Return all Microsoft SQL Server ERRORLOG messages.
|
52
|
+
|
53
|
+
These log files contain information such as:
|
54
|
+
- Logon failures
|
55
|
+
- Enabling/disabling of features, such as xp_cmdshell
|
56
|
+
|
57
|
+
Yields MssqlErrorlogRecord instances with fields:
|
58
|
+
|
59
|
+
.. code-block:: text
|
60
|
+
|
61
|
+
ts (datetime): Timestamp of the log line.
|
62
|
+
instance (str): SQL Server instance name.
|
63
|
+
process (str): Process name.
|
64
|
+
message (str): Log message.
|
65
|
+
path (Path): Path to the log file.
|
66
|
+
|
67
|
+
References:
|
68
|
+
- https://learn.microsoft.com/en-us/sql/relational-databases/logs/view-offline-log-files
|
69
|
+
"""
|
70
|
+
|
71
|
+
for instance, log_path in self.instances:
|
72
|
+
for errorlog in log_path.glob(self.FILE_GLOB):
|
73
|
+
# The errorlog includes a BOM, so endianess gets determined automatically
|
74
|
+
fh = errorlog.open(mode="rt", encoding="utf-16", errors="surrogateescape")
|
75
|
+
buf = ""
|
76
|
+
|
77
|
+
for line in fh:
|
78
|
+
if ts := RE_TIMESTAMP_PATTERN.match(line):
|
79
|
+
yield MssqlErrorlogRecord(
|
80
|
+
ts=datetime.strptime(ts.group(), "%Y-%m-%d %H:%M:%S.%f").replace(tzinfo=timezone.utc),
|
81
|
+
instance=instance,
|
82
|
+
# The process name is a fixed-width field and is always 12 characters long.
|
83
|
+
process=buf[23:35].strip(),
|
84
|
+
message=buf[35:].strip(),
|
85
|
+
path=errorlog,
|
86
|
+
_target=self.target,
|
87
|
+
)
|
88
|
+
buf = ""
|
89
|
+
|
90
|
+
buf += line
|
91
|
+
|
92
|
+
def _find_instances(self) -> list[str, TargetPath]:
|
93
|
+
instances = []
|
94
|
+
|
95
|
+
for subkey in self.target.registry.key(self.MSSQL_KEY).subkeys():
|
96
|
+
if subkey.name.startswith("MSSQL") and "." in subkey.name:
|
97
|
+
instances.append(
|
98
|
+
(
|
99
|
+
subkey.name,
|
100
|
+
self.target.fs.path(subkey.subkey("SQLServerAgent").value("ErrorLogFile").value).parent,
|
101
|
+
)
|
102
|
+
)
|
103
|
+
return instances
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: dissect.target
|
3
|
-
Version: 3.20.
|
3
|
+
Version: 3.20.dev62
|
4
4
|
Summary: This module ties all other Dissect modules together, it provides a programming API and command line tools which allow easy access to various data sources inside disk images or file collections (a.k.a. targets)
|
5
5
|
Author-email: Dissect Team <dissect@fox-it.com>
|
6
6
|
License: Affero General Public License v3
|
@@ -128,6 +128,7 @@ dissect/target/plugins/apps/browser/firefox.py,sha256=mZBBagFfIdiz9kUyK4Hi989I4g
|
|
128
128
|
dissect/target/plugins/apps/browser/iexplore.py,sha256=g_xw0toaiyjevxO8g9XPCOqc-CXZp39FVquRhPFGdTE,8801
|
129
129
|
dissect/target/plugins/apps/container/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
130
130
|
dissect/target/plugins/apps/container/docker.py,sha256=LTsZplaECSfO1Ysp_Y-9WsnNocsreu_iHO8fbSif3g0,16221
|
131
|
+
dissect/target/plugins/apps/database/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
131
132
|
dissect/target/plugins/apps/editor/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
132
133
|
dissect/target/plugins/apps/editor/editor.py,sha256=yJctXY0XTfwW3GKy6XLO2WaWFQLssdBck9ZOcZSyf80,495
|
133
134
|
dissect/target/plugins/apps/editor/windowsnotepad.py,sha256=A9cfFrqbU2zjHRrzYsCnXr-uxKAIsVIKdXXJPYMt6MU,15068
|
@@ -251,7 +252,7 @@ dissect/target/plugins/os/unix/linux/debian/vyos/__init__.py,sha256=47DEQpj8HBSa
|
|
251
252
|
dissect/target/plugins/os/unix/linux/debian/vyos/_os.py,sha256=TPjcfv1n68RCe3Er4aCVQwQDCZwJT-NLvje3kPjDfhk,1744
|
252
253
|
dissect/target/plugins/os/unix/linux/fortios/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
253
254
|
dissect/target/plugins/os/unix/linux/fortios/_keys.py,sha256=jDDHObfsUn9BGoIir9p4J_-rg9rI1rgoOfnL3R3lg4o,123358
|
254
|
-
dissect/target/plugins/os/unix/linux/fortios/_os.py,sha256=
|
255
|
+
dissect/target/plugins/os/unix/linux/fortios/_os.py,sha256=7ZIwWFEfYwE924IvGfuinv1mEP6Uh28pl8VHSmsGKmM,20152
|
255
256
|
dissect/target/plugins/os/unix/linux/fortios/generic.py,sha256=dc6YTDLV-VZq9k8IWmY_PE0sTGkkp3yamR-cYNUCtes,1265
|
256
257
|
dissect/target/plugins/os/unix/linux/fortios/locale.py,sha256=Pe7Bdj8UemCiktLeQnQ50TpY_skARAzRJA0ewAB4710,5243
|
257
258
|
dissect/target/plugins/os/unix/linux/redhat/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
@@ -327,6 +328,7 @@ dissect/target/plugins/os/windows/log/amcache.py,sha256=TabtjNx9Ve-u-Fn0K95A0v_S
|
|
327
328
|
dissect/target/plugins/os/windows/log/etl.py,sha256=t5GpunjzYMvAO9CBOP1ynH6053_PlasnIEIvlLNLU10,7255
|
328
329
|
dissect/target/plugins/os/windows/log/evt.py,sha256=pYRVK3u309yK5pJoogohHWV2a_Lev8FK2zte_ys4SN8,7133
|
329
330
|
dissect/target/plugins/os/windows/log/evtx.py,sha256=eSnMkU7HRmIDZ19WRsF9li08HuEOo51pRJDN2JOua5U,6148
|
331
|
+
dissect/target/plugins/os/windows/log/mssql.py,sha256=sn9LZvKTaam15G1Vl2BZp2P6uph7_jw03L8P9NjlMKw,3745
|
330
332
|
dissect/target/plugins/os/windows/log/pfro.py,sha256=d53Mm7ovZa9crSwVRPwjMVxTd_jCGtE1Kv07GslX9_s,2789
|
331
333
|
dissect/target/plugins/os/windows/log/schedlgu.py,sha256=JaP8H8eTEypWXhx2aFSR_IMam6rQiksbLKhMr_U4fz8,5570
|
332
334
|
dissect/target/plugins/os/windows/regf/7zip.py,sha256=Ox8cLyQtbyYQS7m4eY3onNv1K8N2IkS5wexrC55Urd4,3444
|
@@ -378,10 +380,10 @@ dissect/target/volumes/luks.py,sha256=OmCMsw6rCUXG1_plnLVLTpsvE1n_6WtoRUGQbpmu1z
|
|
378
380
|
dissect/target/volumes/lvm.py,sha256=wwQVR9I3G9YzmY6UxFsH2Y4MXGBcKL9aayWGCDTiWMU,2269
|
379
381
|
dissect/target/volumes/md.py,sha256=7ShPtusuLGaIv27SvEETtgsuoQyAa4iAAeOR1NEaajI,1689
|
380
382
|
dissect/target/volumes/vmfs.py,sha256=-LoUbn9WNwTtLi_4K34uV_-wDw2W5hgaqxZNj4UmqAQ,1730
|
381
|
-
dissect.target-3.20.
|
382
|
-
dissect.target-3.20.
|
383
|
-
dissect.target-3.20.
|
384
|
-
dissect.target-3.20.
|
385
|
-
dissect.target-3.20.
|
386
|
-
dissect.target-3.20.
|
387
|
-
dissect.target-3.20.
|
383
|
+
dissect.target-3.20.dev62.dist-info/COPYRIGHT,sha256=m-9ih2RVhMiXHI2bf_oNSSgHgkeIvaYRVfKTwFbnJPA,301
|
384
|
+
dissect.target-3.20.dev62.dist-info/LICENSE,sha256=DZak_2itbUtvHzD3E7GNUYSRK6jdOJ-GqncQ2weavLA,34523
|
385
|
+
dissect.target-3.20.dev62.dist-info/METADATA,sha256=Jxh4wrXxgKedtQ0Hql8CSr6Q2kz64t25ZsD3aWz5RIg,13025
|
386
|
+
dissect.target-3.20.dev62.dist-info/WHEEL,sha256=R06PA3UVYHThwHvxuRWMqaGcr-PuniXahwjmQRFMEkY,91
|
387
|
+
dissect.target-3.20.dev62.dist-info/entry_points.txt,sha256=BWuxAb_6AvUAQpIQOQU0IMTlaF6TDht2AIZK8bHd-zE,492
|
388
|
+
dissect.target-3.20.dev62.dist-info/top_level.txt,sha256=Mn-CQzEYsAbkxrUI0TnplHuXnGVKzxpDw_po_sXpvv4,8
|
389
|
+
dissect.target-3.20.dev62.dist-info/RECORD,,
|
File without changes
|
File without changes
|
{dissect.target-3.20.dev60.dist-info → dissect.target-3.20.dev62.dist-info}/entry_points.txt
RENAMED
File without changes
|
File without changes
|