Update GraphQL files #122
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 GraphQL files | |
# **What it does**: This updates our GraphQL schemas. | |
# **Why we have it**: We want our GraphQL docs up to date. | |
# **Who does it impact**: Docs engineering, people reading GraphQL docs. | |
on: | |
workflow_dispatch: | |
schedule: | |
- cron: '20 16 * * *' # Run every day at 16:20 UTC / 8:20 PST | |
permissions: | |
contents: write | |
pull-requests: write | |
# **IMPORTANT:** Do not change the FREEZE environment variable set here! | |
# This workflow runs on a recurring basis. To temporarily disable it (e.g., | |
# during a docs deployment freeze), add an Actions Secret to the repo settings | |
# called `FREEZE` with a value of `true`. To re-enable GraphQL updates, simply | |
# delete that Secret from the repo settings. The environment variable here | |
# will duplicate that Secret's value for later evaluation. | |
env: | |
FREEZE: ${{ secrets.FREEZE }} | |
jobs: | |
update_graphql_files: | |
if: github.repository == 'github/docs-internal' | |
runs-on: ubuntu-latest | |
steps: | |
- if: ${{ env.FREEZE == 'true' }} | |
run: | | |
echo 'The repo is currently frozen! Exiting this workflow.' | |
exit 1 # prevents further steps from running | |
- name: Checkout | |
uses: actions/checkout@3df4ab11eba7bda6032a0b82a6bb43b11571feac # v4.0.0 | |
- uses: ./.github/actions/node-npm-setup | |
- name: Run updater scripts | |
env: | |
# need to use a token from a user with access to github/github for this step | |
GITHUB_TOKEN: ${{ secrets.DOCS_BOT_PAT_WRITEORG_PROJECT }} | |
run: | | |
src/graphql/scripts/sync.js | |
- name: Create pull request | |
id: create-pull-request | |
uses: peter-evans/create-pull-request@5b4a9f6a9e2af26e5f02351490b90d01eb8ec1e5 # pin @v5.0.0 | |
env: | |
# Disable pre-commit hooks; they don't play nicely here | |
HUSKY: '0' | |
with: | |
# Need to use a token with repo and workflow scopes for this step. | |
# Token should be a PAT because actions performed with GITHUB_TOKEN | |
# don't trigger other workflows and this action force pushes updates | |
# from the default branch. | |
token: ${{ secrets.DOCS_BOT_PAT_WORKFLOW }} | |
commit-message: 'Update GraphQL data files' | |
title: GraphQL schema update | |
body: | |
"Hello! Some GraphQL data in github/github was updated recently. This PR | |
syncs up the GraphQL data in this repo.\n\n | |
If CI passes, this PR will be auto-merged. :green_heart:\n\n | |
If CI does not pass or other problems arise, contact #docs-engineering on slack." | |
branch: graphql-schema-update | |
- name: Enable GitHub auto-merge | |
if: ${{ steps.create-pull-request.outputs.pull-request-number }} | |
env: | |
GITHUB_TOKEN: ${{ secrets.DOCS_BOT_PAT_READPUBLICKEY }} | |
AUTOMERGE_PR_NUMBER: ${{ steps.create-pull-request.outputs.pull-request-number }} | |
run: node src/workflows/enable-automerge.js | |
- if: ${{ failure() && env.FREEZE != 'true'}} | |
name: Delete remote branch (if previous steps failed) | |
uses: dawidd6/action-delete-branch@47743101a121ad657031e6704086271ca81b1911 | |
with: | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
branches: graphql-schema-update | |
- if: ${{ steps.create-pull-request.outputs.pull-request-number }} | |
name: Approve | |
uses: juliangruber/approve-pull-request-action@dcc4effb325c0b503408619918d56e40653dcc91 | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
number: ${{ steps.create-pull-request.outputs.pull-request-number }} | |
- uses: ./.github/actions/slack-alert | |
if: ${{ failure() && github.event_name != 'workflow_dispatch' }} | |
with: | |
slack_channel_id: ${{ secrets.DOCS_ALERTS_SLACK_CHANNEL_ID }} | |
slack_token: ${{ secrets.SLACK_DOCS_BOT_TOKEN }} |