Skip to content

brockwood/gostrufig

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Gostrufig

Struct driven config management for your Go application!

As a developer, how many times have you been at the mercy of an underlying configuration library to populate configuration data stored in a struct? If you're anything like me, too many to count. That's why there's now Gostrufig! Using a few simple tags and the Gostrufig library, you can manage all of your configuration items right in the struct! Plus, as an added bonus, there's an included persistence layer that will pull data from Etcd. Want an example? First let's do a little importing of packages:

import (
	"github.com/brockwood/gostrufig"
	"github.com/brockwood/gostrufig/driver/etcd" // The gostrufig driver I would like to use
)

With that out of the way, let's get some config data:

type MyConfigInfo struct {
		DecodeDir   string `cfg-def:"/home/user/decoder"`
		Environment string `cfg-ns:"true" cfg-def:"developer"`
		Timer       int
		Type        string
		TestTimeout float64
}
ns := MyConfigInfo{}
etcddriver := etcd.GetGostrufigDriver()
gostrufig := GetGostrufig("appname", "http://localhost:2379", etcddriver)
gostrufig.RetrieveConfig(&ns)

Drivers

Gostrufig comes with a driver interface so that a program can retrieve their configuration data from a backend. Right now, the only driver is for Etcd but the interface is written in such a way that other backends can easily be added.

Struct Tags And Their Function

Does this wet your appetite? Good. Let me fill you in on those sweet sweet tags!

cfg-def

This dandy little tag will allow you to set a default value for that field. Don't worry, Gostrufig handles all the reflection to figure out how to turn that string into the value your struct desires. Set it and forget it!

cfg-ns

This guy might be a bit confusing at first but, in the age of microservices and centralized configs, it'll make more sense. If your app runs in multiple environments but shares a common config, this namespace tag will construct a unique path for that value. For the example above, the configuration would be located at /appname/developer in Etcd. If Environment was set to "production" instead, it would be /appname/production.

Environmental Awareness

To go along with setting a default value in the struct itself, Gostrufig will look at the shell environment for any configuration items. If you wish to override the Environment field above in the shell, just go ahead and set the value for APPNAME_ENVIRONMENT. A good example would be:

export APPNAME_ENVIRONMENT=production

Gostrufig will automagically look for the capitalized names combining the application name and the field name. It's just that easy!

TODO

This is just the start. Coming soon will be:

  • Allowing a program to commit a config back to the persistence layer (you know, if your app has never run against an Etcd server, save your config to Etcd on first run)
  • A YAML and/or JSON persistence layer
  • Notification when a configuration changes and allow an app to update the config without a restart

About

Struct focused config management for Go

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages