python-gallery/gallery/__init__.py

133 lines
3.8 KiB
Python
Raw Normal View History

2023-03-04 13:45:26 +00:00
"""
2023-03-11 23:16:27 +00:00
Onlylegs Gallery
This is the main app file, it loads all the other files and sets up the app
2023-03-04 13:45:26 +00:00
"""
2023-03-04 13:45:26 +00:00
# Import system modules
import os
import logging
# Flask
from flask_compress import Compress
from flask_caching import Cache
from flask_assets import Environment, Bundle
from flask_login import LoginManager
from flask import Flask, render_template, abort
from werkzeug.exceptions import HTTPException
2023-03-04 13:45:26 +00:00
# Configuration
import platformdirs
2023-03-20 17:19:42 +00:00
from dotenv import load_dotenv
from yaml import safe_load
2023-03-20 17:19:42 +00:00
# Import database
from sqlalchemy.orm import sessionmaker
from gallery import db
2023-04-07 12:35:30 +00:00
USER_DIR = platformdirs.user_config_dir("onlylegs")
db_session = sessionmaker(bind=db.engine)
db_session = db_session()
login_manager = LoginManager()
assets = Environment()
2023-04-07 12:35:30 +00:00
cache = Cache(config={"CACHE_TYPE": "SimpleCache", "CACHE_DEFAULT_TIMEOUT": 300})
compress = Compress()
2023-04-08 19:38:16 +00:00
def create_app(test_config=None): # pylint: disable=R0914
2023-03-04 13:45:26 +00:00
"""
Create and configure the main app
"""
2023-04-07 12:35:30 +00:00
app = Flask(__name__, instance_path=os.path.join(USER_DIR, "instance"))
2023-03-20 17:19:42 +00:00
# Get environment variables
2023-04-07 12:35:30 +00:00
load_dotenv(os.path.join(USER_DIR, ".env"))
print("Loaded environment variables")
# Get config file
2023-04-07 12:35:30 +00:00
with open(os.path.join(USER_DIR, "conf.yml"), encoding="utf-8", mode="r") as file:
2023-03-20 17:57:47 +00:00
conf = safe_load(file)
print("Loaded config")
# App configuration
app.config.from_mapping(
2023-04-07 12:35:30 +00:00
SECRET_KEY=os.environ.get("FLASK_SECRET"),
DATABASE=os.path.join(app.instance_path, "gallery.sqlite3"),
UPLOAD_FOLDER=os.path.join(USER_DIR, "uploads"),
ALLOWED_EXTENSIONS=conf["upload"]["allowed-extensions"],
MAX_CONTENT_LENGTH=1024 * 1024 * conf["upload"]["max-size"],
ADMIN_CONF=conf["admin"],
UPLOAD_CONF=conf["upload"],
WEBSITE_CONF=conf["website"],
)
if test_config is None:
2023-04-07 12:35:30 +00:00
app.config.from_pyfile("config.py", silent=True)
else:
app.config.from_mapping(test_config)
login_manager.init_app(app)
2023-04-07 12:35:30 +00:00
login_manager.login_view = "gallery.index"
login_manager.session_protection = "strong"
@login_manager.user_loader
def load_user(user_id):
return db_session.query(db.Users).filter_by(alt_id=user_id).first()
@login_manager.unauthorized_handler
def unauthorized():
2023-04-04 14:00:00 +00:00
error = 401
2023-04-07 12:35:30 +00:00
msg = "You are not authorized to view this page!!!!"
return render_template("error.html", error=error, msg=msg), error
2023-04-04 14:00:00 +00:00
2023-04-08 19:38:16 +00:00
scripts = Bundle(
2023-04-09 00:41:14 +00:00
"js/*.js", filters="jsmin", output="gen/js.js", depends="js/*.js"
2023-04-04 14:00:00 +00:00
)
2023-04-09 00:41:14 +00:00
2023-04-04 14:00:00 +00:00
styles = Bundle(
2023-04-08 19:32:04 +00:00
"sass/*.sass", filters="libsass, cssmin", output="gen/styles.css", depends='sass/**/*.sass'
2023-04-04 14:00:00 +00:00
)
2023-04-09 00:41:14 +00:00
assets.register("scripts", scripts)
2023-04-07 12:35:30 +00:00
assets.register("styles", styles)
2023-04-02 16:50:52 +00:00
# Error handlers, if the error is not a HTTP error, return 500
@app.errorhandler(Exception)
2023-04-02 16:50:52 +00:00
def error_page(err): # noqa
if not isinstance(err, HTTPException):
abort(500)
2023-04-07 12:35:30 +00:00
return (
render_template("error.html", error=err.code, msg=err.description),
err.code,
)
# Load login, registration and logout manager
2023-03-12 15:52:23 +00:00
from gallery import auth
2023-04-07 12:35:30 +00:00
app.register_blueprint(auth.blueprint)
2023-04-06 16:22:56 +00:00
# Load the API
from gallery import api
2023-04-07 12:35:30 +00:00
2023-03-12 15:52:23 +00:00
app.register_blueprint(api.blueprint)
2023-04-06 16:22:56 +00:00
# Load the different views
from gallery.views import index, image, group, settings, profile
2023-04-07 12:35:30 +00:00
2023-04-06 16:22:56 +00:00
app.register_blueprint(index.blueprint)
app.register_blueprint(image.blueprint)
app.register_blueprint(group.blueprint)
app.register_blueprint(profile.blueprint)
app.register_blueprint(settings.blueprint)
# Log to file that the app has started
2023-04-07 12:35:30 +00:00
logging.info("Gallery started successfully!")
# Initialize extensions and return app
assets.init_app(app)
cache.init_app(app)
compress.init_app(app)
2023-03-04 13:45:26 +00:00
return app