首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在flask-security中设置默认角色

在flask-security中设置默认角色
EN

Stack Overflow用户
提问于 2013-06-17 19:44:44
回答 2查看 5.6K关注 0票数 2

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

我已经创建了我需要的角色,所以我只需要以某种方式定义它。不过不知道是怎么回事。

我的代码几乎是从快速入门指南中复制粘贴过来的。不管怎么说,这就是:

代码语言:javascript
复制
# 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')
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-06-17 23:07:55

我用这个git issue中的信息修复了这个问题:

代码语言:javascript
复制
@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()
票数 10
EN

Stack Overflow用户

发布于 2013-06-17 21:13:43

如果您已经创建了角色" user ",则可以在创建/注册用户时将该角色添加到该用户。

代码语言:javascript
复制
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()
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17146724

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档