blob: 89d9cb43c75e35dafe5a2422bab1bb7a92bffca8 (
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
64
65
|
# 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')
_port = config.Config().get('server>port', type_=int)
# 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 = os.path.abspath(os.path.join(
os.path.dirname(__file__), '..', '..', '..'))
ROOT = BUNDLE
# 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(port=_port)
def render(template, **context):
"""Crappy hack for gettext issue in templates!
"""
context['_'] = gettext
return flask.render_template(template, **context)
|