By default a consumer will scan for records every 250ms. This interval can be configured with WithScanInterval.
66 lines
1.4 KiB
Go
66 lines
1.4 KiB
Go
package consumer
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/aws/aws-sdk-go/service/kinesis/kinesisiface"
|
|
)
|
|
|
|
// Option is used to override defaults when creating a new Consumer
|
|
type Option func(*Consumer)
|
|
|
|
// WithGroup overrides the default storage
|
|
func WithGroup(group Group) Option {
|
|
return func(c *Consumer) {
|
|
c.group = group
|
|
}
|
|
}
|
|
|
|
// WithStore overrides the default storage
|
|
func WithStore(store Store) Option {
|
|
return func(c *Consumer) {
|
|
c.store = store
|
|
}
|
|
}
|
|
|
|
// WithLogger overrides the default logger
|
|
func WithLogger(logger Logger) Option {
|
|
return func(c *Consumer) {
|
|
c.logger = logger
|
|
}
|
|
}
|
|
|
|
// WithCounter overrides the default counter
|
|
func WithCounter(counter Counter) Option {
|
|
return func(c *Consumer) {
|
|
c.counter = counter
|
|
}
|
|
}
|
|
|
|
// WithClient overrides the default client
|
|
func WithClient(client kinesisiface.KinesisAPI) Option {
|
|
return func(c *Consumer) {
|
|
c.client = client
|
|
}
|
|
}
|
|
|
|
// WithShardIteratorType overrides the starting point for the consumer
|
|
func WithShardIteratorType(t string) Option {
|
|
return func(c *Consumer) {
|
|
c.initialShardIteratorType = t
|
|
}
|
|
}
|
|
|
|
// WithTimestamp overrides the starting point for the consumer
|
|
func WithTimestamp(t time.Time) Option {
|
|
return func(c *Consumer) {
|
|
c.initialTimestamp = &t
|
|
}
|
|
}
|
|
|
|
// WithScanInterval overrides the scan interval for the consumer
|
|
func WithScanInterval(d time.Duration) Option {
|
|
return func(c *Consumer) {
|
|
c.scanInterval = d
|
|
}
|
|
}
|