const sanksiModel = require('../model/sanksi.model') const handleError = require('../utils/handleError') const response = require('../utils/responseHandler') const { addManyDokumen, addDokumen } = require('../utils/dokumenFunction') const { validate } = require('../utils/validation') const pemantauanModel = require('../model/pemantauan.model') const pelanggaranModel = require('../model/pelanggaran.model') const logModel = require('../model/log.model') const { hariKerja } = require('../utils/hariKerja') const axios = require('../utils/axios') const { cekSatuDataSanksi, cekSatuDataLaporan, cekBanyakDataPelanggaran, cekBanyakDataSanksi } = require('../utils/cekData') const laporanModel = require('../model/laporan.model') exports.create = handleError(async (req, res) => { const { no_sanksi, keterangan, from_date, to_date, tanggal_terima_sanksi, tanggal_akhir_keberatan } = req.body let { pelanggaran_id } = req.body const { laporan_id } = req.params const { dokumen: files, berita_acara, dokumen_terima_sanksi } = req.files const user = req.user const isValid = validate(res, req.body, { no_sanksi: 'string', keterangan: 'string', pelanggaran_id: 'string', from_date: 'string', to_date: 'string', tanggal_terima_sanksi: 'string', tanggal_akhir_keberatan: 'string' }) if (!isValid) return const laporan = await cekSatuDataLaporan(res, user, laporan_id, { evaluasi: { $exists: true, $ne: [] } }) if (!laporan) return const id_pelanggaran = pelanggaran_id.split(',') const pelanggaran = await pelanggaranModel.find({ _id: { $in: id_pelanggaran } }) if (!pelanggaran.length) { return response.error(res, { message: 'pelanggaran_id tidak ada' }) } pelanggaran_id = pelanggaran.map((e) => e._id) const sanksi = await sanksiModel.findOne({ laporan: laporan_id }) if (sanksi) { return response.error(res, { message: 'Sanksi sudah ada' }) } if (!files) { return response.error(res, { message: 'dokumen harus ada' }) } let dokumenBeritaAcara_id = null if (berita_acara) { const dokumenBeritaAcara = await addManyDokumen(berita_acara) dokumenBeritaAcara_id = dokumenBeritaAcara[0] } let dokumenTerimaSanksi_id = [] if (dokumen_terima_sanksi) { const dokumenTerimaSanksi = await addManyDokumen(dokumen_terima_sanksi) dokumenTerimaSanksi_id = dokumenTerimaSanksi.map((e) => e._id) } 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, sanksi: pelanggaran.map(e => ({ label: e.label_sanksi, value: e.sanksi, level: e.level_sanksi })), berita_acara: dokumenBeritaAcara_id, tanggal_terima_sanksi, dokumen_terima_sanksi: dokumenTerimaSanksi_id, tanggal_akhir_keberatan, masa_berlaku: { from_date, to_date }, batas_waktu: { keberatan: hariKerja(10) } }) // if (data) { // await axios.post( // `https://api.kemdikbud.go.id:8243/pddikti/1.2/pt/${laporan.pt.kode}/sanksi`, // JSON.stringify({ // noSanksi: no_sanksi, // tmtBerlaku: from_date, // tstBerlaku: tanggal_terima_sanksi, // idJenisSanksi: Math.max(...pelanggaran.map(e => e.level_sanksi)), // alasan: 'Penetapan sanksi' // }), { // 'Content-Type': 'application/json' // } // ).then(async (data) => { // await logModel.create({ // user: user._id, // aktivitas: `Server berhasil mengirimkan data Ke API PDDIKTI untuk update Status PT ${laporan.pt.nama}` // }) // }).catch(async e => { // await Promise.all([ // laporanModel.updateOne({ // _id: laporan._id // }, { // sanksi: null // }), sanksiModel.deleteOne({ // _id: data._id // }), logModel.create({ // user: user._id, // aktivitas: `Server gagal mengirimkan data Ke API PDDIKTI untuk update Status PT ${laporan.pt.nama}` // }) // ]) // return response.error(res, { // message: 'Gagal Membuat Sanksi', // error: e.message // }) // }) // } await laporanModel.findByIdAndUpdate(laporan._id, { sanksi: data._id // aktif: false, }) 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, berita_acara: dokumenBeritaAcara_id, }) return response.success(res, { message: 'Berhasil membuat Sanksi', data }) }) exports.update = handleError(async (req, res) => { const { no_sanksi, keterangan, from_date, to_date } = req.body let sanksiBody = req.body.sanksi const { sanksi_id } = req.params const files = req.files const user = req.user const isValid = validate(res, req.body, { no_sanksi: 'string', keterangan: 'string', sanksi: 'string', from_date: 'string', to_date: 'string' }) if (!isValid) return const sanksi = await cekSatuDataSanksi(res, user, sanksi_id, { all: true }) if (!sanksi) return // pelanggaran_id = await cekBanyakDataPelanggaran(res, pelanggaran_id) // if (!pelanggaran_id) return sanksiBody = JSON.parse(sanksiBody) // 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.updateOne( { _id: sanksi._id }, { no_sanksi, // pelanggaran: pelanggaran_id, sanksi: sanksiBody, keterangan, dokumen: dokumen_id, masa_berlaku: { from_date, to_date }, $push: { riwayat_sanksi: sanksi } } ) // await laporanModel.findByIdAndUpdate(laporan._id, { // sanksi: data._id, // // aktif: false, // }) await pemantauanModel.create({ laporan: sanksi.laporan._id, sanksi: sanksi._id, action: 'UPDATE SANKSI', pt_id: sanksi.laporan.pt.id, user: user._id, keterangan: 'Melakukan Perubahan Sanksi', dokumen: dokumen_id, data: { no_sanksi, // pelanggaran: pelanggaran_id, sanksi: sanksiBody, keterangan, masa_berlaku: { from_date, to_date } } }) return response.success(res, { message: 'Berhasil merubah Sanksi', data }) }) exports.updatePt = handleError(async (req, res) => { const { is_pengajuan_keberatan, is_pengajuan_banding, is_dokumen_perbaikan } = req.body const { sanksi_id } = req.params const user = req.user const isValid = validate(res, req.body, { is_pengajuan_keberatan: { type: 'boolean', optional: true }, is_pengajuan_banding: { type: 'boolean', optional: true }, is_dokumen_perbaikan: { type: 'boolean', optional: true } }) if (!isValid) return const sanksi = await cekSatuDataSanksi(res, user, sanksi_id) if (!sanksi) return let keterangan = '' let last_step = '' if (is_pengajuan_keberatan == true) { last_step = 'Permohonan Keberatan' keterangan = 'Menerima Pengajuan Keberatan' } else if (is_pengajuan_keberatan == false) { keterangan = 'Membatalkan Pengajuan Keberatan' last_step = 'Dokumen Perbaikan' } if (is_pengajuan_banding == true) { last_step = 'Permohonan Banding' keterangan = 'Menerima Pengajuan Banding' } else if (is_pengajuan_banding == false) { keterangan = 'Membatalkan Pengajuan Banding' last_step = 'Dokumen Perbaikan' } await pemantauanModel.create({ laporan: sanksi.laporan._id, sanksi: sanksi._id, action: 'UPDATE SANKSI', pt_id: sanksi.laporan.pt.id, user: user._id, keterangan }) if (is_dokumen_perbaikan == true) { last_step = 'Dokumen Perbaikan' } await sanksiModel.updateOne( { _id: sanksi._id }, { is_pengajuan_keberatan, is_pengajuan_banding, last_step } ) return response.success(res, { message: 'Berhasil merubah Sanksi' }) }) exports.getAll = handleError(async (req, res) => { const user = req.user const { keberatan, jawaban, banding, cabutSanksi, perbaikan, aktif, delegasi, naikSanksi, turunSanksi, pengajuan_keberatan, bypassCabutSanksi } = req.query const where = {} const q = {} if (aktif && aktif === 'false') { where.aktif = false } if (pengajuan_keberatan === 'true') { where.is_pengajuan_keberatan = true } if (keberatan === 'true') { where['pengajuan.keberatan'] = { $exists: true, $ne: null } where.is_pengajuan_keberatan = true if (jawaban === 'true') { where['jawaban.keberatan'] = { $exists: true, $ne: null } } } if (banding === 'true') { where.banding = true where.is_pengajuan_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 } } } if (cabutSanksi === 'true') { where.$or = [ { perbaikan: { $exists: true, $ne: [] } }, { bypass_cabut_sanksi: { $eq: true } } ] // where.perbaikan = { $exists: true, $ne: [] } if (jawaban === 'true') { where.$or = [ { perbaikan: { $exists: true, $ne: [] }, 'jawaban.cabut_sanksi': { $exists: true, $ne: null } }, { bypass_cabut_sanksi: { $eq: true } } ] // where.$or = where.$or.map(e => ({ ...e, ['pengajuan.cabut_sanksi']: { $exists: true, $ne: null } })) // where['jawaban.cabut_sanksi'] = { $exists: true, $ne: null } } } if (perbaikan === 'true') { where.$or = [{ 'jawaban.banding': { $exists: true, $ne: null } }, { is_pengajuan_keberatan: false }, { is_pengajuan_banding: false }] } if (delegasi === 'true') { where.delegasi = true } if (naikSanksi === 'true') { where['sanksi.level'] = { $in: [1, 2] } } if (turunSanksi === 'true') { where['sanksi.level'] = { $in: [2, 3] } } if (bypassCabutSanksi === 'true') { where.bypass_cabut_sanksi = { $exists: false, $eq: null } } const data = await cekBanyakDataSanksi(user, where, q) 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, aktif, delegasi, all } = 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 } } if (delegasi === 'true') { w.delegasi = true } if (all === 'true') { w.all = true } if (aktif && aktif === 'false') { w.aktif = false } const sanksi = await cekSatuDataSanksi(res, user, sanksi_id, w) if (!sanksi) return return response.success(res, { message: 'Berhasil ambil satu data Sanksi', data: sanksi }) }) exports.editTmt = handleError(async (req, res) => { const user = req.user const { id } = req.params const { from_date, to_date, no_surat } = req.body const files = req.files const sanksi = await cekSatuDataSanksi(res, user, id) if (!sanksi) return const isValid = validate(res, req.body, { from_date: { type: 'date', convert: true }, to_date: { type: 'date', convert: true }, no_surat: 'string' }) if (!isValid) return 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.findByIdAndUpdate(sanksi._id, { masa_berlaku: { from_date, to_date }, 'pengajuan.update_tmt': { no_surat, dokumen: dokumen_id } }) await pemantauanModel.create({ laporan: sanksi.laporan._id, user: user._id, action: 'EDIT TMT', pt_id: sanksi.laporan.pt.id, keterangan: 'Mengubah masa berlaku sanksi', for_public: true }) return response.success(res, { message: 'Berhasil update tmt', data }) }) exports.addPesertaPleno = handleError(async (req, res) => { const isValid = validate(res, req.body, { laporan_id: 'string', nama: 'string' }) if (!isValid) return const { laporan_id, nama } = req.body const laporan = await laporanModel.findOne({ _id: laporan_id // sanksi: { // $eq: null, // $exists: false // } }) if (!laporan) return response.error(res, { code: 404, message: 'laporan_id tidak ada' }) const file = req.file if (!file) { return response.error(res, { message: 'ttd harus ada' }) } const dokumen = await addDokumen(file) await laporanModel.findOneAndUpdate( { _id: laporan._id }, { $push: { peserta_penetapan_sanksi: { nama, ttd: dokumen.id } } } ) return response.success(res, { message: 'Berhasil tambah peserta pleno' }) }) exports.removePesertaPleno = handleError(async (req, res) => { const isValid = validate(res, req.body, { peserta_id: 'string', laporan_id: 'string' }) if (!isValid) return const user = req.user const { laporan_id, peserta_id } = req.body const laporan = await cekSatuDataLaporan(res, user, laporan_id, { evaluasi: { $exists: true, $ne: [] } }) if (!laporan) return await laporanModel.findOneAndUpdate( { _id: laporan._id }, { $pull: { peserta_penetapan_sanksi: { _id: peserta_id } } } ) return response.success(res, { message: 'Berhasil menghapus peserta pleno' }) }) exports.updateToDokumenPerbaikan = handleError(async (req, res) => { const isValid = validate(res, req.body, { sanksi_id: 'string' }) if (!isValid) return const { sanksi_id } = req.body const user = req.user const sanksi = await cekSatuDataSanksi(res, user, sanksi_id) await sanksiModel.updateOne({ _id: sanksi._id }, { is_pengajuan_keberatan: false, 'pengajuan.cabut_sanksi': null }) return response.success(res, { message: 'Berhasil update data Sanksi ke Dokumen Perbaikan' }) })