summaryrefslogtreecommitdiffstats
path: root/api/slackimport.go
diff options
context:
space:
mode:
authorChristopher Speller <crspeller@gmail.com>2016-04-28 16:29:13 -0400
committerJoram Wilander <jwawilander@gmail.com>2016-04-28 16:29:13 -0400
commitf3fa435a1b35c2ada4cd9a81744a41904fe97909 (patch)
tree4044a07b7c7345084e4543282f165d4c5e716f80 /api/slackimport.go
parent938caa061d4f5aad00133926c86d3d6f4485b3a2 (diff)
downloadchat-f3fa435a1b35c2ada4cd9a81744a41904fe97909.tar.gz
chat-f3fa435a1b35c2ada4cd9a81744a41904fe97909.tar.bz2
chat-f3fa435a1b35c2ada4cd9a81744a41904fe97909.zip
Fixing slack import. (#2819)
Diffstat (limited to 'api/slackimport.go')
-rw-r--r--api/slackimport.go25
1 files changed, 24 insertions, 1 deletions
diff --git a/api/slackimport.go b/api/slackimport.go
index 4319fe409..df43e1a8b 100644
--- a/api/slackimport.go
+++ b/api/slackimport.go
@@ -99,6 +99,16 @@ func SlackAddUsers(teamId string, slackusers []SlackUser, log *bytes.Buffer) map
log.WriteString("===============\r\n\r\n")
addedUsers := make(map[string]*model.User)
+
+ // Need the team
+ var team *model.Team
+ if result := <-Srv.Store.Team().Get(teamId); result.Err != nil {
+ log.WriteString(utils.T("api.slackimport.slack_import.team_fail"))
+ return addedUsers
+ } else {
+ team = result.Data.(*model.Team)
+ }
+
for _, sUser := range slackusers {
firstName := ""
lastName := ""
@@ -119,7 +129,7 @@ func SlackAddUsers(teamId string, slackusers []SlackUser, log *bytes.Buffer) map
Password: password,
}
- if mUser := ImportUser(teamId, &newUser); mUser != nil {
+ if mUser := ImportUser(team, &newUser); mUser != nil {
addedUsers[sUser.Id] = mUser
log.WriteString(utils.T("api.slackimport.slack_add_users.email_pwd", map[string]interface{}{"Email": newUser.Email, "Password": password}))
} else {
@@ -173,6 +183,18 @@ func SlackAddPosts(channel *model.Channel, posts []SlackPost, users map[string]*
}
}
+func addSlackUsersToChannel(members []string, users map[string]*model.User, channel *model.Channel, log *bytes.Buffer) {
+ for _, member := range members {
+ if user, ok := users[member]; !ok {
+ log.WriteString(utils.T("api.slackimport.slack_add_channels.failed_to_add_user", map[string]interface{}{"Username": "?"}))
+ } else {
+ if _, err := AddUserToChannel(user, channel); err != nil {
+ log.WriteString(utils.T("api.slackimport.slack_add_channels.failed_to_add_user", map[string]interface{}{"Username": user.Username}))
+ }
+ }
+ }
+}
+
func SlackAddChannels(teamId string, slackchannels []SlackChannel, posts map[string][]SlackPost, users map[string]*model.User, log *bytes.Buffer) map[string]*model.Channel {
// Write Header
log.WriteString(utils.T("api.slackimport.slack_add_channels.added"))
@@ -199,6 +221,7 @@ func SlackAddChannels(teamId string, slackchannels []SlackChannel, posts map[str
log.WriteString(utils.T("api.slackimport.slack_add_channels.merge", map[string]interface{}{"DisplayName": newChannel.DisplayName}))
}
}
+ addSlackUsersToChannel(sChannel.Members, users, mChannel, log)
log.WriteString(newChannel.DisplayName + "\r\n")
addedChannels[sChannel.Id] = mChannel
SlackAddPosts(mChannel, posts[sChannel.Name], users)