2013-09-23 12:37:40 -04:00
|
|
|
import logging
|
2013-09-30 23:54:12 -04:00
|
|
|
import os
|
2013-09-23 12:37:40 -04:00
|
|
|
|
2013-09-25 12:45:12 -04:00
|
|
|
from flask import Flask
|
2013-09-20 18:38:17 -04:00
|
|
|
from flask.ext.principal import Principal
|
2013-09-25 12:45:12 -04:00
|
|
|
from flask.ext.login import LoginManager
|
2013-09-27 19:29:01 -04:00
|
|
|
from flask.ext.mail import Mail
|
2013-10-03 16:19:01 -04:00
|
|
|
|
2014-04-03 18:47:17 -04:00
|
|
|
import features
|
|
|
|
|
2014-04-03 17:31:46 -04:00
|
|
|
from storage import Storage
|
2014-05-13 12:17:26 -04:00
|
|
|
from data import model
|
|
|
|
from data import database
|
2014-04-03 17:31:46 -04:00
|
|
|
from data.userfiles import Userfiles
|
2014-05-09 17:39:43 -04:00
|
|
|
from data.users import UserAuthentication
|
2014-04-07 01:20:09 -04:00
|
|
|
from util.analytics import Analytics
|
2014-04-28 18:59:22 -04:00
|
|
|
from util.exceptionlog import Sentry
|
2014-05-21 19:50:37 -04:00
|
|
|
from util.queuemetrics import QueueMetrics
|
2014-04-10 15:20:16 -04:00
|
|
|
from data.billing import Billing
|
2014-05-09 18:45:11 -04:00
|
|
|
from data.buildlogs import BuildLogs
|
2014-05-21 19:50:37 -04:00
|
|
|
from data.queue import WorkQueue
|
2013-10-03 16:19:01 -04:00
|
|
|
|
2013-09-20 11:55:44 -04:00
|
|
|
|
2014-04-07 16:59:22 -04:00
|
|
|
OVERRIDE_CONFIG_FILENAME = 'conf/stack/config.py'
|
|
|
|
|
|
|
|
|
2013-09-20 11:55:44 -04:00
|
|
|
app = Flask(__name__)
|
2013-10-03 16:19:01 -04:00
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
2013-09-30 23:54:12 -04:00
|
|
|
|
2014-04-07 16:59:22 -04:00
|
|
|
if 'TEST' in os.environ:
|
|
|
|
from test.testconfig import TestConfig
|
|
|
|
logger.debug('Loading test config.')
|
|
|
|
app.config.from_object(TestConfig())
|
|
|
|
else:
|
|
|
|
from config import DefaultConfig
|
|
|
|
logger.debug('Loading default config.')
|
|
|
|
app.config.from_object(DefaultConfig())
|
2014-04-03 17:31:46 -04:00
|
|
|
|
2014-04-07 16:59:22 -04:00
|
|
|
if os.path.exists(OVERRIDE_CONFIG_FILENAME):
|
|
|
|
logger.debug('Applying config file: %s', OVERRIDE_CONFIG_FILENAME)
|
|
|
|
app.config.from_pyfile(OVERRIDE_CONFIG_FILENAME)
|
2013-09-27 19:29:01 -04:00
|
|
|
|
2014-04-03 18:47:17 -04:00
|
|
|
features.import_features(app.config)
|
|
|
|
|
2014-03-17 12:01:13 -04:00
|
|
|
Principal(app, use_sessions=False)
|
2013-09-20 18:38:17 -04:00
|
|
|
|
2014-04-08 23:05:45 -04:00
|
|
|
login_manager = LoginManager(app)
|
|
|
|
mail = Mail(app)
|
|
|
|
storage = Storage(app)
|
|
|
|
userfiles = Userfiles(app)
|
|
|
|
analytics = Analytics(app)
|
2014-04-10 15:20:16 -04:00
|
|
|
billing = Billing(app)
|
2014-04-28 18:59:22 -04:00
|
|
|
sentry = Sentry(app)
|
2014-05-09 18:45:11 -04:00
|
|
|
build_logs = BuildLogs(app)
|
2014-05-21 19:50:37 -04:00
|
|
|
queue_metrics = QueueMetrics(app)
|
2014-05-13 12:17:26 -04:00
|
|
|
authentication = UserAuthentication(app)
|
2014-05-21 19:50:37 -04:00
|
|
|
|
2014-05-22 12:13:41 -04:00
|
|
|
tf = app.config['DB_TRANSACTION_FACTORY']
|
|
|
|
image_diff_queue = WorkQueue(app.config['DIFFS_QUEUE_NAME'], tf)
|
|
|
|
dockerfile_build_queue = WorkQueue(app.config['DOCKERFILE_BUILD_QUEUE_NAME'], tf,
|
2014-05-21 19:50:37 -04:00
|
|
|
reporter=queue_metrics.report)
|
2014-05-22 12:13:41 -04:00
|
|
|
webhook_queue = WorkQueue(app.config['WEBHOOK_QUEUE_NAME'], tf)
|
|
|
|
|
2014-05-13 12:17:26 -04:00
|
|
|
database.configure(app.config)
|
|
|
|
model.config.app_config = app.config
|
|
|
|
model.config.store = storage
|