mirror of
https://github.com/bookwyrm-social/bookwyrm.git
synced 2024-11-28 20:41:46 +00:00
set signed s3 url expiry with env value
Adds S3_SIGNED_URL_EXPIRY val to .env and settings (defaults to 15 mins) Note that this is reset every time the user loads the exports page and is independent of the _creation_ of export files.
This commit is contained in:
parent
5b71e94888
commit
dd27684d4b
3 changed files with 15 additions and 4 deletions
|
@ -71,6 +71,9 @@ ENABLE_THUMBNAIL_GENERATION=true
|
||||||
USE_S3=false
|
USE_S3=false
|
||||||
AWS_ACCESS_KEY_ID=
|
AWS_ACCESS_KEY_ID=
|
||||||
AWS_SECRET_ACCESS_KEY=
|
AWS_SECRET_ACCESS_KEY=
|
||||||
|
# seconds for signed S3 urls to expire
|
||||||
|
# this is currently only used for user export files
|
||||||
|
S3_SIGNED_URL_EXPIRY=900
|
||||||
|
|
||||||
# Commented are example values if you use a non-AWS, S3-compatible service
|
# Commented are example values if you use a non-AWS, S3-compatible service
|
||||||
# AWS S3 should work with only AWS_STORAGE_BUCKET_NAME and AWS_S3_REGION_NAME
|
# AWS S3 should work with only AWS_STORAGE_BUCKET_NAME and AWS_S3_REGION_NAME
|
||||||
|
|
|
@ -375,6 +375,7 @@ if USE_HTTPS:
|
||||||
|
|
||||||
USE_S3 = env.bool("USE_S3", False)
|
USE_S3 = env.bool("USE_S3", False)
|
||||||
USE_AZURE = env.bool("USE_AZURE", False)
|
USE_AZURE = env.bool("USE_AZURE", False)
|
||||||
|
S3_SIGNED_URL_EXPIRY = env.int("S3_SIGNED_URL_EXPIRY", 900)
|
||||||
|
|
||||||
if USE_S3:
|
if USE_S3:
|
||||||
# AWS settings
|
# AWS settings
|
||||||
|
|
|
@ -146,7 +146,12 @@ class Export(View):
|
||||||
# pylint: disable=no-self-use
|
# pylint: disable=no-self-use
|
||||||
@method_decorator(login_required, name="dispatch")
|
@method_decorator(login_required, name="dispatch")
|
||||||
class ExportUser(View):
|
class ExportUser(View):
|
||||||
"""Let users export user data to import into another Bookwyrm instance"""
|
"""
|
||||||
|
Let users export user data to import into another Bookwyrm instance
|
||||||
|
This view creates signed URLs to pre-processed export files in
|
||||||
|
s3 storage on load (if they exist) and allows the user to create
|
||||||
|
a new file.
|
||||||
|
"""
|
||||||
|
|
||||||
def get(self, request):
|
def get(self, request):
|
||||||
"""Request tar file"""
|
"""Request tar file"""
|
||||||
|
@ -166,8 +171,10 @@ class ExportUser(View):
|
||||||
|
|
||||||
# for s3 we download directly from s3, so we need a signed url
|
# for s3 we download directly from s3, so we need a signed url
|
||||||
export["url"] = S3Boto3Storage.url(
|
export["url"] = S3Boto3Storage.url(
|
||||||
storage, f"/exports/{job.task_id}.tar.gz", expire=900
|
storage,
|
||||||
) # temporarily downloadable file, expires after 5 minutes
|
f"/exports/{job.task_id}.tar.gz",
|
||||||
|
expire=settings.S3_SIGNED_URL_EXPIRY,
|
||||||
|
)
|
||||||
|
|
||||||
# for s3 we create a new tar file in s3,
|
# for s3 we create a new tar file in s3,
|
||||||
# so we need to check the size of _that_ file
|
# so we need to check the size of _that_ file
|
||||||
|
@ -207,7 +214,7 @@ class ExportUser(View):
|
||||||
return TemplateResponse(request, "preferences/export-user.html", data)
|
return TemplateResponse(request, "preferences/export-user.html", data)
|
||||||
|
|
||||||
def post(self, request):
|
def post(self, request):
|
||||||
"""Download the json file of a user's data"""
|
"""Trigger processing of a new user export file"""
|
||||||
|
|
||||||
job = BookwyrmExportJob.objects.create(user=request.user)
|
job = BookwyrmExportJob.objects.create(user=request.user)
|
||||||
job.start_job()
|
job.start_job()
|
||||||
|
|
Loading…
Reference in a new issue