mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-26 00:01:20 -04:00 
			
		
		
		
	`RepoTransfer` now is at models, but if we want to move it into `repo` model, it will depend on `Team`. So this PR also makes repo model depend on org model to make it possible. Just refactor, no code change. - [x] Move `DeleteOrganization` from `models/organization` to service layer - [x] Move `AccessibleTeamReposEnv` to `models/repo` - [x] Move `RepoTransfer` from `models` to `models/repo` - [x] Merge `getUserTeamIDs` and `GetUserTeamIDs`, Merge `GetUserTeams` and `getUserTeams`. - [x] Remove `Team`'s `Repos []*repo_model.Repository` to avoid dependency recycle.
		
			
				
	
	
		
			74 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2022 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package organization
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models/db"
 | |
| 	"code.gitea.io/gitea/models/perm"
 | |
| 	"code.gitea.io/gitea/models/unit"
 | |
| )
 | |
| 
 | |
| // TeamRepo represents an team-repository relation.
 | |
| type TeamRepo struct {
 | |
| 	ID     int64 `xorm:"pk autoincr"`
 | |
| 	OrgID  int64 `xorm:"INDEX"`
 | |
| 	TeamID int64 `xorm:"UNIQUE(s)"`
 | |
| 	RepoID int64 `xorm:"UNIQUE(s)"`
 | |
| }
 | |
| 
 | |
| // HasTeamRepo returns true if given repository belongs to team.
 | |
| func HasTeamRepo(ctx context.Context, orgID, teamID, repoID int64) bool {
 | |
| 	has, _ := db.GetEngine(ctx).
 | |
| 		Where("org_id=?", orgID).
 | |
| 		And("team_id=?", teamID).
 | |
| 		And("repo_id=?", repoID).
 | |
| 		Get(new(TeamRepo))
 | |
| 	return has
 | |
| }
 | |
| 
 | |
| // AddTeamRepo adds a repo for an organization's team
 | |
| func AddTeamRepo(ctx context.Context, orgID, teamID, repoID int64) error {
 | |
| 	_, err := db.GetEngine(ctx).Insert(&TeamRepo{
 | |
| 		OrgID:  orgID,
 | |
| 		TeamID: teamID,
 | |
| 		RepoID: repoID,
 | |
| 	})
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| // RemoveTeamRepo remove repository from team
 | |
| func RemoveTeamRepo(ctx context.Context, teamID, repoID int64) error {
 | |
| 	_, err := db.DeleteByBean(ctx, &TeamRepo{
 | |
| 		TeamID: teamID,
 | |
| 		RepoID: repoID,
 | |
| 	})
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| // GetTeamsWithAccessToRepo returns all teams in an organization that have given access level to the repository.
 | |
| func GetTeamsWithAccessToRepo(ctx context.Context, orgID, repoID int64, mode perm.AccessMode) ([]*Team, error) {
 | |
| 	teams := make([]*Team, 0, 5)
 | |
| 	return teams, db.GetEngine(ctx).Where("team.authorize >= ?", mode).
 | |
| 		Join("INNER", "team_repo", "team_repo.team_id = team.id").
 | |
| 		And("team_repo.org_id = ?", orgID).
 | |
| 		And("team_repo.repo_id = ?", repoID).
 | |
| 		OrderBy("name").
 | |
| 		Find(&teams)
 | |
| }
 | |
| 
 | |
| // GetTeamsWithAccessToRepoUnit returns all teams in an organization that have given access level to the repository special unit.
 | |
| func GetTeamsWithAccessToRepoUnit(ctx context.Context, orgID, repoID int64, mode perm.AccessMode, unitType unit.Type) ([]*Team, error) {
 | |
| 	teams := make([]*Team, 0, 5)
 | |
| 	return teams, db.GetEngine(ctx).Where("team_unit.access_mode >= ?", mode).
 | |
| 		Join("INNER", "team_repo", "team_repo.team_id = team.id").
 | |
| 		Join("INNER", "team_unit", "team_unit.team_id = team.id").
 | |
| 		And("team_repo.org_id = ?", orgID).
 | |
| 		And("team_repo.repo_id = ?", repoID).
 | |
| 		And("team_unit.type = ?", unitType).
 | |
| 		OrderBy("name").
 | |
| 		Find(&teams)
 | |
| }
 |