##// END OF EJS Templates
Added tag v5.3.1 for changeset bd23a920e83f
Added tag v5.3.1 for changeset bd23a920e83f

File last commit:

r5553:b90185f7 default
r5570:65455dcb stable
Show More
update.py
83 lines | 3.0 KiB | text/x-python | PythonLexer
copyrights: updated for 2023
r5088 # Copyright (C) 2013-2023 RhodeCode GmbH
update: add new async task to check for updates via scheduler....
r2431 #
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License, version 3
# (only), as published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
# This program is dual-licensed. If you wish to learn more about the
# RhodeCode Enterprise Edition, including its added features, Support services,
# and proprietary license terms, please see https://rhodecode.com/licenses/
import logging
models: major update for python3,...
r5070 import urllib.request
import urllib.error
import urllib.parse
update: sanitize version, and check for version parsing exc
r2434 from packaging.version import Version
update: add new async task to check for updates via scheduler....
r2431
import rhodecode
from rhodecode.lib.ext_json import json
from rhodecode.model import BaseModel
from rhodecode.model.meta import Session
from rhodecode.model.settings import SettingsModel
log = logging.getLogger(__name__)
class UpdateModel(BaseModel):
UPDATE_SETTINGS_KEY = 'update_version'
UPDATE_URL_SETTINGS_KEY = 'rhodecode_update_url'
@staticmethod
def get_update_data(update_url):
"""Return the JSON update data."""
ver = rhodecode.__version__
log.debug('Checking for upgrade on `%s` server', update_url)
python3: fix urllib usage
r4914 opener = urllib.request.build_opener()
chore(code): small code improvements logging & stricter header checks
r5553 opener.addheaders = [('User-agent', f'RhodeCode-SCM/{ver.strip()}')]
update: add new async task to check for updates via scheduler....
r2431 response = opener.open(update_url)
response_data = response.read()
data = json.loads(response_data)
log.debug('update server returned data')
return data
def get_update_url(self):
settings = SettingsModel().get_all_settings()
return settings.get(self.UPDATE_URL_SETTINGS_KEY)
def store_version(self, version):
log.debug('Storing version %s into settings', version)
setting = SettingsModel().create_or_update_setting(
self.UPDATE_SETTINGS_KEY, version)
Session().add(setting)
Session().commit()
automation: enabled automated check for new versions.
r4634 def get_stored_version(self, fallback=None):
update: add new async task to check for updates via scheduler....
r2431 obj = SettingsModel().get_setting_by_name(self.UPDATE_SETTINGS_KEY)
if obj:
return obj.app_settings_value
automation: enabled automated check for new versions.
r4634 return fallback or '0.0.0'
update: add new async task to check for updates via scheduler....
r2431
update: sanitize version, and check for version parsing exc
r2434 def _sanitize_version(self, version):
"""
Cleanup our custom ver.
e.g 4.11.0_20171204_204825_CE_default_EE_default to 4.11.0
"""
return version.split('_')[0]
update: add new async task to check for updates via scheduler....
r2431 def is_outdated(self, cur_version, latest_version=None):
latest_version = latest_version or self.get_stored_version()
update: sanitize version, and check for version parsing exc
r2434 try:
cur_version = self._sanitize_version(cur_version)
return Version(latest_version) > Version(cur_version)
except Exception:
# could be invalid version, etc
return False