Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Consumer ¶
type Consumer interface { // Consume listens to the job queue for messages, consumes them and // schedules the job items for execution. Consume(ctx context.Context, duration time.Duration) }
Consumer represents a domain event listener.
type JobQueue ¶
type JobQueue interface { // Push adds a job to the queue. Push(j *domain.Job) error // Pop removes and returns the head job from the queue. Pop() *domain.Job // Close liberates the bound resources of the job queue. Close() }
JobQueue represents a driven actor queue interface.
type JobService ¶
type JobService interface { // Create creates a new job. Create(name, taskName, description, runAt string, timeout int, taskParams map[string]interface{}) (*domain.Job, error) // Get fetches a job. Get(id string) (*domain.Job, error) // GetJobs fetches all jobs, optionally filters the jobs by status. GetJobs(status string) ([]*domain.Job, error) // Update updates a job. Update(id, name, description string) error // Delete deletes a job. Delete(id string) error }
JobService represents a driver actor service interface.
type ResultService ¶
type ResultService interface { // Get fetches a job result. Get(id string) (*domain.JobResult, error) // Delete deletes a job result. Delete(id string) error }
ResultService represents a driver actor service interface.
type Scheduler ¶
type Scheduler interface { // Schedule polls the repository in given interval and schedules due jobs for execution. Schedule(ctx context.Context, duration time.Duration) }
Scheduler represents a domain event listener.
type Server ¶
type Server interface { // Serve start the server. Serve() // GracefullyStop gracefully stops the server. GracefullyStop() }
Server represents a driver actor service interface.
type Storage ¶
type Storage interface { // CreateJob adds a new job to the repository. CreateJob(j *domain.Job) error // GetJob fetches a job from the repository. GetJob(id string) (*domain.Job, error) // GetJobs fetches all jobs from the repository, optionally filters the jobs by status. GetJobs(status domain.JobStatus) ([]*domain.Job, error) // UpdateJob updates a job to the repository. UpdateJob(id string, j *domain.Job) error // DeleteJob deletes a job from the repository. DeleteJob(id string) error // GetDueJobs fetches all jobs scheduled to run before now and have not been scheduled yet. GetDueJobs() ([]*domain.Job, error) // CreateJobResult adds a new job result to the repository. CreateJobResult(result *domain.JobResult) error // GetJobResult fetches a job result from the repository. GetJobResult(jobID string) (*domain.JobResult, error) // UpdateJobResult updates a job result to the repository. UpdateJobResult(jobID string, result *domain.JobResult) error // DeleteJobResult deletes a job result from the repository. DeleteJobResult(jobID string) error // CheckHealth checks if the storage is alive. CheckHealth() bool // Close terminates any store connections gracefully. Close() error }
Storage represents a driven actor repository interface.
type WorkService ¶
type WorkService interface { // Start starts the worker pool. Start() // Stop signals the workers to stop working gracefully. Stop() // Send sends a work to the worker pool. Send(w work.Work) // CreateWork creates and return a new Work instance. CreateWork(j *domain.Job) work.Work // Exec executes a work. Exec(ctx context.Context, w work.Work) error }
WorkService represents a driver actor service interface.
Click to show internal directories.
Click to hide internal directories.