Header Injection Policy
Policy name |
Header Injection |
Summary |
Adds headers to a request or response. |
Category |
Transformation |
First Flex Gateway version available |
v1.0.0 |
Returned Status Codes |
500 - The configuration includes an expression that was not evaluated. |
Summary
The Header Injection policy adds HTTP headers to the request or response of a message. When you configure this policy for your API, you must specify an inbound and outbound map of the headers that you want to add in the message processing in the form of a key-value pair.
You can optionally include DataWeave expressions in the value or name of the header. For example, all headers matching the following configured expression are injected to the message:
“#[attributes.requestPath]”
If the injected header already exists in the message attributes, the policy creates a new header without overriding the value of the existing one.
Only certain headers are restricted to support multiple values, and they will be overwritten using configured values. These headers are: To overwrite any other existing message header, remove it before adding your header. See the Header Removal policy. |
Configuring Policy Parameters
Flex Gateway Local Mode
In Local Mode, you apply the Header Injection policy to your API via declarative configuration files. Refer to the following policy definition and table of parameters:
- policyRef: name: header-injection-flex config: inboundHeaders: <array> // OPTIONAL, default: [] - key: <string> // REQUIRED value: <string> // REQUIRED outboundHeaders: <array> // OPTIONAL, default: [] - key: <string> // REQUIRED value: <string> // REQUIRED
Parameter | Required or Optional | Default Value | Description |
---|---|---|---|
|
Optional |
Empty array |
List of headers to be injected at the beginning of the message processing. |
|
Required |
N/A |
A string or DataWeave expression for header name |
|
Required |
N/A |
A string or DataWeave expression for header value |
|
Optional |
Empty array |
List of header to be injected at the end of the message processing. |
|
Required |
N/A |
A string or DataWeave expression for header name |
|
Required |
N/A |
A string or DataWeave expression for header value |
|
Resource Configuration Example
In the following example, all the headers matching the configured #[attributes.requestPath]
expression are injected into the message.
- policyRef: name: header-injection-flex config: inboundHeaders: - key: "new-inbound-header" value: "#[attributes.requestPath]" outboundHeaders: - key: "new-outbound-header" value: "#[attributes.requestPath]"
Flex Gateway Connected Mode
When you apply the policy to your API from the UI, the following parameters are displayed:
Parameter | Description |
---|---|
Inbound Header Map |
List of headers to be injected at the beginning of the message processing. |
Inbound Header Key |
String or Dataweave expression to be used as header name at the beginning of the message. |
Inbound Header Value |
String or Dataweave expression to be used as header value at the beginning of the message. |
Outbound Header Map |
List of headers to be injected at the end of the message processing. |
Outbound Header Key |
String or Dataweave expression to be used as header name at the end of the message processing. |
Outbound Header Value |
String or Dataweave expression to be used as header value at the end of the message processing. |
Method & Resource conditions |
The option to add configurations to only a select few or all methods and resources of the API |
Header keys should be compliance with HTTP 1.1 standard. |