Problem
The Graphql endpoint for the API is accessible only to authorised users. Although it is required from a security perspective, it makes testing the API through Insomnia a little tedious. What if we could automatically insert the bearer token every time we made a request using Insomnia?
Solution
Let’s start by creating a new environment. Although not entirely necessary, it makes authenticating on different environments easy. Note: You can give the environment better names such as Dev, Staging, Production etc
data:image/s3,"s3://crabby-images/16843/16843f5d62881a309fc26c080de242e744c508c1" alt="Creating a new environment Creating a new environment"
Now, let’s add some environment variables specific to that environment
- baseUrl : The base URL for all the endpoints
- email: The email used to login
- password: The password used to login
data:image/s3,"s3://crabby-images/3bba1/3bba1d2fb12fd2c262cbf3c5d151e606c293113d" alt="Adding environment variables Adding environment variables"
Let’s make insomnia use the environment.
data:image/s3,"s3://crabby-images/6cd98/6cd986a044625e9b3b54fd792586f0c3e7650ffd" alt="Use the environment Use the environment"
Assuming that the endpoint to get the access token is LoginUser
add a new post request called GetAccessToken
.
Remember the environment variables from earlier. We can use them so that no matter what environment we are on, everything will just work.
data:image/s3,"s3://crabby-images/ff117/ff1175ba39d734f595cbffc45d127c7b43541388" alt="Get token Get token"
Let’s add a new Graphql query and try to send the request. We get a 401 Unauthorized error because we haven’t passed in the bearer token.
data:image/s3,"s3://crabby-images/54609/54609415813678c661f116e79545fb8e857d8a81" alt="Graphql request without bearer token Graphql request without bearer token"
To set the bearer token, we can click on the Bearer tab and enter Response ⇒ Body Attribute for the token.
data:image/s3,"s3://crabby-images/10b21/10b2188b7cbb7cd210d57fae90f95c4f11470c8f" alt="Set the bearer token Set the bearer token"
To edit the tag, click on it.
data:image/s3,"s3://crabby-images/2dc21/2dc210414368cef73cd61ef9f6f734b79d514946" alt="Edit the tag Edit the tag"
In the Edit Tag screen select Post GetAccessToken for the request
data:image/s3,"s3://crabby-images/57a23/57a2339131879826d3f5fb811165205982b0a6ab" alt="Set the request on the tag screen Set the request on the tag screen"
Set the trigger behaviour to Always so that the request is made every time and you get a new token
data:image/s3,"s3://crabby-images/b95ed/b95ed139d5bdd407812d4f8954420918b40a8627" alt="Set the trigger behavior Set the trigger behavior"
For the filter, enter $.accessToken.value
. The value will be dependent on the response that you get from GetAccessToken. If you have set it up correctly, you should see a token in the Live Preview.
data:image/s3,"s3://crabby-images/8cae2/8cae25afb4462434fc0f5a6dc936ac7da56820a3" alt="Set the filter Set the filter"
Now, if you try to resend the request, you should get back a 200 OK response.
data:image/s3,"s3://crabby-images/f4a1c/f4a1cc8b9aa439058a8fb4fa5051fee5c44e3246" alt="Send a successful request Send a successful request"
Conclusion
By automatically generating access tokens every time we make a Graphql request, we can easily test our API using Insomnia
Top comments (0)