| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593 | 
							- const axios = require('../../utils/axios')
 
- const handleError = require('../../utils/v1/handleError')
 
- const response = require('../../utils/responseHandler')
 
- const laporanModel = require('../../model/laporan.model')
 
- const pelanggaranModel = require('../../model/pelanggaran.model')
 
- const pemantauanModel = require('../../model/pemantauan.model')
 
- const { validate } = require('../../utils/v1/validation')
 
- const { notifWA } = require('../../utils/v1/notifFunction')
 
- const { addManyDokumen } = require('../../utils/dokumenFunction')
 
- const userModel = require('../../model/user.model')
 
- const {
 
-   cekSatuDataLaporan,
 
-   cekBanyakDataLaporan,
 
-   cekBanyakDataSanksi,
 
- } = require('../../utils/v1/cekData')
 
- const { TEMPLATE_LAPORAN, PELAPORAN, CREATE_LAPORAN, DIKTI, LLDIKTI, DITUTUP, DELEGASI, TRUE, FALSE, ADD_JADWAL } = require('../../utils/constanta')
 
- const logModel = require('../../model/log.model')
 
- const kontakModel = require('../../model/kontak.model')
 
- const sanksiModel = require('../../model/sanksi.model')
 
- const { isValidObjectId } = require('mongoose')
 
- exports.create = handleError(async (req, res) => {
 
-   const user = req.user
 
-   const files = req.files
 
-   const isValid = validate(res, req.body, {
 
-     no_laporan: 'string',
 
-     pt_id: 'string',
 
-     pelanggaran_id: 'string',
 
-     keterangan: 'string',
 
-   })
 
-   if (!isValid) return
 
-   const { no_laporan, pt_id, keterangan } = req.body
 
-   let { pelanggaran_id } = req.body
 
-   const pt = await axios.get(
 
-     `https://api.kemdikbud.go.id:8243/pddikti/1.2/pt/${pt_id}`
 
-   )
 
-   if (pt.length === 0)
 
-     return response.error(res, {
 
-       message: 'pt_id tidak ditemukan',
 
-     })
 
-   let dokumen_id = []
 
-   if (files.length) {
 
-     const dokumen = await addManyDokumen(files)
 
-     dokumen_id = dokumen.map((e) => e._id)
 
-   }
 
-   pelanggaran_id = pelanggaran_id.split(',')
 
-   const pelanggaran = await pelanggaranModel.find({
 
-     _id: {
 
-       $in: pelanggaran_id,
 
-     },
 
-   })
 
-   if (!pelanggaran.length)
 
-     return response.error(res, { message: 'pelanggaran_id tidak ada' })
 
-   let data = {
 
-     no_laporan,
 
-     user: user._id,
 
-     dokumen: dokumen_id,
 
-     pt: pt[0],
 
-     pelanggaran: pelanggaran_id,
 
-     keterangan,
 
-     role_data: user.role.id === 2021 ? LLDIKTI : DIKTI,
 
-     role_asal: user.role.id === 2021 ? LLDIKTI : DIKTI,
 
-     level: 2,
 
-     step: [PELAPORAN],
 
-     flag: PELAPORAN,
 
-   }
 
-   data = await laporanModel.create(data)
 
-   let contacts = await kontakModel.find()
 
-   contacts = contacts.map((e) => e.nama).join(', ')
 
-   try {
 
-     const notif = await notifWA(TEMPLATE_LAPORAN, [
 
-       {
 
-         key: '1',
 
-         value: 'nama',
 
-         value_text: user.nama,
 
-       },
 
-       { key: '2', value: 'pt', value_text: pt[0].nama },
 
-       { key: '3', value: 'keterangan', value_text: keterangan },
 
-       { key: '4', value: 'no_laporan', value_text: no_laporan },
 
-     ])
 
-     if (notif[0].status == 'success') {
 
-       await logModel.create({
 
-         aktivitas: `Server berhasil mengirim notif wa kepada ${contacts} untuk Pembuatan Laporan`,
 
-       })
 
-     } else {
 
-       await logModel.create({
 
-         aktivitas: `Server gagal mengirim notif wa kepada ${contacts} untuk Pembuatan Laporan, Error: ${JSON.stringify(notif)}`,
 
-       })
 
-     }
 
-   } catch (error) {
 
-     await logModel.create({
 
-       aktivitas: `Server gagal mengirim notif wa kepada ${contacts} untuk Pembuatan Laporan, Error: ${error.message}`,
 
-     })
 
-   }
 
-   await pemantauanModel.create({
 
-     laporan: data._id,
 
-     action: CREATE_LAPORAN,
 
-     pt_id: pt[0].id,
 
-     user: user._id,
 
-     keterangan: 'Membuat Laporan',
 
-     dokumen: dokumen_id,
 
-     for_pt: false,
 
-   })
 
-   return response.success(res, {
 
-     message: 'Berhasil menambah laporan',
 
-     data,
 
-   })
 
- })
 
