|
|
@@ -14,6 +14,7 @@ func init() {
|
|
|
bus.AddHandler("sql", AddOrgUser)
|
|
|
bus.AddHandler("sql", RemoveOrgUser)
|
|
|
bus.AddHandler("sql", GetOrgUsers)
|
|
|
+ bus.AddHandler("sql", UpdateOrgUser)
|
|
|
}
|
|
|
|
|
|
func AddOrgUser(cmd *m.AddOrgUserCommand) error {
|
|
|
@@ -32,6 +33,25 @@ func AddOrgUser(cmd *m.AddOrgUserCommand) error {
|
|
|
})
|
|
|
}
|
|
|
|
|
|
+func UpdateOrgUser(cmd *m.UpdateOrgUserCommand) error {
|
|
|
+ return inTransaction(func(sess *xorm.Session) error {
|
|
|
+ var orgUser m.OrgUser
|
|
|
+ exists, err := sess.Where("org_id=? AND user_id=?", cmd.OrgId, cmd.UserId).Get(&orgUser)
|
|
|
+ if err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+
|
|
|
+ if !exists {
|
|
|
+ return m.ErrOrgUserNotFound
|
|
|
+ }
|
|
|
+
|
|
|
+ orgUser.Role = cmd.Role
|
|
|
+ orgUser.Updated = time.Now()
|
|
|
+ _, err = sess.Id(orgUser.Id).Update(&orgUser)
|
|
|
+ return err
|
|
|
+ })
|
|
|
+}
|
|
|
+
|
|
|
func GetOrgUsers(query *m.GetOrgUsersQuery) error {
|
|
|
query.Result = make([]*m.OrgUserDTO, 0)
|
|
|
sess := x.Table("org_user")
|