mirror of
https://github.com/imayushsaini/Bombsquad-Ballistica-Modded-Server.git
synced 2025-10-20 00:00:39 +00:00
updating mods to api8
This commit is contained in:
parent
99cec14279
commit
ecc4d84189
86 changed files with 78858 additions and 1056 deletions
91
dist/ba_root/mods/tools/ServerUpdate.py
vendored
Normal file
91
dist/ba_root/mods/tools/ServerUpdate.py
vendored
Normal file
|
|
@ -0,0 +1,91 @@
|
|||
from playersData import pdata
|
||||
import time
|
||||
import _thread
|
||||
import urllib.request
|
||||
from efro.terminal import Clr
|
||||
import json
|
||||
import requests
|
||||
import _babase
|
||||
|
||||
VERSION = 71
|
||||
|
||||
|
||||
def check():
|
||||
|
||||
data = {'name': _babase.app.server._config.party_name,
|
||||
'port': str(_babase.get_game_port()),
|
||||
'build': _babase.app.build_number,
|
||||
'bcsversion': VERSION}
|
||||
_thread.start_new_thread(updateProfilesJson, ())
|
||||
_thread.start_new_thread(checkChangelog, ())
|
||||
_thread.start_new_thread(postStatus, (data,))
|
||||
|
||||
|
||||
def updateProfilesJson():
|
||||
profiles = pdata.get_profiles()
|
||||
|
||||
for id in profiles:
|
||||
if "spamCount" not in profiles[id]:
|
||||
profiles[id]["spamCount"] = 0
|
||||
profiles[id]["lastSpam"] = time.time()
|
||||
|
||||
pdata.commit_profiles(profiles)
|
||||
|
||||
|
||||
def postStatus(data):
|
||||
try:
|
||||
res = requests.post('https://bcsservers.ballistica.workers.dev/ping',
|
||||
json=data)
|
||||
except:
|
||||
pass
|
||||
|
||||
|
||||
def checkSpammer(data):
|
||||
def checkMaster(data):
|
||||
try:
|
||||
res = requests.post('https://bcsservers.ballistica.workers.dev/checkspammer',
|
||||
json=data)
|
||||
except:
|
||||
pass
|
||||
# TODO handle response and kick player based on status
|
||||
_thread.start_new_thread(checkMaster, (data,))
|
||||
return
|
||||
|
||||
|
||||
def fetchChangelogs():
|
||||
url = "https://raw.githubusercontent.com/imayushsaini/Bombsquad-Ballistica-Modded-Server/public-server/dist/ba_root/mods/changelogs.json"
|
||||
|
||||
if 2*2 == 4:
|
||||
try:
|
||||
data = urllib.request.urlopen(url)
|
||||
changelog = json.loads(data.read())
|
||||
except:
|
||||
return None
|
||||
else:
|
||||
return changelog
|
||||
|
||||
|
||||
def checkChangelog():
|
||||
changelog = fetchChangelogs()
|
||||
if changelog == None:
|
||||
print(
|
||||
f'{Clr.BRED} UNABLE TO CHECK UPDATES , CHECK MANUALLY FROM URL {Clr.RST}', flush=True)
|
||||
else:
|
||||
msg = ""
|
||||
avail = False
|
||||
for log in changelog:
|
||||
if int(log) > VERSION:
|
||||
avail = True
|
||||
|
||||
if not avail:
|
||||
print(
|
||||
f'{Clr.BGRN}{Clr.WHT} YOU ARE ON LATEST VERSION {Clr.RST}', flush=True)
|
||||
else:
|
||||
print(f'{Clr.BYLW}{Clr.BLU} UPDATES AVAILABLE {Clr.RST}', flush=True)
|
||||
for log in changelog:
|
||||
if int(log) > VERSION:
|
||||
msg = changelog[log]["time"]
|
||||
print(f'{Clr.CYN} {msg} {Clr.RST}', flush=True)
|
||||
|
||||
msg = changelog[log]["log"]
|
||||
print(f'{Clr.MAG} {msg} {Clr.RST}', flush=True)
|
||||
Loading…
Add table
Add a link
Reference in a new issue