parent
5d8b8212cc
commit
16005e14ef
@ -2,6 +2,7 @@ import os
|
|||||||
import secrets
|
import secrets
|
||||||
|
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
|
from storages.backends.gcloud import GoogleCloudStorage
|
||||||
from storages.backends.s3boto3 import S3Boto3Storage
|
from storages.backends.s3boto3 import S3Boto3Storage
|
||||||
|
|
||||||
|
|
||||||
@ -16,11 +17,26 @@ def upload_namer(prefix, instance, filename):
|
|||||||
|
|
||||||
|
|
||||||
class TakaheS3Storage(S3Boto3Storage):
|
class TakaheS3Storage(S3Boto3Storage):
|
||||||
|
"""
|
||||||
|
Custom override backend that makes webp files store correctly
|
||||||
|
"""
|
||||||
|
|
||||||
def get_object_parameters(self, name: str):
|
def get_object_parameters(self, name: str):
|
||||||
params = self.object_parameters.copy()
|
params = self.object_parameters.copy()
|
||||||
|
|
||||||
if name.endswith(".webp"):
|
if name.endswith(".webp"):
|
||||||
params["ContentDisposition"] = "inline"
|
params["ContentDisposition"] = "inline"
|
||||||
params["ContentType"] = "image/webp"
|
params["ContentType"] = "image/webp"
|
||||||
|
return params
|
||||||
|
|
||||||
|
|
||||||
|
class TakaheGoogleCloudStorage(GoogleCloudStorage):
|
||||||
|
"""
|
||||||
|
Custom override backend that makes webp files store correctly
|
||||||
|
"""
|
||||||
|
|
||||||
|
def get_object_parameters(self, name: str):
|
||||||
|
params = self.object_parameters.copy()
|
||||||
|
if name.endswith(".webp"):
|
||||||
|
params["content_disposition"] = "inline"
|
||||||
|
params["content_type"] = "image/webp"
|
||||||
return params
|
return params
|
||||||
|
@ -338,15 +338,14 @@ if SETUP.EMAIL_SERVER:
|
|||||||
if SETUP.MEDIA_BACKEND:
|
if SETUP.MEDIA_BACKEND:
|
||||||
parsed = urllib.parse.urlparse(SETUP.MEDIA_BACKEND)
|
parsed = urllib.parse.urlparse(SETUP.MEDIA_BACKEND)
|
||||||
query = urllib.parse.parse_qs(parsed.query)
|
query = urllib.parse.parse_qs(parsed.query)
|
||||||
if parsed.scheme == "gcs":
|
if parsed.scheme == "gs":
|
||||||
DEFAULT_FILE_STORAGE = "storages.backends.gcloud.GoogleCloudStorage"
|
DEFAULT_FILE_STORAGE = "core.uploads.TakaheGoogleCloudStorage"
|
||||||
if parsed.path.lstrip("/"):
|
GS_BUCKET_NAME = parsed.path.lstrip("/")
|
||||||
GS_BUCKET_NAME = parsed.path.lstrip("/")
|
|
||||||
else:
|
|
||||||
GS_BUCKET_NAME = parsed.hostname
|
|
||||||
GS_QUERYSTRING_AUTH = False
|
GS_QUERYSTRING_AUTH = False
|
||||||
|
if parsed.hostname is not None:
|
||||||
|
port = parsed.port or 443
|
||||||
|
GS_CUSTOM_ENDPOINT = f"https://{parsed.hostname}:{port}"
|
||||||
elif parsed.scheme == "s3":
|
elif parsed.scheme == "s3":
|
||||||
# DEFAULT_FILE_STORAGE = "storages.backends.s3boto3.S3Boto3Storage"
|
|
||||||
DEFAULT_FILE_STORAGE = "core.uploads.TakaheS3Storage"
|
DEFAULT_FILE_STORAGE = "core.uploads.TakaheS3Storage"
|
||||||
AWS_STORAGE_BUCKET_NAME = parsed.path.lstrip("/")
|
AWS_STORAGE_BUCKET_NAME = parsed.path.lstrip("/")
|
||||||
AWS_QUERYSTRING_AUTH = False
|
AWS_QUERYSTRING_AUTH = False
|
||||||
|
Reference in New Issue
Block a user