mirror of
https://github.com/go-gitea/gitea
synced 2025-01-07 00:14:25 +00:00
parent
d45456b1b5
commit
fe32ffe181
@ -592,26 +592,26 @@ func (c *Comment) LoadAttachments(ctx context.Context) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// UpdateAttachments update attachments by UUIDs for the comment
|
// UpdateCommentAttachments update attachments by UUIDs for the comment
|
||||||
func (c *Comment) UpdateAttachments(ctx context.Context, uuids []string) error {
|
func UpdateCommentAttachments(ctx context.Context, c *Comment, uuids []string) error {
|
||||||
ctx, committer, err := db.TxContext(ctx)
|
if len(uuids) == 0 {
|
||||||
if err != nil {
|
return nil
|
||||||
return err
|
|
||||||
}
|
}
|
||||||
defer committer.Close()
|
return db.WithTx(ctx, func(ctx context.Context) error {
|
||||||
|
attachments, err := repo_model.GetAttachmentsByUUIDs(ctx, uuids)
|
||||||
attachments, err := repo_model.GetAttachmentsByUUIDs(ctx, uuids)
|
if err != nil {
|
||||||
if err != nil {
|
return fmt.Errorf("getAttachmentsByUUIDs [uuids: %v]: %w", uuids, err)
|
||||||
return fmt.Errorf("getAttachmentsByUUIDs [uuids: %v]: %w", uuids, err)
|
|
||||||
}
|
|
||||||
for i := 0; i < len(attachments); i++ {
|
|
||||||
attachments[i].IssueID = c.IssueID
|
|
||||||
attachments[i].CommentID = c.ID
|
|
||||||
if err := repo_model.UpdateAttachment(ctx, attachments[i]); err != nil {
|
|
||||||
return fmt.Errorf("update attachment [id: %d]: %w", attachments[i].ID, err)
|
|
||||||
}
|
}
|
||||||
}
|
for i := 0; i < len(attachments); i++ {
|
||||||
return committer.Commit()
|
attachments[i].IssueID = c.IssueID
|
||||||
|
attachments[i].CommentID = c.ID
|
||||||
|
if err := repo_model.UpdateAttachment(ctx, attachments[i]); err != nil {
|
||||||
|
return fmt.Errorf("update attachment [id: %d]: %w", attachments[i].ID, err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
c.Attachments = attachments
|
||||||
|
return nil
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// LoadAssigneeUserAndTeam if comment.Type is CommentTypeAssignees, then load assignees
|
// LoadAssigneeUserAndTeam if comment.Type is CommentTypeAssignees, then load assignees
|
||||||
@ -878,7 +878,7 @@ func updateCommentInfos(ctx context.Context, opts *CreateCommentOptions, comment
|
|||||||
// Check comment type.
|
// Check comment type.
|
||||||
switch opts.Type {
|
switch opts.Type {
|
||||||
case CommentTypeCode:
|
case CommentTypeCode:
|
||||||
if err = updateAttachments(ctx, opts, comment); err != nil {
|
if err = UpdateCommentAttachments(ctx, comment, opts.Attachments); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if comment.ReviewID != 0 {
|
if comment.ReviewID != 0 {
|
||||||
@ -898,7 +898,7 @@ func updateCommentInfos(ctx context.Context, opts *CreateCommentOptions, comment
|
|||||||
}
|
}
|
||||||
fallthrough
|
fallthrough
|
||||||
case CommentTypeReview:
|
case CommentTypeReview:
|
||||||
if err = updateAttachments(ctx, opts, comment); err != nil {
|
if err = UpdateCommentAttachments(ctx, comment, opts.Attachments); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
case CommentTypeReopen, CommentTypeClose:
|
case CommentTypeReopen, CommentTypeClose:
|
||||||
@ -910,23 +910,6 @@ func updateCommentInfos(ctx context.Context, opts *CreateCommentOptions, comment
|
|||||||
return UpdateIssueCols(ctx, opts.Issue, "updated_unix")
|
return UpdateIssueCols(ctx, opts.Issue, "updated_unix")
|
||||||
}
|
}
|
||||||
|
|
||||||
func updateAttachments(ctx context.Context, opts *CreateCommentOptions, comment *Comment) error {
|
|
||||||
attachments, err := repo_model.GetAttachmentsByUUIDs(ctx, opts.Attachments)
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("getAttachmentsByUUIDs [uuids: %v]: %w", opts.Attachments, err)
|
|
||||||
}
|
|
||||||
for i := range attachments {
|
|
||||||
attachments[i].IssueID = opts.Issue.ID
|
|
||||||
attachments[i].CommentID = comment.ID
|
|
||||||
// No assign value could be 0, so ignore AllCols().
|
|
||||||
if _, err = db.GetEngine(ctx).ID(attachments[i].ID).Update(attachments[i]); err != nil {
|
|
||||||
return fmt.Errorf("update attachment [%d]: %w", attachments[i].ID, err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
comment.Attachments = attachments
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func createDeadlineComment(ctx context.Context, doer *user_model.User, issue *Issue, newDeadlineUnix timeutil.TimeStamp) (*Comment, error) {
|
func createDeadlineComment(ctx context.Context, doer *user_model.User, issue *Issue, newDeadlineUnix timeutil.TimeStamp) (*Comment, error) {
|
||||||
var content string
|
var content string
|
||||||
var commentType CommentType
|
var commentType CommentType
|
||||||
|
@ -45,6 +45,24 @@ func TestCreateComment(t *testing.T) {
|
|||||||
unittest.AssertInt64InRange(t, now, then, int64(updatedIssue.UpdatedUnix))
|
unittest.AssertInt64InRange(t, now, then, int64(updatedIssue.UpdatedUnix))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func Test_UpdateCommentAttachment(t *testing.T) {
|
||||||
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
||||||
|
|
||||||
|
comment := unittest.AssertExistsAndLoadBean(t, &issues_model.Comment{ID: 1})
|
||||||
|
attachment := repo_model.Attachment{
|
||||||
|
Name: "test.txt",
|
||||||
|
}
|
||||||
|
assert.NoError(t, db.Insert(db.DefaultContext, &attachment))
|
||||||
|
|
||||||
|
err := issues_model.UpdateCommentAttachments(db.DefaultContext, comment, []string{attachment.UUID})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
|
||||||
|
attachment2 := unittest.AssertExistsAndLoadBean(t, &repo_model.Attachment{ID: attachment.ID})
|
||||||
|
assert.EqualValues(t, attachment.Name, attachment2.Name)
|
||||||
|
assert.EqualValues(t, comment.ID, attachment2.CommentID)
|
||||||
|
assert.EqualValues(t, comment.IssueID, attachment2.IssueID)
|
||||||
|
}
|
||||||
|
|
||||||
func TestFetchCodeComments(t *testing.T) {
|
func TestFetchCodeComments(t *testing.T) {
|
||||||
assert.NoError(t, unittest.PrepareTestDatabase())
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
||||||
|
|
||||||
|
@ -405,19 +405,10 @@ func NewIssueWithIndex(ctx context.Context, doer *user_model.User, opts NewIssue
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(opts.Attachments) > 0 {
|
if err := UpdateIssueAttachments(ctx, opts.Issue.ID, opts.Attachments); err != nil {
|
||||||
attachments, err := repo_model.GetAttachmentsByUUIDs(ctx, opts.Attachments)
|
return err
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("getAttachmentsByUUIDs [uuids: %v]: %w", opts.Attachments, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
for i := 0; i < len(attachments); i++ {
|
|
||||||
attachments[i].IssueID = opts.Issue.ID
|
|
||||||
if _, err = e.ID(attachments[i].ID).Update(attachments[i]); err != nil {
|
|
||||||
return fmt.Errorf("update attachment [id: %d]: %w", attachments[i].ID, err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if err = opts.Issue.LoadAttributes(ctx); err != nil {
|
if err = opts.Issue.LoadAttributes(ctx); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -602,7 +602,7 @@ func updateAttachments(ctx *context.Context, item any, files []string) error {
|
|||||||
case *issues_model.Issue:
|
case *issues_model.Issue:
|
||||||
err = issues_model.UpdateIssueAttachments(ctx, content.ID, files)
|
err = issues_model.UpdateIssueAttachments(ctx, content.ID, files)
|
||||||
case *issues_model.Comment:
|
case *issues_model.Comment:
|
||||||
err = content.UpdateAttachments(ctx, files)
|
err = issues_model.UpdateCommentAttachments(ctx, content, files)
|
||||||
default:
|
default:
|
||||||
return fmt.Errorf("unknown Type: %T", content)
|
return fmt.Errorf("unknown Type: %T", content)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user