feat: allow loading of environment variables from file

pull/20/head
adaexec 6 months ago
parent 80b6f4deaa
commit 8b61b4ec49

@ -3,6 +3,7 @@ package main
import (
"fmt"
"os"
"strings"
"github.com/gabehf/koito/engine"
)
@ -11,7 +12,7 @@ var Version = "dev"
func main() {
if err := engine.Run(
os.Getenv,
readEnvOrFile,
os.Stdout,
Version,
); err != nil {
@ -19,3 +20,21 @@ func main() {
os.Exit(1)
}
}
func readEnvOrFile(envName string) string {
envContent := os.Getenv(envName)
if envContent == "" {
filename := os.Getenv(envName + "_FILE")
if filename != "" {
b, err := os.ReadFile(filename)
if err == nil {
envContent = strings.TrimSpace(string(b))
}
}
}
return envContent
}

@ -5,6 +5,12 @@ description: The available configuration options when setting up Koito.
Koito is configured using **environment variables**. This is the full list of configuration options supported by Koito.
The suffix `_FILE` is also supported for every environment variable. This allows the use of Docker secrets, for example: `KOITO_DATABASE_URL_FILE=/run/secrets/database-url` will load the content of the file at `/run/secrets/database-url` for the environment variable `KOITO_DATABASE_URL`.
:::caution
If the environment variable is defined without **and** with the suffix at the same time, the content of the environment variable without the `_FILE` suffix will have the higher priority.
:::
##### KOITO_DATABASE_URL
- Required: `true`
- Description: A Postgres connection URI. See https://www.postgresql.org/docs/current/libpq-connect.html#LIBPQ-CONNSTRING-URIS for more information.

Loading…
Cancel
Save