2022-06-03 17:47:16 +02:00
|
|
|
{
|
|
|
|
description = "NixOS configuration";
|
|
|
|
inputs = {
|
2022-06-06 11:47:50 +02:00
|
|
|
nix.url = "github:NixOS/nix";
|
2022-06-03 17:47:16 +02:00
|
|
|
nixpkgs.url = "nixpkgs/nixos-22.05";
|
|
|
|
nixpkgs-unstable.url = "nixpkgs/nixos-unstable";
|
|
|
|
|
2022-11-10 20:23:50 +01:00
|
|
|
flake-parts = {
|
|
|
|
url = "github:hercules-ci/flake-parts";
|
|
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
};
|
|
|
|
|
2022-11-23 22:57:09 +01:00
|
|
|
pre-commit-hooks-nix = {
|
|
|
|
url = "github:cachix/pre-commit-hooks.nix";
|
|
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
};
|
2022-07-30 15:00:18 +02:00
|
|
|
|
2022-06-03 17:47:16 +02:00
|
|
|
nixos-hardware.url = "github:NixOS/nixos-hardware";
|
2022-06-03 23:33:25 +02:00
|
|
|
|
2022-12-04 18:03:44 +01:00
|
|
|
deploy-rs.url = "github:serokell/deploy-rs";
|
2022-06-03 23:33:25 +02:00
|
|
|
|
2022-11-10 20:23:50 +01:00
|
|
|
sops-nix = {
|
|
|
|
url = "github:Mic92/sops-nix";
|
|
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
};
|
2022-06-26 18:15:03 +02:00
|
|
|
|
|
|
|
stunkymonkey = {
|
|
|
|
url = "github:Stunkymonkey/stunkymonkey.de";
|
2022-11-10 20:23:50 +01:00
|
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
};
|
|
|
|
|
|
|
|
passworts = {
|
2022-11-23 22:57:09 +01:00
|
|
|
url = "github:Stunkymonkey/passworts";
|
2022-11-10 20:23:50 +01:00
|
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
2022-06-26 18:15:03 +02:00
|
|
|
};
|
2022-06-03 17:47:16 +02:00
|
|
|
};
|
2022-11-10 20:23:50 +01:00
|
|
|
|
2022-11-23 22:57:09 +01:00
|
|
|
outputs = inputs@{ self, flake-parts, deploy-rs, ... }:
|
2022-06-26 22:40:59 +02:00
|
|
|
flake-parts.lib.mkFlake { inherit self; } {
|
2022-11-23 22:57:09 +01:00
|
|
|
|
2022-07-24 17:37:30 +02:00
|
|
|
imports = [
|
2022-12-05 20:32:39 +01:00
|
|
|
./machines/configurations.nix
|
2022-07-24 17:37:30 +02:00
|
|
|
#./nixos/images/default.nix
|
2022-11-23 22:57:09 +01:00
|
|
|
inputs.pre-commit-hooks-nix.flakeModule
|
2022-07-24 17:37:30 +02:00
|
|
|
];
|
2022-11-23 22:57:09 +01:00
|
|
|
|
2022-07-24 17:37:30 +02:00
|
|
|
systems = [ "x86_64-linux" "aarch64-linux" ];
|
2022-11-23 22:57:09 +01:00
|
|
|
|
|
|
|
perSystem = { self', inputs', config, pkgs, ... }: {
|
2022-07-24 17:37:30 +02:00
|
|
|
# make pkgs available to all `perSystem` functions
|
|
|
|
_module.args.pkgs = inputs'.nixpkgs.legacyPackages;
|
2022-11-23 22:57:09 +01:00
|
|
|
|
|
|
|
# enable pre-commit checks
|
|
|
|
pre-commit.settings = {
|
|
|
|
hooks = {
|
|
|
|
shellcheck.enable = true;
|
|
|
|
nixpkgs-fmt.enable = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
devShells.default = pkgs.mkShellNoCC {
|
|
|
|
nativeBuildInputs = [
|
|
|
|
inputs'.sops-nix.packages.sops-import-keys-hook
|
|
|
|
inputs'.deploy-rs.packages.deploy-rs
|
|
|
|
pkgs.nixpkgs-fmt
|
|
|
|
pkgs.shellcheck
|
|
|
|
pkgs.pre-commit
|
|
|
|
];
|
|
|
|
shellHook = ''
|
|
|
|
${config.pre-commit.installationScript}
|
|
|
|
'';
|
|
|
|
};
|
2022-06-26 22:40:59 +02:00
|
|
|
};
|
2022-11-23 22:57:09 +01:00
|
|
|
|
2022-07-24 17:37:30 +02:00
|
|
|
flake = {
|
|
|
|
checks = builtins.mapAttrs (system: deployLib: deployLib.deployChecks self.deploy) deploy-rs.lib;
|
2022-11-23 22:57:09 +01:00
|
|
|
|
2022-12-05 20:32:39 +01:00
|
|
|
deploy = import ./machines/deploy.nix (inputs // {
|
2022-07-24 17:37:30 +02:00
|
|
|
inherit inputs;
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
2022-06-03 17:47:16 +02:00
|
|
|
}
|