2023-04-19 00:17:48 +00:00
|
|
|
"""Main Flask application."""
|
|
|
|
import json
|
|
|
|
import logging
|
|
|
|
from pathlib import Path
|
2023-09-07 19:01:43 +00:00
|
|
|
import sys
|
2023-04-19 00:17:48 +00:00
|
|
|
|
2023-09-30 15:25:18 +00:00
|
|
|
import arroba.server
|
|
|
|
from arroba import xrpc_repo, xrpc_server, xrpc_sync
|
2023-04-19 00:17:48 +00:00
|
|
|
from flask import Flask, g
|
|
|
|
from flask_caching import Cache
|
|
|
|
import flask_gae_static
|
|
|
|
from lexrpc.server import Server
|
2023-09-30 15:25:18 +00:00
|
|
|
import lexrpc.flask_server
|
2023-04-19 00:17:48 +00:00
|
|
|
from oauth_dropins.webutil import (
|
|
|
|
appengine_info,
|
|
|
|
appengine_config,
|
|
|
|
flask_util,
|
|
|
|
)
|
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
2023-09-11 23:21:03 +00:00
|
|
|
# logging.getLogger('lexrpc').setLevel(logging.INFO)
|
2023-04-19 00:17:48 +00:00
|
|
|
logging.getLogger('negotiator').setLevel(logging.WARNING)
|
|
|
|
|
|
|
|
app_dir = Path(__file__).parent
|
|
|
|
|
|
|
|
|
|
|
|
app = Flask(__name__, static_folder=None)
|
|
|
|
app.template_folder = './templates'
|
|
|
|
app.json.compact = False
|
|
|
|
app.config.from_pyfile(app_dir / 'config.py')
|
|
|
|
app.url_map.converters['regex'] = flask_util.RegexConverter
|
|
|
|
app.after_request(flask_util.default_modern_headers)
|
|
|
|
app.register_error_handler(Exception, flask_util.handle_exception)
|
2023-09-07 19:01:43 +00:00
|
|
|
if (appengine_info.LOCAL_SERVER
|
|
|
|
# ugly hack to infer if we're running unit tests
|
|
|
|
and 'unittest' not in sys.modules):
|
2023-04-19 00:17:48 +00:00
|
|
|
flask_gae_static.init_app(app)
|
|
|
|
|
2023-06-20 18:22:54 +00:00
|
|
|
|
2023-04-19 00:17:48 +00:00
|
|
|
# don't redirect API requests with blank path elements
|
2023-05-30 23:36:18 +00:00
|
|
|
app.url_map.merge_slashes = False
|
|
|
|
app.url_map.redirect_defaults = False
|
2023-04-19 00:17:48 +00:00
|
|
|
|
|
|
|
app.wsgi_app = flask_util.ndb_context_middleware(
|
2023-06-22 21:27:02 +00:00
|
|
|
app.wsgi_app, client=appengine_config.ndb_client,
|
|
|
|
# disable in-memory cache
|
|
|
|
# (also in tests/testutil.py)
|
|
|
|
# https://github.com/googleapis/python-ndb/issues/888
|
|
|
|
cache_policy=lambda key: False,
|
|
|
|
)
|
2023-04-19 00:17:48 +00:00
|
|
|
|
|
|
|
cache = Cache(app)
|
2023-09-30 15:25:18 +00:00
|
|
|
|
|
|
|
lexrpc.flask_server.init_flask(arroba.server.server, app)
|