harvester

package module
v0.3.0 Latest Latest
Warning

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

Go to latest
Published: Sep 11, 2019 License: Apache-2.0 Imports: 7 Imported by: 0

README

Harvester CircleCI codecov Go Report Card GoDoc GitHub release

Harvester is a configuration library which helps setting up and monitoring configuration values in order to dynamically reconfigure your application.

Configuration can be obtained from the following sources:

  • Seed values, are hard-coded values into your configuration struct
  • Environment values, are obtained from the environment
  • Flag values, are obtained from CLI flags with the form -flag=value
  • Consul, which is used to get initial values and to monitor them for changes

The order is applied as it is listed above. Consul seeder and monitor are optional and will be used only if Harvester is created with the above components.

Harvester expects a go structure with tags which defines one or more of the above like the following:

type Config struct {
    Name    sync.String  `seed:"John Doe"`
    Age     sync.Int64   `seed:"18" env:"ENV_AGE"`
    City    sync.String  `seed:"London" flag:"city"`
    IsAdmin sync.Bool    `seed:"true" env:"ENV_IS_ADMIN" consul:"/config/is-admin"`
}

The above defines the following fields:

  • Name, which will be seeded with the value John Doe
  • Age, which will be seeded with the value 18, and if exists, overridden with whatever value the env var ENV_AGE holds
  • City, which will be seeded with the value London, and if exists, overridden with whatever value the flag city holds
  • IsAdmin, which will be seeded with the value true, and if exists, overridden with whatever value the env var ENV_AGE holds and then from consul if the consul seeder and/or watcher are provided.

The fields have to be one of the types that the sync package supports in order to allow concurrent read and write to the fields. The following types are supported:

  • sync.String, allows for concurrent string manipulation
  • sync.Int64, allows for concurrent int64 manipulation
  • sync.Float64, allows for concurrent float64 manipulation
  • sync.Bool, allows for concurrent bool manipulation

Harvester has a seeding phase and an optional monitoring phase.

Seeding phase

  • Apply the seed tag value, if present
  • Apply the value contained in the env var, if present
  • Apply the value returned from Consul, if present and harvester is setup to seed from consul
  • Apply the value contained in the CLI flags, if present

Conditions where seeding fails:

  • If at the end of the seeding phase one or more fields have not been seeded
  • If the seed value is invalid
Seeder

Harvester allows the creation of custom getters which are used by the seeder and implement the following interface:

type Getter interface {
    Get(key string) (string, error)
}

Seed and env tags are supported by default, the Consul getter has to be setup when creating a Harvester with the builder.

Monitoring phase (Consul only)

  • Monitor a key and apply if tag key matches
  • Monitor a key-prefix and apply if tag key matches
Monitor

Harvester allows for dynamically changing the config value by monitoring a source. The following sources are available:

  • Consul, which supports monitoring for keys and key-prefixes.

This feature have to be setup when creating a Harvester with the builder.

Builder

The Harvester builder pattern is used to create a Harvester instance. The builder supports setting up:

  • Consul seed, for setting up seeding from Consul
  • Consul monitor, for setting up monitoring from Consul
    h, err := New(&cfg).
                WithConsulSeed("address", "dc", "token").
                WithConsulMonitor("address", "dc", "token", items...).
                Create()

The above snippet set's up a Harvester instance with consul seed and monitor.

Consul

Consul has support for versioning (ModifyIndex) which allows us to change the value only if the version is higher than the one currently.

Examples

Head over to examples readme on how to use harvester

How to Contribute

See Contribution Guidelines.

Code of conduct

Please note that this project is released with a Contributor Code of Conduct. By participating in this project and its community you agree to abide by those terms.

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Builder

type Builder struct {
	// contains filtered or unexported fields
}

Builder of a harvester instance.

func New

func New(cfg interface{}) *Builder

New constructor.

func (*Builder) Create

func (b *Builder) Create() (Harvester, error)

Create the harvester instance.

func (*Builder) WithConsulMonitor

func (b *Builder) WithConsulMonitor(addr, dc, token string, timeout time.Duration, ii ...consul.Item) *Builder

WithConsulMonitor enables support for monitoring key/prefixes on consul.

func (*Builder) WithConsulSeed

func (b *Builder) WithConsulSeed(addr, dataCenter, token string, timeout time.Duration) *Builder

WithConsulSeed enables support for seeding values with consul.

type Harvester

type Harvester interface {
	Harvest(ctx context.Context) error
}

Harvester interface.

type Monitor

type Monitor interface {
	Monitor(ctx context.Context) error
}

Monitor defines a interface for monitoring configuration changes from various sources.

type Seeder

type Seeder interface {
	Seed(cfg *config.Config) error
}

Seeder interface for seeding initial values of the configuration.

Directories

Path Synopsis
examples

Jump to

Keyboard shortcuts

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