117 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
{
 | 
						|
  description = "NixOS + Home Manager configuration with flakes";
 | 
						|
 | 
						|
  inputs = {
 | 
						|
    # Nixpkgs
 | 
						|
    nixpkgs.url = "github:nixos/nixpkgs/nixos-25.05";
 | 
						|
    nixpkgs-unstable.url = "github:nixos/nixpkgs/nixos-unstable";
 | 
						|
 | 
						|
    # Home manager
 | 
						|
    home-manager = {
 | 
						|
      url = "github:nix-community/home-manager/release-25.05";
 | 
						|
      inputs.nixpkgs.follows = "nixpkgs";
 | 
						|
    };
 | 
						|
 | 
						|
    # Flakes our configuration is dependent on.
 | 
						|
    agenix.url = "github:ryantm/agenix";
 | 
						|
    agenix-rekey = {
 | 
						|
      url = "github:oddlama/agenix-rekey";
 | 
						|
      inputs.nixpkgs.follows = "nixpkgs";
 | 
						|
    };
 | 
						|
    impermanence.url = "github:nix-community/impermanence";
 | 
						|
 | 
						|
    # Security enhancement.
 | 
						|
    crowdsec.url = "git+https://codeberg.org/kampka/nix-flake-crowdsec.git";
 | 
						|
 | 
						|
    # Our personal flakes
 | 
						|
    nixvim.url = "git+https://git.sajenim.dev/jasmine/nixvim-config.git";
 | 
						|
    xmonad-config.url = "git+https://git.sajenim.dev/jasmine/xmonad-config.git";
 | 
						|
 | 
						|
    # Add any other flake you might need.
 | 
						|
    nix-minecraft.url = "github:Infinidoge/nix-minecraft";
 | 
						|
    remarks.url = "github:Scrybbling-together/remarks";
 | 
						|
    nix-jetbrains-plugins.url = "github:theCapypara/nix-jetbrains-plugins";
 | 
						|
    claude-code.url = "github:sadjow/claude-code-nix";
 | 
						|
  };
 | 
						|
 | 
						|
  outputs = {
 | 
						|
    self,
 | 
						|
    nixpkgs,
 | 
						|
    home-manager,
 | 
						|
    ...
 | 
						|
  } @ inputs: let
 | 
						|
    inherit (self) outputs;
 | 
						|
    # Supported systems for your flake packages, shell, etc.
 | 
						|
    systems = [
 | 
						|
      "aarch64-linux"
 | 
						|
      "i686-linux"
 | 
						|
      "x86_64-linux"
 | 
						|
      "aarch64-darwin"
 | 
						|
      "x86_64-darwin"
 | 
						|
    ];
 | 
						|
    # This is a function that generates an attribute by calling a function you
 | 
						|
    # pass to it, with each system as an argument
 | 
						|
    forAllSystems = nixpkgs.lib.genAttrs systems;
 | 
						|
  in {
 | 
						|
    # Your custom packages
 | 
						|
    # Acessible through 'nix build', 'nix shell', etc
 | 
						|
    packages = forAllSystems (system: import ./pkgs nixpkgs.legacyPackages.${system});
 | 
						|
    # Formatter for your nix files, available through 'nix fmt'
 | 
						|
    # Other options beside 'alejandra' include 'nixpkgs-fmt'
 | 
						|
    formatter = forAllSystems (system: nixpkgs.legacyPackages.${system}.alejandra);
 | 
						|
 | 
						|
    # Your custom packages and modifications, exported as overlays
 | 
						|
    overlays = import ./overlays {inherit inputs;};
 | 
						|
    # Reusable nixos modules you might want to export
 | 
						|
    # These are usually stuff you would upstream into nixpkgs
 | 
						|
    nixosModules = import ./modules/nixos;
 | 
						|
    # Reusable home-manager modules you might want to export
 | 
						|
    # These are usually stuff you would upstream into home-manager
 | 
						|
    homeManagerModules = import ./modules/home-manager;
 | 
						|
 | 
						|
    # Expose the necessary information in your flake so agenix-rekey
 | 
						|
    # knows where it has too look for secrets and paths.
 | 
						|
    agenix-rekey = inputs.agenix-rekey.configure {
 | 
						|
      userFlake = self;
 | 
						|
      nodes = self.nixosConfigurations;
 | 
						|
    };
 | 
						|
 | 
						|
    # NixOS configuration entrypoint
 | 
						|
    # Available through 'nixos-rebuild --flake .#your-hostname'
 | 
						|
    nixosConfigurations = {
 | 
						|
      fuchsia = nixpkgs.lib.nixosSystem {
 | 
						|
        specialArgs = {inherit inputs outputs;};
 | 
						|
        modules = [
 | 
						|
          ./nixos/fuchsia/configuration.nix
 | 
						|
        ];
 | 
						|
      };
 | 
						|
 | 
						|
      viridian = nixpkgs.lib.nixosSystem {
 | 
						|
        specialArgs = {inherit inputs outputs;};
 | 
						|
        modules = [
 | 
						|
          ./nixos/viridian/configuration.nix
 | 
						|
        ];
 | 
						|
      };
 | 
						|
    };
 | 
						|
 | 
						|
    # Standalone home-manager configuration entrypoint
 | 
						|
    # Available through 'home-manager --flake .#your-username@your-hostname'
 | 
						|
    homeConfigurations = {
 | 
						|
      "sajenim@fuchsia" = home-manager.lib.homeManagerConfiguration {
 | 
						|
        pkgs = nixpkgs.legacyPackages.x86_64-linux;
 | 
						|
        extraSpecialArgs = {inherit inputs outputs;};
 | 
						|
        modules = [
 | 
						|
          ./home-manager/sajenim/fuchsia.nix
 | 
						|
        ];
 | 
						|
      };
 | 
						|
 | 
						|
      "sajenim@viridian" = home-manager.lib.homeManagerConfiguration {
 | 
						|
        pkgs = nixpkgs.legacyPackages.x86_64-linux;
 | 
						|
        extraSpecialArgs = {inherit inputs outputs;};
 | 
						|
        modules = [
 | 
						|
          ./home-manager/sajenim/viridian.nix
 | 
						|
        ];
 | 
						|
      };
 | 
						|
    };
 | 
						|
  };
 | 
						|
}
 |