taskqueue

package
v0.5.0-alpha.1 Latest Latest
Warning

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

Go to latest
Published: Jan 18, 2024 License: MIT Imports: 1 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 QueueTypeFromDispatcherID

func QueueTypeFromDispatcherID(d string) QueueType

func QueueTypeFromTickerID

func QueueTypeFromTickerID(t string) 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