upd: fungsi delete iddevice yg gagal fcm
This commit is contained in:
@@ -100,14 +100,15 @@ export async function GET(request: Request) {
|
|||||||
createdAt: moment(v.createdAt).format("ll")
|
createdAt: moment(v.createdAt).format("ll")
|
||||||
}))
|
}))
|
||||||
|
|
||||||
// await sendFCMNotification('c89yuexsS_uc1tOErVPu5a:APA91bEb6tEKXAfReZjFVJ2mMyOzoW_RXryLSnSJTpbIVV3G0L_DCNkLuRvJ02Ip-Erz88QCQBAt-C2SN8eCRxu3-v1sBzXzKPtDv-huXpkjXsyrkifqvUo')
|
|
||||||
await sendFCMNotificationMany({
|
await sendFCMNotificationMany({
|
||||||
token: [
|
token: [
|
||||||
'c89yuexsS_uc1tOErVPu5a:APA91bEb6tEKXAfReZjFVJ2mMyOzoW_RXryLSnSJTpbIVV3G0L_DCNkLuRvJ02Ip-Erz88QCQBAt-C2SN8eCRxu3-v1sBzXzKPtDv-huXpkjXsyrkifqvUo',
|
'c89yuexsS_uc1tOErVPu5a:APA91bEb6tEKXAfReZjFVJ2mMyOzoW_RXryLSnSJTpbIVV3G0L_DCNkLuRvJ02Ip-Erz88QCQBAt-C2SN8eCRxu3-v1sBzXzKPtDv-huXpkjXsyrkifqvUo',
|
||||||
'cRz96GHKTRaQaRJ35e8Hxa:APA91bEUSxE0VPbqKSzseQ_zGhbYsDofMexKykRw7o_3z2aPM9YFmZbeA2enrmb3qjdZ2g4-QQtiNHAyaZqAT1ITOrwo9jVJlShTeABmEFYP5GLEUZ3dlLc'
|
'cRz96GHKTRaQaRJ35e8Hxa:APA91bEUSxE0VPbqKSzseQ_zGhbYsDofMexKykRw7o_3z2aPM9YFmZbeA2enrmb3qjdZ2g4-QQtiNHAyaZqAT1ITOrwo9jVJlShTeABmEFYP5GLEUZ3dlLc',
|
||||||
|
'gagal_device1',
|
||||||
|
'gagal_device2'
|
||||||
],
|
],
|
||||||
title: "Judul Notifikasi Pengumuman",
|
title: "Judul Notifikasi Pengumuman api biasa",
|
||||||
body: "Pengumuman untuk perangkat",
|
body: "Pengumuman untuk perangkat api biasa",
|
||||||
data: { id: "cm1eqwkwj00067j2bzejyh9u7", category: "division", content: "cm1eqwkvu00017j2b8qnisp9g" }
|
data: { id: "cm1eqwkwj00067j2bzejyh9u7", category: "division", content: "cm1eqwkvu00017j2b8qnisp9g" }
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
@@ -9,10 +9,12 @@ const ApiV2 = new elysia({
|
|||||||
await sendFCMNotificationMany({
|
await sendFCMNotificationMany({
|
||||||
token: [
|
token: [
|
||||||
'c89yuexsS_uc1tOErVPu5a:APA91bEb6tEKXAfReZjFVJ2mMyOzoW_RXryLSnSJTpbIVV3G0L_DCNkLuRvJ02Ip-Erz88QCQBAt-C2SN8eCRxu3-v1sBzXzKPtDv-huXpkjXsyrkifqvUo',
|
'c89yuexsS_uc1tOErVPu5a:APA91bEb6tEKXAfReZjFVJ2mMyOzoW_RXryLSnSJTpbIVV3G0L_DCNkLuRvJ02Ip-Erz88QCQBAt-C2SN8eCRxu3-v1sBzXzKPtDv-huXpkjXsyrkifqvUo',
|
||||||
'cRz96GHKTRaQaRJ35e8Hxa:APA91bEUSxE0VPbqKSzseQ_zGhbYsDofMexKykRw7o_3z2aPM9YFmZbeA2enrmb3qjdZ2g4-QQtiNHAyaZqAT1ITOrwo9jVJlShTeABmEFYP5GLEUZ3dlLc'
|
'cRz96GHKTRaQaRJ35e8Hxa:APA91bEUSxE0VPbqKSzseQ_zGhbYsDofMexKykRw7o_3z2aPM9YFmZbeA2enrmb3qjdZ2g4-QQtiNHAyaZqAT1ITOrwo9jVJlShTeABmEFYP5GLEUZ3dlLc',
|
||||||
|
'gagal_device1',
|
||||||
|
'gagal_device2'
|
||||||
],
|
],
|
||||||
title: "Judul Notifikasi Pengumuman",
|
title: "Judul Notifikasi Pengumuman Elysia",
|
||||||
body: "Pengumuman untuk perangkat",
|
body: "Pengumuman untuk perangkat Elysia",
|
||||||
data: { id: "cm1eqwkwj00067j2bzejyh9u7", category: "division", content: "cm1eqwkvu00017j2b8qnisp9g" }
|
data: { id: "cm1eqwkwj00067j2bzejyh9u7", category: "division", content: "cm1eqwkvu00017j2b8qnisp9g" }
|
||||||
})
|
})
|
||||||
return {
|
return {
|
||||||
|
|||||||
@@ -44,7 +44,6 @@ export async function sendFCM(token: string[], title: string, body: string) {
|
|||||||
tokens: token,
|
tokens: token,
|
||||||
...message,
|
...message,
|
||||||
})
|
})
|
||||||
console.log("✅ FCM berhasil dikirim:", result);
|
|
||||||
if (result.failureCount > 0) {
|
if (result.failureCount > 0) {
|
||||||
const failedTokens: any[] = [];
|
const failedTokens: any[] = [];
|
||||||
result.responses.forEach((resp, idx) => {
|
result.responses.forEach((resp, idx) => {
|
||||||
|
|||||||
17
src/module/_global/fun/delete_device_error.ts
Normal file
17
src/module/_global/fun/delete_device_error.ts
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
import { prisma } from "@/module/_global";
|
||||||
|
|
||||||
|
export default async function deleteDeviceError({ device }: { device: string[] }) {
|
||||||
|
try {
|
||||||
|
const deleteToken = await prisma.tokenDeviceUser.deleteMany({
|
||||||
|
where: {
|
||||||
|
token: {
|
||||||
|
in: device
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return { success: true, message: "Success" }
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error)
|
||||||
|
return { success: false, message: "Internal Server Error" }
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -30,6 +30,7 @@ import { funSendWebPush } from "./fun/send_web_push";
|
|||||||
import ViewFilterData from "./view/view_filter_kategori_data";
|
import ViewFilterData from "./view/view_filter_kategori_data";
|
||||||
import LayoutModalNew from "./layout/layout_modal_new";
|
import LayoutModalNew from "./layout/layout_modal_new";
|
||||||
import { funReadPdf } from "./fun/read_pdf";
|
import { funReadPdf } from "./fun/read_pdf";
|
||||||
|
import deleteDeviceError from "./fun/delete_device_error";
|
||||||
|
|
||||||
export { WARNA };
|
export { WARNA };
|
||||||
export { LayoutLogin };
|
export { LayoutLogin };
|
||||||
@@ -69,3 +70,4 @@ export { funSendWebPush }
|
|||||||
export { ViewFilterData }
|
export { ViewFilterData }
|
||||||
export { LayoutModalNew }
|
export { LayoutModalNew }
|
||||||
export { funReadPdf }
|
export { funReadPdf }
|
||||||
|
export { deleteDeviceError }
|
||||||
15
xsendMany.ts
15
xsendMany.ts
@@ -1,4 +1,4 @@
|
|||||||
// Impor Firebase Admin SDK
|
import { deleteDeviceError } from '@/module/_global';
|
||||||
import CryptoJs from 'crypto-js';
|
import CryptoJs from 'crypto-js';
|
||||||
import { cert, getApps, initializeApp } from "firebase-admin/app";
|
import { cert, getApps, initializeApp } from "firebase-admin/app";
|
||||||
import { getMessaging } from "firebase-admin/messaging";
|
import { getMessaging } from "firebase-admin/messaging";
|
||||||
@@ -46,8 +46,17 @@ export async function sendFCMNotificationMany({ token, title, body, data }: { to
|
|||||||
tokens: token,
|
tokens: token,
|
||||||
...message,
|
...message,
|
||||||
} as any);
|
} as any);
|
||||||
console.log("Notifikasi berhasil dikirim:", response);
|
if (response.failureCount > 0) {
|
||||||
return response;
|
const failedTokens: any[] = [];
|
||||||
|
response.responses.forEach((resp, idx) => {
|
||||||
|
if (!resp.success) {
|
||||||
|
failedTokens.push(token[idx]);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
const del = await deleteDeviceError({ device: failedTokens });
|
||||||
|
}
|
||||||
|
|
||||||
|
return { success: true, message: "Notifikasi berhasil dikirim", };
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error("Error mengirim notifikasi:", error);
|
console.error("Error mengirim notifikasi:", error);
|
||||||
throw error;
|
throw error;
|
||||||
|
|||||||
Reference in New Issue
Block a user