/
main.py
87 lines (80 loc) · 3.13 KB
/
main.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
"""Initial application settings."""
# Standard Library
import os
# Third Party
import flask
import flask_bootstrap
try:
import flask_debugtoolbar
except ImportError:
debugtoolbar = False
else:
debugtoolbar = True
import flask_mail
import flask_security
import flask_sqlalchemy
import flask_migrate
import raven.contrib.flask
# General Setup
app = flask.Flask(__name__)
app.config["DEBUG"] = str(os.getenv("DEBUG", False)).lower() == "true"
DEV_SECRET_KEY = "v=&3w2fsnn+all#(av21nbj9w&w5+$yd71tg*(zng_qwrw=)k*"
app.config["SECRET_KEY"] = os.getenv("SECRET_KEY", DEV_SECRET_KEY)
app.config["TRACKING_ID"] = os.getenv("TRACKING_ID", "")
# Raven
if not app.debug:
raven.contrib.flask.Sentry(app)
# SQLAlchemy
DATABASE_URI = os.getenv("DATABASE_URI", "sqlite:///love_touches.sqlite")
app.config["SQLALCHEMY_DATABASE_URI"] = DATABASE_URI
app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False
db = flask_sqlalchemy.SQLAlchemy(app)
migrate = flask_migrate.Migrate(app, db)
# Bootstrap
serve_local = str(os.getenv("BOOTSTRAP_SERVE_LOCAL", False)).lower() == "true"
app.config["BOOTSTRAP_SERVE_LOCAL"] = serve_local
app.config["BOOTSTRAP_USE_MINIFIED"] = not app.debug
flask_bootstrap.Bootstrap(app)
# Flask-Security
import models # noqa: E402
app.config["SECURITY_MSG_LOGIN"] = ("Please log in to access this page.", "error")
app.config["SECURITY_EMAIL_SENDER"] = "info@love-touches.org"
app.config["SECURITY_PASSWORD_HASH"] = "bcrypt"
pw_salt = "Fa_vX`u`>W52|:+6NFCV_-f+sU#BdUGC:s+!*n"
app.config["SECURITY_PASSWORD_SALT"] = os.getenv("PASSWORD_SALT", pw_salt)
store_salt = "sCZ;2Hd$n~4;}8<2iG3dqgkr~=HQz b7j-yK@,"
app.config["SECURITY_REMEMBER_SALT"] = os.getenv("REMEMBER_SALT", store_salt)
app.config["SECURITY_TRACKABLE"] = True
app.config["SECURITY_CONFIRMABLE"] = True
app.config["SECURITY_CONFIRM_URL"] = "/confirm_email"
app.config["SECURITY_REGISTERABLE"] = True
app.config["SECURITY_REGISTER_URL"] = "/register_user"
app.config["SECURITY_RECOVERABLE"] = True
app.config["SECURITY_LOGIN_URL"] = "/login-user"
app.config["SECURITY_POST_LOGIN_VIEW"] = "post_login"
app.config["SECURITY_CHANGEABLE"] = True
user_datastore = flask_security.SQLAlchemyUserDatastore(db, models.User, models.Role)
app.security = flask_security.Security(app, user_datastore, register_blueprint=False)
state = app.security._state
state.login_manager.login_view = "login"
app.context_processor(flask_security.core._context_processor)
name = "flask_security.core"
security_blueprint = flask_security.views.create_blueprint(state, name)
app.register_blueprint(security_blueprint)
# Debug Toolbar
if debugtoolbar:
app.config["DEBUG_TB_INTERCEPT_REDIRECTS"] = False
flask_debugtoolbar.DebugToolbarExtension(app)
# Flask-Mail
app.config["MAIL_SERVER"] = "192.168.1.110"
user_name = "a032c02e-a437-472f-b666-6a1dd8db40fe"
app.config["MAIL_USERNAME"] = os.getenv("MAIL_USERNAME", user_name)
app.config["MAIL_PASSWORD"] = os.getenv("MAIL_PASSWORD", user_name)
flask_mail.Mail(app)
# Celery
app.config["CELERY_ACCEPT_CONTENT"] = ["json"]
app.config["CELERY_TASK_SERIALIZER"] = "json"
# Local
import views # noqa: E402
app.register_blueprint(views.manage.manage)
app.register_blueprint(views.signup.signup)