nixos/config/flakes: Factor out
This commit is contained in:
parent
d6a68f0542
commit
1c772cd857
88
nixos/modules/config/flakes.nix
Normal file
88
nixos/modules/config/flakes.nix
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
{ config, lib, ... }:
|
||||||
|
let
|
||||||
|
inherit (lib)
|
||||||
|
filterAttrs
|
||||||
|
literalExpression
|
||||||
|
mapAttrsToList
|
||||||
|
mkDefault
|
||||||
|
mkIf
|
||||||
|
mkOption
|
||||||
|
types
|
||||||
|
;
|
||||||
|
|
||||||
|
cfg = config.nix;
|
||||||
|
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options = {
|
||||||
|
nix = {
|
||||||
|
registry = mkOption {
|
||||||
|
type = types.attrsOf (types.submodule (
|
||||||
|
let
|
||||||
|
referenceAttrs = with types; attrsOf (oneOf [
|
||||||
|
str
|
||||||
|
int
|
||||||
|
bool
|
||||||
|
path
|
||||||
|
package
|
||||||
|
]);
|
||||||
|
in
|
||||||
|
{ config, name, ... }:
|
||||||
|
{
|
||||||
|
options = {
|
||||||
|
from = mkOption {
|
||||||
|
type = referenceAttrs;
|
||||||
|
example = { type = "indirect"; id = "nixpkgs"; };
|
||||||
|
description = lib.mdDoc "The flake reference to be rewritten.";
|
||||||
|
};
|
||||||
|
to = mkOption {
|
||||||
|
type = referenceAttrs;
|
||||||
|
example = { type = "github"; owner = "my-org"; repo = "my-nixpkgs"; };
|
||||||
|
description = lib.mdDoc "The flake reference {option}`from` is rewritten to.";
|
||||||
|
};
|
||||||
|
flake = mkOption {
|
||||||
|
type = types.nullOr types.attrs;
|
||||||
|
default = null;
|
||||||
|
example = literalExpression "nixpkgs";
|
||||||
|
description = lib.mdDoc ''
|
||||||
|
The flake input {option}`from` is rewritten to.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
exact = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = true;
|
||||||
|
description = lib.mdDoc ''
|
||||||
|
Whether the {option}`from` reference needs to match exactly. If set,
|
||||||
|
a {option}`from` reference like `nixpkgs` does not
|
||||||
|
match with a reference like `nixpkgs/nixos-20.03`.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
config = {
|
||||||
|
from = mkDefault { type = "indirect"; id = name; };
|
||||||
|
to = mkIf (config.flake != null) (mkDefault (
|
||||||
|
{
|
||||||
|
type = "path";
|
||||||
|
path = config.flake.outPath;
|
||||||
|
} // filterAttrs
|
||||||
|
(n: _: n == "lastModified" || n == "rev" || n == "revCount" || n == "narHash")
|
||||||
|
config.flake
|
||||||
|
));
|
||||||
|
};
|
||||||
|
}
|
||||||
|
));
|
||||||
|
default = { };
|
||||||
|
description = lib.mdDoc ''
|
||||||
|
A system-wide flake registry.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = mkIf cfg.enable {
|
||||||
|
environment.etc."nix/registry.json".text = builtins.toJSON {
|
||||||
|
version = 2;
|
||||||
|
flakes = mapAttrsToList (n: v: { inherit (v) from to exact; }) cfg.registry;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
@ -2,6 +2,7 @@
|
|||||||
./config/appstream.nix
|
./config/appstream.nix
|
||||||
./config/console.nix
|
./config/console.nix
|
||||||
./config/debug-info.nix
|
./config/debug-info.nix
|
||||||
|
./config/flakes.nix
|
||||||
./config/fonts/fontconfig.nix
|
./config/fonts/fontconfig.nix
|
||||||
./config/fonts/fontdir.nix
|
./config/fonts/fontdir.nix
|
||||||
./config/fonts/fonts.nix
|
./config/fonts/fonts.nix
|
||||||
|
@ -159,67 +159,6 @@ in
|
|||||||
(e.g. `<nixpkgs>`).
|
(e.g. `<nixpkgs>`).
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
registry = mkOption {
|
|
||||||
type = types.attrsOf (types.submodule (
|
|
||||||
let
|
|
||||||
referenceAttrs = with types; attrsOf (oneOf [
|
|
||||||
str
|
|
||||||
int
|
|
||||||
bool
|
|
||||||
path
|
|
||||||
package
|
|
||||||
]);
|
|
||||||
in
|
|
||||||
{ config, name, ... }:
|
|
||||||
{
|
|
||||||
options = {
|
|
||||||
from = mkOption {
|
|
||||||
type = referenceAttrs;
|
|
||||||
example = { type = "indirect"; id = "nixpkgs"; };
|
|
||||||
description = lib.mdDoc "The flake reference to be rewritten.";
|
|
||||||
};
|
|
||||||
to = mkOption {
|
|
||||||
type = referenceAttrs;
|
|
||||||
example = { type = "github"; owner = "my-org"; repo = "my-nixpkgs"; };
|
|
||||||
description = lib.mdDoc "The flake reference {option}`from` is rewritten to.";
|
|
||||||
};
|
|
||||||
flake = mkOption {
|
|
||||||
type = types.nullOr types.attrs;
|
|
||||||
default = null;
|
|
||||||
example = literalExpression "nixpkgs";
|
|
||||||
description = lib.mdDoc ''
|
|
||||||
The flake input {option}`from` is rewritten to.
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
exact = mkOption {
|
|
||||||
type = types.bool;
|
|
||||||
default = true;
|
|
||||||
description = lib.mdDoc ''
|
|
||||||
Whether the {option}`from` reference needs to match exactly. If set,
|
|
||||||
a {option}`from` reference like `nixpkgs` does not
|
|
||||||
match with a reference like `nixpkgs/nixos-20.03`.
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
config = {
|
|
||||||
from = mkDefault { type = "indirect"; id = name; };
|
|
||||||
to = mkIf (config.flake != null) (mkDefault (
|
|
||||||
{
|
|
||||||
type = "path";
|
|
||||||
path = config.flake.outPath;
|
|
||||||
} // filterAttrs
|
|
||||||
(n: _: n == "lastModified" || n == "rev" || n == "revCount" || n == "narHash")
|
|
||||||
config.flake
|
|
||||||
));
|
|
||||||
};
|
|
||||||
}
|
|
||||||
));
|
|
||||||
default = { };
|
|
||||||
description = lib.mdDoc ''
|
|
||||||
A system-wide flake registry.
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -234,11 +173,6 @@ in
|
|||||||
]
|
]
|
||||||
++ optional (config.programs.bash.enableCompletion) pkgs.nix-bash-completions;
|
++ optional (config.programs.bash.enableCompletion) pkgs.nix-bash-completions;
|
||||||
|
|
||||||
environment.etc."nix/registry.json".text = builtins.toJSON {
|
|
||||||
version = 2;
|
|
||||||
flakes = mapAttrsToList (n: v: { inherit (v) from to exact; }) cfg.registry;
|
|
||||||
};
|
|
||||||
|
|
||||||
systemd.packages = [ nixPackage ];
|
systemd.packages = [ nixPackage ];
|
||||||
|
|
||||||
# Will only work once https://github.com/NixOS/nix/pull/6285 is merged
|
# Will only work once https://github.com/NixOS/nix/pull/6285 is merged
|
||||||
|
Loading…
Reference in New Issue
Block a user