Add multiple values to headers
Use the headersToAppend capability to add multiple values to the same header.
In this guide, you explore how to use the headersToAppend transformation template attribute to add multiple values to the same header. The values are separated with a comma.
This guide uses a subset of the supported transformation template attributes. To review all the attributes that you can set, see Templating language.
Before you begin
Follow the Get started guide to install Gloo Gateway, set up a gateway resource, and deploy the httpbin sample app.
Get the external address of the gateway and save it in an environment variable.
export INGRESS_GW_ADDRESS=$(kubectl get svc -n gloo-system gloo-proxy-http -o jsonpath="{.status.loadBalancer.ingress[0]['hostname','ip']}") echo $INGRESS_GW_ADDRESSkubectl port-forward deployment/gloo-proxy-http -n gloo-system 8080:8080
Add multiple values to headers
Create a RouteOption or VirtualHostOption resource with the following transformation rules:
- Extract the value of the
Hostrequest header and use this value to build thecustomcookie2string. Then, append the transformed string to theSet-Cookierequest header. - Extract the value of the
Hostrequest header and use this value to build thecustomcookie3string. Then, append the transformed string to the sameSet-Cookierequest header.kubectl apply -f- <<EOF apiVersion: gateway.solo.io/v1 kind: RouteOption metadata: name: transformation namespace: httpbin spec: targetRefs: - group: gateway.networking.k8s.io kind: HTTPRoute name: httpbin options: transformations: requestTransformation: transformationTemplate: headersToAppend: - key: Set-Cookie value: text: 'customcookie2={{ request_header("Host") }}' - key: Set-Cookie value: text: 'customcookie3={{ request_header("Host") }}' EOFkubectl apply -n gloo-system -f- <<EOF apiVersion: gateway.solo.io/v1 kind: VirtualHostOption metadata: name: transformation namespace: gloo-system spec: options: transformations: requestTransformation: transformationTemplate: headersToAppend: - key: Set-Cookie value: text: 'customcookie2={{ request_header("Host") }}' - key: Set-Cookie value: text: 'customcookie3={{ request_header("Host") }}' targetRefs: - group: gateway.networking.k8s.io kind: Gateway name: http namespace: gloo-system EOF
- Extract the value of the
Send a request to the httpbin app. Verify that you see multiple values in the
Set-Cookierequest header.curl -vik -H "host: www.example.com:8080" \ -H "Content-Type: application/json" \ http://$INGRESS_GW_ADDRESS:8080/headerscurl -vik localhost:8080/headers \ -H "host: www.example.com" \ -H "Content-Type: application/json"Example output:
{ "headers": { "Accept": [ "*/*" ], "Host": [ "www.example.com:8080" ], "Set-Cookie": [ "customcookie2=www.example.com:8080", "customcookie3=www.example.com:8080" ], "User-Agent": [ "curl/8.7.1" ], "X-Envoy-Expected-Rq-Timeout-Ms": [ "15000" ], "X-Forwarded-Proto": [ "http" ], "X-Request-Id": [ "09fbe5ed-5060-4cf5-835c-46729bf100db" ] } }
Cleanup
You can remove the resources that you created in this guide.
kubectl delete virtualhostoption transformation -n gloo-system
kubectl delete routeoption transformation -n httpbin