-
Notifications
You must be signed in to change notification settings - Fork 42
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
Enable CORS for /api/v4/file/ endpoints #5649
Comments
Did you try this before when it was the |
I just tried it, and I get the same result on the |
The question is, did it work before ? The introduction of the v4 API is recent, and we're trying to determine if it used to work before that. Note that even though that does look like a bug, the signing API isn't really designed for being used in a browser. As you noted, following redirections is an issue when you have to pass authorization. |
As far as I can tell, it has the same behavior on the
It is perhaps an odd use case... my goal is to write a serverless app and provide additional functionality via an optional WebExtension. It is a password management app, so I wanted to give users the ability to easily build and sign their own version of the extension if they choose.
If CORS was enabled, I think if I disable following redirects using |
I (we) mean on Your use-case is a bit unusual but I agree it would work if |
Ah, sorry. That I don't know. :( Thanks for looking into this. |
I think nothingisdead/addons-server@bec7e68 should fix this. I didn't submit a pull request because I don't have an environment set up to test the change... let me know if you want me to. BTW this will enable CORS on all |
It might work as a hack but we apply CORS globally to all views, so if it's not working we need to understand why instead of hiding the problem. |
Ah, I think I see what's happening. It's not a new issue, and I don't think this patch would fix it. The problem is that view is relying on We'll see what we can do but it's unlikely to be fixed soon. |
Oh I see. That makes sense... thanks again. |
This issue has been automatically marked as stale because it has not had recent activity. If you think this bug should stay open, please comment on the issue with further details. Thank you for your contributions. |
Describe the problem and steps to reproduce it:
After signing an addon using the v4 API, it is impossible to download it in any environment restricted by CORS, even when sending a correct
Authorization
header.I followed the instructions on http://addons-server.readthedocs.io/en/latest/topics/api/signing.html, and was able to sign my addon. However, when using fetch to request the
download_url
, the request is blocked by CORS restrictions. It looks like the/api/v4/file/...
endpoints do not send the CORS header to allow API clients to download the file in CORS-enabled environments. To complicate matters, it doesn't seem like it's even possible to redirect the user to thedownload_url
for unlisted addons, since there is no way to provide theAuthorization
JWT header.What happened?
I got the following error:
What did you expect to happen?
I expected to get a response.
Anything else we should know?
The CORS preflight OPTIONS request indicates that Access-Control-Allow-Origin should be set to *, but the actual GET request doesn't send that header.
OPTIONS request headers:
data:image/s3,"s3://crabby-images/2c5ee/2c5eec14042ce982dd7fc3f4b664a9bd9d729c2c" alt="screenshot from 2018-06-18 00-24-04"
GET request headers:
data:image/s3,"s3://crabby-images/f627b/f627ba64662a0748251f6e29ec65abe2141f3065" alt="screenshot from 2018-06-18 00-05-30"
The text was updated successfully, but these errors were encountered: