Environment variables configuration package for Go microservices.

gocfg

Environment variables configuration package for Go microservices. It helps validate environment variable values and set default values if needed.

Each variable could be defined as required which will cause an error if the environment variable was not defined and doesn't have a default value.

Usage

The init process is split into 2 parts. At first, you need to create a new Config and define the required variables:

cfg := gocfg.New()
var value string
v := &gocfg.Variable{Name: "API_URL"}
cfg.SetString(&value, v)

After all required variables were defined you need to run the Parse() method. It will look up all the variables and validate them:

if err := cfg.Parse(); err != nil {
    log.Fatal(err)
}

Validation

You can validate variable values with predefined validation functions or create custom funcs of the following type func(value interface{}) error. Here is an example of how to create custom validation func:

func ValidateStringRegexpMatch(exp string) func(value interface{}) error {
	return func(value interface{}) error {
		v := value.(string)
		ok, err := regexp.MatchString(exp, v)
		if err != nil {
			return err
		}
		if !ok {
			return fmt.Errorf("value '%s' does not match regular expression '%s'", v, exp)
		}
		return nil
	}
}

func main() {
    v := &gocfg.Variable{
        Name: "API_URL", 
        ValidationFunc: gocfg.ValidateStringRegexpMatch(`^http(s)?\:\/\/.*$`),
    }
    // your code here
}

As you can see you need to do type assetion of the value interface{} argument.

Here is the list of predefined ValidationFuncs:

  • ValidateStringRegexpMatch
  • ValidateStringContains
  • ValidateStringHasPrefix
  • ValidateStringHasSuffix

Example

package main

import (
	"log"

	"github.com/sprokhorov/gocfg"
)

type Config struct {
	ApiURL string
}

func main() {
	cfg := gocfg.New()
	var appCfg Config
	v := &gocfg.Variable{
		Name:           "API_URL",
		Required:       true,
		ValidationFunc: gocfg.ValidateStringRegexpMatch(`^http(s)?\:\/\/.*$`),
	}
	cfg.SetString(&appCfg.ApiURL, v)
	if err := cfg.Parse(); err != nil {
		log.Fatal(err)
	}
}

Owner
Sergey Prokhorov
DevOps Engineer/Software Engineer
Sergey Prokhorov
Similar Resources

A Go library for parsing struct tags from environment variables.

Envconfig Envconfig populates struct field values based on environment variables or arbitrary lookup functions. It supports pre-setting mutations, whi

Jan 2, 2023

Environment variables substitution for Go

envsubst Environment variables substitution for Go. see docs below Installation: From binaries Latest stable envsubst prebuilt binaries for 64-bit Lin

Jan 1, 2023

Quickly read variables from environment files

go-quick-env Quickly read variables from environment files The best way to import environment variables to your code, is by using .env files. This lib

May 11, 2021

Read files into environment variables and execute command

read-file-to-env -- Read files into environment variables and execute command Example use: read-file-to-env -one-line=HOST=/etc/hostname sh -c 'echo h

Nov 12, 2021

A mapper of ENVironment variables to Structure for Go

envs a mapper of ENVironment variables to a Structure for Go. This library maps the environment variables to the struct according to the fields' types

Dec 3, 2021

formicidate is a small tool for Go application can update the value of environment variables in a .env file with code

formicidae Update .env files in Go with code. What is fomicidae? formicidate is a small tool for Go application. You can update the value of environme

Jan 23, 2022

✨Clean and minimalistic environment configuration reader for Golang

Clean Env Minimalistic configuration reader Overview This is a simple configuration reading tool. It just does the following: reads and parses configu

Jan 8, 2023

Golang Configuration tool that support YAML, JSON, TOML, Shell Environment

Configor Golang Configuration tool that support YAML, JSON, TOML, Shell Environment (Supports Go 1.10+) Usage package main import ( "fmt" "github.c

Dec 29, 2022

Tmpl - A tool to apply variables from cli, env, JSON/TOML/YAML files to templates

tmpl allows to apply variables from JSON/TOML/YAML files, environment variables or CLI arguments to template files using Golang text/template and functions from the Sprig project.

Nov 14, 2022
Related tags
Small library to read your configuration from environment variables

envconfig envconfig is a library which allows you to parse your configuration from environment variables and fill an arbitrary struct. See the example

Nov 3, 2022
goconfig uses a struct as input and populates the fields of this struct with parameters from command line, environment variables and configuration file.

goconfig goconfig uses a struct as input and populates the fields of this struct with parameters from command line, environment variables and configur

Dec 15, 2022
🛠 A configuration library for Go that parses environment variables, JSON files, and reloads automatically on SIGHUP
🛠 A configuration library for Go that parses environment variables, JSON files, and reloads automatically on SIGHUP

config A small configuration library for Go that parses environment variables, JSON files, and reloads automatically on SIGHUP. Example func main() {

Dec 11, 2022
Golang library for managing configuration data from environment variables

envconfig import "github.com/kelseyhightower/envconfig" Documentation See godoc Usage Set some environment variables: export MYAPP_DEBUG=false export

Dec 26, 2022
Golang library for reading properties from configuration files in JSON and YAML format or from environment variables.

go-config Golang library for reading properties from configuration files in JSON and YAML format or from environment variables. Usage Create config in

Aug 22, 2022
Lightweight package that makes easier and safer to deal with environment variables.

Envisage A lightweight package that makes easier and safer to deal with environment variables. Example Try it on On GoPlay https://goplay.tools/snippe

Apr 11, 2022
Simple lib to parse environment variables to structs

env Simple lib to parse envs to structs in Go. Example A very basic example: package main import ( "fmt" "time" // if using go modules "github.c

Jan 9, 2023
Un-marshaling environment variables to Go structs

envcfg Un-marshaling environment variables to Go structs Getting Started Let's set a bunch of environment variables and then run your go app #!/usr/bi

Sep 26, 2022
Go helpers to manage environment variables

Envh This library is made up of two parts : Env object : it wraps your environments variables in an object and provides convenient helpers. Env tree o

Sep 26, 2022
A Go port of Ruby's dotenv library (Loads environment variables from `.env`.)

GoDotEnv A Go (golang) port of the Ruby dotenv project (which loads env vars from a .env file) From the original Library: Storing configuration in the

Jan 5, 2023