laporan.controller.js 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. const auth = require('../../middleware/verifyToken')
  2. const { validation } = require('../../middleware/validation')
  3. const uploadFile = require('../../middleware/uploadFile')
  4. const response = require('../../utils/responseHandler')
  5. const { addManyDokumen } = require('../../utils/dokumenFunction')
  6. const checkData = require('../../middleware/checkData')
  7. const pelanggaranModel = require('../../model/pelanggaran.model')
  8. const laporanModel = require('../../model/laporan.model')
  9. const pemantauanModel = require('../../model/pemantauan.model')
  10. const { sendWaCreateLaporan } = require('../../services/v2/notifikasi.service')
  11. const isUnique = require('../../middleware/isUnique')
  12. const {
  13. CREATE_LAPORAN, PELAPORAN, DIKTI, TRUE, LLDIKTI, PENJADWALAN, PEMERIKSAAN, PTB_DIKTI, PTB_LLDIKTI, PTB_PT,
  14. PTB_ADMIN, PTB_READ, FALSE, DELEGASI, DITUTUP, UPDATE_LAPORAN
  15. } = require('../../utils/constanta')
  16. const forRole = require('../../middleware/role')
  17. const handleDokumen = require('../../utils/handleDokumen')
  18. const pddiktiService = require('../../services/v2/pddikti.service')
  19. exports.create = [
  20. auth,
  21. uploadFile.array('dokumen'),
  22. validation((req) => req.body, {
  23. no_laporan: 'string',
  24. pt_id: 'string',
  25. pelanggaran_id: 'string',
  26. keterangan: 'string'
  27. }),
  28. isUnique((req) => req.body.no_laporan, (no_laporan) => laporanModel.findOne({ no_laporan })),
  29. checkData((req) => req.body.pt_id, (pt_id) => pddiktiService.getPT(pt_id), 'pt'),
  30. checkData((req) => req.body.pelanggaran_id, (data) => {
  31. const pelanggaran_id = data.split(',')
  32. return pelanggaranModel.find({
  33. _id: {
  34. $in: pelanggaran_id
  35. }
  36. })
  37. },
  38. 'pelanggaran'
  39. ),
  40. async (req, res) => {
  41. const { no_laporan, keterangan, dokumen } = req.body
  42. const { pt, pelanggaran } = req.data
  43. const user = req.user
  44. let dokumen_id = []
  45. if (dokumen.length) dokumen_id = (await addManyDokumen(dokumen)).map(e => e._id)
  46. try {
  47. const data = await laporanModel.create({
  48. no_laporan,
  49. user: user._id,
  50. dokumen: dokumen_id,
  51. pt: pt[0],
  52. pelanggaran: pelanggaran.map(e => e._id),
  53. keterangan,
  54. role_data: user.role.id === 2021 ? LLDIKTI : DIKTI,
  55. role_asal: user.role.id === 2021 ? LLDIKTI : DIKTI,
  56. step: [PELAPORAN],
  57. flag: PELAPORAN
  58. })
  59. await pemantauanModel.create({
  60. laporan: data._id,
  61. action: CREATE_LAPORAN,
  62. pt_id: pt[0].id,
  63. user: user._id,
  64. keterangan: 'Membuat Laporan',
  65. dokumen: dokumen_id,
  66. for_pt: false
  67. })
  68. await sendWaCreateLaporan({ user, pt, keterangan, no_laporan })
  69. } catch (e) {
  70. return response.error(res, {
  71. message: e.message,
  72. code: 500
  73. })
  74. }
  75. return response.success(res, {
  76. message: 'Berhasil menambah laporan',
  77. code: 201
  78. })
  79. }
  80. ]
  81. exports.getAll = [
  82. auth,
  83. forRole([PTB_DIKTI, PTB_LLDIKTI, PTB_ADMIN, PTB_READ]),
  84. async (req, res) => {
  85. const user = req.user
  86. const { no_laporan, pt_id, penjadwalan, pemeriksaan, aktif, delegasi, all, sanksi, tuntas } = req.query
  87. let query = {}
  88. switch (user.role.id) {
  89. case PTB_DIKTI:
  90. query.$or = [
  91. { role_asal: DIKTI },
  92. { role_data: DIKTI }
  93. ]
  94. if (delegasi === TRUE) {
  95. query = {
  96. role_asal: DIKTI,
  97. role_data: LLDIKTI
  98. }
  99. }
  100. break
  101. case PTB_LLDIKTI:
  102. query.$or = [
  103. { role_asal: LLDIKTI },
  104. { role_data: LLDIKTI }
  105. ]
  106. if (delegasi === TRUE) {
  107. query = {
  108. role_asal: LLDIKTI,
  109. role_data: DIKTI
  110. }
  111. }
  112. query['pt.pembina.id'] = user.lembaga.id
  113. break
  114. }
  115. query.step = { $in: [PELAPORAN] }
  116. if (penjadwalan === TRUE) {
  117. query.step = { $in: [PENJADWALAN] }
  118. }
  119. if (pemeriksaan === TRUE) {
  120. query.step = { $in: [PEMERIKSAAN] }
  121. }
  122. let data
  123. try {
  124. data = await laporanModel
  125. .find(query)
  126. .populate('user')
  127. .populate({ path: 'sanksi', populate: ['pelanggaran'] })
  128. .sort({
  129. createdAt: -1
  130. })
  131. } catch (e) {
  132. return response.error(res, {
  133. message: e.message,
  134. code: 500
  135. })
  136. }
  137. return response.success(res, {
  138. message: 'Berhasil mendapatkan data',
  139. data
  140. })
  141. }
  142. ]
  143. exports.getOne = [
  144. auth,
  145. forRole([PTB_DIKTI, PTB_LLDIKTI, PTB_PT]),
  146. checkData((req) => req.params.id, (id) =>
  147. laporanModel.findById(id)
  148. .populate({ path: 'user', populate: 'foto' })
  149. .populate({ path: 'pelanggaran', select: 'pelanggaran' })
  150. .populate({ path: 'sanksi', populate: ['pelanggaran'] })
  151. .populate('dokumen')
  152. .populate('peserta_penetapan_sanksi.ttd')
  153. .populate({ path: 'evaluasi', populate: ['user', 'dokumen'] })
  154. .populate('tuntas.dokumen'),
  155. 'laporan'
  156. ),
  157. async (req, res) => {
  158. const { laporan } = req.data
  159. return response.success(res, {
  160. message: 'Berhasil mendapatkan data',
  161. data: laporan
  162. })
  163. }
  164. ]
  165. exports.update = [
  166. auth,
  167. forRole([PTB_DIKTI, PTB_LLDIKTI, PTB_PT]),
  168. checkData((req) => req.params.id, (id) => laporanModel.findById(id), 'laporan'),
  169. (req, res, next) => {
  170. if (req.query['redudansi'] === 'true') return handleDokumen.array('dokumen')(req, res, next)
  171. return next()
  172. },
  173. (req, res, next) => {
  174. req.body['dokumen'] = req.files
  175. return next()
  176. },
  177. validation((req) => req.body, {
  178. change_role: { type: 'string', optional: true, enum: [TRUE, FALSE] },
  179. aktif: { type: 'string', optional: true, enum: [TRUE, FALSE] },
  180. keterangan: 'string'
  181. }),
  182. async (req, res) => {
  183. let { keterangan, dokumen } = req.body
  184. const user = req.user
  185. const data = {}
  186. let message = ''
  187. const { change_role, aktif } = req.body
  188. const { laporan } = req.data
  189. if (change_role === 'true') {
  190. data.flag = DELEGASI
  191. data.role_data = user.role.id === 2020 ? LLDIKTI : DIKTI
  192. message = `Laporan didelegasi ke ${user.role.id === 2020 ? LLDIKTI : DIKTI}`
  193. data.alasan_delegasi = keterangan
  194. }
  195. if (aktif) {
  196. data.aktif = aktif === TRUE
  197. let dokumen_id = []
  198. if (dokumen) dokumen_id = (await addManyDokumen(dokumen)).map((e) => e._id)
  199. if (aktif === TRUE) {
  200. message = 'Laporan dibuka'
  201. } else {
  202. message = `Laporan ditutup`
  203. alasan = keterangan
  204. data.flag = DITUTUP
  205. data.tuntas = {
  206. keterangan,
  207. dokumen: dokumen_id
  208. }
  209. data.sebelum_ditutup = {
  210. step : laporan.step
  211. }
  212. data.step = []
  213. }
  214. }
  215. await laporanModel.findByIdAndUpdate(laporan._id, data)
  216. await pemantauanModel.create({
  217. action: UPDATE_LAPORAN,
  218. laporan: laporan._id,
  219. pt_id: laporan.pt.id,
  220. user: user._id,
  221. keterangan: message,
  222. alasan: keterangan,
  223. for_pt: false
  224. })
  225. return response.success(res, {
  226. message: 'Berhasil update laporan'
  227. })
  228. }
  229. ]