Documentation ¶
Index ¶
- Constants
- type NotificationMessage
- type Queue
- func (q *Queue) Cleanup(ctx context.Context, filter queues.FilterCleanup) error
- func (q *Queue) Dequeue(ctx context.Context, receiverTypes []string, batchSize int, ...) error
- func (q *Queue) Enqueue(ctx context.Context, ms ...notification.Message) error
- func (q *Queue) ErrorCallback(ctx context.Context, ms notification.Message) error
- func (q *Queue) Stop(ctx context.Context) error
- func (q *Queue) SuccessCallback(ctx context.Context, ms notification.Message) error
- type QueueOption
- type Strategy
Constants ¶
View Source
const ( MessageQueueTableName = "message_queue" MessageQueueSchemaName = "notification" MessageQueueTableFullName = MessageQueueSchemaName + "." + MessageQueueTableName )
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type NotificationMessage ¶
type NotificationMessage struct { ID string `db:"id"` NotificationID string `db:"notification_id"` Status string `db:"status"` ReceiverType string `db:"receiver_type"` Configs pgc.StringAnyMap `db:"configs"` Details pgc.StringAnyMap `db:"details"` Metadata pgc.StringAnyMap `db:"metadata"` LastError sql.NullString `db:"last_error"` MaxTries int `db:"max_tries"` TryCount int `db:"try_count"` Retryable bool `db:"retryable"` ExpiredAt sql.NullTime `db:"expired_at"` CreatedAt time.Time `db:"created_at"` UpdatedAt time.Time `db:"updated_at"` }
func (*NotificationMessage) FromDomain ¶
func (nm *NotificationMessage) FromDomain(domainMessage notification.Message)
func (*NotificationMessage) ToDomain ¶
func (nm *NotificationMessage) ToDomain() notification.Message
type Queue ¶
type Queue struct {
// contains filtered or unexported fields
}
func (*Queue) Dequeue ¶
func (q *Queue) Dequeue(ctx context.Context, receiverTypes []string, batchSize int, handlerFn func(context.Context, []notification.Message) error) error
Dequeue pop the queue based on specific filters (receiver types or batch size) and process the messages with handlerFn message left in pending state that has expired or been updated long time ago means there was a failure when transforming row into a struct
func (*Queue) ErrorCallback ¶
ErrorCallback is a callback that will be called once the message is failed to be handled by handlerFn
func (*Queue) SuccessCallback ¶
SuccessCallback is a callback that will be called once the message is succesfully handled by handlerFn
type QueueOption ¶
type QueueOption func(*Queue)
func WithStrategy ¶
func WithStrategy(s Strategy) QueueOption
Click to show internal directories.
Click to hide internal directories.