66 lines
1.5 KiB
Nix
66 lines
1.5 KiB
Nix
{
|
|
description = "My NixOS configuration files.";
|
|
|
|
inputs = {
|
|
secrets.url = "git+ssh://git@git.caem.dev/caem/secrets";
|
|
|
|
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.11";
|
|
nixpkgs-unstable.url = "github:nixos/nixpkgs/nixos-unstable";
|
|
|
|
flake-parts.url = "github:hercules-ci/flake-parts";
|
|
|
|
home-manager = {
|
|
url = "github:nix-community/home-manager/release-24.11";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
impermanence.url = "github:nix-community/impermanence";
|
|
|
|
disko = {
|
|
url = "github:nix-community/disko/latest";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
sops-nix = {
|
|
url = "github:Mic92/sops-nix";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
};
|
|
|
|
outputs = {
|
|
nixpkgs,
|
|
nixpkgs-unstable,
|
|
flake-parts,
|
|
impermanence,
|
|
home-manager,
|
|
disko,
|
|
sops-nix,
|
|
secrets,
|
|
...
|
|
} @ inputs: let
|
|
lib = nixpkgs.lib.extend (final: prev:
|
|
import ./lib { lib = final; }
|
|
);
|
|
in {
|
|
nixosConfigurations = lib.mkHosts {
|
|
nixpkgs = nixpkgs;
|
|
inputs = inputs;
|
|
user = "caem";
|
|
modules = [
|
|
impermanence.nixosModules.impermanence
|
|
disko.nixosModules.disko
|
|
sops-nix.nixosModules.sops
|
|
home-manager.nixosModules.home-manager {
|
|
home-manager = {
|
|
useGlobalPkgs = true;
|
|
useUserPackages = true;
|
|
extraSpecialArgs = {
|
|
inherit inputs;
|
|
};
|
|
};
|
|
}
|
|
];
|
|
};
|
|
};
|
|
}
|
|
|