-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathprobe.py
More file actions
83 lines (75 loc) · 1.86 KB
/
probe.py
File metadata and controls
83 lines (75 loc) · 1.86 KB
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
import xml.etree.ElementTree as ET
import base64
import hashlib
import struct
def getData(fn):
tree = ET.parse(fn)
root = tree.getroot()
node = root.find("./string[@name='SAVE_DATA']")
return base64.b64decode(node.text)
fn = ["save.xml"]
n = len(fn)
d = []
for i in xrange(n):
d.append(getData(fn[i]))
print "len(d[%d]) = %d" % (i, len(d[i]))
def findExact(x, dtype):
for i in xrange(len(d[0]) - 32):
flag = True
for j in xrange(n):
if x[j] != struct.unpack_from(dtype, d[j], i)[0]:
flag = False
break
if flag:
print i
def findSeries(x, dtype):
for i in xrange(len(d[0]) - 32):
flag = True
for j in xrange(len(x)):
if x[j] != struct.unpack_from(dtype, d[0], i + 4 * j)[0]:
flag = False
break
if flag:
print i
def findDiff():
for i in xrange(len(d[0]) - 32):
flag = True
for j in xrange(1, n):
if ord(d[0][i]) != ord(d[j][i]):
flag = False
break
if not flag:
print i,
for j in xrange(n):
print "%3d" % ord(d[j][i]),
print
def p(i, j, s, e):
for x in xrange(s, e):
print x,
for y in xrange(i, j):
print ord(d[y][x]),
print
print "catfood"
findSeries([1086], ">L")
print "exp"
findSeries([186397], ">L")
print "fruit storage"
findSeries([12, 13, 12], ">L")
print "unit storage"
findSeries([200, 200], ">L")
print "eyes"
findSeries([8, 3, 24, 30], ">L")
print "item"
findSeries([17, 104, 43], ">L")
"""
p(7, 11)
p(75, 79)
p(8368, 8372)
p(8364, 8368)
p(104154, 104158)
signature = d0[-32:]
hashed = hashlib.md5("battlecatskr"+d0[:-32]).hexdigest()
print "Signature: ", signature
print "Signature: ", d1[-32:]
print "Computed : ", hashed
"""