laporan.controller.js 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610
  1. const axios = require('../utils/axios')
  2. const handleError = require('../utils/handleError')
  3. const response = require('../utils/responseHandler')
  4. const laporanModel = require('../model/laporan.model')
  5. const pelanggaranModel = require('../model/pelanggaran.model')
  6. const pemantauanModel = require('../model/pemantauan.model')
  7. const { validate } = require('../utils/validation')
  8. const { notifWA } = require('../utils/notifFunction')
  9. const { addManyDokumen } = require('../utils/dokumenFunction')
  10. const userModel = require('../model/user.model')
  11. const {
  12. cekSatuDataLaporan,
  13. cekBanyakDataLaporan,
  14. cekBanyakDataSanksi,
  15. } = require('../utils/cekData')
  16. const { TEMPLATE_LAPORAN } = require('../utils/constanta')
  17. const logModel = require('../model/log.model')
  18. const kontakModel = require('../model/kontak.model')
  19. const { isValidObjectId } = require('mongoose')
  20. exports.create = handleError(async (req, res) => {
  21. const user = req.user
  22. const files = req.files
  23. const isValid = validate(res, req.body, {
  24. no_laporan: 'string',
  25. pt_id: 'string',
  26. pelanggaran_id: 'string',
  27. keterangan: 'string',
  28. })
  29. if (!isValid) return
  30. const { no_laporan, pt_id, keterangan } = req.body
  31. let { pelanggaran_id } = req.body
  32. const pt = await axios.get(
  33. `https://api.kemdikbud.go.id:8243/pddikti/1.2/pt/${pt_id}`
  34. )
  35. if (pt.length === 0)
  36. return response.error(res, {
  37. message: 'pt_id tidak ditemukan',
  38. })
  39. let dokumen_id = []
  40. if (files.length) {
  41. const dokumen = await addManyDokumen(files)
  42. dokumen_id = dokumen.map((e) => e._id)
  43. }
  44. pelanggaran_id = pelanggaran_id.split(',')
  45. const pelanggaran = await pelanggaranModel.find({
  46. _id: {
  47. $in: pelanggaran_id,
  48. },
  49. })
  50. if (!pelanggaran.length)
  51. return response.error(res, { message: 'pelanggaran_id tidak ada' })
  52. let data = {
  53. no_laporan,
  54. user: user._id,
  55. dokumen: dokumen_id,
  56. pt: pt[0],
  57. pelanggaran: pelanggaran_id,
  58. keterangan,
  59. role_data: user.role.id === 2020 ? 'dikti' : 'lldikti',
  60. role_asal: user.role.id === 2020 ? 'dikti' : 'lldikti',
  61. level: 2,
  62. }
  63. data = await laporanModel.create(data)
  64. let contacts = await kontakModel.find()
  65. contacts = contacts.map((e) => e.nama).join(', ')
  66. try {
  67. const notif = await notifWA(TEMPLATE_LAPORAN, [
  68. {
  69. key: '1',
  70. value: 'nama',
  71. value_text: user.nama,
  72. },
  73. { key: '2', value: 'pt', value_text: pt[0].nama },
  74. { key: '3', value: 'keterangan', value_text: keterangan },
  75. { key: '4', value: 'no_laporan', value_text: no_laporan },
  76. ])
  77. if (notif[0].status == 'success') {
  78. await logModel.create({
  79. aktivitas: `Server berhasil mengirim notif wa kepada ${contacts} untuk Pembuatan Laporan`,
  80. })
  81. } else {
  82. await logModel.create({
  83. aktivitas: `Server gagal mengirim notif wa kepada ${contacts} untuk Pembuatan Laporan, Error: ${JSON.stringify(notif)}`,
  84. })
  85. }
  86. } catch (error) {
  87. await logModel.create({
  88. aktivitas: `Server gagal mengirim notif wa kepada ${contacts} untuk Pembuatan Laporan, Error: ${error.message}`,
  89. })
  90. }
  91. await pemantauanModel.create({
  92. laporan: data._id,
  93. action: 'CREATE LAPORAN',
  94. pt_id: pt[0].id,
  95. user: user._id,
  96. keterangan: 'Membuat Laporan',
  97. dokumen: dokumen_id,
  98. for_pt: false,
  99. })
  100. return response.success(res, {
  101. message: 'Berhasil menambah laporan',
  102. data,
  103. })
  104. })
  105. // exports.public = handleError(async (req, res) => {
  106. // const isValid = validate(res, req.body, {
  107. // nama: 'string',
  108. // email: 'email',
  109. // alamat: 'string',
  110. // no_hp: 'string',
  111. // no_laporan: 'string',
  112. // pt_id: 'string',
  113. // pelanggaran_id: 'string',
  114. // keterangan: 'string',
  115. // is_private: { type: 'string', enum: ['true', 'false'] },
  116. // })
  117. // if (!isValid) return
  118. // const {
  119. // no_laporan,
  120. // pt_id,
  121. // keterangan,
  122. // nama,
  123. // email,
  124. // alamat,
  125. // no_hp,
  126. // is_private,
  127. // } = req.body
  128. // let { pelanggaran_id } = req.body
  129. // const pt = await axios.get(
  130. // `https://api.kemdikbud.go.id:8243/pddikti/1.2/pt/${pt_id}`
  131. // )
  132. // if (!pt) {
  133. // return response.error(res, {
  134. // message: 'pt_id tidak ditemukan',
  135. // })
  136. // }
  137. // const { dokumen, foto } = req.files
  138. // if (!foto.length) {
  139. // return response.error(res, {
  140. // message: 'foto harus ada',
  141. // })
  142. // }
  143. // const foto_id = await addDokumen(foto[0])
  144. // const user = await userModel.create({
  145. // nama,
  146. // email,
  147. // no_hp,
  148. // alamat,
  149. // isPublic: true,
  150. // isPrivate: is_private === 'true',
  151. // foto: foto_id,
  152. // })
  153. // let dokumen_id = []
  154. // if (dokumen?.length) {
  155. // const dataDokumen = await addManyDokumen(dokumen)
  156. // dokumen_id = dataDokumen.map((e) => e._id)
  157. // }
  158. // pelanggaran_id = pelanggaran_id.split(',')
  159. // const pelanggaran = await pelanggaranModel.find({
  160. // _id: {
  161. // $in: pelanggaran_id,
  162. // },
  163. // })
  164. // if (!pelanggaran.length)
  165. // return response.error(res, { message: 'pelanggaran_id tidak ada' })
  166. // let data = {
  167. // no_laporan,
  168. // user: user._id,
  169. // dokumen: dokumen_id,
  170. // pt: pt[0],
  171. // pelanggaran: pelanggaran_id,
  172. // keterangan,
  173. // role_data: 'dikti',
  174. // }
  175. // data = await laporanModel.create(data)
  176. // await pemantauanModel.create({
  177. // laporan: data._id,
  178. // pt_id: pt[0].id,
  179. // user: user._id,
  180. // keterangan: 'Mengajukan Laporan',
  181. // dokumen: dokumen_id,
  182. // for_pt: false,
  183. // })
  184. // await notifWA('d5609c3c-e9e9-4dbe-9a4e-e8fa772d6770', [
  185. // { key: '1', value: 'nama', value_text: nama },
  186. // { key: '2', value: 'pt', value_text: pt[0].nama },
  187. // { key: '3', value: 'keterangan', value_text: keterangan },
  188. // { key: '4', value: 'no_laporan', value_text: no_laporan },
  189. // ])
  190. // return response.success(res, {
  191. // message: 'Berhasil menambah laporan',
  192. // data,
  193. // })
  194. // })
  195. exports.public = handleError(async (req, res) => {
  196. const user = req.user
  197. const no_laporan = req.no_laporan
  198. let level = req.level
  199. const files = req.files
  200. const isValid = validate(res, req.body, {
  201. pt_id: 'string',
  202. pelanggaran_id: 'string',
  203. keterangan: 'string',
  204. // no_verifikasi: 'string',
  205. })
  206. if (!isValid) return
  207. const { pt_id, keterangan, no_verifikasi } = req.body
  208. let { pelanggaran_id } = req.body
  209. if (no_verifikasi && user.no_verifikasi !== no_verifikasi) {
  210. return response.error(res, {
  211. message: 'no_verifikasi tidak sesuai',
  212. error: { no_verifikasi: 'No. Verifikasi tidak sesuai' },
  213. })
  214. } else if (no_verifikasi && user.no_verifikasi === no_verifikasi) {
  215. level = 3
  216. }
  217. const pt = await axios.get(
  218. `https://api.kemdikbud.go.id:8243/pddikti/1.2/pt/${pt_id}`
  219. )
  220. if (pt.length === 0)
  221. return response.error(res, {
  222. message: 'pt_id tidak ditemukan',
  223. })
  224. let dokumen_id = []
  225. if (files.length) {
  226. const dokumen = await addManyDokumen(files)
  227. dokumen_id = dokumen.map((e) => e._id)
  228. }
  229. pelanggaran_id = pelanggaran_id.split(',')
  230. const pelanggaran = await pelanggaranModel.find({
  231. _id: {
  232. $in: pelanggaran_id,
  233. },
  234. })
  235. if (!pelanggaran.length)
  236. return response.error(res, { message: 'pelanggaran_id tidak ada' })
  237. let data = {
  238. no_laporan,
  239. user: user._id,
  240. dokumen: dokumen_id,
  241. pt: pt[0],
  242. pelanggaran: pelanggaran_id,
  243. keterangan,
  244. role_data: 'dikti',
  245. role_asal: 'dikti',
  246. level,
  247. }
  248. data = await laporanModel.create(data)
  249. await pemantauanModel.create({
  250. laporan: data._id,
  251. action: 'CREATE LAPORAN',
  252. pt_id: pt[0].id,
  253. user: user._id,
  254. keterangan: 'Membuat Laporan',
  255. dokumen: dokumen_id,
  256. for_pt: false,
  257. })
  258. if (no_verifikasi) await userModel.findByIdAndUpdate(user._id, { verified: true })
  259. let contacts = await kontakModel.find()
  260. contacts = contacts.map((e) => e.nama).join(', ')
  261. try {
  262. const notif = await notifWA(TEMPLATE_LAPORAN, [
  263. {
  264. key: '1',
  265. value: 'nama',
  266. value_text: user.isPrivate || !user.nama ? 'rahasia' : user.nama,
  267. },
  268. { key: '2', value: 'pt', value_text: pt[0].nama },
  269. { key: '3', value: 'keterangan', value_text: keterangan },
  270. { key: '4', value: 'no_laporan', value_text: no_laporan },
  271. ])
  272. if (notif[0].status == 'success') {
  273. await logModel.create({
  274. aktivitas: `Server berhasil mengirim notif wa kepada ${contacts} untuk Pembuatan Laporan`,
  275. })
  276. } else {
  277. await logModel.create({
  278. aktivitas: `Server gagal mengirim notif wa kepada ${contacts} untuk Pembuatan Laporan, Error: ${JSON.stringify(notif)}`,
  279. })
  280. }
  281. } catch (error) {
  282. await logModel.create({
  283. aktivitas: `Server gagal mengirim notif wa kepada ${contacts} untuk Pembuatan Laporan, Error: ${error.message}`,
  284. })
  285. }
  286. return response.success(res, {
  287. message: 'Berhasil menambah laporan',
  288. data,
  289. })
  290. })
  291. exports.getLaporanByNoLaporanAndId = handleError(async (req, res) => {
  292. const { no_laporan } = req.params
  293. let where = { evaluasi: { $exists: true, $ne: [] } }
  294. if (isValidObjectId(no_laporan)) where._id = no_laporan
  295. else where.no_laporan = no_laporan
  296. const data = await laporanModel.findOne(where)
  297. .populate({ path: 'user', populate: 'foto' })
  298. .populate({ path: 'pelanggaran', select: 'pelanggaran' })
  299. .populate({ path: 'sanksi', populate: ['pelanggaran'] })
  300. .populate('dokumen')
  301. .populate('peserta_penetapan_sanksi.ttd')
  302. .populate({ path: 'evaluasi', populate: ['user', 'dokumen'] })
  303. if (!data) {
  304. return response.error(res, {
  305. message: 'no_laporan atau id tidak ada',
  306. code: 404,
  307. })
  308. }
  309. return response.success(res, {
  310. message: 'Berhasil ambil data laporan',
  311. data,
  312. })
  313. })
  314. exports.getAll = handleError(async (req, res) => {
  315. const user = req.user
  316. const where = {}
  317. const { no_laporan, pt_id, jadwal, evaluasi, aktif, delegasi, all, sanksi } =
  318. req.query
  319. if (no_laporan) where.no_laporan = no_laporan
  320. if (pt_id) where['pt.id'] = pt_id
  321. if (aktif) where.aktif = aktif === 'true'
  322. if (all) where.all = true
  323. else if (delegasi) where.delegasi = delegasi === 'true'
  324. if (jadwal === 'true') {
  325. where.jadwal = {
  326. $exists: true,
  327. $ne: null,
  328. }
  329. } else if (evaluasi === 'true') {
  330. where.evaluasi = {
  331. $exists: true,
  332. $ne: null,
  333. $not: {
  334. $size: 0,
  335. },
  336. }
  337. } else if (sanksi === 'true') {
  338. where.sanksi = {
  339. $exists: true,
  340. $ne: null,
  341. }
  342. }
  343. let data = await cekBanyakDataLaporan(user, where)
  344. return response.success(res, {
  345. message: 'Berhasil ambil data laporan',
  346. data,
  347. })
  348. })
  349. exports.getOne = handleError(async (req, res) => {
  350. const { id } = req.params
  351. const user = req.user
  352. const { aktif, delegasi, all } = req.query
  353. const where = {}
  354. if (aktif) where.aktif = aktif === 'true'
  355. if (all) where.all = true
  356. else if (delegasi) where.delegasi = delegasi === 'true'
  357. const data = await cekSatuDataLaporan(res, user, id, where)
  358. if (!data) return
  359. return response.success(res, {
  360. message: 'Berhasil ambil data Laporan',
  361. data,
  362. })
  363. })
  364. exports.update = handleError(async (req, res) => {
  365. const { id } = req.params
  366. const user = req.user
  367. const laporan = await cekSatuDataLaporan(res, user, id)
  368. if (!laporan) return
  369. const isValid = validate(res, req.body, {
  370. change_role: { type: 'string', optional: true, enum: ['true', 'false'] },
  371. aktif: { type: 'string', optional: true, enum: ['true', 'false'] },
  372. keterangan: 'string',
  373. })
  374. if (!isValid) return
  375. const data = {}
  376. let keterangan = ''
  377. let alasan = ''
  378. const { change_role, aktif } = req.body
  379. const keterangan2 = req.body.keterangan
  380. if (change_role === 'true') {
  381. data.role_data = user.role.id === 2020 ? 'lldikti' : 'dikti'
  382. keterangan = `Laporan didelegasi ke ${user.role.id === 2020 ? 'LLDIKTI' : 'DIKTI'
  383. }`
  384. alasan = keterangan2
  385. data.alasan_delegasi = keterangan2
  386. // if (laporan.jadwal) {
  387. // await laporanModel.findByIdAndUpdate(laporan._id, {
  388. // $unset: { jadwal: 1 },
  389. // })
  390. // }
  391. }
  392. if (aktif) {
  393. data.aktif = aktif === 'true'
  394. if (aktif === 'true') {
  395. keterangan = 'Laporan dibuka'
  396. } else {
  397. keterangan = `Laporan ditutup`
  398. alasan = keterangan2
  399. }
  400. }
  401. const update = await laporanModel.findByIdAndUpdate(laporan._id, data)
  402. if (change_role || aktif) {
  403. await pemantauanModel.create({
  404. action: 'UPDATE LAPORAN',
  405. laporan: laporan._id,
  406. pt_id: laporan.pt.id,
  407. user: user._id,
  408. keterangan,
  409. alasan,
  410. for_pt: false,
  411. })
  412. }
  413. return response.success(res, {
  414. message: 'Berhasil update laporan',
  415. data: update,
  416. })
  417. })
  418. exports.jumlahLaporan = handleError(async (req, res) => {
  419. const laporan = await laporanModel.aggregate([
  420. {
  421. $match: {
  422. aktif: true,
  423. },
  424. },
  425. {
  426. $group: {
  427. _id: '$pt.pembina.nama',
  428. jumlah_laporan: {
  429. $sum: 1,
  430. },
  431. propinsi: {
  432. $addToSet: '$pt.propinsi.nama',
  433. },
  434. },
  435. },
  436. {
  437. $sort: {
  438. _id: 1,
  439. },
  440. },
  441. ])
  442. return response.success(res, {
  443. message: 'Jumlah Laporan',
  444. data: laporan,
  445. })
  446. })
  447. exports.laporanByPembina = handleError(async (req, res) => {
  448. const { idPembina } = req.params
  449. const {
  450. penjadwalan,
  451. pemeriksaan,
  452. sanksi,
  453. keberatan,
  454. banding,
  455. perbaikan,
  456. cabutSanksi,
  457. } = req.query
  458. const user = req.user
  459. const where = {}
  460. let isLaporan = true
  461. let isSanksi = true
  462. if (penjadwalan === 'true') {
  463. where.jadwal = {
  464. $exists: true,
  465. $ne: null,
  466. }
  467. isLaporan = true
  468. isSanksi = false
  469. }
  470. if (pemeriksaan === 'true') {
  471. where.evaluasi = {
  472. $exists: true,
  473. $ne: null,
  474. $not: {
  475. $size: 0,
  476. },
  477. }
  478. isLaporan = true
  479. isSanksi = false
  480. }
  481. if (sanksi === 'true') {
  482. where.sanksi = {
  483. $exists: true,
  484. $ne: null,
  485. }
  486. isLaporan = false
  487. isSanksi = true
  488. }
  489. if (keberatan === 'true') {
  490. where['pengajuan.keberatan'] = { $exists: true, $ne: null }
  491. isLaporan = false
  492. isSanksi = true
  493. }
  494. if (banding === 'true') {
  495. where.banding = true
  496. where['pengajuan.keberatan'] = { $exists: true, $ne: null }
  497. where['jawaban.keberatan'] = { $exists: true, $ne: null }
  498. where['pengajuan.banding'] = { $exists: true, $ne: null }
  499. isLaporan = false
  500. isSanksi = true
  501. }
  502. if (cabutSanksi === 'true') {
  503. where.perbaikan = {
  504. $exists: true,
  505. $ne: null,
  506. $not: {
  507. $size: 0,
  508. },
  509. }
  510. isLaporan = false
  511. isSanksi = true
  512. }
  513. if (perbaikan === 'true') {
  514. where['jawaban.banding'] = { $exists: true, $ne: null }
  515. isLaporan = false
  516. isSanksi = true
  517. }
  518. const [laporan, dataSanksi] = await Promise.all([
  519. (async () =>
  520. isLaporan
  521. ? await cekBanyakDataLaporan(user, {
  522. 'pt.pembina.id': idPembina,
  523. all: true,
  524. ...where,
  525. })
  526. : [])(),
  527. (async () =>
  528. isSanksi
  529. ? (
  530. await cekBanyakDataSanksi(
  531. user,
  532. { all: true, ...where },
  533. {
  534. ['pt.pembina.id']: idPembina,
  535. }
  536. )
  537. ).filter((e) => e.laporan != null)
  538. : [])(),
  539. ])
  540. return response.success(res, {
  541. message: 'berhasil get laporan by pembina',
  542. data: { laporan, sanksi: dataSanksi },
  543. })
  544. })
  545. exports.getOneLaporanPublic = handleError(async (req, res) => {
  546. const { id } = req.params
  547. const data = await laporanModel.findById(id)
  548. .populate({ path: 'user', populate: 'foto' })
  549. .populate({ path: 'pelanggaran', select: 'pelanggaran' })
  550. .populate({ path: 'sanksi', populate: ['pelanggaran'] })
  551. .populate('dokumen')
  552. .populate('peserta_penetapan_sanksi.ttd')
  553. .populate({ path: 'evaluasi', populate: ['user', 'dokumen'] })
  554. console.log(data)
  555. if (!data) return response.error(res, {
  556. code: 404,
  557. message: 'laporan_id tidak ada'
  558. })
  559. return response.success(res, {
  560. message: 'Berhasil ambil satu data Laporan',
  561. data,
  562. })
  563. })