| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 | const axios = require('../utils/axios')const handleError = require('../utils/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/validation')const { addManyDokumen } = require('../utils/dokumenFunction')const { cekSatuDataLaporan, cekBanyakDataLaporan } = require('../utils/cekData')exports.create = handleError(async (req, res) => {  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)    return response.error(res, {      message: 'pt_id tidak ditemukan',    })  const files = req.files  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' })  const user = req.user  let data = {    no_laporan,    user: user._id,    dokumen: dokumen_id,    pt: pt[0],    pelanggaran: pelanggaran_id,    keterangan,    role_data: user.role.id === 2020 ? 'dikti' : 'lldikti',  }  data = await laporanModel.create(data)  await pemantauanModel.create({    laporan: data._id,    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.getAll = handleError(async (req, res) => {  const user = req.user  const where = {}  const { id, no_laporan, pt_id, jadwal, evaluasi } = req.query  if (id) where._id = id  if (no_laporan) where.no_laporan = no_laporan  if (pt_id) where.pt.id = pt_id  if (jadwal === 'true')    where.jadwal = {      $exists: true,      $ne: null,    }  if (evaluasi === 'true')    where.evaluasi = {      $exists: true,      $ne: null,      $not: {        $size: 0,      },    }  let data = await cekBanyakDataLaporan(user, where)  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 data = await cekSatuDataLaporan(res, user, id)  if (!data) return  return response.success(res, {    message: 'Berhasil ambil data Laporan',    data,  })})
 |