-
-
Notifications
You must be signed in to change notification settings - Fork 291
/
1.init.py
188 lines (153 loc) · 5.35 KB
/
1.init.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
import os
import re
import shutil
from zipfile import ZipFile
import requests
import urllib3
from settings import (
BASE_FOLDER,
USE_PROXY,
PROXIES,
VERSION_INFO_OVERRIDE,
force_version_info,
VERSION_INFO_OVERRIDE_BETA,
force_version_info_beta,
)
import zipfile
# disable warning if we use proxy
urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
CLIENT_FOLDER = BASE_FOLDER + 'TriliumNext Notes-linux-x64'
REPO_NAME = 'TriliumNext/Notes'
# regex match which file to download if multiple files exists
PREFERRED_RELEASE_NAME_PATTERN = 'TriliumNextNotes-.*?-linux-x64.zip'
SOURCE_CODE_NAME_PATTERN = 'TriliumNextNotes-.*?-linux-x64.zip'
CMD_STOP_SERVICE = """pkill -9 trilium"""
# 是否从GitHub下载文件
# whether download files from GitHub
DO_DOWNLOAD = True
# 是否删除临时文件
# whether delete template files
# DO_DELETE = False
DO_DELETE = True
def requests_get(url):
ret = None
try:
ret = requests.get(url, proxies=PROXIES, verify=not USE_PROXY)
except Exception as e:
print(
'If github is not available, you can set USE_PROXY to True and set PROXIES to your proxy.'
)
print('Exception', e)
return ret
def get_latest_version():
"""get latest version info"""
print('get latest version info')
url = f'https://api.github.com/repos/{REPO_NAME}/releases/latest'
print(url)
res = requests_get(url)
version_info = {}
# zipball_url is the source code
version_info['zipball_url'] = res.json()['zipball_url']
version_info['name'] = res.json()['name']
for x in res.json()['assets']:
if not re.match(PREFERRED_RELEASE_NAME_PATTERN, x['name']):
continue
version_info['browser_download_url'] = x['browser_download_url']
break
if 'browser_download_url' not in version_info:
print(
'Did not find a matching release! Please check file name and modify PREFERRED_RELEASE_NAME_PATTERN.'
)
exit()
print(f'latest version is {version_info["name"]}')
return version_info
def backup_old_service():
backup_suffix = '_old'
backup_dir = CLIENT_FOLDER + backup_suffix
if os.path.exists(backup_dir):
shutil.rmtree(backup_dir)
os.mkdir(backup_dir)
if os.path.exists(CLIENT_FOLDER):
os.system(f'mv "{CLIENT_FOLDER}" "{CLIENT_FOLDER}{backup_suffix}"')
print(f'old version is moved to "{CLIENT_FOLDER}{backup_suffix}"')
def download_file(url, file_name=None):
"""download file"""
print('download file')
if not file_name:
file_name = url.split('/')[-1]
print('downloading ...')
if DO_DOWNLOAD:
with requests.get(url, proxies=PROXIES, verify=False, stream=True) as r:
r.raise_for_status()
with open(file_name, 'wb') as f:
for chunk in r.iter_content(chunk_size=8192):
f.write(chunk)
print(f'download complete, file saved as {file_name}')
return file_name
def stop_service():
if CMD_STOP_SERVICE:
os.system(CMD_STOP_SERVICE)
def clean_cache():
os.system('rm -rf ~/.config/TriliumNext Notes/Cache/')
os.system('rm -rf ~/.config/TriliumNext Notes/Code Cache/')
os.system('rm -rf ~/.config/TriliumNext Notes/GPUCache/')
def decompress_package(file_name):
print(f'decompress {file_name}')
if file_name.endswith('tar.xz'):
try:
os.system(f'xz -d {file_name}')
except:
pass
os.system(f'tar -xf {file_name[:-3]}')
if DO_DELETE:
os.system(f'rm -f {file_name[:-3]}')
if file_name.endswith('.zip'):
decompress_source_package(file_name)
def decompress_source_package(file_name):
if file_name.endswith('.zip'):
with ZipFile(file_name, 'r') as zip:
# printing all the contents of the zip file
extracted_folder = zip.namelist()[0].split('/')[0]
if extracted_folder:
os.system(f'unzip -o {file_name}')
os.system('pwd')
if DO_DELETE:
os.system(f'rm -rf trilium-src.zip')
print(extracted_folder)
os.system(f'mv {extracted_folder} trilium-src')
if __name__ == '__main__':
if os.path.exists(BASE_FOLDER):
if not (input(f'BASE_FOLDER exists! DELETE {BASE_FOLDER}, continue?(y)')).lower() in [
'y',
'yes',
]:
exit()
os.system(f'rm -rf {BASE_FOLDER}')
os.makedirs(BASE_FOLDER)
print('BASE_FOLDER', BASE_FOLDER)
os.chdir(BASE_FOLDER)
if VERSION_INFO_OVERRIDE:
if VERSION_INFO_OVERRIDE_BETA:
version_info = force_version_info_beta
else:
version_info = force_version_info
else:
version_info = get_latest_version()
print(version_info)
stop_service()
# 翻译不生效可以尝试删除缓存
# If the translation doesn't work, clean the cache files may help
clean_cache()
# backup_old_service()
# 下载release
# get release file
file_name = download_file(version_info['browser_download_url'])
print(f'file_name {file_name}')
decompress_package(file_name)
# 下载源码
# get source code
file_name = download_file(version_info['zipball_url'], 'trilium-src.zip')
file_name = 'trilium-src.zip'
print(f'file_name {file_name}')
decompress_source_package(file_name)
print('finished!')