nix/utils/default.nix

110 lines
3.8 KiB
Nix
Raw Normal View History

2024-12-15 23:36:16 -07:00
{ inputs, secrets }:
{
2025-01-06 18:32:12 -07:00
createHomeManagerConfig = {
system ? "x86_64-linux",
meta ? {}
2025-01-06 18:32:12 -07:00
}: inputs.home-manager.lib.homeManagerConfiguration {
2025-01-06 18:51:02 -07:00
pkgs = import inputs.nixpkgs { inherit system; config.allowUnfree = true; };
modules = [
2025-01-06 18:51:02 -07:00
../home-manager/standalone.nix
{ meta.home-manager = meta; }
];
2025-01-06 18:32:12 -07:00
extraSpecialArgs = {
inherit inputs system secrets;
2025-01-06 18:32:12 -07:00
pkgs-stable = inputs.nixpkgs-stable.legacyPackages.${system};
};
};
2025-01-06 18:32:12 -07:00
2024-12-15 23:36:16 -07:00
createNixosSystem = {
system ? "x86_64-linux",
entrypoint
}: inputs.nixpkgs.lib.nixosSystem {
inherit system;
specialArgs = {
inherit inputs system secrets;
pkgs-stable = inputs.nixpkgs-stable.legacyPackages.${system};
2024-12-15 23:36:16 -07:00
};
modules = [ entrypoint ];
};
createColmenaHive = {
defaultSystem ? "x86_64-linux",
hostConfigs ? []
}: {
# Set meta options for the colmena hive
meta = {
# Standard options
allowApplyAll = false;
# Defaults for nodes
nixpkgs = import inputs.nixpkgs { system = defaultSystem; };
specialArgs = {
inherit inputs secrets;
system = defaultSystem;
};
# Overrides for individual nodes
nodeNixpkgs = (
builtins.foldl'
(acc: cur:
acc // {
${cur.name} = inputs.nixpkgs.legacyPackages.${cur.system};
2024-12-15 23:36:16 -07:00
}
)
{}
(builtins.filter
(c: builtins.hasAttr "system" c && c.system != defaultSystem)
hostConfigs)
);
nodeSpecialArgs = (
builtins.foldl'
(acc: cur:
acc // {
${cur.name} = {
inherit inputs secrets;
system = cur.system;
pkgs-stable = inputs.nixpkgs-stable.legacyPackages.${cur.system};
2024-12-15 23:36:16 -07:00
};
}
)
{}
(builtins.filter
(c: builtins.hasAttr "system" c && c.system != defaultSystem)
hostConfigs)
);
};
} // (
# Add all of the hosts
builtins.foldl'
(acc: cur:
acc // {
${cur.name} = { ... }: {
deployment = {
2024-12-15 23:45:19 -07:00
replaceUnknownProfiles = if (builtins.hasAttr "allowLocal" cur) then cur.allowLocal else false;
2024-12-15 23:36:16 -07:00
targetUser = if (builtins.hasAttr "sshUser" cur) then cur.sshUser else "root";
targetHost = if (builtins.hasAttr "sshHost" cur) then cur.sshHost else cur.name;
targetPort = if (builtins.hasAttr "sshPort" cur) then cur.sshPort else 22;
2024-12-15 23:45:19 -07:00
allowLocalDeployment = if (builtins.hasAttr "allowLocal" cur) then cur.allowLocal else false;
2024-12-15 23:36:16 -07:00
};
imports = [ cur.entrypoint ];
};
}
)
{}
hostConfigs
);
2024-12-21 22:29:34 -07:00
createDroidSystem = {
system ? "aarch64-linux",
entrypoint
}: inputs.nix-on-droid.lib.nixOnDroidConfiguration {
pkgs = inputs.nixpkgs.legacyPackages.${system};
2024-12-21 22:29:34 -07:00
modules = [ entrypoint ];
extraSpecialArgs = {
inherit inputs system secrets;
pkgs-stable = inputs.nixpkgs-stable.legacyPackages.${system};
2024-12-21 22:29:34 -07:00
};
};
}