Skip to content
/ gonfig Public

Gonfig is a Go library for loading, writing, and managing configuration data from a JSON file. It provides a variety of options for custom configuration based on the needs of the user.

License

Notifications You must be signed in to change notification settings

core49/gonfig

Repository files navigation

Go Version Project status Last commit Go Report Card codecov MIT license GoDoc

Gonfig

Gonfig is a Go library for loading, writing, and managing configuration data from a JSON file. It provides a variety of options for custom configuration based on the needs of the user.

Installation

Gonfig can be installed using go get:

go get github.com/core49/gonfig

Usage

To use Gonfig, first create a repository instance with your desired options:

package main

import "github.com/core49/gonfig"

type YourConfigStruct struct {
	Var1 string
	var2 int
}

func main() {
	// Create a new repository instance with options
	// It will not use the os arguments and uses the provided file path
	conf, err := gonfig.New(
		gonfig.OptionDisableDefaultFlagConfiguration(true),
		gonfig.OptionSetConfigFilePathVariable("/path/to/config.json"),
	)

	if err != nil {
		// Handle error
	}

	var config YourConfigStruct

	// Check if the file exists or if the file is empty
	if exists, err := conf.IsEmpty(&config); err != nil || exists {
		// handle error or what you want to do if the file exists
	}

	// Write an empty JSON skeleton of the struct/model to the file
	if err := conf.WriteSkeleton(&config); err != nil {
		// Handle error
	}

	// Load configuration data into a struct/model
	if err := conf.Load(&config); err != nil {
		// Handle error
	}
}

Options

The following options are available when creating a new repository instance:

  • OptionSetFileSystem(fs afero.Fs) - sets the file system to the given afero file system instance.
  • OptionSetConfigFilePathVariable(path string) - sets the file path to the given string.
  • OptionDisableDefaultFlagConfiguration(v bool) - disables the default flag configuration if set to true.
  • OptionSetFlagConfiguration(fc gonfig.FlagConfiguration) - sets the flag configuration to the given flag configuration slice.
  • OptionAppendFlagConfig(fc gonfig.FlagConfig) - appends the given flag configuration to the flag configuration slice.
  • OptionSetOsArgs(osArgs []string) - sets the os arguments to the given string slice.

Contributing

Contributions to the Gonfig project are welcome and encouraged! Please see the contributing guidelines for more information.

License

Gonfig is licensed under the MIT License.

About

Gonfig is a Go library for loading, writing, and managing configuration data from a JSON file. It provides a variety of options for custom configuration based on the needs of the user.

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages