Source code
Revision control
Copy as Markdown
Other Tools
import importlib
header_helpers = importlib.import_module("storage-access-api.resources.header-helpers")
# Sets the `Activate-Storage-Access` response header to a `retry` value
# corresponding to the supplied `allowed_origin`.
def maybe_set_retry(allowed_origin, response):
if allowed_origin is None:
return
if allowed_origin == b'*':
retry_response = b'retry; allowed-origin=*'
elif allowed_origin == b'':
retry_response = b'retry'
else:
retry_response = b'retry; allowed-origin=\"' + allowed_origin + b'\"'
response.headers.set(b'Activate-Storage-Access', retry_response)
def main(request, response):
request_params = request.GET
if b'key' in request_params:
key = request_params.first(b'key')
# Do not handle requests without a key parameter.
else:
return (400, [], b'')
allowed_origin = request_params.first(b'retry-allowed-origin', None)
storage_access_status = request.headers.get(b'sec-fetch-storage-access')
# If a request has been successfully retried and set to active, store its
# headers under a modified key so they can be retrieved independently of
# the initial request's headers.
if storage_access_status == b'active':
key += b'active'
maybe_set_retry(allowed_origin, response)
# Check if the request should redirect.
header_helpers.maybe_set_redirect(request_params, response, storage_access_status)
request.server.stash.put(header_helpers.make_stash_key(key, request_params),
header_helpers.get_stashable_headers(request.headers),
header_helpers.RETRIEVAL_PATH)
return header_helpers.make_response_body(request_params)