package management import ( "github.com/caos/logging" iam_model "github.com/caos/zitadel/internal/iam/model" "github.com/caos/zitadel/pkg/grpc/management" "github.com/golang/protobuf/ptypes" ) func loginPolicyRequestToModel(policy *management.LoginPolicyRequest) *iam_model.LoginPolicy { return &iam_model.LoginPolicy{ AllowUsernamePassword: policy.AllowUsernamePassword, AllowExternalIdp: policy.AllowExternalIdp, AllowRegister: policy.AllowRegister, ForceMFA: policy.ForceMfa, } } func loginPolicyFromModel(policy *iam_model.LoginPolicy) *management.LoginPolicy { creationDate, err := ptypes.TimestampProto(policy.CreationDate) logging.Log("GRPC-2Fsm8").OnError(err).Debug("date parse failed") changeDate, err := ptypes.TimestampProto(policy.ChangeDate) logging.Log("GRPC-3Flo0").OnError(err).Debug("date parse failed") return &management.LoginPolicy{ AllowUsernamePassword: policy.AllowUsernamePassword, AllowExternalIdp: policy.AllowExternalIdp, AllowRegister: policy.AllowRegister, CreationDate: creationDate, ChangeDate: changeDate, ForceMfa: policy.ForceMFA, } } func loginPolicyViewFromModel(policy *iam_model.LoginPolicyView) *management.LoginPolicyView { creationDate, err := ptypes.TimestampProto(policy.CreationDate) logging.Log("GRPC-5Tsm8").OnError(err).Debug("date parse failed") changeDate, err := ptypes.TimestampProto(policy.ChangeDate) logging.Log("GRPC-8dJgs").OnError(err).Debug("date parse failed") return &management.LoginPolicyView{ Default: policy.Default, AllowUsernamePassword: policy.AllowUsernamePassword, AllowExternalIdp: policy.AllowExternalIDP, AllowRegister: policy.AllowRegister, CreationDate: creationDate, ChangeDate: changeDate, ForceMfa: policy.ForceMFA, } } func idpProviderSearchRequestToModel(request *management.IdpProviderSearchRequest) *iam_model.IDPProviderSearchRequest { return &iam_model.IDPProviderSearchRequest{ Limit: request.Limit, Offset: request.Offset, } } func idpProviderSearchResponseFromModel(response *iam_model.IDPProviderSearchResponse) *management.IdpProviderSearchResponse { return &management.IdpProviderSearchResponse{ Limit: response.Limit, Offset: response.Offset, TotalResult: response.TotalResult, Result: idpProviderViewsFromModel(response.Result), } } func idpProviderToModel(provider *management.IdpProviderID) *iam_model.IDPProvider { return &iam_model.IDPProvider{ IdpConfigID: provider.IdpConfigId, Type: iam_model.IDPProviderTypeSystem, } } func idpProviderAddToModel(provider *management.IdpProviderAdd) *iam_model.IDPProvider { return &iam_model.IDPProvider{ IdpConfigID: provider.IdpConfigId, Type: idpProviderTypeToModel(provider.IdpProviderType), } } func idpProviderIDFromModel(provider *iam_model.IDPProvider) *management.IdpProviderID { return &management.IdpProviderID{ IdpConfigId: provider.IdpConfigID, } } func idpProviderFromModel(provider *iam_model.IDPProvider) *management.IdpProvider { return &management.IdpProvider{ IdpConfigId: provider.IdpConfigID, IdpProvider_Type: idpProviderTypeFromModel(provider.Type), } } func idpProviderViewsFromModel(providers []*iam_model.IDPProviderView) []*management.IdpProviderView { converted := make([]*management.IdpProviderView, len(providers)) for i, provider := range providers { converted[i] = idpProviderViewFromModel(provider) } return converted } func idpProviderViewFromModel(provider *iam_model.IDPProviderView) *management.IdpProviderView { return &management.IdpProviderView{ IdpConfigId: provider.IDPConfigID, Name: provider.Name, Type: idpConfigTypeToModel(provider.IDPConfigType), } } func idpConfigTypeToModel(providerType iam_model.IdpConfigType) management.IdpType { switch providerType { case iam_model.IDPConfigTypeOIDC: return management.IdpType_IDPTYPE_OIDC case iam_model.IDPConfigTypeSAML: return management.IdpType_IDPTYPE_SAML default: return management.IdpType_IDPTYPE_UNSPECIFIED } } func idpProviderTypeToModel(providerType management.IdpProviderType) iam_model.IDPProviderType { switch providerType { case management.IdpProviderType_IDPPROVIDERTYPE_SYSTEM: return iam_model.IDPProviderTypeSystem case management.IdpProviderType_IDPPROVIDERTYPE_ORG: return iam_model.IDPProviderTypeOrg default: return iam_model.IDPProviderTypeSystem } } func idpProviderTypeFromModel(providerType iam_model.IDPProviderType) management.IdpProviderType { switch providerType { case iam_model.IDPProviderTypeSystem: return management.IdpProviderType_IDPPROVIDERTYPE_SYSTEM case iam_model.IDPProviderTypeOrg: return management.IdpProviderType_IDPPROVIDERTYPE_ORG default: return management.IdpProviderType_IDPPROVIDERTYPE_UNSPECIFIED } } func secondFactorResultFromModel(result *iam_model.SecondFactorsSearchResponse) *management.SecondFactorsResult { converted := make([]management.SecondFactorType, len(result.Result)) for i, mfaType := range result.Result { converted[i] = secondFactorTypeFromModel(mfaType) } return &management.SecondFactorsResult{ SecondFactors: converted, } } func secondFactorFromModel(mfaType iam_model.SecondFactorType) *management.SecondFactor { return &management.SecondFactor{ SecondFactor: secondFactorTypeFromModel(mfaType), } } func secondFactorTypeFromModel(mfaType iam_model.SecondFactorType) management.SecondFactorType { switch mfaType { case iam_model.SecondFactorTypeOTP: return management.SecondFactorType_SECONDFACTORTYPE_OTP case iam_model.SecondFactorTypeU2F: return management.SecondFactorType_SECONDFACTORTYPE_U2F default: return management.SecondFactorType_SECONDFACTORTYPE_UNSPECIFIED } } func secondFactorTypeToModel(mfaType *management.SecondFactor) iam_model.SecondFactorType { switch mfaType.SecondFactor { case management.SecondFactorType_SECONDFACTORTYPE_OTP: return iam_model.SecondFactorTypeOTP case management.SecondFactorType_SECONDFACTORTYPE_U2F: return iam_model.SecondFactorTypeU2F default: return iam_model.SecondFactorTypeUnspecified } } func multiFactorResultFromModel(result *iam_model.MultiFactorsSearchResponse) *management.MultiFactorsResult { converted := make([]management.MultiFactorType, len(result.Result)) for i, mfaType := range result.Result { converted[i] = multiFactorTypeFromModel(mfaType) } return &management.MultiFactorsResult{ MultiFactors: converted, } } func multiFactorFromModel(mfaType iam_model.MultiFactorType) *management.MultiFactor { return &management.MultiFactor{ MultiFactor: multiFactorTypeFromModel(mfaType), } } func multiFactorTypeFromModel(mfaType iam_model.MultiFactorType) management.MultiFactorType { switch mfaType { case iam_model.MultiFactorTypeU2FWithPIN: return management.MultiFactorType_MULTIFACTORTYPE_U2F_WITH_PIN default: return management.MultiFactorType_MULTIFACTORTYPE_UNSPECIFIED } } func multiFactorTypeToModel(mfaType *management.MultiFactor) iam_model.MultiFactorType { switch mfaType.MultiFactor { case management.MultiFactorType_MULTIFACTORTYPE_U2F_WITH_PIN: return iam_model.MultiFactorTypeU2FWithPIN default: return iam_model.MultiFactorTypeUnspecified } }