-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathpublish-resource-regions.sh
executable file
·69 lines (53 loc) · 1.55 KB
/
publish-resource-regions.sh
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
#!/bin/bash
#
# Publish a resource to all regions
#
# Run this from the resource folder
regions_to_publish=(us-west-2 us-east-1)
successes=()
failures=()
cfn validate
cfn generate
# Create the package
echo "About to run cfn submit --dry-run to create the package"
echo ""
cfn submit --dry-run
echo ""
TYPE_NAME=$(cat .rpdk-config | jq -r .typeName)
TYPE_NAME_LOWER="$(echo $TYPE_NAME | sed s/::/-/g | tr '[:upper:]' '[:lower:]')"
# For example, awscommunity-s3-deletebucketcontents
echo "TYPE_NAME_LOWER is $TYPE_NAME_LOWER"
ZIPFILE="${TYPE_NAME_LOWER}.zip"
echo "ZIPFILE is $ZIPFILE"
ACCOUNT_ID=$(aws sts get-caller-identity|jq -r .Account)
echo "ACCOUNT_ID is $ACCOUNT_ID"
HANDLER_BUCKET="cep-handler-${ACCOUNT_ID}"
# We only need to copy the handler zip once, since it's not regional
# We use this bucket for logs also. The only drawback is if there are
# failures, it can be hard to sort out which log file belongs to which region.
echo "Copying schema package handler to $HANDLER_BUCKET"
aws s3 cp $ZIPFILE s3://$HANDLER_BUCKET/$ZIPFILE
for region in ${regions_to_publish[@]}
do
echo "About to start publishing to $region"
../deregister-all.sh $region
../publish-resource.sh $region
if [ "$?" -eq 0 ]
then
echo "Publishing to $region succeeded"
successes+=($region)
else
echo "Publishing to $region failed"
failures+=($region)
fi
done
echo "The following regions succeeded:"
for s in "${successes[@]}"
do
echo $s
done
echo "The following regions failed:"
for f in "${failures[@]}"
do
echo $f
done