| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- const handleError = require('../../utils/v1/handleError')
- const response = require('../../utils/responseHandler')
- const pemantauanModel = require('../../model/pemantauan.model')
- const { cekSatuDataLaporan, cekSatuDataSanksi } = require('../../utils/v1/cekData')
- const laporanModel = require('../../model/laporan.model')
- const userModel = require('../../model/user.model')
- const { TRUE } = require('../../utils/constanta')
- exports.get = handleError(async (req, res) => {
- const user = req.user
- const { laporan_id } = req.params
- const { delegasi, asc, all } = req.query
- const where = {}
- if (delegasi) where.delegasi = true
- if (all) where.all = true
- const laporan = await cekSatuDataLaporan(res, user, laporan_id, where)
- if (!laporan) return
- const data = await pemantauanModel
- .find({ laporan: laporan._id })
- .populate({ path: 'user', select: 'nama role isPublic isPrivate' })
- .populate({ path: 'sanksi', select: 'no_sanksi' })
- .populate({ path: 'laporan', select: 'no_laporan' })
- .populate({ path: 'sanksi', select: 'no_sanksi' })
- .populate('dokumen')
- .populate('berita_acara')
- .sort({ createdAt: asc === TRUE ? 1 : -1 })
- return response.success(res, {
- message: 'Berhasil ambil data Pemantauan',
- data,
- })
- })
- exports.getPT = handleError(async (req, res) => {
- const user = req.user
- const data = await pemantauanModel
- .find({ pt_id: user.lembaga.id, for_pt: true })
- .populate({ path: 'user', select: 'nama role isPublic isPrivate' })
- .populate({ path: 'laporan', select: 'no_laporan' })
- .populate({ path: 'sanksi', select: 'no_sanksi' })
- .populate('dokumen')
- .sort({ createdAt: -1 })
- return response.success(res, {
- message: 'Berhasil ambil data Pemantauan',
- data,
- })
- })
- exports.public = handleError(async (req, res) => {
- const { no_laporan } = req.query
- if (!no_laporan) {
- return response.error(res, {
- message: 'query no_hp dan no_laporan harus ada',
- })
- }
- const laporan = await laporanModel
- .findOne({
- no_laporan,
- })
- .populate('dokumen')
- .populate({ path: 'pelanggaran', select: 'pelanggaran' })
- .select(
- 'no_laporan pt.nama keterangan pelanggaran createdAt aktif role_data user'
- )
- const user = laporan && (await userModel.findById(laporan.user))
- if (!laporan || !user?.isPublic) {
- return response.error(res, {
- message: 'laporan tidak ada',
- })
- }
- const data = await pemantauanModel
- .find({ laporan, for_public: true })
- .populate({ path: 'user', select: 'nama isPublic role' })
- .select('user keterangan laporan sanksi')
- .populate({ path: 'laporan', select: 'no_laporan' })
- .populate({ path: 'sanksi', select: 'no_sanksi' })
- return response.success(res, {
- message: 'tes',
- data: { laporan, pemantauan: data },
- })
- })
|