2024-07-26 09:09:08 -05:00
|
|
|
package identity
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"strconv"
|
|
|
|
|
2024-08-15 06:38:43 -05:00
|
|
|
"github.com/grafana/authlib/claims"
|
2024-07-26 09:09:08 -05:00
|
|
|
common "github.com/grafana/grafana/pkg/apimachinery/apis/common/v0alpha1"
|
|
|
|
identity "github.com/grafana/grafana/pkg/apimachinery/apis/identity/v0alpha1"
|
|
|
|
"github.com/grafana/grafana/pkg/apimachinery/utils"
|
2024-08-15 06:38:43 -05:00
|
|
|
"github.com/grafana/grafana/pkg/registry/apis/identity/legacy"
|
2024-07-26 09:09:08 -05:00
|
|
|
"github.com/grafana/grafana/pkg/services/apiserver/endpoints/request"
|
|
|
|
"github.com/grafana/grafana/pkg/services/team"
|
2024-08-15 06:38:43 -05:00
|
|
|
"k8s.io/apimachinery/pkg/apis/meta/internalversion"
|
|
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
|
|
"k8s.io/apimachinery/pkg/runtime"
|
|
|
|
"k8s.io/apiserver/pkg/registry/rest"
|
2024-07-26 09:09:08 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
_ rest.Scoper = (*legacyTeamStorage)(nil)
|
|
|
|
_ rest.SingularNameProvider = (*legacyTeamStorage)(nil)
|
|
|
|
_ rest.Getter = (*legacyTeamStorage)(nil)
|
|
|
|
_ rest.Lister = (*legacyTeamStorage)(nil)
|
|
|
|
_ rest.Storage = (*legacyTeamStorage)(nil)
|
|
|
|
)
|
|
|
|
|
|
|
|
type legacyTeamStorage struct {
|
2024-08-15 06:38:43 -05:00
|
|
|
service legacy.LegacyIdentityStore
|
2024-07-26 09:09:08 -05:00
|
|
|
tableConverter rest.TableConvertor
|
|
|
|
resourceInfo common.ResourceInfo
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *legacyTeamStorage) New() runtime.Object {
|
|
|
|
return s.resourceInfo.NewFunc()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *legacyTeamStorage) Destroy() {}
|
|
|
|
|
|
|
|
func (s *legacyTeamStorage) NamespaceScoped() bool {
|
|
|
|
return true // namespace == org
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *legacyTeamStorage) GetSingularName() string {
|
|
|
|
return s.resourceInfo.GetSingularName()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *legacyTeamStorage) NewList() runtime.Object {
|
|
|
|
return s.resourceInfo.NewListFunc()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *legacyTeamStorage) ConvertToTable(ctx context.Context, object runtime.Object, tableOptions runtime.Object) (*metav1.Table, error) {
|
|
|
|
return s.tableConverter.ConvertToTable(ctx, object, tableOptions)
|
|
|
|
}
|
|
|
|
|
2024-08-15 06:38:43 -05:00
|
|
|
func (s *legacyTeamStorage) doList(ctx context.Context, ns claims.NamespaceInfo, query legacy.ListTeamQuery) (*identity.TeamList, error) {
|
2024-07-26 09:09:08 -05:00
|
|
|
if query.Limit < 1 {
|
|
|
|
query.Limit = 100
|
|
|
|
}
|
2024-08-15 06:38:43 -05:00
|
|
|
|
|
|
|
rsp, err := s.service.ListTeams(ctx, ns, query)
|
2024-07-26 09:09:08 -05:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2024-08-15 06:38:43 -05:00
|
|
|
list := &identity.TeamList{
|
|
|
|
ListMeta: metav1.ListMeta{
|
|
|
|
ResourceVersion: strconv.FormatInt(rsp.RV, 10),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, team := range rsp.Teams {
|
2024-07-26 09:09:08 -05:00
|
|
|
item := identity.Team{
|
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: team.UID,
|
2024-08-15 06:38:43 -05:00
|
|
|
Namespace: ns.Value,
|
2024-07-26 09:09:08 -05:00
|
|
|
CreationTimestamp: metav1.NewTime(team.Created),
|
|
|
|
ResourceVersion: strconv.FormatInt(team.Updated.UnixMilli(), 10),
|
|
|
|
},
|
|
|
|
Spec: identity.TeamSpec{
|
|
|
|
Title: team.Name,
|
|
|
|
Email: team.Email,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
meta, err := utils.MetaAccessor(&item)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
meta.SetUpdatedTimestamp(&team.Updated)
|
|
|
|
meta.SetOriginInfo(&utils.ResourceOriginInfo{
|
|
|
|
Name: "SQL",
|
|
|
|
Path: strconv.FormatInt(team.ID, 10),
|
|
|
|
})
|
|
|
|
list.Items = append(list.Items, item)
|
|
|
|
}
|
2024-08-15 06:38:43 -05:00
|
|
|
if rsp.ContinueID > 0 {
|
|
|
|
list.ListMeta.Continue = strconv.FormatInt(rsp.ContinueID, 10)
|
|
|
|
}
|
2024-07-26 09:09:08 -05:00
|
|
|
return list, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *legacyTeamStorage) List(ctx context.Context, options *internalversion.ListOptions) (runtime.Object, error) {
|
|
|
|
ns, err := request.NamespaceInfoFrom(ctx, true)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2024-08-15 06:38:43 -05:00
|
|
|
query := legacy.ListTeamQuery{
|
2024-07-26 09:09:08 -05:00
|
|
|
OrgID: ns.OrgID,
|
2024-08-15 06:38:43 -05:00
|
|
|
Limit: options.Limit,
|
|
|
|
}
|
|
|
|
if options.Continue != "" {
|
|
|
|
query.ContinueID, err = strconv.ParseInt(options.Continue, 10, 64)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return s.doList(ctx, ns, query)
|
2024-07-26 09:09:08 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *legacyTeamStorage) Get(ctx context.Context, name string, options *metav1.GetOptions) (runtime.Object, error) {
|
|
|
|
ns, err := request.NamespaceInfoFrom(ctx, true)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2024-08-15 06:38:43 -05:00
|
|
|
rsp, err := s.doList(ctx, ns, legacy.ListTeamQuery{
|
2024-07-26 09:09:08 -05:00
|
|
|
OrgID: ns.OrgID,
|
2024-08-15 06:38:43 -05:00
|
|
|
Limit: 1,
|
2024-07-26 09:09:08 -05:00
|
|
|
UID: name,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
if len(rsp.Items) > 0 {
|
|
|
|
return &rsp.Items[0], nil
|
|
|
|
}
|
|
|
|
return nil, s.resourceInfo.NewNotFound(name)
|
|
|
|
}
|
2024-08-15 06:38:43 -05:00
|
|
|
|
|
|
|
func asTeam(team *team.Team, ns string) (*identity.Team, error) {
|
|
|
|
item := &identity.Team{
|
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: team.UID,
|
|
|
|
Namespace: ns,
|
|
|
|
CreationTimestamp: metav1.NewTime(team.Created),
|
|
|
|
ResourceVersion: strconv.FormatInt(team.Updated.UnixMilli(), 10),
|
|
|
|
},
|
|
|
|
Spec: identity.TeamSpec{
|
|
|
|
Title: team.Name,
|
|
|
|
Email: team.Email,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
meta, err := utils.MetaAccessor(item)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
meta.SetUpdatedTimestamp(&team.Updated)
|
|
|
|
meta.SetOriginInfo(&utils.ResourceOriginInfo{
|
|
|
|
Name: "SQL",
|
|
|
|
Path: strconv.FormatInt(team.ID, 10),
|
|
|
|
})
|
|
|
|
return item, nil
|
|
|
|
}
|