gitea源码

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. // Copyright 2021 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package repo
  4. import (
  5. "context"
  6. "fmt"
  7. "time"
  8. "code.gitea.io/gitea/models/db"
  9. user_model "code.gitea.io/gitea/models/user"
  10. "code.gitea.io/gitea/modules/log"
  11. "code.gitea.io/gitea/modules/util"
  12. )
  13. // UpdateRepositoryOwnerNames updates repository owner_names (this should only be used when the ownerName has changed case)
  14. func UpdateRepositoryOwnerNames(ctx context.Context, ownerID int64, ownerName string) error {
  15. if ownerID == 0 {
  16. return nil
  17. }
  18. if _, err := db.GetEngine(ctx).Where("owner_id = ?", ownerID).Cols("owner_name").NoAutoTime().Update(&Repository{
  19. OwnerName: ownerName,
  20. }); err != nil {
  21. return err
  22. }
  23. return nil
  24. }
  25. // UpdateRepositoryUpdatedTime updates a repository's updated time
  26. func UpdateRepositoryUpdatedTime(ctx context.Context, repoID int64, updateTime time.Time) error {
  27. _, err := db.GetEngine(ctx).Exec("UPDATE repository SET updated_unix = ? WHERE id = ?", updateTime.Unix(), repoID)
  28. return err
  29. }
  30. // UpdateRepositoryColsWithAutoTime updates repository's columns and the timestamp fields automatically
  31. func UpdateRepositoryColsWithAutoTime(ctx context.Context, repo *Repository, colName string, moreColNames ...string) error {
  32. _, err := db.GetEngine(ctx).ID(repo.ID).Cols(append([]string{colName}, moreColNames...)...).Update(repo)
  33. return err
  34. }
  35. // UpdateRepositoryColsNoAutoTime updates repository's columns, doesn't change timestamp field automatically
  36. func UpdateRepositoryColsNoAutoTime(ctx context.Context, repo *Repository, colName string, moreColNames ...string) error {
  37. _, err := db.GetEngine(ctx).ID(repo.ID).Cols(append([]string{colName}, moreColNames...)...).NoAutoTime().Update(repo)
  38. return err
  39. }
  40. // ErrReachLimitOfRepo represents a "ReachLimitOfRepo" kind of error.
  41. type ErrReachLimitOfRepo struct {
  42. Limit int
  43. }
  44. // IsErrReachLimitOfRepo checks if an error is a ErrReachLimitOfRepo.
  45. func IsErrReachLimitOfRepo(err error) bool {
  46. _, ok := err.(ErrReachLimitOfRepo)
  47. return ok
  48. }
  49. func (err ErrReachLimitOfRepo) Error() string {
  50. return fmt.Sprintf("user has reached maximum limit of repositories [limit: %d]", err.Limit)
  51. }
  52. func (err ErrReachLimitOfRepo) Unwrap() error {
  53. return util.ErrPermissionDenied
  54. }
  55. // ErrRepoAlreadyExist represents a "RepoAlreadyExist" kind of error.
  56. type ErrRepoAlreadyExist struct {
  57. Uname string
  58. Name string
  59. }
  60. // IsErrRepoAlreadyExist checks if an error is a ErrRepoAlreadyExist.
  61. func IsErrRepoAlreadyExist(err error) bool {
  62. _, ok := err.(ErrRepoAlreadyExist)
  63. return ok
  64. }
  65. func (err ErrRepoAlreadyExist) Error() string {
  66. return fmt.Sprintf("repository already exists [uname: %s, name: %s]", err.Uname, err.Name)
  67. }
  68. func (err ErrRepoAlreadyExist) Unwrap() error {
  69. return util.ErrAlreadyExist
  70. }
  71. // ErrRepoFilesAlreadyExist represents a "RepoFilesAlreadyExist" kind of error.
  72. type ErrRepoFilesAlreadyExist struct {
  73. Uname string
  74. Name string
  75. }
  76. // IsErrRepoFilesAlreadyExist checks if an error is a ErrRepoAlreadyExist.
  77. func IsErrRepoFilesAlreadyExist(err error) bool {
  78. _, ok := err.(ErrRepoFilesAlreadyExist)
  79. return ok
  80. }
  81. func (err ErrRepoFilesAlreadyExist) Error() string {
  82. return fmt.Sprintf("repository files already exist [uname: %s, name: %s]", err.Uname, err.Name)
  83. }
  84. func (err ErrRepoFilesAlreadyExist) Unwrap() error {
  85. return util.ErrAlreadyExist
  86. }
  87. // CheckCreateRepository check if doer could create a repository in new owner
  88. func CheckCreateRepository(ctx context.Context, doer, owner *user_model.User, name string, overwriteOrAdopt bool) error {
  89. if !doer.CanCreateRepoIn(owner) {
  90. return ErrReachLimitOfRepo{owner.MaxRepoCreation}
  91. }
  92. if err := IsUsableRepoName(name); err != nil {
  93. return err
  94. }
  95. has, err := IsRepositoryModelOrDirExist(ctx, owner, name)
  96. if err != nil {
  97. return fmt.Errorf("IsRepositoryExist: %w", err)
  98. } else if has {
  99. return ErrRepoAlreadyExist{owner.Name, name}
  100. }
  101. repoPath := RepoPath(owner.Name, name)
  102. isExist, err := util.IsExist(repoPath)
  103. if err != nil {
  104. log.Error("Unable to check if %s exists. Error: %v", repoPath, err)
  105. return err
  106. }
  107. if !overwriteOrAdopt && isExist {
  108. return ErrRepoFilesAlreadyExist{owner.Name, name}
  109. }
  110. return nil
  111. }
  112. // UpdateRepoSize updates the repository size, calculating it using getDirectorySize
  113. func UpdateRepoSize(ctx context.Context, repoID, gitSize, lfsSize int64) error {
  114. _, err := db.GetEngine(ctx).ID(repoID).Cols("size", "git_size", "lfs_size").NoAutoTime().Update(&Repository{
  115. Size: gitSize + lfsSize,
  116. GitSize: gitSize,
  117. LFSSize: lfsSize,
  118. })
  119. return err
  120. }