Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
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 // CheckHealth checks if the job queue is alive. CheckHealth() bool // 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 PipelineService ¶ added in v0.8.0
type PipelineService interface { // Create creates a new pipeline. Create(name, description, runAt string, jobs []*domain.Job) (*domain.Pipeline, error) // Get fetches a pipeline. Get(id string) (*domain.Pipeline, error) // GetPipelines fetches all pipelines, optionally filters the pipelines by status. GetPipelines(status string) ([]*domain.Pipeline, error) // GetPipelineJobs fetches the jobs of a specified pipeline. GetPipelineJobs(id string) ([]*domain.Job, error) // Update updates a pipeline. Update(id, name, description string) error // Delete deletes a pipeline. Delete(id string) error }
PipelineService 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) // Dispatch listens to the job queue for messages, consumes them and // dispatches the jobs for execution. Dispatch(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) // GetDueJobs fetches all jobs scheduled to run before now and have not been scheduled yet. GetDueJobs() ([]*domain.Job, error) // GetJobsByPipelineID fetches the jobs of the specified pipeline. GetJobsByPipelineID(pipelineID string) ([]*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 // 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 // CreatePipeline adds a new pipeline and of its jobs to the repository. CreatePipeline(p *domain.Pipeline) error // GetPipeline fetches a pipeline from the repository. GetPipeline(id string) (*domain.Pipeline, error) // GetPipelines fetches all pipelines from the repository, optionally filters the pipelines by status. GetPipelines(status domain.JobStatus) ([]*domain.Pipeline, error) // UpdatePipeline updates a pipeline to the repository. UpdatePipeline(id string, p *domain.Pipeline) error // DeletePipeline deletes a pipeline and all its jobs from the repository. DeletePipeline(id 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 TaskService ¶ added in v0.6.0
type TaskService interface { // Register registers a new task in the task repository. Register(name string, taskFunc taskrepo.TaskFunc) // GetTaskRepository returns the task repository. GetTaskRepository() *taskrepo.TaskRepository }
TaskService represents a driver actor service interface.
type WorkService ¶
type WorkService interface { // Start starts the worker pool. Start() // Stop signals the workers to stop working gracefully. Stop() // Dispatch dispatches a work to the worker pool. Dispatch(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.