-
Notifications
You must be signed in to change notification settings - Fork 3.9k
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
feat: http api - iam authorizer #14853
Conversation
Last outstanding authorizer for http apis. resolves #10534
cc @nija-at How should I go forward with the testing bit? The build fails right now because of the linting done on all package.json files |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See my comment below.
@@ -192,3 +193,25 @@ api.addRoutes({ | |||
authorizer, | |||
}); | |||
``` | |||
|
|||
## IAM Authorizers |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi @iRoachie -
This does not feel like the right approach to solving IAM authorizers. Just having an HttpIamAuthorizer
class to set the AuthorizationType
and then leaving it up to the user to correctly configure the IAM policy feels sub-optimal.
I would suggest going with an alternate approach. Here's my proposal written in the form of what the user experience will be -
const api = new HttpApi(stack, 'HttpApi');
const routes: Route[] = api.addRoutes({ ... });
routes[0].grantInvoke(principal, { // principal is of type iam.IPrincipal
httpMethod: 'GET'
});
This should, under the hood, automatically set the AuthorizationType
to AWS_IAM
and attach the relevant IAM permissions to the principal.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I was going based on usage and what was requested in #10534.
As far as I understand the use case for IAM Authorization is to set policies on individual users to grant access to all/some routes.
I see where you are going with your suggestion however I think this can be an add-on to what is currently in this PR. If we only change the authorizationType when grantInvoke is called on a route then we automatically rule out scenarios where user permissions are managed outside of cdk/cloudformation (which is pretty common for physical users).
So just to be clear they're two things here:
- Setting route to use IAM Authorization
- Allowing an easy way to assign the relevant policies to a user/principal so that it can invoke that route.
924c117
to
ebfd5f2
Compare
AWS CodeBuild CI Report
Powered by github-codebuild-logs, available on the AWS Serverless Application Repository |
Hey all. What's needed to move this PR forward? |
@misterjoshua i’m a bit unsure how to go through with integration tests. I added an example which generates an AWS signature to attach to the request to simulate a real environment. this fails the lint because of the additional package.json file. |
@iRoachie I have taken a crack at fixing the integration tests. My branch is here: https://github.com/misterjoshua/aws-cdk/tree/ft/http-api-iam-authorizer Some notes:
Let me know your thoughts. |
Fixes #15123 See also: [@nija-at's comments on `grantInvoke`](#14853 (comment)), #10534 ---- *By submitting this pull request, I confirm that my contribution is made under the terms of the Apache-2.0 license*
@misterjoshua Awesome job. Apologize I didn't have the time. |
No worries. Thanks for getting the boulder rolling! |
Fixes aws#15123 See also: [@nija-at's comments on `grantInvoke`](aws#14853 (comment)), aws#10534 ---- *By submitting this pull request, I confirm that my contribution is made under the terms of the Apache-2.0 license*
Last outstanding authorizer for http apis.
resolves #10534
Not totally sure if we should include the bit inside
integ.iam.signature
but I added it as a way to test the integ stack.By submitting this pull request, I confirm that my contribution is made under the terms of the Apache-2.0 license