Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Cannot change path of httpApi event on lambda #33

Open
HancoVisagie opened this issue Jan 22, 2023 · 1 comment
Open

Cannot change path of httpApi event on lambda #33

HancoVisagie opened this issue Jan 22, 2023 · 1 comment
Labels
help wanted Extra attention is needed

Comments

@HancoVisagie
Copy link

Take this for example

  World:
    name: ${self:service}-${self:provider.stage}-WorldFunction
    handler: ${self:custom.handler.prefix}.UserHandler::World
    events:
      - httpApi:
          method: GET
          path: /world

deploy this, works fine, then do this:

  World:
    name: ${self:service}-${self:provider.stage}-WorldFunction
    handler: ${self:custom.handler.prefix}.UserHandler::World
    events:
      - httpApi:
          method: GET
          path: /world2

and I get the following error:
Unable to find Route by key GET /world within the provided RouteSettings

Disable the extension and deployment succeeds.

@DianaIonita
Copy link
Owner

Hi @HancoVisagie,

Thank you for reporting the issue.

I think this is happening because endpoints and route throttling settings are distinct entities in API Gateway. It means that, when an endpoint path is removed or renamed, the route settings remain behind.

After you renamed your httpApi path, the throttling route defined for your old /world path stayed. When the plugin called API Gateway's updateStage to add the new /world2 route with its throttling settings, it failed because API Gateway expected it to include /world throttling settings.

Currently, you can fix the issue by manually removing your /world route settings. The plugin will then be able to create throttling settings for the new /world2 route:

image

As for a long term solution, I'm not sure yet. One way, I suppose, would be to make this plugin clean up routes before it tries defining throttling settings. I don't support this solution, because it wouldn't really know what it was cleaning up.

What are your thoughts?

@DianaIonita DianaIonita added the help wanted Extra attention is needed label Feb 3, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

2 participants