|
@ -535,6 +535,10 @@ func createComment(e *xorm.Session, opts *CreateCommentOptions) (_ *Comment, err |
|
|
return nil, err |
|
|
return nil, err |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if err = updateCommentInfos(e, opts, comment); err != nil { |
|
|
|
|
|
return nil, err |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
if err = sendCreateCommentAction(e, opts, comment); err != nil { |
|
|
if err = sendCreateCommentAction(e, opts, comment); err != nil { |
|
|
return nil, err |
|
|
return nil, err |
|
|
} |
|
|
} |
|
@ -546,19 +550,7 @@ func createComment(e *xorm.Session, opts *CreateCommentOptions) (_ *Comment, err |
|
|
return comment, nil |
|
|
return comment, nil |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func sendCreateCommentAction(e *xorm.Session, opts *CreateCommentOptions, comment *Comment) (err error) { |
|
|
|
|
|
// Compose comment action, could be plain comment, close or reopen issue/pull request.
|
|
|
|
|
|
// This object will be used to notify watchers in the end of function.
|
|
|
|
|
|
act := &Action{ |
|
|
|
|
|
ActUserID: opts.Doer.ID, |
|
|
|
|
|
ActUser: opts.Doer, |
|
|
|
|
|
Content: fmt.Sprintf("%d|%s", opts.Issue.Index, strings.Split(opts.Content, "\n")[0]), |
|
|
|
|
|
RepoID: opts.Repo.ID, |
|
|
|
|
|
Repo: opts.Repo, |
|
|
|
|
|
Comment: comment, |
|
|
|
|
|
CommentID: comment.ID, |
|
|
|
|
|
IsPrivate: opts.Repo.IsPrivate, |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
func updateCommentInfos(e *xorm.Session, opts *CreateCommentOptions, comment *Comment) (err error) { |
|
|
// Check comment type.
|
|
|
// Check comment type.
|
|
|
switch opts.Type { |
|
|
switch opts.Type { |
|
|
case CommentTypeCode: |
|
|
case CommentTypeCode: |
|
@ -574,8 +566,6 @@ func sendCreateCommentAction(e *xorm.Session, opts *CreateCommentOptions, commen |
|
|
} |
|
|
} |
|
|
fallthrough |
|
|
fallthrough |
|
|
case CommentTypeComment: |
|
|
case CommentTypeComment: |
|
|
act.OpType = ActionCommentIssue |
|
|
|
|
|
|
|
|
|
|
|
if _, err = e.Exec("UPDATE `issue` SET num_comments=num_comments+1 WHERE id=?", opts.Issue.ID); err != nil { |
|
|
if _, err = e.Exec("UPDATE `issue` SET num_comments=num_comments+1 WHERE id=?", opts.Issue.ID); err != nil { |
|
|
return err |
|
|
return err |
|
|
} |
|
|
} |
|
@ -601,30 +591,54 @@ func sendCreateCommentAction(e *xorm.Session, opts *CreateCommentOptions, commen |
|
|
return fmt.Errorf("update attachment [%d]: %v", attachments[i].ID, err) |
|
|
return fmt.Errorf("update attachment [%d]: %v", attachments[i].ID, err) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
case CommentTypeReopen, CommentTypeClose: |
|
|
|
|
|
if err = opts.Issue.updateClosedNum(e); err != nil { |
|
|
|
|
|
return err |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
// update the issue's updated_unix column
|
|
|
|
|
|
return updateIssueCols(e, opts.Issue, "updated_unix") |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func sendCreateCommentAction(e *xorm.Session, opts *CreateCommentOptions, comment *Comment) (err error) { |
|
|
|
|
|
// Compose comment action, could be plain comment, close or reopen issue/pull request.
|
|
|
|
|
|
// This object will be used to notify watchers in the end of function.
|
|
|
|
|
|
act := &Action{ |
|
|
|
|
|
ActUserID: opts.Doer.ID, |
|
|
|
|
|
ActUser: opts.Doer, |
|
|
|
|
|
Content: fmt.Sprintf("%d|%s", opts.Issue.Index, strings.Split(opts.Content, "\n")[0]), |
|
|
|
|
|
RepoID: opts.Repo.ID, |
|
|
|
|
|
Repo: opts.Repo, |
|
|
|
|
|
Comment: comment, |
|
|
|
|
|
CommentID: comment.ID, |
|
|
|
|
|
IsPrivate: opts.Repo.IsPrivate, |
|
|
|
|
|
} |
|
|
|
|
|
// Check comment type.
|
|
|
|
|
|
switch opts.Type { |
|
|
|
|
|
case CommentTypeCode: |
|
|
|
|
|
if comment.ReviewID != 0 { |
|
|
|
|
|
if comment.Review == nil { |
|
|
|
|
|
if err := comment.loadReview(e); err != nil { |
|
|
|
|
|
return err |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
if comment.Review.Type <= ReviewTypePending { |
|
|
|
|
|
return nil |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
fallthrough |
|
|
|
|
|
case CommentTypeComment: |
|
|
|
|
|
act.OpType = ActionCommentIssue |
|
|
case CommentTypeReopen: |
|
|
case CommentTypeReopen: |
|
|
act.OpType = ActionReopenIssue |
|
|
act.OpType = ActionReopenIssue |
|
|
if opts.Issue.IsPull { |
|
|
if opts.Issue.IsPull { |
|
|
act.OpType = ActionReopenPullRequest |
|
|
act.OpType = ActionReopenPullRequest |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if err = opts.Issue.updateClosedNum(e); err != nil { |
|
|
|
|
|
return err |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
case CommentTypeClose: |
|
|
case CommentTypeClose: |
|
|
act.OpType = ActionCloseIssue |
|
|
act.OpType = ActionCloseIssue |
|
|
if opts.Issue.IsPull { |
|
|
if opts.Issue.IsPull { |
|
|
act.OpType = ActionClosePullRequest |
|
|
act.OpType = ActionClosePullRequest |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if err = opts.Issue.updateClosedNum(e); err != nil { |
|
|
|
|
|
return err |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
// update the issue's updated_unix column
|
|
|
|
|
|
if err = updateIssueCols(e, opts.Issue, "updated_unix"); err != nil { |
|
|
|
|
|
return err |
|
|
|
|
|
} |
|
|
} |
|
|
// Notify watchers for whatever action comes in, ignore if no action type.
|
|
|
// Notify watchers for whatever action comes in, ignore if no action type.
|
|
|
if act.OpType > 0 { |
|
|
if act.OpType > 0 { |
|
|