2019-12-03 05:18:30 +00:00
|
|
|
{
|
2019-12-05 08:36:15 +00:00
|
|
|
description = "A highly structured configuration database.";
|
2019-12-05 05:36:36 +00:00
|
|
|
|
2022-02-02 03:15:24 +00:00
|
|
|
nixConfig.extra-experimental-features = "nix-command flakes";
|
2021-07-16 21:09:26 +00:00
|
|
|
|
2020-08-02 04:08:41 +00:00
|
|
|
inputs = {
|
2022-04-09 14:40:03 +00:00
|
|
|
# Track channels with commits tested and built by hydra
|
2023-05-17 22:04:39 +00:00
|
|
|
nixos.url = "github:nixos/nixpkgs/nixos-23.05";
|
2021-08-06 01:30:40 +00:00
|
|
|
latest.url = "github:nixos/nixpkgs/nixos-unstable";
|
2021-04-02 02:10:24 +00:00
|
|
|
|
2022-11-07 10:24:59 +00:00
|
|
|
flake-compat.url = "github:edolstra/flake-compat";
|
|
|
|
flake-compat.flake = false;
|
2022-11-07 10:24:59 +00:00
|
|
|
|
2022-08-27 11:49:55 +00:00
|
|
|
digga.url = "github:pub-solar/digga/fix/bootstrap-iso";
|
2021-07-15 22:15:18 +00:00
|
|
|
digga.inputs.nixpkgs.follows = "nixos";
|
|
|
|
digga.inputs.nixlib.follows = "nixos";
|
2021-07-12 22:32:13 +00:00
|
|
|
digga.inputs.home-manager.follows = "home";
|
2022-02-02 03:15:24 +00:00
|
|
|
digga.inputs.deploy.follows = "deploy";
|
2023-02-01 10:29:34 +00:00
|
|
|
digga.inputs.darwin.follows = "darwin";
|
|
|
|
digga.inputs.flake-compat.follows = "flake-compat";
|
2021-07-15 22:15:18 +00:00
|
|
|
|
2023-05-17 22:04:39 +00:00
|
|
|
home.url = "github:nix-community/home-manager/release-23.05";
|
2021-02-07 21:24:41 +00:00
|
|
|
home.inputs.nixpkgs.follows = "nixos";
|
2021-07-15 22:15:18 +00:00
|
|
|
|
2021-03-02 03:30:47 +00:00
|
|
|
darwin.url = "github:LnL7/nix-darwin";
|
2022-02-02 03:15:24 +00:00
|
|
|
darwin.inputs.nixpkgs.follows = "nixos";
|
2021-07-15 22:15:18 +00:00
|
|
|
|
2022-02-18 00:22:48 +00:00
|
|
|
deploy.url = "github:serokell/deploy-rs";
|
2022-02-02 03:15:24 +00:00
|
|
|
deploy.inputs.nixpkgs.follows = "nixos";
|
2023-02-01 10:29:34 +00:00
|
|
|
deploy.inputs.flake-compat.follows = "flake-compat";
|
2021-07-15 22:15:18 +00:00
|
|
|
|
2021-05-13 17:35:23 +00:00
|
|
|
agenix.url = "github:ryantm/agenix";
|
2022-02-02 03:15:24 +00:00
|
|
|
agenix.inputs.nixpkgs.follows = "nixos";
|
2023-02-01 10:29:34 +00:00
|
|
|
agenix.inputs.darwin.follows = "darwin";
|
2021-04-02 02:10:24 +00:00
|
|
|
|
2021-03-02 03:30:47 +00:00
|
|
|
nixos-hardware.url = "github:nixos/nixos-hardware";
|
2021-07-15 22:15:18 +00:00
|
|
|
|
2023-05-31 18:59:02 +00:00
|
|
|
nvfetcher.url = "github:berberman/nvfetcher";
|
|
|
|
nvfetcher.inputs.nixpkgs.follows = "nixos";
|
|
|
|
nvfetcher.inputs.flake-compat.follows = "flake-compat";
|
2023-07-02 11:26:12 +00:00
|
|
|
|
2023-09-13 10:06:28 +00:00
|
|
|
triton-vmtools.url = "git+https://git.pub.solar/pub-solar/infra?ref=main&dir=vmtools";
|
2023-01-28 22:27:21 +00:00
|
|
|
triton-vmtools.inputs.nixpkgs.follows = "nixos";
|
2022-11-27 20:56:40 +00:00
|
|
|
|
2023-01-28 22:27:21 +00:00
|
|
|
keycloak-theme-pub-solar.url = "git+https://git.pub.solar/pub-solar/keycloak-theme?ref=main";
|
|
|
|
keycloak-theme-pub-solar.inputs.nixpkgs.follows = "nixos";
|
2022-11-20 22:28:23 +00:00
|
|
|
};
|
2019-12-14 04:39:25 +00:00
|
|
|
|
2023-01-28 22:51:33 +00:00
|
|
|
outputs = {
|
|
|
|
self,
|
|
|
|
digga,
|
|
|
|
nixos,
|
|
|
|
home,
|
|
|
|
nixos-hardware,
|
|
|
|
agenix,
|
|
|
|
deploy,
|
2023-07-02 11:27:04 +00:00
|
|
|
nvfetcher,
|
2023-01-28 22:51:33 +00:00
|
|
|
triton-vmtools,
|
|
|
|
keycloak-theme-pub-solar,
|
|
|
|
...
|
|
|
|
} @ inputs:
|
2021-07-16 21:01:25 +00:00
|
|
|
digga.lib.mkFlake
|
2020-08-02 04:08:41 +00:00
|
|
|
{
|
2021-07-12 22:32:13 +00:00
|
|
|
inherit self inputs;
|
2021-07-16 21:01:25 +00:00
|
|
|
|
2021-07-15 22:15:18 +00:00
|
|
|
channelsConfig = {
|
2022-02-02 03:15:24 +00:00
|
|
|
# allowUnfree = true;
|
2020-08-02 04:08:41 +00:00
|
|
|
};
|
2021-07-16 21:01:25 +00:00
|
|
|
|
2023-06-28 17:20:11 +00:00
|
|
|
supportedSystems = ["x86_64-linux" "aarch64-linux" "aarch64-darwin"];
|
2022-01-31 16:47:45 +00:00
|
|
|
|
2022-08-14 12:15:02 +00:00
|
|
|
channels = {
|
2021-07-16 21:01:25 +00:00
|
|
|
nixos = {
|
2022-08-14 12:15:02 +00:00
|
|
|
imports = [(digga.lib.importOverlays ./overlays)];
|
2023-05-13 16:43:12 +00:00
|
|
|
overlays = [
|
|
|
|
(self: super: {
|
|
|
|
deploy-rs = {
|
2023-05-31 18:59:02 +00:00
|
|
|
inherit (inputs.nixos.legacyPackages.x86_64-linux) deploy-rs;
|
2023-07-02 15:56:17 +00:00
|
|
|
lib = inputs.deploy.lib.x86_64-linux;
|
2023-05-13 16:43:12 +00:00
|
|
|
};
|
|
|
|
})
|
|
|
|
];
|
2021-07-16 21:01:25 +00:00
|
|
|
};
|
2022-01-31 16:52:56 +00:00
|
|
|
latest = {};
|
2022-11-20 22:28:23 +00:00
|
|
|
};
|
2021-07-16 21:01:25 +00:00
|
|
|
|
2022-01-31 16:47:45 +00:00
|
|
|
lib = import ./lib {lib = digga.lib // nixos.lib;};
|
2022-11-20 22:28:23 +00:00
|
|
|
|
2022-01-31 16:47:45 +00:00
|
|
|
sharedOverlays = [
|
2021-07-16 21:01:25 +00:00
|
|
|
(final: prev: {
|
|
|
|
__dontExport = true;
|
2022-01-31 16:47:45 +00:00
|
|
|
lib = prev.lib.extend (lfinal: lprev: {
|
2021-07-16 21:01:25 +00:00
|
|
|
our = self.lib;
|
2022-11-20 22:28:23 +00:00
|
|
|
});
|
|
|
|
})
|
2023-02-01 10:14:50 +00:00
|
|
|
agenix.overlays.default
|
2023-05-31 18:59:02 +00:00
|
|
|
nvfetcher.overlays.default
|
2022-11-20 22:28:23 +00:00
|
|
|
|
2022-08-14 12:21:11 +00:00
|
|
|
(import ./pkgs)
|
2022-01-31 16:47:45 +00:00
|
|
|
];
|
2022-11-20 22:28:23 +00:00
|
|
|
|
2021-04-22 03:44:15 +00:00
|
|
|
nixos = {
|
2021-07-16 21:01:25 +00:00
|
|
|
hostDefaults = {
|
2022-01-31 16:47:45 +00:00
|
|
|
system = "x86_64-linux";
|
2021-07-16 21:01:25 +00:00
|
|
|
channelName = "nixos";
|
2021-07-20 23:33:45 +00:00
|
|
|
imports = [(digga.lib.importExportableModules ./modules)];
|
2022-08-14 12:21:11 +00:00
|
|
|
modules = [
|
2022-01-31 16:52:56 +00:00
|
|
|
{lib.our = self.lib;}
|
2022-09-01 12:34:57 +00:00
|
|
|
# FIXME: upstream module causes a huge number of unnecessary
|
2022-01-31 16:52:56 +00:00
|
|
|
# dependencies to be pulled in for all systems -- many of them are
|
2022-09-01 12:34:57 +00:00
|
|
|
# graphical. should only be imported as needed.
|
|
|
|
# digga.nixosModules.bootstrapIso
|
2021-07-16 21:01:25 +00:00
|
|
|
digga.nixosModules.nixConfig
|
|
|
|
home.nixosModules.home-manager
|
|
|
|
agenix.nixosModules.age
|
2022-01-31 16:52:56 +00:00
|
|
|
];
|
2021-07-16 21:01:25 +00:00
|
|
|
};
|
2021-04-22 03:44:15 +00:00
|
|
|
|
2021-07-16 21:01:25 +00:00
|
|
|
imports = [(digga.lib.importHosts ./hosts)];
|
2021-04-22 03:44:15 +00:00
|
|
|
hosts = {
|
2023-03-27 11:36:56 +00:00
|
|
|
# Set host-specific properties here
|
2021-07-16 21:01:25 +00:00
|
|
|
bootstrap = {
|
2021-10-11 22:11:36 +00:00
|
|
|
modules = [
|
2022-09-01 12:34:57 +00:00
|
|
|
digga.nixosModules.bootstrapIso
|
2021-07-16 21:01:25 +00:00
|
|
|
];
|
|
|
|
};
|
2022-06-04 21:45:06 +00:00
|
|
|
PubSolarOS = {
|
2023-04-11 17:19:28 +00:00
|
|
|
# Broken since https://github.com/NixOS/nixpkgs/commit/5bcef4224928fe45312f0ee321ddf0f0e8feeb7b
|
|
|
|
# Needs a fix in https://github.com/divnix/digga/blob/main/src/tests.nix#L12-L21
|
|
|
|
#tests = [
|
|
|
|
# (import ./tests/first-test.nix {
|
|
|
|
# pkgs = nixos.legacyPackages.x86_64-linux;
|
|
|
|
# lib = nixos.lib;
|
|
|
|
# })
|
|
|
|
#];
|
2021-05-27 17:41:55 +00:00
|
|
|
};
|
2022-11-20 22:28:23 +00:00
|
|
|
};
|
2021-07-16 21:01:25 +00:00
|
|
|
importables = rec {
|
2021-07-20 23:33:45 +00:00
|
|
|
profiles =
|
|
|
|
digga.lib.rakeLeaves ./profiles
|
|
|
|
// {
|
|
|
|
users = digga.lib.rakeLeaves ./users;
|
2021-07-16 21:01:25 +00:00
|
|
|
};
|
|
|
|
suites = with profiles; rec {
|
2022-08-13 20:59:05 +00:00
|
|
|
base = [users.pub-solar users.root];
|
2022-01-31 16:47:45 +00:00
|
|
|
iso = base ++ [base-user graphical pub-solar-iso];
|
2022-08-14 13:18:55 +00:00
|
|
|
pubsolaros = [full-install base-user users.root];
|
2021-10-24 20:03:28 +00:00
|
|
|
anonymous = [pubsolaros users.pub-solar];
|
2021-05-27 17:41:55 +00:00
|
|
|
};
|
2021-04-22 03:44:15 +00:00
|
|
|
};
|
2023-01-28 22:51:33 +00:00
|
|
|
};
|
2021-07-16 21:01:25 +00:00
|
|
|
|
2023-01-28 22:51:33 +00:00
|
|
|
home = {
|
|
|
|
imports = [(digga.lib.importExportableModules ./users/modules)];
|
|
|
|
modules = [];
|
|
|
|
importables = rec {
|
|
|
|
profiles = digga.lib.rakeLeaves ./users/profiles;
|
|
|
|
suites = with profiles; rec {
|
|
|
|
base = [direnv git];
|
2021-05-27 17:41:55 +00:00
|
|
|
};
|
2021-04-22 03:44:15 +00:00
|
|
|
};
|
2023-01-28 22:51:33 +00:00
|
|
|
users = {
|
2023-01-29 01:40:14 +00:00
|
|
|
pub-solar = {suites, ...}: {
|
|
|
|
imports = suites.base;
|
|
|
|
|
2023-02-01 09:10:28 +00:00
|
|
|
home.stateVersion = "21.03";
|
|
|
|
};
|
|
|
|
barkeeper = {suites, ...}: {
|
|
|
|
imports = suites.base;
|
|
|
|
|
2023-01-29 01:40:14 +00:00
|
|
|
home.stateVersion = "21.03";
|
|
|
|
};
|
2023-01-28 22:51:33 +00:00
|
|
|
}; # digga.lib.importers.rakeLeaves ./users/hm;
|
|
|
|
};
|
2021-04-22 03:44:15 +00:00
|
|
|
|
2023-01-28 22:51:33 +00:00
|
|
|
devshell = ./shell;
|
2021-05-29 19:53:33 +00:00
|
|
|
|
2023-01-28 22:51:33 +00:00
|
|
|
homeConfigurations = digga.lib.mkHomeConfigurations self.nixosConfigurations;
|
2021-05-02 17:35:29 +00:00
|
|
|
|
2023-01-28 22:51:33 +00:00
|
|
|
deploy.nodes = digga.lib.mkDeployNodes self.nixosConfigurations {
|
|
|
|
flora-6 = {
|
|
|
|
sshUser = "barkeeper";
|
|
|
|
hostname = "flora-6.pub.solar";
|
2023-07-02 11:26:12 +00:00
|
|
|
fastConnect = true;
|
|
|
|
profilesOrder = ["system" "direnv"];
|
|
|
|
profiles.direnv = {
|
|
|
|
user = "barkeeper";
|
2023-07-02 15:56:17 +00:00
|
|
|
path = self.pkgs.x86_64-linux.nixos.deploy-rs.lib.activate.home-manager self.homeConfigurationsPortable.x86_64-linux.barkeeper;
|
2023-07-02 11:26:12 +00:00
|
|
|
};
|
2022-10-05 10:02:28 +00:00
|
|
|
};
|
2023-05-13 16:43:12 +00:00
|
|
|
#example = {
|
|
|
|
# hostname = "example.com:22";
|
|
|
|
# sshUser = "bartender";
|
|
|
|
# fastConnect = true;
|
|
|
|
# profilesOrder = ["system" "direnv"];
|
|
|
|
# profiles.direnv = {
|
|
|
|
# user = "bartender";
|
2023-07-02 15:56:17 +00:00
|
|
|
# path = self.pkgs.x86_64-linux.nixos.deploy-rs.lib.x86_64-linux.activate.home-manager self.homeConfigurationsPortable.x86_64-linux.bartender;
|
2023-05-13 16:43:12 +00:00
|
|
|
# };
|
|
|
|
#};
|
2022-08-13 20:35:43 +00:00
|
|
|
};
|
|
|
|
};
|
2019-12-03 05:18:30 +00:00
|
|
|
}
|