1
0
Fork 0
nix-configuration/flake.nix

136 lines
4 KiB
Nix
Raw Normal View History

# Based on the Auxolotl template: https://github.com/auxolotl/templates
2024-02-29 09:53:34 -05:00
# For info on Flakes, see: https://nixos-and-flakes.thiscute.world/nixos-with-flakes/nixos-with-flakes-enabled
{
description = "Aires' system Flake";
2024-02-29 09:53:34 -05:00
inputs = {
# Import the desired Nix channel. Defaults to unstable, which uses a fully tested rolling release model.
# You can find a list of channels at https://wiki.nixos.org/wiki/Nix_channels
# To follow a different channel, replace `nixos-unstable` with the channel name, e.g. `nixos-24.05`.
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.05";
nixpkgs-unstable.url = "github:nixos/nixpkgs/nixos-unstable";
2024-05-06 08:38:54 -04:00
# Use Lix in place of Nix.
# If you'd rather use regular Nix, remove `lix-module.nixosModules.default` from the `modules` section below.
# To learn more about Lix, see https://lix.systems/
lix-module = {
url = "git+https://git.lix.systems/lix-project/nixos-module?ref=release-2.90";
inputs.nixpkgs.follows = "nixpkgs";
};
2024-02-29 09:53:34 -05:00
# Flatpak support
nix-flatpak.url = "github:gmodena/nix-flatpak/v0.4.1";
2024-05-03 22:36:50 -04:00
# SecureBoot support
2024-06-27 10:10:44 -04:00
lanzaboote.url = "github:nix-community/lanzaboote/v0.4.1";
# NixOS hardware quirks
nixos-hardware.url = "github:8bitbuddhist/nixos-hardware/master";
2024-02-29 09:53:34 -05:00
# Home-manager support
home-manager = {
2024-07-26 14:54:01 -04:00
url = "github:nix-community/home-manager/release-24.05";
inputs.nixpkgs.follows = "nixpkgs";
};
2024-05-16 20:08:57 -04:00
# "Secrets management"
nix-secrets = {
url = "git+file:./nix-secrets";
2024-05-16 20:08:57 -04:00
flake = false;
};
};
2024-02-29 09:53:34 -05:00
outputs =
inputs@{
self,
home-manager,
lanzaboote,
lix-module,
nix-flatpak,
nixos-hardware,
nixpkgs,
nixpkgs-unstable,
2024-05-16 20:08:57 -04:00
nix-secrets,
...
}:
let
forAllSystems =
function:
nixpkgs.lib.genAttrs [
"x86_64-linux"
"aarch64-linux"
] (system: function nixpkgs.legacyPackages.${system});
2024-02-29 09:53:34 -05:00
# Define shared modules and imports
2024-05-16 20:08:57 -04:00
defaultModules = [
./modules/autoimport.nix
(import nix-secrets)
lix-module.nixosModules.default
lanzaboote.nixosModules.lanzaboote
nix-flatpak.nixosModules.nix-flatpak
home-manager.nixosModules.home-manager
{
_module.args = {
inherit inputs;
};
2024-05-16 20:08:57 -04:00
home-manager = {
/*
When running, Home Manager will use the global package cache.
It will also back up any files that it would otherwise overwrite.
The originals will have the extension shown below.
*/
useGlobalPkgs = true;
useUserPackages = true;
backupFileExtension = "home-manager-backup";
};
}
];
in
{
formatter = forAllSystems (pkgs: pkgs.nixfmt-rfc-style);
nixosConfigurations = {
Dimaga = nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
# Add unstable repo
specialArgs = {
pkgs-unstable = import nixpkgs-unstable {
system = "x86_64-linux";
config.allowUnfree = true;
};
};
2024-05-16 20:08:57 -04:00
modules = defaultModules ++ [
nixos-hardware.nixosModules.common-cpu-intel
./hosts/Dimaga
];
};
2024-02-29 09:53:34 -05:00
Khanda = nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
2024-05-16 20:08:57 -04:00
modules = defaultModules ++ [
nixos-hardware.nixosModules.microsoft-surface-pro-9
./hosts/Khanda
];
};
Pihole = nixpkgs.lib.nixosSystem {
system = "aarch64-linux";
2024-05-16 20:08:57 -04:00
modules = defaultModules ++ [
nixos-hardware.nixosModules.raspberry-pi-4
./hosts/Pihole
];
};
Shura = nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
2024-05-16 20:08:57 -04:00
modules = defaultModules ++ [
nixos-hardware.nixosModules.lenovo-legion-16arha7
./hosts/Shura
];
};
};
};
}