Threat Model
Spoofing
-
A user can mistype the Makes installation command and wrongly install a different (potentially malicious) tool.
Mitigation:
- The installation command is given in plain-text, users can copy-paste it to avoid typos.
-
A user can mistype the target project to be built with Makes, and end-up building (and potentially running) a different (potentially malicious) project.
Mitigation:
- The most common use case
(running makes on the project in the current working directory)
has a very convenient syntax:
$ m .
, which is very unlikely to be mistyped. - When referencing a project over the internet, the user is forced to use a git provider (github/gitlab), the owner account (which should be trusted by the user), the target repository, and a branch, commit or tag.
By using a commit, the user can force the integrity of the downloaded data to match what they expect.
- The most common use case
(running makes on the project in the current working directory)
has a very convenient syntax:
Tampering
-
The Nix Store can be tampered with if no good installation measures are taken by the user.
Mitigation:
- The Nix installation is responsibility of the user,
but in general,
a user could bind mount
/nix
as a read-only file system, and make the/nix/store
only accessible by root and thenixbld
group users, reducing an attack vector to the physical or local layer, which can be further protected by the use of frameworks like SLSA, and full disk encryption using LUKS.
- The Nix installation is responsibility of the user,
but in general,
a user could bind mount
Repudiation
-
In single tenant setups, for instance when developers run Makes in their laptops, there is nothing to repudiate, there is only one user performing builds (the developer). However, in multi-tenant setups, for instance when Makes is run in a shared CI/CD system, a user could deny running a build.
Mitigation:
- Makes produces SLSA Provenance Attestations, which identify the builder and the built artifact.
- Most CI/CD systems (and particularly the ones supported by Makes) offer logs collection, so it would be easy to associate a build with the identity that triggered it. It is responsibility of the users to configure such CI/CD systems in a secure way and to protect (and backup) the logs.
Information Disclosure
-
Although the
/nix/store
is individual per user, a user may write secrets to it, and then those secrets can be published to a binary cache that is publicly accessible.Examples of this include Nix idioms like:
Mitigation:
- Nothing from the
/nix/store
is pushed to a binary cache by default. A user would need to configure the cache explicitly, and expose the corresponding secret in an environment variable. - Makes has support for binary caches
that require a secret for reading and writting,
so a user may chose to use this instead
as an extra layer of prevention
if loading secrets to the
/nix/store
is mandatory. Please see https://cachix.org/ for more information. -
Makes has utilities for working with secrets in a way that they are only copied to the
/nix/store
in encrypted form, and then decrypted at runtime, where there are safe from disclosure.For example:
secretsForAwsFromEnv
,secretsForAwsFromGitlab
,secretsForEnvFromSops
, andsecretsForTerraformFromEnv
.However, we don't currently have a way to protect the user from using
builtins.fetch*
. If your workflow needs this, please avoid pushing artifacts to a public binary cache, or use a private binary cache instead. -
Makes copies the contents of the git repository into a trusted control plane, and excludes all of the files that are not tracked by Git from this checkout. This means that if the file with secrets is inside the repository, but included in the
.gitignore
such that agit fetch
of the given remote and revision would ignore it, Makes would not copy it into the trusted control plane, and therefore Nix wouldn't load it into the/nix/store
.
- Nothing from the
Denial of Service
WIP
Elevation of Privileges
WIP