2023-12-03 22:41:15 +13:00
|
|
|
# This file is part of PieFed, which is licensed under the GNU General Public License (GPL) version 3.0.
|
2023-08-22 21:24:11 +12:00
|
|
|
# You should have received a copy of the GPL along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2023-07-28 16:22:12 +12:00
|
|
|
import logging
|
|
|
|
from logging.handlers import SMTPHandler, RotatingFileHandler
|
|
|
|
import os
|
2024-05-09 13:59:52 +12:00
|
|
|
from flask import Flask, request, current_app, session
|
2023-07-28 16:22:12 +12:00
|
|
|
from flask_sqlalchemy import SQLAlchemy
|
|
|
|
from flask_migrate import Migrate
|
|
|
|
from flask_login import LoginManager
|
2023-08-22 21:24:11 +12:00
|
|
|
from flask_bootstrap import Bootstrap5
|
2023-07-28 16:22:12 +12:00
|
|
|
from flask_mail import Mail
|
|
|
|
from flask_moment import Moment
|
|
|
|
from flask_babel import Babel, lazy_gettext as _l
|
2023-09-16 19:09:04 +12:00
|
|
|
from flask_caching import Cache
|
2023-12-24 13:28:41 +13:00
|
|
|
from celery import Celery
|
2023-08-29 22:01:06 +12:00
|
|
|
from sqlalchemy_searchable import make_searchable
|
|
|
|
|
2023-07-28 16:22:12 +12:00
|
|
|
from config import Config
|
|
|
|
|
|
|
|
|
2024-03-17 20:33:29 +13:00
|
|
|
def get_locale():
|
2024-05-09 19:30:06 +12:00
|
|
|
try:
|
|
|
|
if session.get('ui_language', None):
|
|
|
|
return session['ui_language']
|
|
|
|
else:
|
|
|
|
try:
|
|
|
|
return request.accept_languages.best_match(current_app.config['LANGUAGES'])
|
|
|
|
except:
|
|
|
|
return 'en'
|
|
|
|
except:
|
|
|
|
return 'en'
|
2024-03-17 20:33:29 +13:00
|
|
|
|
|
|
|
|
2023-12-17 00:12:49 +13:00
|
|
|
db = SQLAlchemy() # engine_options={'pool_size': 5, 'max_overflow': 10} # session_options={"autoflush": False}
|
2023-07-28 16:22:12 +12:00
|
|
|
migrate = Migrate()
|
2023-08-05 21:26:44 +12:00
|
|
|
login = LoginManager()
|
|
|
|
login.login_view = 'auth.login'
|
|
|
|
login.login_message = _l('Please log in to access this page.')
|
2023-07-28 16:22:12 +12:00
|
|
|
mail = Mail()
|
2023-08-22 21:24:11 +12:00
|
|
|
bootstrap = Bootstrap5()
|
2023-07-28 16:22:12 +12:00
|
|
|
moment = Moment()
|
2024-03-17 20:33:29 +13:00
|
|
|
babel = Babel(locale_selector=get_locale)
|
2023-09-17 21:19:51 +12:00
|
|
|
cache = Cache()
|
2023-12-24 13:28:41 +13:00
|
|
|
celery = Celery(__name__, broker=Config.CELERY_BROKER_URL)
|
2023-07-28 16:22:12 +12:00
|
|
|
|
|
|
|
|
|
|
|
def create_app(config_class=Config):
|
|
|
|
app = Flask(__name__)
|
|
|
|
app.config.from_object(config_class)
|
|
|
|
|
2024-02-28 17:25:10 +01:00
|
|
|
if app.config['SENTRY_DSN']:
|
|
|
|
import sentry_sdk
|
|
|
|
sentry_sdk.init(
|
|
|
|
dsn=app.config["SENTRY_DSN"],
|
2024-05-06 14:19:39 +12:00
|
|
|
enable_tracing=False,
|
2024-02-28 17:25:10 +01:00
|
|
|
)
|
|
|
|
|
2023-07-28 16:22:12 +12:00
|
|
|
db.init_app(app)
|
|
|
|
migrate.init_app(app, db, render_as_batch=True)
|
2023-08-05 21:26:44 +12:00
|
|
|
login.init_app(app)
|
2023-07-28 16:22:12 +12:00
|
|
|
mail.init_app(app)
|
2023-08-22 21:24:11 +12:00
|
|
|
bootstrap.init_app(app)
|
2023-07-28 16:22:12 +12:00
|
|
|
moment.init_app(app)
|
2023-08-29 22:01:06 +12:00
|
|
|
make_searchable(db.metadata)
|
2023-07-28 16:22:12 +12:00
|
|
|
babel.init_app(app, locale_selector=get_locale)
|
2023-09-16 19:09:04 +12:00
|
|
|
cache.init_app(app)
|
2023-12-24 13:28:41 +13:00
|
|
|
celery.conf.update(app.config)
|
2023-07-28 16:22:12 +12:00
|
|
|
|
|
|
|
from app.main import bp as main_bp
|
|
|
|
app.register_blueprint(main_bp)
|
|
|
|
|
|
|
|
from app.errors import bp as errors_bp
|
|
|
|
app.register_blueprint(errors_bp)
|
|
|
|
|
|
|
|
from app.admin import bp as admin_bp
|
|
|
|
app.register_blueprint(admin_bp, url_prefix='/admin')
|
|
|
|
|
2023-08-05 21:26:44 +12:00
|
|
|
from app.activitypub import bp as activitypub_bp
|
|
|
|
app.register_blueprint(activitypub_bp)
|
|
|
|
|
2023-08-26 15:41:11 +12:00
|
|
|
from app.auth import bp as auth_bp
|
|
|
|
app.register_blueprint(auth_bp, url_prefix='/auth')
|
|
|
|
|
2023-08-29 22:01:06 +12:00
|
|
|
from app.community import bp as community_bp
|
|
|
|
app.register_blueprint(community_bp, url_prefix='/community')
|
|
|
|
|
2023-11-30 06:36:08 +13:00
|
|
|
from app.post import bp as post_bp
|
|
|
|
app.register_blueprint(post_bp)
|
|
|
|
|
2023-10-07 21:32:19 +13:00
|
|
|
from app.user import bp as user_bp
|
|
|
|
app.register_blueprint(user_bp)
|
|
|
|
|
2023-11-29 22:12:55 +13:00
|
|
|
from app.domain import bp as domain_bp
|
|
|
|
app.register_blueprint(domain_bp)
|
|
|
|
|
2024-01-28 18:11:32 +13:00
|
|
|
from app.topic import bp as topic_bp
|
|
|
|
app.register_blueprint(topic_bp)
|
|
|
|
|
2024-02-17 20:05:57 +13:00
|
|
|
from app.chat import bp as chat_bp
|
|
|
|
app.register_blueprint(chat_bp)
|
|
|
|
|
2024-03-01 20:32:29 +13:00
|
|
|
from app.search import bp as search_bp
|
|
|
|
app.register_blueprint(search_bp)
|
|
|
|
|
2024-05-12 13:02:45 +12:00
|
|
|
from app.tag import bp as tag_bp
|
|
|
|
app.register_blueprint(tag_bp)
|
|
|
|
|
2024-08-12 20:23:26 +12:00
|
|
|
from app.dev import bp as dev_bp
|
|
|
|
app.register_blueprint(dev_bp)
|
2024-08-08 09:29:45 -04:00
|
|
|
|
2023-07-28 16:22:12 +12:00
|
|
|
# send error reports via email
|
2024-03-01 16:43:05 +13:00
|
|
|
if app.config['MAIL_SERVER'] and app.config['MAIL_ERRORS']:
|
2023-07-28 16:22:12 +12:00
|
|
|
auth = None
|
|
|
|
if app.config['MAIL_USERNAME'] or app.config['MAIL_PASSWORD']:
|
|
|
|
auth = (app.config['MAIL_USERNAME'],
|
|
|
|
app.config['MAIL_PASSWORD'])
|
|
|
|
secure = None
|
|
|
|
if app.config['MAIL_USE_TLS']:
|
|
|
|
secure = ()
|
|
|
|
mail_handler = SMTPHandler(
|
|
|
|
mailhost=(app.config['MAIL_SERVER'], app.config['MAIL_PORT']),
|
2024-02-25 09:59:13 +01:00
|
|
|
fromaddr=(app.config['MAIL_FROM']),
|
2024-02-24 13:33:28 +13:00
|
|
|
toaddrs=app.config['ADMINS'], subject='PieFed error',
|
2023-07-28 16:22:12 +12:00
|
|
|
credentials=auth, secure=secure)
|
|
|
|
mail_handler.setLevel(logging.ERROR)
|
|
|
|
app.logger.addHandler(mail_handler)
|
|
|
|
|
|
|
|
# log rotation
|
|
|
|
if not os.path.exists('logs'):
|
|
|
|
os.mkdir('logs')
|
|
|
|
file_handler = RotatingFileHandler('logs/pyfedi.log',
|
|
|
|
maxBytes=1002400, backupCount=15)
|
|
|
|
file_handler.setFormatter(logging.Formatter(
|
|
|
|
'%(asctime)s %(levelname)s: %(message)s '
|
|
|
|
'[in %(pathname)s:%(lineno)d]'))
|
|
|
|
file_handler.setLevel(logging.INFO)
|
|
|
|
app.logger.addHandler(file_handler)
|
|
|
|
|
|
|
|
app.logger.setLevel(logging.INFO)
|
|
|
|
app.logger.info('Started!') # let's go!
|
|
|
|
|
|
|
|
return app
|
|
|
|
|
|
|
|
|
|
|
|
from app import models
|