Tafkas/solarpi

View on GitHub
solarpi/app.py

Summary

Maintainability
A
0 mins
Test Coverage
# -*- coding: utf-8 -*-
"""The app module, containing the app factory function."""

from flask import Flask, render_template

from solarpi import public, weather, charts, statistics, tables
from solarpi.assets import assets
from solarpi.extensions import cache, db, migrate, debug_toolbar
from solarpi.settings import ProdConfig


def create_app(config_object=ProdConfig):
    """An application factory, as explained here:
        http://flask.pocoo.org/docs/patterns/appfactories/

    :param config_object: The configuration object to use.
    """
    app = Flask(__name__)
    app.config.from_object(config_object)
    register_extensions(app)
    register_blueprints(app)
    register_errorhandlers(app)
    return app


def register_extensions(app):
    assets.init_app(app)
    cache.init_app(app, config={"CACHE_TYPE": "simple"})
    db.init_app(app)
    debug_toolbar.init_app(app)
    migrate.init_app(app, db)
    return None


def register_blueprints(app):
    app.register_blueprint(charts.views.blueprint)
    app.register_blueprint(public.views.blueprint)
    app.register_blueprint(statistics.views.blueprint)
    app.register_blueprint(tables.views.blueprint)
    app.register_blueprint(weather.views.blueprint)

    return None


def register_errorhandlers(app):
    def render_error(error):
        # If a HTTPException, pull the `code` attribute; default to 500
        error_code = getattr(error, "code", 500)
        return render_template("{0}.html".format(error_code)), error_code

    for errcode in [401, 404, 500]:
        app.errorhandler(errcode)(render_error)
    return None