nixos/flake.nix

205 lines
5.5 KiB
Nix

{
description = "Andreas Zweili's Nixos configuration";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-21.11";
nixpkgs-unstable.url = "github:NixOS/nixpkgs/nixos-unstable";
# look here for the hardware options https://github.com/NixOS/nixos-hardware/blob/master/flake.nix#L5
nixos-hardware.url = "github:nixos/nixos-hardware";
agenix = {
url = "github:ryantm/agenix";
inputs.nixpkgs.follows = "nixpkgs";
};
home-manager = {
url = "github:nix-community/home-manager/release-21.11";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs =
inputs@{ self
, agenix
, nixpkgs
, nixpkgs-unstable
, nixos-hardware
, home-manager
}:
let
custom = import ./custom;
system = custom.system;
username = custom.username;
overlay-unstable = final: prev: {
unstable = import nixpkgs-unstable {
system = custom.system;
config.allowUnfree = true;
};
};
pkgs = import nixpkgs {
inherit system;
config = {
allowUnfree = true;
};
overlays = [
overlay-unstable
];
};
mkComputer = { hostname, system ? "x86_64-linux" }: nixpkgs.lib.nixosSystem {
inherit system pkgs;
specialArgs = { inherit custom inputs; };
modules = (
[
# System configuration for this host
"${self}/systems/${hostname}"
# Common configuration
(import ./modules/common-x86 { inherit custom inputs pkgs system; })
home-manager.nixosModules.home-manager
{
home-manager.useGlobalPkgs = true;
home-manager.useUserPackages = true;
home-manager.users.${custom.username}.imports = [
(import ./home-manager/desktop.nix { inherit custom pkgs inputs; })
];
}
]);
};
mkVM = { hostname, system ? "x86_64-linux" }: nixpkgs.lib.nixosSystem {
inherit system pkgs;
specialArgs = {
inherit custom inputs;
};
modules = (
[
# System configuration for this host
"${self}/systems/${hostname}"
# Common configuration
./modules/common-x86
agenix.nixosModules.age
{ environment.systemPackages = [ agenix.defaultPackage.${system} ]; }
home-manager.nixosModules.home-manager
{
home-manager.useGlobalPkgs = true;
home-manager.useUserPackages = true;
home-manager.users.${custom.username}.imports = [
(import ./home-manager/headless.nix { inherit custom pkgs inputs; })
];
}
]);
};
mkRaspi = { hostname, system ? "aarch64-linux" }: nixpkgs.lib.nixosSystem {
inherit system;
specialArgs = { inherit custom inputs; };
modules = (
[
# System configuration for this host
"${self}/systems/${hostname}"
# Common configuration
./modules/common
agenix.nixosModules.age
{ environment.systemPackages = [ agenix.defaultPackage.${system} ]; }
home-manager.nixosModules.home-manager
{
home-manager.useGlobalPkgs = true;
home-manager.useUserPackages = true;
home-manager.users.${custom.username}.imports = [
(import ./home-manager/headless.nix { inherit custom pkgs inputs; })
];
}
]);
};
in
{
nixosConfigurations = {
gwyn = mkComputer {
hostname = "gwyn";
};
nixos-vm = mkComputer {
hostname = "desktop-vm";
};
staubfinger = mkComputer {
hostname = "staubfinger";
};
# Servers
git = mkVM {
hostname = "git";
};
grav = mkVM {
hostname = "grav";
};
heimdall = mkVM {
hostname = "heimdall";
};
jdownloader = mkVM {
hostname = "jdownloader";
};
k3s-master1 = mkVM {
hostname = "k3s-master1";
};
k3s-node1 = mkVM {
hostname = "k3s-node1";
};
k3s-node2 = mkVM {
hostname = "k3s-node2";
};
mail = mkVM {
hostname = "mail";
};
nextcloud = mkVM {
hostname = "nextcloud";
};
nixos-management = mkVM {
hostname = "nixos-management";
};
nomad-master1 = mkVM {
hostname = "nomad-master1";
};
nomad-client1 = mkVM {
hostname = "nomad-client1";
};
pihole = mkVM {
hostname = "pihole";
};
plex = mkVM {
hostname = "plex";
};
proxy = mkVM {
hostname = "proxy";
};
raspi-test = mkRaspi {
hostname = "raspi-test";
};
restic-server = mkVM {
hostname = "restic-server";
};
rss-bridge = mkVM {
hostname = "rss-bridge";
};
ttrss = mkVM {
hostname = "ttrss";
};
};
homeConfigurations = {
"${custom.username}@co-ws-con4" = home-manager.lib.homeManagerConfiguration {
configuration = import ./home-manager/work-wsl.nix;
inherit system username;
homeDirectory = "/home/${custom.username}";
extraSpecialArgs = {
inherit custom inputs;
};
};
};
};
}