-
-
Notifications
You must be signed in to change notification settings - Fork 867
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] Broken listdir #1431
Comments
Not sure if this is 100% caused by this issue, but looks like that. I am doing python manage.py collectstatic --noinput --verbosity 2 and after 1.14.4 it started failing. From logs I see that prior to 1.14.4 almost all files are like this:
But int 1.14.4 they are:
So I assume the issue is indeed with listing the direction. The main issue is that for me it results in
My storage is class CustomS3Boto3Storage(S3Boto3Storage):
display_location: str
def url(self, name: str) -> str:
return f"{self.display_location}/{name}"
class StaticStorage(ManifestFilesMixin, CustomS3Boto3Storage):
bucket_name: str = settings.AWS_STORAGE_BUCKET_NAME
location: str = f"{settings.AWS_LOCATION}/static"
display_location: str = (
f"{settings.STATIC_CDN_CUSTOM_DOMAIN}/{settings.DO_SPACES_BUCKET_NAME}/{settings.DO_SPACES_ENV_PREFIX}/static"
) Both in 1.13 and 1.14.3 everything works fine |
Hi, thanks for the reports. The comment in reply to my question: #1403 (comment) @tonybaloney do you have any thoughts here? @Frodothedwarf can you shed further light on why this change had to be made? For Azure I rely largely on the community. |
@LeaveMyYard you seem to be using AWS S3 storage is that correct? The justifications for why this changes were made are that Azure does not support crawling like Django is trying to do when handling files (the part where it goes into one folder, then subfolders and proceeds until no folders is left. Instead Azure returns all files available, resulting in one API call, which is much more efficient than trying to crawl. However I have seen that Azure supports the listing of files with prefix of the folder, like "folder1/". If this needs to be changed I can make a new pull request solving this. I made the change due to Djangos "--clear" command was broken. @marcinfair where do you make use of the os.listdir()? |
@Frodothedwarf Digital Ocean Spaces to be precise |
I haven't touched that part of django-storages, I only made changes to the Azure part.
|
I just listing files in azure storage in some of my custom functions. Maybe I wasn't super clear. What I meant, was that previous implementation of AzureStorage.listdir() returned names of files in azure storage folder without prepended full path, which was the same behaviour as os.listdir(). I decided to upgrade to v.1.14.4 and make workaround by implementing old behaviour of listdir with custom method on AzureStorage class.
|
I guess this could be implmeented correctly, if I understand correctly you want the full path? |
Previous implementation of listdir() I guess was fine. Method had been returning |
I just ran into this as well. The 1.14.3 implementation almost correct, but it had a bug when the file path was not appended (see #1270 )
I assume because of that problem, the implementation was assumed to not work at all, so it was changed to this
However, I assume that this could be fixed with something as simple as
|
Since #1403 the logic of listdir was changed and this is not compatible with standard lib os.listdir. Do you plane do leave it as is or fix this behavior?
Issue occurs since v.1.14.4
thanx
The text was updated successfully, but these errors were encountered: