forked from HoraceAndTheSpider/Amiberry-XML-Builder
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathopenretroid.py
131 lines (95 loc) · 3.75 KB
/
openretroid.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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
import hashlib
import json
import os
import posixpath
import urllib
import uuid
import lhafile
ROOT_DIR = os.path.dirname(__file__)
HDD_PREFIX = 'DH0'
VARIANT_PREFIX = ['WHDLoad']
SHA1_URL = 'http://sha1.fengestad.no/'
#
# all credit for this module goes to Olly Ainger
# i did nothing here
#
def generate_variant_uuid(file_sha1s):
file_sha1s_joined = "/".join(sorted(file_sha1s))
sha1_url = SHA1_URL + file_sha1s_joined
return str(uuid.uuid5(uuid.NAMESPACE_URL, str(sha1_url)))
def get_file_metadata(archive, file):
metadata = {}
if file.comment:
metadata['comment'] = file.comment
file_name = file.filename.replace(os.path.sep, posixpath.sep)
metadata['name'] = posixpath.join(HDD_PREFIX, file_name)
if not metadata['name'].endswith(posixpath.sep):
data = archive.read(file.filename)
metadata['sha1'] = get_sha1(data)
metadata['size'] = len(data)
return metadata
def read_archive(file_path):
files_metadata = []
archive = lhafile.lhafile.LhaFile(file_path)
files_to_scan = []
for archived_file in archive.infolist():
# Only read the folders in the archive
if not os.path.sep in archived_file.filename:
continue
# Exclude '*.info' files
if archived_file.filename.lower().endswith('.info'):
continue
files_to_scan.append(archived_file)
for archived_file in files_to_scan:
file_metadata = get_file_metadata(archive, archived_file)
files_metadata.append(file_metadata)
files_metadata = sorted(files_metadata, key=lambda x: x['name'])
return files_metadata
def get_dh0_sha1(files_metadata):
json_dumps = json.dumps(files_metadata)
return get_sha1(json_dumps.encode())
def get_sha1(data):
return hashlib.sha1(data).hexdigest()
def parse_file(file_path):
if file_path.lower().endswith('.lha'):
with open(file_path, 'rb') as archive_file:
lha_sha1 = get_sha1(archive_file.read())
files_metadata = read_archive(file_path)
file_sha1s = []
for file in files_metadata:
if not file.get('sha1'):
continue
file_sha1s.append(file['sha1'])
variant_uuid = generate_variant_uuid(file_sha1s)
dh0_sha1 = get_dh0_sha1(files_metadata)
filename = os.path.basename(file_path)
_, *variant_parts = os.path.splitext(filename)[0].split('_')
archive_metadata = {
'uuid': variant_uuid,
'filename': filename,
'variant_name': ', '.join(VARIANT_PREFIX + variant_parts),
'sha1': lha_sha1,
'files': files_metadata,
'dh0_sha1': dh0_sha1,
}
return archive_metadata
def traverse_directory(directory):
print('Processing Directory: {}'.format(directory))
lha_files_metadata = []
for item in os.listdir(directory):
item_path = os.path.join(directory, item)
if os.path.isdir(item_path):
lha_files_metadata = lha_files_metadata + \
traverse_directory(item_path)
if os.path.isfile(item_path):
parse_result = parse_file(item_path)
if parse_result:
lha_files_metadata.append(parse_result)
return lha_files_metadata
if __name__ == '__main__':
print('Hi Dom, here is a demo of the OpenRetro Variant UUID Generator')
file = './Speedball_v2.0_0581.lha'
print('Getting details for file: {}'.format(file))
file_details = parse_file(file)
print("Variant UUID: {}".format(file_details['uuid']))
print("Openretro URL: http://www.openretro.org/game/{}".format(file_details['uuid']))