Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/lib/server/flask/_app.py
blob: f4b8096423af552b8029f277b238e8f9290c557e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
# python import
import os, logging

# common gettext import
from gettext import gettext

# server import
from server import config

# get APP_NAME or default name
APP_NAME = config.Config().get('activity>name')
APP_NAME = 'my_activity' if APP_NAME is None else APP_NAME

# get app config values
_debug = config.Config().get('server>debug')
_key = config.Config().get('server>secret_key')

# flask import
import flask

# sugar or debug root path factory
try:
    from sugar.activity import activity
    BUNDLE = activity.get_bundle_path()
    ROOT   = activity.get_activity_root()
except Exception, e:
    BUNDLE = '.'
    ROOT   = '.'

# init app
app = flask.Flask(__name__)
app.debug = True if _debug is None else _debug
app.secret_key = 'NO_KEY_OOPS' if _key is None else _key
# override jinja template path
app.jinja_loader.searchpath = [os.path.join(BUNDLE, 'templates')]

# init static folder path
from werkzeug import SharedDataMiddleware
app.wsgi_app = SharedDataMiddleware(app.wsgi_app,
        {'/static': os.path.join(BUNDLE, 'static')})

# set basic logging out of sugar
try:
    import sugar
    # get sugar logger
    logger = logging.getLogger(APP_NAME)
    logger.setLevel(logging.DEBUG)
except Exception:
    # .. or flask logger
    logger = app.logger


def run_app():
    """run method to trigger at from python class.
    """
    app.run()


def render(template, **context):
    """Crappy hack for gettext issue in templates!
    """
    context['_'] = gettext
    return flask.render_template(template, **context)