summaryrefslogtreecommitdiffstats
path: root/app/post.go
diff options
context:
space:
mode:
authorJoram Wilander <jwawilander@gmail.com>2017-04-04 15:17:47 -0400
committerChristopher Speller <crspeller@gmail.com>2017-04-04 15:17:47 -0400
commit97de1d0982ddb4818f5e41527f4d7da2234e829f (patch)
treecd48347c553b954eea8cca6daec689cbe02249f4 /app/post.go
parent1fa3f2351c98e4d1b9c198e357d90ac0d436dcaa (diff)
downloadchat-97de1d0982ddb4818f5e41527f4d7da2234e829f.tar.gz
chat-97de1d0982ddb4818f5e41527f4d7da2234e829f.tar.bz2
chat-97de1d0982ddb4818f5e41527f4d7da2234e829f.zip
Fix blanking out of FileIds and backwards compatability issue with v3 (#5950)
Diffstat (limited to 'app/post.go')
-rw-r--r--app/post.go33
1 files changed, 15 insertions, 18 deletions
diff --git a/app/post.go b/app/post.go
index 7589a19df..7f38a9bd2 100644
--- a/app/post.go
+++ b/app/post.go
@@ -247,11 +247,10 @@ func SendEphemeralPost(teamId, userId string, post *model.Post) *model.Post {
return post
}
-func UpdatePost(post *model.Post) (*model.Post, *model.AppError) {
+func UpdatePost(post *model.Post, safeUpdate bool) (*model.Post, *model.AppError) {
if utils.IsLicensed {
if *utils.Cfg.ServiceSettings.AllowEditPost == model.ALLOW_EDIT_POST_NEVER {
- err := model.NewLocAppError("updatePost", "api.post.update_post.permissions_denied.app_error", nil, "")
- err.StatusCode = http.StatusForbidden
+ err := model.NewAppError("UpdatePost", "api.post.update_post.permissions_denied.app_error", nil, "", http.StatusForbidden)
return nil, err
}
}
@@ -263,33 +262,28 @@ func UpdatePost(post *model.Post) (*model.Post, *model.AppError) {
oldPost = result.Data.(*model.PostList).Posts[post.Id]
if oldPost == nil {
- err := model.NewLocAppError("updatePost", "api.post.update_post.find.app_error", nil, "id="+post.Id)
- err.StatusCode = http.StatusBadRequest
+ err := model.NewAppError("UpdatePost", "api.post.update_post.find.app_error", nil, "id="+post.Id, http.StatusBadRequest)
return nil, err
}
if oldPost.UserId != post.UserId {
- err := model.NewLocAppError("updatePost", "api.post.update_post.permissions.app_error", nil, "oldUserId="+oldPost.UserId)
- err.StatusCode = http.StatusBadRequest
+ err := model.NewAppError("UpdatePost", "api.post.update_post.permissions.app_error", nil, "oldUserId="+oldPost.UserId, http.StatusBadRequest)
return nil, err
}
if oldPost.DeleteAt != 0 {
- err := model.NewLocAppError("updatePost", "api.post.update_post.permissions_details.app_error", map[string]interface{}{"PostId": post.Id}, "")
- err.StatusCode = http.StatusBadRequest
+ err := model.NewAppError("UpdatePost", "api.post.update_post.permissions_details.app_error", map[string]interface{}{"PostId": post.Id}, "", http.StatusBadRequest)
return nil, err
}
if oldPost.IsSystemMessage() {
- err := model.NewLocAppError("updatePost", "api.post.update_post.system_message.app_error", nil, "id="+post.Id)
- err.StatusCode = http.StatusBadRequest
+ err := model.NewAppError("UpdatePost", "api.post.update_post.system_message.app_error", nil, "id="+post.Id, http.StatusBadRequest)
return nil, err
}
if utils.IsLicensed {
if *utils.Cfg.ServiceSettings.AllowEditPost == model.ALLOW_EDIT_POST_TIME_LIMIT && model.GetMillis() > oldPost.CreateAt+int64(*utils.Cfg.ServiceSettings.PostEditTimeLimit*1000) {
- err := model.NewLocAppError("updatePost", "api.post.update_post.permissions_time_limit.app_error", map[string]interface{}{"timeLimit": *utils.Cfg.ServiceSettings.PostEditTimeLimit}, "")
- err.StatusCode = http.StatusBadRequest
+ err := model.NewAppError("UpdatePost", "api.post.update_post.permissions_time_limit.app_error", map[string]interface{}{"timeLimit": *utils.Cfg.ServiceSettings.PostEditTimeLimit}, "", http.StatusBadRequest)
return nil, err
}
}
@@ -299,12 +293,15 @@ func UpdatePost(post *model.Post) (*model.Post, *model.AppError) {
*newPost = *oldPost
newPost.Message = post.Message
- newPost.Props = post.Props
newPost.EditAt = model.GetMillis()
newPost.Hashtags, _ = model.ParseHashtags(post.Message)
- newPost.IsPinned = post.IsPinned
- newPost.HasReactions = post.HasReactions
- newPost.FileIds = post.FileIds
+
+ if !safeUpdate {
+ newPost.IsPinned = post.IsPinned
+ newPost.HasReactions = post.HasReactions
+ newPost.FileIds = post.FileIds
+ newPost.Props = post.Props
+ }
if result := <-Srv.Store.Post().Update(newPost, oldPost); result.Err != nil {
return nil, result.Err
@@ -327,7 +324,7 @@ func PatchPost(postId string, patch *model.PostPatch) (*model.Post, *model.AppEr
post.Patch(patch)
- updatedPost, err := UpdatePost(post)
+ updatedPost, err := UpdatePost(post, false)
if err != nil {
return nil, err
}