mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-26 09:19:38 +00:00 
			
		
		
		
	 f680dd934d
			
		
	
	f680dd934d
	
	
	
		
			
			* chore: rename package errors to zerrors * rename package errors to gerrors * fix error related linting issues * fix zitadel error assertion * fix gosimple linting issues * fix deprecated linting issues * resolve gci linting issues * fix import structure --------- Co-authored-by: Elio Bischof <elio@zitadel.com>
		
			
				
	
	
		
			163 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			163 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package query
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"database/sql"
 | |
| 	"errors"
 | |
| 	"time"
 | |
| 
 | |
| 	sq "github.com/Masterminds/squirrel"
 | |
| 
 | |
| 	"github.com/zitadel/zitadel/internal/api/authz"
 | |
| 	"github.com/zitadel/zitadel/internal/api/call"
 | |
| 	"github.com/zitadel/zitadel/internal/crypto"
 | |
| 	"github.com/zitadel/zitadel/internal/query/projection"
 | |
| 	"github.com/zitadel/zitadel/internal/telemetry/tracing"
 | |
| 	"github.com/zitadel/zitadel/internal/zerrors"
 | |
| )
 | |
| 
 | |
| var (
 | |
| 	smtpConfigsTable = table{
 | |
| 		name:          projection.SMTPConfigProjectionTable,
 | |
| 		instanceIDCol: projection.SMTPConfigColumnInstanceID,
 | |
| 	}
 | |
| 	SMTPConfigColumnAggregateID = Column{
 | |
| 		name:  projection.SMTPConfigColumnAggregateID,
 | |
| 		table: smtpConfigsTable,
 | |
| 	}
 | |
| 	SMTPConfigColumnCreationDate = Column{
 | |
| 		name:  projection.SMTPConfigColumnCreationDate,
 | |
| 		table: smtpConfigsTable,
 | |
| 	}
 | |
| 	SMTPConfigColumnChangeDate = Column{
 | |
| 		name:  projection.SMTPConfigColumnChangeDate,
 | |
| 		table: smtpConfigsTable,
 | |
| 	}
 | |
| 	SMTPConfigColumnResourceOwner = Column{
 | |
| 		name:  projection.SMTPConfigColumnResourceOwner,
 | |
| 		table: smtpConfigsTable,
 | |
| 	}
 | |
| 	SMTPConfigColumnInstanceID = Column{
 | |
| 		name:  projection.SMTPConfigColumnInstanceID,
 | |
| 		table: smtpConfigsTable,
 | |
| 	}
 | |
| 	SMTPConfigColumnSequence = Column{
 | |
| 		name:  projection.SMTPConfigColumnSequence,
 | |
| 		table: smtpConfigsTable,
 | |
| 	}
 | |
| 	SMTPConfigColumnTLS = Column{
 | |
| 		name:  projection.SMTPConfigColumnTLS,
 | |
| 		table: smtpConfigsTable,
 | |
| 	}
 | |
| 	SMTPConfigColumnSenderAddress = Column{
 | |
| 		name:  projection.SMTPConfigColumnSenderAddress,
 | |
| 		table: smtpConfigsTable,
 | |
| 	}
 | |
| 	SMTPConfigColumnSenderName = Column{
 | |
| 		name:  projection.SMTPConfigColumnSenderName,
 | |
| 		table: smtpConfigsTable,
 | |
| 	}
 | |
| 	SMTPConfigColumnReplyToAddress = Column{
 | |
| 		name:  projection.SMTPConfigColumnReplyToAddress,
 | |
| 		table: smtpConfigsTable,
 | |
| 	}
 | |
| 	SMTPConfigColumnSMTPHost = Column{
 | |
| 		name:  projection.SMTPConfigColumnSMTPHost,
 | |
| 		table: smtpConfigsTable,
 | |
| 	}
 | |
| 	SMTPConfigColumnSMTPUser = Column{
 | |
| 		name:  projection.SMTPConfigColumnSMTPUser,
 | |
| 		table: smtpConfigsTable,
 | |
| 	}
 | |
| 	SMTPConfigColumnSMTPPassword = Column{
 | |
| 		name:  projection.SMTPConfigColumnSMTPPassword,
 | |
| 		table: smtpConfigsTable,
 | |
| 	}
 | |
| )
 | |
| 
 | |
| type SMTPConfigs struct {
 | |
| 	SearchResponse
 | |
| 	SMTPConfigs []*SMTPConfig
 | |
| }
 | |
