os/flake.nix

195 lines
6.4 KiB
Nix
Raw Normal View History

2019-12-02 22:18:30 -07:00
{
2019-12-05 01:36:15 -07:00
description = "A highly structured configuration database.";
nixConfig.extra-experimental-features = "nix-command flakes";
nixConfig.extra-substituters = "https://nix-dram.cachix.org https://dram.cachix.org https://nrdxp.cachix.org https://nix-community.cachix.org";
nixConfig.extra-trusted-public-keys = "nix-dram.cachix.org-1:CKjZ0L1ZiqH3kzYAZRt8tg8vewAx5yj8Du/+iR8Efpg= dram.cachix.org-1:baoy1SXpwYdKbqdTbfKGTKauDDeDlHhUpC+QuuILEMY= nrdxp.cachix.org-1:Fc5PSqY2Jm1TrWfm88l6cvGWwz3s93c6IOifQWnhNW4= nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs=";
inputs =
{
# Track channels with commits tested and built by hydra
nixos.url = "github:nixos/nixpkgs/nixos-22.05";
latest.url = "github:nixos/nixpkgs/nixos-unstable";
2022-01-31 17:52:56 +01:00
master.url = "github:nixos/nixpkgs/master";
2021-04-01 21:10:24 -05:00
digga.url = "github:pub-solar/digga/fix/bootstrap-iso";
digga.inputs.nixpkgs.follows = "nixos";
digga.inputs.nixlib.follows = "nixos";
digga.inputs.home-manager.follows = "home";
digga.inputs.deploy.follows = "deploy";
home.url = "github:nix-community/home-manager/release-22.05";
home.inputs.nixpkgs.follows = "nixos";
2021-03-01 20:30:47 -07:00
darwin.url = "github:LnL7/nix-darwin";
darwin.inputs.nixpkgs.follows = "nixos";
deploy.url = "github:serokell/deploy-rs";
deploy.inputs.nixpkgs.follows = "nixos";
agenix.url = "github:ryantm/agenix";
agenix.inputs.nixpkgs.follows = "nixos";
2021-04-01 21:10:24 -05:00
naersk.url = "github:nmattia/naersk";
naersk.inputs.nixpkgs.follows = "nixos";
2021-03-01 20:30:47 -07:00
nixos-hardware.url = "github:nixos/nixos-hardware";
2021-04-01 21:10:24 -05:00
nixos-generators.url = "github:nix-community/nixos-generators";
2021-05-30 21:10:28 +02:00
# PubSolarOS additions
2022-07-08 14:20:00 +02:00
triton-vmtools.url = "git+https://git.b12f.io/pub-solar/infra?ref=main&dir=vmtools";
triton-vmtools.inputs.nixpkgs.follows = "latest";
2022-10-18 16:49:40 +02:00
tritonshell.url = "git+https://git.greenbaum.cloud/dev/tritonshell?ref=main";
tritonshell.inputs.nixpkgs.follows = "latest";
nix-autobahn.url = "github:wucke13/nix-autobahn";
nix-autobahn.inputs.nixpkgs.follows = "latest";
2022-03-23 11:27:32 +01:00
nix-autobahn.inputs.naersk.follows = "naersk";
};
outputs =
{ self
, digga
, nixos
, home
, nixos-hardware
, nur
, agenix
, deploy
, tritonshell
, nix-autobahn
, ...
} @ inputs:
2021-07-16 16:01:25 -05:00
digga.lib.mkFlake
{
inherit self inputs;
channelsConfig = {
2022-09-06 11:34:52 +02:00
allowUnfree = true;
};
2021-07-16 16:01:25 -05:00
2022-01-31 17:51:42 +01:00
supportedSystems = [ "x86_64-linux" "aarch64-linux" ];
2021-07-16 16:01:25 -05:00
channels = {
nixos = {
2021-07-20 18:33:45 -05:00
imports = [ (digga.lib.importOverlays ./overlays) ];
overlays = [ ];
2021-07-16 16:01:25 -05:00
};
latest = { };
2022-01-31 17:52:56 +01:00
master = { };
2021-07-16 16:01:25 -05:00
};
lib = import ./lib { lib = digga.lib // nixos.lib; };
2021-04-21 22:44:15 -05:00
2021-07-16 16:01:25 -05:00
sharedOverlays = [
(final: prev: {
__dontExport = true;
lib = prev.lib.extend (lfinal: lprev: {
our = self.lib;
});
})
nur.overlay
agenix.overlay
(import ./pkgs)
2021-07-16 16:01:25 -05:00
];
2021-04-21 22:44:15 -05:00
nixos = {
2021-07-16 16:01:25 -05:00
hostDefaults = {
system = "x86_64-linux";
channelName = "nixos";
imports = [ (digga.lib.importExportableModules ./modules) ];
modules = [
2021-07-16 16:01:25 -05:00
{ lib.our = self.lib; }
# FIXME: upstream module causes a huge number of unnecessary
# dependencies to be pulled in for all systems -- many of them are
# graphical. should only be imported as needed.
# digga.nixosModules.bootstrapIso
2021-07-16 16:01:25 -05:00
digga.nixosModules.nixConfig
home.nixosModules.home-manager
agenix.nixosModules.age
];
};
2021-07-20 18:33:45 -05:00
imports = [ (digga.lib.importHosts ./hosts) ];
2021-07-16 16:01:25 -05:00
hosts = {
/* set host specific properties here */
bootstrap = {
modules = [
digga.nixosModules.bootstrapIso
];
};
PubSolarOS = {
tests = [
(import ./tests/first-test.nix { pkgs = nixos.legacyPackages.x86_64-linux; lib = nixos.lib; })
];
};
2022-01-19 01:13:15 +01:00
fae = {
system = "aarch64-linux";
};
2022-07-08 14:20:00 +02:00
powder = {
system = "x86_64-linux";
};
2021-05-27 10:41:55 -07:00
};
2021-07-16 16:01:25 -05:00
importables = rec {
2021-07-20 18:33:45 -05:00
profiles = digga.lib.rakeLeaves ./profiles // {
users = digga.lib.rakeLeaves ./users;
2021-07-16 16:01:25 -05:00
};
suites = with profiles; rec {
base = [ users.pub-solar users.root ];
2022-01-31 17:47:45 +01:00
iso = base ++ [ base-user graphical pub-solar-iso ];
pubsolaros = [ full-install base-user users.root ];
2021-10-24 22:03:28 +02:00
anonymous = [ pubsolaros users.pub-solar ];
teutat3s = pubsolaros ++ [ users.teutat3s ];
dumpyourvms = teutat3s ++ [ graphical ];
ryzensun = teutat3s ++ [ graphical ];
2021-07-16 16:01:25 -05:00
};
2021-05-27 10:41:55 -07:00
};
2021-04-21 22:44:15 -05:00
};
2021-07-16 16:01:25 -05:00
home = {
imports = [ (digga.lib.importExportableModules ./users/modules) ];
modules = [ ];
2021-07-16 16:01:25 -05:00
importables = rec {
2021-07-20 18:33:45 -05:00
profiles = digga.lib.rakeLeaves ./users/profiles;
2021-07-16 16:01:25 -05:00
suites = with profiles; rec {
2021-09-21 22:27:53 +02:00
base = [ direnv ];
2021-07-16 16:01:25 -05:00
};
2021-05-27 10:41:55 -07:00
};
2021-07-16 16:01:25 -05:00
users = {
2021-10-24 22:03:28 +02:00
pub-solar = { suites, ... }: { imports = suites.base; };
2022-01-31 17:52:56 +01:00
teutat3s = { suites, ... }: { imports = suites.base; };
2021-07-16 16:01:25 -05:00
}; # digga.lib.importers.rakeLeaves ./users/hm;
2021-04-21 22:44:15 -05:00
};
devshell = ./shell;
2021-05-29 12:53:33 -07:00
2021-07-16 16:01:25 -05:00
homeConfigurations = digga.lib.mkHomeConfigurations self.nixosConfigurations;
2022-01-19 01:13:15 +01:00
deploy.nodes = digga.lib.mkDeployNodes self.nixosConfigurations {
fae = {
2022-01-31 17:51:42 +01:00
hostname = "fae.fritz.box:22";
sshUser = "pub-solar";
fastConnect = true;
2022-01-19 01:13:15 +01:00
profilesOrder = [ "system" "direnv" ];
profiles.direnv = {
user = "pub-solar";
path = deploy.lib.x86_64-linux.activate.home-manager self.homeConfigurationsPortable.x86_64-linux.pub-solar;
2022-01-19 01:13:15 +01:00
};
};
2022-07-08 14:20:00 +02:00
powder = {
hostname = "80.71.153.194";
sshUser = "root";
profilesOrder = [ "system" "direnv" ];
profiles.direnv = {
user = "pub-solar";
path = deploy.lib.x86_64-linux.activate.home-manager self.homeConfigurationsPortable.x86_64-linux.pub-solar;
};
};
2022-01-19 01:13:15 +01:00
};
2021-07-16 16:01:25 -05:00
}
2021-04-21 22:44:15 -05:00
;
2019-12-02 22:18:30 -07:00
}