144 lines
4.0 KiB
Nix
144 lines
4.0 KiB
Nix
{
|
|
description = "My deploy-rs config for logos";
|
|
|
|
inputs = {
|
|
agenix.url = "github:ryantm/agenix";
|
|
deploy-rs.url = "github:serokell/deploy-rs";
|
|
home-manager.url = "github:nix-community/home-manager";
|
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
|
utils.url = "github:numtide/flake-utils";
|
|
|
|
# my apps
|
|
printerfacts = {
|
|
url = "git+https://tulpa.dev/cadey/printerfacts.git?ref=main";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
inputs.flake-utils.follows = "utils";
|
|
};
|
|
mara = {
|
|
url = "git+https://tulpa.dev/Xe/mara.git?ref=main";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
inputs.utils.follows = "utils";
|
|
};
|
|
snoo2nebby = {
|
|
url = "git+https://tulpa.dev/cadey/snoo2nebby.git?ref=main";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
inputs.utils.follows = "utils";
|
|
};
|
|
rhea = {
|
|
url = "github:Xe/rhea";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
waifud = {
|
|
url = "github:Xe/waifud";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
inputs.utils.follows = "utils";
|
|
};
|
|
};
|
|
|
|
outputs = { self, nixpkgs, deploy-rs, home-manager, agenix, printerfacts, mara
|
|
, snoo2nebby, rhea, waifud, ... }:
|
|
let
|
|
pkgs = nixpkgs.legacyPackages."x86_64-linux";
|
|
mkSystem = extraModules:
|
|
nixpkgs.lib.nixosSystem rec {
|
|
system = "x86_64-linux";
|
|
modules = [
|
|
agenix.nixosModules.age
|
|
home-manager.nixosModules.home-manager
|
|
|
|
({ config, ... }: {
|
|
system.configurationRevision = self.sourceInfo.rev;
|
|
services.getty.greetingLine =
|
|
"<<< Welcome to NixOS ${config.system.nixos.label} @ ${self.sourceInfo.rev} - \\l >>>";
|
|
|
|
home-manager.useGlobalPkgs = true;
|
|
home-manager.useUserPackages = true;
|
|
})
|
|
./common
|
|
|
|
printerfacts.nixosModules.${system}.printerfacts
|
|
mara.nixosModules.${system}.bot
|
|
snoo2nebby.nixosModule.${system}
|
|
rhea.nixosModule.${system}
|
|
|
|
] ++ extraModules;
|
|
};
|
|
in {
|
|
devShell.x86_64-linux = pkgs.mkShell {
|
|
buildInputs = [
|
|
deploy-rs.packages.x86_64-linux.deploy-rs
|
|
agenix.packages.x86_64-linux.agenix
|
|
];
|
|
};
|
|
|
|
nixosConfigurations = {
|
|
# avalon
|
|
chrysalis = mkSystem [ ./hosts/chrysalis ./hardware/location/YOW ];
|
|
logos = mkSystem [
|
|
./hosts/logos
|
|
./hardware/alrest
|
|
./hardware/location/YOW
|
|
waifud.nixosModules.x86_64-linux.waifud-runner
|
|
];
|
|
|
|
# cloud
|
|
firgu = mkSystem [ ./hosts/firgu ];
|
|
|
|
# vms
|
|
## logos
|
|
hugo = mkSystem [ ./hosts/vm/hugo ./hardware/libvirt-generic ];
|
|
};
|
|
|
|
deploy.nodes.chrysalis = {
|
|
hostname = "192.168.2.29";
|
|
sshUser = "root";
|
|
fastConnection = true;
|
|
|
|
profiles.system = {
|
|
user = "root";
|
|
path = deploy-rs.lib.x86_64-linux.activate.nixos
|
|
self.nixosConfigurations.chrysalis;
|
|
};
|
|
};
|
|
|
|
# deploy.nodes.firgu = {
|
|
# hostname = "149.248.59.1";
|
|
# sshUser = "root";
|
|
|
|
# profiles.system = {
|
|
# user = "root";
|
|
# path = deploy-rs.lib.x86_64-linux.activate.nixos
|
|
# self.nixosConfigurations.firgu;
|
|
# };
|
|
# };
|
|
|
|
deploy.nodes.logos = {
|
|
hostname = "192.168.2.35";
|
|
sshUser = "root";
|
|
fastConnection = true;
|
|
|
|
profiles.system = {
|
|
user = "root";
|
|
path = deploy-rs.lib.x86_64-linux.activate.nixos
|
|
self.nixosConfigurations.logos;
|
|
};
|
|
};
|
|
|
|
deploy.nodes.hugo = {
|
|
hostname = "10.77.129.6";
|
|
sshUser = "root";
|
|
fastConnection = true;
|
|
|
|
profiles.system = {
|
|
user = "root";
|
|
path = deploy-rs.lib.x86_64-linux.activate.nixos
|
|
self.nixosConfigurations.hugo;
|
|
};
|
|
};
|
|
|
|
# This is highly advised, and will prevent many possible mistakes
|
|
checks = builtins.mapAttrs
|
|
(system: deployLib: deployLib.deployChecks self.deploy) deploy-rs.lib;
|
|
};
|
|
}
|