summaryrefslogtreecommitdiffstats
path: root/cmd
diff options
context:
space:
mode:
authorGeorge Goldberg <george@gberg.me>2017-09-04 18:54:24 +0100
committerGitHub <noreply@github.com>2017-09-04 18:54:24 +0100
commitba2868775d2476813fb8f48156d5f232a101f39d (patch)
tree78dfe43062f63a34a1749854ea99fb5a8e4542ff /cmd
parent1e78ff831e8aba2ff98dcd85709f06eca006f0a4 (diff)
downloadchat-ba2868775d2476813fb8f48156d5f232a101f39d.tar.gz
chat-ba2868775d2476813fb8f48156d5f232a101f39d.tar.bz2
chat-ba2868775d2476813fb8f48156d5f232a101f39d.zip
PLT-7216: CLI Command to move channels between teams. (#7149)
* PLT-7216: CLI Command to move channels between teams. * Add comment
Diffstat (limited to 'cmd')
-rw-r--r--cmd/platform/channel.go77
1 files changed, 77 insertions, 0 deletions
diff --git a/cmd/platform/channel.go b/cmd/platform/channel.go
index 215d0c863..c9256a37f 100644
--- a/cmd/platform/channel.go
+++ b/cmd/platform/channel.go
@@ -71,6 +71,16 @@ Archived channels are appended with ' (archived)'.`,
RunE: listChannelsCmdF,
}
+var moveChannelsCmd = &cobra.Command{
+ Use: "move [team] [channels]",
+ Short: "Moves channels to the specified team",
+ Long: `Moves the provided channels to the specified team.
+Validates that all users in the channel belong to the target team. Incoming/Outgoing webhooks are moved along with the channel.
+Channels can be specified by [team]:[channel]. ie. myteam:mychannel or by channel ID.`,
+ Example: " channel move newteam oldteam:mychannel",
+ RunE: moveChannelsCmdF,
+}
+
var restoreChannelsCmd = &cobra.Command{
Use: "restore [channels]",
Short: "Restore some channels",
@@ -109,6 +119,7 @@ func init() {
archiveChannelsCmd,
deleteChannelsCmd,
listChannelsCmd,
+ moveChannelsCmd,
restoreChannelsCmd,
modifyChannelCmd,
)
@@ -300,6 +311,72 @@ func deleteChannel(channel *model.Channel) *model.AppError {
return app.PermanentDeleteChannel(channel)
}
+func moveChannelsCmdF(cmd *cobra.Command, args []string) error {
+ if err := initDBCommandContextCobra(cmd); err != nil {
+ return err
+ }
+
+ if len(args) < 2 {
+ return errors.New("Enter the destination team and at least one channel to move.")
+ }
+
+ team := getTeamFromTeamArg(args[0])
+ if team == nil {
+ return errors.New("Unable to find destination team '" + args[0] + "'")
+ }
+
+ channels := getChannelsFromChannelArgs(args[1:])
+ for i, channel := range channels {
+ if channel == nil {
+ CommandPrintErrorln("Unable to find channel '" + args[i] + "'")
+ continue
+ }
+ if err := moveChannel(team, channel); err != nil {
+ CommandPrintErrorln("Unable to move channel '" + channel.Name + "' error: " + err.Error())
+ } else {
+ CommandPrettyPrintln("Moved channel '" + channel.Name + "'")
+ }
+ }
+
+ return nil
+}
+
+func moveChannel(team *model.Team, channel *model.Channel) *model.AppError {
+ oldTeamId := channel.TeamId
+
+ if err := app.MoveChannel(team, channel); err != nil {
+ return err
+ }
+
+ if incomingWebhooks, err := app.GetIncomingWebhooksForTeamPage(oldTeamId, 0, 10000000); err != nil {
+ return err
+ } else {
+ for _, webhook := range incomingWebhooks {
+ if webhook.ChannelId == channel.Id {
+ webhook.TeamId = team.Id
+ if result := <-app.Srv.Store.Webhook().UpdateIncoming(webhook); result.Err != nil {
+ CommandPrintErrorln("Failed to move incoming webhook '" + webhook.Id + "' to new team.")
+ }
+ }
+ }
+ }
+
+ if outgoingWebhooks, err := app.GetOutgoingWebhooksForTeamPage(oldTeamId, 0, 10000000); err != nil {
+ return err
+ } else {
+ for _, webhook := range outgoingWebhooks {
+ if webhook.ChannelId == channel.Id {
+ webhook.TeamId = team.Id
+ if result := <-app.Srv.Store.Webhook().UpdateOutgoing(webhook); result.Err != nil {
+ CommandPrintErrorln("Failed to move outgoing webhook '" + webhook.Id + "' to new team.")
+ }
+ }
+ }
+ }
+
+ return nil
+}
+
func listChannelsCmdF(cmd *cobra.Command, args []string) error {
if err := initDBCommandContextCobra(cmd); err != nil {
return err