forked from 1053960054/HarbourToulu
-
Notifications
You must be signed in to change notification settings - Fork 0
/
jd_check_dependent.py
242 lines (231 loc) · 9.75 KB
/
jd_check_dependent.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
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
File: jd_check_dependent.py(Harbour库依赖一键检测安装(不可禁用)每2小时检测一次)
Author: HarbourJ
Date: 2022/8/12 20:37
TG: https://t.me/HarbourToulu
TgChat: https://t.me/HarbourSailing
cron: 0 0 */2 * * *
new Env('HarbourJ库依赖一键安装');
Description:1.HarbourToulu库jd_sign本地算法依赖一键检测安装脚本;
2.自动识别机器系统/架构,拉取最新依赖文件;
3.本地sign算法已编译支持Windows(amd64)、Linux(amd64/arm64/arm)、Macos(x86_64)系统/架构;
4.默认支持python3版本为3.8-3.10,过低可能会报错;
5.若本一键配置脚本无法安装所需jd_sign依赖文件,请前往https://github.com/HarbourJ/HarbourToulu/releases自行下载系统对应的jd_sign依赖压缩文件,解压并放置/scripts/HarbourJ_HarbourToulu_main文件夹内即可。
6.‼️‼️‼️初次拉库必须先运行本脚本‼️‼️‼️
"""
import sys
import requests, os, platform
from functools import partial
print = partial(print, flush=True)
def updateDependent():
"""
更新依赖的主函数
"""
system = platform.system().lower()
PyVersion_ = platform.python_version()
PyVersion = ''.join(PyVersion_.split('.')[:2])
if int(PyVersion) > 310:
print(f"✅识别本机设备Py版本为{PyVersion_},版本太高暂不支持,可退回青龙2.11.3版本!\n")
sys.exit()
if system == "windows":
fileName = f"jd_sign-win-amd64-py{PyVersion}.zip"
print(f"✅识别本机设备为Windows amd64,Py版本为{PyVersion_}\n")
rtu = signReleaseUpdate()
if rtu == 9:
sys.exit()
if rtu:
removeOldSign()
if download(rtu, fileName):
import zipfile
f = zipfile.ZipFile(fileName, 'r')
for file in f.namelist():
f.extract(file, os.getcwd())
f.close()
return True
elif system == "darwin":
fileName = f"jd_sign-darwin-x86_64-py{PyVersion}.tar.gz"
print(f"✅识别本机设备为MacOS x86_64,Py版本为{PyVersion_}\n")
rtu = signReleaseUpdate()
if rtu == 9:
sys.exit()
if rtu:
removeOldSign()
if download(rtu, fileName):
os.system(f'tar xvf {fileName}')
os.system(f'rm -rf {fileName}')
return True
else:
rtu = signReleaseUpdate()
if rtu == 9:
sys.exit()
if rtu:
removeOldSign()
framework = os.uname().machine
if framework == "x86_64":
fileName = f"jd_sign-linux-amd64-py{PyVersion}.tar.gz"
print(f"✅识别本机设备为Linux {framework},Py版本为{PyVersion_}\n")
if download(rtu, fileName):
os.system(f'tar xvf {fileName}')
os.system(f'rm -rf {fileName}')
return True
elif framework == "aarch64" or framework == "arm64":
fileName = f"jd_sign-linux-arm64-py{PyVersion}.tar.gz"
print(f"✅识别本机设备为Linux {framework},Py版本为{PyVersion_}\n")
check_ld_libc(rtu)
if download(rtu, fileName):
os.system(f'tar xvf {fileName}')
os.system(f'rm -rf {fileName}')
return True
elif framework == "armv7l":
fileName = f"jd_sign-linux-arm-py{PyVersion}.tar.gz"
print(f"✅识别本机设备为Linux {framework},Py版本为{PyVersion_}\n")
check_ld_libc(rtu)
if download(rtu, fileName):
os.system(f'tar xvf {fileName}')
os.system(f'rm -rf {fileName}')
return True
else:
fileName = f"jd_sign-linux-amd64-py{PyVersion}.tar.gz"
print(f"⚠️无法识别本机设备操作系统,默认本机设备为Linux x86_64,Py版本为{PyVersion_}\n")
if download(rtu, fileName):
os.system(f'tar xvf {fileName}')
os.system(f'rm -rf {fileName}')
return True
def check_ld_libc(version):
"""
检测是否存在ld-linux-aarch64.so.1、libc.musl-aarch64.so.1动态依赖文件
"""
if "ld-linux-aarch64.so.1" in (os.listdir('/lib')):
print("🗣已存在arm64-ld依赖\n")
pass
else:
if download(version, "ld-linux-aarch64.tar.gz"):
os.system('tar xvf ld-linux-aarch64.tar.gz')
os.system('cp ld-linux-aarch64.so.1 /lib')
if "ld-linux-aarch64.so.1" in (os.listdir('/lib')):
print("✅arm64-ld依赖安装完成~\n")
os.system('rm -rf ld-linux-aarch64.tar.gz')
os.system('rm -rf ld-linux-aarch64.so.1')
else:
print("❌arm64-ld依赖安装失败,请前往https://github.com/HarbourJ/HarbourToulu/blob/main/README.md,查看依赖安装教程\n")
if "libc.musl-aarch64.so.1" in (os.listdir('/lib')):
print("🗣已存在arm64-libc依赖\n")
pass
else:
if download(version, "libc.musl-aarch64.tar.gz"):
os.system('tar xvf libc.musl-aarch64.tar.gz')
os.system('cp libc.musl-aarch64.so.1 /lib')
if "libc.musl-aarch64.so.1" in (os.listdir('/lib')):
print("✅arm64-libc依赖安装完成~\n")
os.system('rm -rf libc.musl-aarch64.tar.gz')
os.system('rm -rf libc.musl-aarch64.so.1')
else:
print("❌arm64-libc依赖安装失败,请前往https://github.com/HarbourJ/HarbourToulu/blob/main/README.md,查看依赖安装教程\n")
def download(version, systemFile):
raw_url = f"https://ghproxy.com/https://github.com/HarbourJ/HarbourToulu/releases/download/{version}/{systemFile}"
try:
fileList = os.listdir()
if systemFile in fileList:
os.remove(systemFile)
except:
print(f"❌删除{fileList}失败\n")
try:
try:
import wget
except ImportError as e:
print(e)
if "No module" in str(e):
os.system("pip install wget")
import wget
wget.download(raw_url)
print(f"✅{systemFile}下载成功\n")
return True
except Exception as e:
print(e)
print(f"❌{systemFile}下载失败\n")
return False
def removeOldSign():
fileList = os.listdir()
if "jd_sign.so" in fileList:
try:
os.remove("jd_sign.so")
print("✅成功删除历史jd_sign依赖文件\n")
except:
pass
elif "jd_sign_x86.so" in fileList:
try:
os.remove("jd_sign_x86.so")
print("✅成功删除历史jd_sign依赖文件\n")
except:
pass
elif "jd_sign_arm64.so" in fileList:
try:
os.remove("jd_sign_arm64.so")
print("✅成功删除历史jd_sign依赖文件\n")
except:
pass
def signReleaseUpdate():
"""
判断Release内的主要文件是否更新(判断utils内版本更新log文件-signUpdateLog.log)
"""
GitAPI = "https://ghproxy.com/https://raw.githubusercontent.com/HarbourJ/HarbourToulu/main/utils/signUpdateLog.log"
# try:
headers = {
'accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
'accept-encoding': 'gzip, deflate, br',
'accept-language': 'zh-CN,zh;q=0.9',
'referer': 'https://github.com/HarbourJ/HarbourToulu/blob/main/jdCookie.py',
'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.0.0 Safari/537.36'
}
response = requests.request("GET", url=GitAPI, headers=headers, timeout=20)
if response.status_code == 200:
res = response.text.split('\n')
print(f'📝最新sign为 {res[-1]}版本\n')
new_version = res[-1].split(' v')[-1]
# 获取上一次检查所记录的version值
try:
with open('signUpdate.log', "r") as f0:
last_version = f0.read()
except Exception as e:
# print(e)
# 以log格式写入文件
with open("signUpdate.log", "w") as f1:
f1.write('')
last_version = ''
with open("signUpdate.log", "w") as f2:
f2.write(new_version)
if new_version != last_version:
print("⏰检测到依赖版本有更新,自动更新...\n")
return new_version
else:
print("📝检测到依赖版本无更新\n")
try:
from jd_sign import remote_redis
result = remote_redis(export_name="Test01", db_index=15)
print(f'🎉{result}\n')
print("✅依赖正常,退出程序")
return 9
except:
print("⏰依赖不正常,自动修复中...\n")
return new_version
else:
print(f'❌请求失败:{GitAPI}\n')
print(f'❌错误信息:{response.txt}\n')
return False
# except:
# print(f'❌请求URL失败:{GitAPI}\n')
# return False
def main():
updateDependent()
try:
from jd_sign import remote_redis
result = remote_redis(export_name="Test01", db_index=15)
print(f'🎉{result}\n')
if result:
print("✅依赖安装/更新完成")
except:
print("‼️依赖安装/更新失败,请前往https://github.com/HarbourJ/HarbourToulu/blob/main/README.md,查看依赖安装教程")
if __name__ == '__main__':
main()