| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592 | 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 } = 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.tuntas?.keterangan || e.aktif === false || e.aktif === true && e.sanksi?.jawaban?.cabut_sanksi?.status === 'Diterima' || e.sanksi?.aktif === false && !e.sanksi?.masa_berlaku?.from_date)      .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)).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,  })})
 |