2022-08-25 05:31:57 +03:00
// Copyright 2022 The Gitea Authors. All rights reserved.
2022-11-27 21:20:29 +03:00
// SPDX-License-Identifier: MIT
2022-08-25 05:31:57 +03:00
package organization
import (
2023-09-16 17:39:12 +03:00
"context"
2022-08-25 05:31:57 +03:00
"fmt"
"strings"
"code.gitea.io/gitea/models/db"
repo_model "code.gitea.io/gitea/models/repo"
"code.gitea.io/gitea/models/unit"
user_model "code.gitea.io/gitea/models/user"
"xorm.io/builder"
)
// MinimalOrg represents a simple organization with only the needed columns
type MinimalOrg = Organization
// GetUserOrgsList returns all organizations the given user has access to
2023-09-16 17:39:12 +03:00
func GetUserOrgsList ( ctx context . Context , user * user_model . User ) ( [ ] * MinimalOrg , error ) {
2022-08-25 05:31:57 +03:00
schema , err := db . TableInfo ( new ( user_model . User ) )
if err != nil {
return nil , err
}
outputCols := [ ] string {
"id" ,
"name" ,
"full_name" ,
"visibility" ,
"avatar" ,
"avatar_email" ,
"use_custom_avatar" ,
}
groupByCols := & strings . Builder { }
for _ , col := range outputCols {
fmt . Fprintf ( groupByCols , "`%s`.%s," , schema . Name , col )
}
groupByStr := groupByCols . String ( )
groupByStr = groupByStr [ 0 : len ( groupByStr ) - 1 ]
2023-09-16 17:39:12 +03:00
sess := db . GetEngine ( ctx )
2022-08-25 05:31:57 +03:00
sess = sess . Select ( groupByStr + ", count(distinct repo_id) as org_count" ) .
Table ( "user" ) .
Join ( "INNER" , "team" , "`team`.org_id = `user`.id" ) .
Join ( "INNER" , "team_user" , "`team`.id = `team_user`.team_id" ) .
Join ( "LEFT" , builder .
Select ( "id as repo_id, owner_id as repo_owner_id" ) .
From ( "repository" ) .
Where ( repo_model . AccessibleRepositoryCondition ( user , unit . TypeInvalid ) ) , "`repository`.repo_owner_id = `team`.org_id" ) .
Where ( "`team_user`.uid = ?" , user . ID ) .
GroupBy ( groupByStr )
type OrgCount struct {
Organization ` xorm:"extends" `
OrgCount int
}
orgCounts := make ( [ ] * OrgCount , 0 , 10 )
if err := sess .
Asc ( "`user`.name" ) .
Find ( & orgCounts ) ; err != nil {
return nil , err
}
orgs := make ( [ ] * MinimalOrg , len ( orgCounts ) )
for i , orgCount := range orgCounts {
orgCount . Organization . NumRepos = orgCount . OrgCount
orgs [ i ] = & orgCount . Organization
}
return orgs , nil
}