pemantauan.controller.js 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. const axios = require('../utils/axios')
  2. const handleError = require('../utils/handleError')
  3. const response = require('../utils/responseHandler')
  4. const pemantauanModel = require('../model/pemantauan.model')
  5. const { cekSatuDataLaporan, cekSatuDataSanksi } = require('../utils/cekData')
  6. const laporanModel = require('../model/laporan.model')
  7. const userModel = require('../model/user.model')
  8. exports.get = handleError(async (req, res) => {
  9. const user = req.user
  10. const { laporan_id } = req.params
  11. const { delegasi, asc, all } = req.query
  12. // const pt = await axios.get(
  13. // `https://api.kemdikbud.go.id:8243/pddikti/1.2/pt/${pt_id}`
  14. // )
  15. // if (!pt) {
  16. // return response.error(res, {
  17. // message: 'pt_id tidak ditemukan',
  18. // })
  19. // }
  20. // if (user.role.id === 2021 && user.lembaga.id !== pt[0].pembina.id) {
  21. // return response.error(res, {
  22. // message: 'pt_id tidak ditemukan',
  23. // })
  24. // }
  25. const where = {}
  26. if (delegasi) where.delegasi = true
  27. if (all) where.all = true
  28. const laporan = await cekSatuDataLaporan(res, user, laporan_id, where)
  29. if (!laporan) return
  30. const data = await pemantauanModel
  31. .find({ laporan: laporan._id })
  32. .populate({ path: 'user', select: 'nama role isPublic isPrivate' })
  33. .populate({ path: 'sanksi', select: 'no_sanksi' })
  34. .populate({ path: 'laporan', select: 'no_laporan' })
  35. .populate({ path: 'sanksi', select: 'no_sanksi' })
  36. .populate('dokumen')
  37. .sort({ createdAt: asc == 'true' ? 1 : -1 })
  38. return response.success(res, {
  39. message: 'Berhasil ambil data Pemantauan',
  40. data,
  41. })
  42. })
  43. exports.getPT = handleError(async (req, res) => {
  44. const user = req.user
  45. const data = await pemantauanModel
  46. .find({ pt_id: user.lembaga.id, for_pt: true })
  47. .populate({ path: 'user', select: 'nama role isPublic isPrivate' })
  48. .populate({ path: 'laporan', select: 'no_laporan' })
  49. .populate({ path: 'sanksi', select: 'no_sanksi' })
  50. .populate('dokumen')
  51. .sort({ createdAt: -1 })
  52. return response.success(res, {
  53. message: 'Berhasil ambil data Pemantauan',
  54. data,
  55. })
  56. })
  57. exports.public = handleError(async (req, res) => {
  58. const { no_laporan } = req.query
  59. if (!no_laporan) {
  60. return response.error(res, {
  61. message: 'query no_hp dan no_laporan harus ada',
  62. })
  63. }
  64. const laporan = await laporanModel
  65. .findOne({
  66. no_laporan,
  67. })
  68. .populate('dokumen')
  69. .populate({ path: 'pelanggaran', select: 'pelanggaran' })
  70. .select(
  71. 'no_laporan pt.nama keterangan pelanggaran createdAt aktif role_data user'
  72. )
  73. const user = laporan && (await userModel.findById(laporan.user))
  74. if (!laporan || !user?.isPublic) {
  75. return response.error(res, {
  76. message: 'laporan tidak ada',
  77. })
  78. }
  79. const data = await pemantauanModel
  80. .find({ laporan, for_public: true })
  81. .populate({ path: 'user', select: 'nama isPublic role' })
  82. .select('user keterangan laporan sanksi')
  83. .populate({ path: 'laporan', select: 'no_laporan' })
  84. .populate({ path: 'sanksi', select: 'no_sanksi' })
  85. return response.success(res, {
  86. message: 'tes',
  87. data: { laporan, pemantauan: data },
  88. })
  89. })