availabili.tf/backend-flask/app_db.py

67 lines
2.2 KiB
Python
Raw Normal View History

2024-12-09 17:03:43 -08:00
from os import environ
2024-11-10 17:21:25 -08:00
from flask import Flask
from flask_migrate import Migrate
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy import MetaData
from sqlalchemy.orm import DeclarativeBase
class BaseModel(DeclarativeBase):
pass
convention = {
"ix": "ix_%(column_0_label)s",
"uq": "uq_%(table_name)s_%(column_0_name)s",
"ck": "ck_%(table_name)s_%(constraint_name)s",
"fk": "fk_%(table_name)s_%(column_0_name)s_%(referred_table_name)s",
"pk": "pk_%(table_name)s"
}
2024-12-10 18:18:40 -08:00
def connect_db_with_app(database_uri: str | None, include_migrate=True):
database_uri = database_uri or environ.get("DATABASE_URI")
if not database_uri:
raise ValueError("Database URI is not provided")
2024-12-09 17:03:43 -08:00
print("Connecting to database: " + database_uri)
app.config["SQLALCHEMY_DATABASE_URI"] = database_uri
2024-11-10 17:21:25 -08:00
db.init_app(app)
2024-12-09 17:03:43 -08:00
if include_migrate:
migrate.init_app(app, db)
with app.app_context():
print("Running dialect: " + db.engine.dialect.name)
2024-12-10 18:18:40 -08:00
import models as _
if environ.get("FLASK_ENV") == "production":
print("Creating tables if they do not exist")
db.create_all()
2024-12-09 17:03:43 -08:00
def connect_celery_with_app():
def celery_init_app(app):
from celery import Celery, Task
class FlaskTask(Task):
def __call__(self, *args: object, **kwargs: object) -> object:
with app.app_context():
return self.run(*args, **kwargs)
celery_app = Celery(app.name, task_cls=FlaskTask, broker=app.config["CELERY"]["broker_url"])
celery_app.config_from_object(app.config["CELERY"])
celery_app.set_default()
app.extensions["celery"] = celery_app
return celery_app
app.config.from_mapping(
CELERY=dict(
broker_url=environ.get("CELERY_BROKER_URL", "redis://redis:6379/0"),
result_backend=environ.get("CELERY_RESULT_BACKEND", "redis://redis:6379/0"),
task_ignore_result=True,
)
)
app.config.from_prefixed_env()
celery_init_app(app)
def create_app() -> Flask:
return Flask(__name__)
2024-11-10 17:21:25 -08:00
metadata = MetaData(naming_convention=convention)
2024-12-09 17:03:43 -08:00
app = create_app()
2024-11-10 17:21:25 -08:00
db = SQLAlchemy(model_class=BaseModel, metadata=metadata)
2024-11-27 01:03:41 -08:00
migrate = Migrate(app, db, render_as_batch=True)