gatus
Example
{config, ...}: {
gatus = {
enable = true;
db = {
type = "postgres";
passwordFile = config.sops.secrets."gatus/postgresPassword".path;
};
settings.endpoints = [
{
name = "Some website";
url = "https://example.com";
client.dns-resolver = "tcp://1.1.1.1:53";
conditions = [
"[STATUS] == 200"
];
}
];
oidc = {
enable = true;
clientSecretFile = config.sops.secrets."gatus/authelia_client_secret".path;
clientSecretHash = "$pbkdf2-sha512$...";
};
};
}Stack Options
nps.stacks.gatus.containers.gatus
Alias of {option}services.podman.containers.gatus.
nps.stacks.gatus.containers.gatus-db
Alias of {option}services.podman.containers.gatus-db.
nps.stacks.gatus.db.passwordFile
The file containing the PostgreSQL password for the database. Only used if db.type is set to "postgres".
nps.stacks.gatus.db.type
Type of the database to use.
Can be set to "sqlite" or "postgres".
If set to "postgres", the passwordFile option must be set.
nps.stacks.gatus.db.username
The PostgreSQL user to use for the database. Only used if db.type is set to "postgres".
nps.stacks.gatus.defaultEndpoint
Default endpoint settings. Will merged with each provided endpoint. Only applies if endpoint does not override the default endpoint settings.
YAML 1.1 value
{
client = {
insecure = true;
timeout = "10s";
};
conditions = [
"[STATUS] >= 200"
"[STATUS] < 300"
];
group = "core";
interval = "5m";
}
nps.stacks.gatus.enable
Whether to enable Gatus. The module also provides an extension that will add Gatus options to a container. This allows services to be added to Gatus by settings container options.
nps.stacks.gatus.extraEnv
Extra environment variables to set for the container. Variables can be either set directly or sourced from a file (e.g. for secrets).
See https://github.com/TwiN/gatus?tab=readme-ov-file#configuration
attribute set of (null or boolean or signed integer or string or absolute path or (submodule))
{ }
{
FOO = "bar";
SOME_SECRET = {
fromFile = "/run/secrets/secret_name";
};
}
nps.stacks.gatus.extraSettingsFiles
List of additional YAML files to include in the settings. These files will be mounted as is. Can be used to directly provide YAML files containing secrets, e.g. from sops
nps.stacks.gatus.oidc.clientSecretFile
The file containing the client secret for the Gatus OIDC client that will be registered in Authelia.
nps.stacks.gatus.oidc.clientSecretHash
The hashed client_secret. Will be set in the Authelia client config. For examples on how to generate a client secret, see
https://www.authelia.com/integration/openid-connect/frequently-asked-questions/#client-secret
nps.stacks.gatus.oidc.enable
Whether to enable OIDC login with Authelia. This will register an OIDC client in Authelia and setup the necessary configuration.
For details, see:
nps.stacks.gatus.oidc.userGroup
Users of this group will be able to log in
nps.stacks.gatus.settings
Settings for the Gatus container. Will be converted to YAML and passed to the container.