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
30 lines
843 B
TypeScript
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 } };
|
|
});
|