{"id":33914059,"url":"https://github.com/floryn08/homelab-alm","last_synced_at":"2026-04-26T16:02:41.937Z","repository":{"id":301424960,"uuid":"1006193575","full_name":"floryn08/homelab-alm","owner":"floryn08","description":"Application Lifecycle Management as a Kubernetes Operator for my Homelab","archived":false,"fork":false,"pushed_at":"2026-04-17T06:44:20.000Z","size":305,"stargazers_count":0,"open_issues_count":3,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2026-04-17T08:32:31.642Z","etag":null,"topics":["alm","k8s-operator","operator-sdk"],"latest_commit_sha":null,"homepage":"https://floryn08.github.io/homelab-alm/","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/floryn08.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2025-06-21T17:46:20.000Z","updated_at":"2026-03-27T14:10:36.000Z","dependencies_parsed_at":"2025-06-26T20:34:07.692Z","dependency_job_id":"3d40dad1-ca1d-43f2-b9c4-e33cc9f886db","html_url":"https://github.com/floryn08/homelab-alm","commit_stats":null,"previous_names":["floryn08/homelab-alm"],"tags_count":62,"template":false,"template_full_name":null,"purl":"pkg:github/floryn08/homelab-alm","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/floryn08%2Fhomelab-alm","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/floryn08%2Fhomelab-alm/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/floryn08%2Fhomelab-alm/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/floryn08%2Fhomelab-alm/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/floryn08","download_url":"https://codeload.github.com/floryn08/homelab-alm/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/floryn08%2Fhomelab-alm/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":32303177,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-26T09:34:17.070Z","status":"ssl_error","status_checked_at":"2026-04-26T09:34:00.993Z","response_time":129,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["alm","k8s-operator","operator-sdk"],"created_at":"2025-12-12T06:09:06.139Z","updated_at":"2026-04-26T16:02:41.922Z","avatar_url":"https://github.com/floryn08.png","language":"Go","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Homelab ALM\n\nKubernetes operator that automates certificate and ingress creation by fetching domain configuration from Vault.\n\n## What It Does\n\nCreates **cert-manager Certificates** and **Traefik IngressRoutes** using domain names stored in HashiCorp Vault.\n\nInstead of hardcoding domains everywhere, you store them once in Vault and reference them by key.\n\n## Quick Start\n\n### Prerequisites\n\n- Kubernetes with cert-manager and Traefik v3\n- HashiCorp Vault with domain config at `kv/data/domains`\n- ClusterIssuer named `ca-issuer` (or specify your own)\n\n### Install\n\n```bash\nhelm install homelab-alm ./deployment/helm \\\n  --set image=ghcr.io/floryn08/homelab-alm:v1.4.0 \\\n  --namespace homelab-alm-system \\\n  --create-namespace\n```\n\n### Configure Vault\n\n```bash\nvault kv put kv/domains \\\n  prodDomain=example.com \\\n  stagingDomain=staging.example.com\n```\n\nSet environment variables for the operator:\n- `VAULT_ADDR=https://vault.example.com:8200`\n- `VAULT_TOKEN=your-token`\n\n## Usage\n\n### Create a Certificate\n\n```yaml\napiVersion: networking.alm.homelab/v1\nkind: CertificateRequest\nmetadata:\n  name: myapp-cert\nspec:\n  domainKey: prodDomain      # Looks up in Vault\n  subdomain: myapp           # Creates myapp.example.com\n  secretName: myapp-tls\n  issuerName: ca-issuer      # Optional, defaults to ca-issuer\n  issuerKind: ClusterIssuer  # Optional, defaults to ClusterIssuer\n```\n\n### Create an Ingress\n\n```yaml\napiVersion: networking.alm.homelab/v1\nkind: IngressRequest\nmetadata:\n  name: myapp-ingress\nspec:\n  domainKey: prodDomain\n  subdomain: myapp\n  serviceName: myapp-service\n  servicePort: \"80\"\n  entrypoints: [websecure]\n  tls:\n    secretName: myapp-tls\n```\n\n## CRD Reference\n\n### CertificateRequest\n\n| Field | Required | Description |\n|-------|----------|-------------|\n| `domainKey` | Yes | Key to lookup in Vault |\n| `subdomain` | No | Subdomain to prepend to domain |\n| `secretName` | Yes | K8s secret name for certificate |\n| `vaultPath` | No | Vault path (default: `kv/data/domains`) |\n| `issuerName` | No | cert-manager issuer (default: `ca-issuer`) |\n| `issuerKind` | No | `Issuer` or `ClusterIssuer` (default: `ClusterIssuer`) |\n\n### IngressRequest\n\n| Field | Required | Description |\n|-------|----------|-------------|\n| `domainKey` | Yes | Key to lookup in Vault |\n| `subdomain` | Yes | Subdomain to prepend to domain |\n| `serviceName` | Yes | Target Kubernetes service |\n| `servicePort` | Yes | Target service port |\n| `vaultPath` | No | Vault path (default: `kv/data/domains`) |\n| `entrypoints` | No | Traefik entrypoints (default: `[web]`) |\n| `tls.secretName` | No | TLS secret reference |\n| `tls.certResolver` | No | Traefik cert resolver |\n| `middlewares` | No | List of Traefik middlewares |\n\n## Development\n\n```bash\n# Generate manifests after changing CRDs\nmake manifests generate\n\n# Run tests\nmake test\n\n# Run locally (requires VAULT_ADDR and VAULT_TOKEN)\nmake run\n\n# Build and deploy\nmake docker-build docker-push IMG=your-registry/homelab-alm:tag\nmake deploy IMG=your-registry/homelab-alm:tag\n```\n\n## Troubleshooting\n\n**Operator not working?**\n```bash\nkubectl logs -n homelab-alm-system deployment/homelab-alm-controller-manager\n```\n\n**Domain not found?**\n```bash\nvault kv get kv/domains\n```\n\n**Certificate not issued?**\n```bash\nkubectl get certificate -A\nkubectl describe certificaterequest \u003cname\u003e\n```","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ffloryn08%2Fhomelab-alm","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Ffloryn08%2Fhomelab-alm","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ffloryn08%2Fhomelab-alm/lists"}