flask-admin:如何获取当前用户的其他信息(除了ID,姓名,电子邮件)?



我希望用户的姓名和他的团队在创建项目时会自动存储。这些类定义下面:

class Team(db.Model, RoleMixin):
    id = db.Column(db.Integer(), primary_key=True)
    name = db.Column(db.String(80), unique=True)
    def __str__(self):
       return self.name  
class User(db.Model, UserMixin):
    id = db.Column(db.Integer, primary_key=True)
    first_name = db.Column(db.String(255))
    last_name = db.Column(db.String(255))
    email = db.Column(db.String(255), unique=True)
    teams = db.relationship('Team', secondary=teams_users,uselist=False,
                        backref=db.backref('users', lazy='dynamic'))
    def __str__(self):
       return self.first_name
 class Project(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    team = db.Column(db.Unicode(64))
    developer = db.Column(db.Unicode(128))  
       def __unicode__(self):
          return self.developer

创建一个项目时,我使用以下内容来存储当前用户的名字和团队:

     class ProjectView(sqla.ModelView):
        def on_model_change(self, form, model, is_created):
           if is_created:
             model.developer = current_user.first_name
             model.team = current_user.teams

正确保存了用户名,但团队未能保存。我还尝试存储model.team =current_user.emailmodel.team =current_user.last_namemodel.team =current_user.id,并且所有工作都可以。不确定发生了什么原因为什么无法存储current_user.teams。谢谢。

因为 User.teams不是 db.Column,例如 Project.team和其他字段,即 db.relationship,如果您想为其分配一个值,它必须是 Team

所以您必须做类似:

的事情
class ProjectView(sqla.ModelView):
    def on_model_change(self, form, model, is_created):
        if is_created:
            model.developer = current_user.first_name
            model.team = Team(name=current_user.teams)

相关内容

最新更新