2024-08-14 17:18:14 +03:00
|
|
|
package webkey
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
2025-04-02 16:53:06 +02:00
|
|
|
"google.golang.org/protobuf/types/known/timestamppb"
|
|
|
|
|
2024-08-14 17:18:14 +03:00
|
|
|
"github.com/zitadel/zitadel/internal/api/authz"
|
|
|
|
"github.com/zitadel/zitadel/internal/telemetry/tracing"
|
|
|
|
"github.com/zitadel/zitadel/internal/zerrors"
|
2025-04-02 16:53:06 +02:00
|
|
|
webkey "github.com/zitadel/zitadel/pkg/grpc/webkey/v2beta"
|
2024-08-14 17:18:14 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
func (s *Server) CreateWebKey(ctx context.Context, req *webkey.CreateWebKeyRequest) (_ *webkey.CreateWebKeyResponse, err error) {
|
|
|
|
ctx, span := tracing.NewSpan(ctx)
|
|
|
|
defer func() { span.EndWithError(err) }()
|
|
|
|
|
|
|
|
if err = checkWebKeyFeature(ctx); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
webKey, err := s.command.CreateWebKey(ctx, createWebKeyRequestToConfig(req))
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &webkey.CreateWebKeyResponse{
|
2025-04-02 16:53:06 +02:00
|
|
|
Id: webKey.KeyID,
|
|
|
|
CreationDate: timestamppb.New(webKey.ObjectDetails.EventDate),
|
2024-08-14 17:18:14 +03:00
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Server) ActivateWebKey(ctx context.Context, req *webkey.ActivateWebKeyRequest) (_ *webkey.ActivateWebKeyResponse, err error) {
|
|
|
|
ctx, span := tracing.NewSpan(ctx)
|
|
|
|
defer func() { span.EndWithError(err) }()
|
|
|
|
|
|
|
|
if err = checkWebKeyFeature(ctx); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
details, err := s.command.ActivateWebKey(ctx, req.GetId())
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &webkey.ActivateWebKeyResponse{
|
2025-04-02 16:53:06 +02:00
|
|
|
ChangeDate: timestamppb.New(details.EventDate),
|
2024-08-14 17:18:14 +03:00
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Server) DeleteWebKey(ctx context.Context, req *webkey.DeleteWebKeyRequest) (_ *webkey.DeleteWebKeyResponse, err error) {
|
|
|
|
ctx, span := tracing.NewSpan(ctx)
|
|
|
|
defer func() { span.EndWithError(err) }()
|
|
|
|
|
|
|
|
if err = checkWebKeyFeature(ctx); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2025-04-02 16:53:06 +02:00
|
|
|
deletedAt, err := s.command.DeleteWebKey(ctx, req.GetId())
|
2024-08-14 17:18:14 +03:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2025-04-02 16:53:06 +02:00
|
|
|
var deletionDate *timestamppb.Timestamp
|
|
|
|
if !deletedAt.IsZero() {
|
|
|
|
deletionDate = timestamppb.New(deletedAt)
|
|
|
|
}
|
2024-08-14 17:18:14 +03:00
|
|
|
return &webkey.DeleteWebKeyResponse{
|
2025-04-02 16:53:06 +02:00
|
|
|
DeletionDate: deletionDate,
|
2024-08-14 17:18:14 +03:00
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Server) ListWebKeys(ctx context.Context, _ *webkey.ListWebKeysRequest) (_ *webkey.ListWebKeysResponse, err error) {
|
|
|
|
ctx, span := tracing.NewSpan(ctx)
|
|
|
|
defer func() { span.EndWithError(err) }()
|
|
|
|
|
|
|
|
if err = checkWebKeyFeature(ctx); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
list, err := s.query.ListWebKeys(ctx)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &webkey.ListWebKeysResponse{
|
2025-04-02 16:53:06 +02:00
|
|
|
WebKeys: webKeyDetailsListToPb(list),
|
2024-08-14 17:18:14 +03:00
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func checkWebKeyFeature(ctx context.Context) error {
|
|
|
|
if !authz.GetFeatures(ctx).WebKey {
|
|
|
|
return zerrors.ThrowPreconditionFailed(nil, "WEBKEY-Ohx6E", "Errors.WebKey.FeatureDisabled")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|