mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-30 22:11:07 +00:00 
			
		
		
		
	This PR replaces unnecessary calls to formatting functions (`fmt.Printf`, `fmt.Errorf`, ...) by non-formatting equivalents. Resolves #7967 Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/7994 Reviewed-by: Gusted <gusted@noreply.codeberg.org> Co-authored-by: chavacava <chavacava@noreply.codeberg.org> Co-committed-by: chavacava <chavacava@noreply.codeberg.org>
		
			
				
	
	
		
			158 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			158 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2019 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package issue
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"errors"
 | |
| 	"fmt"
 | |
| 
 | |
| 	"forgejo.org/models/db"
 | |
| 	issues_model "forgejo.org/models/issues"
 | |
| 	repo_model "forgejo.org/models/repo"
 | |
| 	user_model "forgejo.org/models/user"
 | |
| 	"forgejo.org/modules/timeutil"
 | |
| 	notify_service "forgejo.org/services/notify"
 | |
| )
 | |
| 
 | |
| // CreateRefComment creates a commit reference comment to issue.
 | |
| func CreateRefComment(ctx context.Context, doer *user_model.User, repo *repo_model.Repository, issue *issues_model.Issue, content, commitSHA string) error {
 | |
| 	if len(commitSHA) == 0 {
 | |
| 		return errors.New("cannot create reference with empty commit SHA")
 | |
| 	}
 | |
| 
 | |
| 	// Check if same reference from same commit has already existed.
 | |
| 	has, err := db.GetEngine(ctx).Get(&issues_model.Comment{
 | |
| 		Type:      issues_model.CommentTypeCommitRef,
 | |
| 		IssueID:   issue.ID,
 | |
| 		CommitSHA: commitSHA,
 | |
| 	})
 | |
| 	if err != nil {
 | |
| 		return fmt.Errorf("check reference comment: %w", err)
 | |
| 	} else if has {
 | |
| 		return nil
 | |
| 	}
 | |
| 
 | |
| 	_, err = issues_model.CreateComment(ctx, &issues_model.CreateCommentOptions{
 | |
| 		Type:      issues_model.CommentTypeCommitRef,
 | |
| 		Doer:      doer,
 | |
| 		Repo:      repo,
 | |
| 		Issue:     issue,
 | |
| 		CommitSHA: commitSHA,
 | |
| 		Content:   content,
 | |
| 	})
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| // CreateIssueComment creates a plain issue comment.
 | |
| func CreateIssueComment(ctx context.Context, doer *user_model.User, repo *repo_model.Repository, issue *issues_model.Issue, content string, attachments []string) (*issues_model.Comment, error) {
 | |
| 	// Check if doer is blocked by the poster of the issue or by the owner of the repository.
 | |
| 	if user_model.IsBlockedMultiple(ctx, []int64{issue.PosterID, repo.OwnerID}, doer.ID) {
 | |
| 		return nil, user_model.ErrBlockedByUser
 | |
| 	}
 | |
| 
 | |
| 	comment, err := issues_model.CreateComment(ctx, &issues_model.CreateCommentOptions{
 | |
| 		Type:        issues_model.CommentTypeComment,
 | |
| 		Doer:        doer,
 | |
| 		Repo:        repo,
 | |
| 		Issue:       issue,
 | |
| 		Content:     content,
 | |
| 		Attachments: attachments,
 | |
| 	})
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	mentions, err := issues_model.FindAndUpdateIssueMentions(ctx, issue, doer, comment.Content)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	notify_service.CreateIssueComment(ctx, doer, repo, issue, comment, mentions)
 | |
| 
 | |
| 	return comment, nil
 | |
| }
 | |
| 
 | |
| // UpdateComment updates information of comment.
 | |
| func UpdateComment(ctx context.Context, c *issues_model.Comment, contentVersion int, doer *user_model.User, oldContent string) error {
 | |
| 	if err := c.LoadReview(ctx); err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	isPartOfPendingReview := c.Review != nil && c.Review.Type == issues_model.ReviewTypePending
 | |
| 
 | |
| 	needsContentHistory := c.Content != oldContent && c.Type.HasContentSupport() && !isPartOfPendingReview
 | |
| 	if needsContentHistory {
 | |
| 		hasContentHistory, err := issues_model.HasIssueContentHistory(ctx, c.IssueID, c.ID)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 		if !hasContentHistory {
 | |
| 			if err = issues_model.SaveIssueContentHistory(ctx, c.PosterID, c.IssueID, c.ID,
 | |
| 				c.CreatedUnix, oldContent, true); err != nil {
 | |
| 				return err
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if err := issues_model.UpdateComment(ctx, c, contentVersion, doer); err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	if needsContentHistory {
 | |
| 		historyDate := timeutil.TimeStampNow()
 | |
| 		if c.Issue.NoAutoTime {
 | |
| 			historyDate = c.Issue.UpdatedUnix
 | |
| 		}
 | |
| 		err := issues_model.SaveIssueContentHistory(ctx, doer.ID, c.IssueID, c.ID, historyDate, c.Content, false)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if !isPartOfPendingReview {
 | |
| 		notify_service.UpdateComment(ctx, doer, c, oldContent)
 | |
| 	}
 | |
| 
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // DeleteComment deletes the comment
 | |
| func DeleteComment(ctx context.Context, doer *user_model.User, comment *issues_model.Comment) error {
 | |
| 	err := db.WithTx(ctx, func(ctx context.Context) error {
 | |
| 		reviewID := comment.ReviewID
 | |
| 
 | |
| 		err := issues_model.DeleteComment(ctx, comment)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 
 | |
| 		if comment.Review != nil {
 | |
| 			reviewType := comment.Review.Type
 | |
| 			if reviewType == issues_model.ReviewTypePending {
 | |
| 				found, err := db.GetEngine(ctx).Table("comment").Where("review_id = ?", reviewID).Exist()
 | |
| 				if err != nil {
 | |
| 					return err
 | |
| 				} else if !found {
 | |
| 					_, err := db.GetEngine(ctx).Table("review").Where("id = ?", reviewID).Delete()
 | |
| 					if err != nil {
 | |
| 						return err
 | |
| 					}
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 		return nil
 | |
| 	})
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	if err := comment.LoadReview(ctx); err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	if comment.Review == nil || comment.Review.Type != issues_model.ReviewTypePending {
 | |
| 		notify_service.DeleteComment(ctx, doer, comment)
 | |
| 	}
 | |
| 
 | |
| 	return nil
 | |
| }
 |