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.

org.go 2.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. // Copyright 2014 The Gogs Authors. All rights reserved.
  2. // Copyright 2019 The Gitea Authors. All rights reserved.
  3. // SPDX-License-Identifier: MIT
  4. package models
  5. import (
  6. "context"
  7. "fmt"
  8. "code.gitea.io/gitea/models/db"
  9. "code.gitea.io/gitea/models/organization"
  10. access_model "code.gitea.io/gitea/models/perm/access"
  11. repo_model "code.gitea.io/gitea/models/repo"
  12. )
  13. // RemoveOrgUser removes user from given organization.
  14. func RemoveOrgUser(ctx context.Context, orgID, userID int64) error {
  15. ou := new(organization.OrgUser)
  16. has, err := db.GetEngine(ctx).
  17. Where("uid=?", userID).
  18. And("org_id=?", orgID).
  19. Get(ou)
  20. if err != nil {
  21. return fmt.Errorf("get org-user: %w", err)
  22. } else if !has {
  23. return nil
  24. }
  25. org, err := organization.GetOrgByID(ctx, orgID)
  26. if err != nil {
  27. return fmt.Errorf("GetUserByID [%d]: %w", orgID, err)
  28. }
  29. // Check if the user to delete is the last member in owner team.
  30. if isOwner, err := organization.IsOrganizationOwner(ctx, orgID, userID); err != nil {
  31. return err
  32. } else if isOwner {
  33. t, err := organization.GetOwnerTeam(ctx, org.ID)
  34. if err != nil {
  35. return err
  36. }
  37. if t.NumMembers == 1 {
  38. if err := t.LoadMembers(ctx); err != nil {
  39. return err
  40. }
  41. if t.Members[0].ID == userID {
  42. return organization.ErrLastOrgOwner{UID: userID}
  43. }
  44. }
  45. }
  46. ctx, committer, err := db.TxContext(ctx)
  47. if err != nil {
  48. return err
  49. }
  50. defer committer.Close()
  51. if _, err := db.DeleteByID[organization.OrgUser](ctx, ou.ID); err != nil {
  52. return err
  53. } else if _, err = db.Exec(ctx, "UPDATE `user` SET num_members=num_members-1 WHERE id=?", orgID); err != nil {
  54. return err
  55. }
  56. // Delete all repository accesses and unwatch them.
  57. env, err := organization.AccessibleReposEnv(ctx, org, userID)
  58. if err != nil {
  59. return fmt.Errorf("AccessibleReposEnv: %w", err)
  60. }
  61. repoIDs, err := env.RepoIDs(1, org.NumRepos)
  62. if err != nil {
  63. return fmt.Errorf("GetUserRepositories [%d]: %w", userID, err)
  64. }
  65. for _, repoID := range repoIDs {
  66. if err = repo_model.WatchRepo(ctx, userID, repoID, false); err != nil {
  67. return err
  68. }
  69. }
  70. if len(repoIDs) > 0 {
  71. if _, err = db.GetEngine(ctx).
  72. Where("user_id = ?", userID).
  73. In("repo_id", repoIDs).
  74. Delete(new(access_model.Access)); err != nil {
  75. return err
  76. }
  77. }
  78. // Delete member in their teams.
  79. teams, err := organization.GetUserOrgTeams(ctx, org.ID, userID)
  80. if err != nil {
  81. return err
  82. }
  83. for _, t := range teams {
  84. if err = removeTeamMember(ctx, t, userID); err != nil {
  85. return err
  86. }
  87. }
  88. return committer.Commit()
  89. }