taskqueue

package
v0.2.0-alpha.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 27, 2023 License: MIT Imports: 2 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type QueueType

type QueueType string
const (
	EVENT_PROCESSING_QUEUE QueueType = "event_processing_queue"
	JOB_PROCESSING_QUEUE   QueueType = "job_processing_queue"
	DISPATCHER_POOL_QUEUE  QueueType = "dispatcher_pool_queue"
	SCHEDULING_QUEUE       QueueType = "scheduling_queue"
)

func QueueTypeFromDispatcher

func QueueTypeFromDispatcher(d *db.DispatcherModel) QueueType

func QueueTypeFromTicker

func QueueTypeFromTicker(t *db.TickerModel) QueueType

type Task

type Task struct {
	// ID is the ID of the task.
	ID string `json:"id"`

	// Queue is the queue of the task.
	Queue QueueType `json:"queue"`

	// Payload is the payload of the task.
	Payload map[string]interface{} `json:"payload"`

	// Metadata is the metadata of the task.
	Metadata map[string]interface{} `json:"metadata"`

	// Retries is the number of retries for the task.
	Retries int `json:"retries"`

	// RetryDelay is the delay between retries.
	RetryDelay int `json:"retry_delay"`
}

type TaskQueue

type TaskQueue interface {
	// AddTask adds a task to the queue. Implementations should ensure that Start().
	AddTask(ctx context.Context, queue QueueType, task *Task) error

	// Subscribe subscribes to the task queue.
	Subscribe(ctx context.Context, queueType QueueType) (<-chan *Task, error)
}

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL