mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-02 20:06:06 +01:00 
			
		
		
		
	Change all license headers to comply with REUSE specification. Fix #16132 Co-authored-by: flynnnnnnnnnn <flynnnnnnnnnn@github> Co-authored-by: John Olheiser <john.olheiser@gmail.com>
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			86 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"
 | 
						|
	repo_model "code.gitea.io/gitea/models/repo"
 | 
						|
 | 
						|
	"xorm.io/builder"
 | 
						|
)
 | 
						|
 | 
						|
// 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
 | 
						|
}
 | 
						|
 | 
						|
type SearchTeamRepoOptions struct {
 | 
						|
	db.ListOptions
 | 
						|
	TeamID int64
 | 
						|
}
 | 
						|
 | 
						|
// GetRepositories returns paginated repositories in team of organization.
 | 
						|
func GetTeamRepositories(ctx context.Context, opts *SearchTeamRepoOptions) ([]*repo_model.Repository, error) {
 | 
						|
	sess := db.GetEngine(ctx)
 | 
						|
	if opts.TeamID > 0 {
 | 
						|
		sess = sess.In("id",
 | 
						|
			builder.Select("repo_id").
 | 
						|
				From("team_repo").
 | 
						|
				Where(builder.Eq{"team_id": opts.TeamID}),
 | 
						|
		)
 | 
						|
	}
 | 
						|
	if opts.PageSize > 0 {
 | 
						|
		sess.Limit(opts.PageSize, (opts.Page-1)*opts.PageSize)
 | 
						|
	}
 | 
						|
	var repos []*repo_model.Repository
 | 
						|
	return repos, sess.OrderBy("repository.name").
 | 
						|
		Find(&repos)
 | 
						|
}
 | 
						|
 | 
						|
// 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)
 | 
						|
}
 |