pemantauan.controller.js 3.1 KB

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