diff options
Diffstat (limited to 'store/sqlstore/channel_member_history_store.go')
-rw-r--r-- | store/sqlstore/channel_member_history_store.go | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/store/sqlstore/channel_member_history_store.go b/store/sqlstore/channel_member_history_store.go new file mode 100644 index 000000000..20d0d3335 --- /dev/null +++ b/store/sqlstore/channel_member_history_store.go @@ -0,0 +1,102 @@ +// Copyright (c) 2017-present Mattermost, Inc. All Rights Reserved. +// See License.txt for license information. + +package sqlstore + +import ( + "net/http" + + l4g "github.com/alecthomas/log4go" + "github.com/mattermost/mattermost-server/model" + "github.com/mattermost/mattermost-server/store" +) + +type SqlChannelMemberHistoryStore struct { + SqlStore +} + +func NewSqlChannelMemberHistoryStore(sqlStore SqlStore) store.ChannelMemberHistoryStore { + s := &SqlChannelMemberHistoryStore{ + SqlStore: sqlStore, + } + + for _, db := range sqlStore.GetAllConns() { + table := db.AddTableWithName(model.ChannelMemberHistory{}, "ChannelMemberHistory").SetKeys(false, "ChannelId", "UserId", "JoinTime") + table.ColMap("ChannelId").SetMaxSize(26) + table.ColMap("UserId").SetMaxSize(26) + table.ColMap("JoinTime").SetNotNull(true) + } + + return s +} + +func (s SqlChannelMemberHistoryStore) LogJoinEvent(userId string, channelId string, joinTime int64) store.StoreChannel { + return store.Do(func(result *store.StoreResult) { + channelMemberHistory := &model.ChannelMemberHistory{ + UserId: userId, + ChannelId: channelId, + JoinTime: joinTime, + } + + if err := s.GetMaster().Insert(channelMemberHistory); err != nil { + result.Err = model.NewAppError("SqlChannelMemberHistoryStore.LogJoinEvent", "store.sql_channel_member_history.log_join_event.app_error", map[string]interface{}{"ChannelMemberHistory": channelMemberHistory}, err.Error(), http.StatusInternalServerError) + } + }) +} + +func (s SqlChannelMemberHistoryStore) LogLeaveEvent(userId string, channelId string, leaveTime int64) store.StoreChannel { + return store.Do(func(result *store.StoreResult) { + query := ` + UPDATE ChannelMemberHistory + SET LeaveTime = :LeaveTime + WHERE UserId = :UserId + AND ChannelId = :ChannelId + AND LeaveTime IS NULL` + + params := map[string]interface{}{"UserId": userId, "ChannelId": channelId, "LeaveTime": leaveTime} + if sqlResult, err := s.GetMaster().Exec(query, params); err != nil { + result.Err = model.NewAppError("SqlChannelMemberHistoryStore.LogLeaveEvent", "store.sql_channel_member_history.log_leave_event.update_error", nil, err.Error(), http.StatusInternalServerError) + } else if rows, err := sqlResult.RowsAffected(); err == nil && rows != 1 { + // there was no join event to update + l4g.Warn("Channel join event for user %v and channel %v not found", userId, channelId) + } + }) +} + +func (s SqlChannelMemberHistoryStore) GetUsersInChannelDuring(startTime int64, endTime int64, channelId string) store.StoreChannel { + return store.Do(func(result *store.StoreResult) { + query := ` + SELECT + cmh.*, + u.Email + FROM ChannelMemberHistory cmh + INNER JOIN Users u ON cmh.UserId = u.Id + WHERE cmh.ChannelId = :ChannelId + AND cmh.JoinTime <= :EndTime + AND (cmh.LeaveTime IS NULL OR cmh.LeaveTime >= :StartTime) + ORDER BY cmh.JoinTime ASC` + + params := map[string]interface{}{"ChannelId": channelId, "StartTime": startTime, "EndTime": endTime} + var histories []*model.ChannelMemberHistory + if _, err := s.GetReplica().Select(&histories, query, params); err != nil { + result.Err = model.NewAppError("SqlChannelMemberHistoryStore.GetUsersInChannelAt", "store.sql_channel_member_history.get_users_in_channel_during.app_error", params, err.Error(), http.StatusInternalServerError) + } else { + result.Data = histories + } + }) +} + +func (s SqlChannelMemberHistoryStore) PurgeHistoryBefore(time int64, channelId string) store.StoreChannel { + return store.Do(func(result *store.StoreResult) { + query := ` + DELETE FROM ChannelMemberHistory + WHERE ChannelId = :ChannelId + AND LeaveTime IS NOT NULL + AND LeaveTime <= :AtTime` + + params := map[string]interface{}{"AtTime": time, "ChannelId": channelId} + if _, err := s.GetMaster().Exec(query, params); err != nil { + result.Err = model.NewAppError("SqlChannelMemberHistoryStore.PurgeHistoryBefore", "store.sql_channel_member_history.purge_history_before.app_error", params, err.Error(), http.StatusInternalServerError) + } + }) +} |