mirror of
https://github.com/zitadel/zitadel.git
synced 2025-08-11 21:47:32 +00:00
feat: add http as sms provider (#8540)
# Which Problems Are Solved Send SMS messages as a HTTP call to a relay, for own logic on handling different SMS providers. # How the Problems Are Solved Add HTTP as SMS provider type and handling of webhook messages in the notification handlers. # Additional Changes Clean up old Twilio events, which were supposed to handle the general SMS providers with deactivate, activate and remove. # Additional Context Partially closes #8270 --------- Co-authored-by: Livio Spring <livio.a@gmail.com>
This commit is contained in:
@@ -34,23 +34,23 @@ func (s *Server) GetSMSProvider(ctx context.Context, req *admin_pb.GetSMSProvide
|
||||
}
|
||||
|
||||
func (s *Server) AddSMSProviderTwilio(ctx context.Context, req *admin_pb.AddSMSProviderTwilioRequest) (*admin_pb.AddSMSProviderTwilioResponse, error) {
|
||||
id, result, err := s.command.AddSMSConfigTwilio(ctx, authz.GetInstance(ctx).InstanceID(), AddSMSConfigTwilioToConfig(req))
|
||||
if err != nil {
|
||||
smsConfig := addSMSConfigTwilioToConfig(ctx, req)
|
||||
if err := s.command.AddSMSConfigTwilio(ctx, smsConfig); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return &admin_pb.AddSMSProviderTwilioResponse{
|
||||
Details: object.DomainToAddDetailsPb(result),
|
||||
Id: id,
|
||||
Details: object.DomainToAddDetailsPb(smsConfig.Details),
|
||||
Id: smsConfig.ID,
|
||||
}, nil
|
||||
}
|
||||
|
||||
func (s *Server) UpdateSMSProviderTwilio(ctx context.Context, req *admin_pb.UpdateSMSProviderTwilioRequest) (*admin_pb.UpdateSMSProviderTwilioResponse, error) {
|
||||
result, err := s.command.ChangeSMSConfigTwilio(ctx, authz.GetInstance(ctx).InstanceID(), req.Id, UpdateSMSConfigTwilioToConfig(req))
|
||||
if err != nil {
|
||||
smsConfig := updateSMSConfigTwilioToConfig(ctx, req)
|
||||
if err := s.command.ChangeSMSConfigTwilio(ctx, smsConfig); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return &admin_pb.UpdateSMSProviderTwilioResponse{
|
||||
Details: object.DomainToChangeDetailsPb(result),
|
||||
Details: object.DomainToChangeDetailsPb(smsConfig.Details),
|
||||
}, nil
|
||||
}
|
||||
|
||||
@@ -65,6 +65,27 @@ func (s *Server) UpdateSMSProviderTwilioToken(ctx context.Context, req *admin_pb
|
||||
}, nil
|
||||
}
|
||||
|
||||
func (s *Server) AddSMSProviderHTTP(ctx context.Context, req *admin_pb.AddSMSProviderHTTPRequest) (*admin_pb.AddSMSProviderHTTPResponse, error) {
|
||||
smsConfig := addSMSConfigHTTPToConfig(ctx, req)
|
||||
if err := s.command.AddSMSConfigHTTP(ctx, smsConfig); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return &admin_pb.AddSMSProviderHTTPResponse{
|
||||
Details: object.DomainToAddDetailsPb(smsConfig.Details),
|
||||
Id: smsConfig.ID,
|
||||
}, nil
|
||||
}
|
||||
|
||||
func (s *Server) UpdateSMSProviderHTTP(ctx context.Context, req *admin_pb.UpdateSMSProviderHTTPRequest) (*admin_pb.UpdateSMSProviderHTTPResponse, error) {
|
||||
smsConfig := updateSMSConfigHTTPToConfig(ctx, req)
|
||||
if err := s.command.ChangeSMSConfigHTTP(ctx, smsConfig); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return &admin_pb.UpdateSMSProviderHTTPResponse{
|
||||
Details: object.DomainToChangeDetailsPb(smsConfig.Details),
|
||||
}, nil
|
||||
}
|
||||
|
||||
func (s *Server) ActivateSMSProvider(ctx context.Context, req *admin_pb.ActivateSMSProviderRequest) (*admin_pb.ActivateSMSProviderResponse, error) {
|
||||
result, err := s.command.ActivateSMSConfig(ctx, authz.GetInstance(ctx).InstanceID(), req.Id)
|
||||
if err != nil {
|
||||
|
@@ -1,9 +1,14 @@
|
||||
package admin
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
"github.com/muhlemmer/gu"
|
||||
|
||||
"github.com/zitadel/zitadel/internal/api/authz"
|
||||
"github.com/zitadel/zitadel/internal/api/grpc/object"
|
||||
"github.com/zitadel/zitadel/internal/command"
|
||||
"github.com/zitadel/zitadel/internal/domain"
|
||||
"github.com/zitadel/zitadel/internal/notification/channels/twilio"
|
||||
"github.com/zitadel/zitadel/internal/query"
|
||||
admin_pb "github.com/zitadel/zitadel/pkg/grpc/admin"
|
||||
settings_pb "github.com/zitadel/zitadel/pkg/grpc/settings"
|
||||
@@ -30,10 +35,11 @@ func SMSConfigsToPb(configs []*query.SMSConfig) []*settings_pb.SMSProvider {
|
||||
|
||||
func SMSConfigToProviderPb(config *query.SMSConfig) *settings_pb.SMSProvider {
|
||||
return &settings_pb.SMSProvider{
|
||||
Details: object.ToViewDetailsPb(config.Sequence, config.CreationDate, config.ChangeDate, config.ResourceOwner),
|
||||
Id: config.ID,
|
||||
State: smsStateToPb(config.State),
|
||||
Config: SMSConfigToPb(config),
|
||||
Details: object.ToViewDetailsPb(config.Sequence, config.CreationDate, config.ChangeDate, config.ResourceOwner),
|
||||
Id: config.ID,
|
||||
Description: config.Description,
|
||||
State: smsStateToPb(config.State),
|
||||
Config: SMSConfigToPb(config),
|
||||
}
|
||||
}
|
||||
|
||||
@@ -41,9 +47,20 @@ func SMSConfigToPb(config *query.SMSConfig) settings_pb.SMSConfig {
|
||||
if config.TwilioConfig != nil {
|
||||
return TwilioConfigToPb(config.TwilioConfig)
|
||||
}
|
||||
if config.HTTPConfig != nil {
|
||||
return HTTPConfigToPb(config.HTTPConfig)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func HTTPConfigToPb(http *query.HTTP) *settings_pb.SMSProvider_Http {
|
||||
return &settings_pb.SMSProvider_Http{
|
||||
Http: &settings_pb.HTTPConfig{
|
||||
Endpoint: http.Endpoint,
|
||||
},
|
||||
}
|
||||
}
|
||||
|
||||
func TwilioConfigToPb(twilio *query.Twilio) *settings_pb.SMSProvider_Twilio {
|
||||
return &settings_pb.SMSProvider_Twilio{
|
||||
Twilio: &settings_pb.TwilioConfig{
|
||||
@@ -64,17 +81,39 @@ func smsStateToPb(state domain.SMSConfigState) settings_pb.SMSProviderConfigStat
|
||||
}
|
||||
}
|
||||
|
||||
func AddSMSConfigTwilioToConfig(req *admin_pb.AddSMSProviderTwilioRequest) *twilio.Config {
|
||||
return &twilio.Config{
|
||||
SID: req.Sid,
|
||||
SenderNumber: req.SenderNumber,
|
||||
Token: req.Token,
|
||||
func addSMSConfigTwilioToConfig(ctx context.Context, req *admin_pb.AddSMSProviderTwilioRequest) *command.AddTwilioConfig {
|
||||
return &command.AddTwilioConfig{
|
||||
ResourceOwner: authz.GetInstance(ctx).InstanceID(),
|
||||
Description: req.Description,
|
||||
SID: req.Sid,
|
||||
SenderNumber: req.SenderNumber,
|
||||
Token: req.Token,
|
||||
}
|
||||
}
|
||||
|
||||
func UpdateSMSConfigTwilioToConfig(req *admin_pb.UpdateSMSProviderTwilioRequest) *twilio.Config {
|
||||
return &twilio.Config{
|
||||
SID: req.Sid,
|
||||
SenderNumber: req.SenderNumber,
|
||||
func updateSMSConfigTwilioToConfig(ctx context.Context, req *admin_pb.UpdateSMSProviderTwilioRequest) *command.ChangeTwilioConfig {
|
||||
return &command.ChangeTwilioConfig{
|
||||
ResourceOwner: authz.GetInstance(ctx).InstanceID(),
|
||||
ID: req.Id,
|
||||
Description: gu.Ptr(req.Description),
|
||||
SID: gu.Ptr(req.Sid),
|
||||
SenderNumber: gu.Ptr(req.SenderNumber),
|
||||
}
|
||||
}
|
||||
|
||||
func addSMSConfigHTTPToConfig(ctx context.Context, req *admin_pb.AddSMSProviderHTTPRequest) *command.AddSMSHTTP {
|
||||
return &command.AddSMSHTTP{
|
||||
ResourceOwner: authz.GetInstance(ctx).InstanceID(),
|
||||
Description: req.GetDescription(),
|
||||
Endpoint: req.GetEndpoint(),
|
||||
}
|
||||
}
|
||||
|
||||
func updateSMSConfigHTTPToConfig(ctx context.Context, req *admin_pb.UpdateSMSProviderHTTPRequest) *command.ChangeSMSHTTP {
|
||||
return &command.ChangeSMSHTTP{
|
||||
ResourceOwner: authz.GetInstance(ctx).InstanceID(),
|
||||
ID: req.Id,
|
||||
Description: gu.Ptr(req.Description),
|
||||
Endpoint: gu.Ptr(req.Endpoint),
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user