mirror of
https://github.com/donovanglover/nix-config.git
synced 2024-11-22 16:23:57 +01:00
3da9c62869
Now it's possible to use the system without mullvad vpn.
97 lines
3.0 KiB
Nix
97 lines
3.0 KiB
Nix
{
|
|
inputs = {
|
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
|
|
|
home-manager = {
|
|
url = "github:nix-community/home-manager";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
stylix = {
|
|
url = "github:danth/stylix";
|
|
inputs = {
|
|
nixpkgs.follows = "nixpkgs";
|
|
home-manager.follows = "home-manager";
|
|
};
|
|
};
|
|
|
|
sakaya = {
|
|
url = "github:donovanglover/sakaya";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
};
|
|
|
|
outputs = { self, nixpkgs, home-manager, stylix, ... } @ attrs: let
|
|
inherit (nixpkgs.lib) nixosSystem;
|
|
inherit (nixpkgs.legacyPackages.x86_64-linux) nixpkgs-fmt callPackage;
|
|
|
|
checkArgs = {
|
|
pkgs = nixpkgs.legacyPackages.x86_64-linux;
|
|
inherit self;
|
|
};
|
|
|
|
flakeOutputs = [ "overlays" "nixosModules" "homeManagerModules" "packages" ];
|
|
flakeDirectories = [ "overlays" "modules" "home" "packages" ];
|
|
packageDirectory = "packages";
|
|
in {
|
|
formatter.x86_64-linux = nixpkgs-fmt;
|
|
|
|
nixosConfigurations = {
|
|
nixos = nixosSystem {
|
|
system = "x86_64-linux";
|
|
specialArgs = attrs;
|
|
modules = [
|
|
home-manager.nixosModules.home-manager
|
|
stylix.nixosModules.stylix
|
|
./hardware/laptop.nix
|
|
{
|
|
environment.pathsToLink = [
|
|
"/share/backgrounds"
|
|
"/share/eww"
|
|
"/share/thumbnailers"
|
|
"/share/fonts"
|
|
];
|
|
|
|
nixpkgs.overlays = builtins.attrValues self.overlays;
|
|
imports = builtins.attrValues self.nixosModules;
|
|
home-manager.sharedModules = builtins.attrValues self.homeManagerModules;
|
|
environment.systemPackages = builtins.attrValues self.packages.x86_64-linux;
|
|
|
|
modules = {
|
|
hardware = {
|
|
disableLaptopKeyboard = true;
|
|
lidIgnore = true;
|
|
powerIgnore = true;
|
|
};
|
|
|
|
networking = {
|
|
mullvad = true;
|
|
};
|
|
};
|
|
}
|
|
];
|
|
};
|
|
};
|
|
|
|
checks.x86_64-linux = {
|
|
hyprland = import ./tests/hyprland.nix checkArgs;
|
|
neovim = import ./tests/neovim.nix checkArgs;
|
|
};
|
|
} //
|
|
(builtins.listToAttrs
|
|
(builtins.map
|
|
(attributeName: {
|
|
name = attributeName;
|
|
value = let
|
|
directory = builtins.replaceStrings flakeOutputs flakeDirectories attributeName;
|
|
attributeValue = (builtins.listToAttrs
|
|
(builtins.map
|
|
(file: {
|
|
name = builtins.replaceStrings [ ".nix" ] [ "" ] file;
|
|
value = if directory == packageDirectory then callPackage ./${directory}/${file} { } else import ./${directory}/${file}; })
|
|
(builtins.attrNames (builtins.readDir ./${directory}))));
|
|
attributeSet = if directory == packageDirectory then { x86_64-linux = attributeValue; } else attributeValue;
|
|
in (attributeSet); })
|
|
(flakeOutputs)));
|
|
}
|