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
No description provided
Readme 394 KiB
Languages
TypeScript 98.2%
Dockerfile 1.8%