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

Cache preflight responses (Access-Control-Max-Age) #261

Closed
ThomasOrlita opened this issue Jun 13, 2021 · 5 comments
Closed

Cache preflight responses (Access-Control-Max-Age) #261

ThomasOrlita opened this issue Jun 13, 2021 · 5 comments

Comments

@ThomasOrlita
Copy link

ThomasOrlita commented Jun 13, 2021

🐣 Is your feature request related to a problem? Please describe.

Every time a CORS request to Ackee is sent, it is preceded by a preflight OPTIONS request which allows the website to send the request. However, since no Access-Control-Max-Age header is sent, the preflight request is sent every time.

💡 Describe the solution you'd like

Send Access-Control-Max-Age alongside the Access-Control-Allow-{Origin,Methods,Headers,Credentials} headers. This means the OPTIONS header will have to be sent only once per site and then the browser won't send the preflight request again until the cache expires.

@electerious
Copy link
Owner

I've implemented it, but reverted it for now. I'm not sure how the caching works when allowing multiple origins. Both Ackee and the recommended nginx config are dynamically changing the origin based on the request. Caching the origin would be problematic in that case.

@mathe42
Copy link

mathe42 commented Jul 26, 2021

I looked at the spec:

Access-Control-Max-Age
Indicates the number of seconds (5 by default) the information provided by the Access-Control-Allow-Methods and Access-Control-Allow-Headers headers can be cached.

So Origin is not cached.

For spec see https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Access-Control-Max-Age

Note that

Firefox caps this at 24 hours (86400 seconds).
Chromium (prior to v76) caps at 10 minutes (600 seconds).
Chromium (starting in v76) caps at 2 hours (7200 seconds).

(see https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Access-Control-Max-Age#directives)

[EDIT]

https://runebook.dev/en/docs/http/headers/access-control-max-age

States that

The Access-Control-Max-Age response header indicates how long the results of a preflight request (that is the information contained in the Access-Control-Allow-Methods and Access-Control-Allow-Headers headers) can be cached.

@mathe42
Copy link

mathe42 commented Jul 26, 2021

As I understand the result of the preflight request is cached. So the browser has for each origin a list of cached preflight requests so the cached data don't need to contain information about the allow-origin header as only successfull preflights are cached.

@ThomasOrlita
Copy link
Author

I've been sending the preflight cache header from 2b170a4 for half a year now and it works without any issues.

@electerious
Copy link
Owner

@ThomasOrlita Thanks for letting me know. I've merged the branch. It will be a part of the next release :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants