summaryrefslogtreecommitdiff
path: root/modules/nixos/suites
diff options
context:
space:
mode:
Diffstat (limited to 'modules/nixos/suites')
-rw-r--r--modules/nixos/suites/default.nix6
-rw-r--r--modules/nixos/suites/personal.nix18
-rw-r--r--modules/nixos/suites/server.nix23
3 files changed, 47 insertions, 0 deletions
diff --git a/modules/nixos/suites/default.nix b/modules/nixos/suites/default.nix
new file mode 100644
index 0000000..0d11285
--- /dev/null
+++ b/modules/nixos/suites/default.nix
@@ -0,0 +1,6 @@
+{
+ imports = [
+ ./personal.nix
+ ./server.nix
+ ];
+}
diff --git a/modules/nixos/suites/personal.nix b/modules/nixos/suites/personal.nix
new file mode 100644
index 0000000..830062b
--- /dev/null
+++ b/modules/nixos/suites/personal.nix
@@ -0,0 +1,18 @@
+{
+ config,
+ lib,
+ secretsDir,
+ ...
+}: let
+ cfg = config.suites.personal;
+in {
+ config = lib.mkIf cfg.enable {
+ age = {
+ identityPaths = ["/etc/age/key"];
+ secrets = {
+ rootPassword.file = secretsDir + "/rootPassword.age";
+ sethPassword.file = secretsDir + "/sethPassword.age";
+ };
+ };
+ };
+}
diff --git a/modules/nixos/suites/server.nix b/modules/nixos/suites/server.nix
new file mode 100644
index 0000000..ac0c001
--- /dev/null
+++ b/modules/nixos/suites/server.nix
@@ -0,0 +1,23 @@
+{
+ config,
+ lib,
+ ...
+}: let
+ cfg = config.suites.server;
+in {
+ options.suites.server = {
+ enable = lib.mkEnableOption "Server configuration set";
+ };
+
+ config = lib.mkIf cfg.enable {
+ features.tailscale = {
+ enable = true;
+ ssh.enable = true;
+ };
+
+ server = {
+ enable = true;
+ secrets.enable = true;
+ };
+ };
+}