Setting Bucket Policy DigitalOcean Spaces
I’ve recently set up PeerTube for personal use, after native support for object storage was merged.
It’s running on DigitalOcean Kubernetes, and using DigitalOcean Spaces for object storage.
I quickly ran into issues. Any video uploaded to PeerTube was inaccessible, because the object ACL was set to private. I could manually set them to public read in DigitalOcean’s UI, or get PeerTube to set it, but both seemed like bad options. DigitalOcean does support enabling public listing, which means all the objects in your bucket can be listed as long as someone has the bucket URL. This naturally isn’t great, because if someone uploads a private video to PeerTube, anyone can list all of the objects in the bucket and end up finding it anyway.
After pulling on the thread long enough, I found that Spaces supports bucket policies, which allow you to specify a global ACL that applies to all objects.
To apply this policy, you need to set up AWS CLI:
brew install awscli
aws configure
The arguments to aws configure
are the same as those described in DigitalOcean’s guide to set up s3cmd
.
Next, you can save the following to policy.json
, replacing BUCKET_NAME
with the name of your bucket:
{
"Version": "2008-10-17",
"Statement": [
{
"Sid": "AddPerm",
"Effect": "Allow",
"Principal": "*",
"Action": "s3:GetObject",
"Resource": "arn:aws:s3:::BUCKET_NAME/*"
}
]
}
You can then apply the policy with, replacing BUCKET_NAME
with the name of your bucket, and REGION
with the bucket region (e.g. sgp1
):
aws s3api --endpoint=https://REGION.digitaloceanspaces.com put-bucket-policy --bucket BUCKET_NAME --policy file://policy.json
Now any objects uploaded to your bucket will be publicly readable, but no one will be able to list the contents of the bucket in their entirety.
On the web
A Nun Answers Questions
Wed Nov 20 2024 by Kev QuirkNo finishing thoughts
Tue Nov 19 2024 by Joel's Log FilesOn Founding the Swiss Laravel Association
Fri Nov 15 2024 by stefanzweifel.devCompiling Lisp to Bytecode and Running It
Tue Oct 15 2024 by Andrew Healey's BlogGoing Buildless
Sun Sep 8 2024 by Max Böck
Generated by openring