Skip to content

Republish dock-tech #12

Republish dock-tech

Republish dock-tech #12

name: Create and deploy portal
on:
push:
branches:
- main
paths-ignore:
- '.github/**' # Ignore any changes in the .github directory
- 'README.md' # Ignore changes to README.md
jobs:
collect_dirs:
runs-on: ubuntu-latest
outputs:
dirs: ${{ steps.collect-dirs.outputs.dirs }}
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
fetch-depth: 2 # Fetch last 2 commits to get access to HEAD and HEAD~1 (previous commit)
- name: Collect Changed Directories
id: collect-dirs
run: |
# Only consider directories that have changed on latest commit and exist in the repo
CHANGED_DIRS=$(git diff --name-only HEAD~1 HEAD | \
grep -v '^.github/' | \
grep -v '^README.md' | \
cut -d'/' -f1 | \
sort -u | \
while read dir; do
if [ -d "$dir" ]; then
echo "$dir"
fi
done | \
tr -d '"' | \
jq -R -s -c 'split("\n") | map(select(length > 0))')
echo "directories=$CHANGED_DIRS" >> $GITHUB_ENV
echo "::set-output name=dirs::$CHANGED_DIRS"
build_and_deploy:
needs: collect_dirs
runs-on: ubuntu-latest
strategy:
matrix:
directory: ${{ fromJson(needs.collect_dirs.outputs.dirs) }}
if: ${{ needs.collect_dirs.outputs.dirs != '[]' }} # Only run if directories are found
steps:
- name: Debug Changed Directories
run: |
echo "CHANGED_DIRS: ${{ needs.collect_dirs.outputs.dirs }}"
- name: Checkout code
uses: actions/checkout@v3
- name: Add Random Waiting Time
uses: AliSajid/random-wait-action@f9109712daa7a8103f7be16b68634b9d376587a7 # v2.4.1
with:
minimum: 15
maximum: 50
- name: Zip BuildFiles and send to APIMatic
continue-on-error: true # Allow deployment to fail without halting the action
run: |
cd ${{ matrix.directory }}
echo "Zipping BuildFiles in ${{ matrix.directory }}..."
zip -r portal-input.zip BuildFiles/* > /dev/null
echo "Zipped BuildFiles successfully."
echo "Sending zip to APIMatic..."
RESPONSE=$(curl -s --output response.zip --write-out '%{http_code}\t%{content_type}' --request POST \
--url 'https://api.apimatic.io/portal' \
-H 'Authorization: X-Auth-Key ${{ secrets.APIMATIC_API_KEY }}' \
-F "[email protected]")
echo "Raw curl response: $RESPONSE"
HTTP_CODE=$(echo "$RESPONSE" | cut -f1)
CONTENT_TYPE=$(echo "$RESPONSE" | cut -f2)
if [ "$HTTP_CODE" -ne 200 ]; then
echo "APIMatic transformer failed with HTTP_CODE=$HTTP_CODE. Exiting."
exit 1
fi
echo "Request successful. Unzipping response..."
mkdir -p Portal
unzip -qq response.zip -d Portal
ls Portal
- name: Add Random Waiting Time
uses: AliSajid/random-wait-action@f9109712daa7a8103f7be16b68634b9d376587a7 # v2.4.1
with:
minimum: 10
maximum: 40
- name: Check and Create Cloudflare Project if Needed
continue-on-error: true # Allow deployment to fail without halting the action
run: |
PROJECT_NAME=$(basename ${{ matrix.directory }})-apimatic-catalog
echo "Checking if Cloudflare project '$PROJECT_NAME' exists..."
PAGE=1
EXISTING_PROJECTS=""
while true; do
# Make the API request for the current page
RESPONSE=$(curl -s --request GET \
--url "https://api.cloudflare.com/client/v4/accounts/${{ secrets.CLOUDFLARE_ACCOUNT_ID }}/pages/projects?page=$PAGE" \
--header 'Content-Type: application/json' \
-H "Authorization: Bearer ${{ secrets.CLOUDFLARE_API_TOKEN }}")
# Append project names from the current page to the variable
PROJECTS=$(echo "$RESPONSE" | jq -r '.result[]?.name // empty')
EXISTING_PROJECTS+="$PROJECTS"$'\n'
# Check if more pages exist
TOTAL_PAGES=$(echo "$RESPONSE" | jq -r '.result_info.total_pages // 0')
if [ "$PAGE" -ge "$TOTAL_PAGES" ]; then
break
fi
PAGE=$((PAGE + 1))
done
# Output all projects
echo "$EXISTING_PROJECTS"
# Check if the current project name exists in the list
if echo "$EXISTING_PROJECTS" | grep -q "^$PROJECT_NAME$"; then
echo "Project '$PROJECT_NAME' already exists on Cloudflare."
else
echo "Project '$PROJECT_NAME' not found. Creating new Cloudflare project..."
# Create the new project
CREATE_RESPONSE=$(curl -s --request POST \
--url https://api.cloudflare.com/client/v4/accounts/${{ secrets.CLOUDFLARE_ACCOUNT_ID }}/pages/projects \
--header 'Content-Type: application/json' \
-H "Authorization: Bearer ${{ secrets.CLOUDFLARE_API_TOKEN }}" \
--data '{
"name": "'"$PROJECT_NAME"'",
"production_branch": "main"
}')
# Check if the project creation was successful
if echo "$CREATE_RESPONSE" | jq -e '.success' > /dev/null; then
echo "Successfully created Cloudflare project '$PROJECT_NAME'."
else
echo "Failed to create Cloudflare project '$PROJECT_NAME'. Response: $CREATE_RESPONSE"
exit 1
fi
fi
- name: Deploy to Cloudflare Pages
uses: cloudflare/wrangler-action@v3
with:
apiToken: ${{ secrets.CLOUDFLARE_API_TOKEN }}
accountId: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }}
command: pages deploy ${{ matrix.directory }}/Portal --project-name=${{ matrix.directory }}-apimatic-catalog
continue-on-error: true # Allow deployment to fail without halting the action
update_readme:
needs: build_and_deploy
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Truncate README.md and Append Filtered Subdomains
run: |
# Truncate README.md after line 87
head -n 87 README.md > temp_README.md && mv temp_README.md README.md
PAGE=1
README_FILE="README.md"
# Add a new line (backslash) to README.md
echo "\\" >> $README_FILE
subdomain_lines=""
while true; do
# Fetch the current page from the API
RESPONSE=$(curl --silent --request GET \
--url "https://api.cloudflare.com/client/v4/accounts/${{ secrets.CLOUDFLARE_ACCOUNT_ID }}/pages/projects?page=$PAGE" \
--header 'Content-Type: application/json' \
-H "Authorization: Bearer ${{ secrets.CLOUDFLARE_API_TOKEN }}")
# Extract subdomains that contain "-apimatic-catalog" and format them
subdomain_lines+=$(echo "$RESPONSE" | \
jq -r '.result[] | select(.subdomain | contains("-apimatic-catalog")) | .subdomain' | \
sed 's/^/* <http:\/\//' | sed 's/$/>/'$'\n')
# Check pagination
TOTAL_PAGES=$(echo "$RESPONSE" | jq '.result_info.total_pages')
if [ "$PAGE" -ge "$TOTAL_PAGES" ]; then
break
fi
# Move to the next page
PAGE=$((PAGE + 1))
done
# Append to README.md without a trailing slash
echo -e "$subdomain_lines" >> $README_FILE
# Output the updated README for debugging purposes
echo "Updated README.md content:"
cat $README_FILE
- name: Commit and Push the Updated README.md
run: |
git config --global user.name "github-actions[bot]"
git config --global user.email "github-actions[bot]@users.noreply.github.com"
git add README.md
git commit -m "Update README.md with filtered Cloudflare subdomains"
git push
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}