From 90952cd2bce8941de7a2a4a24e5734fc21253c22 Mon Sep 17 00:00:00 2001 From: Peyo Date: Tue, 17 Dec 2024 16:07:11 +0100 Subject: [PATCH] ip_rule_cellar_example --- content/doc/addons/cellar.md | 49 ++++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) diff --git a/content/doc/addons/cellar.md b/content/doc/addons/cellar.md index cbfc567c..da8aaf8d 100644 --- a/content/doc/addons/cellar.md +++ b/content/doc/addons/cellar.md @@ -379,6 +379,55 @@ s3cmd delpolicy s3:// The original ACL should apply to all of your objects after that. + +### IP restrictions + +If you need to restrict your S3 Cellar to certain IPs, you can use a policy. +To do so, you can use the template below in a `policy.json` file. This example show how to block actions from any IP that isn't `192.168.1.6`. + +- Replace the `` with your bucket name in the policy file. +- Change the `Effect` to "`Allow` or `Deny` depending on your needs. +- Change the IP address under `Condition` to select which IP should trigger the rule. + +```json {filename="IP-restriction-policy.json"} +{ + "Version": "2012-10-17", + "Id": "S3PolicyIPRestrict", + "Statement": [ + { + "Sid": "IPAllow", + "Effect": "Deny", + "Principal": { + "AWS": "*" + }, + "Action": "s3:*", + "Resource": [ + "arn:aws:s3:::", + "arn:aws:s3:::/*" + ], + "Condition" : { + "IpAddress" : { + "aws:SourceIp": ["0.0.0.0/0"] + }, + "NotIpAddress": { + "aws:SourceIp": ["192.168.1.6/32"] + } + } + } + ] +} +``` + +To apply the policy, use this command: +``` +s3cmd setpolicy ./policy.json s3:// +``` + +To delete the policy, use this command: +``` +s3cmd delpolicy ./policy.json s3:// +``` + ### User access Cellar doesn't natively support creating different user accesses for the same add-on. Granting access to your Cellar add-on grants full access to all of your buckets. To grant limited access to a bucket, do the following: