-
Notifications
You must be signed in to change notification settings - Fork 691
82 lines (75 loc) · 3.87 KB
/
examples.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
name: Generate magic buttons for examples and publish
on:
push:
branches: [ release_gh ]
paths: ['examples/**/**']
jobs:
publish_examples_magic_buttons:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Create description files
run: |
FOLDERS=$(ls -d examples/*/ | jq -R)
for EXAMPLE_FOLDER in $FOLDERS;
do
RESOURCE=$(cut -d "/" -f 2 <<< "$EXAMPLE_FOLDER")
FILENAME=description.md
if [[ "$RESOURCE" != "zips" ]]; then
if [ -f "./examples/$RESOURCE/$FILENAME" ]; then
echo "./examples/$RESOURCE/$FILENAME exists."
else
printf '# Overview \nThis is a Terraform configuration that creates the `'${RESOURCE}'` service on Oracle Cloud Infrastructure. \n\nThe Terraform code is used to create a Resource Manager stack, that creates the required resources and configures the application on the created resources.' > ./examples/${RESOURCE}/${FILENAME}
echo "./examples/$RESOURCE/$FILENAME created."
fi
fi
done
- name: Commit and Push Changes
run: |
if [ -n "$(git status --porcelain)" ]; then
git config --global user.name "tf-oci-pub"
git config --global user.email "Tf-oci-pub_ww@oracle.com"
git pull origin release_gh
git add ./examples/*
git commit -m "Added - Description files for service examples"
git push
else
echo "No changes!";
fi
- name: Create README files
run: |
if [ -d "./examples/zips" ]; then
rm -r examples/zips
fi
mkdir -p examples/zips
printf '## Terraform Oracle Cloud Infrastructure Provider Examples \n### Examples In This Directory \nThis directory contains Terraform configuration files showing how to create specific resources. The examples are intended to be as simple as possible, in most cases containing only the specific resource and any dependencies required for it to run. These do not represent production configurations or real world scenarios. The magic buttons of the examples can be found below.\n' > ./examples/${RESOURCE}/README.md
FOLDERS=$(ls -d examples/*/ | jq -R)
MAGIC_LINK="https://cloud.oracle.com/resourcemanager/stacks/create?zipUrl=https://github.com/${{ github.repository_owner }}/${{ github.event.repository.name }}/raw/master/examples/zips/"
for EXAMPLE_FOLDER in $FOLDERS;
do
RESOURCE=$(cut -d "/" -f 2 <<< "$EXAMPLE_FOLDER")
if [[ "$RESOURCE" != "zips" ]]; then
FILENAME=description.md
FILEZIP=${RESOURCE}.zip
FOLDER=$(echo "$EXAMPLE_FOLDER" | tr -d '"')
zip -r $FILEZIP $FOLDER || { printf '\n Unable to create zips.\n'; exit 1; }
mv $FILEZIP ./examples/zips
cat ./examples/${RESOURCE}/$FILENAME > ./examples/${RESOURCE}/README.md
printf '\n## Magic Button \n[![Deploy to Oracle Cloud](https://oci-resourcemanager-plugin.plugins.oci.oraclecloud.com/latest/deploy-to-oracle-cloud.svg)]('${MAGIC_LINK}${FILEZIP}')' >>./examples/${RESOURCE}/README.md
printf '%s\n' '- '${RESOURCE}'
[![Deploy to Oracle Cloud](https://oci-resourcemanager-plugin.plugins.oci.oraclecloud.com/latest/deploy-to-oracle-cloud.svg)]('${MAGIC_LINK}${FILEZIP}')' >> ./examples/README.md
fi
done
- name: Commit and Push Changes
run: |
if [ -n "$(git status --porcelain)" ]; then
git config --global user.name "tf-oci-pub"
git config --global user.email "Tf-oci-pub_ww@oracle.com"
git pull origin release_gh
git add ./examples/*
git commit -m "Added - README.md of service examples with magic button"
git push
else
echo "No changes!";
fi