- exports.public = handleError(async (req, res) => {
 
-   const user = req.user
 
-   const no_laporan = req.no_laporan
 
-   let level = req.level
 
-   const files = req.files
 
-   const isValid = validate(res, req.body, {
 
-     pt_id: 'string',
 
-     pelanggaran_id: 'string',
 
-     keterangan: 'string',
 
-     // no_verifikasi: 'string',
 
-   })
 
-   if (!isValid) return
 
-   const { pt_id, keterangan, no_verifikasi } = req.body
 
-   let { pelanggaran_id } = req.body
 
-   if (no_verifikasi && user.no_verifikasi !== no_verifikasi) {
 
-     return response.error(res, {
 
-       message: 'no_verifikasi tidak sesuai',
 
-       error: { no_verifikasi: 'No. Verifikasi tidak sesuai' },
 
-     })
 
-   } else if (no_verifikasi && user.no_verifikasi === no_verifikasi) {
 
-     level = 3
 
-   }
 
-   const pt = await axios.get(
 
-     `https://api.kemdikbud.go.id:8243/pddikti/1.2/pt/${pt_id}`
 
-   )
 
-   if (pt.length === 0)
 
-     return response.error(res, {
 
-       message: 'pt_id tidak ditemukan',
 
-     })
 
-   let dokumen_id = []
 
-   if (files.length) {
 
-     const dokumen = await addManyDokumen(files)
 
-     dokumen_id = dokumen.map((e) => e._id)
 
-   }
 
-   pelanggaran_id = pelanggaran_id.split(',')
 
-   const pelanggaran = await pelanggaranModel.find({
 
-     _id: {
 
-       $in: pelanggaran_id,
 
-     },
 
-   })
 
-   if (!pelanggaran.length)
 
-     return response.error(res, { message: 'pelanggaran_id tidak ada' })
 
-   let data = {
 
-     no_laporan,
 
-     user: user._id,
 
-     dokumen: dokumen_id,
 
-     pt: pt[0],
 
-     pelanggaran: pelanggaran_id,
 
-     keterangan,
 
-     role_data: 'dikti',
 
-     role_asal: 'dikti',
 
-     level,
 
-   }
 
-   data = await laporanModel.create(data)
 
-   await pemantauanModel.create({
 
-     laporan: data._id,
 
-     action: 'CREATE LAPORAN',
 
-     pt_id: pt[0].id,
 
-     user: user._id,
 
-     keterangan: 'Membuat Laporan',
 
-     dokumen: dokumen_id,
 
-     for_pt: false,
 
-   })
 
-   if (no_verifikasi) await userModel.findByIdAndUpdate(user._id, { verified: true })
 
-   let contacts = await kontakModel.find()
 
-   contacts = contacts.map((e) => e.nama).join(', ')
 
-   try {
 
-     const notif = await notifWA(TEMPLATE_LAPORAN, [
 
-       {
 
-         key: '1',
 
-         value: 'nama',
 
-         value_text: user.isPrivate || !user.nama ? 'rahasia' : user.nama,
 
-       },
 
-       { key: '2', value: 'pt', value_text: pt[0].nama },
 
-       { key: '3', value: 'keterangan', value_text: keterangan },
 
-       { key: '4', value: 'no_laporan', value_text: no_laporan },
 
-     ])
 
-     if (notif[0].status == 'success') {
 
-       await logModel.create({
 
-         aktivitas: `Server berhasil mengirim notif wa kepada ${contacts} untuk Pembuatan Laporan`,
 
-       })
 
-     } else {
 
-       await logModel.create({
 
-         aktivitas: `Server gagal mengirim notif wa kepada ${contacts} untuk Pembuatan Laporan, Error: ${JSON.stringify(notif)}`,
 
-       })
 
-     }
 
-   } catch (error) {
 
-     await logModel.create({
 
-       aktivitas: `Server gagal mengirim notif wa kepada ${contacts} untuk Pembuatan Laporan, Error: ${error.message}`,
 
-     })
 
-   }
 
-   return response.success(res, {
 
-     message: 'Berhasil menambah laporan',
 
-     data,
 
-   })
 
- })
 
