diff options
author | Carlos Tadeu Panato Junior <ctadeu@gmail.com> | 2017-04-03 18:38:26 +0200 |
---|---|---|
committer | George Goldberg <george@gberg.me> | 2017-04-03 17:38:26 +0100 |
commit | 7eb09dbffdd87f36eff0d781eaeb0e816bbdac21 (patch) | |
tree | 0eaffc09d53116322fa5d8d51e0528829f5ab622 /api4/team.go | |
parent | 36c74d7b47253249ec83aedacf409a93de1d182f (diff) | |
download | chat-7eb09dbffdd87f36eff0d781eaeb0e816bbdac21.tar.gz chat-7eb09dbffdd87f36eff0d781eaeb0e816bbdac21.tar.bz2 chat-7eb09dbffdd87f36eff0d781eaeb0e816bbdac21.zip |
[APIV4] POST /teams/{team_id}/import for apiv4 (#5920)
Diffstat (limited to 'api4/team.go')
-rw-r--r-- | api4/team.go | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/api4/team.go b/api4/team.go index 4bca56994..85a083ee1 100644 --- a/api4/team.go +++ b/api4/team.go @@ -4,7 +4,10 @@ package api4 import ( + "bytes" + "io" "net/http" + "strconv" l4g "github.com/alecthomas/log4go" "github.com/mattermost/platform/app" @@ -36,6 +39,8 @@ func InitTeam() { BaseRoutes.TeamMember.Handle("", ApiSessionRequired(getTeamMember)).Methods("GET") BaseRoutes.TeamByName.Handle("/exists", ApiSessionRequired(teamExists)).Methods("GET") BaseRoutes.TeamMember.Handle("/roles", ApiSessionRequired(updateTeamMemberRoles)).Methods("PUT") + + BaseRoutes.Team.Handle("/import", ApiSessionRequired(importTeam)).Methods("POST") } func createTeam(c *Context, w http.ResponseWriter, r *http.Request) { @@ -468,3 +473,77 @@ func teamExists(c *Context, w http.ResponseWriter, r *http.Request) { w.Write([]byte(model.MapBoolToJson(resp))) return } + +func importTeam(c *Context, w http.ResponseWriter, r *http.Request) { + c.RequireTeamId() + if c.Err != nil { + return + } + + if !app.SessionHasPermissionToTeam(c.Session, c.Params.TeamId, model.PERMISSION_IMPORT_TEAM) { + c.SetPermissionError(model.PERMISSION_IMPORT_TEAM) + return + } + + if err := r.ParseMultipartForm(10000000); err != nil { + c.Err = model.NewLocAppError("importTeam", "api.team.import_team.parse.app_error", nil, err.Error()) + return + } + + importFromArray, ok := r.MultipartForm.Value["importFrom"] + importFrom := importFromArray[0] + + fileSizeStr, ok := r.MultipartForm.Value["filesize"] + if !ok { + c.Err = model.NewLocAppError("importTeam", "api.team.import_team.unavailable.app_error", nil, "") + c.Err.StatusCode = http.StatusBadRequest + return + } + + fileSize, err := strconv.ParseInt(fileSizeStr[0], 10, 64) + if err != nil { + c.Err = model.NewLocAppError("importTeam", "api.team.import_team.integer.app_error", nil, "") + c.Err.StatusCode = http.StatusBadRequest + return + } + + fileInfoArray, ok := r.MultipartForm.File["file"] + if !ok { + c.Err = model.NewLocAppError("importTeam", "api.team.import_team.no_file.app_error", nil, "") + c.Err.StatusCode = http.StatusBadRequest + return + } + + if len(fileInfoArray) <= 0 { + c.Err = model.NewLocAppError("importTeam", "api.team.import_team.array.app_error", nil, "") + c.Err.StatusCode = http.StatusBadRequest + return + } + + fileInfo := fileInfoArray[0] + + fileData, err := fileInfo.Open() + defer fileData.Close() + if err != nil { + c.Err = model.NewLocAppError("importTeam", "api.team.import_team.open.app_error", nil, err.Error()) + c.Err.StatusCode = http.StatusBadRequest + return + } + + var log *bytes.Buffer + switch importFrom { + case "slack": + var err *model.AppError + if err, log = app.SlackImport(fileData, fileSize, c.Params.TeamId); err != nil { + c.Err = err + c.Err.StatusCode = http.StatusBadRequest + } + } + + w.Header().Set("Content-Disposition", "attachment; filename=MattermostImportLog.txt") + w.Header().Set("Content-Type", "application/octet-stream") + if c.Err != nil { + w.WriteHeader(c.Err.StatusCode) + } + io.Copy(w, bytes.NewReader(log.Bytes())) +} |