mirror of
https://github.com/BOSWatch/BW3-Core.git
synced 2026-01-02 14:50:25 +01:00
implement fetching from online version
This commit is contained in:
parent
35c6de4c54
commit
185af05f99
71
boswatch/updater.py
Normal file
71
boswatch/updater.py
Normal file
|
|
@ -0,0 +1,71 @@
|
|||
#!/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:
|
||||
def __init__(self):
|
||||
self._url = "https://raw.githubusercontent.com/BOSWatch/BW3-Core/master/boswatch/version.py"
|
||||
self._clientVersion = None
|
||||
self._serverVersion = None
|
||||
self._date = None
|
||||
self._branch = None
|
||||
|
||||
def getVersion(self):
|
||||
logging.debug("check for updates")
|
||||
data = urllib.request.urlopen(self._url)
|
||||
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]
|
||||
|
||||
def checkVersion(self):
|
||||
if version.client["major"] < self._clientVersion["major"] or \
|
||||
version.client["minor"] < self._clientVersion["minor"] or \
|
||||
version.client["patch"] < self._clientVersion["patch"]:
|
||||
logging.info("There is a client update available: %d.%d.%d -> %d.%d.%d",
|
||||
version.client["major"], version.client["minor"], version.client["patch"],
|
||||
self._clientVersion["major"], self._clientVersion["minor"], self._clientVersion["patch"])
|
||||
|
||||
if version.server["major"] < self._serverVersion["major"] or \
|
||||
version.server["minor"] < self._serverVersion["minor"] or \
|
||||
version.server["patch"] < self._serverVersion["patch"]:
|
||||
logging.info("There is a server update available: %d.%d.%d -> %d.%d.%d",
|
||||
version.server["major"], version.server["minor"], version.server["patch"],
|
||||
self._serverVersion["major"], self._serverVersion["minor"], self._serverVersion["patch"])
|
||||
|
||||
|
||||
|
||||
Loading…
Reference in a new issue