registry

package
v0.0.0-...-098c36e Latest Latest
Warning

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

Go to latest
Published: May 10, 2023 License: Apache-2.0 Imports: 6 Imported by: 5

Documentation

Overview

Package registry contains infrastructure to support the persistence of Job definitions.

Job and Dependency Registries

Systems need to be able to create and access Jobs and Dependency instances potentially from other implementations, and the registry provides a way to register new Job types both internal and external to the amboy package, and ensures that Jobs can be persiststed and handled generically as needed.

When you implement a new amboy/dependency.Manager or amboy.Job type, be sure to write a simple factory function for the type and register the factory in an init() function. Consider the following example:

func init() {
   RegisterJobType("noop", noopJobFactory)
}

func noopJobFactory() amboy.Job {
   return &NoopJob{}  /
}

The dependency and job registers have similar interfaces.

The registry package also provides functions for converting between an "interchange" format for persisting Job objects of mixed types consistently. Typically only authors of Queue implementations will need to use these operations.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func AddCheckType

func AddCheckType(name string, f dependency.CheckFactory)

AddCheckType registers a callback function used in the production of some dependencies

func AddDependencyType

func AddDependencyType(name string, f dependency.ManagerFactory)

AddDependencyType registers a new dependency.Manager factories.

func AddJobType

func AddJobType(name string, f JobFactory)

AddJobType adds a job type to the amboy package's internal registry of job types. This registry is used to support serialization and de-serialization of between persistence layers.

func GetCheckFactory

func GetCheckFactory(name string) (dependency.CheckFactory, error)

GetCheckFactory returns a callback function factory for use in dependencies

func GetDependencyFactory

func GetDependencyFactory(name string) (dependency.ManagerFactory, error)

GetDependencyFactory returns a dependency.Manager factory function from the registry based on the name produced. If the name does not exist, then the error value is non-nil.

func IsVersionResolutionError

func IsVersionResolutionError(err error) bool

IsVersionResolutionError returns true if an error is a resolution error and false otherwise.

func JobTypeNames

func JobTypeNames() <-chan string

JobTypeNames returns an iterator of all registered Job types

func NewDependencyResolutionError

func NewDependencyResolutionError(reg dependency.TypeInfo, version int) error

NewDependencyResolutionError returns an error if the version in the dependency type and the version provided are mismatched. This error is detectable using the IsVersionResolutionError.

func NewJobResolutionError

func NewJobResolutionError(reg amboy.JobType, version int) error

NewJobResolutionError returns an error if the version in the job type and the version provided are mismatched. This error is detectable using the IsVersionResolutionError.

Types

type DependencyInterchange

type DependencyInterchange struct {
	ID         string        `bson:"id,omitempty" json:"id,omitempty" yaml:"id,omitempty" db:"id"`
	Type       string        `json:"type" bson:"type" yaml:"type" db:"dep_type"`
	Version    int           `json:"version" bson:"version" yaml:"version" db:"dep_version"`
	Edges      []string      `bson:"edges" json:"edges" yaml:"edges" db:"_"`
	Dependency rawDependency `json:"dependency" bson:"dependency" yaml:"dependency" db:"dependency"`
}

DependencyInterchange objects are a standard form for dependency.Manager objects. Amboy (should) only pass DependencyInterchange objects between processes, which have the type information in easy to access and index-able locations.

type JobFactory

type JobFactory func() amboy.Job

JobFactory is an alias for a function that returns a Job interface. All Job implementation should have a factory function with this signature to use with the amboy.RegisterJobType and amboy.JobFactory functions that use an internal registry of jobs to handle correct serialization and de-serialization of job objects.

func GetJobFactory

func GetJobFactory(name string) (JobFactory, error)

GetJobFactory produces Job objects of specific implementations based on the type name, used in RegisterJobType and in the JobType.Name field.

type JobInterchange

type JobInterchange struct {
	Name       string                 `json:"name" bson:"_id" yaml:"name" db:"id"`
	Type       string                 `json:"type" bson:"type" yaml:"type" db:"type"`
	Group      string                 `bson:"group,omitempty" json:"group,omitempty" yaml:"group,omitempty" db:"queue_group"`
	Version    int                    `json:"version" bson:"version" yaml:"version" db:"version"`
	Priority   int                    `json:"priority" bson:"priority" yaml:"priority" db:"priority"`
	Status     amboy.JobStatusInfo    `bson:"status" json:"status" yaml:"status" db:"status"`
	Scopes     []string               `bson:"scopes,omitempty" json:"scopes,omitempty" yaml:"scopes,omitempty" db:"scopes"`
	TimeInfo   amboy.JobTimeInfo      `bson:"time_info" json:"time_info,omitempty" yaml:"time_info,omitempty" db:"time_info"`
	Job        rawJob                 `json:"job" bson:"job" yaml:"job" db:"body"`
	Dependency *DependencyInterchange `json:"dependency,omitempty" bson:"dependency,omitempty" yaml:"dependency,omitempty" db:"depdendency"`
}

JobInterchange provides a consistent way to describe and reliably serialize Job objects between different queue instances. Interchange is also used internally as part of JobGroup Job type.

func MakeJobInterchange

func MakeJobInterchange(j amboy.Job, convertTo Marshaler) (*JobInterchange, error)

MakeJobInterchange changes a Job interface into a JobInterchange structure, for easier serialization.

func (*JobInterchange) Raw

func (j *JobInterchange) Raw() []byte

Raw returns the serialized version of the job.

func (*JobInterchange) Resolve

func (j *JobInterchange) Resolve(convertFrom Unmarshaler) (amboy.Job, error)

Resolve reverses the process of ConvertToInterchange and converts the interchange format to a Job object using the types in the registry. Returns an error if the job type of the JobInterchange object isn't registered or the current version of the job produced by the registry is *not* the same as the version of the Job.

type Marshaler

type Marshaler func(interface{}) ([]byte, error)

type Unmarshaler

type Unmarshaler func([]byte, interface{}) error

Unmrashaler describes a standard function that takes a byte slice and populates an object from this serialized view, and is available as a type to make it more clear that queue implementations are responsible for mantaining their population

Jump to

Keyboard shortcuts

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