Dynamic Headers
This example shows how to leverage the extension system to dynamically manipulate headers per request.
ts
import { Graffle } from 'graffle'
const graffle = Graffle
.create()
.transport({
url: `http://localhost:3000/graphql`,
})
.anyware(({ pack }) => {
if (pack.input.transportType !== `http`) return pack()
return pack({
input: {
...pack.input,
headers: {
'X-Sent-At-Time': Date.now().toString(),
},
},
})
})
.anyware(({ exchange }) => {
// todo wrong type / runtime value
console.log(exchange.input.request)
return exchange()
})
await graffle.gql`{ pokemons { name } }`.send()
Outputs
txt
{
methodMode: 'post',
headers: Headers {
accept: 'application/graphql-response+json; charset=utf-8, application/json; charset=utf-8',
'content-type': 'application/json',
'x-sent-at-time': '1736741812397'
},
method: 'post',
url: 'http://localhost:3000/graphql',
body: '{"query":"{ pokemons { name } }"}'
}