forked from OwO-Network/Repo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
generate_json.py
96 lines (81 loc) · 3.07 KB
/
generate_json.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
'''
Author: Vincent Young
Date: 2023-10-06 05:43:37
LastEditors: Vincent Young
LastEditTime: 2023-10-06 05:47:41
FilePath: /OwO-Repo/generate_json.py
Telegram: https://t.me/missuo
Copyright © 2023 by Vincent, All Rights Reserved.
'''
from github import Github
import json
import argparse
import pandas as pd
from get_bundle_id import get_single_bundle_id
import os
import shutil
if __name__ == "__main__":
parser = argparse.ArgumentParser()
parser.add_argument("-t", "--token", help="Github token")
args = parser.parse_args()
token = args.token
out_file = "apps.json"
clone_file = "index.html"
with open(out_file, "r") as f:
data = json.load(f)
if os.path.exists("bundleId.csv"):
df = pd.read_csv("bundleId.csv")
else:
df = pd.DataFrame(columns=["name", "bundleId"])
# clear apps
data["apps"] = []
g = Github(token)
repo_name = "owo-network/Repo"
repo = g.get_repo(repo_name)
releases = repo.get_releases()
for release in releases:
print(release.title)
for asset in release.get_assets():
if not asset.name.endswith(".ipa"):
continue
name = asset.name[:-4]
date = asset.created_at.strftime("%Y-%m-%d")
full_date = asset.created_at.strftime("%Y%m%d%H%M%S")
try:
app_name, version, tweaks = name.split("_", 2)
tweaks, _ = tweaks.split("@", 1)
if tweaks:
tweaks = "Injected with " + tweaks[:-1].replace("_", " ")
except:
app_name = name
version = "Unknown"
tweaks = None
if app_name in df.name.values:
bundle_id = str(df[df.name == app_name].bundleId.values[0])
else:
bundle_id = get_single_bundle_id(asset.browser_download_url)
df = pd.concat([df, pd.DataFrame(
{"name": [app_name], "bundleId": [bundle_id]})], ignore_index=True)
data["apps"].append(
{
"name": app_name,
"realBundleID": bundle_id,
"bundleID": bundle_id,
"bundleIdentifier": bundle_id,
"version": version,
"versionDate": date,
"fullDate": full_date,
"size": asset.size,
"down": asset.browser_download_url,
"downloadURL": asset.browser_download_url,
"developerName": "",
"localizedDescription": tweaks,
"icon": f"https://raw.githubusercontent.com/{repo_name}/main/icons/{bundle_id}.png",
"iconURL": f"https://raw.githubusercontent.com/{repo_name}/main/icons/{bundle_id}.png"
}
)
data["apps"].sort(key=lambda x: x["fullDate"], reverse=True)
df.to_csv("bundleId.csv", index=False)
with open(out_file, 'w') as json_file:
json.dump(data, json_file, indent=4)
shutil.copyfile(out_file, clone_file)