如何将flask-admin添加到蓝图中?

时间:2014-02-27 09:54:53

标签: flask flask-admin

例如:

from flask import Flask
from flask.ext.admin import Admin, BaseView, expose

class MyView(BaseView):
    @expose('/')
    def index(self):
        return self.render('index.html')

app = Flask(__name__)

admin = Admin(app)
admin.add_view(MyView(name='Hello'))

app.run()

但是,如果我需要一个名为' views.py'的新文件,如何将一个视图添加到views.py给管理员? 我需要使用蓝图吗?

4 个答案:

答案 0 :(得分:8)

对于我的项目,我实际上制作了一个支持烧瓶管理的Blueprint子类:

from flask import Blueprint
from flask_admin.contrib.sqla import ModelView
from flask_admin import Admin

class AdminBlueprint(Blueprint):
    views=None


    def __init__(self,*args, **kargs):
        self.views = []
        return super(AdminBlueprint, self).__init__('admin2', __name__,url_prefix='/admin2',static_folder='static', static_url_path='/static/admin')


    def add_view(self, view):
        self.views.append(view)

    def register(self,app, options, first_registration=False):
        print app
        admin = Admin(app, name='microblog', template_mode='adminlte')

        for v in self.views:
            admin.add_view(v)

        return super(AdminBlueprint, self).register(app, options, first_registration)

有关详细信息,您可以在此处阅读我的博客:http://blog.sadafnoor.me/blog/how-to-add-flask-admin-to-a-blueprint/

答案 1 :(得分:5)

您不需要蓝图。在views.py中为您在主项目中定义的admin对象添加导入:

from projectmodule import admin
from flask.ext.admin import BaseView, expose

class MyView(BaseView):
    @expose('/')
    def index(self):
        return self.render('index.html')

admin.add_view(MyView(name='Hello'))

并在您的主projectmodule文件中使用:

from flask import Flask
from flask.ext.admin import Admin


app = Flask(__name__)
admin = Admin(app)

# import the views
import views

app.run()

e.g。在设置import views的行之后添加admin = Admin(app)

答案 2 :(得分:4)

我对这个问题已经很晚了,但无论如何......我的猜测是你希望使用Application Factory模式并使用Flask-Admin。关于潜在问题有一个nice discussion。我使用了一个非常难看的解决方案,在 init .py文件中实例化Flask-Admin:

from flask_admin.contrib.sqla import ModelView

class UserModelView(ModelView):

    create_modal = True
    edit_modal = True
    can_export = True

def create_app(config_name):
    app = Flask(__name__)
    app.config.from_object(config[config_name])
    db.init_app(app)


    # import models here because otherwise it will throw errors    
    from models import User, Sector, Article

    admin.init_app(app)
    admin.add_view(UserModelView(User, db.session))      

    # attach blueprints
    from .main import main as main_blueprint
    app.register_blueprint(main_blueprint)

    from .auth import auth as auth_blueprint
    app.register_blueprint(auth_blueprint, url_prefix='/auth')

    return app

答案 3 :(得分:2)

我有一个带有一个蓝图的flask应用程序(以及登录/注销到admin)。 这是我发现使用一些自定义功能实施flask admin的最佳解决方案。

我的结构如下:

my_app
  main
    __init__.py
    routes.py
  static
  templates
  __init__.py
  config.py
  models.py
  run.py

来自models.py的自定义管理员索引视图

from flask_admin import AdminIndexView

class MyAdminIndexView(AdminIndexView):
    def is_accessible(self):
        return current_user.is_authenticated

    def inaccessible_callback(self, name, **kwargs):
        return redirect(url_for('main.home'))

主要 init .py如下:


from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_admin import Admin
from flask_admin.menu import MenuLink
from my_app.config import Config

# create extensions
db = SQLAlchemy()
admin = Admin()

def create_app(config_class=Config): # default configutation

    app = Flask(__name__)
    app.config.from_object(Config)

    #initialize extensions
    db.init_app(app)
    ...

    # customized admin views
    from my_app.models import MyAdminIndexView
    admin.init_app(app,index_view=MyAdminIndexView())
    admin.add_link(MenuLink(name='Home', url='/'))
    admin.add_link(MenuLink(name='Logout', url='/logout'))

    #blueprint
    from my_app.main.routes import main
    app.register_blueprint(main)

    return app

我认为这是到目前为止我提出的最优雅的解决方案。