- exports.getLaporanByNoLaporanAndId = handleError(async (req, res) => {
 
-   const { no_laporan } = req.params
 
-   let where = { evaluasi: { $exists: true, $ne: [] } }
 
-   if (isValidObjectId(no_laporan)) where._id = no_laporan
 
-   else where.no_laporan = no_laporan
 
-   const data = await laporanModel.findOne(where)
 
-     .populate({ path: 'user', populate: 'foto' })
 
-     .populate({ path: 'pelanggaran', select: 'pelanggaran' })
 
-     .populate({ path: 'sanksi', populate: ['pelanggaran'] })
 
-     .populate('dokumen')
 
-     .populate('peserta_penetapan_sanksi.ttd')
 
-     .populate({ path: 'evaluasi', populate: ['user', 'dokumen'] })
 
-   if (!data) {
 
-     return response.error(res, {
 
-       message: 'no_laporan atau id tidak ada',
 
-       code: 404,
 
-     })
 
-   }
 
-   return response.success(res, {
 
-     message: 'Berhasil ambil data laporan',
 
-     data,
 
-   })
 
- })
 
- exports.getAll = handleError(async (req, res) => {
 
-   const user = req.user
 
-   const where = {}
 
-   const { no_laporan, pt_id, jadwal, evaluasi, aktif, delegasi, all, sanksi, tuntas } =
 
-     req.query
 
-   if (no_laporan) where.no_laporan = no_laporan
 
-   if (pt_id) where['pt.id'] = pt_id
 
-   if (aktif) where.aktif = aktif === 'true'
 
-   if (all) where.all = true
 
-   else if (delegasi) where.delegasi = delegasi === 'true'
 
-   if (jadwal === 'true') {
 
-     where.jadwal = {
 
-       $exists: true,
 
-       $ne: null,
 
-     }
 
-   } else if (evaluasi === 'true') {
 
-     where.evaluasi = {
 
-       $exists: true,
 
-       $ne: null,
 
-       $not: {
 
-         $size: 0,
 
-       },
 
-     }
 
-   } else if (sanksi === 'true') {
 
-     where.sanksi = {
 
-       $exists: true,
 
-       $ne: null,
 
-     }
 
-   } else if (tuntas === 'true') {
 
-     let dataLaporan = (await cekBanyakDataLaporan(user, { aktif: 'empty', all: true, }, { lean: true }))
 
-       .filter(e => e.aktif === false || e.sanksi?.aktif === false)
 
-       .map(e => ({ ...e, status: e.aktif === false || e.tuntas?.keterangan ? 'Ditutup' : e.sanksi?.jawaban?.cabut_sanksi?.status === 'Diterima' ? 'Diterima' : !e.sanksi?.masa_berlaku ? 'Selesai' : 'Ditutup' }))
 
-     // let dataSanksi = await cekBanyakDataSanksi(user, {
 
-     //   aktif: false, 'jawaban.cabut_sanksi.status': 'Diterima'
 
-     // })
 
-     // const w = {}
 
-     // switch (user.role.id) {
 
-     //   case 2020:
 
-     //     w.$or = [{
 
-     //       role_asal: DIKTI
 
-     //     }, {
 
-     //       role_data: DIKTI
 
-     //     }]
 
-     //     break
 
-     //   case 2021:
 
-     //     w.$or = [{
 
-     //       role_asal: LLDIKTI
 
-     //     }, {
 
-     //       role_data: LLDIKTI
 
-     //     }]
 
-     //     w['pt.pembina.id'] = user.lembaga.id
 
-     //     break
 
-     // }
 
-     // const dataLaporan = (await laporanModel.find(w).populate('sanksi').lean())
 
-     //   .filter(e => e.aktif === false || e.tuntas?.keterangan || e.sanksi?.jawaban?.cabut_sanksi === 'Diterima' && e.sanksi?.aktif === false || !e.sanksi?.masa_berlaku)
 
-     //   .map(e => ({...e, status: e.aktif === false || e.tuntas?.keterangan ? 'Ditutup' : e.sanksi?.jawaban?.cabut_sanksi === 'Diterima'? 'Diterima' : !e.sanksi?.masa_berlaku ? 'Selesai' : 'Ditutup'}))
 
-     return response.success(res, {
 
-       message: 'Berhasil ambil data laporan dan sanksi tuntas dan ditutup',
 
-       data: dataLaporan
 
-     })
 
-   }
 
-   let data = (await cekBanyakDataLaporan(user, where))
 
-   if (!all) data = data.filter(e => !e.sanksi || e.sanksi?.aktif === true)
 
-   return response.success(res, {
 
-     message: 'Berhasil ambil data laporan',
 
-     data,
 
-   })
 
- })
 
