mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-26 06:39:11 +00:00 
			
		
		
		
	feat(v2): register user u2f (#6020)
This commit is contained in:
		| @@ -3,13 +3,13 @@ package user | ||||
| import ( | ||||
| 	"context" | ||||
|  | ||||
| 	"google.golang.org/protobuf/encoding/protojson" | ||||
| 	"google.golang.org/protobuf/types/known/structpb" | ||||
|  | ||||
| 	"github.com/zitadel/zitadel/internal/api/authz" | ||||
| 	"github.com/zitadel/zitadel/internal/api/grpc/object/v2" | ||||
| 	"github.com/zitadel/zitadel/internal/domain" | ||||
| 	caos_errs "github.com/zitadel/zitadel/internal/errors" | ||||
| 	object_pb "github.com/zitadel/zitadel/pkg/grpc/object/v2alpha" | ||||
| 	user "github.com/zitadel/zitadel/pkg/grpc/user/v2alpha" | ||||
| ) | ||||
|  | ||||
| @@ -41,24 +41,32 @@ func passkeyAuthenticatorToDomain(pa user.PasskeyAuthenticator) domain.Authentic | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func passkeyRegistrationDetailsToPb(details *domain.PasskeyRegistrationDetails, err error) (*user.RegisterPasskeyResponse, error) { | ||||
| func webAuthNRegistrationDetailsToPb(details *domain.WebAuthNRegistrationDetails, err error) (*object_pb.Details, *structpb.Struct, error) { | ||||
| 	if err != nil { | ||||
| 		return nil, nil, err | ||||
| 	} | ||||
| 	options := new(structpb.Struct) | ||||
| 	if err := options.UnmarshalJSON(details.PublicKeyCredentialCreationOptions); err != nil { | ||||
| 		return nil, nil, caos_errs.ThrowInternal(err, "USERv2-Dohr6", "Errors.Internal") | ||||
| 	} | ||||
| 	return object.DomainToDetailsPb(details.ObjectDetails), options, nil | ||||
| } | ||||
|  | ||||
| func passkeyRegistrationDetailsToPb(details *domain.WebAuthNRegistrationDetails, err error) (*user.RegisterPasskeyResponse, error) { | ||||
| 	objectDetails, options, err := webAuthNRegistrationDetailsToPb(details, err) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	options := new(structpb.Struct) | ||||
| 	if err := protojson.Unmarshal(details.PublicKeyCredentialCreationOptions, options); err != nil { | ||||
| 		return nil, caos_errs.ThrowInternal(err, "USERv2-Dohr6", "Errors.Internal") | ||||
| 	} | ||||
| 	return &user.RegisterPasskeyResponse{ | ||||
| 		Details:                            object.DomainToDetailsPb(details.ObjectDetails), | ||||
| 		PasskeyId:                          details.PasskeyID, | ||||
| 		Details:                            objectDetails, | ||||
| 		PasskeyId:                          details.ID, | ||||
| 		PublicKeyCredentialCreationOptions: options, | ||||
| 	}, nil | ||||
| } | ||||
|  | ||||
| func (s *Server) VerifyPasskeyRegistration(ctx context.Context, req *user.VerifyPasskeyRegistrationRequest) (*user.VerifyPasskeyRegistrationResponse, error) { | ||||
| 	resourceOwner := authz.GetCtxData(ctx).ResourceOwner | ||||
| 	pkc, err := protojson.Marshal(req.GetPublicKeyCredential()) | ||||
| 	pkc, err := req.GetPublicKeyCredential().MarshalJSON() | ||||
| 	if err != nil { | ||||
| 		return nil, caos_errs.ThrowInternal(err, "USERv2-Pha2o", "Errors.Internal") | ||||
| 	} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Tim Möhlmann
					Tim Möhlmann