Add exponential backoff to Cloudflare API calls #138
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
--- | |
name: routing | |
on: | |
pull_request: | |
branches: | |
- master | |
jobs: | |
routing: | |
env: | |
CLOUDFLARE_ACCOUNT_ID: ${{ secrets.CF_ACCOUNT_ID }} | |
CLOUDFLARE_API_TOKEN: ${{ secrets.CF_ACCOUNT_TOKEN }} | |
GITHUB_TOKEN: ${{ secrets.GH_TOKEN }} | |
WRANGLER_SEND_METRICS: false | |
OWNER: ${{ github.repository_owner }} | |
REPOSITORY: ${{ github.repository }} | |
BRANCH: ${{ github.head_ref }} | |
CUSTOM_DOMAIN: nephelai.io | |
if: github.event.pull_request.type != 'closed' | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v3 | |
- name: Install NodeJS | |
uses: actions/setup-node@v3 | |
with: | |
node-version: 18 | |
- name: Install utilities | |
run: sudo apt-get install -y jq httpie make | |
- name: Build project | |
run: make build | |
- name: Set worker name envvar | |
run: echo "WORKER=${REPOSITORY/$OWNER\//}-${BRANCH}-${GITHUB_WORKFLOW}" >> $GITHUB_ENV | |
- name: Set worker fqdn envvar | |
run: echo "FQDN=${WORKER}.${CUSTOM_DOMAIN}" >> $GITHUB_ENV | |
- name: Set worker dns content envvar | |
run: echo "CONTENT=8.8.8.8" >> $GITHUB_ENV | |
- name: Clean previous records for custom domain | |
run: > | |
records=$(npx cfcli --domain ${CUSTOM_DOMAIN} --type A --format json find ${FQDN} ${CONTENT} | jq '. | length' -r); | |
if [[ $records -gt 0 ]]; then | |
npx cfcli --domain ${CUSTOM_DOMAIN} find ${FQDN} --format json | | |
jq '. | map(("--type " + .type + " " + .name + " " + .content)) | .[]' -r | | |
xargs npx cfcli --domain ${CUSTOM_DOMAIN} rm | |
fi | |
env: | |
CF_API_KEY: ${{ secrets.CF_ACCOUNT_TOKEN }} | |
- name: Deploy Cloudflare Worker | |
uses: mathiasvr/command-output@v2.0.0 | |
with: | |
run: | | |
echo Deploying worker "$WORKER"; \ | |
make run -- deploy \ | |
--verbose \ | |
--literal GITHUB_APPLY:true \ | |
--variable WORKER \ | |
--secret GITHUB_TOKEN \ | |
--name "$WORKER" \ | |
--route "$FQDN/*"; | |
- name: Test default domain route / | |
uses: nick-fields/retry@v2 | |
with: | |
max_attempts: 6 | |
retry_on: error | |
timeout_seconds: 10 | |
command: > | |
ADDRESS="$(dig +short $FQDN @1.1.1.1 | head -1)"; | |
return_header=$(curl -sk "https://$FQDN/" --resolve "$FQDN:443:$ADDRESS" -D- | head -1); | |
return_code=$(echo "$return_header" | awk '{print $2}'); | |
echo "return code is $return_code"; | |
if [[ "$return_code" != "200" ]]; then | |
exit 1; | |
fi; | |
curl -sk "https://$FQDN" --resolve "$FQDN:443:$ADDRESS" | grep "^Hello world" | |
- name: Test custom domain route /foo | |
uses: nick-fields/retry@v2 | |
with: | |
max_attempts: 6 | |
retry_on: error | |
timeout_seconds: 10 | |
command: > | |
ADDRESS="$(dig +short $FQDN @1.1.1.1 | head -1)"; | |
return_header=$(curl -sk "https://$FQDN/foo" --resolve "$FQDN:443:$ADDRESS" -D- | head -1); | |
return_code=$(echo "$return_header" | awk '{print $2}'); | |
echo "return code is $return_code"; | |
if [[ "$return_code" != "200" ]]; then | |
exit 1; | |
fi; | |
curl -sk "https://$FQDN" --resolve "$FQDN:443:$ADDRESS" | grep "^Hello world" | |
- name: Update Cloudflare Worker routes | |
uses: mathiasvr/command-output@v2.0.0 | |
with: | |
run: | | |
echo Deploying worker "$WORKER"; \ | |
make run -- deploy \ | |
--verbose \ | |
--literal GITHUB_APPLY:true \ | |
--variable WORKER \ | |
--secret GITHUB_TOKEN \ | |
--name "$WORKER" \ | |
--route "$FQDN/hello" \ | |
--route "$FQDN/hola"; | |
- name: Test default domain route / | |
uses: nick-fields/retry@v2 | |
with: | |
max_attempts: 6 | |
retry_on: error | |
timeout_seconds: 10 | |
command: > | |
ADDRESS="$(dig +short $FQDN @1.1.1.1 | head -1)"; | |
return_header=$(curl -sk "https://$FQDN/" --resolve "$FQDN:443:$ADDRESS" -D- | head -1); | |
return_code=$(echo "$return_header" | awk '{print $2}'); | |
echo "return code is $return_code"; | |
if [[ "$return_code" != "200" ]]; then | |
exit 0; | |
fi; | |
- name: Test custom domain route /foo | |
uses: nick-fields/retry@v2 | |
with: | |
max_attempts: 6 | |
retry_on: error | |
timeout_seconds: 10 | |
command: > | |
ADDRESS="$(dig +short $FQDN @1.1.1.1 | head -1)"; | |
return_header=$(curl -sk "https://$FQDN/foo" --resolve "$FQDN:443:$ADDRESS" -D- | head -1); | |
return_code=$(echo "$return_header" | awk '{print $2}'); | |
echo "return code is $return_code"; | |
if [[ "$return_code" != "200" ]]; then | |
exit 0; | |
fi; | |
- name: Test custom domain route /hello | |
uses: nick-fields/retry@v2 | |
with: | |
max_attempts: 6 | |
retry_on: error | |
timeout_seconds: 10 | |
command: > | |
ADDRESS="$(dig +short $FQDN @1.1.1.1 | head -1)"; | |
return_header=$(curl -sk "https://$FQDN/hello" --resolve "$FQDN:443:$ADDRESS" -D- | head -1); | |
return_code=$(echo "$return_header" | awk '{print $2}'); | |
echo "return code is $return_code"; | |
if [[ "$return_code" != "200" ]]; then | |
exit 1; | |
fi; | |
curl -sk "https://$FQDN/hello" --resolve "$FQDN:443:$ADDRESS" | grep "^Hello world" | |
- name: Test custom domain route /hola | |
uses: nick-fields/retry@v2 | |
with: | |
max_attempts: 6 | |
retry_on: error | |
timeout_seconds: 10 | |
command: > | |
ADDRESS="$(dig +short $FQDN @1.1.1.1 | head -1)"; | |
return_header=$(curl -sk "https://$FQDN/hola" --resolve "$FQDN:443:$ADDRESS" -D- | head -1); | |
return_code=$(echo "$return_header" | awk '{print $2}'); | |
echo "return code is $return_code"; | |
if [[ "$return_code" != "200" ]]; then | |
exit 1; | |
fi; | |
curl -sk "https://$FQDN" --resolve "$FQDN:443:$ADDRESS" | grep "^Hello world" | |
- name: Test custom domain route /hallo | |
uses: nick-fields/retry@v2 | |
with: | |
max_attempts: 6 | |
retry_on: error | |
timeout_seconds: 10 | |
command: > | |
ADDRESS="$(dig +short $FQDN @1.1.1.1 | head -1)"; | |
return_header=$(curl -sk "https://$FQDN/hallo" --resolve "$FQDN:443:$ADDRESS" -D- | head -1); | |
return_code=$(echo "$return_header" | awk '{print $2}'); | |
echo "return code is $return_code"; | |
if [[ "$return_code" != "200" ]]; then | |
exit 0; | |
fi; | |
- name: Update Cloudflare Worker routes | |
uses: mathiasvr/command-output@v2.0.0 | |
with: | |
run: | | |
echo Deploying worker "$WORKER"; \ | |
make run -- deploy \ | |
--verbose \ | |
--literal GITHUB_APPLY:true \ | |
--variable WORKER \ | |
--secret GITHUB_TOKEN \ | |
--name "$WORKER" \ | |
--route "$FQDN/hello" \ | |
--route "$FQDN/hallo"; | |
- name: Test custom domain route /hello | |
uses: nick-fields/retry@v2 | |
with: | |
max_attempts: 6 | |
retry_on: error | |
timeout_seconds: 10 | |
command: > | |
ADDRESS="$(dig +short $FQDN @1.1.1.1 | head -1)"; | |
return_header=$(curl -sk "https://$FQDN/hello" --resolve "$FQDN:443:$ADDRESS" -D- | head -1); | |
return_code=$(echo "$return_header" | awk '{print $2}'); | |
echo "return code is $return_code"; | |
if [[ "$return_code" != "200" ]]; then | |
exit 1; | |
fi; | |
curl -sk "https://$FQDN" --resolve "$FQDN:443:$ADDRESS" | grep "^Hello world" | |
- name: Test custom domain route /hola | |
uses: nick-fields/retry@v2 | |
with: | |
max_attempts: 6 | |
retry_on: error | |
timeout_seconds: 10 | |
command: > | |
ADDRESS="$(dig +short $FQDN @1.1.1.1 | head -1)"; | |
return_header=$(curl -sk "https://$FQDN/hola" --resolve "$FQDN:443:$ADDRESS" -D- | head -1); | |
return_code=$(echo "$return_header" | awk '{print $2}'); | |
echo "return code is $return_code"; | |
if [[ "$return_code" != "200" ]]; then | |
exit 0; | |
fi; | |
- name: Test custom domain route /hallo | |
uses: nick-fields/retry@v2 | |
with: | |
max_attempts: 6 | |
retry_on: error | |
timeout_seconds: 10 | |
command: > | |
ADDRESS="$(dig +short $FQDN @1.1.1.1 | head -1)"; | |
return_header=$(curl -sk "https://$FQDN/hallo" --resolve "$FQDN:443:$ADDRESS" -D- | head -1); | |
return_code=$(echo "$return_header" | awk '{print $2}'); | |
echo "return code is $return_code"; | |
if [[ "$return_code" != "200" ]]; then | |
exit 1; | |
fi; | |
curl -sk "https://$FQDN" --resolve "$FQDN:443:$ADDRESS" | grep "^Hello world" | |
- name: Update Cloudflare Worker routes | |
uses: mathiasvr/command-output@v2.0.0 | |
with: | |
run: | | |
echo Deploying worker "$WORKER"; \ | |
make run -- deploy \ | |
--verbose \ | |
--literal GITHUB_APPLY:true \ | |
--variable WORKER \ | |
--secret GITHUB_TOKEN \ | |
--name "$WORKER" \ | |
--route "$FQDN/*"; | |
- name: Test default domain route / | |
uses: nick-fields/retry@v2 | |
with: | |
max_attempts: 6 | |
retry_on: error | |
timeout_seconds: 10 | |
command: > | |
ADDRESS="$(dig +short $FQDN @1.1.1.1 | head -1)"; | |
return_header=$(curl -sk "https://$FQDN/" --resolve "$FQDN:443:$ADDRESS" -D- | head -1); | |
return_code=$(echo "$return_header" | awk '{print $2}'); | |
echo "return code is $return_code"; | |
if [[ "$return_code" != "200" ]]; then | |
exit 1; | |
fi; | |
curl -sk "https://$FQDN" --resolve "$FQDN:443:$ADDRESS" | grep "^Hello world" | |
- name: Delete Cloudflare Worker | |
uses: mathiasvr/command-output@v2.0.0 | |
with: | |
run: | | |
make run -- delete \ | |
--verbose \ | |
--name "$WORKER" |