A lightweight Express service that schedules and sends Firebase Cloud Messaging (FCM) push notifications to wake up registered devices.
Dev
cp .env.example .env
Edit .env — set FIREBASE_SERVICE_ACCOUNT_JSON
Here is one way to generate the contents: cat your-downloaded-key.json | jq -c .
pnpm install
pnpm run dev
The server starts on http://localhost:3003 (or the port in PORT). Hot-reloads on file changes.
Set NODE_ENV=test-local in .env to bypass JWT expiry verification during local development.
Production
Runs TypeScript directly via tsx (no compile step).
pnpm install --prod
pnpm start
Or with Docker:
docker build --no-cache -t notify-wakeup-api:amd-$NOTIFY_WAKEUP_API_VERSION --platform linux/amd64 .
docker run --env-file notify-wakeup-api.env -p 3003:3003 notify-wakeup-api
Required environment variables:
| Variable | Description |
|---|---|
FIREBASE_SERVICE_ACCOUNT_JSON |
Inline service account JSON (one line). If unset, falls back to Application Default Credentials. |
PORT |
HTTP port (default: 3003). |
FCM_TOKEN_DATA_DIR |
Directory for persisting registered FCM tokens (default: ./data). |
Description
Languages
TypeScript
98.2%
Dockerfile
1.8%