nixos-config/flake.nix
2025-02-02 20:49:01 +01:00

166 lines
4.6 KiB
Nix

{
description = "My NixOS config";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.11";
stable.url = "github:nixos/nixpkgs/nixos-24.11";
# unstable.url = "github:nixos/nixpkgs/nixos-unstable";
# home-manager-unstable = {
# url = "github:nix-community/home-manager";
# inputs.nixpkgs.follows = "unstable";
# };
home-manager = {
url = "github:nix-community/home-manager/release-24.11";
inputs.nixpkgs.follows = "stable";
};
thymis = {
url = "github:Thymis-io/thymis";
inputs.nixpkgs.follows = "stable";
};
tildefriends.url = "git+https://dev.tildefriends.net/cory/tildefriends?ref=main";
vedirect-reader.url = "git+https://gitea.com/tasiaiso/vedirect-reader";
tasiaiso-vulpecula-zone = {
url = "git+https://git.vulpecula.zone/tasiaiso/tasiaiso.vulpecula.zone";
inputs.nixpkgs.follows = "stable";
};
vulpecula-zone = {
url = "git+https://git.vulpecula.zone/tasiaiso/vulpecula.zone";
inputs.nixpkgs.follows = "stable";
};
# home-manager = {
# url = "github:nix-community/home-manager/release-24.05";
# inputs.nixpkgs.follows = "stable";
# };
# nixos-conf-editor.url = "github:snowfallorg/nixos-conf-editor";
# nix-software-center.url = "github:snowfallorg/nix-software-center";
agenix = {
url = "github:ryantm/agenix";
inputs.nixpkgs.follows = "stable";
};
lanzaboote = {
url = "github:nix-community/lanzaboote/v0.4.2";
inputs.nixpkgs.follows = "stable";
};
};
outputs = {
self,
nixpkgs,
stable,
thymis,
home-manager,
vedirect-reader,
# nixos-conf-editor,
# nix-software-center,
tildefriends,
agenix,
tasiaiso-vulpecula-zone,
vulpecula-zone,
lanzaboote,
...
} @ inputs: let
inherit (self) outputs;
# Supported systems for your flake packages, shell, etc.
systems = [
"aarch64-linux"
"x86_64-linux"
];
# This is a function that generates an attribute by calling a function you
# pass to it, with each system as an argument
forAllSystems = nixpkgs.lib.genAttrs systems;
in {
# Your custom packages
# Accessible through 'nix build', 'nix shell', etc
packages = forAllSystems (system: import ./pkgs nixpkgs.legacyPackages.${system});
# Formatter for your nix files, available through 'nix fmt'
# Other options beside 'alejandra' include 'nixpkgs-fmt'
formatter = forAllSystems (system: nixpkgs.legacyPackages.${system}.alejandra);
# Your custom packages and modifications, exported as overlays
overlays = import ./overlays {inherit inputs;};
# Reusable nixos modules you might want to export
# These are usually stuff you would upstream into nixpkgs
nixosModules = import ./modules/nixos;
# NixOS configuration entrypoint
# Available through 'nixos-rebuild build --flake .#phoenix'
# or nixos-rebuild switch --flake .#$(cat /etc/hostname)
nixosConfigurations = {
phoenix = stable.lib.nixosSystem {
system = "x86_64-linux";
specialArgs = {inherit inputs outputs;};
modules = [
./hosts/phoenix/configuration.nix
];
};
theseus = stable.lib.nixosSystem {
system = "x86_64-linux";
specialArgs = {inherit inputs outputs;};
modules = [
./hosts/theseus/configuration.nix
];
};
stuff = stable.lib.nixosSystem {
system = "x86_64-linux";
specialArgs = {inherit inputs outputs;};
modules = [
./hosts/stuff/configuration.nix
];
};
enry = stable.lib.nixosSystem {
system = "aarch64-linux";
specialArgs = {inherit inputs outputs;};
modules = [
./hosts/enry/configuration.nix
];
};
cave = stable.lib.nixosSystem {
system = "x86_64-linux";
specialArgs = {inherit inputs outputs;};
modules = [
./hosts/cave/configuration.nix
];
};
# vulpecula = stable.lib.nixosSystem {
# system = "x86_64-linux";
# specialArgs = {inherit inputs outputs;};
# modules = [
# ./hosts/vulpecula/configuration.nix
# ];
# };
vulpecula-vps = stable.lib.nixosSystem {
system = "x86_64-linux";
specialArgs = {inherit inputs outputs;};
modules = [
./hosts/vulpecula-vps/configuration.nix
];
};
jo = stable.lib.nixosSystem {
system = "x86_64-linux";
specialArgs = {inherit inputs outputs;};
modules = [
./hosts/jo/configuration.nix
];
};
};
};
}