{ description = "home-manager config from dotfiles"; inputs = { nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable"; systems.url = "github:nix-systems/default"; home-manager = { url = "github:nix-community/home-manager"; inputs.nixpkgs.follows = "nixpkgs"; }; vscode-server = { url = "github:nix-community/nixos-vscode-server"; inputs.nixpkgs.follows = "nixpkgs"; }; fw_nix = { url = "git+https://github.com/futureware-tech/nix.git"; inputs.nixpkgs.follows = "nixpkgs"; }; darwin = { url = "github:nix-darwin/nix-darwin"; inputs.nixpkgs.follows = "nixpkgs"; }; nix-homebrew.url = "github:zhaofengli/nix-homebrew"; git-hooks = { url = "github:cachix/git-hooks.nix"; inputs.nixpkgs.follows = "nixpkgs"; }; jail-nix.url = "sourcehut:~alexdavid/jail.nix"; }; outputs = { self, nixpkgs, systems, home-manager, vscode-server, darwin, ... }@inputs: let trustedSSHKeys = [ "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIBxRBsFGa8OFbviYDGSAKLgfm/K2XUxvCo+31FW37yab artem" "sk-ssh-ed25519@openssh.com AAAAGnNrLXNzaC1lZDI1NTE5QG9wZW5zc2guY29tAAAAIPAtIXXHm58julnr7S0xzBTM1jN5JkKxOL4JpuWDOa2jAAAABHNzaDo= office-dock-usb-a" "sk-ssh-ed25519@openssh.com AAAAGnNrLXNzaC1lZDI1NTE5QG9wZW5zc2guY29tAAAAIHY1xx0huqV6Mcc2WngYDabITeNUbGamJ8//206MxxVTAAAABHNzaDo= keychain-usb-c" "sk-ssh-ed25519@openssh.com AAAAGnNrLXNzaC1lZDI1NTE5QG9wZW5zc2guY29tAAAAIHzY2eOz+JdaKOpIgZbF5FsZzQy0l8vPJjAQdTpBFGsoAAAABHNzaDo= safe" "ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBJg7zQ4H0LQeQcILZBwCzQ+MYKtCgKm7HPe9oFeoyprKZXAvpm+HDHtaYdU39JF9f+nvRztzXuMhgETAQMAQCkc= fingerprint@macbook" ]; eachSystem = nixpkgs.lib.genAttrs (import systems); in { checks = eachSystem (system: { pre-commit-check = inputs.git-hooks.lib.${system}.run ( { src = ./.; } // inputs.fw_nix.lib.pre-commit ); }); homeModules = { mac-portable = import ./modules/home/mac-portable.nix; linux-headless = import ./modules/home/linux-headless.nix; }; darwinModules = { mac-portable = import ./modules/darwin/mac-portable.nix; }; nixosModules = { linux-headless = import ./modules/nixos/linux-headless.nix; }; homeConfigurations."artem@deimos" = home-manager.lib.homeManagerConfiguration { pkgs = nixpkgs.legacyPackages.x86_64-linux; extraSpecialArgs.primaryUser = "artem"; modules = [ vscode-server.homeModules.default self.homeModules.linux-headless ./hosts/deimos/home.nix ]; }; homeConfigurations."artem@mars" = home-manager.lib.homeManagerConfiguration { pkgs = nixpkgs.legacyPackages.x86_64-darwin; extraSpecialArgs = { primaryUser = "artem"; inherit trustedSSHKeys; }; modules = [ self.homeModules.mac-portable ./hosts/mars/home.nix ]; }; darwinConfigurations.mars = darwin.lib.darwinSystem { system = "x86_64-darwin"; specialArgs.primaryUser = "artem"; modules = [ self.darwinModules.mac-portable inputs.fw_nix.nixosModules.tools inputs.fw_nix.nixosModules.nix-settings inputs.fw_nix.nixosModules.futureware inputs.nix-homebrew.darwinModules.nix-homebrew ./hosts/mars/darwin.nix ]; }; nixosConfigurations.deimos = let system = "x86_64-linux"; in nixpkgs.lib.nixosSystem { inherit system; specialArgs = { inherit trustedSSHKeys; inherit (inputs) jail-nix; }; modules = [ self.nixosModules.linux-headless inputs.fw_nix.nixosModules.nix-gc inputs.fw_nix.nixosModules.nix-settings inputs.fw_nix.nixosModules.tools inputs.fw_nix.nixosModules.sshd inputs.fw_nix.nixosModules.futureware ./hosts/deimos/nixos.nix ]; }; devShells = eachSystem ( system: let pkgs = import nixpkgs { inherit system; }; inherit (self.checks.${system}.pre-commit-check) shellHook enabledPackages; in { default = pkgs.mkShell { packages = enabledPackages; inherit shellHook; }; } ); }; }