-
Notifications
You must be signed in to change notification settings - Fork 365
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
Azure Storage Blob SDK Uploads Only 250MB #1208
Comments
Hello @brt5586, thanks for contributing to the Password Pusher community! We will respond as soon as possible. |
Hi @brt5586 - thanks this is useful info. I'm traveling for the next couple weeks but I'll take a closer look and see if I can make the improvement once I get back. |
Hi @brt5586 I previously didn't have this documented well but could you confirm that you put in the proper CORS configuration for the Azure storage? One of the CORS configurations is to allow the Updated CORS documentation for Azure is here: https://github.com/pglombardo/PasswordPusher/blob/master/Configuration.md#azure-storage-cors-configuration |
I'm having the same problem, being limited to uploading max 256MB files to Azure Blob Storage due to the old API version being used. According to this thread: It should be possible to pass the following setting to force a newer version: I believe 2024-05-04 is the current version recommended to be used: Is that anything you can use from PWP? |
Hi @msundman78 - that's helpful thanks. I dug in a little bit and Azure support doesn't seem to be in great shape. I'll document here for the record. Password Pusher uses ActiveStorage to upload/store/retrieve files. This is the section on how to configure Azure storage. It references the azure-storage-blob Ruby gem which hasn't been updated since 2021. :-( When I go to the source code for that gem, it's been deprecated by Microsoft with no clear alternative. This is the discussion in the Rails community: rails/rails#49983 @msundman78 you might be able to manually set that value. You could create a file require "azure-storage-ruby"
Azure::Storage::Blob::Default::STG_VERSION = "2024-05-04" |
Thanks @pglombardo. After some more digging I found that ActiveStorage is using SAS tokens for DirectUpload, which does not use the x-ms-version header for selecting the API version. Instead the API version is selected when generating the SAS URL in the SignedVersion (sv) parameter, or the optional api-version parameter [1]. The SignedVersion parameter is also defined in the STG_VERSION constant but in the Common module instead of the Blob module. I also found that in API version 2020-12-06 and higher the Signature format was changed slightly making them incompatible with the current azure-storage-blob implementation [2]. However, all API versions since 2019-12-12 support 5 GB single PUT uploads [3]. Below code in
[1] https://learn.microsoft.com/en-us/rest/api/storageservices/versioning-for-the-azure-storage-services#authorize-requests-by-using-a-shared-access-signature |
@msundman78 - that is an excellent investigation and solution! You should also post this in rails/rails#49983 for others in the Rails community that are facing this. For anyone else reading this thread and using Azure as a backend, could you confirm that the fix above works for you? If so, I'll roll this initializer into the main code base. Thanks @msundman78! |
@pglombardo, I also wonder how ActiveStorage decision to drop support for azure-storage-blob will affect Azure Blob support in pwpush? If I understand this blogg right, it should be able to switch to Active Storage adapter to use the new azure-blob gem instead: |
No... this issue just got lost in the noise and I haven't been back with all the other things happening. That is a great find. I'll be upgrading the app to Rails 8 soon - when I do I'll switch over to that new azure-blob gem. |
Issue when uploading to a storage blob, 250MB is the hard limit - this is easy to reproduce - currently got NGINX as the frontend proxy, postgres as docker container and same with pwpusher on Ubuntu 22.04 on Azure VM.
The issue:
When uploading to storage blob, you will notice in console '413' error response indicating the file size is too large. Looking further into this and it's to do with the SAS service version: (outlined here: https://learn.microsoft.com/en-us/rest/api/storageservices/put-blob?tabs=azure-ad#remarks)
https://REDACTED.blob.core.windows.net/REDACTED/randomfile?sp=rw&sv=2018-11-09&se=2023-06-28T10%3A00%3A50Z&sr=REDACTED
As seen above it's requested the 2018-11-09 service version which is 250MB limit, since then it's now been upped 5GB with newer service versions.
I'm using the latest version of pwpusher, please can you change this?
The text was updated successfully, but these errors were encountered: