replace imports in the middle of code with current_app

This commit is contained in:
dogeystamp 2023-04-30 17:28:17 -04:00
parent bdabb4a85a
commit ec3245dd4f
Signed by: dogeystamp
GPG Key ID: 7225FE3592EFFA38
5 changed files with 29 additions and 31 deletions

View File

@ -9,13 +9,14 @@ from .config import DevelopmentConfig, ProductionConfig, TestingConfig, overlay_
app = Flask(__name__) app = Flask(__name__)
CORS(app) CORS(app)
if os.getenv("RUN_ENV") == "test": with app.app_context():
overlay_config(TestingConfig, "./config-testing.yml") if os.getenv("RUN_ENV") == "test":
elif app.config["DEBUG"]: overlay_config(TestingConfig, "./config-testing.yml")
overlay_config(DevelopmentConfig) elif app.config["DEBUG"]:
app.logger.warning("Running in DEVELOPMENT MODE; do NOT use this in production!") overlay_config(DevelopmentConfig)
else: app.logger.warning("Running in DEVELOPMENT MODE; do NOT use this in production!")
overlay_config(ProductionConfig) else:
overlay_config(ProductionConfig)
bcrypt = Bcrypt(app) bcrypt = Bcrypt(app)
db = SQLAlchemy(app) db = SQLAlchemy(app)
@ -27,10 +28,13 @@ storage = None
from sachet.storage import FileSystem from sachet.storage import FileSystem
if _storage_method == "filesystem":
storage = FileSystem() with app.app_context():
else: db.create_all()
raise ValueError(f"{_storage_method} is not a valid storage method.") if _storage_method == "filesystem":
storage = FileSystem()
else:
raise ValueError(f"{_storage_method} is not a valid storage method.")
import sachet.server.commands import sachet.server.commands
@ -45,6 +49,3 @@ app.register_blueprint(admin_blueprint)
from sachet.server.files.views import files_blueprint from sachet.server.files.views import files_blueprint
app.register_blueprint(files_blueprint) app.register_blueprint(files_blueprint)
with app.app_context():
db.create_all()

View File

@ -1,4 +1,5 @@
from os import getenv, path from os import getenv, path
from flask import current_app
import yaml import yaml
sqlalchemy_base = "sqlite:///sachet" sqlalchemy_base = "sqlite:///sachet"
@ -51,9 +52,7 @@ def overlay_config(base, config_file=None):
if config["SECRET_KEY"] == "" or config["SECRET_KEY"] is None: if config["SECRET_KEY"] == "" or config["SECRET_KEY"] is None:
raise ValueError("Please set secret_key within the configuration.") raise ValueError("Please set secret_key within the configuration.")
from sachet.server import app current_app.config.from_object(base)
app.config.from_object(base)
for k, v in config.items(): for k, v in config.items():
app.config[k] = v current_app.config[k] = v

View File

@ -1,10 +1,10 @@
from sachet.server import app, db, ma, bcrypt, storage from sachet.server import db, ma, bcrypt, storage
import datetime import datetime
import jwt import jwt
from enum import IntFlag from enum import IntFlag
from bitmask import Bitmask from bitmask import Bitmask
from marshmallow import fields, ValidationError from marshmallow import fields, ValidationError
from flask import request, jsonify, url_for from flask import request, jsonify, url_for, current_app
from sqlalchemy_utils import UUIDType from sqlalchemy_utils import UUIDType
import uuid import uuid
@ -87,7 +87,7 @@ class User(db.Model):
self.permissions = permissions self.permissions = permissions
self.password = bcrypt.generate_password_hash( self.password = bcrypt.generate_password_hash(
password, app.config.get("BCRYPT_LOG_ROUNDS") password, current_app.config.get("BCRYPT_LOG_ROUNDS")
).decode() ).decode()
self.username = username self.username = username
self.register_date = datetime.datetime.now() self.register_date = datetime.datetime.now()
@ -100,7 +100,7 @@ class User(db.Model):
"sub": self.username, "sub": self.username,
"jti": jti, "jti": jti,
} }
return jwt.encode(payload, app.config.get("SECRET_KEY"), algorithm="HS256") return jwt.encode(payload, current_app.config.get("SECRET_KEY"), algorithm="HS256")
def read_token(token): def read_token(token):
"""Read a JWT and validate it. """Read a JWT and validate it.
@ -111,7 +111,7 @@ class User(db.Model):
data = jwt.decode( data = jwt.decode(
token, token,
app.config["SECRET_KEY"], current_app.config["SECRET_KEY"],
algorithms=["HS256"], algorithms=["HS256"],
) )
@ -153,7 +153,7 @@ class BlacklistToken(db.Model):
data = jwt.decode( data = jwt.decode(
token, token,
app.config["SECRET_KEY"], current_app.config["SECRET_KEY"],
algorithms=["HS256"], algorithms=["HS256"],
) )
self.expires = datetime.datetime.fromtimestamp(data["exp"]) self.expires = datetime.datetime.fromtimestamp(data["exp"])

View File

@ -1,4 +1,5 @@
from sachet.storage import Storage from sachet.storage import Storage
from flask import current_app
from pathlib import Path from pathlib import Path
from werkzeug.utils import secure_filename from werkzeug.utils import secure_filename
import json import json
@ -6,21 +7,18 @@ import json
class FileSystem(Storage): class FileSystem(Storage):
def __init__(self): def __init__(self):
# prevent circular import when inspecting this file outside of Flask config_path = Path(current_app.config["SACHET_FILE_DIR"])
from sachet.server import app
config_path = Path(app.config["SACHET_FILE_DIR"])
if config_path.is_absolute(): if config_path.is_absolute():
self._directory = config_path self._directory = config_path
else: else:
self._directory = Path(app.instance_path) / config_path self._directory = Path(current_app.instance_path) / config_path
self._files_directory = self._directory / Path("files") self._files_directory = self._directory / Path("files")
self._files_directory.mkdir(mode=0o700, exist_ok=True, parents=True) self._files_directory.mkdir(mode=0o700, exist_ok=True, parents=True)
if not self._directory.is_dir(): if not self._directory.is_dir():
raise OSError(f"'{app.config['SACHET_FILE_DIR']}' is not a directory.") raise OSError(f"'{current_app.config['SACHET_FILE_DIR']}' is not a directory.")
def _get_path(self, name): def _get_path(self, name):
name = secure_filename(name) name = secure_filename(name)

View File

@ -1,6 +1,6 @@
import pytest import pytest
from sachet.server.commands import create_db, drop_db, create_user, delete_user from sachet.server.commands import create_db, drop_db, create_user, delete_user
from sachet.server import app, db from sachet.server import db
from sqlalchemy import inspect from sqlalchemy import inspect
from sachet.server.models import User from sachet.server.models import User