view jabberbot/ @ 5206:64854adb52fc

add Expires header with now + 10 seconds for AttachFile do=get and do=box User's browser shall usually request the wiki content as it might change fast. It'll either get a 200 OK response with the content, or (if content was not modified) a 304 NOT MODIFIED response. Without the Expires header, browser does not request the content (I guess it uses some builtin heuristics then to determine when to do a request, and that that might be much too slow for fast changing wikis).
author Thomas Waldmann <tw AT waldmann-edv DOT de>
date Sat, 10 Oct 2009 15:54:36 +0200
parents 6f06c7d051a4
children b397401dda7f
line wrap: on
line source
# -*- coding: iso-8859-1 -*-
    MoinMoin - jabber bot i18n routines

    @copyright: 2007 by Karol Nowak <>
    @license: GNU GPL, see COPYING for details.
import logging, xmlrpclib
from jabberbot.config import BotConfig


def get_text(original, lang="en"):
    """ Return a translation of text in the user's language.

        @type original: unicode
    if original == u"":
        return u""

    if not TRANSLATIONS:

        return TRANSLATIONS[lang][original]
    except KeyError:
        return original

def init_i18n(config):
    """Prepare i18n

    @type config: jabberbot.config.BotConfig

    TRANSLATIONS = request_translations(config) or {'en': {}}

def request_translations(config):
    """Download translations from wiki using xml rpc

    @type config: jabberbot.config.BotConfig


    wiki = xmlrpclib.Server(config.wiki_url + "?action=xmlrpc2")
    log = logging.getLogger(__name__)
    log.debug("Initialising i18n...")

        translations =  wiki.getBotTranslations()
        return translations
    except xmlrpclib.Fault, fault:
        log.error("XML RPC fault occured while getting translations: %s" % (str(fault), ))
    except xmlrpclib.Error, error:
        log.error("XML RPC error occured while getting translations: %s" % (str(error), ))
    except Exception, exc:
        log.error("Unexpected exception occured while getting translations: %s" % (str(exc), ))

    log.error("Translations could not be downloaded, is wiki is accesible?")
    return None