2024-12-12 14:41:43 +01:00
|
|
|
# SPDX-FileCopyrightText: 2024 Tom Hubrecht <tom.hubrecht@dgnum.eu>
|
|
|
|
#
|
|
|
|
# SPDX-License-Identifier: EUPL-1.2
|
|
|
|
|
2024-10-09 17:04:30 +02:00
|
|
|
let
|
|
|
|
_sources = import ../npins;
|
|
|
|
|
2025-01-16 10:43:57 +01:00
|
|
|
inherit (import _sources.nixos-unstable { }) lib;
|
2024-12-22 11:47:04 +01:00
|
|
|
|
|
|
|
meta = import ../meta lib;
|
2024-10-09 17:04:30 +02:00
|
|
|
|
2025-01-24 16:34:42 +01:00
|
|
|
inherit (import ../lib/nix-lib) setDefault unique;
|
2024-12-05 12:37:51 +01:00
|
|
|
|
|
|
|
getAttr = lib.flip builtins.getAttr;
|
|
|
|
|
2024-10-09 17:04:30 +02:00
|
|
|
in
|
|
|
|
|
|
|
|
rec {
|
2024-12-05 12:37:51 +01:00
|
|
|
_memberKeys = builtins.mapAttrs (_: v: v.sshKeys) meta.organization.members;
|
|
|
|
_builderKeys = builtins.mapAttrs (_: v: v.builderKeys) meta.organization.members;
|
|
|
|
_nodeKeys = builtins.mapAttrs (_: v: v.sshKeys) meta.nodes;
|
2024-10-09 17:04:30 +02:00
|
|
|
|
2024-12-05 12:37:51 +01:00
|
|
|
# Get keys of the users
|
|
|
|
getMemberKeys = name: builtins.concatLists (builtins.map (getAttr _memberKeys) name);
|
2024-10-09 17:04:30 +02:00
|
|
|
|
2024-12-05 12:37:51 +01:00
|
|
|
# Get builder keys of the users
|
|
|
|
getBuilderKeys = getAttr _builderKeys;
|
2025-02-06 01:23:32 +01:00
|
|
|
|
2024-12-05 12:37:51 +01:00
|
|
|
# Get keys of the ssh server
|
|
|
|
getNodeKeys = name: builtins.concatLists (builtins.map (getAttr _nodeKeys) name);
|
2024-10-09 17:04:30 +02:00
|
|
|
|
2024-12-05 12:37:51 +01:00
|
|
|
# List of keys for the root group
|
|
|
|
rootKeys = getMemberKeys meta.organization.groups.root;
|
2024-10-09 17:04:30 +02:00
|
|
|
|
2024-12-05 12:37:51 +01:00
|
|
|
# All keys that can access a node
|
2024-10-09 17:04:30 +02:00
|
|
|
getNodeKeys' =
|
|
|
|
node:
|
|
|
|
let
|
2024-12-05 12:37:51 +01:00
|
|
|
names = [ node ] ++
|
|
|
|
meta.nodes.${node}.admins
|
|
|
|
++ (builtins.concatMap (g: meta.organization.groups.${g}) meta.nodes.${node}.adminGroups);
|
2024-10-09 17:04:30 +02:00
|
|
|
in
|
2024-12-05 12:37:51 +01:00
|
|
|
unique (getMemberKeys names ++ getNodeKeys [ node ]);
|
2024-10-09 17:04:30 +02:00
|
|
|
|
2024-12-05 12:37:51 +01:00
|
|
|
# List of keys for all machines wide secrets
|
|
|
|
machineKeys = rootKeys ++ (getNodeKeys (builtins.attrNames meta.nodes));
|
2024-10-09 17:04:30 +02:00
|
|
|
|
2024-12-05 12:37:51 +01:00
|
|
|
mkSecrets = nodes: setDefault { publicKeys = unique (builtins.concatMap getNodeKeys' nodes); };
|
2024-12-22 11:47:04 +01:00
|
|
|
|
2024-12-05 12:37:51 +01:00
|
|
|
machineKeysBySystem = system:
|
2024-12-22 11:47:04 +01:00
|
|
|
rootKeys
|
2024-12-05 12:37:51 +01:00
|
|
|
++ (getNodeKeys (builtins.attrNames (lib.filterAttrs (_: v: v.nixpkgs.system == system) meta.nodes)));
|
2024-10-09 17:04:30 +02:00
|
|
|
}
|