0
0
Fork 0
forked from afnix/infra
Repository for AFNix-managed infrastructure
Find a file
Pierre Bourdon 1aa5321595
garage01: init
Very basic setup right now and no terraform support for admin / bucket
management. But it works and serves on https://s3.afnix.fr

Co-authored-by: Raito Bezarius <raito@afnix.fr>
2025-09-29 22:54:56 +02:00
common garage01: init 2025-09-29 22:54:56 +02:00
dashboards feat(grafana): plug jsonnet-based dashboards in provisioning 2024-08-24 16:32:21 +02:00
dnscontrol garage01: init 2025-09-29 22:54:56 +02:00
hosts afnix: Onboard nix-zulip 2025-09-21 21:38:01 +02:00
lib flake: use flake-parts and simplify(?) 2025-02-17 22:02:12 +01:00
netboot/arm64 feat: introduce ARM64 baremetal nodes 2025-02-12 22:30:45 +01:00
overlays baremetal/hypervisors: run SNI to multiplex TLS services 2025-09-26 01:22:07 +02:00
pki feat(systems): trust our infra chain on all systems 2025-01-01 03:43:13 +01:00
secrets garage01: init 2025-09-29 22:54:56 +02:00
services baremetal/hypervisors: run SNI to multiplex TLS services 2025-09-26 01:22:07 +02:00
terraform terraform/afnix/superadmin/vault: add basic machine identity fragment 2025-09-26 01:22:07 +02:00
vm garage01: init 2025-09-29 22:54:56 +02:00
.editorconfig editorconfig: init 2024-07-13 01:10:18 +00:00
.envrc chore: add lorri to prevent direnv from blocking, closes #147 2024-10-27 09:42:11 +00:00
.gitattributes feat(secrets): flag .age secret blobs as binary 2025-02-25 17:30:56 +01:00
.gitignore gitignore: fix exclusion pattern for per-tenant secrets 2025-07-30 14:03:47 +02:00
baremetal-nodes.nix flake: use flake-parts and simplify(?) 2025-02-17 22:02:12 +01:00
builders.nix hydra: configure machines via /etc 2025-03-23 00:48:10 +01:00
colmena.nix flake: use flake-parts and simplify(?) 2025-02-17 22:02:12 +01:00
default.nix feat: sign the ICA1 CSR 2024-12-31 17:50:23 +01:00
flake.lock afnix/website: update 2025-09-21 12:29:51 +02:00
flake.nix flake/vault-login: use oidc-afnix path for OIDC connections to OpenBao 2025-09-25 23:10:27 +02:00
LICENSE Initial commit 2024-06-23 06:41:53 +02:00
README.md docs(dns): add small section to README 2025-05-09 10:26:00 +02:00
renovate.json renovate: enable lock file maintenance settings 2025-09-08 08:22:16 +02:00
secrets.nix garage01: init 2025-09-29 22:54:56 +02:00

Infrastructure for the donut shaped thing that is absolutely not a donut.

Quick start

Enter our dev-shell for things like our colmena wrapper, secrets helper and required binaries:

$ nix develop

Build the infrastructure

$ colmena build --on @localboot

Notice that @localboot is load-bearing as we have some machines that cannot be deployed with vanilla Colmena. Fixing this is welcome.

$ colmena apply dry-activate $machine # Verify that the nvd log is reasonable.
$ colmena apply $machine
$ nix flake update
$ colmena apply dry-activate --on @localboot # Verify that the nvd log is reasonable. Run it twice to get only NVD logs shown.
$ colmena apply --on @localboot

Deploy the Terraform infrastructure

$ vault-login
$ eval "$(get-secrets)"
$ nix run .#tf -- plan # Vanilla Terraform from there.
$ nix run .#tf -- apply

Make changes to DNS via dnscontrol

$ vault-login
$ eval "$(get-secrets)"
$ cd dnscontrol
$ dnscontrol preview # preview the changes without applying them
$ dnscontrol push # apply changes

Troubleshooting

I failed to deploy gerrit01

Our Gerrit source build is known to have some hiccups sometimes, we are always interested in build logs, feel free to attach information in a new issue so we can make it more reliable.

get-secrets fails

Are you a floral-admin ? If not, please get in touch with one of the superadmins.