You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

v292.go 1.9KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. // Copyright 2024 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package v1_22 //nolint
  4. import (
  5. "code.gitea.io/gitea/models/project"
  6. "code.gitea.io/gitea/modules/setting"
  7. "xorm.io/builder"
  8. "xorm.io/xorm"
  9. )
  10. // CheckProjectColumnsConsistency ensures there is exactly one default board per project present
  11. func CheckProjectColumnsConsistency(x *xorm.Engine) error {
  12. sess := x.NewSession()
  13. defer sess.Close()
  14. if err := sess.Begin(); err != nil {
  15. return err
  16. }
  17. limit := setting.Database.IterateBufferSize
  18. if limit <= 0 {
  19. limit = 50
  20. }
  21. start := 0
  22. for {
  23. var projects []project.Project
  24. if err := sess.SQL("SELECT DISTINCT `p`.`id`, `p`.`creator_id` FROM `project` `p` WHERE (SELECT COUNT(*) FROM `project_board` `pb` WHERE `pb`.`project_id` = `p`.`id` AND `pb`.`default` = ?) != 1", true).
  25. Limit(limit, start).
  26. Find(&projects); err != nil {
  27. return err
  28. }
  29. if len(projects) == 0 {
  30. break
  31. }
  32. start += len(projects)
  33. for _, p := range projects {
  34. var boards []project.Board
  35. if err := sess.Where("project_id=? AND `default` = ?", p.ID, true).OrderBy("sorting").Find(&boards); err != nil {
  36. return err
  37. }
  38. if len(boards) == 0 {
  39. if _, err := sess.Insert(project.Board{
  40. ProjectID: p.ID,
  41. Default: true,
  42. Title: "Uncategorized",
  43. CreatorID: p.CreatorID,
  44. }); err != nil {
  45. return err
  46. }
  47. continue
  48. }
  49. var boardsToUpdate []int64
  50. for id, b := range boards {
  51. if id > 0 {
  52. boardsToUpdate = append(boardsToUpdate, b.ID)
  53. }
  54. }
  55. if _, err := sess.Where(builder.Eq{"project_id": p.ID}.And(builder.In("id", boardsToUpdate))).
  56. Cols("`default`").Update(&project.Board{Default: false}); err != nil {
  57. return err
  58. }
  59. }
  60. if start%1000 == 0 {
  61. if err := sess.Commit(); err != nil {
  62. return err
  63. }
  64. if err := sess.Begin(); err != nil {
  65. return err
  66. }
  67. }
  68. }
  69. return sess.Commit()
  70. }