config

package
v1.0.1 Latest Latest
Warning

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

Go to latest
Published: Jan 8, 2021 License: MIT Imports: 10 Imported by: 0

Documentation

Overview

Package config provides an easy way to create and manage configurations for mey projects written in go.

By extending 'IContext' interface, developers can easily use a porject-specific configurations. It requires to provide base information.

 type IContext interface {
	GetDefaultConfig() interface{} //a default config struct filled with default values
	GetHomePath() string // a default home path
	GetConfigFileName() string // a config file name
	GetTemplate() string // a default toml config file template.
 }

Internally, the pkg has functions to find and manage a configuration file, and automatically generates toml file using the template, if the file does not exist. The template is filled with default values of GetDefaultConfig() The template must follow this format

string_type = "{{.STRUCT.FILED}}"
bool/number_type = {{.STRUCT.FILED}}
string_array_type = [{{range .STRUCT.FILED}}
"{{.}}", {{end}}
]
bool/number_array_type = [{{range .STRUCT.FILED}}
{{.}}, {{end}}
]
map = does not support

[substruct]
field_in_substruct = ...
...

.STRUCT and .FIELD must have a same name with a matched exported struct or field. You can find a detail example at a 'config_test.go' file.

If there exists multiple configration files, a priorty is

  1. filename given using a flag
  2. home set at env
  3. a default os home dir'

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type BaseContext

type BaseContext struct {
	IContext
	Vc *viper.Viper
}

BaseContext has IContext interface to get default information to find or generate a configuration file, and viper instance to store and perform actions

func NewBaseContext

func NewBaseContext(contextImpl IContext, homePath string, configFilePath string, envPrefix string) BaseContext

NewBaseContext returns a BaseContext that is used to load configuration easily.

This functions requests an IContext that contains basic config setting vars.

Other parameters(homePath, configFilePath, envPrefix) are optional. If you do not insert them, then this will automatically infer home and config path using a context of the given contextImpl. (see retrievePath func) If you insert only homePath, then this will try to find a config file at that path. Or if you insert only configFilePath, then this will try to open that file.

This only supports a toml extension.

func (*BaseContext) BindPFlags

func (ctx *BaseContext) BindPFlags(flagSet *pflag.FlagSet)

BindPFlags binds a flagSet, given at a command line, to this context and maps to configuration parameters

func (*BaseContext) ExpandPathEnv

func (ctx *BaseContext) ExpandPathEnv(path string) string

ExpandPathEnv is similar with 'os.ExpandEnv(s string)' func. This replace ${var} of $var in a path string according to the values of the current environment in the context. Undefined values are replaced by the empty string.

func (*BaseContext) LoadOrCreateConfig

func (ctx *BaseContext) LoadOrCreateConfig(defaultConf interface{}) error

LoadOrCreateConfig loads a config file using the information in a context. If the config file or it's parent directory doesn't exist, then this creats those first using a default name and an automatically generated configration text.

type IContext

type IContext interface {
	GetDefaultConfig() interface{}
	GetHomePath() string
	GetConfigFileName() string
	GetTemplate() string
}

IContext provides base information to search or create default configuration file

Jump to

Keyboard shortcuts

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