-
Notifications
You must be signed in to change notification settings - Fork 1
/
CloudFormation.json
122 lines (122 loc) · 2.67 KB
/
CloudFormation.json
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
{
"AWSTemplateFormatVersion": "2010-09-09",
"Description": "This stack will create a S3 bucket that can be used as a temporary public network storage with a self-destruct mechanism to delete object after a set period of time.",
"Parameters": {
"DataRestingPlace": {
"Description": "The S3 bucket name where you want to store your data.",
"Type": "String"
},
"ExpiersIn": {
"Description": "Set after how many days the object should be automatically deleted.",
"Type": "Number"
}
},
"Resources": {
"S3DriveSelfdestruct": {
"Type": "AWS::S3::Bucket",
"Properties": {
"BucketName": {
"Fn::Sub": "${DataRestingPlace}"
},
"PublicAccessBlockConfiguration": {
"BlockPublicAcls": false,
"BlockPublicPolicy": false,
"IgnorePublicAcls": false,
"RestrictPublicBuckets": false
},
"LifecycleConfiguration": {
"Rules": [
{
"Id": {
"Fn::Sub": "${ExpiersIn}Day(s)"
},
"ExpirationInDays": {
"Fn::Sub": "${ExpiersIn}"
},
"Status": "Enabled"
}
]
},
"Tags": [
{
"Key": "Name",
"Value": "S3 Drive Self-destruct"
},
{
"Key": "Source",
"Value": "0x4447 LLC"
},
{
"Key": "Info",
"Value": "https://0x4447.com"
}
]
}
},
"IAMGroup": {
"Type": "AWS::IAM::Group",
"Properties": {
"GroupName": "0x4447_s3_drive_self_destruct",
"Policies": [
{
"PolicyName": "l_r_w_d_plus_rename",
"PolicyDocument": {
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"s3:ListBucket",
"s3:GetObject",
"s3:PutObject",
"s3:DeleteObject",
"s3:GetObjectAcl",
"s3:GetObjectVersionAcl",
"s3:PutObjectAcl",
"s3:PutObjectVersionAcl"
],
"Resource": [
{
"Fn::Sub": "arn:aws:s3:::${S3DriveSelfdestruct}"
},
{
"Fn::Sub": "arn:aws:s3:::${S3DriveSelfdestruct}/*"
}
]
},
{
"Effect": "Allow",
"Action": "s3:ListAllMyBuckets",
"Resource": "*"
}
]
}
}
]
}
},
"S3DriveSelfdestructPolicy": {
"Type": "AWS::S3::BucketPolicy",
"Properties": {
"Bucket": {
"Fn::Sub": "${S3DriveSelfdestruct}"
},
"PolicyDocument": {
"Version": "2008-10-17",
"Statement": [
{
"Effect": "Allow",
"Principal": {
"AWS": "*"
},
"Action": "s3:GetObject",
"Resource": {
"Fn::Sub": "arn:aws:s3:::${S3DriveSelfdestruct}/*"
}
}
]
}
}
}
}
}