2022-03-01 01:29:34 +00:00
|
|
|
#pragma once
|
2023-04-01 03:18:41 +00:00
|
|
|
///@file
|
2022-03-01 01:29:34 +00:00
|
|
|
|
|
|
|
#include "types.hh"
|
|
|
|
#include "config.hh"
|
|
|
|
|
|
|
|
#include <map>
|
|
|
|
#include <limits>
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
|
|
|
|
namespace nix {
|
|
|
|
|
|
|
|
struct FetchSettings : public Config
|
|
|
|
{
|
|
|
|
FetchSettings();
|
|
|
|
|
|
|
|
Setting<StringMap> accessTokens{this, {}, "access-tokens",
|
|
|
|
R"(
|
|
|
|
Access tokens used to access protected GitHub, GitLab, or
|
|
|
|
other locations requiring token-based authentication.
|
|
|
|
|
|
|
|
Access tokens are specified as a string made up of
|
|
|
|
space-separated `host=token` values. The specific token
|
|
|
|
used is selected by matching the `host` portion against the
|
|
|
|
"host" specification of the input. The actual use of the
|
|
|
|
`token` value is determined by the type of resource being
|
|
|
|
accessed:
|
|
|
|
|
|
|
|
* Github: the token value is the OAUTH-TOKEN string obtained
|
|
|
|
as the Personal Access Token from the Github server (see
|
2022-03-06 23:01:14 +00:00
|
|
|
https://docs.github.com/en/developers/apps/building-oauth-apps/authorizing-oauth-apps).
|
2022-03-01 01:29:34 +00:00
|
|
|
|
|
|
|
* Gitlab: the token value is either the OAuth2 token or the
|
|
|
|
Personal Access Token (these are different types tokens
|
|
|
|
for gitlab, see
|
|
|
|
https://docs.gitlab.com/12.10/ee/api/README.html#authentication).
|
|
|
|
The `token` value should be `type:tokenstring` where
|
|
|
|
`type` is either `OAuth2` or `PAT` to indicate which type
|
|
|
|
of token is being specified.
|
|
|
|
|
|
|
|
Example `~/.config/nix/nix.conf`:
|
|
|
|
|
|
|
|
```
|
|
|
|
access-tokens = github.com=23ac...b289 gitlab.mycompany.com=PAT:A123Bp_Cd..EfG gitlab.com=OAuth2:1jklw3jk
|
|
|
|
```
|
|
|
|
|
|
|
|
Example `~/code/flake.nix`:
|
|
|
|
|
|
|
|
```nix
|
|
|
|
input.foo = {
|
|
|
|
type = "gitlab";
|
|
|
|
host = "gitlab.mycompany.com";
|
|
|
|
owner = "mycompany";
|
|
|
|
repo = "pro";
|
|
|
|
};
|
|
|
|
```
|
|
|
|
|
|
|
|
This example specifies three tokens, one each for accessing
|
2023-02-24 15:17:47 +00:00
|
|
|
github.com, gitlab.mycompany.com, and gitlab.com.
|
2022-03-01 01:29:34 +00:00
|
|
|
|
|
|
|
The `input.foo` uses the "gitlab" fetcher, which might
|
|
|
|
requires specifying the token type along with the token
|
|
|
|
value.
|
|
|
|
)"};
|
|
|
|
|
|
|
|
Setting<bool> allowDirty{this, true, "allow-dirty",
|
|
|
|
"Whether to allow dirty Git/Mercurial trees."};
|
|
|
|
|
|
|
|
Setting<bool> warnDirty{this, true, "warn-dirty",
|
|
|
|
"Whether to warn about dirty Git/Mercurial trees."};
|
|
|
|
|
2024-05-15 09:11:32 +00:00
|
|
|
Setting<std::string> flakeRegistry{this, "vendored", "flake-registry",
|
2021-10-27 22:56:36 +00:00
|
|
|
R"(
|
|
|
|
Path or URI of the global flake registry.
|
|
|
|
|
2024-05-15 09:11:32 +00:00
|
|
|
URIs are deprecated. When set to 'vendored', defaults to a vendored
|
|
|
|
copy of https://channels.nixos.org/flake-registry.json.
|
|
|
|
|
2021-10-27 22:56:36 +00:00
|
|
|
When empty, disables the global flake registry.
|
2023-01-16 22:51:04 +00:00
|
|
|
)",
|
|
|
|
{}, true, Xp::Flakes};
|
2021-10-27 22:56:36 +00:00
|
|
|
|
2022-03-01 01:29:34 +00:00
|
|
|
|
|
|
|
Setting<bool> useRegistries{this, true, "use-registries",
|
2023-01-16 22:51:04 +00:00
|
|
|
"Whether to use flake registries to resolve flake references.",
|
|
|
|
{}, true, Xp::Flakes};
|
2022-03-01 01:29:34 +00:00
|
|
|
|
|
|
|
Setting<bool> acceptFlakeConfig{this, false, "accept-flake-config",
|
2024-06-11 02:55:40 +00:00
|
|
|
R"(
|
|
|
|
Whether to accept Lix configuration from the `nixConfig` attribute of
|
|
|
|
a flake without prompting. This is almost always a very bad idea.
|
|
|
|
|
|
|
|
Setting this setting as a trusted user allows Nix flakes to gain root
|
|
|
|
access on your machine if they set one of the several
|
|
|
|
trusted-user-only settings that execute commands as root.
|
|
|
|
|
|
|
|
See [multi-user installations](@docroot@/installation/multi-user.md)
|
|
|
|
for more details on the Lix security model.
|
|
|
|
)",
|
2023-01-16 22:51:04 +00:00
|
|
|
{}, true, Xp::Flakes};
|
2022-03-01 01:29:34 +00:00
|
|
|
|
|
|
|
Setting<std::string> commitLockFileSummary{
|
|
|
|
this, "", "commit-lockfile-summary",
|
|
|
|
R"(
|
|
|
|
The commit summary to use when committing changed flake lock files. If
|
|
|
|
empty, the summary is generated based on the action performed.
|
2023-01-16 22:51:04 +00:00
|
|
|
)",
|
|
|
|
{}, true, Xp::Flakes};
|
2022-03-01 01:29:34 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// FIXME: don't use a global variable.
|
|
|
|
extern FetchSettings fetchSettings;
|
|
|
|
|
|
|
|
}
|