{ description = "Lgm's NixOS Flake"; inputs = { # There are many ways to reference flake inputs. # The most widely used is `github:owner/name/reference`, # which represents the GitHub repository URL + branch/commit-id/tag. nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; nixpkgs-stable.url = "github:NixOS/nixpkgs/nixos-23.05"; # nix-index-database.url = "github:nix-community/nix-index-database"; # nix-index-database.inputs.nixpkgs.follows = "nixpkgs"; # nur = { # url = "github:nix-community/NUR"; # }; nixpkgs-vesktop.url = "github:pluiedev/nixpkgs/patch-1"; # nixpkgs-unstable.url = "github:NixOS/nixpkgs/nixos-unstable"; # home-manager, used for managing user configuration home-manager = { url = "github:nix-community/home-manager/master"; # The `follows` keyword in inputs is used for inheritance. # Here, `inputs.nixpkgs` of home-manager is kept consistent with # the `inputs.nixpkgs` of the current flake, # to avoid problems caused by different versions of nixpkgs. inputs.nixpkgs.follows = "nixpkgs"; }; }; outputs = inputs@{ nixpkgs, nixpkgs-stable, # nix-index-database, # nur, home-manager, ... }: { nixosConfigurations.lgm-nixos = nixpkgs.lib.nixosSystem rec { system = "x86_64-linux"; specialArgs = { pkgs-stable = import nixpkgs-stable { system = system; config.allowUnfree = true; }; secrets = import ./secrets {}; }; modules = [ # nur.nixosModules.nur ./configuration.nix # nix-index-database.nixosModules.nix-index ./mounts.nix # make home-manager as a module of nixos # so that home-manager configuration will be deployed automatically when executing `nixos-rebuild switch` home-manager.nixosModules.home-manager { home-manager.useGlobalPkgs = true; home-manager.useUserPackages = true; home-manager.users.lgm = import ./home.nix; home-manager.extraSpecialArgs = with specialArgs; { inherit pkgs-stable; inherit secrets; }; } ]; }; }; }