在flask-security中设置默认角色

我正在尝试在用户向我的网站注册时设置默认角色,当前在用户注册时未设置任何角色。


我已经创建了所需的角色,因此只需要以某种方式对其进行定义。不确定如何。


我的代码几乎是快速入门指南中的复制粘贴。无论如何,这里是:


# Define models

roles_users = db.Table('roles_users',

        db.Column('user_id', db.Integer(), db.ForeignKey('user.id')),

        db.Column('role_id', db.Integer(), db.ForeignKey('role.id')))


class Role(db.Model, RoleMixin):

    id = db.Column(db.Integer(), primary_key=True)

    name = db.Column(db.String(80), unique=True)

    description = db.Column(db.String(255))


class User(db.Model, UserMixin):

    id = db.Column(db.Integer, primary_key=True)

    email = db.Column(db.String(255), unique=True)

    password = db.Column(db.String(255))

    active = db.Column(db.Boolean())

    confirmed_at = db.Column(db.DateTime())

    roles = db.relationship('Role', secondary=roles_users, backref=db.backref('users', lazy='dynamic'))


# Setup Flask-Security

user_datastore = SQLAlchemyUserDatastore(db, User, Role)

security = Security(app, user_datastore)



import users.getUser as getUser


#@app.before_first_request

def create_user():

    db.create_all()

    user_datastore.create_user(email='my@email.com', password='password')

    db.session.commit()


@flask_sijax.route(app, '/')

def test():

    print user_datastore.create_role(name='User', description='Generic user role')

    db.session.commit()

    return render_template('test.html')


回首忆惘然
浏览 268回答 2
2回答

MMMHUHU

我使用此git问题中的信息对此进行了修复:@user_registered.connect_via(app)def user_registered_sighandler(app, user, confirm_token):    default_role = user_datastore.find_role("User")    user_datastore.add_role_to_user(user, default_role)    db.session.commit()

HUH函数

如果您已经创建了角色“用户”,则可以在创建/注册用户时将该角色添加到用户。def create_user():    db.create_all()    user = user_datastore.create_user(email='my@email.com', password='password')    default_role = user_datastore.find_role(name="User")    user_datastore.add_role_to_user(user, default_role)    db.session.commit()
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Python