sanksi.controller.js 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. const sanksiModel = require('../model/sanksi.model')
  2. const handleError = require('../utils/handleError')
  3. const response = require('../utils/responseHandler')
  4. const { addManyDokumen } = require('../utils/dokumenFunction')
  5. const { validate } = require('../utils/validation')
  6. const pemantauanModel = require('../model/pemantauan.model')
  7. const logModel = require('../model/log.model')
  8. const { hariKerja } = require('../utils/hariKerja')
  9. const {
  10. cekSatuDataSanksi,
  11. cekSatuDataLaporan,
  12. cekBanyakDataPelanggaran,
  13. cekBanyakDataSanksi,
  14. } = require('../utils/cekData')
  15. const laporanModel = require('../model/laporan.model')
  16. const ip = require('ip')
  17. const osValue = require('../utils/osValue')
  18. exports.create = handleError(async (req, res) => {
  19. const { no_sanksi, keterangan } = req.body
  20. let { pelanggaran_id } = req.body
  21. const { laporan_id } = req.params
  22. const files = req.files
  23. const user = req.user
  24. const isValid = validate(res, req.body, {
  25. no_sanksi: 'string',
  26. keterangan: 'string',
  27. pelanggaran_id: 'string',
  28. })
  29. if (!isValid) return
  30. const laporan = await cekSatuDataLaporan(res, user, laporan_id, {
  31. evaluasi: { $exists: true, $ne: [] },
  32. })
  33. if (!laporan) return
  34. pelanggaran_id = await cekBanyakDataPelanggaran(res, pelanggaran_id)
  35. if (!pelanggaran_id) return
  36. const sanksi = await sanksiModel.findOne({ laporan: laporan_id })
  37. if (sanksi) {
  38. return response.error(res, {
  39. message: 'Sanksi sudah ada',
  40. })
  41. }
  42. if (!files.length) {
  43. return response.error(res, {
  44. message: 'dokumen harus ada',
  45. })
  46. }
  47. const dokumen = await addManyDokumen(files)
  48. const dokumen_id = dokumen.map((e) => e._id)
  49. const data = await sanksiModel.create({
  50. no_sanksi,
  51. laporan: laporan._id,
  52. user: user._id,
  53. pelanggaran: pelanggaran_id,
  54. keterangan,
  55. dokumen: dokumen_id,
  56. batas_waktu: {
  57. keberatan: hariKerja(10),
  58. },
  59. })
  60. await laporanModel.findByIdAndUpdate(laporan._id, { sanksi: data._id })
  61. await pemantauanModel.create({
  62. laporan: laporan._id,
  63. sanksi: data._id,
  64. action: 'CREATE SANKSI',
  65. pt_id: laporan.pt.id,
  66. user: user._id,
  67. keterangan: 'Melakukan penetapan Sanksi',
  68. dokumen: dokumen_id,
  69. })
  70. await logModel.create({
  71. user: user._id,
  72. aktivitas: `Berhasil melakukan penetapan sanksi pada laporan id: ${laporan._id}, sanksi id: ${data._id}`,
  73. os: osValue(),
  74. ipv4: ip.address('public', 'ipv4'),
  75. })
  76. return response.success(res, {
  77. message: 'Berhasil membuat Sanksi',
  78. data,
  79. })
  80. })
  81. exports.getAll = handleError(async (req, res) => {
  82. const user = req.user
  83. const { keberatan, jawaban, banding, cabutSanksi, perbaikan } = req.query
  84. const where = {}
  85. if (keberatan === 'true') {
  86. where['pengajuan.keberatan'] = { $exists: true, $ne: null }
  87. if (jawaban === 'true') {
  88. where['jawaban.keberatan'] = { $exists: true, $ne: null }
  89. }
  90. } else if (banding === 'true') {
  91. where.banding = true
  92. where['pengajuan.keberatan'] = { $exists: true, $ne: null }
  93. where['jawaban.keberatan'] = { $exists: true, $ne: null }
  94. where['pengajuan.banding'] = { $exists: true, $ne: null }
  95. if (jawaban === 'true') {
  96. where['jawaban.banding'] = { $exists: true, $ne: null }
  97. }
  98. } else if (cabutSanksi === 'true') {
  99. where['pengajuan.cabut_sanksi'] = { $exists: true, $ne: null }
  100. if (jawaban === 'true') {
  101. where['jawaban.cabut_sanksi'] = { $exists: true, $ne: null }
  102. }
  103. } else if (perbaikan === 'true') {
  104. where.$or = [
  105. { 'jawaban.cabut_sanksi': { $exists: true, $ne: null } },
  106. { 'jawaban.banding': { $exists: true, $ne: null } },
  107. ]
  108. }
  109. const data = await cekBanyakDataSanksi(user, where)
  110. return response.success(res, {
  111. message: 'Berhasil ambil data Sanksi',
  112. data,
  113. })
  114. })
  115. exports.getOne = handleError(async (req, res) => {
  116. const user = req.user
  117. const { sanksi_id } = req.params
  118. const w = {}
  119. const { banding } = req.query
  120. if (banding === 'true') {
  121. w.banding = true
  122. w['pengajuan.keberatan'] = { $exists: true, $ne: null }
  123. w['jawaban.keberatan'] = { $exists: true, $ne: null }
  124. w['pengajuan.banding'] = { $exists: true, $ne: null }
  125. }
  126. const sanksi = await cekSatuDataSanksi(res, user, sanksi_id, w)
  127. if (!sanksi) return
  128. return response.success(res, {
  129. message: 'Berhasil ambil satu data Sanksi',
  130. data: sanksi,
  131. })
  132. })