Gonçalo Rodrigues e018e627e3 infra: manage CI secrets and ghcr.io pull credentials via Terraform
Adds github provider + ci.tf which provisions:
- KUBECONFIG GitHub Actions secret (from local kubeconfig)
- ghcr-credentials k8s pull secret in finance and auth namespaces

Run `terraform apply -var github_token=<PAT>` once after cluster setup.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-06-13 14:21:15 +01:00

62 lines
1.9 KiB
HCL

terraform {
required_providers {
kubernetes = {
source = "hashicorp/kubernetes"
version = "2.32.0"
}
helm = {
source = "hashicorp/helm"
version = "~> 2.17"
}
random = {
source = "hashicorp/random"
version = "~> 3.6"
}
github = {
source = "integrations/github"
version = "~> 6.0"
}
}
}
variable "github_token" {
description = "GitHub PAT with repo and write:packages scopes (used for Actions secrets and ghcr.io pull)"
type = string
sensitive = true
}
variable "github_owner" {
description = "GitHub username / org that owns the homelab repo"
type = string
default = "GoncaloRodri"
}
provider "github" {
token = var.github_token
owner = var.github_owner
}
locals {
kubeconfig = yamldecode(file(pathexpand("~/.kube/config")))
kubectx = one([for c in local.kubeconfig.contexts : c if c.name == local.kubeconfig.current-context])
kubecluster = one([for c in local.kubeconfig.clusters : c if c.name == local.kubectx.context.cluster])
kubeuser = one([for u in local.kubeconfig.users : u if u.name == local.kubectx.context.user])
server = replace(local.kubecluster.cluster.server, "0.0.0.0", "127.0.0.1")
}
provider "kubernetes" {
host = local.server
client_certificate = base64decode(local.kubeuser.user.client-certificate-data)
client_key = base64decode(local.kubeuser.user.client-key-data)
cluster_ca_certificate = base64decode(local.kubecluster.cluster.certificate-authority-data)
}
provider "helm" {
kubernetes {
host = local.server
client_certificate = base64decode(local.kubeuser.user.client-certificate-data)
client_key = base64decode(local.kubeuser.user.client-key-data)
cluster_ca_certificate = base64decode(local.kubecluster.cluster.certificate-authority-data)
}
}