2016-06-25 12:57:47 +02:00
|
|
|
import flask
|
|
|
|
import flask_sqlalchemy
|
|
|
|
import flask_bootstrap
|
|
|
|
import flask_login
|
|
|
|
import flask_script
|
|
|
|
import flask_migrate
|
2016-02-20 14:57:26 +02:00
|
|
|
|
2016-02-20 21:11:59 +02:00
|
|
|
import os
|
2016-04-20 22:37:17 +02:00
|
|
|
import docker
|
2016-02-20 14:57:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
# Create application
|
2016-06-25 12:57:47 +02:00
|
|
|
app = flask.Flask(__name__)
|
2016-02-20 14:57:26 +02:00
|
|
|
|
2016-02-20 21:11:59 +02:00
|
|
|
default_config = {
|
2016-03-20 16:36:56 +02:00
|
|
|
'SQLALCHEMY_DATABASE_URI': 'sqlite:////data/freeposte.db',
|
2016-02-20 21:11:59 +02:00
|
|
|
'SQLALCHEMY_TRACK_MODIFICATIONS': False,
|
2016-04-20 22:37:17 +02:00
|
|
|
'SECRET_KEY': 'changeMe',
|
|
|
|
'DOCKER_SOCKET': 'unix:///var/run/docker.sock',
|
2016-02-24 08:44:49 +02:00
|
|
|
'DEBUG': False
|
2016-02-20 21:11:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
# Load configuration from the environment if available
|
|
|
|
for key, value in default_config.items():
|
|
|
|
app.config[key] = os.environ.get(key, value)
|
|
|
|
|
2016-03-20 16:36:56 +02:00
|
|
|
# Setup components
|
2016-06-25 12:57:47 +02:00
|
|
|
flask_bootstrap.Bootstrap(app)
|
|
|
|
db = flask_sqlalchemy.SQLAlchemy(app)
|
|
|
|
migrate = flask_migrate.Migrate(app, db)
|
2016-03-19 21:37:48 +02:00
|
|
|
login_manager = flask_login.LoginManager()
|
|
|
|
login_manager.init_app(app)
|
|
|
|
|
2016-06-25 12:57:47 +02:00
|
|
|
# Manager commnad
|
|
|
|
manager = flask_script.Manager(app)
|
|
|
|
manager.add_command('db', flask_migrate.MigrateCommand)
|
|
|
|
|
2016-04-20 22:37:17 +02:00
|
|
|
# Connect to the Docker socket
|
|
|
|
dockercli = docker.Client(base_url=app.config['DOCKER_SOCKET'])
|
|
|
|
|
2016-03-20 16:36:56 +02:00
|
|
|
# Finally setup the blueprint
|
|
|
|
from freeposte import admin
|
|
|
|
app.register_blueprint(admin.app, url_prefix='/admin')
|