Files
sistem-desa-mandiri/src/app/api/mobile/auth-token/route.ts

76 lines
2.8 KiB
TypeScript

import { prisma } from "@/module/_global";
import { funGetUserById } from "@/module/auth";
import { createLogUserMobile } from "@/module/user";
import { NextResponse } from "next/server";
export async function POST(request: Request) {
try {
const { token, user, category } = (await request.json());
const userMobile = await funGetUserById({ id: user })
if (userMobile.id == "null" || userMobile.id == undefined || userMobile.id == "") {
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 200 });
}
const cek = await prisma.tokenDeviceUser.count({
where: {
idUser: userMobile.id,
token
}
})
if (category != "register") {
// create log user
const log = await createLogUserMobile({ act: 'LOGIN', desc: 'User login', table: 'user', data: '', user: userMobile.id })
}
if (cek == 0 && token != "" && token != undefined && token != null) {
const data = await prisma.tokenDeviceUser.create({
data: {
token,
idUser: userMobile.id
}
});
return NextResponse.json({ success: true, message: "Berhasil mendaftarkan token" }, { status: 200 });
}
return NextResponse.json({ success: true, message: "Token sudah terdaftar" }, { status: 200 })
} catch (error) {
console.error(error);
return NextResponse.json({ success: false, message: "Gagal menambahkan token, coba lagi nanti (error: 500)", reason: (error as Error).message, }, { status: 500 });
}
};
export async function PUT(request: Request) {
try {
const { token, user, category } = (await request.json());
const userMobile = await funGetUserById({ id: user })
if (userMobile.id == "null" || userMobile.id == undefined || userMobile.id == "") {
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 200 });
}
if (token != "" && token != undefined && token != null) {
const data = await prisma.tokenDeviceUser.deleteMany({
where: {
token,
idUser: userMobile.id
}
});
}
if (category != "unregister") {
// create log user
const log = await createLogUserMobile({ act: 'LOGOUT', desc: 'User logout', table: 'user', data: '', user: userMobile.id })
}
return NextResponse.json({ success: true, message: "Berhasil menghapus token", }, { status: 200 });
} catch (error) {
console.error(error);
return NextResponse.json({ success: false, message: "Gagal menghapus token, coba lagi nanti (error: 500)", reason: (error as Error).message, }, { status: 500 });
}
};