Search code examples
amazon-web-servicesaws-api-gatewayamazon-cognitolambda-authorizer

Cognito user pool does not show up API Gateway after setting authorizer


I have created a Cognito user pool authorizer for an API Gateway service that invokes a lambda function. The Authorizer is getting completely ignored and I am able to invoke the service without any token. I have deployed the service multiple times. I have created multiple gateway APIs and still see the same issue.

On comparing with an older API where I have the Authorizer working the only difference I could see is that that when I check the Resource tab in the API. The old service method (POST) shows Authorization: COGNITO_USER_POOL and all the new APIs show Authorization: None. Is something broken with the API Gateway or am I missing a step.


Solution

  • To fix this, you should do the following steps:

    1. Head to the AWS API Gateway Console.
    2. Select the REST API that is in question.
    3. Click on the "Method Request" tab.
    4. Select the drop-down menu beside the "AUTHORIZATION" tab.
    5. Select your Cognito User Pool Authorizer, which you had defined by a unique name. If you do not remember the name of the Cognito User Pool Authorizer, you can look it up in the API Gateway Authorizers section.
    6. Select the Authorizer, save the change, and re-deploy the API.
    7. Test the REST API out from POSTMAN(or any REST Client), or the browser.
    8. If you do not provide the JWT Token from Cognito, you would get an HTTP 401 Unauthorized Error.

    And yes, you are indeed right. You are facing the problem of the Authorizer not functioning because the Authorizer is not linked to the REST API. To link it, you would need to do it manually from the Method Request Tab. Another point to note is that Authorizers can be re-used between multiple REST APIs in API Gateway.