diff options
author | Emile <git@emile.space> | 2024-03-09 22:56:01 +0100 |
---|---|---|
committer | Emile <git@emile.space> | 2024-03-09 22:56:01 +0100 |
commit | 55ee036fd7ebed24097c8da1ca8a0b0829264670 (patch) | |
tree | 9c600d75a4f59f8ec253c5caadc1f77b2cecb0da /flake.nix |
big bang
Diffstat (limited to 'flake.nix')
-rw-r--r-- | flake.nix | 185 |
1 files changed, 185 insertions, 0 deletions
diff --git a/flake.nix b/flake.nix new file mode 100644 index 0000000..0d69e47 --- /dev/null +++ b/flake.nix @@ -0,0 +1,185 @@ +{ + inputs = { + nixpkgs.url = "git+https://github.com/nixos/nixpkgs?ref=release-23.11"; + nixpkgs-unstable.url = "git+https://github.com/nixos/nixpkgs?ref=nixpkgs-unstable"; + + darwin.url = "git+https://github.com/lnl7/nix-darwin"; + darwin.inputs.nixpkgs.follows = "nixpkgs"; + + deploy-rs.url = "git+https://github.com/serokell/deploy-rs?ref=master"; + deploy-rs.inputs.nixpkgs.follows = "nixpkgs-unstable"; + + agenix.url = "git+https://github.com/ryantm/agenix"; + agenix.inputs.nixpkgs.follows = "nixpkgs"; + + home-manager.url = "git+https://github.com/nix-community/home-manager?ref=release-23.11"; + home-manager.inputs.nixpkgs.follows = "nixpkgs-unstable"; + + naersk.url = "git+https://github.com/nix-community/naersk"; + naersk.inputs.nixpkgs.follows = "nixpkgs-unstable"; + + hefe-internal.url = "git+ssh://gitea@git.emile.space/hanemile/hefe-internal.git?ref=main"; + }; + + outputs = { + self, + nixpkgs, nixpkgs-unstable, # general packages + darwin, # darwin related stuff + deploy-rs, # deploy the hosts + agenix, # store secrets crypted using age + home-manager, # manage my home envs + naersk, # build rust stuff + hefe-internal, # internal tooling + ... }@inputs: + let + lib = import ./nix/lib inputs; + helper = lib.flake-helper; + in { + + hosts = { + caladan = { + system = "aarch64-darwin"; + sshUser = "hydra"; + homeManagerEnable = true; + }; + corrino = { + system = "x86_64-linux"; + ip = "corrino"; + description = "Hetzner AX41 dual 512GB NVME"; + modules = [ hefe-internal.nixosModules.corrino ]; + # TODO: install znc irc bouncer + }; + chusuk = { + # ip = "chusuk.pinto-pike.ts.net"; + system = "x86_64-linux"; + description = "lenovo t480"; + }; + hacknix = { + # ip = "hacknix.pinto-pike.ts.net"; # clone repo and deploy within + system = "x86_64-linux"; + description = "hacking vm"; + }; + mail = { + # ip = "mail.pinto-pike.ts.net"; # clone repo and deploy within + system = "x86_64-linux"; + description = "mail server"; + }; + + + #ecaz = {}; + + # gamont = { + # description = "pi 2 tfp" + # }; + + #kolhar = {}; # nixos vm on caladan + #hagal = {}; # apple tv + + # palma = { + # description = "NAS"; + # }; + # lampadas = { + # hostname = "lampadas"; + # description = "palma bmc"; + # }; + + # parmentier = { + # description = "ryzen 5 3600 + RTX A2000"; + # }; + # lankiveil = { + # hostname = "lankiveil"; + # description = "parmentier bmc"; + # }; + + # poritrin = { + # description = "ryzen 5 3600g"; + # }; + # lernaeus = { + # hostname = "lernaeus"; + # description = "poritrin bmc"; + # }; + + #kaitain = {}; + + # futher names: https://neoencyclopedia.fandom.com/wiki/List_of_Dune_planets + # Muritan + # Naraj + # Palma + # Parmentier + # Poritrin + # Richese + # Romo + # Rossak + # Sikun + # Synchrony + # Tleilax + # Tupile + # Zanovar + }; + + nixosConfigurations = helper.mapToNixosConfigurations self.hosts; + darwinConfigurations = helper.mapToDarwinConfigurations self.hosts; + + overlays = { + emile = import ./nix/pkgs/overlay.nix; + default = self.overlays.emile; + + unstable = final: prev: { + unstable = import nixpkgs-unstable { + system = "x86_64-linux"; + config.allowUnfree = true; + }; + }; + }; + + deploy.nodes = helper.mapToDeployRsConfiguration self.hosts; + deploy.autoRollback = true; + + packages = + nixpkgs.lib.genAttrs [ "x86_64-linux" "aarch64-darwin" ] (system: + let + pkgs = import nixpkgs { + inherit system; + overlays = [ + self.overlays.emile + + # some arguments for packages + (_: _: { inherit naersk; }) + ]; + }; + in { + inherit (pkgs) + vokobe + # emu-riscv + # emu-mips + # emu-x86_64 + ; + }); + + hydraJobs = { + inherit (self) packages; + nixosConfigurations = helper.buildHosts self.nixosConfigurations; + }; + + templates = { + # ; nix nix registry add hefe /Users/emile/Documents/hefe + # ; nix flake init -t hefe#ctf + ctf = { + description = "A basic ctf env with pwn, rev, ... tools"; + path = ./nix/templates/ctf; + welcomeText = '' + # A basic CTF env + ## Intended usage + The intended usage of this flake is... + + ## More info + - [Rust language](https://www.rust-lang.org/) + - [Rust on the NixOS Wiki](https://nixos.wiki/wiki/Rust) + - ... + ''; + }; + }; + + # checks = builtins.mapAttrs (system: deployLib: deployLib.deployChecks self.deploy) deploy-rs.lib; + }; +} |