HAPTIC¶
HAPTIC (HAProxy Template Ingress Controller) is a template-driven HAProxy Ingress Controller for Kubernetes that generates HAProxy configurations using Scriggo templates and deploys them via the HAProxy Dataplane API.
flowchart LR
K["Kubernetes Resources"] --> T["Template Engine"]
T --> H["HAProxy Pods"]
Community Project
This is an independent community project and is not affiliated with or endorsed by HAProxy Technologies.
What is HAPTIC?¶
HAPTIC is an event-driven Kubernetes controller that:
- Watches any Kubernetes resource - Ingresses, Services, Secrets, Gateway API resources, or any custom resource type you configure
- Renders Scriggo templates - A fast, Go-native template engine
- Validates before deployment - Deploy with confidence knowing configurations are validated before they reach your load balancers
- Deploys configurations to HAProxy pods via the Dataplane API
Unlike traditional ingress controllers with hardcoded configuration logic, HAPTIC uses a template-driven approach that gives you full control over the generated HAProxy configuration. This means you can:
- Define custom annotations that your platform users can use, implemented with just a few lines of template code
- Support new standards like Gateway API without waiting for controller updates
- Watch domain-specific CRDs and generate HAProxy configuration from any Kubernetes resource type
Key Features¶
Template-Driven Flexibility¶
Traditional ingress controllers embed configuration logic in code. HAPTIC inverts this:
- Full HAProxy access - Write any HAProxy directive using the configuration language
- Add features without code changes - New directives are template updates, not controller releases
- Iterate rapidly - Deploy configuration changes in minutes, not release cycles
- Rich template context - Access any Kubernetes resource, fetch external data via HTTP, and use controller state in your templates
- Everything is templatable - Generate not just
haproxy.cfgbut also map files, SSL certificates, CRT-lists, and custom auxiliary files
Production Ready¶
- High availability - Leader election with automatic failover
- Comprehensive validation - Validating webhook, template validation, and CI/CD-runnable tests
- Observability - Prometheus metrics, structured logging, and debug endpoints
- HTTP resource access - Fetch external data for use in templates
Ready to use out of the box
The Helm chart ships with Template Libraries enabled by default. They cover Kubernetes Ingress and Gateway API resources with annotation support comparable to existing HAProxy ingress controllers — no template authoring required. Customizing or extending the templates is entirely optional.
Architecture¶
The controller follows an event-driven architecture where changes to Kubernetes resources trigger a pipeline that renders templates, validates the output, and syncs configurations to HAProxy pods.
flowchart TB
subgraph API["Kubernetes API"]
R["Any Resource<br/>(Ingress, Gateway, CRDs, ...)"]
end
subgraph Controller["Controller Pod"]
W["Watcher"]
T["Template Engine"]
V["Validator"]
end
subgraph HAProxy["HAProxy Pod"]
D["Dataplane API"]
H["HAProxy"]
end
R --> W
W --> T
T --> V
V --> D
D --> H
Key components:
- Watcher - Subscribes to Kubernetes API for configured resource types
- Template Engine - Renders Scriggo templates with resource data as context
- Validator - Validates generated HAProxy configuration before deployment
- Dataplane Syncer - Applies configuration changes to HAProxy pods via the Dataplane API
Quick Start¶
For a complete walkthrough, see the Getting Started guide which covers deploying HAProxy pods, installing the controller, and verifying your setup.
Install with Helm¶
helm install my-controller oci://registry.gitlab.com/haproxy-haptic/haptic/charts/haptic --version 0.1.0
The Helm chart includes template libraries that support Kubernetes Ingress resources out of the box. See the Helm Chart Documentation for configuration options.
Verify Installation¶
Check the current rendered HAProxy configuration and deployment status:
Note
haproxycfg is the short name for HAProxyCfg — a read-only resource the controller creates to expose the currently deployed configuration. To view or edit the template configuration, use htplcfg (short for HAProxyTemplateConfig). See the CRD Reference for all available fields.
Create an Ingress¶
With the default template libraries enabled, you can create an Ingress resource:
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: example
spec:
ingressClassName: haproxy
rules:
- host: example.com
http:
paths:
- path: /
pathType: Prefix
backend:
service:
name: example-service
port:
number: 80
Extend with Custom Annotations¶
One of the key strengths of HAPTIC is how easily you can add custom behavior. Suppose your platform users need to inject an X-Request-ID header for distributed tracing. With HAPTIC, add a template snippet to your Helm values:
controller:
config:
templateSnippets:
frontend-filters-request-id:
template: |
{%- for _, ingress := range resources.ingresses.List() %}
{%- var header = fallback(ingress.metadata.annotations["example.com/request-id-header"], "") %}
{%- if header != "" %}
http-request set-header {{ header }} %[uuid()]
{%- end %}
{%- end %}
Users then enable it by adding example.com/request-id-header: "X-Request-ID" as an Ingress annotation. This pattern works for any HAProxy feature — rate limiting, health checks, header manipulation, or anything else HAProxy supports.
The template system is fully hackable: override any snippet, replace the main template entirely, or disable all libraries and start from scratch. See the Templating Guide for how snippets, extension points, and the full template context work.
Check the Result¶
View the generated HAProxy configuration:
Viewing YAML Output
Using kubectl get haproxycfg -o yaml doesn't display multiline configuration content well - literal \n characters appear instead of line breaks. Use kubectl describe for readable output.
Where to Go Next¶
- Essential: Getting Started → Templating → CRD Reference
- Custom resources beyond Ingress: Watching Resources
- Template tests for CI/CD: Validation Tests
- Reference: Supported Configuration, Troubleshooting
- Helm chart configuration: Helm Chart Documentation