-
Notifications
You must be signed in to change notification settings - Fork 123
/
Copy pathpersistentProp.py
executable file
·57 lines (48 loc) · 2.53 KB
/
persistentProp.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
import os
import datetime
from scripts.artifact_report import ArtifactHtmlReport
from scripts.ilapfuncs import logfunc, tsv, timeline, is_platform_windows
def get_persistentProp(files_found, report_folder, seeker, wrap_text, time_offset):
for file_found in files_found:
file_found = str(file_found)
if not file_found.endswith('persistent_properties'):
continue # Skip all other files
data_list = []
with open(file_found, 'r') as f:
for line in f:
clean = line.strip()
if clean.startswith('persist.sys.boot.reason.historyDreboot'):
parts = clean.split(',')
utctimestamp = (datetime.datetime.utcfromtimestamp(int(parts[-1])).strftime('%Y-%m-%d %H:%M:%S'))
description = parts[0]
data_list.append((utctimestamp, description))
if clean.startswith('reboot,factory_reset,'):
parts = clean.split(',')
utctimestamp = (datetime.datetime.utcfromtimestamp(int(parts[-1])).strftime('%Y-%m-%d %H:%M:%S'))
description = parts[0] + ' ' + parts[1]
data_list.append((utctimestamp, description))
if clean.startswith('reboot'):
parts = clean.split(',')
if len(parts) == 2:
utctimestamp = (datetime.datetime.utcfromtimestamp(int(parts[-1])).strftime('%Y-%m-%d %H:%M:%S'))
description = parts[0]
data_list.append((utctimestamp, description))
if data_list:
report = ArtifactHtmlReport('Persistent Properties')
report.start_artifact_report(report_folder, 'Persistent Properties')
report.add_script()
data_headers = ('Timestamp', 'Event')
report.write_artifact_data_table(data_headers, data_list, file_found)
report.end_artifact_report()
tsvname = f'Persistent Properties'
tsv(report_folder, data_headers, data_list, tsvname)
tlactivity = f'Persistent Properties'
timeline(report_folder, tlactivity, data_list, data_headers)
else:
logfunc('No Persistent Properties data available')
__artifacts__ = {
"persistentProp": (
"Wipe & Setup",
('*/property/persistent_properties'),
get_persistentProp)
}