Lock file maintenance deps (#53) #9
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 | |
on: | |
push: | |
branches: | |
- main | |
paths: | |
- 'scripts/**' | |
- 'src/**' | |
- 'package.json' | |
- 'pnpm-lock.yaml' | |
- 'wrangler.toml' | |
jobs: | |
deploy: | |
name: Deploy Commands & Worker | |
runs-on: ubuntu-latest | |
timeout-minutes: 60 | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@1d96c772d19495a3b5c517cd2bc0cb401ea0529f # v4 | |
- name: Install pnpm | |
uses: pnpm/action-setup@v3 | |
- name: Install Node 20 | |
uses: actions/setup-node@60edb5dd545a775178f52524783378180af0d1f8 # v4 | |
with: | |
node-version: 20 | |
cache: 'pnpm' | |
- name: Install dependencies | |
run: pnpm install --frozen-lockfile | |
- name: Create empty .dev.vars file | |
run: touch .dev.vars | |
- name: Deploy commands to Discord | |
run: pnpm run deploy-commands | |
env: | |
APPLICATION_ID: ${{ secrets.APPLICATION_ID }} | |
DISCORD_TOKEN: ${{ secrets.DISCORD_TOKEN }} | |
# The wrangler action normally installs a hardcoded version of wrangler. | |
# This step gets the version we use from package.json. | |
# See https://github.com/cloudflare/wrangler-action/issues/231#issuecomment-1976018383. | |
- name: Set wrangler version | |
id: wrangler | |
run: echo "version=$(jq -r .devDependencies.wrangler package.json | cut -c2-)" >> "$GITHUB_OUTPUT" | |
- name: Build & Deploy Worker | |
uses: cloudflare/wrangler-action@7c01cc48d88a1f83b4716e0557c168854a9dcdb8 # v3 | |
with: | |
apiToken: ${{ secrets.CLOUDFLARE_API_TOKEN }} | |
accountId: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }} | |
wranglerVersion: ${{ steps.wrangler.outputs.version }} | |
secrets: | | |
DISCORD_WEBHOOK | |
PUBLIC_KEY | |
WEBHOOK_SECRET | |
env: | |
DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }} | |
PUBLIC_KEY: ${{ secrets.PUBLIC_KEY }} | |
WEBHOOK_SECRET: ${{ secrets.WEBHOOK_SECRET }} |