| 
 | |
| type SMTPConfig struct {
 | |
| 	AggregateID   string
 | |
| 	CreationDate  time.Time
 | |
| 	ChangeDate    time.Time
 | |
| 	ResourceOwner string
 | |
| 	Sequence      uint64
 | |
| 
 | |
| 	TLS            bool
 | |
| 	SenderAddress  string
 | |
| 	SenderName     string
 | |
| 	ReplyToAddress string
 | |
| 	Host           string
 | |
| 	User           string
 | |
| 	Password       *crypto.CryptoValue
 | |
| }
 | |
| 
 | |
| func (q *Queries) SMTPConfigByAggregateID(ctx context.Context, aggregateID string) (config *SMTPConfig, err error) {
 | |
| 	ctx, span := tracing.NewSpan(ctx)
 | |
| 	defer func() { span.EndWithError(err) }()
 | |
| 
 | |
| 	stmt, scan := prepareSMTPConfigQuery(ctx, q.client)
 | |
| 	query, args, err := stmt.Where(sq.Eq{
 | |
| 		SMTPConfigColumnAggregateID.identifier(): aggregateID,
 | |
| 		SMTPConfigColumnInstanceID.identifier():  authz.GetInstance(ctx).InstanceID(),
 | |
| 	}).ToSql()
 | |
| 	if err != nil {
 | |
| 		return nil, zerrors.ThrowInternal(err, "QUERY-3m9sl", "Errors.Query.SQLStatment")
 | |
| 	}
 | |
| 
 | |
| 	err = q.client.QueryRowContext(ctx, func(row *sql.Row) error {
 | |
| 		config, err = scan(row)
 | |
| 		return err
 | |
| 	}, query, args...)
 | |
| 	return config, err
 | |
| }
 | |
| 
 | |
| func prepareSMTPConfigQuery(ctx context.Context, db prepareDatabase) (sq.SelectBuilder, func(*sql.Row) (*SMTPConfig, error)) {
 | |
| 	password := new(crypto.CryptoValue)
 | |
| 
 | |
| 	return sq.Select(
 | |
| 			SMTPConfigColumnAggregateID.identifier(),
 | |
| 			SMTPConfigColumnCreationDate.identifier(),
 | |
| 			SMTPConfigColumnChangeDate.identifier(),
 | |
| 			SMTPConfigColumnResourceOwner.identifier(),
 | |
| 			SMTPConfigColumnSequence.identifier(),
 | |
| 			SMTPConfigColumnTLS.identifier(),
 | |
| 			SMTPConfigColumnSenderAddress.identifier(),
 | |
| 			SMTPConfigColumnSenderName.identifier(),
 | |
| 			SMTPConfigColumnReplyToAddress.identifier(),
 | |
| 			SMTPConfigColumnSMTPHost.identifier(),
 | |
| 			SMTPConfigColumnSMTPUser.identifier(),
 | |
| 			SMTPConfigColumnSMTPPassword.identifier()).
 | |
| 			From(smtpConfigsTable.identifier() + db.Timetravel(call.Took(ctx))).
 | |
| 			PlaceholderFormat(sq.Dollar),
 | |
| 		func(row *sql.Row) (*SMTPConfig, error) {
 | |
| 			config := new(SMTPConfig)
 | |
| 			err := row.Scan(
 | |
| 				&config.AggregateID,
 | |
| 				&config.CreationDate,
 | |
| 				&config.ChangeDate,
 | |
| 				&config.ResourceOwner,
 | |
| 				&config.Sequence,
 | |
| 				&config.TLS,
 | |
| 				&config.SenderAddress,
 | |
| 				&config.SenderName,
 | |
| 				&config.ReplyToAddress,
 | |
| 				&config.Host,
 | |
| 				&config.User,
 | |
| 				&password,
 | |
| 			)
 | |
| 			if err != nil {
 | |
| 				if errors.Is(err, sql.ErrNoRows) {
 | |
| 					return nil, zerrors.ThrowNotFound(err, "QUERY-fwofw", "Errors.SMTPConfig.NotFound")
 | |
| 				}
 | |
| 				return nil, zerrors.ThrowInternal(err, "QUERY-9k87F", "Errors.Internal")
 | |
| 			}
 | |
| 			config.Password = password
 | |
| 			return config, nil
 | |
| 		}
 | |
| }
 |