- exports.getOne = handleError(async (req, res) => {
 
-   const { id } = req.params
 
-   const user = req.user
 
-   const { aktif, delegasi, all } = req.query
 
-   const where = {}
 
-   if (aktif) where.aktif = aktif === TRUE
 
-   if (all) where.all = true
 
-   else if (delegasi) where.delegasi = delegasi === TRUE
 
-   const data = await cekSatuDataLaporan(res, user, id, { normal: true })
 
-   if (!data) return
 
-   return response.success(res, {
 
-     message: 'Berhasil ambil data Laporan',
 
-     data,
 
-   })
 
- })
 
- exports.update = handleError(async (req, res) => {
 
-   const { id } = req.params
 
-   const user = req.user
 
-   const files = req.files
 
-   const laporan = await cekSatuDataLaporan(res, user, id, { normal: true })
 
-   if (!laporan) return
 
-   const isValid = validate(res, req.body, {
 
-     change_role: { type: 'string', optional: true, enum: [TRUE, FALSE] },
 
-     aktif: { type: 'string', optional: true, enum: [TRUE, FALSE] },
 
-     keterangan: 'string',
 
-   })
 
-   if (!isValid) return
 
-   const data = {}
 
-   let keterangan = ''
 
-   let alasan = ''
 
-   const { change_role, aktif } = req.body
 
-   const keterangan2 = req.body.keterangan
 
-   if (change_role === TRUE) {
 
-     data.flag = DELEGASI
 
-     data.role_data = user.role.id === 2020 ? 'lldikti' : 'dikti'
 
-     keterangan = `Laporan didelegasi ke ${user.role.id === 2020 ? 'LLDIKTI' : 'DIKTI'}`
 
-     alasan = keterangan2
 
-     data.alasan_delegasi = keterangan2
 
-     // if (laporan.jadwal) {
 
-     //   await laporanModel.findByIdAndUpdate(laporan._id, {
 
-     //     $unset: { jadwal: 1 },
 
-     //   })
 
-     // }
 
-   }
 
-   if (aktif) {
 
-     let dokumen_id = []
 
-     data.aktif = aktif === 'true'
 
-     if (files) {
 
-       const dokumen = await addManyDokumen(files)
 
-       dokumen_id = dokumen.map((e) => e._id)
 
-     }
 
-     if (aktif === 'true') {
 
-       keterangan = 'Laporan dibuka'
 
-     } else {
 
-       keterangan = `Laporan ditutup`
 
-       alasan = keterangan2
 
-       data.flag = DITUTUP
 
-       data.tuntas = {
 
-         keterangan: keterangan2,
 
-         dokumen: dokumen_id,
 
-       }
 
-     }
 
-   }
 
-   const update = await laporanModel.findByIdAndUpdate(laporan._id, data)
 
-   if (change_role || aktif) {
 
-     await pemantauanModel.create({
 
-       action: 'UPDATE LAPORAN',
 
-       laporan: laporan._id,
 
-       pt_id: laporan.pt.id,
 
-       user: user._id,
 
-       keterangan,
 
-       alasan,
 
-       for_pt: false,
 
-     })
 
-   }
 
-   return response.success(res, {
 
-     message: 'Berhasil update laporan',
 
-     data: update,
 
-   })
 
- })
 
