Use extractors for headers
Use Gloo Gateway extractors to retrieve request header values, transform them, and add them back as headers to the request.
In this guide, you use an extractor to retrieve the account ID from an account
request header by using a regular expression. The extractor is then used to build a custom value for the x-account-solo
header. You return the transformed header as a request header.
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.
Use extractors for headers
Create a RouteOption or VirtualHostOption resource that defines the following transformation rules:
- Use a regular expression to capture the value of the
account
request header and store that value in theaccount_id
extractor. - Use the
account_id
extractor to build a custom string and add this string to thex-account-solo
request header.
- Use a regular expression to capture the value of the
Send a request to the httpbin app with the
account: abc123
header. Verify that you see the transformed account value in thex-account-solo
request header.Example output:
< HTTP/1.1 200 OK HTTP/1.1 200 OK < access-control-allow-credentials: true ... < { "headers": { "Accept": [ "*/*" ], "Account": [ "abc123" ], "Host": [ "www.example.com:8080" ], "X-Account-Solo": [ "account: abc123-solo" ], "User-Agent": [ "curl/8.7.1" ], "X-Envoy-Expected-Rq-Timeout-Ms": [ "15000" ], "X-Forwarded-Proto": [ "http" ], "X-Request-Id": [ "7f2340db-c971-4449-b6cf-3bd8dd377f02" ] } }
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