foundation-vault (hashicorp/vault:1.18, digest-pinned) with integrated raft storage in foundation-vault-data (-> /vault/file, which the entrypoint chowns to the vault user), IPC_LOCK for mlock, internal only (8200 unpublished). Init + unseal reuse the olsitec-core pattern but over docker-exec/SSH (ADR-007): the foundation-vault-init command inits 1-of-1 Shamir, unseals, and emits keys + root token on stdout — marked secret and NOT streamed (logging:Stderr) so they never reach the terminal/logs (D2). run.sh captures them into vaultCredentials:* (the one bootstrap secret that cannot live in Vault, CONTRACT_002 §2.4) with an idempotent guard that avoids churning the config. vault-unseal.sh is the passphrase-gated reboot helper (ADR-004): reads keys from config, unseals over an SSH stdin pipe. run.sh also now pins the Pulumi backend per-process (PULUMI_BACKEND_URL) instead of a global `pulumi login`. Live on cx33 Helsinki: initialized + unsealed (raft 1.18.5), keys captured to encrypted config, idempotent re-up reuses stored keys, container-restart reseal recovered by vault-unseal.sh. Acceptance T05 met. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
66 lines
3.2 KiB
YAML
66 lines
3.2 KiB
YAML
# Pulumi.foundation.yaml — stack config for the `foundation` stack (initial Hetzner home).
|
|
#
|
|
# NON-SECRET values only here (CONTRACT_001 §1.2) — safe to commit in plaintext.
|
|
# Secrets (CONTRACT_001 §1.3) are added by `pulumi config set --secret` as
|
|
# `secure: v1:…` (passphrase-encrypted): foundation:cloudflareApiToken,
|
|
# foundation:backup.offsiteAccessKey/SecretKey, and later vaultCredentials:*.
|
|
#
|
|
# Master passphrase: pass olsitec-foundation/PULUMI_CONFIG_PASSPHRASE (the ONE
|
|
# external secret). Image digests live in foundation/VERSIONS, not here (D5).
|
|
config:
|
|
# --- identity / networking (real: olsitec.net) ---
|
|
foundation:baseDomain: olsitec.net
|
|
foundation:hosts.forge: forge.olsitec.net
|
|
foundation:hosts.vault: vault.olsitec.net
|
|
foundation:hosts.s3: s3.olsitec.net
|
|
foundation:hosts.git: git.olsitec.net
|
|
foundation:forgeSshPort: "2222"
|
|
# --- deployment target: the Helsinki cx33 VM (Docker-over-SSH, port 222) ---
|
|
foundation:vm.host: 204.168.234.72
|
|
foundation:vm.user: root
|
|
foundation:vm.sshPort: "222"
|
|
# --- container plane (CONTRACT_003) ---
|
|
foundation:network.name: foundation-net
|
|
foundation:network.subnet: 172.30.0.0/24
|
|
foundation:dataRoot: /srv/foundation
|
|
# --- TLS: real Let's Encrypt via Cloudflare DNS-01 ---
|
|
foundation:tls.mode: letsencrypt-dns01
|
|
foundation:tls.acmeEmail: a.niemann@olsitec.de
|
|
# --- Cloudflare (DNS records + DNS-01); token is a SECRET set separately ---
|
|
foundation:cloudflare.zoneId: 27e587d5574d5fd6e2cf75b9e914a02c
|
|
# --- fixed names (derived, non-secret; creds generated → Vault) ---
|
|
foundation:postgres.db: foundation
|
|
foundation:postgres.forgejoDb: forgejo
|
|
foundation:rustfs.buckets:
|
|
- forgejo-packages
|
|
- forgejo-artifacts
|
|
- forgejo-lfs
|
|
- foundation-backups
|
|
foundation:forgejo.adminUser: platform-admin
|
|
foundation:forgejo.orgName: olsitec
|
|
foundation:runner.labels:
|
|
- docker:docker://node:20-bookworm
|
|
- dind:docker://-
|
|
# --- credential feature flags (ADR-002) ---
|
|
foundation:features.postgres: "true"
|
|
foundation:features.rustfs: "true"
|
|
foundation:features.forgejo: "true"
|
|
foundation:features.runner: "true"
|
|
foundation:features.backup: "true"
|
|
foundation:features.registry: "true"
|
|
# --- backup: offsite = home Synology MinIO (CONTRACT_004); creds are SECRET ---
|
|
foundation:backup.bucket: foundation-backups
|
|
foundation:backup.offsiteEndpoint: https://minio.wob.olsitec.de:19000
|
|
foundation:backup.retentionDaily: "7"
|
|
foundation:backup.retentionWeekly: "4"
|
|
foundation:cloudflareApiToken:
|
|
secure: v1:xDFqTVZxRm2nvIrQ:ddjNyqKi4C27Fppp9YA0B+gNZPtjWig/NBC6y9dR3cQ8xfNfwEsEHxvRgn8aUTH9UrmjXtLEoYk=
|
|
foundation:backup.offsiteAccessKey:
|
|
secure: v1:svEvJ5K9u+FMnpV/:RztjS8VMSxrdgpBtbNpBPA6gfPLVgnABp77diBC6nWGHZRnG
|
|
foundation:backup.offsiteSecretKey:
|
|
secure: v1:lkkGBjgmJqVziusc:gpmw5lkfFAjXzeFikhtQnvWObYpKD3Bq5XSmrBA/vlLaoqqxFGAAO4Cq7V8nOLZ926x3fXukPQI=
|
|
vaultCredentials:unsealKeys:
|
|
secure: v1:9YpTkFoQanMwxAQV:dJ4YmXS0aOTHPbuK1H6AJ0SAJ0CjYX0iIyLOQAUNfsOWLsSy5TXxPpGecieBWkzc4AALDkJNlQN9Xo6Q0ZcaSg==
|
|
vaultCredentials:rootToken:
|
|
secure: v1:OUpYMjnaftxMUKjv:2m+dydQopXGRleeX6ddhYSHgHP7HHZXYLAvQHXUvaA91qajoxU+VugDB/Rs=
|
|
encryptionsalt: v1:5YhUt8BVfH0=:v1:DPCHl+7zwn4RaMPj:A19tZzBlZ1NmDtTWrHreEKk5e8idyw==
|