mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-12 19:13:52 +00:00
3f345b1ade
* fix: org tests * fix: org tests * fix: user grant test * fix: user grant test * fix: project and project role test * fix: project grant test * fix: project grant test * fix: project member, grant member, app changed tests * fix: application tests * fix: application tests * fix: add oidc app test * fix: add oidc app test * fix: add api keys test * fix: iam policies * fix: iam and org member tests * fix: idp config tests * fix: iam tests * fix: user tests * fix: user tests * fix: user tests * fix: user tests * fix: user tests * fix: user tests * fix: user tests * fix: user tests * fix: user tests * fix: user tests * fix: org domain test * fix: org tests * fix: org tests * fix: implement org idps * fix: pr requests * fix: email tests * fix: fix idp check * fix: fix user profile
146 lines
4.2 KiB
Go
146 lines
4.2 KiB
Go
package command
|
|
|
|
import (
|
|
"github.com/caos/zitadel/internal/domain"
|
|
"github.com/caos/zitadel/internal/repository/user"
|
|
)
|
|
|
|
func writeModelToHuman(wm *HumanWriteModel) *domain.Human {
|
|
human := &domain.Human{
|
|
ObjectRoot: writeModelToObjectRoot(wm.WriteModel),
|
|
Username: wm.UserName,
|
|
State: wm.UserState,
|
|
Profile: &domain.Profile{
|
|
FirstName: wm.FirstName,
|
|
LastName: wm.LastName,
|
|
NickName: wm.NickName,
|
|
DisplayName: wm.DisplayName,
|
|
PreferredLanguage: wm.PreferredLanguage,
|
|
Gender: wm.Gender,
|
|
},
|
|
Email: &domain.Email{
|
|
EmailAddress: wm.Email,
|
|
IsEmailVerified: wm.IsEmailVerified,
|
|
},
|
|
}
|
|
if wm.Phone != "" {
|
|
human.Phone = &domain.Phone{
|
|
PhoneNumber: wm.Phone,
|
|
}
|
|
}
|
|
if wm.Country != "" || wm.Locality != "" || wm.PostalCode != "" || wm.Region != "" || wm.StreetAddress != "" {
|
|
human.Address = &domain.Address{
|
|
Country: wm.Country,
|
|
Locality: wm.Locality,
|
|
PostalCode: wm.PostalCode,
|
|
Region: wm.Region,
|
|
StreetAddress: wm.StreetAddress,
|
|
}
|
|
}
|
|
return human
|
|
}
|
|
|
|
func writeModelToProfile(wm *HumanProfileWriteModel) *domain.Profile {
|
|
return &domain.Profile{
|
|
ObjectRoot: writeModelToObjectRoot(wm.WriteModel),
|
|
FirstName: wm.FirstName,
|
|
LastName: wm.LastName,
|
|
NickName: wm.NickName,
|
|
DisplayName: wm.DisplayName,
|
|
PreferredLanguage: wm.PreferredLanguage,
|
|
Gender: wm.Gender,
|
|
}
|
|
}
|
|
|
|
func writeModelToEmail(wm *HumanEmailWriteModel) *domain.Email {
|
|
return &domain.Email{
|
|
ObjectRoot: writeModelToObjectRoot(wm.WriteModel),
|
|
EmailAddress: wm.Email,
|
|
IsEmailVerified: wm.IsEmailVerified,
|
|
}
|
|
}
|
|
|
|
func writeModelToPhone(wm *HumanPhoneWriteModel) *domain.Phone {
|
|
return &domain.Phone{
|
|
ObjectRoot: writeModelToObjectRoot(wm.WriteModel),
|
|
PhoneNumber: wm.Phone,
|
|
IsPhoneVerified: wm.IsPhoneVerified,
|
|
}
|
|
}
|
|
func writeModelToAddress(wm *HumanAddressWriteModel) *domain.Address {
|
|
return &domain.Address{
|
|
ObjectRoot: writeModelToObjectRoot(wm.WriteModel),
|
|
Country: wm.Country,
|
|
Locality: wm.Locality,
|
|
PostalCode: wm.PostalCode,
|
|
Region: wm.Region,
|
|
StreetAddress: wm.StreetAddress,
|
|
}
|
|
}
|
|
|
|
func writeModelToMachine(wm *MachineWriteModel) *domain.Machine {
|
|
return &domain.Machine{
|
|
ObjectRoot: writeModelToObjectRoot(wm.WriteModel),
|
|
Username: wm.UserName,
|
|
Name: wm.Name,
|
|
Description: wm.Description,
|
|
State: wm.UserState,
|
|
}
|
|
}
|
|
|
|
func keyWriteModelToMachineKey(wm *MachineKeyWriteModel) *domain.MachineKey {
|
|
return &domain.MachineKey{
|
|
ObjectRoot: writeModelToObjectRoot(wm.WriteModel),
|
|
KeyID: wm.KeyID,
|
|
Type: wm.KeyType,
|
|
ExpirationDate: wm.ExpirationDate,
|
|
}
|
|
}
|
|
|
|
func readModelToU2FTokens(wm *HumanU2FTokensReadModel) []*domain.WebAuthNToken {
|
|
tokens := make([]*domain.WebAuthNToken, len(wm.WebAuthNTokens))
|
|
for i, token := range wm.WebAuthNTokens {
|
|
tokens[i] = writeModelToWebAuthN(token)
|
|
}
|
|
return tokens
|
|
}
|
|
|
|
func readModelToPasswordlessTokens(wm *HumanPasswordlessTokensReadModel) []*domain.WebAuthNToken {
|
|
tokens := make([]*domain.WebAuthNToken, len(wm.WebAuthNTokens))
|
|
for i, token := range wm.WebAuthNTokens {
|
|
tokens[i] = writeModelToWebAuthN(token)
|
|
}
|
|
return tokens
|
|
}
|
|
|
|
func writeModelToWebAuthN(wm *HumanWebAuthNWriteModel) *domain.WebAuthNToken {
|
|
return &domain.WebAuthNToken{
|
|
ObjectRoot: writeModelToObjectRoot(wm.WriteModel),
|
|
WebAuthNTokenID: wm.WebauthNTokenID,
|
|
Challenge: wm.Challenge,
|
|
KeyID: wm.KeyID,
|
|
PublicKey: wm.PublicKey,
|
|
AttestationType: wm.AttestationType,
|
|
AAGUID: wm.AAGUID,
|
|
SignCount: wm.SignCount,
|
|
WebAuthNTokenName: wm.WebAuthNTokenName,
|
|
State: wm.State,
|
|
}
|
|
}
|
|
|
|
func authRequestDomainToAuthRequestInfo(authRequest *domain.AuthRequest) *user.AuthRequestInfo {
|
|
info := &user.AuthRequestInfo{
|
|
ID: authRequest.ID,
|
|
UserAgentID: authRequest.AgentID,
|
|
SelectedIDPConfigID: authRequest.SelectedIDPConfigID,
|
|
}
|
|
if authRequest.BrowserInfo != nil {
|
|
info.BrowserInfo = &user.BrowserInfo{
|
|
UserAgent: authRequest.BrowserInfo.UserAgent,
|
|
AcceptLanguage: authRequest.BrowserInfo.AcceptLanguage,
|
|
RemoteIP: authRequest.BrowserInfo.RemoteIP,
|
|
}
|
|
}
|
|
return info
|
|
}
|