BW3-Core/boswatch/updater.py

86 lines
3.6 KiB
Python
Raw Permalink Normal View History

2019-03-08 09:05:20 +01:00
#!/usr/bin/python
# -*- coding: utf-8 -*-
"""!
____ ____ ______ __ __ __ _____
/ __ )/ __ \/ ___/ | / /___ _/ /______/ /_ |__ /
/ __ / / / /\__ \| | /| / / __ `/ __/ ___/ __ \ /_ <
/ /_/ / /_/ /___/ /| |/ |/ / /_/ / /_/ /__/ / / / ___/ /
/_____/\____//____/ |__/|__/\__,_/\__/\___/_/ /_/ /____/
German BOS Information Script
by Bastian Schroll
@file: updater.py
@date: 08.03.2019
@author: Bastian Schroll
@description: Class for a BOSWatch automated updates
"""
import logging
import urllib.request
import re
from boswatch import version
logging.debug("- %s loaded", __name__)
class Updater:
2019-03-11 22:04:19 +01:00
def __init__(self, branch):
2019-03-08 09:05:20 +01:00
self._clientVersion = None
self._serverVersion = None
self._date = None
2019-03-11 22:04:19 +01:00
self._branch = branch
2019-03-08 09:05:20 +01:00
2019-03-11 22:04:19 +01:00
def _getOnlineVersion(self):
data = urllib.request.urlopen("https://raw.githubusercontent.com/BOSWatch/BW3-Core/" + self._branch + "/boswatch/version.py")
2019-03-08 09:05:20 +01:00
for line in data:
content = str(line, "utf8")
if "client = " in content:
data = re.findall("(\d+)", content)
self._clientVersion = {"major": int(data[0]), "minor": int(data[1]), "patch": int(data[2])}
if "server = " in content:
data = re.findall("(\d+)", content)
self._serverVersion = {"major": int(data[0]), "minor": int(data[1]), "patch": int(data[2])}
if "date = " in content:
data = re.findall("(\d+)", content)
self._date = {"day": int(data[0]), "month": int(data[1]), "year": int(data[2])}
if "branch = " in content:
data = re.findall("(?:branch)(?:[ =\"]+)(\w*)", content)
self._branch = data[0]
2019-03-11 22:04:19 +01:00
def checkClientUpdate(self):
logging.debug("checking for client update")
self._getOnlineVersion()
2019-03-08 09:05:20 +01:00
if version.client["major"] < self._clientVersion["major"] or \
version.client["minor"] < self._clientVersion["minor"] or \
version.client["patch"] < self._clientVersion["patch"]:
2019-03-11 22:04:19 +01:00
logging.info("There is a client update from available: %d.%d.%d (%d.%d.%d) -> %d.%d.%d (%d.%d.%d)",
2019-03-08 09:05:20 +01:00
version.client["major"], version.client["minor"], version.client["patch"],
2019-03-11 22:04:19 +01:00
version.date["day"], version.date["month"], version.date["year"],
self._clientVersion["major"], self._clientVersion["minor"], self._clientVersion["patch"],
self._date["day"], self._date["month"], self._date["year"])
return False
else:
logging.debug("client is up to date")
return True
2019-03-08 09:05:20 +01:00
2019-03-11 22:04:19 +01:00
def checkServerUpdate(self):
logging.debug("checking for server update")
self._getOnlineVersion()
2019-03-08 09:05:20 +01:00
if version.server["major"] < self._serverVersion["major"] or \
version.server["minor"] < self._serverVersion["minor"] or \
version.server["patch"] < self._serverVersion["patch"]:
2019-03-11 22:04:19 +01:00
logging.info("There is a server update from %d.%d.%d available: %d.%d.%d -> %d.%d.%d",
version.date["day"], version.date["month"], version.date["year"],
2019-03-08 09:05:20 +01:00
version.server["major"], version.server["minor"], version.server["patch"],
self._serverVersion["major"], self._serverVersion["minor"], self._serverVersion["patch"])
2019-03-11 22:04:19 +01:00
return False
else:
logging.debug("server is up to date")
return True
2019-03-08 09:05:20 +01:00
2019-03-11 22:04:19 +01:00
def doUpdate(self):
pass