-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathextr_jpegsnoop.py
executable file
·99 lines (88 loc) · 3.55 KB
/
extr_jpegsnoop.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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
'''
Crude script to read Signatures.inl from JPEGsnoop and produce a python dict.
It is a good idea to run it through "black" source formatter afterwards.
A dict like this is produced of the JPEGsnoop data:
sigs = {
"010024c0f1734b148ceccd76ee92d9a1": [
{
"eEditor": "ENUM_EDITOR_SW",
"strCSigRot": "01e80b819244db40bc79151703625e2f",
"strMSwDisp": "Apple ImageIO.framework",
"strMSwTrim": "",
"strUmQual": "054",
"strXMake": "Apple ImageIO.framework",
"strXModel": "",
"strXSubsamp": "",
}
],
"0100e9aa36415d0482e7ad68eaf372c3": [
{
"eEditor": "ENUM_EDITOR_CAM",
"strCSigRot": "012840f1b30da4789a3345257eeb59c9",
"strMSwDisp": "",
"strMSwTrim": "",
"strUmQual": "FINE",
"strXMake": "NIKON",
"strXModel": "E4800",
"strXSubsamp": "2x1",
},
{
"eEditor": "ENUM_EDITOR_CAM",
"strCSigRot": "012840f1b30da4789a3345257eeb59c9",
"strMSwDisp": "",
"strMSwTrim": "",
"strUmQual": "",
"strXMake": "OLYMPUS IMAGING CORP.",
"strXModel": "SP310",
"strXSubsamp": "2x1",
},
],
}
'''
import re
import sys
from pprint import pprint
def extract_data():
column_names = ['eEditor', 'strXMake', 'strXModel', 'strUmQual', 'strCSig', 'strCSigRot', 'strXSubsamp', 'strMSwTrim', 'strMSwDisp']
data = {}
for line in sys.stdin:
# Check if line contains an MD5 hash
if re.search(r'[a-fA-F0-9]{32}', line):
# Extract the first constant and all "_T" strings
constants = re.findall(r'\b[A-Z_]+\b', line)
_T_strings = re.findall(r'_T\("([^"]*)"\)', line)
# Check if there are enough "_T" strings
if len(_T_strings) >= len(column_names) - 1:
# Create a dictionary for this line
line_data = {column_names[0]: constants[0]}
for i in range(1, len(column_names)):
if column_names[i] == 'strCSig' or column_names[i] == 'strCSigRot':
line_data[column_names[i]] = _T_strings[i-1].lower()
else:
line_data[column_names[i]] = _T_strings[i-1]
# Add the line data to the main data dictionary using strCSig as key
strCSig = _T_strings[column_names.index('strCSig')-1].lower()
if re.match(r'[a-f0-9]{32}', strCSig):
line_data_csig = line_data.copy()
line_data_csig.pop('strCSig', None)
if strCSig in data:
data[strCSig].append(line_data_csig)
else:
data[strCSig] = [line_data_csig]
# Add the line data to the main data dictionary using strCSigRot as key
strCSigRot = _T_strings[column_names.index('strCSigRot')-1].lower()
if re.match(r'[a-f0-9]{32}', strCSigRot):
line_data_rot = line_data.copy()
line_data_rot.pop('strCSigRot', None)
if strCSigRot in data:
data[strCSigRot].append(line_data_rot)
else:
data[strCSigRot] = [line_data_rot]
return data
# Use the function
pprint(extract_data())
#data = extract_data()
#print("len: ", len(data))
#pprint(data['01BBB1709AC9C1F89220D955A31A8F34'.lower()])
#for key in data.keys():
# print(key)