Styleguide and contributions update #1106
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: Deploy Preview | |
env: | |
COMMENT_HEADER: clerk-docs-preview | |
on: | |
pull_request_target: | |
types: [labeled, synchronize] | |
jobs: | |
# When a PR is labeled with the `deploy-preview` label, we manually trigger a preview deployment of the site and assign it a stable URL. | |
# A comment is kept up-to-date on the PR as the deployment progresses. | |
# | |
# Forks are handled by using the gh CLI to checkout the forked branch, and then we push up a branch to the origin. | |
# This should be safe as it requires someone with triage permissions on the repository to apply the label. | |
deploy: | |
env: | |
VERCEL_ORG_ID: ${{ secrets.VERCEL_ORG_ID }} | |
VERCEL_PROJECT_ID: ${{ secrets.VERCEL_PROJECT_ID }} | |
permissions: | |
contents: write | |
pull-requests: write | |
if: ${{ github.event.action == 'labeled' && github.event.label.name == 'deploy-preview' }} | |
runs-on: ubuntu-latest | |
steps: | |
- name: Get date | |
run: | | |
echo "DATE=$(date -u +"%b %d, %Y %I:%M %p")" >> $GITHUB_ENV | |
- uses: actions/[email protected] | |
- name: Checkout fork | |
env: | |
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
id: checkout-fork | |
if: ${{ github.event.pull_request.head.repo.fork == true }} | |
run: | | |
gh pr checkout ${{ github.event.pull_request.number }} | |
git_branch=$(git rev-parse --abbrev-ref HEAD) | |
git push origin $git_branch | |
echo "branch=$git_branch" >> $GITHUB_OUTPUT | |
- name: Checkout application | |
uses: actions/[email protected] | |
with: | |
repository: clerk/clerk-marketing | |
token: ${{ secrets.CLERK_GH_TOKEN }} | |
path: app | |
ref: production | |
- run: npm install --global vercel@latest | |
- name: Pull Vercel environment information | |
run: | | |
vercel pull --yes --environment=preview --token=${{ secrets.VERCEL_TOKEN }} | |
- name: Deploy to Vercel | |
id: vercel-deploy | |
env: | |
DOCS_BRANCH: ${{ steps.checkout-fork.outputs.branch || github.event.pull_request.head.ref }} | |
run: | | |
cd app | |
git checkout -b preview/$DOCS_BRANCH | |
vercel deploy --token=${{ secrets.VERCEL_TOKEN }} --build-env DOCS_BRANCH=$DOCS_BRANCH --env DOCS_BRANCH=$DOCS_BRANCH --no-wait > deployment_url.txt | |
echo "url=$(cat deployment_url.txt)" >> $GITHUB_OUTPUT | |
- name: Create preview comment - baking | |
uses: marocchino/[email protected] | |
with: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
number: ${{ github.event.pull_request.number }} | |
header: ${{ env.COMMENT_HEADER}} | |
message: | | |
Hey @${{ github.event.sender.login }}, your docs preview is currently baking and should be available shortly. | |
| Status | Preview | Updated (UTC) | | |
| :-- | :-- | :-- | | |
| :cook: _Baking..._ | [Inspect](${{ steps.vercel-deploy.outputs.url }}) | ${{ env.DATE }} | | |
- name: Get date | |
run: | | |
echo "DATE=$(date -u +"%b %d, %Y %I:%M %p")" >> $GITHUB_ENV | |
- name: Wait for deployment | |
id: vercel-wait-for-deploy | |
run: | | |
vercel inspect --token=${{ secrets.VERCEL_TOKEN }} --wait ${{ steps.vercel-deploy.outputs.url }} --timeout 10m --scope clerk-production | |
vercel alias set ${{ steps.vercel-deploy.outputs.url }} docs-preview-${{ github.event.pull_request.number }}.clerkpreview.com --token=${{ secrets.VERCEL_TOKEN }} --scope clerk-production | |
echo "stable_url=https://docs-preview-${{ github.event.pull_request.number }}.clerkpreview.com" >> $GITHUB_OUTPUT | |
- name: Create preview comment - deployed | |
uses: marocchino/[email protected] | |
with: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
number: ${{ github.event.pull_request.number }} | |
header: ${{ env.COMMENT_HEADER }} | |
message: | | |
Hey @${{ github.event.sender.login }}, your docs preview is available. | |
| Status | Preview | Updated (UTC) | | |
| :-- | :-- | :-- | | |
| :cookie: Deployed | [Visit preview](${{ steps.vercel-wait-for-deploy.outputs.stable_url }}/docs) | ${{ env.DATE }} | | |
<!-- deployed:true --> | |
# On PR sync, trigger a revalidate of the existing deploy preview. This is much faster than a full re-deploy. | |
revalidate: | |
if: ${{ github.event.action == 'synchronize' }} | |
runs-on: ubuntu-latest | |
permissions: | |
contents: read | |
pull-requests: write | |
env: | |
CLERK_COM_BASE_URL: https://docs-preview-${{ github.event.pull_request.number }}.clerkpreview.com | |
steps: | |
- name: Find comment | |
uses: peter-evans/[email protected] | |
id: find-comment | |
with: | |
issue-number: ${{ github.event.pull_request.number }} | |
body-includes: deployed:true | |
- name: Update fork | |
env: | |
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
id: checkout-fork | |
if: ${{ github.event.pull_request.head.repo.fork == true && steps.find-comment.outputs.comment-id != 0}} | |
run: | | |
gh pr checkout ${{ github.event.pull_request.number }} | |
git_branch=$(git rev-parse --abbrev-ref HEAD) | |
git push origin $git_branch | |
- name: Get date | |
run: | | |
echo "DATE=$(date -u +"%b %d, %Y %I:%M %p")" >> $GITHUB_ENV | |
- name: Trigger revalidate | |
if: ${{ steps.find-comment.outputs.comment-id != 0 }} | |
run: | | |
curl -X POST ${{ env.CLERK_COM_BASE_URL }}/api/revalidate-docs \ | |
-H "Content-Type: application/json" \ | |
-H "Authorization: Bearer ${{ secrets.REVALIDATE_DOCS_SECRET }}" \ | |
-d "{\"paths\": \"*\"}" | |
- name: Create preview comment - updated | |
if: ${{ steps.find-comment.outputs.comment-id != 0 }} | |
uses: marocchino/[email protected] | |
with: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
number: ${{ github.event.pull_request.number }} | |
header: ${{ env.COMMENT_HEADER }} | |
message: | | |
Hey @${{ github.event.sender.login }}, your docs preview is available. | |
| Status | Preview | Updated (UTC) | | |
| :-- | :-- | :-- | | |
| :cookie: Updated | [Visit preview](${{ env.CLERK_COM_BASE_URL }}/docs) | ${{ env.DATE }} | | |
<!-- deployed:true --> |