mirror of
https://gitlab.com/upRootNutrition/dotfiles.git
synced 2025-06-16 10:05:13 -05:00
refactor: improved readability
This commit is contained in:
parent
14b62b909a
commit
26eee6ca61
1 changed files with 92 additions and 96 deletions
|
@ -21,24 +21,6 @@
|
||||||
(builtins.genList (i: i) numOptions)
|
(builtins.genList (i: i) numOptions)
|
||||||
);
|
);
|
||||||
in let
|
in let
|
||||||
peopleSubmodule = lib.types.submodule {
|
|
||||||
options =
|
|
||||||
builtins.listToAttrs (
|
|
||||||
map (name: {
|
|
||||||
inherit name;
|
|
||||||
value = stringType;
|
|
||||||
})
|
|
||||||
[
|
|
||||||
"user0"
|
|
||||||
"user1"
|
|
||||||
]
|
|
||||||
)
|
|
||||||
// {
|
|
||||||
users = lib.mkOption {
|
|
||||||
type = lib.types.attrsOf userSubmodule;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
userSubmodule = lib.types.submodule {
|
userSubmodule = lib.types.submodule {
|
||||||
options = {
|
options = {
|
||||||
name = stringType;
|
name = stringType;
|
||||||
|
@ -49,41 +31,6 @@ in let
|
||||||
paths = genOptions stringType "path";
|
paths = genOptions stringType "path";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
serviceSubmodule = lib.types.submodule {
|
|
||||||
options =
|
|
||||||
builtins.listToAttrs (map (name: {
|
|
||||||
inherit name;
|
|
||||||
value = stringType;
|
|
||||||
})
|
|
||||||
[
|
|
||||||
"acme"
|
|
||||||
"caddy"
|
|
||||||
"castopod"
|
|
||||||
"forgejo"
|
|
||||||
"jellyfin"
|
|
||||||
"mastodon"
|
|
||||||
"matrix"
|
|
||||||
"minecraft"
|
|
||||||
"nextcloud"
|
|
||||||
"nginx"
|
|
||||||
"ollama"
|
|
||||||
"owncast"
|
|
||||||
"peertube"
|
|
||||||
"postgresql"
|
|
||||||
"samba"
|
|
||||||
"syncthing"
|
|
||||||
"synology"
|
|
||||||
"vaultwarden"
|
|
||||||
"web"
|
|
||||||
"wiki"
|
|
||||||
"writefreely"
|
|
||||||
])
|
|
||||||
// {
|
|
||||||
instances = lib.mkOption {
|
|
||||||
type = lib.types.attrsOf instanceSubmodule;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
instanceSubmodule = lib.types.submodule {
|
instanceSubmodule = lib.types.submodule {
|
||||||
options = {
|
options = {
|
||||||
subdomain = stringType;
|
subdomain = stringType;
|
||||||
|
@ -102,58 +49,107 @@ in let
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
machineSubmodule = lib.types.submodule {
|
deviceSubmodule = lib.types.submodule {
|
||||||
options =
|
options = let
|
||||||
builtins.listToAttrs (map (name: {
|
mountConfig = {
|
||||||
inherit name;
|
mount = stringType;
|
||||||
value = stringType;
|
device = stringType;
|
||||||
})
|
options = listType;
|
||||||
[
|
|
||||||
"desktop"
|
|
||||||
"laptop"
|
|
||||||
"nas"
|
|
||||||
"phone"
|
|
||||||
"printer0"
|
|
||||||
"printer1"
|
|
||||||
"server"
|
|
||||||
"tablet"
|
|
||||||
])
|
|
||||||
// {
|
|
||||||
devices = lib.mkOption {
|
|
||||||
type = lib.types.attrsOf deviceSubmodule;
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
in
|
||||||
|
{
|
||||||
|
boot = mountConfig;
|
||||||
|
ip = genOptions stringType "address";
|
||||||
|
label = stringType;
|
||||||
|
name = stringType;
|
||||||
|
sync = stringType;
|
||||||
|
}
|
||||||
|
// genOptions mountConfig "folder"
|
||||||
|
// genOptions mountConfig "samba"
|
||||||
|
// genOptions mountConfig "storage";
|
||||||
};
|
};
|
||||||
deviceSubmodule = let
|
|
||||||
mountConfig = {
|
|
||||||
mount = stringType;
|
|
||||||
device = stringType;
|
|
||||||
options = listType;
|
|
||||||
};
|
|
||||||
in
|
|
||||||
lib.types.submodule {
|
|
||||||
options =
|
|
||||||
{
|
|
||||||
boot = mountConfig;
|
|
||||||
ip = genOptions stringType "address";
|
|
||||||
label = stringType;
|
|
||||||
name = stringType;
|
|
||||||
sync = stringType;
|
|
||||||
}
|
|
||||||
// genOptions mountConfig "folder"
|
|
||||||
// genOptions mountConfig "samba"
|
|
||||||
// genOptions mountConfig "storage";
|
|
||||||
};
|
|
||||||
in {
|
in {
|
||||||
options = {
|
options = {
|
||||||
services = lib.mkOption {
|
services = lib.mkOption {
|
||||||
type = serviceSubmodule;
|
type = lib.types.submodule {
|
||||||
|
options =
|
||||||
|
builtins.listToAttrs (map (name: {
|
||||||
|
inherit name;
|
||||||
|
value = stringType;
|
||||||
|
})
|
||||||
|
[
|
||||||
|
"acme"
|
||||||
|
"caddy"
|
||||||
|
"castopod"
|
||||||
|
"forgejo"
|
||||||
|
"jellyfin"
|
||||||
|
"mastodon"
|
||||||
|
"matrix"
|
||||||
|
"minecraft"
|
||||||
|
"nextcloud"
|
||||||
|
"nginx"
|
||||||
|
"ollama"
|
||||||
|
"owncast"
|
||||||
|
"peertube"
|
||||||
|
"postgresql"
|
||||||
|
"samba"
|
||||||
|
"syncthing"
|
||||||
|
"synology"
|
||||||
|
"vaultwarden"
|
||||||
|
"web"
|
||||||
|
"wiki"
|
||||||
|
"writefreely"
|
||||||
|
])
|
||||||
|
// {
|
||||||
|
instances = lib.mkOption {
|
||||||
|
type = lib.types.attrsOf instanceSubmodule;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
machines = lib.mkOption {
|
machines = lib.mkOption {
|
||||||
type = machineSubmodule;
|
type = lib.types.submodule {
|
||||||
|
options =
|
||||||
|
builtins.listToAttrs (map (name: {
|
||||||
|
inherit name;
|
||||||
|
value = stringType;
|
||||||
|
})
|
||||||
|
[
|
||||||
|
"desktop"
|
||||||
|
"laptop"
|
||||||
|
"nas"
|
||||||
|
"phone"
|
||||||
|
"printer0"
|
||||||
|
"printer1"
|
||||||
|
"server"
|
||||||
|
"tablet"
|
||||||
|
])
|
||||||
|
// {
|
||||||
|
devices = lib.mkOption {
|
||||||
|
type = lib.types.attrsOf deviceSubmodule;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
people = lib.mkOption {
|
people = lib.mkOption {
|
||||||
type = peopleSubmodule;
|
type = lib.types.submodule {
|
||||||
|
options =
|
||||||
|
builtins.listToAttrs (
|
||||||
|
map (name: {
|
||||||
|
inherit name;
|
||||||
|
value = stringType;
|
||||||
|
})
|
||||||
|
[
|
||||||
|
"user0"
|
||||||
|
"user1"
|
||||||
|
]
|
||||||
|
)
|
||||||
|
// {
|
||||||
|
users = lib.mkOption {
|
||||||
|
type = lib.types.attrsOf userSubmodule;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue