| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 | 
							- const sanksiModel = require('../model/sanksi.model')
 
- const handleError = require('../utils/handleError')
 
- const response = require('../utils/responseHandler')
 
- const { addManyDokumen } = require('../utils/dokumenFunction')
 
- const { validate } = require('../utils/validation')
 
- const pemantauanModel = require('../model/pemantauan.model')
 
- const logModel = require('../model/log.model')
 
- const { hariKerja } = require('../utils/hariKerja')
 
- const {
 
-   cekSatuDataSanksi,
 
-   cekSatuDataLaporan,
 
-   cekBanyakDataPelanggaran,
 
-   cekBanyakDataSanksi,
 
- } = require('../utils/cekData')
 
- const laporanModel = require('../model/laporan.model')
 
- const ip = require('ip')
 
- const osValue = require('../utils/osValue')
 
- exports.create = handleError(async (req, res) => {
 
-   const { no_sanksi, keterangan } = req.body
 
-   let { pelanggaran_id } = req.body
 
-   const { laporan_id } = req.params
 
-   const files = req.files
 
-   const user = req.user
 
-   const isValid = validate(res, req.body, {
 
-     no_sanksi: 'string',
 
-     keterangan: 'string',
 
-     pelanggaran_id: 'string',
 
-   })
 
-   if (!isValid) return
 
-   const laporan = await cekSatuDataLaporan(res, user, laporan_id, {
 
-     evaluasi: { $exists: true, $ne: [] },
 
-   })
 
-   if (!laporan) return
 
-   pelanggaran_id = await cekBanyakDataPelanggaran(res, pelanggaran_id)
 
-   if (!pelanggaran_id) return
 
-   const sanksi = await sanksiModel.findOne({ laporan: laporan_id })
 
-   if (sanksi) {
 
-     return response.error(res, {
 
-       message: 'Sanksi sudah ada',
 
-     })
 
-   }
 
-   if (!files.length) {
 
-     return response.error(res, {
 
-       message: 'dokumen harus ada',
 
-     })
 
-   }
 
-   const dokumen = await addManyDokumen(files)
 
-   const dokumen_id = dokumen.map((e) => e._id)
 
-   const data = await sanksiModel.create({
 
-     no_sanksi,
 
-     laporan: laporan._id,
 
-     user: user._id,
 
-     pelanggaran: pelanggaran_id,
 
-     keterangan,
 
-     dokumen: dokumen_id,
 
-     batas_waktu: {
 
-       keberatan: hariKerja(10),
 
-     },
 
-   })
 
-   await laporanModel.findByIdAndUpdate(laporan._id, { sanksi: data._id })
 
-   await pemantauanModel.create({
 
-     laporan: laporan._id,
 
-     sanksi: data._id,
 
-     action: 'CREATE SANKSI',
 
-     pt_id: laporan.pt.id,
 
-     user: user._id,
 
-     keterangan: 'Melakukan penetapan Sanksi',
 
-     dokumen: dokumen_id,
 
-   })
 
-   await logModel.create({
 
-     user: user._id,
 
-     aktivitas: `Berhasil melakukan penetapan sanksi pada laporan id: ${laporan._id}, sanksi id: ${data._id}`,
 
-     os: osValue(),
 
-     ipv4: ip.address('public', 'ipv4'),
 
-   })
 
-   return response.success(res, {
 
-     message: 'Berhasil membuat Sanksi',
 
-     data,
 
-   })
 
- })
 
- exports.getAll = handleError(async (req, res) => {
 
-   const user = req.user
 
-   const { keberatan, jawaban, banding, cabutSanksi, perbaikan } = req.query
 
-   const where = {}
 
-   if (keberatan === 'true') {
 
-     where['pengajuan.keberatan'] = { $exists: true, $ne: null }
 
-     if (jawaban === 'true') {
 
-       where['jawaban.keberatan'] = { $exists: true, $ne: null }
 
-     }
 
-   } else if (banding === 'true') {
 
-     where.banding = true
 
-     where['pengajuan.keberatan'] = { $exists: true, $ne: null }
 
-     where['jawaban.keberatan'] = { $exists: true, $ne: null }
 
-     where['pengajuan.banding'] = { $exists: true, $ne: null }
 
-     if (jawaban === 'true') {
 
-       where['jawaban.banding'] = { $exists: true, $ne: null }
 
-     }
 
-   } else if (cabutSanksi === 'true') {
 
-     where['pengajuan.cabut_sanksi'] = { $exists: true, $ne: null }
 
-     if (jawaban === 'true') {
 
-       where['jawaban.cabut_sanksi'] = { $exists: true, $ne: null }
 
-     }
 
-   } else if (perbaikan === 'true') {
 
-     where.$or = [
 
-       { 'jawaban.cabut_sanksi': { $exists: true, $ne: null } },
 
-       { 'jawaban.banding': { $exists: true, $ne: null } },
 
-     ]
 
-   }
 
-   const data = await cekBanyakDataSanksi(user, where)
 
-   return response.success(res, {
 
-     message: 'Berhasil ambil data Sanksi',
 
-     data,
 
-   })
 
- })
 
- exports.getOne = handleError(async (req, res) => {
 
-   const user = req.user
 
-   const { sanksi_id } = req.params
 
-   const w = {}
 
-   const { banding } = req.query
 
-   if (banding === 'true') {
 
-     w.banding = true
 
-     w['pengajuan.keberatan'] = { $exists: true, $ne: null }
 
-     w['jawaban.keberatan'] = { $exists: true, $ne: null }
 
-     w['pengajuan.banding'] = { $exists: true, $ne: null }
 
-   }
 
-   const sanksi = await cekSatuDataSanksi(res, user, sanksi_id, w)
 
-   if (!sanksi) return
 
-   return response.success(res, {
 
-     message: 'Berhasil ambil satu data Sanksi',
 
-     data: sanksi,
 
-   })
 
- })
 
 
  |