-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathACS-OSS-PutBucketReferer.yml
126 lines (126 loc) · 3.87 KB
/
ACS-OSS-PutBucketReferer.yml
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
123
124
125
126
FormatVersion: OOS-2019-06-01
Description:
en: Put the bucket referer
zh-cn: 设置存储空间防盗链
name-en: ACS-OSS-PutBucketReferer
name-zh-cn: 设置存储空间防盗链
categories:
- security
Parameters:
regionId:
Type: String
Label:
en: RegionId
zh-cn: 地域ID
AssociationProperty: RegionId
Default: '{{ ACS::RegionId }}'
bucketName:
Label:
en: BucketName
zh-cn: OSS bucket 名称
Type: String
allowEmptyReferer:
Label:
en: AllowEmptyReferer
zh-cn: 是否允许Referer字段为空的请求访问
Description:
en: Specify whether to allow access to requests whose Referer field is empty
zh-cn: 指定是否允许Referer字段为空的请求访问
Type: String
Default: 'true'
AllowedValues:
- 'true'
- 'false'
refererList:
Description:
en: for example:[http://www.aliyun.com, https://www.aliyun.com]
zh-cn: 例如:[http://www.aliyun.com, https://www.aliyun.com]
Label:
en: Save Referer Access Whitelist URL
zh-cn: 保存Referer访问白名单的网址
Type: List
Default: []
OOSAssumeRole:
Label:
en: OOSAssumeRole
zh-cn: OOS扮演的RAM角色
Type: String
Default: ''
RamRole: '{{ OOSAssumeRole }}'
Tasks:
- Name: convertXmlParameters
Action: 'ACS::ECS::SMCConversionConstantByJqScript'
Description:
en: Automatically make bucket referer configuration
zh-cn: 自动生成存储空间防盗链规则
Properties:
parameter: '{{ refererList }}'
jqScript:
- '. [] | split("[") | join("") | split("]") | join("") | split("\"") | join("") |split(",") | map(. | .="<Referer>"+.+"</Referer>") as $item| $item | join("") as $itemList | "<RefererConfiguration><AllowEmptyReferer>{{ allowEmptyReferer }}</AllowEmptyReferer><RefererList>"+$itemList+"</RefererList>" as $refererList |$refererList'
- .
Outputs:
xmlValues:
Type: String
ValueSelector: firstValue
- Name: putBucketReferer
Action: 'ACS::ExecuteAPI'
Description:
en: 'Enable the bucket referer'
zh-cn: 开启存储空间防盗链
Properties:
Service: OSS
API: PutBucketReferer
Method: PUT
URI: '?referer'
Headers:
Content-MD5: ""
Content-Type: application/xml
Parameters:
BucketName: '{{ bucketName }}'
RegionId: '{{ regionId }}'
Body: '<?xml version="1.0" encoding="UTF-8"?>{{ convertXmlParameters.xmlValues }}</RefererConfiguration>'
- Name: waitBucketRefererNoRefererList
Action: 'ACS::WaitFor'
Description:
en: Wait for the bucket referer modification to complete when referer is allowed to be empty
zh-cn: 等待存储空间防盗链允许为空时修改完成
When:
'Fn::Equals':
- '{{ refererList }}'
- []
OnSuccess: 'ACS::END'
Properties:
Service: OSS
API: GetBucketReferer
Method: GET
URI: '?referer'
Headers: {}
Parameters:
BucketName: '{{ bucketName }}'
RegionId: '{{ regionId }}'
DesiredValues:
- '{{ allowEmptyReferer }}'
PropertySelector: '.RefererConfiguration.AllowEmptyReferer'
- Name: waitBucketReferer
Action: 'ACS::WaitFor'
Description:
en: Wait for the bucket referer modification to complete
zh-cn: 等待存储空间防盗链修改完成
Properties:
Service: OSS
API: GetBucketReferer
Method: GET
URI: '?referer'
Headers: {}
Parameters:
BucketName: '{{ bucketName }}'
RegionId: '{{ regionId }}'
NotDesiredValues: '{{ refererList }}'
PropertySelector: '.RefererConfiguration.RefererList.Referer-{{ refererList }}'
Outputs:
refererInfo:
Type: Json
Value:
bucketName: '{{ bucketName }}'
allowEmptyReferer: '{{ allowEmptyReferer }}'
refererList: '{{ refererList }}'