Improve the problem statement, add comments, and a function to get in… #53
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: Update GitHub Pages | |
on: | |
push: | |
branches: | |
# We want to trigger the workflow action whenever there is a push to the main branch. | |
- main # Note that it requires the yml file to be a part of this branch to trigger the workflow action. | |
# We need the write permission for the workflow actions because it writes to a json file and push changes | |
permissions: | |
contents: write | |
pull-requests: write | |
jobs: | |
update-content: | |
runs-on: ubuntu-latest | |
steps: | |
# Step 1: Configure the Git user to be used for all the git operations below | |
- name: Configure Git user | |
run: | | |
git config --global user.email "github-actions[bot]@users.noreply.github.com" | |
git config --global user.name "github-actions[bot]" | |
# Step 2: Checkout the 'github_pages_from_main' branch | |
- name: Checkout github_pages_from_main branch | |
uses: actions/checkout@v4 | |
with: | |
ref: github_pages_from_main | |
# Step 3: Configure the git pull strategy to be used while performing the pull and merge | |
- name: Configure Git Pull Strategy | |
run: git config pull.rebase false # Use 'true' for rebase or 'ff only' for fast-forward only | |
# Step 4: Merge changes from 'origin/main' into 'github_pages_from_main' | |
# Note that we have to specify the merge conflict resolution | |
# And we specify that it is ok to have different point of time of creation | |
# of both the target and destination branches (a.k.a., allow unrelated histories) | |
# and that we would always accept the changes from origin/main over the destination branch. | |
# It means, the base (origin/main) takes priority over the one that pulls the changes. | |
- name: Merge main into github_pages_from_main | |
run: | | |
git remote set-url origin https://x-access-token:${{ secrets.TOKEN }}@github.com/${{ github.repository }}.git | |
git checkout github_pages_from_main | |
git pull origin main --allow-unrelated-histories -X theirs | |
# Step 5: Ensure files.json exists | |
- name: Create files.json if it does not exist | |
run: | | |
if [ ! -f files.json ]; then | |
echo "[]" > files.json | |
fi | |
# Step 6: Run the JavaScript script to update the files.json | |
- name: Set up Node.js | |
uses: actions/setup-node@v3 | |
with: | |
node-version: '20' | |
# Step 7: Install dependencies that our script may need to run properly | |
- name: Install dependencies | |
run: npm install node-fetch | |
# Step 8: Run the script | |
- name: Run update script | |
env: | |
GITHUB_TOKEN: ${{ secrets.TOKEN }} | |
# This is the script that will run on GitHub (This is not a browser script). | |
run: node updateContentGitHubActionsGitHubPages.mjs | |
# Step 9: Commit and push changes to github_pages_from_main | |
- name: Commit and push changes to github_pages_from_main | |
env: | |
GITHUB_TOKEN: ${{ secrets.TOKEN }} | |
run: | | |
git config --global user.name 'github-actions[bot]' | |
git config --global user.email 'github-actions[bot]@users.noreply.github.com' | |
git add files.json | |
git commit -m 'Update files.json with latest Kotlin files' || echo "No changes to commit" | |
git push https://x-access-token:${{ secrets.TOKEN }}@github.com/${{ github.repository }}.git HEAD:github_pages_from_main | |
deploy: | |
needs: update-content | |
runs-on: ubuntu-latest | |
steps: | |
# Step 10: Make sure to check out to the same branch that we set up in repository/settings/pages/deployment branch | |
- name: Checkout github_pages_from_main branch | |
uses: actions/checkout@v3 | |
with: | |
ref: github_pages_from_main | |
- name: Deploy to GitHub Pages | |
uses: peaceiris/actions-gh-pages@v3 | |
with: | |
github_token: ${{ secrets.TOKEN }} | |
publish_dir: ./kotlinDSAWithIntellijIdea | |
# The GitHub workflow action will push the changes to this branch | |
# It is a good idea to have GitHub pages related changes on a separate and a dedicated branch | |
destination_branch: gh-pages # This is a standard, common GitHub bot branch that takes control from this point |