| 
									
										
										
										
											2020-08-21 08:53:14 +01:00
										 |  |  | // Copyright 2020 The Gitea Authors. All rights reserved. | 
					
						
							| 
									
										
										
										
											2022-11-27 13:20:29 -05:00
										 |  |  | // SPDX-License-Identifier: MIT | 
					
						
							| 
									
										
										
										
											2020-08-21 08:53:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-05 18:33:45 +02:00
										 |  |  | package v1_13 | 
					
						
							| 
									
										
										
										
											2020-08-21 08:53:14 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2025-03-27 19:40:14 +00:00
										 |  |  | 	"forgejo.org/modules/timeutil" | 
					
						
							| 
									
										
										
										
											2020-08-21 08:53:14 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	"xorm.io/xorm" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-02 16:54:36 +08:00
										 |  |  | func CreateReviewsForCodeComments(x *xorm.Engine) error { | 
					
						
							| 
									
										
										
										
											2020-08-21 08:53:14 +01:00
										 |  |  | 	// Review | 
					
						
							|  |  |  | 	type Review struct { | 
					
						
							|  |  |  | 		ID               int64 `xorm:"pk autoincr"` | 
					
						
							|  |  |  | 		Type             int | 
					
						
							|  |  |  | 		ReviewerID       int64 `xorm:"index"` | 
					
						
							|  |  |  | 		OriginalAuthor   string | 
					
						
							|  |  |  | 		OriginalAuthorID int64 | 
					
						
							|  |  |  | 		IssueID          int64  `xorm:"index"` | 
					
						
							|  |  |  | 		Content          string `xorm:"TEXT"` | 
					
						
							|  |  |  | 		// Official is a review made by an assigned approver (counts towards approval) | 
					
						
							|  |  |  | 		Official bool   `xorm:"NOT NULL DEFAULT false"` | 
					
						
							|  |  |  | 		CommitID string `xorm:"VARCHAR(40)"` | 
					
						
							|  |  |  | 		Stale    bool   `xorm:"NOT NULL DEFAULT false"` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		CreatedUnix timeutil.TimeStamp `xorm:"INDEX created"` | 
					
						
							|  |  |  | 		UpdatedUnix timeutil.TimeStamp `xorm:"INDEX updated"` | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	const ReviewTypeComment = 2 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Comment represents a comment in commit and issue page. | 
					
						
							|  |  |  | 	type Comment struct { | 
					
						
							|  |  |  | 		ID               int64 `xorm:"pk autoincr"` | 
					
						
							|  |  |  | 		Type             int   `xorm:"INDEX"` | 
					
						
							|  |  |  | 		PosterID         int64 `xorm:"INDEX"` | 
					
						
							|  |  |  | 		OriginalAuthor   string | 
					
						
							|  |  |  | 		OriginalAuthorID int64 | 
					
						
							|  |  |  | 		IssueID          int64 `xorm:"INDEX"` | 
					
						
							|  |  |  | 		LabelID          int64 | 
					
						
							|  |  |  | 		OldProjectID     int64 | 
					
						
							|  |  |  | 		ProjectID        int64 | 
					
						
							|  |  |  | 		OldMilestoneID   int64 | 
					
						
							|  |  |  | 		MilestoneID      int64 | 
					
						
							|  |  |  | 		AssigneeID       int64 | 
					
						
							|  |  |  | 		RemovedAssignee  bool | 
					
						
							|  |  |  | 		ResolveDoerID    int64 | 
					
						
							|  |  |  | 		OldTitle         string | 
					
						
							|  |  |  | 		NewTitle         string | 
					
						
							|  |  |  | 		OldRef           string | 
					
						
							|  |  |  | 		NewRef           string | 
					
						
							|  |  |  | 		DependentIssueID int64 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		CommitID int64 | 
					
						
							|  |  |  | 		Line     int64 // - previous line / + proposed line | 
					
						
							|  |  |  | 		TreePath string | 
					
						
							|  |  |  | 		Content  string `xorm:"TEXT"` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Path represents the 4 lines of code cemented by this comment | 
					
						
							|  |  |  | 		PatchQuoted string `xorm:"TEXT patch"` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		CreatedUnix timeutil.TimeStamp `xorm:"INDEX created"` | 
					
						
							|  |  |  | 		UpdatedUnix timeutil.TimeStamp `xorm:"INDEX updated"` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Reference issue in commit message | 
					
						
							|  |  |  | 		CommitSHA string `xorm:"VARCHAR(40)"` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		ReviewID    int64 `xorm:"index"` | 
					
						
							|  |  |  | 		Invalidated bool | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Reference an issue or pull from another comment, issue or PR | 
					
						
							|  |  |  | 		// All information is about the origin of the reference | 
					
						
							|  |  |  | 		RefRepoID    int64 `xorm:"index"` // Repo where the referencing | 
					
						
							|  |  |  | 		RefIssueID   int64 `xorm:"index"` | 
					
						
							|  |  |  | 		RefCommentID int64 `xorm:"index"`    // 0 if origin is Issue title or content (or PR's) | 
					
						
							| 
									
										
										
										
											2021-07-08 07:38:13 -04:00
										 |  |  | 		RefAction    int   `xorm:"SMALLINT"` // What happens if RefIssueID resolves | 
					
						
							| 
									
										
										
										
											2020-08-21 08:53:14 +01:00
										 |  |  | 		RefIsPull    bool | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-13 21:17:21 +02:00
										 |  |  | 	if err := x.Sync(new(Review), new(Comment)); err != nil { | 
					
						
							| 
									
										
										
										
											2020-08-21 08:53:14 +01:00
										 |  |  | 		return err | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-08-23 01:12:40 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-15 02:52:12 +08:00
										 |  |  | 	updateComment := func(comments []*Comment) error { | 
					
						
							| 
									
										
										
										
											2020-08-23 01:12:40 +08:00
										 |  |  | 		sess := x.NewSession() | 
					
						
							|  |  |  | 		defer sess.Close() | 
					
						
							|  |  |  | 		if err := sess.Begin(); err != nil { | 
					
						
							| 
									
										
										
										
											2020-08-21 08:53:14 +01:00
										 |  |  | 			return err | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-23 01:12:40 +08:00
										 |  |  | 		for _, comment := range comments { | 
					
						
							|  |  |  | 			review := &Review{ | 
					
						
							|  |  |  | 				Type:             ReviewTypeComment, | 
					
						
							|  |  |  | 				ReviewerID:       comment.PosterID, | 
					
						
							|  |  |  | 				IssueID:          comment.IssueID, | 
					
						
							|  |  |  | 				Official:         false, | 
					
						
							|  |  |  | 				CommitID:         comment.CommitSHA, | 
					
						
							|  |  |  | 				Stale:            comment.Invalidated, | 
					
						
							|  |  |  | 				OriginalAuthor:   comment.OriginalAuthor, | 
					
						
							|  |  |  | 				OriginalAuthorID: comment.OriginalAuthorID, | 
					
						
							|  |  |  | 				CreatedUnix:      comment.CreatedUnix, | 
					
						
							|  |  |  | 				UpdatedUnix:      comment.CreatedUnix, | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			if _, err := sess.NoAutoTime().Insert(review); err != nil { | 
					
						
							|  |  |  | 				return err | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			reviewComment := &Comment{ | 
					
						
							|  |  |  | 				Type:             22, | 
					
						
							|  |  |  | 				PosterID:         comment.PosterID, | 
					
						
							|  |  |  | 				Content:          "", | 
					
						
							|  |  |  | 				IssueID:          comment.IssueID, | 
					
						
							|  |  |  | 				ReviewID:         review.ID, | 
					
						
							|  |  |  | 				OriginalAuthor:   comment.OriginalAuthor, | 
					
						
							|  |  |  | 				OriginalAuthorID: comment.OriginalAuthorID, | 
					
						
							|  |  |  | 				CreatedUnix:      comment.CreatedUnix, | 
					
						
							|  |  |  | 				UpdatedUnix:      comment.CreatedUnix, | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			if _, err := sess.NoAutoTime().Insert(reviewComment); err != nil { | 
					
						
							|  |  |  | 				return err | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			comment.ReviewID = review.ID | 
					
						
							|  |  |  | 			if _, err := sess.ID(comment.ID).Cols("review_id").NoAutoTime().Update(comment); err != nil { | 
					
						
							|  |  |  | 				return err | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return sess.Commit() | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-15 02:52:12 +08:00
										 |  |  | 	start := 0 | 
					
						
							|  |  |  | 	batchSize := 100 | 
					
						
							| 
									
										
										
										
											2020-08-23 01:12:40 +08:00
										 |  |  | 	for { | 
					
						
							| 
									
										
										
										
											2021-03-15 02:52:12 +08:00
										 |  |  | 		comments := make([]*Comment, 0, batchSize) | 
					
						
							| 
									
										
										
										
											2020-08-23 01:12:40 +08:00
										 |  |  | 		if err := x.Where("review_id = 0 and type = 21").Limit(batchSize, start).Find(&comments); err != nil { | 
					
						
							|  |  |  | 			return err | 
					
						
							| 
									
										
										
										
											2020-08-21 08:53:14 +01:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2020-08-23 01:12:40 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if err := updateComment(comments); err != nil { | 
					
						
							| 
									
										
										
										
											2020-08-21 08:53:14 +01:00
										 |  |  | 			return err | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-23 01:12:40 +08:00
										 |  |  | 		start += len(comments) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if len(comments) < batchSize { | 
					
						
							|  |  |  | 			break | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2020-08-21 08:53:14 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-23 01:12:40 +08:00
										 |  |  | 	return nil | 
					
						
							| 
									
										
										
										
											2020-08-21 08:53:14 +01:00
										 |  |  | } |