Я новичок в использовании Blueprint & Application-Factory. У меня возникают проблемы при попытке заставить Flask -Security работать с методом фабрики приложений. Я просмотрел несколько постов и не смог найти решение, которое работает. При моей текущей установке я получаю эту ошибку: RecursionError: максимальная глубина рекурсии превышена при вызове объекта Python, и я полагаю, что установка @ security.context_processor вызывает это. Я хотел бы знать, имеет ли смысл то, как я это структурировал, и как я могу интегрировать Flask -Security в фабрику приложений. Приложение структурировано, как показано ниже (у меня есть несколько задач с сельдереем, но я удалил его для простоты):
app_factory
- app/
- __init__.py
- factory.py
- models.py
- tasks.py
- views.py
- adminbp/
- securitybp/
- templates/
- admin/
- index.html
- statics
- config.py
- run.py
app_factory > run.py
from app import factory
import app
if __name__ == "__main__":
app = factory.create_app()
app.run()
app_factory > __init_.py
from celery import Celery
def make_celery(app_name=__name__):
celery_broker_url = ''
celery_backend_url = ''
return Celery(app_name, backend=celery_backend_url, broker=celery_broker_url)
celery = make_celery()
app_factory > app > factory.py
import os
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_admin import Admin
from flask_security import Security
db = SQLAlchemy()
admin = Admin()
security = Security()
PKG_NAME = os.path.dirname(os.path.realpath(__file__)).split("\\")[1]
def create_app(app_name=PKG_NAME, **kwargs):
app = Flask(app_name)
app.config.from_pyfile('config.py')
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+mysqlconnector: ...'
db.init_app(app)
admin.init_app(app)
from app.views import bp
app.register_blueprint(bp)
from app.adminbp.routes import adminbp, user_datastore
app.register_blueprint(adminbp)
from app.securitybp.routes import securitybp
app.register_blueprint(securitybp)
security._state = security.init_app(app, user_datastore)
# security = Security(app, user_datastore)
return app
app_factory > app > views.py
import os
import flask_admin
from flask import Blueprint, render_template, current_app
from .factory import db
from .tasks import make_file
from .models import Role, User, MyBaseView
bp = Blueprint("views", __name__, template_folder='templates')
class CustomView(MyBaseView):
@expose('/')
def index(self):
return self.render('admin/custom_index.html')
@bp.route("/")
def index():
results = "Testing"
return render_template ('index.html',results=results)
app_factory > app > adminbp > routes.py
from flask import render_template, Blueprint
from ..models import User, Role, MyModelView, UserView, MyBaseView, Role, User
from ..factory import db, admin, security
from flask_admin.contrib.sqla import ModelView
from flask_security import current_user, login_required, RoleMixin, Security, \
SQLAlchemySessionUserDatastore, UserMixin, utils
adminbp = Blueprint('adminbp', __name__,template_folder='templates/admin')
user_datastore = SQLAlchemySessionUserDatastore(db, User, Role)
admin.add_view(MyModelView(Role, db.session, menu_icon_type='fa', menu_icon_value='fa-server', name="Roles"))
admin.add_view(UserView(User, db.session, menu_icon_type='fa', menu_icon_value='fa-users', name="Users"))
app_factory > app > securitybp > routes.py
from flask import render_template, Blueprint
from ..factory import security
securitybp = Blueprint('securitybp', __name__)
# @security.context_processor
def security_context_processor():
return dict(
admin_base_template=admin.base_template,
admin_view=admin.index_view,
h=admin_helpers,
get_url=url_for
)
security.context_processor(security_context_processor)
Спасибо заранее для изучения этого!