Documentation ¶
Index ¶
- type Acks
- type CompressionCodec
- type Configurer
- type ConsumerOpts
- type Driver
- func (d *Driver) Pause(ctx context.Context, p string) error
- func (d *Driver) Push(ctx context.Context, job jobs.Job) error
- func (d *Driver) Resume(ctx context.Context, p string) error
- func (d *Driver) Run(ctx context.Context, p jobs.Pipeline) error
- func (d *Driver) State(ctx context.Context) (*jobs.State, error)
- func (d *Driver) Stop(ctx context.Context) error
- type GroupOptions
- type Item
- func (i *Item) Ack() error
- func (i *Item) Body() []byte
- func (i *Item) Context() ([]byte, error)
- func (i *Item) Copy() *Item
- func (i *Item) ID() string
- func (i *Item) Metadata() map[string][]string
- func (i *Item) Nack() error
- func (i *Item) Priority() int64
- func (i *Item) Requeue(headers map[string][]string, _ int64) error
- func (i *Item) Respond(_ []byte, _ string) error
- type Offset
- type OffsetTypes
- type Options
- type ProducerOpts
- type SASL
- type SASLMechanism
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type CompressionCodec ¶
type CompressionCodec string
type Configurer ¶
type ConsumerOpts ¶
type ConsumerOpts struct { Topics []string `mapstructure:"topics" json:"topics"` ConsumeRegexp bool `mapstructure:"consume_regexp" json:"consume_regexp"` MaxFetchMessageSize int32 `mapstructure:"max_fetch_message_size" json:"max_fetch_message_size"` MinFetchMessageSize int32 `mapstructure:"min_fetch_message_size" json:"min_fetch_message_size"` ConsumePartitions map[string]map[int32]*Offset `mapstructure:"consume_partitions" json:"consume_partitions"` ConsumerOffset *Offset `mapstructure:"consumer_offset" json:"consumer_offset"` }
type Driver ¶
type Driver struct {
// contains filtered or unexported fields
}
func FromConfig ¶
func FromConfig(tracer *sdktrace.TracerProvider, configKey string, log *zap.Logger, cfg Configurer, pipeline jobs.Pipeline, pq pq.Queue, cmder chan<- jobs.Commander) (*Driver, error)
FromConfig initializes kafka pipeline from the configuration
func FromPipeline ¶
func FromPipeline(tracer *sdktrace.TracerProvider, pipeline jobs.Pipeline, log *zap.Logger, cfg Configurer, pq pq.Queue, cmder chan<- jobs.Commander) (*Driver, error)
FromPipeline initializes pipeline on-the-fly
type GroupOptions ¶
type Item ¶
type Item struct { // Job contains pluginName of job broker (usually PHP class). Job string `json:"job"` // Ident is unique identifier of the job, should be provided from outside Ident string `json:"id"` // Payload is string data (usually JSON) passed to Job broker. Payload string `json:"payload"` // Headers with key-values pairs Headers map[string][]string `json:"headers"` // Options contains set of PipelineOptions specific to job execution. Can be empty. Options *Options `json:"options,omitempty"` // contains filtered or unexported fields }
func (*Item) Context ¶
Context packs job context (job, id) into binary payload. Not used in the amqp, amqp.Table used instead
type Offset ¶
type Offset struct { Type OffsetTypes `mapstructure:"type"` Value int64 `mapstructure:"value"` }
type OffsetTypes ¶
type OffsetTypes string
const ( At OffsetTypes = "At" AfterMilli OffsetTypes = "AfterMilli" AtEnd OffsetTypes = "AtEnd" AtStart OffsetTypes = "AtStart" Relative OffsetTypes = "Relative" WithEpoch OffsetTypes = "WithEpoch" )
type Options ¶
type Options struct { // Priority is job priority, default - 10 // pointer to distinguish 0 as a priority and nil as priority not set Priority int64 `json:"priority"` // Pipeline manually specified pipeline. Pipeline string `json:"pipeline,omitempty"` // Delay defines time duration to delay execution for. Defaults to none. Delay int64 `json:"delay,omitempty"` // AutoAck option AutoAck bool `json:"auto_ack"` Topic string Metadata string Partition int32 Offset int64 }
Options carry information about how to handle given job.
type ProducerOpts ¶
type ProducerOpts struct { DisableIdempotent bool `mapstructure:"disable_idempotent" json:"disable_idempotent"` RequiredAcks Acks `mapstructure:"required_acks" json:"required_acks"` MaxMessageBytes int32 `mapstructure:"max_message_bytes" json:"max_message_bytes"` RequestTimeout time.Duration `mapstructure:"request_timeout" json:"request_timeout"` DeliveryTimeout time.Duration `mapstructure:"delivery_timeout" json:"delivery_timeout"` TransactionTimeout time.Duration `mapstructure:"transaction_timeout" json:"transaction_timeout"` CompressionCodec CompressionCodec `mapstructure:"compression_codec" json:"compression_codec"` }
type SASL ¶
type SASL struct { Type SASLMechanism `mapstructure:"type" json:"type"` // plain Username string `mapstructure:"username" json:"username"` Password string `mapstructure:"password" json:"password"` Zid string `mapstructure:"zid" json:"zid"` // aws_msk_iam AccessKey string `mapstructure:"access_key" json:"access_key"` SecretKey string `mapstructure:"secret_key" json:"secret_key"` SessionToken string `mapstructure:"session_token" json:"session_token"` UserAgent string `mapstructure:"user_agent" json:"user_agent"` }
type SASLMechanism ¶
type SASLMechanism string
Click to show internal directories.
Click to hide internal directories.