Merge pull request #342 from bipproduction/amalia/20-nov-24
upd: web push
This commit is contained in:
@@ -124,7 +124,7 @@ model User {
|
|||||||
DivisionCalendarMember DivisionCalendarMember[]
|
DivisionCalendarMember DivisionCalendarMember[]
|
||||||
Notifications Notifications[] @relation("UserToUser")
|
Notifications Notifications[] @relation("UserToUser")
|
||||||
Notifications2 Notifications[] @relation("UserFromUser")
|
Notifications2 Notifications[] @relation("UserFromUser")
|
||||||
Subscribe Subscribe[]
|
Subscribe Subscribe?
|
||||||
}
|
}
|
||||||
|
|
||||||
model UserLog {
|
model UserLog {
|
||||||
@@ -518,4 +518,4 @@ model Subscribe {
|
|||||||
subscription String @db.Text
|
subscription String @db.Text
|
||||||
createdAt DateTime? @default(now())
|
createdAt DateTime? @default(now())
|
||||||
updatedAt DateTime? @updatedAt
|
updatedAt DateTime? @updatedAt
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
import { prisma } from "@/module/_global";
|
import { funSendWebPush, prisma } from "@/module/_global";
|
||||||
import { funGetUserByCookies } from "@/module/auth";
|
import { funGetUserByCookies } from "@/module/auth";
|
||||||
import _ from "lodash";
|
import _ from "lodash";
|
||||||
import moment from "moment";
|
import moment from "moment";
|
||||||
@@ -160,14 +160,25 @@ export async function POST(request: Request) {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
select: {
|
select: {
|
||||||
idUser: true
|
idUser: true,
|
||||||
|
User: {
|
||||||
|
select: {
|
||||||
|
Subscribe: {
|
||||||
|
select: {
|
||||||
|
subscription: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
// mengirim notifikasi
|
||||||
|
// datanotif untuk realtime notifikasi
|
||||||
|
// datapush untuk web push notifikasi ketika aplikasi tidak aktif
|
||||||
const dataNotif = memberNotif.map((v: any) => ({
|
const dataNotif = memberNotif.map((v: any) => ({
|
||||||
..._.omit(v, ["idUser"]),
|
..._.omit(v, ["idUser", "User", "Subscribe"]),
|
||||||
idUserTo: v.idUser,
|
idUserTo: v.idUser,
|
||||||
idUserFrom: userId,
|
idUserFrom: userId,
|
||||||
category: 'announcement',
|
category: 'announcement',
|
||||||
@@ -176,15 +187,30 @@ export async function POST(request: Request) {
|
|||||||
desc: 'Anda memiliki pengumuman baru. Silahkan periksa detailnya.'
|
desc: 'Anda memiliki pengumuman baru. Silahkan periksa detailnya.'
|
||||||
}))
|
}))
|
||||||
|
|
||||||
|
const dataPush = memberNotif.map((v: any) => ({
|
||||||
|
..._.omit(v, ["idUser", "User", "Subscribe"]),
|
||||||
|
idUser: v.idUser,
|
||||||
|
subscription: v.User.Subscribe?.subscription,
|
||||||
|
}))
|
||||||
|
|
||||||
if (userRoleLogin != "supadmin") {
|
if (userRoleLogin != "supadmin") {
|
||||||
const perbekel = await prisma.user.findFirst({
|
const perbekel = await prisma.user.findFirst({
|
||||||
where: {
|
where: {
|
||||||
isActive: true,
|
isActive: true,
|
||||||
idUserRole: "supadmin",
|
idUserRole: "supadmin",
|
||||||
idVillage: user.idVillage
|
idVillage: user.idVillage
|
||||||
|
},
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
Subscribe: {
|
||||||
|
select: {
|
||||||
|
subscription: true
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
dataNotif.push({
|
dataNotif.push({
|
||||||
idUserTo: perbekel?.id,
|
idUserTo: perbekel?.id,
|
||||||
idUserFrom: userId,
|
idUserFrom: userId,
|
||||||
@@ -193,8 +219,17 @@ export async function POST(request: Request) {
|
|||||||
title: 'Pengumuman Baru',
|
title: 'Pengumuman Baru',
|
||||||
desc: 'Anda memiliki pengumuman baru. Silahkan periksa detailnya.'
|
desc: 'Anda memiliki pengumuman baru. Silahkan periksa detailnya.'
|
||||||
})
|
})
|
||||||
|
|
||||||
|
dataPush.push({
|
||||||
|
idUser: perbekel?.id,
|
||||||
|
subscription: perbekel?.Subscribe?.subscription
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const pushNotif = dataPush.filter((item) => item.subscription != undefined)
|
||||||
|
|
||||||
|
const sendWebPush = await funSendWebPush({ sub: pushNotif, message: { title: 'Pengumuman Baru', body: 'Anda memiliki pengumuman baru. Silahkan periksa detailnya.' } })
|
||||||
const insertNotif = await prisma.notifications.createMany({
|
const insertNotif = await prisma.notifications.createMany({
|
||||||
data: dataNotif
|
data: dataNotif
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
import { prisma } from "@/module/_global";
|
import { funSendWebPush, prisma } from "@/module/_global";
|
||||||
import { funGetUserByCookies } from "@/module/auth";
|
import { funGetUserByCookies } from "@/module/auth";
|
||||||
import { createLogUser } from "@/module/user";
|
import { createLogUser } from "@/module/user";
|
||||||
import _ from "lodash";
|
import _ from "lodash";
|
||||||
@@ -134,15 +134,23 @@ export async function POST(request: Request) {
|
|||||||
select: {
|
select: {
|
||||||
User: {
|
User: {
|
||||||
select: {
|
select: {
|
||||||
id: true
|
id: true,
|
||||||
|
Subscribe: {
|
||||||
|
select: {
|
||||||
|
subscription: true
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
// mengirim notifikasi
|
||||||
|
// datanotif untuk realtime notifikasi
|
||||||
|
// datapush untuk web push notifikasi ketika aplikasi tidak aktif
|
||||||
const dataNotif = memberDivision.map((v: any) => ({
|
const dataNotif = memberDivision.map((v: any) => ({
|
||||||
..._.omit(v, ["User"]),
|
..._.omit(v, ["User", "Subscribe"]),
|
||||||
idUserTo: v.User.id,
|
idUserTo: v.User.id,
|
||||||
idUserFrom: String(user.id),
|
idUserFrom: String(user.id),
|
||||||
category: 'division/' + idDivision + '/discussion',
|
category: 'division/' + idDivision + '/discussion',
|
||||||
@@ -151,12 +159,26 @@ export async function POST(request: Request) {
|
|||||||
desc: 'Terdapat diskusi baru. Silahkan periksa detailnya.'
|
desc: 'Terdapat diskusi baru. Silahkan periksa detailnya.'
|
||||||
}))
|
}))
|
||||||
|
|
||||||
|
const dataPush = memberDivision.map((v: any) => ({
|
||||||
|
..._.omit(v, ["User", "Subscribe"]),
|
||||||
|
idUser: v.User.id,
|
||||||
|
subscription: v.User.Subscribe?.subscription,
|
||||||
|
}))
|
||||||
|
|
||||||
if (userRoleLogin != "supadmin") {
|
if (userRoleLogin != "supadmin") {
|
||||||
const perbekel = await prisma.user.findFirst({
|
const perbekel = await prisma.user.findFirst({
|
||||||
where: {
|
where: {
|
||||||
isActive: true,
|
isActive: true,
|
||||||
idUserRole: "supadmin",
|
idUserRole: "supadmin",
|
||||||
idVillage: user.idVillage
|
idVillage: user.idVillage
|
||||||
|
},
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
Subscribe: {
|
||||||
|
select: {
|
||||||
|
subscription: true
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -168,6 +190,11 @@ export async function POST(request: Request) {
|
|||||||
title: 'Diskusi Baru',
|
title: 'Diskusi Baru',
|
||||||
desc: 'Terdapat diskusi baru. Silahkan periksa detailnya.'
|
desc: 'Terdapat diskusi baru. Silahkan periksa detailnya.'
|
||||||
})
|
})
|
||||||
|
|
||||||
|
dataPush.push({
|
||||||
|
idUser: perbekel?.id,
|
||||||
|
subscription: perbekel?.Subscribe?.subscription
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
if (userRoleLogin != "cosupadmin") {
|
if (userRoleLogin != "cosupadmin") {
|
||||||
@@ -176,6 +203,14 @@ export async function POST(request: Request) {
|
|||||||
isActive: true,
|
isActive: true,
|
||||||
idUserRole: "cosupadmin",
|
idUserRole: "cosupadmin",
|
||||||
idGroup: user.idGroup
|
idGroup: user.idGroup
|
||||||
|
},
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
Subscribe: {
|
||||||
|
select: {
|
||||||
|
subscription: true
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -187,8 +222,16 @@ export async function POST(request: Request) {
|
|||||||
title: 'Diskusi Baru',
|
title: 'Diskusi Baru',
|
||||||
desc: 'Terdapat diskusi baru. Silahkan periksa detailnya.'
|
desc: 'Terdapat diskusi baru. Silahkan periksa detailnya.'
|
||||||
})
|
})
|
||||||
|
|
||||||
|
dataPush.push({
|
||||||
|
idUser: ketuaGrup?.id,
|
||||||
|
subscription: ketuaGrup?.Subscribe?.subscription
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const pushNotif = dataPush.filter((item) => item.subscription != undefined)
|
||||||
|
|
||||||
|
const sendWebPush = await funSendWebPush({ sub: pushNotif, message: { body: 'Terdapat diskusi baru. Silahkan periksa detailnya.', title: 'Diskusi Baru' } })
|
||||||
const insertNotif = await prisma.notifications.createMany({
|
const insertNotif = await prisma.notifications.createMany({
|
||||||
data: dataNotif
|
data: dataNotif
|
||||||
})
|
})
|
||||||
|
|||||||
26
src/module/_global/fun/send_web_push.ts
Normal file
26
src/module/_global/fun/send_web_push.ts
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
import { WibuServerPush } from "wibu-pkg";
|
||||||
|
|
||||||
|
export async function funSendWebPush({ sub, message }: { sub: { idUser: string, subscription: string }[], message: { body: string, title: string } }) {
|
||||||
|
try {
|
||||||
|
const subs: PushSubscription[] = sub.map((v) => JSON.parse(v.subscription)) as PushSubscription[]
|
||||||
|
|
||||||
|
const kirim = await WibuServerPush.sendMany({
|
||||||
|
subscriptions: subs as any,
|
||||||
|
data: {
|
||||||
|
body: message.body,
|
||||||
|
title: message.title,
|
||||||
|
link: "/home?cat=notification",
|
||||||
|
variant: "notification"
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
if (kirim) {
|
||||||
|
return { success: true, message: "Berhasil mengirim notifikasi" }
|
||||||
|
}
|
||||||
|
|
||||||
|
return { success: false, message: "Gagal mengirim notifikasi" }
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Send web push notification error", error);
|
||||||
|
return { success: false, message: "Gagal mengirim notifikasi" }
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -26,6 +26,7 @@ import { ScrollProvider } from "./components/scroll_provider";
|
|||||||
import SkeletonUser from "./components/skeleton_user";
|
import SkeletonUser from "./components/skeleton_user";
|
||||||
import SkeletonList from "./components/skeleton_list";
|
import SkeletonList from "./components/skeleton_list";
|
||||||
import { funViewDir } from "./fun/view_dir";
|
import { funViewDir } from "./fun/view_dir";
|
||||||
|
import { funSendWebPush } from "./fun/send_web_push";
|
||||||
|
|
||||||
export { WARNA };
|
export { WARNA };
|
||||||
export { LayoutLogin };
|
export { LayoutLogin };
|
||||||
@@ -61,3 +62,4 @@ export { SkeletonUser }
|
|||||||
export { SkeletonList }
|
export { SkeletonList }
|
||||||
export { keyWibu }
|
export { keyWibu }
|
||||||
export { funViewDir }
|
export { funViewDir }
|
||||||
|
export { funSendWebPush }
|
||||||
|
|||||||
Reference in New Issue
Block a user