2019-12-02 03:32:03 +00:00
|
|
|
import os
|
2019-12-06 03:32:57 +00:00
|
|
|
from werkzeug.middleware.proxy_fix import ProxyFix
|
2019-12-02 03:32:03 +00:00
|
|
|
from flask import Flask
|
|
|
|
from flask_seasurf import SeaSurf
|
|
|
|
|
|
|
|
from .lib import utils
|
|
|
|
|
|
|
|
|
|
|
|
def create_app(config=None):
|
|
|
|
from . import models, routes, services
|
|
|
|
from .assets import assets
|
|
|
|
app = Flask(__name__)
|
|
|
|
|
|
|
|
# Proxy
|
|
|
|
app.wsgi_app = ProxyFix(app.wsgi_app)
|
|
|
|
|
|
|
|
# CSRF protection
|
|
|
|
csrf = SeaSurf(app)
|
|
|
|
csrf.exempt(routes.index.dyndns_checkip)
|
|
|
|
csrf.exempt(routes.index.dyndns_update)
|
|
|
|
csrf.exempt(routes.index.saml_authorized)
|
|
|
|
csrf.exempt(routes.api.api_login_create_zone)
|
|
|
|
csrf.exempt(routes.api.api_login_delete_zone)
|
|
|
|
csrf.exempt(routes.api.api_generate_apikey)
|
|
|
|
csrf.exempt(routes.api.api_delete_apikey)
|
|
|
|
csrf.exempt(routes.api.api_update_apikey)
|
|
|
|
csrf.exempt(routes.api.api_zone_subpath_forward)
|
|
|
|
csrf.exempt(routes.api.api_zone_forward)
|
|
|
|
csrf.exempt(routes.api.api_create_zone)
|
|
|
|
|
2019-12-04 04:50:46 +00:00
|
|
|
# Load config from env variables if using docker
|
|
|
|
if os.path.exists(os.path.join(app.root_path, 'docker_config.py')):
|
|
|
|
app.config.from_object('powerdnsadmin.docker_config')
|
|
|
|
else:
|
|
|
|
# Load default configuration
|
|
|
|
app.config.from_object('powerdnsadmin.default_config')
|
2019-12-02 03:32:03 +00:00
|
|
|
|
2019-12-04 04:50:46 +00:00
|
|
|
# Load config file from FLASK_CONF env variable
|
2019-12-02 03:32:03 +00:00
|
|
|
if 'FLASK_CONF' in os.environ:
|
|
|
|
app.config.from_envvar('FLASK_CONF')
|
|
|
|
|
|
|
|
# Load app sepecified configuration
|
|
|
|
if config is not None:
|
|
|
|
if isinstance(config, dict):
|
|
|
|
app.config.update(config)
|
|
|
|
elif config.endswith('.py'):
|
|
|
|
app.config.from_pyfile(config)
|
|
|
|
|
2019-12-04 04:50:46 +00:00
|
|
|
# HSTS
|
|
|
|
if app.config.get('HSTS_ENABLED'):
|
|
|
|
from flask_sslify import SSLify
|
|
|
|
_sslify = SSLify(app)
|
|
|
|
|
2019-12-02 03:32:03 +00:00
|
|
|
# Load app's components
|
|
|
|
assets.init_app(app)
|
|
|
|
models.init_app(app)
|
|
|
|
routes.init_app(app)
|
|
|
|
services.init_app(app)
|
|
|
|
|
|
|
|
# Register filters
|
|
|
|
app.jinja_env.filters['display_record_name'] = utils.display_record_name
|
|
|
|
app.jinja_env.filters['display_master_name'] = utils.display_master_name
|
|
|
|
app.jinja_env.filters['display_second_to_time'] = utils.display_time
|
|
|
|
app.jinja_env.filters[
|
|
|
|
'email_to_gravatar_url'] = utils.email_to_gravatar_url
|
|
|
|
app.jinja_env.filters[
|
|
|
|
'display_setting_state'] = utils.display_setting_state
|
|
|
|
|
|
|
|
# Register context proccessors
|
|
|
|
from .models.setting import Setting
|
|
|
|
|
|
|
|
@app.context_processor
|
|
|
|
def inject_sitename():
|
|
|
|
setting = Setting().get('site_name')
|
|
|
|
return dict(SITE_NAME=setting)
|
|
|
|
|
|
|
|
@app.context_processor
|
|
|
|
def inject_setting():
|
|
|
|
setting = Setting()
|
|
|
|
return dict(SETTING=setting)
|
|
|
|
|
|
|
|
return app
|