Setting Headers
This method is not relevant to all handlers!
Please make sure the handler you are using supports this method: You can do it by checking if handler’s config reference (appearing on it’s designated doc) includes the header fields mentioned in this doc.
Using (very) long headers?
Under the hood, Mesh is using uWebSockets to serve the GraphQL API. uWebSockets has a length
limit, and responds with 431 code if the header is too long. In case you are using long headers, you
may need to set UWS_HTTP_MAX_HEADERS_SIZE environment variable with a higher value. For example,
you can set it to 16384 (16KB).
Setting configurations
There are two headers-designated configuration fields under each handler - schemaHeaders and
operationHeaders:
operationHeaders
Optional field. Used to set the Headers for operation execution. Expects JSON object representing the Headers.
In this example operationHeaders is used to defined the content of the request as Json:
sources:
  - name: Example
    handler:
      <handler-name>:
        operationHeaders:
          Content-Type: application/jsonschemaHeaders
Optional field. Used to set the Headers for schema introspection. Expects JSON object representing the Headers.
Dynamic Header Values (e.g., for Authorization)
Mesh can take dynamic values from the GraphQL Context or the environmental variables. For example,
if you use mesh dev or mesh start, GraphQL Context will be the incoming HTTP request.
The expression inside dynamic values should be as in JS.
From Context (HTTP Header for mesh dev or mesh start)
sources:
  - name: Example
    handler:
      <handler-name>:
        operationHeaders:
          # Please do not use capital letters while getting the headers
          # Use "{context.headers['x-my-api-token']}" if you want just the value of the header
          Authorization: Bearer {context.headers['x-my-api-token']}
          # You can also access to the cookies like below;
          # Authorization: Bearer {context.cookies.myApiToken}From Environment Variables
Set up the variable on your environment, e.g VERY_SECRET_TOKEN=12345. Then you can use it using
{env.VERY_SECRET_TOKEN}.
The config wil look something like:
sources:
  - name: Example
    handler:
      <handler-name>:
        operationHeaders:
          Authorization: Bearer {env.VERY_SECRET_TOKEN}