SOPS Block

Table of Contents

Provider Contracts
Usage
Options Reference

Defined in /modules/blocks/sops.nix.

This block sets up a sops-nix secret.

It is only a small layer on top of sops-nix options to adapt it to the secret contract.

Provider Contracts

This block provides the following contracts:

As requested by the contract, when asking for a secret with the shb.sops module, the path where the secret will be located can be found under the shb.sops.secrets.<name>.result option.

Usage

First, a file with encrypted secrets must be created by following the secrets setup section.

With Requester Module

This example shows how to use this sops block to fulfill the request of a module using the secret contract under the option services.mymodule.mysecret.

shb.sops.secret."mymodule/mysecret".request = config.services.mymodule.mysecret.request;
services.mymodule.mysecret.result = config.shb.sops.secret."mymodule/mysecret".result;

Manual Module

The provider module can be used on its own, without a requester module:

shb.sops.secret."mymodule/mysecret".request = {
  mode = "0400";
  owner = "owner";
};
services.mymodule.mysecret.path = config.sops.secret."mymodule/mysecret".result.path;

Options Reference

shb.sops.secret

Secret following the secret contract.

Type: attribute set of (submodule)

Default: { }

Declared by:

<selfhostblocks/modules/blocks/sops.nix>
shb.sops.secret.<name>.request

Request part of the secret contract.

Options set by the requester module enforcing some properties the secret should have.

Type: submodule

Default: ""

Declared by:

<selfhostblocks/modules/blocks/sops.nix>
shb.sops.secret.<name>.request.group

Linux group owning the secret file.

Type: string

Default: "root"

Declared by:

<selfhostblocks/modules/blocks/sops.nix>
shb.sops.secret.<name>.request.mode

Mode of the secret file.

Type: string

Default: "0400"

Declared by:

<selfhostblocks/modules/blocks/sops.nix>
shb.sops.secret.<name>.request.owner

Linux user owning the secret file.

Type: string

Default: "root"

Declared by:

<selfhostblocks/modules/blocks/sops.nix>
shb.sops.secret.<name>.request.restartUnits

Systemd units to restart after the secret is updated.

Type: list of string

Default: [ ]

Declared by:

<selfhostblocks/modules/blocks/sops.nix>
shb.sops.secret.<name>.result

Result part of the secret contract.

Options set by the provider module that indicates where the secret can be found.

Type: submodule

Default:

{
  path = "/run/secrets/<name>";
}

Declared by:

<selfhostblocks/modules/blocks/sops.nix>
shb.sops.secret.<name>.result.path

Path to the file containing the secret generated out of band.

This path will exist after deploying to a target host, it is not available through the nix store.

Type: path

Default: "/run/secrets/<name>"

Declared by:

<selfhostblocks/modules/blocks/sops.nix>
shb.sops.secret.<name>.settings

Settings specific to the Sops provider.

This is a passthrough option to set sops-nix options.

Note though that the mode, owner, group, and restartUnits are managed by the shb.sops.secret.<name>.request option.

Type: attribute set of anything

Default: { }

Declared by:

<selfhostblocks/modules/blocks/sops.nix>