cabutSanksi.controller.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. const handleError = require('../../utils/handleError')
  2. const sanksiModel = require('../../model/sanksi.model')
  3. const { addManyDokumen } = require('../../utils/dokumenFunction')
  4. const { validate } = require('../../utils/validation')
  5. const { cekSatuDataSanksi, cekSatuDataLaporan } = require('../../utils/cekData')
  6. const response = require('../../utils/responseHandler')
  7. const pemantauanModel = require('../../model/pemantauan.model')
  8. exports.create = handleError(async (req, res) => {
  9. const user = req.user
  10. const { laporan_id, sanksi_id } = req.query
  11. if (!laporan_id || !sanksi_id) {
  12. return response.error(res, {
  13. message: 'query laporan_id atau sanksi_id harus ada',
  14. })
  15. }
  16. const laporan = await cekSatuDataLaporan(res, user, laporan_id)
  17. const sanksi = await cekSatuDataSanksi(res, user, sanksi_id)
  18. if (!laporan || !sanksi) return
  19. const files = req.files
  20. if (!files?.length) {
  21. return response.error(res, {
  22. message: 'dokumen harus ada',
  23. })
  24. }
  25. const dokumen = await addManyDokumen(files)
  26. const dokumen_id = dokumen.map((e) => e._id)
  27. const data = await sanksiModel.findOneAndUpdate(
  28. {
  29. laporan: laporan._id,
  30. _id: sanksi._id,
  31. ['pengajuan.cabut_sanksi']: { $exists: false, $eq: null },
  32. },
  33. {
  34. ['pengajuan.cabut_sanksi']: {
  35. dokumen: dokumen_id,
  36. },
  37. }
  38. )
  39. if (!data) {
  40. return response.error(res, {
  41. message: 'cabut_sanksi sudah ada',
  42. })
  43. }
  44. await pemantauanModel.create({
  45. laporan: laporan._id,
  46. sanksi: sanksi._id,
  47. pt_id: laporan.pt.id,
  48. user: user._id,
  49. keterangan: 'Mengajukan Pencabutan Sanksi',
  50. dokumen: dokumen_id,
  51. })
  52. return response.success(res, {
  53. data,
  54. message: 'Berhasil menambah cabut_sanksi',
  55. })
  56. })
  57. exports.createJawaban = handleError(async (req, res) => {
  58. const user = req.user
  59. const { laporan_id, sanksi_id } = req.query
  60. if (!laporan_id || !sanksi_id) {
  61. return response.error(res, {
  62. message: 'query laporan_id atau sanksi_id harus ada',
  63. })
  64. }
  65. const laporan = await cekSatuDataLaporan(res, user, laporan_id)
  66. const sanksi = await cekSatuDataSanksi(res, user, sanksi_id)
  67. if (!laporan || !sanksi) return
  68. const isValid = validate(res, req.body, {
  69. status: 'string',
  70. keterangan: 'string',
  71. })
  72. if (!isValid) return
  73. const files = req.files
  74. if (!files?.length) {
  75. return response.error(res, {
  76. message: 'dokumen harus ada',
  77. })
  78. }
  79. const dokumen = await addManyDokumen(files)
  80. const dokumen_id = dokumen.map((e) => e._id)
  81. const { status, keterangan } = req.body
  82. const data = await sanksiModel.findOneAndUpdate(
  83. {
  84. laporan: laporan._id,
  85. _id: sanksi._id,
  86. ['pengajuan.cabut_sanksi']: { $exists: true, $ne: null },
  87. },
  88. {
  89. ['jawaban.cabut_sanksi']: {
  90. status,
  91. keterangan,
  92. dokumen: dokumen_id,
  93. },
  94. }
  95. )
  96. if (!data) {
  97. return response.error(res, {
  98. message: 'cabut_sanksi tidak ada',
  99. })
  100. }
  101. await pemantauanModel.create({
  102. laporan: laporan._id,
  103. sanksi: sanksi._id,
  104. pt_id: laporan.pt.id,
  105. user: user._id,
  106. keterangan: 'Menjawab Pengajuan Pencabutan Sanksi',
  107. dokumen: dokumen_id,
  108. })
  109. return response.success(res, {
  110. data,
  111. })
  112. })