| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | package query | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"context" | 
					
						
							|  |  |  | 	"database/sql" | 
					
						
							| 
									
										
										
										
											2023-12-08 16:30:55 +02:00
										 |  |  | 	"errors" | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 	"time" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	sq "github.com/Masterminds/squirrel" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/zitadel/zitadel/internal/api/authz" | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | 	"github.com/zitadel/zitadel/internal/api/call" | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 	"github.com/zitadel/zitadel/internal/domain" | 
					
						
							| 
									
										
										
										
											2023-10-19 12:19:10 +02:00
										 |  |  | 	"github.com/zitadel/zitadel/internal/eventstore/handler/v2" | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 	"github.com/zitadel/zitadel/internal/query/projection" | 
					
						
							|  |  |  | 	"github.com/zitadel/zitadel/internal/telemetry/tracing" | 
					
						
							| 
									
										
										
										
											2023-12-08 16:30:55 +02:00
										 |  |  | 	"github.com/zitadel/zitadel/internal/zerrors" | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type NotificationPolicy struct { | 
					
						
							|  |  |  | 	ID            string | 
					
						
							|  |  |  | 	Sequence      uint64 | 
					
						
							|  |  |  | 	CreationDate  time.Time | 
					
						
							|  |  |  | 	ChangeDate    time.Time | 
					
						
							|  |  |  | 	ResourceOwner string | 
					
						
							|  |  |  | 	State         domain.PolicyState | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	PasswordChange bool | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	IsDefault bool | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var ( | 
					
						
							|  |  |  | 	notificationPolicyTable = table{ | 
					
						
							|  |  |  | 		name:          projection.NotificationPolicyProjectionTable, | 
					
						
							|  |  |  | 		instanceIDCol: projection.NotificationPolicyColumnInstanceID, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationPolicyColID = Column{ | 
					
						
							|  |  |  | 		name:  projection.NotificationPolicyColumnID, | 
					
						
							|  |  |  | 		table: notificationPolicyTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationPolicyColSequence = Column{ | 
					
						
							|  |  |  | 		name:  projection.NotificationPolicyColumnSequence, | 
					
						
							|  |  |  | 		table: notificationPolicyTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationPolicyColCreationDate = Column{ | 
					
						
							|  |  |  | 		name:  projection.NotificationPolicyColumnCreationDate, | 
					
						
							|  |  |  | 		table: notificationPolicyTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationPolicyColChangeDate = Column{ | 
					
						
							|  |  |  | 		name:  projection.NotificationPolicyColumnChangeDate, | 
					
						
							|  |  |  | 		table: notificationPolicyTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationPolicyColResourceOwner = Column{ | 
					
						
							|  |  |  | 		name:  projection.NotificationPolicyColumnResourceOwner, | 
					
						
							|  |  |  | 		table: notificationPolicyTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationPolicyColInstanceID = Column{ | 
					
						
							|  |  |  | 		name:  projection.NotificationPolicyColumnInstanceID, | 
					
						
							|  |  |  | 		table: notificationPolicyTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationPolicyColPasswordChange = Column{ | 
					
						
							|  |  |  | 		name:  projection.NotificationPolicyColumnPasswordChange, | 
					
						
							|  |  |  | 		table: notificationPolicyTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationPolicyColIsDefault = Column{ | 
					
						
							|  |  |  | 		name:  projection.NotificationPolicyColumnIsDefault, | 
					
						
							|  |  |  | 		table: notificationPolicyTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationPolicyColState = Column{ | 
					
						
							|  |  |  | 		name:  projection.NotificationPolicyColumnStateCol, | 
					
						
							|  |  |  | 		table: notificationPolicyTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationPolicyColOwnerRemoved = Column{ | 
					
						
							|  |  |  | 		name:  projection.NotificationPolicyColumnOwnerRemoved, | 
					
						
							|  |  |  | 		table: notificationPolicyTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 14:49:02 +02:00
										 |  |  | func (q *Queries) NotificationPolicyByOrg(ctx context.Context, shouldTriggerBulk bool, orgID string, withOwnerRemoved bool) (policy *NotificationPolicy, err error) { | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 	ctx, span := tracing.NewSpan(ctx) | 
					
						
							|  |  |  | 	defer func() { span.EndWithError(err) }() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if shouldTriggerBulk { | 
					
						
							| 
									
										
										
										
											2023-10-26 17:07:56 +02:00
										 |  |  | 		_, traceSpan := tracing.NewNamedSpan(ctx, "TriggerNotificationPolicyProjection") | 
					
						
							| 
									
										
										
										
											2023-10-19 12:19:10 +02:00
										 |  |  | 		ctx, err = projection.NotificationPolicyProjection.Trigger(ctx, handler.WithAwaitRunning()) | 
					
						
							| 
									
										
										
										
											2023-10-26 17:07:56 +02:00
										 |  |  | 		traceSpan.EndWithError(err) | 
					
						
							| 
									
										
										
										
											2023-07-07 11:15:05 +03:00
										 |  |  | 		if err != nil { | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 			return nil, err | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	eq := sq.Eq{NotificationPolicyColInstanceID.identifier(): authz.GetInstance(ctx).InstanceID()} | 
					
						
							|  |  |  | 	if !withOwnerRemoved { | 
					
						
							|  |  |  | 		eq[NotificationPolicyColOwnerRemoved.identifier()] = false | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | 	stmt, scan := prepareNotificationPolicyQuery(ctx, q.client) | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 	query, args, err := stmt.Where( | 
					
						
							|  |  |  | 		sq.And{ | 
					
						
							|  |  |  | 			eq, | 
					
						
							|  |  |  | 			sq.Or{ | 
					
						
							|  |  |  | 				sq.Eq{NotificationPolicyColID.identifier(): orgID}, | 
					
						
							|  |  |  | 				sq.Eq{NotificationPolicyColID.identifier(): authz.GetInstance(ctx).InstanceID()}, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}). | 
					
						
							|  |  |  | 		OrderBy(NotificationPolicyColIsDefault.identifier()).Limit(1).ToSql() | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2023-12-08 16:30:55 +02:00
										 |  |  | 		return nil, zerrors.ThrowInternal(err, "QUERY-Xuoapqm", "Errors.Query.SQLStatement") | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 14:49:02 +02:00
										 |  |  | 	err = q.client.QueryRowContext(ctx, func(row *sql.Row) error { | 
					
						
							|  |  |  | 		policy, err = scan(row) | 
					
						
							|  |  |  | 		return err | 
					
						
							|  |  |  | 	}, query, args...) | 
					
						
							|  |  |  | 	return policy, err | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 14:49:02 +02:00
										 |  |  | func (q *Queries) DefaultNotificationPolicy(ctx context.Context, shouldTriggerBulk bool) (policy *NotificationPolicy, err error) { | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 	ctx, span := tracing.NewSpan(ctx) | 
					
						
							|  |  |  | 	defer func() { span.EndWithError(err) }() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if shouldTriggerBulk { | 
					
						
							| 
									
										
										
										
											2023-10-26 17:07:56 +02:00
										 |  |  | 		_, traceSpan := tracing.NewNamedSpan(ctx, "TriggerNotificationPolicyProjection") | 
					
						
							| 
									
										
										
										
											2023-10-19 12:19:10 +02:00
										 |  |  | 		ctx, err = projection.NotificationPolicyProjection.Trigger(ctx, handler.WithAwaitRunning()) | 
					
						
							| 
									
										
										
										
											2023-10-26 17:07:56 +02:00
										 |  |  | 		traceSpan.EndWithError(err) | 
					
						
							| 
									
										
										
										
											2023-07-07 11:15:05 +03:00
										 |  |  | 		if err != nil { | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 			return nil, err | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | 	stmt, scan := prepareNotificationPolicyQuery(ctx, q.client) | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 	query, args, err := stmt.Where(sq.Eq{ | 
					
						
							|  |  |  | 		NotificationPolicyColID.identifier():         authz.GetInstance(ctx).InstanceID(), | 
					
						
							|  |  |  | 		NotificationPolicyColInstanceID.identifier(): authz.GetInstance(ctx).InstanceID(), | 
					
						
							|  |  |  | 	}). | 
					
						
							|  |  |  | 		OrderBy(NotificationPolicyColIsDefault.identifier()). | 
					
						
							|  |  |  | 		Limit(1).ToSql() | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2023-12-08 16:30:55 +02:00
										 |  |  | 		return nil, zerrors.ThrowInternal(err, "QUERY-xlqp209", "Errors.Query.SQLStatement") | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 14:49:02 +02:00
										 |  |  | 	err = q.client.QueryRowContext(ctx, func(row *sql.Row) error { | 
					
						
							|  |  |  | 		policy, err = scan(row) | 
					
						
							|  |  |  | 		return err | 
					
						
							|  |  |  | 	}, query, args...) | 
					
						
							|  |  |  | 	return policy, err | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | func prepareNotificationPolicyQuery(ctx context.Context, db prepareDatabase) (sq.SelectBuilder, func(*sql.Row) (*NotificationPolicy, error)) { | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 	return sq.Select( | 
					
						
							|  |  |  | 			NotificationPolicyColID.identifier(), | 
					
						
							|  |  |  | 			NotificationPolicyColSequence.identifier(), | 
					
						
							|  |  |  | 			NotificationPolicyColCreationDate.identifier(), | 
					
						
							|  |  |  | 			NotificationPolicyColChangeDate.identifier(), | 
					
						
							|  |  |  | 			NotificationPolicyColResourceOwner.identifier(), | 
					
						
							|  |  |  | 			NotificationPolicyColPasswordChange.identifier(), | 
					
						
							|  |  |  | 			NotificationPolicyColIsDefault.identifier(), | 
					
						
							|  |  |  | 			NotificationPolicyColState.identifier(), | 
					
						
							|  |  |  | 		). | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | 			From(notificationPolicyTable.identifier() + db.Timetravel(call.Took(ctx))). | 
					
						
							|  |  |  | 			PlaceholderFormat(sq.Dollar), | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 		func(row *sql.Row) (*NotificationPolicy, error) { | 
					
						
							|  |  |  | 			policy := new(NotificationPolicy) | 
					
						
							|  |  |  | 			err := row.Scan( | 
					
						
							|  |  |  | 				&policy.ID, | 
					
						
							|  |  |  | 				&policy.Sequence, | 
					
						
							|  |  |  | 				&policy.CreationDate, | 
					
						
							|  |  |  | 				&policy.ChangeDate, | 
					
						
							|  |  |  | 				&policy.ResourceOwner, | 
					
						
							|  |  |  | 				&policy.PasswordChange, | 
					
						
							|  |  |  | 				&policy.IsDefault, | 
					
						
							|  |  |  | 				&policy.State, | 
					
						
							|  |  |  | 			) | 
					
						
							|  |  |  | 			if err != nil { | 
					
						
							| 
									
										
										
										
											2023-12-08 16:30:55 +02:00
										 |  |  | 				if errors.Is(err, sql.ErrNoRows) { | 
					
						
							|  |  |  | 					return nil, zerrors.ThrowNotFound(err, "QUERY-x0so2p", "Errors.NotificationPolicy.NotFound") | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2023-12-08 16:30:55 +02:00
										 |  |  | 				return nil, zerrors.ThrowInternal(err, "QUERY-Zixoooq", "Errors.Internal") | 
					
						
							| 
									
										
										
										
											2023-01-25 09:49:41 +01:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			return policy, nil | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | } |