nixos/flake.nix

105 lines
2.7 KiB
Nix
Raw Normal View History

{
description = "NixOS configuration";
inputs = {
2022-06-06 11:47:50 +02:00
nix.url = "github:NixOS/nix";
2023-11-29 22:38:52 +01:00
nixpkgs.url = "nixpkgs/nixos-23.11";
nixpkgs-unstable.url = "nixpkgs/nixos-unstable";
2022-12-25 12:03:56 +01:00
flake-parts.url = "github:hercules-ci/flake-parts";
2022-11-10 20:23:50 +01:00
pre-commit-hooks-nix = {
url = "github:cachix/pre-commit-hooks.nix";
inputs.nixpkgs.follows = "nixpkgs";
};
nixos-hardware.url = "github:NixOS/nixos-hardware";
2022-06-03 23:33:25 +02:00
2024-01-18 22:37:39 +01:00
nixinate.url = "github:matthewcroughan/nixinate";
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
2023-03-10 21:41:41 +01:00
nixos-generators = {
url = "github:nix-community/nixos-generators";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-03-18 16:58:18 +01:00
disko = {
url = "github:nix-community/disko";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-03-10 21:41:41 +01:00
# own flakes
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 = {
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-11-10 20:23:50 +01:00
2024-01-18 22:37:39 +01:00
outputs = inputs@{ self, flake-parts, nixinate, ... }:
2022-12-25 12:03:56 +01:00
flake-parts.lib.mkFlake { inherit inputs; } {
2022-07-24 17:37:30 +02:00
imports = [
2022-12-05 20:32:39 +01:00
./machines/configurations.nix
2023-03-12 18:50:22 +01:00
./images/flake-module.nix
inputs.pre-commit-hooks-nix.flakeModule
2022-07-24 17:37:30 +02:00
];
2022-07-24 17:37:30 +02:00
systems = [ "x86_64-linux" "aarch64-linux" ];
perSystem = { self', inputs', config, pkgs, system, ... }: {
2022-07-24 17:37:30 +02:00
# make pkgs available to all `perSystem` functions
_module.args.pkgs = import inputs.nixpkgs {
inherit system;
};
# enable pre-commit checks
pre-commit.settings = {
hooks = {
2024-04-14 20:25:04 +02:00
deadnix = {
enable = true;
settings.noLambdaPatternNames = true;
};
2023-11-07 22:51:21 +01:00
markdownlint.enable = true;
nixpkgs-fmt.enable = true;
2023-11-07 22:51:21 +01:00
shellcheck.enable = true;
2023-11-07 23:20:11 +01:00
statix.enable = true;
2023-06-24 17:24:42 +02:00
typos = {
enable = true;
excludes = [ "secrets\\.yaml" "\\.sops\\.yaml" ];
2023-06-24 17:24:42 +02:00
};
2023-07-30 12:51:21 +02:00
yamllint = {
enable = true;
excludes = [ "secrets\\.yaml" ];
};
};
};
devShells.default = pkgs.mkShellNoCC {
nativeBuildInputs = [
inputs'.sops-nix.packages.sops-import-keys-hook
2023-03-18 16:58:18 +01:00
inputs'.disko.packages.disko
2024-01-18 22:37:39 +01:00
# formatter + linter
2023-11-07 22:51:21 +01:00
pkgs.deadnix
2023-03-10 21:41:41 +01:00
pkgs.nixpkgs-fmt
2023-11-07 22:51:21 +01:00
pkgs.shellcheck
2023-11-07 23:20:11 +01:00
pkgs.statix
2023-06-24 17:24:42 +02:00
pkgs.typos
];
shellHook = ''
${config.pre-commit.installationScript}
'';
};
2022-06-26 22:40:59 +02:00
};
2024-01-18 22:37:39 +01:00
# flake = {};
flake.apps = inputs.nixinate.nixinate."x86_64-linux" self;
2022-07-24 17:37:30 +02:00
};
}