| 
									
										
										
										
											2022-03-07 14:22:37 +01:00
										 |  |  | package query | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"context" | 
					
						
							|  |  |  | 	"database/sql" | 
					
						
							| 
									
										
										
										
											2023-12-08 16:30:55 +02:00
										 |  |  | 	"errors" | 
					
						
							| 
									
										
										
										
											2022-03-07 14:22:37 +01:00
										 |  |  | 	"time" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	sq "github.com/Masterminds/squirrel" | 
					
						
							| 
									
										
										
										
											2022-03-23 09:02:39 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-27 01:01:45 +02:00
										 |  |  | 	"github.com/zitadel/zitadel/internal/api/authz" | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | 	"github.com/zitadel/zitadel/internal/api/call" | 
					
						
							| 
									
										
										
										
											2022-04-27 01:01:45 +02:00
										 |  |  | 	"github.com/zitadel/zitadel/internal/domain" | 
					
						
							|  |  |  | 	"github.com/zitadel/zitadel/internal/query/projection" | 
					
						
							| 
									
										
										
										
											2022-12-01 09:18:53 +01:00
										 |  |  | 	"github.com/zitadel/zitadel/internal/telemetry/tracing" | 
					
						
							| 
									
										
										
										
											2023-12-08 16:30:55 +02:00
										 |  |  | 	"github.com/zitadel/zitadel/internal/zerrors" | 
					
						
							| 
									
										
										
										
											2022-03-07 14:22:37 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type DebugNotificationProvider struct { | 
					
						
							|  |  |  | 	AggregateID   string | 
					
						
							|  |  |  | 	CreationDate  time.Time | 
					
						
							|  |  |  | 	ChangeDate    time.Time | 
					
						
							|  |  |  | 	Sequence      uint64 | 
					
						
							|  |  |  | 	ResourceOwner string | 
					
						
							|  |  |  | 	State         domain.NotificationProviderState | 
					
						
							|  |  |  | 	Type          domain.NotificationProviderType | 
					
						
							|  |  |  | 	Compact       bool | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var ( | 
					
						
							|  |  |  | 	notificationProviderTable = table{ | 
					
						
							| 
									
										
										
										
											2022-10-27 08:08:36 +02:00
										 |  |  | 		name:          projection.DebugNotificationProviderTable, | 
					
						
							|  |  |  | 		instanceIDCol: projection.DebugNotificationProviderInstanceIDCol, | 
					
						
							| 
									
										
										
										
											2022-03-07 14:22:37 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	NotificationProviderColumnAggID = Column{ | 
					
						
							|  |  |  | 		name:  projection.DebugNotificationProviderAggIDCol, | 
					
						
							|  |  |  | 		table: notificationProviderTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationProviderColumnCreationDate = Column{ | 
					
						
							|  |  |  | 		name:  projection.DebugNotificationProviderCreationDateCol, | 
					
						
							|  |  |  | 		table: notificationProviderTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationProviderColumnChangeDate = Column{ | 
					
						
							|  |  |  | 		name:  projection.DebugNotificationProviderChangeDateCol, | 
					
						
							|  |  |  | 		table: notificationProviderTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationProviderColumnSequence = Column{ | 
					
						
							|  |  |  | 		name:  projection.DebugNotificationProviderSequenceCol, | 
					
						
							|  |  |  | 		table: notificationProviderTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationProviderColumnResourceOwner = Column{ | 
					
						
							|  |  |  | 		name:  projection.DebugNotificationProviderResourceOwnerCol, | 
					
						
							|  |  |  | 		table: notificationProviderTable, | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2022-03-23 09:02:39 +01:00
										 |  |  | 	NotificationProviderColumnInstanceID = Column{ | 
					
						
							|  |  |  | 		name:  projection.DebugNotificationProviderInstanceIDCol, | 
					
						
							|  |  |  | 		table: notificationProviderTable, | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2022-03-07 14:22:37 +01:00
										 |  |  | 	NotificationProviderColumnState = Column{ | 
					
						
							|  |  |  | 		name:  projection.DebugNotificationProviderStateCol, | 
					
						
							|  |  |  | 		table: notificationProviderTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationProviderColumnType = Column{ | 
					
						
							|  |  |  | 		name:  projection.DebugNotificationProviderTypeCol, | 
					
						
							|  |  |  | 		table: notificationProviderTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	NotificationProviderColumnCompact = Column{ | 
					
						
							|  |  |  | 		name:  projection.DebugNotificationProviderCompactCol, | 
					
						
							|  |  |  | 		table: notificationProviderTable, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 12:49:22 +02:00
										 |  |  | func (q *Queries) NotificationProviderByIDAndType(ctx context.Context, aggID string, providerType domain.NotificationProviderType) (provider *DebugNotificationProvider, err error) { | 
					
						
							| 
									
										
										
										
											2022-12-01 09:18:53 +01:00
										 |  |  | 	ctx, span := tracing.NewSpan(ctx) | 
					
						
							|  |  |  | 	defer func() { span.EndWithError(err) }() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | 	query, scan := prepareDebugNotificationProviderQuery(ctx, q.client) | 
					
						
							| 
									
										
										
										
											2022-03-07 14:22:37 +01:00
										 |  |  | 	stmt, args, err := query.Where( | 
					
						
							| 
									
										
										
										
											2022-03-23 09:02:39 +01:00
										 |  |  | 		sq.And{ | 
					
						
							| 
									
										
										
										
											2022-11-30 17:01:17 +01:00
										 |  |  | 			sq.Eq{NotificationProviderColumnInstanceID.identifier(): authz.GetInstance(ctx).InstanceID()}, | 
					
						
							| 
									
										
										
										
											2022-03-23 09:02:39 +01:00
										 |  |  | 			sq.Or{ | 
					
						
							|  |  |  | 				sq.Eq{ | 
					
						
							|  |  |  | 					NotificationProviderColumnAggID.identifier(): aggID, | 
					
						
							|  |  |  | 					NotificationProviderColumnType.identifier():  providerType, | 
					
						
							|  |  |  | 				}, | 
					
						
							| 
									
										
										
										
											2022-03-07 14:22:37 +01:00
										 |  |  | 			}, | 
					
						
							|  |  |  | 		}). | 
					
						
							|  |  |  | 		Limit(1).ToSql() | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2023-12-08 16:30:55 +02:00
										 |  |  | 		return nil, zerrors.ThrowInternal(err, "QUERY-f9jSf", "Errors.Query.SQLStatement") | 
					
						
							| 
									
										
										
										
											2022-03-07 14:22:37 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 12:49:22 +02:00
										 |  |  | 	err = q.client.QueryRowContext(ctx, func(row *sql.Row) error { | 
					
						
							|  |  |  | 		provider, err = scan(row) | 
					
						
							|  |  |  | 		return err | 
					
						
							|  |  |  | 	}, stmt, args...) | 
					
						
							|  |  |  | 	return provider, err | 
					
						
							| 
									
										
										
										
											2022-03-07 14:22:37 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | func prepareDebugNotificationProviderQuery(ctx context.Context, db prepareDatabase) (sq.SelectBuilder, func(*sql.Row) (*DebugNotificationProvider, error)) { | 
					
						
							| 
									
										
										
										
											2022-03-07 14:22:37 +01:00
										 |  |  | 	return sq.Select( | 
					
						
							|  |  |  | 			NotificationProviderColumnAggID.identifier(), | 
					
						
							|  |  |  | 			NotificationProviderColumnCreationDate.identifier(), | 
					
						
							|  |  |  | 			NotificationProviderColumnChangeDate.identifier(), | 
					
						
							|  |  |  | 			NotificationProviderColumnSequence.identifier(), | 
					
						
							|  |  |  | 			NotificationProviderColumnResourceOwner.identifier(), | 
					
						
							|  |  |  | 			NotificationProviderColumnState.identifier(), | 
					
						
							|  |  |  | 			NotificationProviderColumnType.identifier(), | 
					
						
							|  |  |  | 			NotificationProviderColumnCompact.identifier(), | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | 		).From(notificationProviderTable.identifier() + db.Timetravel(call.Took(ctx))). | 
					
						
							|  |  |  | 			PlaceholderFormat(sq.Dollar), | 
					
						
							| 
									
										
										
										
											2022-03-07 14:22:37 +01:00
										 |  |  | 		func(row *sql.Row) (*DebugNotificationProvider, error) { | 
					
						
							|  |  |  | 			p := new(DebugNotificationProvider) | 
					
						
							|  |  |  | 			err := row.Scan( | 
					
						
							|  |  |  | 				&p.AggregateID, | 
					
						
							|  |  |  | 				&p.CreationDate, | 
					
						
							|  |  |  | 				&p.ChangeDate, | 
					
						
							|  |  |  | 				&p.Sequence, | 
					
						
							|  |  |  | 				&p.ResourceOwner, | 
					
						
							|  |  |  | 				&p.State, | 
					
						
							|  |  |  | 				&p.Type, | 
					
						
							|  |  |  | 				&p.Compact, | 
					
						
							|  |  |  | 			) | 
					
						
							|  |  |  | 			if err != nil { | 
					
						
							| 
									
										
										
										
											2023-12-08 16:30:55 +02:00
										 |  |  | 				if errors.Is(err, sql.ErrNoRows) { | 
					
						
							|  |  |  | 					return nil, zerrors.ThrowNotFound(err, "QUERY-s9ujf", "Errors.NotificationProvider.NotFound") | 
					
						
							| 
									
										
										
										
											2022-03-07 14:22:37 +01:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2023-12-08 16:30:55 +02:00
										 |  |  | 				return nil, zerrors.ThrowInternal(err, "QUERY-2liu0", "Errors.Internal") | 
					
						
							| 
									
										
										
										
											2022-03-07 14:22:37 +01:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			return p, nil | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | } |