2020-08-26 07:56:23 +00:00
|
|
|
package management
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2021-01-20 10:06:52 +00:00
|
|
|
|
2020-08-26 07:56:23 +00:00
|
|
|
"github.com/golang/protobuf/ptypes/empty"
|
|
|
|
|
2021-01-20 10:06:52 +00:00
|
|
|
"github.com/caos/zitadel/internal/api/authz"
|
2020-08-26 07:56:23 +00:00
|
|
|
"github.com/caos/zitadel/pkg/grpc/management"
|
|
|
|
)
|
|
|
|
|
|
|
|
func (s *Server) IdpByID(ctx context.Context, id *management.IdpID) (*management.IdpView, error) {
|
|
|
|
config, err := s.org.IDPConfigByID(ctx, id.Id)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return idpViewFromModel(config), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Server) CreateOidcIdp(ctx context.Context, oidcIdpConfig *management.OidcIdpConfigCreate) (*management.Idp, error) {
|
2021-01-20 10:06:52 +00:00
|
|
|
config, err := s.command.AddIDPConfig(ctx, createOidcIdpToDomain(oidcIdpConfig))
|
2020-08-26 07:56:23 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2021-01-20 10:06:52 +00:00
|
|
|
return idpFromDomain(config), nil
|
2020-08-26 07:56:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Server) UpdateIdpConfig(ctx context.Context, idpConfig *management.IdpUpdate) (*management.Idp, error) {
|
2021-01-20 10:06:52 +00:00
|
|
|
config, err := s.command.ChangeIDPConfig(ctx, updateIdpToDomain(ctx, idpConfig))
|
2020-08-26 07:56:23 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2021-01-20 10:06:52 +00:00
|
|
|
return idpFromDomain(config), nil
|
2020-08-26 07:56:23 +00:00
|
|
|
}
|
|
|
|
|
2021-01-20 10:06:52 +00:00
|
|
|
func (s *Server) DeactivateIdpConfig(ctx context.Context, id *management.IdpID) (*empty.Empty, error) {
|
|
|
|
err := s.command.DeactivateIDPConfig(ctx, id.Id, authz.GetCtxData(ctx).OrgID)
|
|
|
|
return &empty.Empty{}, err
|
2020-08-26 07:56:23 +00:00
|
|
|
}
|
|
|
|
|
2021-01-20 10:06:52 +00:00
|
|
|
func (s *Server) ReactivateIdpConfig(ctx context.Context, id *management.IdpID) (*empty.Empty, error) {
|
|
|
|
err := s.command.ReactivateIDPConfig(ctx, id.Id, authz.GetCtxData(ctx).OrgID)
|
|
|
|
return &empty.Empty{}, err
|
2020-08-26 07:56:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Server) RemoveIdpConfig(ctx context.Context, id *management.IdpID) (*empty.Empty, error) {
|
2021-01-20 10:06:52 +00:00
|
|
|
err := s.command.RemoveIDPConfig(ctx, id.Id, authz.GetCtxData(ctx).OrgID)
|
2020-08-26 07:56:23 +00:00
|
|
|
return &empty.Empty{}, err
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Server) UpdateOidcIdpConfig(ctx context.Context, request *management.OidcIdpConfigUpdate) (*management.OidcIdpConfig, error) {
|
2021-01-20 10:06:52 +00:00
|
|
|
config, err := s.command.ChangeIDPOIDCConfig(ctx, updateOidcIdpToDomain(ctx, request))
|
2020-08-26 07:56:23 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2021-01-20 10:06:52 +00:00
|
|
|
return oidcIdpConfigFromDomain(config), nil
|
2020-08-26 07:56:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Server) SearchIdps(ctx context.Context, request *management.IdpSearchRequest) (*management.IdpSearchResponse, error) {
|
2020-10-20 12:26:19 +00:00
|
|
|
searchRequest, err := idpConfigSearchRequestToModel(request)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
response, err := s.org.SearchIDPConfigs(ctx, searchRequest)
|
2020-08-26 07:56:23 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return idpConfigSearchResponseFromModel(response), nil
|
|
|
|
}
|