Merge pull request #448 from bipproduction/amalia/19-mei-25
Amalia/19 mei 25
This commit is contained in:
@@ -1,6 +1,6 @@
|
|||||||
import { DIR, funDeleteFile, funUploadFile, prisma } from "@/module/_global";
|
import { DIR, funDeleteFile, funUploadFile, prisma } from "@/module/_global";
|
||||||
import { funGetUserByCookies } from "@/module/auth";
|
import { funGetUserById } from "@/module/auth";
|
||||||
import { createLogUser } from "@/module/user";
|
import { createLogUserMobile } from "@/module/user";
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
|
||||||
|
|
||||||
@@ -8,9 +8,12 @@ import { NextResponse } from "next/server";
|
|||||||
export async function GET(request: Request, context: { params: { id: string } }) {
|
export async function GET(request: Request, context: { params: { id: string } }) {
|
||||||
try {
|
try {
|
||||||
const { id } = context.params;
|
const { id } = context.params;
|
||||||
const user = await funGetUserByCookies()
|
const { searchParams } = new URL(request.url);
|
||||||
if (user.id == undefined) {
|
const user = searchParams.get("user")
|
||||||
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 401 });
|
const userLogin = await funGetUserById({ id: String(user) })
|
||||||
|
|
||||||
|
if (userLogin.id == "null" || userLogin.id == undefined || userLogin.id == "") {
|
||||||
|
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 200 });
|
||||||
}
|
}
|
||||||
|
|
||||||
const data = await prisma.bannerImage.findUnique({
|
const data = await prisma.bannerImage.findUnique({
|
||||||
@@ -31,9 +34,10 @@ export async function GET(request: Request, context: { params: { id: string } })
|
|||||||
export async function DELETE(request: Request, context: { params: { id: string } }) {
|
export async function DELETE(request: Request, context: { params: { id: string } }) {
|
||||||
try {
|
try {
|
||||||
const { id } = context.params;
|
const { id } = context.params;
|
||||||
const user = await funGetUserByCookies()
|
const { user } = (await request.json());
|
||||||
if (user.id == undefined) {
|
const userLogin = await funGetUserById({ id: user })
|
||||||
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 401 });
|
if (userLogin.id == "null" || userLogin.id == undefined || userLogin.id == "") {
|
||||||
|
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 200 });
|
||||||
}
|
}
|
||||||
|
|
||||||
const upd = await prisma.bannerImage.update({
|
const upd = await prisma.bannerImage.update({
|
||||||
@@ -47,7 +51,7 @@ export async function DELETE(request: Request, context: { params: { id: string }
|
|||||||
|
|
||||||
|
|
||||||
// create log user
|
// create log user
|
||||||
const log = await createLogUser({ act: 'DELETE', desc: 'User menghapus banner', table: 'bannerImage', data: id })
|
const log = await createLogUserMobile({ act: 'DELETE', desc: 'User menghapus banner', table: 'bannerImage', data: id, user: String(userLogin.id) })
|
||||||
|
|
||||||
return NextResponse.json({ success: true, message: "Berhasil menghapus banner" }, { status: 200 });
|
return NextResponse.json({ success: true, message: "Berhasil menghapus banner" }, { status: 200 });
|
||||||
|
|
||||||
@@ -62,17 +66,18 @@ export async function DELETE(request: Request, context: { params: { id: string }
|
|||||||
export async function PUT(request: Request, context: { params: { id: string } }) {
|
export async function PUT(request: Request, context: { params: { id: string } }) {
|
||||||
try {
|
try {
|
||||||
const { id } = context.params;
|
const { id } = context.params;
|
||||||
const user = await funGetUserByCookies()
|
|
||||||
if (user.id == undefined) {
|
|
||||||
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 401 });
|
|
||||||
}
|
|
||||||
|
|
||||||
const body = await request.formData()
|
const body = await request.formData()
|
||||||
const file = body.get("file") as File
|
const file = body.get("file") as File
|
||||||
const data = body.get("data")
|
const data = body.get("data")
|
||||||
const { title } = JSON.parse(data as string)
|
const { title, user } = JSON.parse(data as string)
|
||||||
|
|
||||||
|
|
||||||
|
const userLogin = await funGetUserById({ id: user })
|
||||||
|
|
||||||
|
if (userLogin.id == "null" || userLogin.id == undefined || userLogin.id == "") {
|
||||||
|
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 200 });
|
||||||
|
}
|
||||||
|
|
||||||
const upd = await prisma.bannerImage.update({
|
const upd = await prisma.bannerImage.update({
|
||||||
where: {
|
where: {
|
||||||
id: String(id)
|
id: String(id)
|
||||||
@@ -102,7 +107,7 @@ export async function PUT(request: Request, context: { params: { id: string } })
|
|||||||
}
|
}
|
||||||
|
|
||||||
// create log user
|
// create log user
|
||||||
const log = await createLogUser({ act: 'UPDATE', desc: 'User mengupdate data banner', table: 'bannerImage', data: user.id })
|
const log = await createLogUserMobile({ act: 'UPDATE', desc: 'User mengupdate data banner', table: 'bannerImage', data: id, user: String(userLogin.id) })
|
||||||
|
|
||||||
return NextResponse.json({ success: true, message: "Berhasil mengupdate banner" }, { status: 200 });
|
return NextResponse.json({ success: true, message: "Berhasil mengupdate banner" }, { status: 200 });
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
import { DIR, funUploadFile, funViewDir, prisma } from "@/module/_global";
|
import { DIR, funUploadFile, prisma } from "@/module/_global";
|
||||||
import { funGetUserById } from "@/module/auth";
|
import { funGetUserById } from "@/module/auth";
|
||||||
import { createLogUser } from "@/module/user";
|
import { createLogUserMobile } from "@/module/user";
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
|
||||||
|
|
||||||
@@ -38,32 +38,22 @@ export async function GET(request: Request) {
|
|||||||
// CREATE BANNER
|
// CREATE BANNER
|
||||||
export async function POST(request: Request) {
|
export async function POST(request: Request) {
|
||||||
try {
|
try {
|
||||||
console.log('masuklas')
|
|
||||||
console.log(request)
|
|
||||||
const body = await request.formData()
|
const body = await request.formData()
|
||||||
const fileAwal = body.get("file");
|
const file = body.get("file") as File;
|
||||||
const file = JSON.parse(fileAwal as string)
|
|
||||||
const fileFix = file as File
|
|
||||||
const fileCoba = new File([fileFix], fileFix.name, { type: fileFix.type});
|
|
||||||
const data = body.get("data");
|
const data = body.get("data");
|
||||||
|
|
||||||
console.log(body, fileCoba)
|
|
||||||
|
|
||||||
const { title, user } = JSON.parse(data as string)
|
const { title, user } = JSON.parse(data as string)
|
||||||
|
|
||||||
if (user == "null" || user == undefined || user == "") {
|
|
||||||
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 401 });
|
|
||||||
}
|
|
||||||
|
|
||||||
const userLogin = await funGetUserById({ id: user })
|
const userLogin = await funGetUserById({ id: user })
|
||||||
|
|
||||||
|
if (userLogin.id == "null" || userLogin.id == undefined || userLogin.id == "") {
|
||||||
|
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 200 });
|
||||||
|
}
|
||||||
|
|
||||||
const fExt = fileCoba.name.split(".").pop()
|
|
||||||
const fName = fileCoba.name.replace("." + fExt, "")
|
|
||||||
const newFile = new File([fileCoba], fileCoba.name, { type: fileCoba.type });
|
|
||||||
|
|
||||||
const ini = funViewDir({ dirId: DIR.user })
|
const fExt = file.name.split(".").pop()
|
||||||
const upload = await funUploadFile({ file: fileCoba, dirId: DIR.banner })
|
const newFile = new File([file], file.name, { type: file.type });
|
||||||
|
|
||||||
|
const upload = await funUploadFile({ file: newFile, dirId: DIR.banner })
|
||||||
if (upload.success) {
|
if (upload.success) {
|
||||||
const create = await prisma.bannerImage.create({
|
const create = await prisma.bannerImage.create({
|
||||||
data: {
|
data: {
|
||||||
@@ -71,12 +61,14 @@ export async function POST(request: Request) {
|
|||||||
idVillage: userLogin.idVillage,
|
idVillage: userLogin.idVillage,
|
||||||
extension: String(fExt),
|
extension: String(fExt),
|
||||||
image: upload.data.id
|
image: upload.data.id
|
||||||
|
},
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
// create log user
|
// create log user
|
||||||
const log = await createLogUser({ act: 'CREATE', desc: 'User menambah data banner baru', table: 'bannerImage', data: String(userLogin.id) })
|
const log = await createLogUserMobile({ act: 'CREATE', desc: 'User menambah data banner baru', table: 'bannerImage', data: String(create.id), user: String(userLogin.id) })
|
||||||
|
|
||||||
return Response.json({ success: true, message: 'Sukses menambah data banner' }, { status: 200 });
|
return Response.json({ success: true, message: 'Sukses menambah data banner' }, { status: 200 });
|
||||||
} else {
|
} else {
|
||||||
return Response.json({ success: false, message: 'Gagal menambah data banner' }, { status: 200 });
|
return Response.json({ success: false, message: 'Gagal menambah data banner' }, { status: 200 });
|
||||||
|
|||||||
@@ -1,17 +1,20 @@
|
|||||||
import { DIR, funDeleteFile, funUploadFile, prisma } from "@/module/_global";
|
import { DIR, funDeleteFile, funUploadFile, prisma } from "@/module/_global";
|
||||||
import { funGetUserByCookies } from "@/module/auth";
|
import { funGetUserById } from "@/module/auth";
|
||||||
import { createLogUser } from "@/module/user";
|
import { createLogUserMobile } from "@/module/user";
|
||||||
import _ from "lodash";
|
import _ from "lodash";
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
|
||||||
// HAPUS FILE PROJECT BUKAN PAKE ISACTIVE
|
// HAPUS FILE PROJECT BUKAN PAKE ISACTIVE
|
||||||
export async function DELETE(request: Request, context: { params: { id: string } }) {
|
export async function DELETE(request: Request, context: { params: { id: string } }) {
|
||||||
try {
|
try {
|
||||||
const user = await funGetUserByCookies()
|
|
||||||
if (user.id == undefined) {
|
|
||||||
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 401 });
|
|
||||||
}
|
|
||||||
const { id } = context.params;
|
const { id } = context.params;
|
||||||
|
const { user } = (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 data = await prisma.projectFile.count({
|
const data = await prisma.projectFile.count({
|
||||||
where: {
|
where: {
|
||||||
id: id,
|
id: id,
|
||||||
@@ -24,7 +27,7 @@ export async function DELETE(request: Request, context: { params: { id: string }
|
|||||||
success: false,
|
success: false,
|
||||||
message: "Hapus file gagal, data tidak ditemukan",
|
message: "Hapus file gagal, data tidak ditemukan",
|
||||||
},
|
},
|
||||||
{ status: 404 }
|
{ status: 200 }
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -43,14 +46,13 @@ export async function DELETE(request: Request, context: { params: { id: string }
|
|||||||
});
|
});
|
||||||
|
|
||||||
// create log user
|
// create log user
|
||||||
const log = await createLogUser({ act: 'DELETE', desc: 'User menghapus file kegiatan', table: 'project', data: String(dataRelasi?.idProject) })
|
const log = await createLogUserMobile({ act: 'DELETE', desc: 'User menghapus file kegiatan', table: 'project', data: String(dataRelasi?.idProject), user: userMobile.id })
|
||||||
|
|
||||||
|
|
||||||
return NextResponse.json(
|
return NextResponse.json(
|
||||||
{
|
{
|
||||||
success: true,
|
success: true,
|
||||||
message: "File berhasil dihapus",
|
message: "File berhasil dihapus",
|
||||||
data,
|
|
||||||
},
|
},
|
||||||
{ status: 200 }
|
{ status: 200 }
|
||||||
);
|
);
|
||||||
@@ -65,14 +67,15 @@ export async function DELETE(request: Request, context: { params: { id: string }
|
|||||||
// CEK FILE PROJECT APAKAH PERNAH DIUPLOAD PADA PROJECT YG SAMA
|
// CEK FILE PROJECT APAKAH PERNAH DIUPLOAD PADA PROJECT YG SAMA
|
||||||
export async function PUT(request: Request, context: { params: { id: string } }) {
|
export async function PUT(request: Request, context: { params: { id: string } }) {
|
||||||
try {
|
try {
|
||||||
const user = await funGetUserByCookies()
|
|
||||||
if (user.id == undefined) {
|
|
||||||
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 401 });
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
const { id } = context.params;
|
const { id } = context.params;
|
||||||
const body = await request.formData()
|
const body = await request.formData()
|
||||||
|
const data = JSON.parse(body.get("data") as string)
|
||||||
|
const user = await funGetUserById({ id: data.user })
|
||||||
|
|
||||||
|
if (user.id == "null" || user.id == undefined || user.id == "") {
|
||||||
|
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 200 });
|
||||||
|
}
|
||||||
|
|
||||||
const file = body.get("file") as File
|
const file = body.get("file") as File
|
||||||
const fileName = file.name
|
const fileName = file.name
|
||||||
|
|
||||||
@@ -88,7 +91,7 @@ export async function PUT(request: Request, context: { params: { id: string } })
|
|||||||
success: false,
|
success: false,
|
||||||
message: "Upload file gagal, data kegiatan tidak ditemukan",
|
message: "Upload file gagal, data kegiatan tidak ditemukan",
|
||||||
},
|
},
|
||||||
{ status: 404 }
|
{ status: 200 }
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -113,7 +116,7 @@ export async function PUT(request: Request, context: { params: { id: string } })
|
|||||||
|
|
||||||
|
|
||||||
if (cek) {
|
if (cek) {
|
||||||
return NextResponse.json({ success: false, message: "File sudah pernah diupload" }, { status: 400 });
|
return NextResponse.json({ success: false, message: "File sudah pernah diupload" }, { status: 200 });
|
||||||
} else {
|
} else {
|
||||||
return NextResponse.json({ success: true, message: "Cek berhasil" }, { status: 200 });
|
return NextResponse.json({ success: true, message: "Cek berhasil" }, { status: 200 });
|
||||||
}
|
}
|
||||||
@@ -128,14 +131,15 @@ export async function PUT(request: Request, context: { params: { id: string } })
|
|||||||
// TAMBAH FILE PROJECT
|
// TAMBAH FILE PROJECT
|
||||||
export async function POST(request: Request, context: { params: { id: string } }) {
|
export async function POST(request: Request, context: { params: { id: string } }) {
|
||||||
try {
|
try {
|
||||||
const user = await funGetUserByCookies()
|
|
||||||
if (user.id == undefined) {
|
|
||||||
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 401 });
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
const { id } = context.params;
|
const { id } = context.params;
|
||||||
const body = await request.formData()
|
const body = await request.formData()
|
||||||
|
const data = JSON.parse(body.get("data") as string)
|
||||||
|
const user = await funGetUserById({ id: data.user })
|
||||||
|
|
||||||
|
if (user.id == "null" || user.id == undefined || user.id == "") {
|
||||||
|
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 200 });
|
||||||
|
}
|
||||||
|
|
||||||
const cekFile = body.has("file0")
|
const cekFile = body.has("file0")
|
||||||
|
|
||||||
const dataCek = await prisma.project.count({
|
const dataCek = await prisma.project.count({
|
||||||
@@ -150,46 +154,39 @@ export async function POST(request: Request, context: { params: { id: string } }
|
|||||||
success: false,
|
success: false,
|
||||||
message: "Tambah file kegiatan gagal, data tugas tidak ditemukan",
|
message: "Tambah file kegiatan gagal, data tugas tidak ditemukan",
|
||||||
},
|
},
|
||||||
{ status: 404 }
|
{ status: 200 }
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
const dataProject = await prisma.project.findUnique({
|
|
||||||
where: {
|
|
||||||
id: id,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (cekFile) {
|
if (cekFile) {
|
||||||
for (var pair of body.entries()) {
|
console.log('masuk file')
|
||||||
if (String(pair[0]).substring(0, 4) == "file") {
|
// for (var pair of body.entries()) {
|
||||||
const file = body.get(pair[0]) as File
|
// if (String(pair[0]).substring(0, 4) == "file") {
|
||||||
const fExt = file.name.split(".").pop()
|
// const file = body.get(pair[0]) as File
|
||||||
const fName = file.name.replace("." + fExt, "")
|
// const fExt = file.name.split(".").pop()
|
||||||
|
// const fName = file.name.replace("." + fExt, "")
|
||||||
|
|
||||||
const upload = await funUploadFile({ file: file, dirId: DIR.project })
|
// const upload = await funUploadFile({ file: file, dirId: DIR.project })
|
||||||
if (upload.success) {
|
// if (upload.success) {
|
||||||
const insertToTable = await prisma.projectFile.create({
|
// const insertToTable = await prisma.projectFile.create({
|
||||||
data: {
|
// data: {
|
||||||
idStorage: upload.data.id,
|
// idStorage: upload.data.id,
|
||||||
idProject: id,
|
// idProject: id,
|
||||||
name: fName,
|
// name: fName,
|
||||||
extension: String(fExt),
|
// extension: String(fExt),
|
||||||
|
|
||||||
},
|
// },
|
||||||
select: {
|
// select: {
|
||||||
id: true
|
// id: true
|
||||||
}
|
// }
|
||||||
})
|
// })
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
// create log user
|
// // create log user
|
||||||
const log = await createLogUser({ act: 'CREATE', desc: 'User menambah file kegiatan', table: 'project', data: String(id) })
|
// const log = await createLogUserMobile({ act: 'CREATE', desc: 'User menambah file kegiatan', table: 'project', data: String(id), user: user.id })
|
||||||
return NextResponse.json({ success: true, message: "Berhasil mengupload file kegiatan" }, { status: 200 });
|
return NextResponse.json({ success: true, message: "Berhasil mengupload file kegiatan" }, { status: 200 });
|
||||||
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
|
|||||||
@@ -151,14 +151,13 @@ export async function POST(request: Request) {
|
|||||||
const body = await request.formData()
|
const body = await request.formData()
|
||||||
const data = JSON.parse(body.get("data") as string)
|
const data = JSON.parse(body.get("data") as string)
|
||||||
const file = body.get("file") as File
|
const file = body.get("file") as File
|
||||||
|
const user = await funGetUserById({ id: data.user })
|
||||||
|
|
||||||
if (data.user == "null" || data.user == undefined || data.user == "") {
|
if (user.id == "null" || user.id == undefined || user.id == "") {
|
||||||
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 200 });
|
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 200 });
|
||||||
}
|
}
|
||||||
|
|
||||||
const user = await funGetUserById({ id: data.user })
|
|
||||||
const village = String(user.idVillage)
|
const village = String(user.idVillage)
|
||||||
|
|
||||||
let groupFix = data.idGroup
|
let groupFix = data.idGroup
|
||||||
|
|
||||||
if (groupFix == null || groupFix == undefined || groupFix == "") {
|
if (groupFix == null || groupFix == undefined || groupFix == "") {
|
||||||
|
|||||||
Reference in New Issue
Block a user