104 lines
3.4 KiB
Nix
104 lines
3.4 KiB
Nix
{
|
|
description = "NixOS system";
|
|
|
|
inputs = {
|
|
secrets = {
|
|
url = "git+ssh://git@git.caspervk.net/caspervk/nixos-secrets.git";
|
|
};
|
|
nixpkgs = {
|
|
url = "github:NixOS/nixpkgs/nixos-24.05";
|
|
};
|
|
nixpkgs-unstable = {
|
|
url = "github:NixOS/nixpkgs/nixos-unstable";
|
|
};
|
|
nixos-hardware = {
|
|
# nixos-hardware is a collection of NixOS modules covering hardware
|
|
# quirks. The modules are imported in each hosts' hardware.nix. See
|
|
# https://github.com/NixOS/nixos-hardware/blob/master/flake.nix for
|
|
# a list of available modules.
|
|
url = "github:NixOS/nixos-hardware/master";
|
|
};
|
|
impermanence = {
|
|
url = "github:nix-community/impermanence";
|
|
};
|
|
agenix = {
|
|
url = "github:ryantm/agenix";
|
|
inputs.nixpkgs.follows = "nixpkgs"; # use the same nixpkgs as the system
|
|
inputs.home-manager.follows = "home-manager"; # use the same home-manager as the system
|
|
inputs.darwin.follows = ""; # don't download dawrin dependencies
|
|
};
|
|
nix-index-database = {
|
|
url = "github:nix-community/nix-index-database";
|
|
inputs.nixpkgs.follows = "nixpkgs"; # use the same nixpkgs as the system
|
|
};
|
|
home-manager = {
|
|
url = "github:nix-community/home-manager/release-24.05";
|
|
inputs.nixpkgs.follows = "nixpkgs"; # use the same nixpkgs as the system
|
|
};
|
|
home-manager-unstable = {
|
|
url = "github:nix-community/home-manager/master";
|
|
inputs.nixpkgs.follows = "nixpkgs"; # use the same nixpkgs as the system
|
|
};
|
|
simple-nixos-mailserver = {
|
|
# TODO
|
|
# url = "gitlab:simple-nixos-mailserver/nixos-mailserver/nixos-24.05";
|
|
url = "gitlab:simple-nixos-mailserver/nixos-mailserver/41059fc548088e49e3ddb3a2b4faeb5de018e60f";
|
|
inputs.nixpkgs.follows = "nixpkgs"; # use the same nixpkgs as the system
|
|
};
|
|
};
|
|
|
|
outputs = {
|
|
self,
|
|
nixpkgs,
|
|
...
|
|
} @ inputs: {
|
|
# https://kamadorueda.com/alejandra/
|
|
formatter.x86_64-linux = nixpkgs.legacyPackages.x86_64-linux.alejandra;
|
|
formatter.aarch64-linux = nixpkgs.legacyPackages.aarch64-linux.alejandra;
|
|
|
|
nixosConfigurations = {
|
|
# Hetzner VPS
|
|
alpha = nixpkgs.lib.nixosSystem {
|
|
system = "aarch64-linux";
|
|
specialArgs = inputs; # pass flake inputs to modules
|
|
modules = [./hosts/alpha];
|
|
};
|
|
# Hetzner VPS
|
|
delta = nixpkgs.lib.nixosSystem {
|
|
system = "aarch64-linux";
|
|
specialArgs = inputs; # pass flake inputs to modules
|
|
modules = [./hosts/delta];
|
|
};
|
|
# Work laptop
|
|
mu = nixpkgs.lib.nixosSystem {
|
|
system = "x86_64-linux";
|
|
specialArgs = inputs; # pass flake inputs to modules
|
|
modules = [./hosts/mu];
|
|
};
|
|
# Home desktop
|
|
omega = nixpkgs.lib.nixosSystem {
|
|
system = "x86_64-linux";
|
|
specialArgs = inputs; # pass flake inputs to modules
|
|
modules = [./hosts/omega];
|
|
};
|
|
# Home Server
|
|
sigma = nixpkgs.lib.nixosSystem {
|
|
system = "aarch64-linux";
|
|
specialArgs = inputs; # pass flake inputs to modules
|
|
modules = [./hosts/sigma];
|
|
};
|
|
# Tor relay
|
|
tor = nixpkgs.lib.nixosSystem {
|
|
system = "x86_64-linux";
|
|
specialArgs = inputs; # pass flake inputs to modules
|
|
modules = [./hosts/tor];
|
|
};
|
|
# Laptop
|
|
zeta = nixpkgs.lib.nixosSystem {
|
|
system = "x86_64-linux";
|
|
specialArgs = inputs; # pass flake inputs to modules
|
|
modules = [./hosts/zeta];
|
|
};
|
|
};
|
|
};
|
|
}
|