X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/ae44eb36129b207e217c3dea05e9a5cad2194fd5..c20ffa09925ec21f3631e6f14f078f2f8b05be70:/forum_modules/updater/base.py diff --git a/forum_modules/updater/base.py b/forum_modules/updater/base.py index 44af2ea..c5bac16 100644 --- a/forum_modules/updater/base.py +++ b/forum_modules/updater/base.py @@ -13,10 +13,12 @@ import logging from xml.dom.minidom import parse, parseString +from forum.startup import get_database_engine from forum.models import Question, User -from forum.settings import APP_URL, SVN_REVISION +from forum.settings import APP_URL, SVN_REVISION, APP_TITLE, APP_DESCRIPTION from django import VERSION as DJANGO_VERSION from django.utils import simplejson +from django.utils.html import escape from django.utils.encoding import smart_unicode from django.conf import settings as django_settings from django.utils.translation import ugettext as _ @@ -36,6 +38,18 @@ def get_site_views(): return views +# Gets the active users count since the last visit +def get_active_users(): + users_count = 0 + + try: + if settings.LATEST_UPDATE_DATETIME: + users_count = User.objects.filter(last_login__gt=settings.LATEST_UPDATE_DATETIME).count() + except: + pass + + return users_count + def get_server_name(): url = '%s/' % APP_URL @@ -75,12 +89,16 @@ def check_for_updates(): admin_emails_xml += '' % email admin_emails_xml += '' + database_type = get_database_engine() + statistics = """ + + - + @@ -90,12 +108,15 @@ def check_for_updates(): """ % { 'site_key' : settings.SITE_KEY, 'app_url' : APP_URL, + 'app_title' : escape(APP_TITLE.value), + 'app_description' : escape(APP_DESCRIPTION.value), 'svn_revision' : svn_revision, 'site_views' : get_site_views(), 'server_name' : get_server_name(), + 'active_users' : get_active_users(), 'python_version' : ''.join(sys.version.splitlines()), 'django_version' : str(DJANGO_VERSION), - 'database' : django_settings.DATABASE_ENGINE, + 'database' : database_type, 'os' : str(os.uname()), 'emails' : admin_emails_xml, } @@ -137,6 +158,10 @@ def check_for_updates(): messages_dom = parseString(messages_xml) messages_count = len(messages_dom.getElementsByTagName('message')) + # Set the latest update datetime to now. + now = datetime.datetime.now() + settings.LATEST_UPDATE_DATETIME.set_value(now) + return _('%d update messages have been downloaded.') % messages_count def update_trigger(): @@ -146,6 +171,4 @@ def update_trigger(): update_status = check_for_updates() logging.error(smart_unicode("Update process has been triggered: %s" % update_status)) - - # Set the latest update datetime to now. settings.LATEST_UPDATE_DATETIME.set_value(now)