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

UsageIdentifierKeys added into AuthResponse for use in Built-In Authorizers #2129

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 7 additions & 2 deletions chalice/app.py
Original file line number Diff line number Diff line change
@@ -1436,7 +1436,8 @@ class AuthResponse(object):
'PATCH', 'POST', 'PUT', 'GET']

def __init__(self, routes: List[Union[str, 'AuthRoute']],
principal_id: str, context: Optional[Dict[str, str]] = None):
principal_id: str, context: Optional[Dict[str, str]] = None,
usage_identifier_key: Optional[str] = None):
self.routes: List[Union[str, 'AuthRoute']] = routes
self.principal_id: str = principal_id
# The request is used to generate full qualified ARNs
@@ -1445,13 +1446,17 @@ def __init__(self, routes: List[Union[str, 'AuthRoute']],
if context is None:
context = {}
self.context: Dict[str, str] = context
self.usage_identifier_key: Optional[str] = usage_identifier_key

def to_dict(self, request: AuthRequest) -> Dict[str, Any]:
return {
response = {
'context': self.context,
'principalId': self.principal_id,
'policyDocument': self._generate_policy(request),
}
if self.usage_identifier_key:
response['usageIdentifierKey'] = self.usage_identifier_key
return response

def _generate_policy(self, request: AuthRequest) -> Dict[str, Any]:
allowed_resources = self._generate_allowed_resources(request)
5 changes: 5 additions & 0 deletions docs/source/api.rst
Original file line number Diff line number Diff line change
@@ -812,6 +812,11 @@ These classes are used when defining built-in authorizers in Chalice.
will be accessible in the ``app.current_request.context``
in all subsequent authorized requests for this user.

.. attribute:: usage_identifier_key

An optional string value that represents a usage plan's api
key if the ``apiKeySource`` for that plan is set to ``AUTHORIZER``.

.. class:: AuthRoute(path, methods)

This class be used in the ``routes`` attribute of a
33 changes: 33 additions & 0 deletions tests/unit/test_app.py
Original file line number Diff line number Diff line change
@@ -1507,6 +1507,39 @@ def test_root_resource(auth_request):
}


def test_auth_response_with_usage_identifier_key(auth_request):
event = {
'type': 'TOKEN',
'authorizationToken': 'authtoken',
'methodArn': 'arn:aws:execute-api:us-west-2:1:id/dev/GET/a',
}
auth_app = app.Chalice('builtin-auth')

response = {
'context': {},
'principalId': 'principal',
'policyDocument': {
'Version': '2012-10-17',
'Statement': [
{'Action': 'execute-api:Invoke',
'Effect': 'Allow',
'Resource': [
'arn:aws:execute-api:us-west-2:1:id/dev/*/a'
]}
]
},
'usageIdentifierKey': 'api-key'
}

@auth_app.authorizer()
def builtin_auth(auth_request):
return app.AuthResponse(['/a'], 'principal',
usage_identifier_key='api-key')

actual = builtin_auth(event, None)
assert actual == response


def test_can_register_scheduled_event_with_str(sample_app):
@sample_app.schedule('rate(1 minute)')
def foo(event):