nix/flake.nix
2023-08-14 20:25:18 +09:00

112 lines
3.5 KiB
Nix

{
# INFORMATION
# When building for a system, remember to change the hostname variable below
description = "NixOS System Config";
inputs = {
# NixOS packages
# stable-nixpkgs.url = "nixpkgs/nixos-23.05";
unstable-nixpkgs.url = "nixpkgs/nixos-unstable";
# master-nixpkgs.url = "nixpkgs/master";
# Manage dotfiles in a home directory
home-manager.url = "github:nix-community/home-manager/release-23.05";
home-manager.inputs.nixpkgs.follows = "unstable-nixpkgs";
# Secureboot Configuration
lanzaboote.url = "github:nix-community/lanzaboote";
lanzaboote.inputs.nixpkgs.follows = "unstable-nixpkgs";
# Nix User Repository
nur.url = "github:nix-community/NUR";
# Hardware support
# nixos-hardware.url = "github:NixOS/nixos-hardware/master";
# hyprland flake
hyprland.url = "github:hyprwm/Hyprland";
# Encrypted secrets in Nix configuration files
# https://github.com/Mic92/sops-nix
sops-nix.url = "github:Mic92/sops-nix";
};
outputs = {
# stable-nixpkgs,
unstable-nixpkgs,
# master-nixpkgs,
home-manager,
lanzaboote,
nur,
sops-nix,
# nixos-hardware,
hyprland,
...
}@inputs:
let
# Variables - Remember to set these
hostname = "nixos-laptop"; # Should probably set this in a minimal configuration.nix
system = "x86_64-linux";
pkgs = import unstable-nixpkgs {
inherit system;
config = { allowUnfree = true; };
};
# unstable = import unstable-nixpkgs {
# inherit system;
# config = { allowUnfree = true; };
# };
#
# master = import master-nixpkgs {
# inherit system;
# config = { allowUnfree = true; };
# }
lib = unstable-nixpkgs.lib;
in {
# NixOS Configuration files:
nixosConfigurations = {
# Declare a generic configuration using the $hostname variable:
${hostname} = lib.nixosSystem {
inherit system;
specialArgs = {
# inherit unstable;
# inherit master;
inherit hostname;
};
modules = [
# Configuration Imports
./hosts/${hostname}/hardware-configuration.nix # Hardware Configuration
./hosts/${hostname}/configuration.nix # Extra options for the host configuration
./configuration.nix # Common NixOS Configuration
# Flake Imports
sops-nix.nixosModules.sops # Handle secrets
lanzaboote.nixosModules.lanzaboote # SecureBoot Configuration
nur.nixosModules.nur # NixOS User Repository
# nixos-hardware.nixosModules.lenovo-thinkpad-p1 # Thinkpad P1 hardware configuration
# Home Manager settings
home-manager.nixosModules.home-manager {
home-manager.useGlobalPkgs = true;
home-manager.useUserPackages = true;
home-manager.users.albert.imports = [
({ config, ... }: import ./users/albert/home.nix {
inherit config pkgs hostname hyprland;
})
];
home-manager.users.root.imports = [
({ config, ... }: import ./users/root/home.nix {
inherit config pkgs hostname;
})
];
nixpkgs.overlays = [
nur.overlay
];
}
]; # modules
}; # lib.nixosSystem - ${hostname}
}; # nixosConfiguration
};
}