mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-06 13:37:40 +00:00
f3e6f3b23b
* feat(command): remove org * refactor: imports, unused code, error handling * reduce org removed in action * add org deletion to projections * add org removal to projections * add org removal to projections * org removed projection * lint import * projections * fix: table names in tests * fix: table names in tests * logging * add org state * fix(domain): add Owner removed to object details * feat(ListQuery): add with owner removed * fix(org-delete): add bool to functions to select with owner removed * fix(org-delete): add bools to user grants with events to determine if dependencies lost owner * fix(org-delete): add unit tests for owner removed and org removed events * fix(org-delete): add handling of org remove for grants and members * fix(org-delete): correction of unit tests for owner removed * fix(org-delete): update projections, unit tests and get functions * fix(org-delete): add change date to authnkeys and owner removed to org metadata * fix(org-delete): include owner removed for login names * fix(org-delete): some column fixes in projections and build for queries with owner removed * indexes * fix(org-delete): include review changes * fix(org-delete): change user projection name after merge * fix(org-delete): include review changes for project grant where no project owner is necessary * fix(org-delete): include auth and adminapi tables with owner removed information * fix(org-delete): cleanup username and orgdomain uniqueconstraints when org is removed * fix(org-delete): add permissions for org.remove * remove unnecessary unique constraints * fix column order in primary keys * fix(org-delete): include review changes * fix(org-delete): add owner removed indexes and chang setup step to create tables * fix(org-delete): move PK order of instance_id and change added user_grant from review * fix(org-delete): no params for prepareUserQuery * change to step 6 * merge main * fix(org-delete): OldUserName rename to private * fix linting * cleanup * fix: remove org test * create prerelease * chore: delete org-delete as prerelease Co-authored-by: Stefan Benz <stefan@caos.ch> Co-authored-by: Livio Spring <livio.a@gmail.com> Co-authored-by: Fabi <38692350+hifabienne@users.noreply.github.com> Co-authored-by: Stefan Benz <46600784+stebenz@users.noreply.github.com>
133 lines
3.4 KiB
Go
133 lines
3.4 KiB
Go
package model
|
|
|
|
import (
|
|
"github.com/zitadel/zitadel/internal/domain"
|
|
caos_errors "github.com/zitadel/zitadel/internal/errors"
|
|
|
|
"time"
|
|
)
|
|
|
|
type IDPProviderView struct {
|
|
AggregateID string
|
|
IDPConfigID string
|
|
IDPProviderType IDPProviderType
|
|
Name string
|
|
StylingType IDPStylingType
|
|
IDPConfigType IdpConfigType
|
|
IDPState IDPConfigState
|
|
|
|
CreationDate time.Time
|
|
ChangeDate time.Time
|
|
Sequence uint64
|
|
}
|
|
|
|
type IDPProviderSearchRequest struct {
|
|
Offset uint64
|
|
Limit uint64
|
|
SortingColumn IDPProviderSearchKey
|
|
Asc bool
|
|
Queries []*IDPProviderSearchQuery
|
|
}
|
|
|
|
type IDPProviderSearchKey int32
|
|
|
|
const (
|
|
IDPProviderSearchKeyUnspecified IDPProviderSearchKey = iota
|
|
IDPProviderSearchKeyAggregateID
|
|
IDPProviderSearchKeyIdpConfigID
|
|
IDPProviderSearchKeyState
|
|
IDPProviderSearchKeyInstanceID
|
|
IDPProviderSearchKeyOwnerRemoved
|
|
)
|
|
|
|
type IDPProviderSearchQuery struct {
|
|
Key IDPProviderSearchKey
|
|
Method domain.SearchMethod
|
|
Value interface{}
|
|
}
|
|
|
|
type IDPProviderSearchResponse struct {
|
|
Offset uint64
|
|
Limit uint64
|
|
TotalResult uint64
|
|
Result []*IDPProviderView
|
|
Sequence uint64
|
|
Timestamp time.Time
|
|
}
|
|
|
|
func (r *IDPProviderSearchRequest) EnsureLimit(limit uint64) error {
|
|
if r.Limit > limit {
|
|
return caos_errors.ThrowInvalidArgument(nil, "SEARCH-3n8fs", "Errors.Limit.ExceedsDefault")
|
|
}
|
|
if r.Limit == 0 {
|
|
r.Limit = limit
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (r *IDPProviderSearchRequest) AppendAggregateIDQuery(aggregateID string) {
|
|
r.Queries = append(r.Queries, &IDPProviderSearchQuery{Key: IDPProviderSearchKeyAggregateID, Method: domain.SearchMethodEquals, Value: aggregateID})
|
|
}
|
|
|
|
func IdpProviderViewsToDomain(idpProviders []*IDPProviderView) []*domain.IDPProvider {
|
|
providers := make([]*domain.IDPProvider, len(idpProviders))
|
|
for i, provider := range idpProviders {
|
|
p := &domain.IDPProvider{
|
|
IDPConfigID: provider.IDPConfigID,
|
|
Type: idpProviderTypeToDomain(provider.IDPProviderType),
|
|
Name: provider.Name,
|
|
IDPConfigType: idpConfigTypeToDomain(provider.IDPConfigType),
|
|
StylingType: idpStylingTypeToDomain(provider.StylingType),
|
|
IDPState: idpStateToDomain(provider.IDPState),
|
|
}
|
|
providers[i] = p
|
|
}
|
|
return providers
|
|
}
|
|
|
|
func idpProviderTypeToDomain(idpType IDPProviderType) domain.IdentityProviderType {
|
|
switch idpType {
|
|
case IDPProviderTypeSystem:
|
|
return domain.IdentityProviderTypeSystem
|
|
case IDPProviderTypeOrg:
|
|
return domain.IdentityProviderTypeOrg
|
|
default:
|
|
return domain.IdentityProviderTypeSystem
|
|
}
|
|
}
|
|
|
|
func idpConfigTypeToDomain(idpType IdpConfigType) domain.IDPConfigType {
|
|
switch idpType {
|
|
case IDPConfigTypeOIDC:
|
|
return domain.IDPConfigTypeOIDC
|
|
case IDPConfigTypeSAML:
|
|
return domain.IDPConfigTypeSAML
|
|
case IDPConfigTypeJWT:
|
|
return domain.IDPConfigTypeJWT
|
|
default:
|
|
return domain.IDPConfigTypeOIDC
|
|
}
|
|
}
|
|
|
|
func idpStylingTypeToDomain(stylingType IDPStylingType) domain.IDPConfigStylingType {
|
|
switch stylingType {
|
|
case IDPStylingTypeGoogle:
|
|
return domain.IDPConfigStylingTypeGoogle
|
|
default:
|
|
return domain.IDPConfigStylingTypeUnspecified
|
|
}
|
|
}
|
|
|
|
func idpStateToDomain(state IDPConfigState) domain.IDPConfigState {
|
|
switch state {
|
|
case IDPConfigStateActive:
|
|
return domain.IDPConfigStateActive
|
|
case IDPConfigStateInactive:
|
|
return domain.IDPConfigStateInactive
|
|
case IDPConfigStateRemoved:
|
|
return domain.IDPConfigStateRemoved
|
|
default:
|
|
return domain.IDPConfigStateActive
|
|
}
|
|
}
|