| 
									
										
										
										
											2022-10-22 10:08:10 -05:00
										 |  |  | // Copyright 2022 The Gitea Authors. All rights reserved. | 
					
						
							| 
									
										
										
										
											2022-11-27 13:20:29 -05:00
										 |  |  | // SPDX-License-Identifier: MIT | 
					
						
							| 
									
										
										
										
											2022-10-22 10:08:10 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-05 18:33:45 +02:00
										 |  |  | package v1_18 | 
					
						
							| 
									
										
										
										
											2022-10-22 10:08:10 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-27 19:40:14 +00:00
										 |  |  | 	"forgejo.org/models/issues" | 
					
						
							| 
									
										
										
										
											2022-10-22 10:08:10 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	"xorm.io/builder" | 
					
						
							|  |  |  | 	"xorm.io/xorm" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-02 16:54:36 +08:00
										 |  |  | func UpdateOpenMilestoneCounts(x *xorm.Engine) error { | 
					
						
							| 
									
										
										
										
											2022-10-22 10:08:10 -05:00
										 |  |  | 	var openMilestoneIDs []int64 | 
					
						
							|  |  |  | 	err := x.Table("milestone").Select("id").Where(builder.Neq{"is_closed": 1}).Find(&openMilestoneIDs) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return fmt.Errorf("error selecting open milestone IDs: %w", err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for _, id := range openMilestoneIDs { | 
					
						
							|  |  |  | 		_, err := x.ID(id). | 
					
						
							|  |  |  | 			SetExpr("num_issues", builder.Select("count(*)").From("issue").Where( | 
					
						
							|  |  |  | 				builder.Eq{"milestone_id": id}, | 
					
						
							|  |  |  | 			)). | 
					
						
							|  |  |  | 			SetExpr("num_closed_issues", builder.Select("count(*)").From("issue").Where( | 
					
						
							|  |  |  | 				builder.Eq{ | 
					
						
							|  |  |  | 					"milestone_id": id, | 
					
						
							|  |  |  | 					"is_closed":    true, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			)). | 
					
						
							|  |  |  | 			Update(&issues.Milestone{}) | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			return fmt.Errorf("error updating issue counts in milestone %d: %w", id, err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		_, err = x.Exec("UPDATE `milestone` SET completeness=100*num_closed_issues/(CASE WHEN num_issues > 0 THEN num_issues ELSE 1 END) WHERE id=?", | 
					
						
							|  |  |  | 			id, | 
					
						
							|  |  |  | 		) | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			return fmt.Errorf("error setting completeness on milestone %d: %w", id, err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return nil | 
					
						
							|  |  |  | } |