mirror of
https://github.com/zitadel/zitadel.git
synced 2025-08-11 20:47:32 +00:00
feat: add http as smtp provider (#8545)
# Which Problems Are Solved Send Email messages as a HTTP call to a relay, for own logic on handling different Email providers # How the Problems Are Solved Create endpoints under Email provider to manage SMTP and HTTP in the notification handlers. # Additional Changes Clean up old logic in command and query side to handle the general Email 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:
@@ -12,8 +12,20 @@ import (
|
||||
type IAMSMTPConfigWriteModel struct {
|
||||
eventstore.WriteModel
|
||||
|
||||
ID string
|
||||
Description string
|
||||
ID string
|
||||
Description string
|
||||
|
||||
SMTPConfig *SMTPConfig
|
||||
HTTPConfig *HTTPConfig
|
||||
|
||||
State domain.SMTPConfigState
|
||||
|
||||
domain string
|
||||
domainState domain.InstanceDomainState
|
||||
smtpSenderAddressMatchesInstanceDomain bool
|
||||
}
|
||||
|
||||
type SMTPConfig struct {
|
||||
TLS bool
|
||||
Host string
|
||||
User string
|
||||
@@ -21,11 +33,6 @@ type IAMSMTPConfigWriteModel struct {
|
||||
SenderAddress string
|
||||
SenderName string
|
||||
ReplyToAddress string
|
||||
State domain.SMTPConfigState
|
||||
|
||||
domain string
|
||||
domainState domain.InstanceDomainState
|
||||
smtpSenderAddressMatchesInstanceDomain bool
|
||||
}
|
||||
|
||||
func NewIAMSMTPConfigWriteModel(instanceID, id, domain string) *IAMSMTPConfigWriteModel {
|
||||
@@ -73,6 +80,23 @@ func (wm *IAMSMTPConfigWriteModel) Reduce() error {
|
||||
continue
|
||||
}
|
||||
wm.reduceSMTPConfigChangedEvent(e)
|
||||
case *instance.SMTPConfigPasswordChangedEvent:
|
||||
if wm.ID != e.ID {
|
||||
continue
|
||||
}
|
||||
if e.Password != nil {
|
||||
wm.SMTPConfig.Password = e.Password
|
||||
}
|
||||
case *instance.SMTPConfigHTTPAddedEvent:
|
||||
if wm.ID != e.ID {
|
||||
continue
|
||||
}
|
||||
wm.reduceSMTPConfigHTTPAddedEvent(e)
|
||||
case *instance.SMTPConfigHTTPChangedEvent:
|
||||
if wm.ID != e.ID {
|
||||
continue
|
||||
}
|
||||
wm.reduceSMTPConfigHTTPChangedEvent(e)
|
||||
case *instance.SMTPConfigRemovedEvent:
|
||||
if wm.ID != e.ID {
|
||||
continue
|
||||
@@ -120,6 +144,8 @@ func (wm *IAMSMTPConfigWriteModel) Query() *eventstore.SearchQueryBuilder {
|
||||
instance.SMTPConfigRemovedEventType,
|
||||
instance.SMTPConfigChangedEventType,
|
||||
instance.SMTPConfigPasswordChangedEventType,
|
||||
instance.SMTPConfigHTTPAddedEventType,
|
||||
instance.SMTPConfigHTTPChangedEventType,
|
||||
instance.SMTPConfigActivatedEventType,
|
||||
instance.SMTPConfigDeactivatedEventType,
|
||||
instance.SMTPConfigRemovedEventType,
|
||||
@@ -133,6 +159,9 @@ func (wm *IAMSMTPConfigWriteModel) Query() *eventstore.SearchQueryBuilder {
|
||||
func (wm *IAMSMTPConfigWriteModel) NewChangedEvent(ctx context.Context, aggregate *eventstore.Aggregate, id, description string, tls bool, fromAddress, fromName, replyToAddress, smtpHost, smtpUser string, smtpPassword *crypto.CryptoValue) (*instance.SMTPConfigChangedEvent, bool, error) {
|
||||
changes := make([]instance.SMTPConfigChanges, 0)
|
||||
var err error
|
||||
if wm.SMTPConfig == nil {
|
||||
return nil, false, nil
|
||||
}
|
||||
|
||||
if wm.ID != id {
|
||||
changes = append(changes, instance.ChangeSMTPConfigID(id))
|
||||
@@ -140,22 +169,22 @@ func (wm *IAMSMTPConfigWriteModel) NewChangedEvent(ctx context.Context, aggregat
|
||||
if wm.Description != description {
|
||||
changes = append(changes, instance.ChangeSMTPConfigDescription(description))
|
||||
}
|
||||
if wm.TLS != tls {
|
||||
if wm.SMTPConfig.TLS != tls {
|
||||
changes = append(changes, instance.ChangeSMTPConfigTLS(tls))
|
||||
}
|
||||
if wm.SenderAddress != fromAddress {
|
||||
if wm.SMTPConfig.SenderAddress != fromAddress {
|
||||
changes = append(changes, instance.ChangeSMTPConfigFromAddress(fromAddress))
|
||||
}
|
||||
if wm.SenderName != fromName {
|
||||
if wm.SMTPConfig.SenderName != fromName {
|
||||
changes = append(changes, instance.ChangeSMTPConfigFromName(fromName))
|
||||
}
|
||||
if wm.ReplyToAddress != replyToAddress {
|
||||
if wm.SMTPConfig.ReplyToAddress != replyToAddress {
|
||||
changes = append(changes, instance.ChangeSMTPConfigReplyToAddress(replyToAddress))
|
||||
}
|
||||
if wm.Host != smtpHost {
|
||||
if wm.SMTPConfig.Host != smtpHost {
|
||||
changes = append(changes, instance.ChangeSMTPConfigSMTPHost(smtpHost))
|
||||
}
|
||||
if wm.User != smtpUser {
|
||||
if wm.SMTPConfig.User != smtpUser {
|
||||
changes = append(changes, instance.ChangeSMTPConfigSMTPUser(smtpUser))
|
||||
}
|
||||
if smtpPassword != nil {
|
||||
@@ -171,15 +200,58 @@ func (wm *IAMSMTPConfigWriteModel) NewChangedEvent(ctx context.Context, aggregat
|
||||
return changeEvent, true, nil
|
||||
}
|
||||
|
||||
func (wm *IAMSMTPConfigWriteModel) NewHTTPChangedEvent(ctx context.Context, aggregate *eventstore.Aggregate, id, description, endpoint string) (*instance.SMTPConfigHTTPChangedEvent, bool, error) {
|
||||
changes := make([]instance.SMTPConfigHTTPChanges, 0)
|
||||
var err error
|
||||
if wm.HTTPConfig == nil {
|
||||
return nil, false, nil
|
||||
}
|
||||
|
||||
if wm.ID != id {
|
||||
changes = append(changes, instance.ChangeSMTPConfigHTTPID(id))
|
||||
}
|
||||
if wm.Description != description {
|
||||
changes = append(changes, instance.ChangeSMTPConfigHTTPDescription(description))
|
||||
}
|
||||
if wm.HTTPConfig.Endpoint != endpoint {
|
||||
changes = append(changes, instance.ChangeSMTPConfigHTTPEndpoint(endpoint))
|
||||
}
|
||||
if len(changes) == 0 {
|
||||
return nil, false, nil
|
||||
}
|
||||
changeEvent, err := instance.NewSMTPConfigHTTPChangeEvent(ctx, aggregate, id, changes)
|
||||
if err != nil {
|
||||
return nil, false, err
|
||||
}
|
||||
return changeEvent, true, nil
|
||||
}
|
||||
|
||||
func (wm *IAMSMTPConfigWriteModel) reduceSMTPConfigAddedEvent(e *instance.SMTPConfigAddedEvent) {
|
||||
wm.Description = e.Description
|
||||
wm.TLS = e.TLS
|
||||
wm.Host = e.Host
|
||||
wm.User = e.User
|
||||
wm.Password = e.Password
|
||||
wm.SenderAddress = e.SenderAddress
|
||||
wm.SenderName = e.SenderName
|
||||
wm.ReplyToAddress = e.ReplyToAddress
|
||||
wm.SMTPConfig = &SMTPConfig{
|
||||
TLS: e.TLS,
|
||||
Host: e.Host,
|
||||
User: e.User,
|
||||
Password: e.Password,
|
||||
SenderName: e.SenderName,
|
||||
SenderAddress: e.SenderAddress,
|
||||
ReplyToAddress: e.ReplyToAddress,
|
||||
}
|
||||
wm.State = domain.SMTPConfigStateInactive
|
||||
// If ID has empty value we're dealing with the old and unique smtp settings
|
||||
// These would be the default values for ID and State
|
||||
if e.ID == "" {
|
||||
wm.Description = "generic"
|
||||
wm.ID = e.Aggregate().ResourceOwner
|
||||
wm.State = domain.SMTPConfigStateActive
|
||||
}
|
||||
}
|
||||
|
||||
func (wm *IAMSMTPConfigWriteModel) reduceSMTPConfigHTTPAddedEvent(e *instance.SMTPConfigHTTPAddedEvent) {
|
||||
wm.Description = e.Description
|
||||
wm.HTTPConfig = &HTTPConfig{
|
||||
Endpoint: e.Endpoint,
|
||||
}
|
||||
wm.State = domain.SMTPConfigStateInactive
|
||||
// If ID has empty value we're dealing with the old and unique smtp settings
|
||||
// These would be the default values for ID and State
|
||||
@@ -191,29 +263,54 @@ func (wm *IAMSMTPConfigWriteModel) reduceSMTPConfigAddedEvent(e *instance.SMTPCo
|
||||
}
|
||||
|
||||
func (wm *IAMSMTPConfigWriteModel) reduceSMTPConfigChangedEvent(e *instance.SMTPConfigChangedEvent) {
|
||||
if wm.SMTPConfig == nil {
|
||||
return
|
||||
}
|
||||
|
||||
if e.Description != nil {
|
||||
wm.Description = *e.Description
|
||||
}
|
||||
if e.TLS != nil {
|
||||
wm.TLS = *e.TLS
|
||||
wm.SMTPConfig.TLS = *e.TLS
|
||||
}
|
||||
if e.Host != nil {
|
||||
wm.Host = *e.Host
|
||||
wm.SMTPConfig.Host = *e.Host
|
||||
}
|
||||
if e.User != nil {
|
||||
wm.User = *e.User
|
||||
wm.SMTPConfig.User = *e.User
|
||||
}
|
||||
if e.Password != nil {
|
||||
wm.Password = e.Password
|
||||
wm.SMTPConfig.Password = e.Password
|
||||
}
|
||||
if e.FromAddress != nil {
|
||||
wm.SenderAddress = *e.FromAddress
|
||||
wm.SMTPConfig.SenderAddress = *e.FromAddress
|
||||
}
|
||||
if e.FromName != nil {
|
||||
wm.SenderName = *e.FromName
|
||||
wm.SMTPConfig.SenderName = *e.FromName
|
||||
}
|
||||
if e.ReplyToAddress != nil {
|
||||
wm.ReplyToAddress = *e.ReplyToAddress
|
||||
wm.SMTPConfig.ReplyToAddress = *e.ReplyToAddress
|
||||
}
|
||||
|
||||
// If ID has empty value we're dealing with the old and unique smtp settings
|
||||
// These would be the default values for ID and State
|
||||
if e.ID == "" {
|
||||
wm.Description = "generic"
|
||||
wm.ID = e.Aggregate().ResourceOwner
|
||||
wm.State = domain.SMTPConfigStateActive
|
||||
}
|
||||
}
|
||||
|
||||
func (wm *IAMSMTPConfigWriteModel) reduceSMTPConfigHTTPChangedEvent(e *instance.SMTPConfigHTTPChangedEvent) {
|
||||
if wm.HTTPConfig == nil {
|
||||
return
|
||||
}
|
||||
|
||||
if e.Description != nil {
|
||||
wm.Description = *e.Description
|
||||
}
|
||||
if e.Endpoint != nil {
|
||||
wm.HTTPConfig.Endpoint = *e.Endpoint
|
||||
}
|
||||
|
||||
// If ID has empty value we're dealing with the old and unique smtp settings
|
||||
@@ -227,13 +324,8 @@ func (wm *IAMSMTPConfigWriteModel) reduceSMTPConfigChangedEvent(e *instance.SMTP
|
||||
|
||||
func (wm *IAMSMTPConfigWriteModel) reduceSMTPConfigRemovedEvent(e *instance.SMTPConfigRemovedEvent) {
|
||||
wm.Description = ""
|
||||
wm.TLS = false
|
||||
wm.SenderName = ""
|
||||
wm.SenderAddress = ""
|
||||
wm.ReplyToAddress = ""
|
||||
wm.Host = ""
|
||||
wm.User = ""
|
||||
wm.Password = nil
|
||||
wm.HTTPConfig = nil
|
||||
wm.SMTPConfig = nil
|
||||
wm.State = domain.SMTPConfigStateRemoved
|
||||
|
||||
// If ID has empty value we're dealing with the old and unique smtp settings
|
||||
|
Reference in New Issue
Block a user