Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
25 changes: 21 additions & 4 deletions .github/workflows/deploy.yml
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,8 @@ jobs:
deploy:
if: github.actor != 'dependabot[bot]'
runs-on: ubuntu-latest
env:
TARGET_ENV: ${{ github.ref == 'refs/heads/main' && 'production' || 'preview' }}
environment:
name: ${{ github.ref == 'refs/heads/main' && 'production' || 'preview' }}
url: https://coverage-tracker.zerostash.org
Expand All @@ -35,7 +37,7 @@ jobs:

- uses: actions/setup-node@48b55a011bda9f5d6aeb4c2d9c7362e8dae4041e # v6.4.0
with:
node-version: '22'
node-version: '24'
cache: npm
cache-dependency-path: |
package-lock.json
Expand All @@ -53,14 +55,29 @@ jobs:
DB_ID: ${{ secrets.CLOUDFLARE_D1_DATABASE_ID }}
run: |
# Use jq to update the database_id inside the d1_databases array
jq --arg new_val "${DB_ID}" '.env.prod.d1_databases[0].database_id = $new_val' wrangler.json > wrangler.json.tmp
jq --arg new_val "${DB_ID}" '.env."${TARGET_ENV}".d1_databases[0].database_id = $new_val' wrangler.json > wrangler.json.tmp

# Replace the old file with the newly updated one
mv wrangler.json.tmp wrangler.json

- name: Set up secrets
env:
GITHUB_APP_ID: ${{ secrets.GITHUB_APP_ID }}
GITHUB_APP_CLIENT_ID: ${{ secrets.GITHUB_APP_CLIENT_ID }}
GITHUB_APP_PRIVATE_KEY: ${{ secrets.GITHUB_APP_PRIVATE_KEY }}
GITHUB_WEBHOOK_SECRET: ${{ secrets.GITHUB_WEBHOOK_SECRET }}
CF_ACCESS_AUD: ${{ secrets.CF_ACCESS_AUD }}
CF_ACCESS_TEAM_DOMAIN: ${{ secrets.CF_ACCESS_TEAM_DOMAIN }}
run: |
echo "$GITHUB_APP_ID" | npx wrangler secret put GITHUB_APP_ID --env "$TARGET_ENV"
echo "$GITHUB_APP_CLIENT_ID" | npx wrangler secret put GITHUB_APP_CLIENT_ID --env "$TARGET_ENV"
echo "$GITHUB_APP_PRIVATE_KEY" | npx wrangler secret put GITHUB_APP_PRIVATE_KEY --env "$TARGET_ENV"
echo "$GITHUB_WEBHOOK_SECRET" | npx wrangler secret put GITHUB_WEBHOOK_SECRET --env "$TARGET_ENV"
echo "$CF_ACCESS_AUD" | npx wrangler secret put CF_ACCESS_AUD --env "$TARGET_ENV"
echo "$CF_ACCESS_TEAM_DOMAIN" | npx wrangler secret put CF_ACCESS_TEAM_DOMAIN --env "$TARGET_ENV"

- name: Deploy Worker + assets
if: github.ref == 'refs/heads/main'
run: npx wrangler deploy --env prod
run: npx wrangler deploy --env "$TARGET_ENV"
env:
CLOUDFLARE_API_TOKEN: ${{ secrets.CLOUDFLARE_API_TOKEN }}
CLOUDFLARE_ACCOUNT_ID: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }}
4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,12 @@
"private": true,
"scripts": {
"dev": "wrangler dev --env dev",
"deploy": "wrangler d1 migrations apply DB --remote && wrangler deploy",
"deploy": "wrangler d1 migrations apply DB --remote && wrangler deploy --env production",
"typecheck": "tsc --noEmit",
"test": "vitest run",
"db:migrate:local": "wrangler d1 migrations apply DB --local --env dev",
"db:seed:local": "wrangler d1 execute DB --local --file test/seed-local.sql --env dev",
"db:migrate:remote": "wrangler d1 migrations apply DB --remote"
"db:migrate:remote": "wrangler d1 migrations apply DB --remote --env production"
},
"dependencies": {
"hono": "^4.6.0",
Expand Down
14 changes: 12 additions & 2 deletions worker-configuration.d.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/* eslint-disable */
// Generated by Wrangler by running `wrangler types` (hash: 4da199130f00b626578a818ba765ff7b)
// Generated by Wrangler by running `wrangler types` (hash: fe199aae2c0315020845f5624581203b)
// Runtime types generated with workerd@1.20260625.1 2026-06-25 nodejs_compat
interface __BaseEnv_Env {
DB?: D1Database;
Expand All @@ -21,7 +21,17 @@ declare namespace Cloudflare {
ASSETS: Fetcher;
DEV_BYPASS_SECRET: string;
}
interface ProdEnv {
interface ProductionEnv {
DB: D1Database;
ASSETS: Fetcher;
GITHUB_APP_ID: string;
GITHUB_APP_CLIENT_ID: string;
GITHUB_APP_PRIVATE_KEY: string;
GITHUB_WEBHOOK_SECRET: string;
CF_ACCESS_AUD: string;
CF_ACCESS_TEAM_DOMAIN: string;
}
interface PreviewEnv {
DB: D1Database;
ASSETS: Fetcher;
GITHUB_APP_ID: string;
Expand Down
21 changes: 20 additions & 1 deletion wrangler.json
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@
]
}
},
"prod": {
"production": {
"observability": { "enabled": true },
"triggers": { "crons": ["30 6 * * *"] },
"d1_databases": [
Expand All @@ -49,6 +49,25 @@
"CF_ACCESS_TEAM_DOMAIN"
]
}
},
"preview": {
"d1_databases": [
{
"binding": "DB",
"database_name": "coverage",
"migrations_dir": "migrations"
}
],
"secrets": {
"required": [
"GITHUB_APP_ID",
"GITHUB_APP_CLIENT_ID",
"GITHUB_APP_PRIVATE_KEY",
"GITHUB_WEBHOOK_SECRET",
"CF_ACCESS_AUD",
"CF_ACCESS_TEAM_DOMAIN"
]
}
}
}
}
Loading