Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/caarlos0/env
A simple, zero-dependencies library to parse environment variables into structs
https://github.com/caarlos0/env
config configuration environment environment-variables go golang hacktoberfest
Last synced: 5 days ago
JSON representation
A simple, zero-dependencies library to parse environment variables into structs
- Host: GitHub
- URL: https://github.com/caarlos0/env
- Owner: caarlos0
- License: mit
- Created: 2015-07-28T02:14:37.000Z (over 9 years ago)
- Default Branch: main
- Last Pushed: 2024-12-20T11:46:14.000Z (about 1 month ago)
- Last Synced: 2025-01-06T15:12:25.589Z (19 days ago)
- Topics: config, configuration, environment, environment-variables, go, golang, hacktoberfest
- Language: Go
- Homepage: https://pkg.go.dev/github.com/caarlos0/env/v11
- Size: 434 KB
- Stars: 5,048
- Watchers: 28
- Forks: 258
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
Awesome Lists containing this project
- awesome-go - env - Parse environment variables to Go structs (with defaults). (Configuration / Standard CLI)
- fucking-awesome-go - env - Parse environment variables to Go structs (with defaults). (Configuration / Standard CLI)
- zero - env
- awesome-starred-test - caarlos0/env - A simple, zero-dependencies library to parse environment variables into structs (Go)
- awesome-repositories - caarlos0/env - A simple, zero-dependencies library to parse environment variables into structs (Go)
- awesome-go - env - Parse environment variables to Go structs (with defaults). (Configuration / Standard CLI)
- go-awesome - env - Parse ENV environment variables into a structure (Open source library / Construction)
- awesome-list - env
- awesome-golang-repositories - env - dependencies library to parse environment variables into structs. (Repositories)
- awesome-go - env - Parse environment variables to Go structs (with defaults). (Configuration / Standard CLI)
- awesome-go - env - A KISS way to deal with environment variables in Go. - ★ 615 (Configuration)
- awesome-go-extra - env - dependencies library to parse environment variables into structs.|2646|180|0|2015-07-28T02:14:37Z|2022-08-22T12:38:16Z| (Configuration / Advanced Console UIs)
- awesome-go-with-stars - env - Parse environment variables to Go structs (with defaults). (Configuration / Standard CLI)
- my-awesome - caarlos0/env - variables,go,golang,hacktoberfest pushed_at:2024-12 star:5.1k fork:0.3k A simple, zero-dependencies library to parse environment variables into structs (Go)
- awesome-go - env - Parse environment variables to Go structs (with defaults). Stars:`5.1K`. (Configuration / Standard CLI)
- awesome-go-cn - env
- awesome-go-plus - env - Parse environment variables to Go structs (with defaults). ![stars](https://img.shields.io/badge/stars-5080-blue) (Configuration / Standard CLI)
- awesome-go-plus - env - Parse environment variables to Go structs (with defaults). (Configuration / Standard CLI)
- awesome-go - env
- awesome-go - env
README
A simple, zero-dependencies library to parse environment variables into structs.
###### Installation
```bash
go get github.com/caarlos0/env/v11
```###### Getting started
```go
type config struct {
Home string `env:"HOME"`
}// parse
var cfg config
err := env.Parse(&cfg)// parse with generics
cfg, err := env.ParseAs[config]()
```You can see the full documentation and list of examples at [pkg.go.dev](https://pkg.go.dev/github.com/caarlos0/env/v11).
---
## Used and supported by
Encore – the platform for building Go-based cloud backends.
## Usage
### Caveats
> [!CAUTION]
>
> _Unexported fields_ will be **ignored** by `env`.
> This is by design and will not change.### Functions
- `Parse`: parse the current environment into a type
- `ParseAs`: parse the current environment into a type using generics
- `ParseWithOptions`: parse the current environment into a type with custom options
- `ParseAsWithOptions`: parse the current environment into a type with custom options and using generics
- `Must`: can be used to wrap `Parse.*` calls to panic on error
- `GetFieldParams`: get the `env` parsed options for a type
- `GetFieldParamsWithOptions`: get the `env` parsed options for a type with custom options### Supported types
Out of the box all built-in types are supported, plus a few others that are commonly used.
Complete list:
- `bool`
- `float32`
- `float64`
- `int16`
- `int32`
- `int64`
- `int8`
- `int`
- `string`
- `uint16`
- `uint32`
- `uint64`
- `uint8`
- `uint`
- `time.Duration`
- `time.Location`
- `encoding.TextUnmarshaler`
- `url.URL`Pointers, slices and slices of pointers, and maps of those types are also supported.
You may also add custom parsers for your types.
### Tags
The following tags are provided:
- `env`: sets the environment variable name and optionally takes the tag options described below
- `envDefault`: sets the default value for the field
- `envPrefix`: can be used in a field that is a complex type to set a prefix to all environment variables used in it
- `envSeparator`: sets the character to be used to separate items in slices and maps (default: `,`)
- `envKeyValSeparator`: sets the character to be used to separate keys and their values in maps (default: `:`)### `env` tag options
Here are all the options available for the `env` tag:
- `,expand`: expands environment variables, e.g. `FOO_${BAR}`
- `,file`: instructs that the content of the variable is a path to a file that should be read
- `,init`: initialize nil pointers
- `,notEmpty`: make the field errors if the environment variable is empty
- `,required`: make the field errors if the environment variable is not set
- `,unset`: unset the environment variable after use### Parse Options
There are a few options available in the functions that end with `WithOptions`:
- `Environment`: keys and values to be used instead of `os.Environ()`
- `TagName`: specifies another tag name to use rather than the default `env`
- `PrefixTagName`: specifies another prefix tag name to use rather than the default `envPrefix`
- `DefaultValueTagName`: specifies another default tag name to use rather than the default `envDefault`
- `RequiredIfNoDef`: set all `env` fields as required if they do not declare `envDefault`
- `OnSet`: allows to hook into the `env` parsing and do something when a value is set
- `Prefix`: prefix to be used in all environment variables
- `UseFieldNameByDefault`: defines whether or not `env` should use the field name by default if the `env` key is missing
- `FuncMap`: custom parse functions for custom types### Documentation and examples
Examples are live in [pkg.go.dev](https://pkg.go.dev/github.com/caarlos0/env/v11),
and also in the [example test file](./example_test.go).## Current state
`env` is considered feature-complete.
I do not intent to add any new features unless they really make sense, and are
requested by many people.Eventual bug fixes will keep being merged.
## Badges
[![Release](https://img.shields.io/github/release/caarlos0/env.svg?style=for-the-badge)](https://github.com/goreleaser/goreleaser/releases/latest)
[![Software License](https://img.shields.io/badge/license-MIT-brightgreen.svg?style=for-the-badge)](/LICENSE.md)
[![Build status](https://img.shields.io/github/actions/workflow/status/caarlos0/env/build.yml?style=for-the-badge&branch=main)](https://github.com/caarlos0/env/actions?workflow=build)
[![Codecov branch](https://img.shields.io/codecov/c/github/caarlos0/env/main.svg?style=for-the-badge)](https://codecov.io/gh/caarlos0/env)
[![Go docs](https://img.shields.io/badge/godoc-reference-blue.svg?style=for-the-badge)](http://godoc.org/github.com/caarlos0/env/v11)
[![Powered By: GoReleaser](https://img.shields.io/badge/powered%20by-goreleaser-green.svg?style=for-the-badge)](https://github.com/goreleaser)
[![Conventional Commits](https://img.shields.io/badge/Conventional%20Commits-1.0.0-yellow.svg?style=for-the-badge)](https://conventionalcommits.org)## Related projects
- [envdoc](https://github.com/g4s8/envdoc) - generate documentation for environment variables from `env` tags
## Stargazers over time
[![Stargazers over time](https://starchart.cc/caarlos0/env.svg)](https://starchart.cc/caarlos0/env)