summaryrefslogtreecommitdiffstats
path: root/app/team.go
diff options
context:
space:
mode:
authorJesús Espino <jespinog@gmail.com>2018-02-13 10:43:28 +0100
committerJesús Espino <jespinog@gmail.com>2018-02-13 10:43:28 +0100
commitbda8736770f89399f4bca189bc3559f0141cab8e (patch)
tree0eefdda2540444b72a7d7e0147c9acbfa9155330 /app/team.go
parent32c1f7be239ddb19d6c59b114d9ae1a543f8ba9c (diff)
downloadchat-bda8736770f89399f4bca189bc3559f0141cab8e.tar.gz
chat-bda8736770f89399f4bca189bc3559f0141cab8e.tar.bz2
chat-bda8736770f89399f4bca189bc3559f0141cab8e.zip
XYZ-111: Check max users per team on re-join after leave a team
Diffstat (limited to 'app/team.go')
-rw-r--r--app/team.go12
1 files changed, 9 insertions, 3 deletions
diff --git a/app/team.go b/app/team.go
index 8e8c29e2a..a15c64c3f 100644
--- a/app/team.go
+++ b/app/team.go
@@ -302,10 +302,16 @@ func (a *App) joinUserToTeam(team *model.Team, user *model.User) (*model.TeamMem
return rtm, true, nil
}
- if tmr := <-a.Srv.Store.Team().UpdateMember(tm); tmr.Err != nil {
- return nil, false, tmr.Err
+ if membersCount := <-a.Srv.Store.Team().GetActiveMemberCount(tm.TeamId); membersCount.Err != nil {
+ return nil, false, membersCount.Err
+ } else if membersCount.Data.(int64) >= int64(*a.Config().TeamSettings.MaxUsersPerTeam) {
+ return nil, false, model.NewAppError("joinUserToTeam", "app.team.join_user_to_team.max_accounts.app_error", nil, "teamId="+tm.TeamId, http.StatusBadRequest)
} else {
- return tmr.Data.(*model.TeamMember), false, nil
+ if tmr := <-a.Srv.Store.Team().UpdateMember(tm); tmr.Err != nil {
+ return nil, false, tmr.Err
+ } else {
+ return tmr.Data.(*model.TeamMember), false, nil
+ }
}
} else {
// Membership appears to be missing. Lets try to add.