rebreak-monorepo/backend/server/api/users/me/push-token.delete.ts
chahinebrini 38df6fc79d feat(chat): push notifications for DMs + rooms
Backend:
- Prisma PushToken model + chat_push_enabled flag on profiles
- Migration 20260530_add_push_tokens (push_tokens table + profile flag)
- Service sendChatPush with expo-server-sdk (auto-disable invalid tokens)
- Fire-and-forget push trigger in sendDirectMessage + createRoomMessage
- API POST /users/me/push-token (upsert) + DELETE (soft-disable)

Client (rebreak-native):
- usePushTokenRegistration hook: permission, getExpoPushTokenAsync,
  Android channel 'chat', POST to backend; idempotent per session
- Notification tap deep-link: dm -> /dm?userId, room -> /room?roomId

Deploy:
- run_quiet spinner for silent altool/xcodebuild/gradle phases
- Release-notes pipeline (--notes flag / NEXT_RELEASE.md / interactive)
  archived to CHANGELOG.md, printed with ASC + Play Console links
- Default version bump ON (--no-bump opt-out), build cleanup
- NEXT_RELEASE.md with push-notification release note
2026-05-30 08:16:45 +02:00

30 lines
843 B
TypeScript

/**
* DELETE /api/users/me/push-token?token=ExponentPushToken[xxx]
*
* Client deregistriert Token (Logout, Permission-Revoke, App-Uninstall-Cleanup).
* Wir setzen `enabled = false` statt zu löschen — Audit-Trail bleibt erhalten.
*/
import { requireUser } from "../../../utils/auth";
import { usePrisma } from "../../../utils/prisma";
export default defineEventHandler(async (event) => {
const user = await requireUser(event);
const query = getQuery(event);
const token = typeof query.token === "string" ? query.token : "";
if (!token) {
throw createError({
statusCode: 400,
data: { error: "MISSING_TOKEN" },
});
}
const db = usePrisma();
await db.pushToken.updateMany({
where: { token, userId: user.id },
data: { enabled: false },
});
return { success: true, data: { ok: true } };
});