- exports.jumlahLaporan = handleError(async (req, res) => {
 
-   const laporan = await laporanModel.aggregate([
 
-     {
 
-       $match: {
 
-         aktif: true,
 
-       },
 
-     },
 
-     {
 
-       $group: {
 
-         _id: '$pt.pembina.nama',
 
-         jumlah_laporan: {
 
-           $sum: 1,
 
-         },
 
-         propinsi: {
 
-           $addToSet: '$pt.propinsi.nama',
 
-         },
 
-       },
 
-     },
 
-     {
 
-       $sort: {
 
-         _id: 1,
 
-       },
 
-     },
 
-   ])
 
-   return response.success(res, {
 
-     message: 'Jumlah Laporan',
 
-     data: laporan,
 
-   })
 
- })
 
- exports.laporanByPembina = handleError(async (req, res) => {
 
-   const { idPembina } = req.params
 
-   const {
 
-     penjadwalan,
 
-     pemeriksaan,
 
-     sanksi,
 
-     keberatan,
 
-     banding,
 
-     perbaikan,
 
-     cabutSanksi,
 
-     delegasi,
 
-     ditutup,
 
-     diterima
 
-   } = req.query
 
-   let where = {}
 
-   let where2 = {}
 
-   let isLaporan = true
 
-   let isSanksi = false
 
-   if (penjadwalan === 'true') {
 
-     where.jadwal = {
 
-       $exists: true,
 
-       $ne: null,
 
-     }
 
-     isLaporan = true
 
-     isSanksi = false
 
-   }
 
-   if (pemeriksaan === 'true') {
 
-     where.evaluasi = {
 
-       $exists: true,
 
-       $ne: null,
 
-       $not: {
 
-         $size: 0,
 
-       },
 
-     }
 
-     isLaporan = true
 
-     isSanksi = false
 
-   }
 
-   if (sanksi === 'true') {
 
-     where.sanksi = {
 
-       $exists: true,
 
-       $ne: null,
 
-     }
 
-     isLaporan = false
 
-     isSanksi = true
 
-   }
 
-   if (keberatan === 'true') {
 
-     where2['pengajuan.keberatan'] = { $exists: true, $ne: null }
 
-     isLaporan = false
 
-     isSanksi = true
 
-   }
 
-   if (banding === 'true') {
 
-     where2['pengajuan.banding'] = { $exists: true, $ne: null }
 
-     isLaporan = false
 
-     isSanksi = true
 
-   }
 
-   if (cabutSanksi === 'true') {
 
-     where2['pengajuan.cabut_sanksi'] = {
 
-       $exists: true,
 
-       $ne: null,
 
-     }
 
-     isLaporan = false
 
-     isSanksi = true
 
-   }
 
-   if (perbaikan === 'true') {
 
-     where2.perbaikan = {
 
-       $exists: true,
 
-       $ne: null,
 
-       $not: {
 
-         $size: 0,
 
-       },
 
-     }
 
-     isLaporan = false
 
-     isSanksi = true
 
-   }
 
-   if (delegasi === 'true') {
 
-     where = {
 
-       role_asal: 'dikti',
 
-       role_data: 'lldikti'
 
-     }
 
-     isLaporan = true
 
-     isSanksi = false
 
-   }
 
-   if (ditutup === 'true') {
 
-     where.aktif = false
 
-     isLaporan = true
 
-     isSanksi = false
 
-   }
 
-   if (diterima === 'true') {
 
-     where2 = {
 
-       'jawaban.cabut_sanksi.status': 'Diterima',
 
-       aktif: false
 
-     }
 
-     isLaporan = false
 
-     isSanksi = true
 
-   }
 
-   let laporan = []
 
-   if (isSanksi) {
 
-     laporan = (await laporanModel.find({ ...where, 'pt.pembina.id': idPembina }).lean().populate({ path: 'sanksi', match: where2 }).lean())
 
-       .filter(e => e.sanksi)
 
-       .map(e => {
 
-         let step = 'Pelaporan'
 
-         if (e.jadwal && !e.evaluasi.length) step = 'Penjadwalan'
 
-         else if (e.evaluasi.length && !e.sanksi) step = 'Pemeriksaan'
 
-         else if (e.sanksi?.pengajuan?.cabut_sanksi) step = 'Cabut Sanksi'
 
-         else if (e.sanksi?.pengajuan?.keberatan && !e.sanksi?.pengajuan?.banding) step = 'Keberatan'
 
-         else if (e.sanksi?.aktif === false && !e.sanksi?.masa_berlaku?.from_date) step = 'Selesai'
 
-         else if (e.sanksi?.aktif === false && e.jawaban?.cabut_sanksi?.status === 'Diterima') step = 'Diterima'
 
-         else if (e.sanksi?.pengajuan?.banding) step = 'Banding'
 
-         else if (e.sanksi) step = 'Sanksi'
 
-         return { ...e, step }
 
-       })
 
-   } else if (isLaporan) {
 
-     laporan = (await laporanModel.find({ ...where, 'pt.pembina.id': idPembina }).lean().populate({ path: 'sanksi', match: where2 }).lean())
 
-       .map(e => {
 
-         let step = 'Pelaporan'
 
-         if (e.jadwal && !e.evaluasi.length) step = 'Penjadwalan'
 
-         else if (e.evaluasi.length && !e.sanksi) step = 'Pemeriksaan'
 
-         else if (e.sanksi?.pengajuan?.cabut_sanksi) step = 'Cabut Sanksi'
 
-         else if (e.sanksi?.pengajuan?.keberatan && !e.sanksi?.pengajuan?.banding) step = 'Keberatan'
 
-         else if (e.sanksi?.aktif === false && !e.sanksi?.masa_berlaku?.from_date) step = 'Selesai'
 
-         else if (e.sanksi?.aktif === false && e.jawaban?.cabut_sanksi?.status === 'Diterima') step = 'Diterima'
 
-         else if (e.sanksi?.pengajuan?.banding) step = 'Banding'
 
-         else if (e.sanksi) step = 'Sanksi'
 
-         return { ...e, step }
 
-       })
 
-   }
 
-   return response.success(res, {
 
-     message: 'berhasil get laporan by pembina',
 
-     data: laporan,
 
-   })
 
- })
 
- exports.getOneLaporanPublic = handleError(async (req, res) => {
 
-   const { id } = req.params
 
-   const data = await laporanModel.findById(id)
 
-     .populate({ path: 'user', populate: 'foto' })
 
-     .populate({ path: 'pelanggaran', select: 'pelanggaran' })
 
-     .populate({ path: 'sanksi', populate: ['pelanggaran'] })
 
-     .populate('dokumen')
 
-     .populate('peserta_penetapan_sanksi.ttd')
 
-     .populate({ path: 'evaluasi', populate: ['user', 'dokumen'] })
 
-   console.log(data)
 
-   if (!data) return response.error(res, {
 
-     code: 404,
 
-     message: 'laporan_id tidak ada'
 
-   })
 
-   return response.success(res, {
 
-     message: 'Berhasil ambil satu data Laporan',
 
-     data,
 
-   })
 
- })
 
 
  |