forked from clan/clan-core
Merge pull request 'clanModules: init packages' (#1697) from hsjobeki/clan-core:hsjobeki-main into main
This commit is contained in:
commit
7050dcc37f
@ -10,6 +10,7 @@
|
|||||||
single-disk = ./single-disk;
|
single-disk = ./single-disk;
|
||||||
matrix-synapse = ./matrix-synapse;
|
matrix-synapse = ./matrix-synapse;
|
||||||
moonlight = ./moonlight;
|
moonlight = ./moonlight;
|
||||||
|
packages = ./packages;
|
||||||
postgresql = ./postgresql;
|
postgresql = ./postgresql;
|
||||||
root-password = ./root-password;
|
root-password = ./root-password;
|
||||||
sshd = ./sshd;
|
sshd = ./sshd;
|
||||||
|
4
clanModules/packages/README.md
Normal file
4
clanModules/packages/README.md
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
---
|
||||||
|
description = "Define package sets from nixpkgs and install them on one or more machines"
|
||||||
|
categories = ["packages"]
|
||||||
|
---
|
19
clanModules/packages/default.nix
Normal file
19
clanModules/packages/default.nix
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
{
|
||||||
|
config,
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
options.clan.packages = {
|
||||||
|
packages = lib.mkOption {
|
||||||
|
type = lib.types.listOf lib.types.str;
|
||||||
|
description = "The packages to install on the machine";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
config = {
|
||||||
|
environment.systemPackages = map (
|
||||||
|
pName: lib.getAttrFromPath (lib.splitString "." pName) pkgs
|
||||||
|
) config.clan.packages.packages;
|
||||||
|
};
|
||||||
|
}
|
1
clanModules/packages/roles/default.nix
Normal file
1
clanModules/packages/roles/default.nix
Normal file
@ -0,0 +1 @@
|
|||||||
|
{ }
|
@ -59,6 +59,7 @@ nav:
|
|||||||
- reference/clanModules/localsend.md
|
- reference/clanModules/localsend.md
|
||||||
- reference/clanModules/matrix-synapse.md
|
- reference/clanModules/matrix-synapse.md
|
||||||
- reference/clanModules/moonlight.md
|
- reference/clanModules/moonlight.md
|
||||||
|
- reference/clanModules/packages.md
|
||||||
- reference/clanModules/postgresql.md
|
- reference/clanModules/postgresql.md
|
||||||
- reference/clanModules/root-password.md
|
- reference/clanModules/root-password.md
|
||||||
- reference/clanModules/single-disk.md
|
- reference/clanModules/single-disk.md
|
||||||
|
@ -9,6 +9,48 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"services": {
|
"services": {
|
||||||
|
"packages": {
|
||||||
|
"editors": {
|
||||||
|
"meta": {
|
||||||
|
"name": "Some editor packages"
|
||||||
|
},
|
||||||
|
"roles": {
|
||||||
|
"default": {
|
||||||
|
"machines": ["minimal-inventory-machine"]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"machines": {
|
||||||
|
"minimal-inventory-machine": {
|
||||||
|
"config": {
|
||||||
|
"packages": ["zed-editor"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"config": {
|
||||||
|
"packages": ["vim"]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"browsing": {
|
||||||
|
"meta": {
|
||||||
|
"name": "Web browsing packages"
|
||||||
|
},
|
||||||
|
"roles": {
|
||||||
|
"default": {
|
||||||
|
"machines": ["minimal-inventory-machine"]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"machines": {
|
||||||
|
"minimal-inventory-machine": {
|
||||||
|
"config": {
|
||||||
|
"packages": ["chromium"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"config": {
|
||||||
|
"packages": ["firefox"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"single-disk": {
|
"single-disk": {
|
||||||
"default": {
|
"default": {
|
||||||
"meta": {
|
"meta": {
|
||||||
|
Loading…
Reference in New Issue
Block a user