diff --git a/.gitignore b/.gitignore index 3063fa0..df345ea 100644 --- a/.gitignore +++ b/.gitignore @@ -75,4 +75,5 @@ CMakeLists.txt.user* #pyproject *.pyproject *.pyproject.user -*.ui \ No newline at end of file +*.ui +settings.json \ No newline at end of file diff --git a/hlna.py b/hlna.py index ec84cb2..288e02c 100755 --- a/hlna.py +++ b/hlna.py @@ -508,39 +508,39 @@ WantedBy=default.target @click.argument('id_mods_ark', nargs=-1) def mod(g, m, i, id_mods_ark): if g == "ark": - id_game_workshop = "346110" if not os.path.isdir(dir_mods_ark): create_dir(dir_mods_ark) id_mods_ark = id_mods_ark[0].split(',') for id_mod in id_mods_ark: - dir_ark_mods = f"{dir_mods_ark}/{id_mod}" - if not os.path.isfile(f"{dir_ark_mods}.mod"): + dir_mod_ark = f"{dir_mods_ark}/{id_mod}" + if not os.path.isfile(f"{dir_mod_ark}.mod"): + print_line(f"{dir_mod_ark}.mod") if i: - moddownload(id_mod, id_game_workshop, dir_ark_mods) + moddownload(id_mod,dir_mod_ark) else: - os.system(f"rm -rf {dir_ark_mods}") - print_line(f"{dir_ark_mods} удалён") + os.system(f"rm -rf {dir_mod_ark}") + print_line(f"{dir_mod_ark} удалён") os.system(f"rm {dir_mods_ark}/{id_mod}.mod") print_line(f"{dir_mods_ark}/{id_mod}.mod удалён") - os.system(f"mv {dir_workshop_ark}/appworkshop_{id_game_workshop}.acf {dir_ark_mods}/appworkshop_{id_game_workshop}.acf") else: - modupdate(g, m, id_mod, dir_ark_mods) + modupdate(g, m, id_mod, dir_mod_ark) + else: + print_line("Не поддерживаемая игра") -def modupdate(g, m, id_mod, dir_ark_mods): +def modupdate(g, m, id_mod, dir_mod_ark): if g == "ark": - if not os.path.isfile(os.path.join(dir_ark_mods, f"appworkshop_{id_mod}.acf")): - return - with open(os.path.join(dir_ark_mods, f"appworkshop_{id_mod}.acf"), "r") as f: + # if not os.path.isfile(os.path.join(dir_ark_mods, f"appworkshop_{id_mod}.acf")): + # return + with open(os.path.join(dir_mod_ark, f"appworkshop_346110.acf"), "r") as f: content = f.readlines() content = "".join(content) locale_date = "" - - for line in content.split("\n"): + for line in content.splitlines(): if '\t"WorkshopItemsInstalled"' in line: - for line in content.split("\n"): - if f'\t\t"{id_mod}"' in line: - locale_date = line.split('"')[5] + for line in content.splitlines(): + if f'\t\t"timeupdated"' in line: + locale_date = line.split('"')[3] if '}' in line: break break @@ -553,82 +553,92 @@ def modupdate(g, m, id_mod, dir_ark_mods): json_zapros = zapros.json() steam_date = json_zapros['response']['publishedfiledetails'][0]['time_updated'] - if steam_date and locale_date == steam_date: - return + if int(steam_date) != int(locale_date): + moddownload(g, m, id_mod, dir_mod_ark) + else: + print_line(f"Мод {id_mod} обновлен") - if steam_date and locale_date != steam_date: - print_line("хз") -def modupdateall(): +def modupdateall(g, m): + print_line("Вход в обновление всех") for file in os.listdir(dir_mods_ark): if os.path.isfile(os.path.join(dir_mods_ark, file)): if file.endswith('.mod'): - print(file) + id_mod = file.split(".")[0] + if id_mod == "111111111": + continue + dir_mod_ark = f"{dir_mods_ark}/{id_mod}" + modupdate(g, m, id_mod, dir_mod_ark) -def moddownload(id_mod, id_game_workshop, dir_ark_mods): +def moddownload(g, m, id_mod, dir_mod_ark): """Распаковывает файлы мода и создаёт .mod файл для него""" - dir_steam_workshop = f"{dir_workshop_ark}/content/{id_game_workshop}/{id_mod}/WindowsNoEditor" - dir_extract = dir_ark_mods - if id_mod == "111111111": - return - os.system(f"steamcmd +login anonymous +workshop_download_item {id_game_workshop} {id_mod} +quit") - try: - for curdir, subdirs, files in os.walk(os.path.join(dir_steam_workshop)): - for file in files: - name, ext = os.path.splitext(file) - if ext == ".z": - src = os.path.join(curdir, file) - dst = os.path.join(curdir, name) - uncompressed = os.path.join(curdir, file + ".uncompressed_size") - unpack(src, dst) - print("[+] Extracted " + file) - os.remove(src) - if os.path.isfile(uncompressed): - os.remove(uncompressed) - except Exception as e: - print(e) - print("[x] Unpacking .z files failed, aborting mod install") - return False + if g == "ark": + id_game_workshop = "346110" + dir_steam_workshop = f"{dir_workshop_ark}/content/{id_game_workshop}/{id_mod}/WindowsNoEditor" + dir_extract = dir_mod_ark + if id_mod == "111111111": + return + if os.path.isfile(f"{dir_workshop_ark}/appworkshop_{id_game_workshop}.acf"): + os.system(f"rm {dir_workshop_ark}/appworkshop_{id_game_workshop}.acf") + os.system(f"steamcmd +login anonymous +workshop_download_item {id_game_workshop} {id_mod} +quit") + try: + for curdir, subdirs, files in os.walk(os.path.join(dir_steam_workshop)): + for file in files: + name, ext = os.path.splitext(file) + if ext == ".z": + src = os.path.join(curdir, file) + dst = os.path.join(curdir, name) + uncompressed = os.path.join(curdir, file + ".uncompressed_size") + unpack(src, dst) + print("[+] Extracted " + file) + os.remove(src) + if os.path.isfile(uncompressed): + os.remove(uncompressed) + except Exception as e: + print(e) + print("[x] Unpacking .z files failed, aborting mod install") + return False - os.system(f"rm -rf {dir_ark_mods}") - os.system(f"mv -f {dir_steam_workshop} {dir_ark_mods}") + os.system(f"rm -rf {dir_mod_ark}") + os.system(f"mv -f {dir_steam_workshop} {dir_mod_ark}") - modname = subprocess.check_output( - ['curl', '-s', f'https://steamcommunity.com/sharedfiles/filedetails/?id={id_mod}']).decode('utf-8') - modname = re.search(r'
7777
")) - self.label_2.setText(_translate("MainWindow", "Порт")) - self.label_3.setText(_translate("MainWindow", "Querry порт")) - self.textEdit_3.setHtml(_translate("MainWindow", "\n" + self.label_2.setText(_translate("mainWindow", "Порт")) + self.label_3.setText(_translate("mainWindow", "Querry порт")) + self.textEdit_3.setHtml(_translate("mainWindow", "\n" "\n" "27015
")) - self.textEdit_4.setHtml(_translate("MainWindow", "\n" + self.textEdit_4.setHtml(_translate("mainWindow", "\n" "\n" "27042
")) - self.label_4.setText(_translate("MainWindow", "Rcon порт")) - self.label_5.setText(_translate("MainWindow", "Пароль сессии")) - self.label_6.setText(_translate("MainWindow", "Пароль администратора")) - self.label_7.setText(_translate("MainWindow", "Количество игроков")) - self.checkBox.setText(_translate("MainWindow", "Передавать в глобальный список серверов")) - self.groupBox_2.setTitle(_translate("MainWindow", "ini")) - self.tabWidget_2.setTabText(self.tabWidget_2.indexOf(self.tab_5), _translate("MainWindow", "Tab 1")) - self.tabWidget_2.setTabText(self.tabWidget_2.indexOf(self.tab_6), _translate("MainWindow", "Tab 2")) - self.tabWidget.setTabText(self.tabWidget.indexOf(self.tab), _translate("MainWindow", "ARK")) - self.label_8.setText(_translate("MainWindow", "Имя сессии")) - self.textEdit_9.setHtml(_translate("MainWindow", "\n" + self.label_4.setText(_translate("mainWindow", "Rcon порт")) + self.label_5.setText(_translate("mainWindow", "Пароль сессии")) + self.label_6.setText(_translate("mainWindow", "Пароль администратора")) + self.label_7.setText(_translate("mainWindow", "Количество игроков")) + self.checkBox.setText(_translate("mainWindow", "Передавать в глобальный список серверов")) + self.groupBox_2.setTitle(_translate("mainWindow", "ini")) + self.tabWidget_2.setTabText(self.tabWidget_2.indexOf(self.tab_5), _translate("mainWindow", "Tab 1")) + self.tabWidget_2.setTabText(self.tabWidget_2.indexOf(self.tab_6), _translate("mainWindow", "Tab 2")) + self.tabWidget.setTabText(self.tabWidget.indexOf(self.tab), _translate("mainWindow", "ARK")) + self.label_8.setText(_translate("mainWindow", "Имя сессии")) + self.textEdit_9.setHtml(_translate("mainWindow", "\n" "\n" "