laporan.controller.js 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383
  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 logModel = require('../model/log.model')
  8. const { validate } = require('../utils/validation')
  9. const { notifWA } = require('../utils/notifFunction')
  10. const { addManyDokumen } = require('../utils/dokumenFunction')
  11. const userModel = require('../model/user.model')
  12. const { cekSatuDataLaporan, cekBanyakDataLaporan } = require('../utils/cekData')
  13. exports.create = handleError(async (req, res) => {
  14. const user = req.user
  15. const files = req.files
  16. const isValid = validate(res, req.body, {
  17. no_laporan: 'string',
  18. pt_id: 'string',
  19. pelanggaran_id: 'string',
  20. keterangan: 'string',
  21. })
  22. if (!isValid) return
  23. const { no_laporan, pt_id, keterangan } = req.body
  24. let { pelanggaran_id } = req.body
  25. const pt = await axios.get(
  26. `https://api.kemdikbud.go.id:8243/pddikti/1.2/pt/${pt_id}`
  27. )
  28. if (pt.length === 0)
  29. return response.error(res, {
  30. message: 'pt_id tidak ditemukan',
  31. })
  32. let dokumen_id = []
  33. if (files.length) {
  34. const dokumen = await addManyDokumen(files)
  35. dokumen_id = dokumen.map((e) => e._id)
  36. }
  37. pelanggaran_id = pelanggaran_id.split(',')
  38. const pelanggaran = await pelanggaranModel.find({
  39. _id: {
  40. $in: pelanggaran_id,
  41. },
  42. })
  43. if (!pelanggaran.length)
  44. return response.error(res, { message: 'pelanggaran_id tidak ada' })
  45. let data = {
  46. no_laporan,
  47. user: user._id,
  48. dokumen: dokumen_id,
  49. pt: pt[0],
  50. pelanggaran: pelanggaran_id,
  51. keterangan,
  52. role_data: user.role.id === 2020 ? 'dikti' : 'lldikti',
  53. role_asal: user.role.id === 2020 ? 'dikti' : 'lldikti',
  54. level: 2,
  55. }
  56. data = await laporanModel.create(data)
  57. await pemantauanModel.create({
  58. laporan: data._id,
  59. action: 'CREATE LAPORAN',
  60. pt_id: pt[0].id,
  61. user: user._id,
  62. keterangan: 'Membuat Laporan',
  63. dokumen: dokumen_id,
  64. for_pt: false,
  65. })
  66. await logModel.create({
  67. user: user._id,
  68. aktivitas: `Berhasil membuat laporan, laporan id: ${data._id}`,
  69. })
  70. return response.success(res, {
  71. message: 'Berhasil menambah laporan',
  72. data,
  73. })
  74. })
  75. // exports.public = handleError(async (req, res) => {
  76. // const isValid = validate(res, req.body, {
  77. // nama: 'string',
  78. // email: 'email',
  79. // alamat: 'string',
  80. // no_hp: 'string',
  81. // no_laporan: 'string',
  82. // pt_id: 'string',
  83. // pelanggaran_id: 'string',
  84. // keterangan: 'string',
  85. // is_private: { type: 'string', enum: ['true', 'false'] },
  86. // })
  87. // if (!isValid) return
  88. // const {
  89. // no_laporan,
  90. // pt_id,
  91. // keterangan,
  92. // nama,
  93. // email,
  94. // alamat,
  95. // no_hp,
  96. // is_private,
  97. // } = req.body
  98. // let { pelanggaran_id } = req.body
  99. // const pt = await axios.get(
  100. // `https://api.kemdikbud.go.id:8243/pddikti/1.2/pt/${pt_id}`
  101. // )
  102. // if (!pt) {
  103. // return response.error(res, {
  104. // message: 'pt_id tidak ditemukan',
  105. // })
  106. // }
  107. // const { dokumen, foto } = req.files
  108. // if (!foto.length) {
  109. // return response.error(res, {
  110. // message: 'foto harus ada',
  111. // })
  112. // }
  113. // const foto_id = await addDokumen(foto[0])
  114. // const user = await userModel.create({
  115. // nama,
  116. // email,
  117. // no_hp,
  118. // alamat,
  119. // isPublic: true,
  120. // isPrivate: is_private === 'true',
  121. // foto: foto_id,
  122. // })
  123. // let dokumen_id = []
  124. // if (dokumen?.length) {
  125. // const dataDokumen = await addManyDokumen(dokumen)
  126. // dokumen_id = dataDokumen.map((e) => e._id)
  127. // }
  128. // pelanggaran_id = pelanggaran_id.split(',')
  129. // const pelanggaran = await pelanggaranModel.find({
  130. // _id: {
  131. // $in: pelanggaran_id,
  132. // },
  133. // })
  134. // if (!pelanggaran.length)
  135. // return response.error(res, { message: 'pelanggaran_id tidak ada' })
  136. // let data = {
  137. // no_laporan,
  138. // user: user._id,
  139. // dokumen: dokumen_id,
  140. // pt: pt[0],
  141. // pelanggaran: pelanggaran_id,
  142. // keterangan,
  143. // role_data: 'dikti',
  144. // }
  145. // data = await laporanModel.create(data)
  146. // await pemantauanModel.create({
  147. // laporan: data._id,
  148. // pt_id: pt[0].id,
  149. // user: user._id,
  150. // keterangan: 'Mengajukan Laporan',
  151. // dokumen: dokumen_id,
  152. // for_pt: false,
  153. // })
  154. // await notifWA('d5609c3c-e9e9-4dbe-9a4e-e8fa772d6770', [
  155. // { key: '1', value: 'nama', value_text: nama },
  156. // { key: '2', value: 'pt', value_text: pt[0].nama },
  157. // { key: '3', value: 'keterangan', value_text: keterangan },
  158. // { key: '4', value: 'no_laporan', value_text: no_laporan },
  159. // ])
  160. // return response.success(res, {
  161. // message: 'Berhasil menambah laporan',
  162. // data,
  163. // })
  164. // })
  165. exports.public = handleError(async (req, res) => {
  166. const user = req.user
  167. const no_laporan = req.no_laporan
  168. let level = req.level
  169. const files = req.files
  170. const isValid = validate(res, req.body, {
  171. pt_id: 'string',
  172. pelanggaran_id: 'string',
  173. keterangan: 'string',
  174. // no_verifikasi: 'string',
  175. })
  176. if (!isValid) return
  177. const { pt_id, keterangan, no_verifikasi } = req.body
  178. let { pelanggaran_id } = req.body
  179. if (no_verifikasi && user.no_verifikasi !== no_verifikasi) {
  180. return response.error(res, {
  181. message: 'no_verifikasi tidak sesuai',
  182. error: { no_verifikasi: 'No. Verifikasi tidak sesuai' },
  183. })
  184. } else if (no_verifikasi && user.no_verifikasi === no_verifikasi) {
  185. level = 3
  186. }
  187. const pt = await axios.get(
  188. `https://api.kemdikbud.go.id:8243/pddikti/1.2/pt/${pt_id}`
  189. )
  190. if (pt.length === 0)
  191. return response.error(res, {
  192. message: 'pt_id tidak ditemukan',
  193. })
  194. let dokumen_id = []
  195. if (files.length) {
  196. const dokumen = await addManyDokumen(files)
  197. dokumen_id = dokumen.map((e) => e._id)
  198. }
  199. pelanggaran_id = pelanggaran_id.split(',')
  200. const pelanggaran = await pelanggaranModel.find({
  201. _id: {
  202. $in: pelanggaran_id,
  203. },
  204. })
  205. if (!pelanggaran.length)
  206. return response.error(res, { message: 'pelanggaran_id tidak ada' })
  207. let data = {
  208. no_laporan,
  209. user: user._id,
  210. dokumen: dokumen_id,
  211. pt: pt[0],
  212. pelanggaran: pelanggaran_id,
  213. keterangan,
  214. role_data: 'dikti',
  215. role_asal: 'dikti',
  216. level,
  217. }
  218. data = await laporanModel.create(data)
  219. await pemantauanModel.create({
  220. laporan: data._id,
  221. action: 'CREATE LAPORAN',
  222. pt_id: pt[0].id,
  223. user: user._id,
  224. keterangan: 'Membuat Laporan',
  225. dokumen: dokumen_id,
  226. for_pt: false,
  227. })
  228. if (no_verifikasi)
  229. await userModel.findByIdAndUpdate(user._id, { verified: true })
  230. await notifWA('d5609c3c-e9e9-4dbe-9a4e-e8fa772d6770', [
  231. {
  232. key: '1',
  233. value: 'nama',
  234. value_text: user.isPrivate || !user.nama ? 'rahasia' : user.nama,
  235. },
  236. { key: '2', value: 'pt', value_text: pt[0].nama },
  237. { key: '3', value: 'keterangan', value_text: keterangan },
  238. { key: '4', value: 'no_laporan', value_text: no_laporan },
  239. ])
  240. await logModel.create({
  241. user: user._id,
  242. aktivitas: `Public berhasil membuat laporan, laporan id: ${data._id}`,
  243. })
  244. return response.success(res, {
  245. message: 'Berhasil menambah laporan',
  246. data,
  247. })
  248. })
  249. exports.getAll = handleError(async (req, res) => {
  250. const user = req.user
  251. const where = {}
  252. const { no_laporan, pt_id, jadwal, evaluasi, aktif, delegasi } = req.query
  253. if (no_laporan) where.no_laporan = no_laporan
  254. if (pt_id) where['pt.id'] = pt_id
  255. if (aktif) where.aktif = aktif === 'true'
  256. if (delegasi) where.delegasi = delegasi === 'true'
  257. if (jadwal === 'true') {
  258. where.jadwal = {
  259. $exists: true,
  260. $ne: null,
  261. }
  262. } else if (evaluasi === 'true') {
  263. where.evaluasi = {
  264. $exists: true,
  265. $ne: null,
  266. $not: {
  267. $size: 0,
  268. },
  269. }
  270. }
  271. let data = await cekBanyakDataLaporan(user, where)
  272. return response.success(res, {
  273. message: 'Berhasil ambil data laporan',
  274. data,
  275. })
  276. })
  277. exports.getOne = handleError(async (req, res) => {
  278. const { id } = req.params
  279. const user = req.user
  280. const { aktif, delegasi } = req.query
  281. const where = {}
  282. if (aktif) where.aktif = aktif === 'true'
  283. if (delegasi) where.delegasi = delegasi === 'true'
  284. const data = await cekSatuDataLaporan(res, user, id, where)
  285. if (!data) return
  286. return response.success(res, {
  287. message: 'Berhasil ambil data Laporan',
  288. data,
  289. })
  290. })
  291. exports.update = handleError(async (req, res) => {
  292. const { id } = req.params
  293. const user = req.user
  294. const laporan = await cekSatuDataLaporan(res, user, id)
  295. if (!laporan) return
  296. const isValid = validate(res, req.body, {
  297. change_role: { type: 'string', optional: true, enum: ['true', 'false'] },
  298. aktif: { type: 'string', optional: true, enum: ['true', 'false'] },
  299. keterangan: 'string',
  300. })
  301. if (!isValid) return
  302. const data = {}
  303. let keterangan = ''
  304. let alasan = ''
  305. const { change_role, aktif } = req.body
  306. const keterangan2 = req.body.keterangan
  307. if (change_role === 'true') {
  308. data.role_data = user.role.id === 2020 ? 'lldikti' : 'dikti'
  309. keterangan = `Laporan didelegasi ke ${
  310. user.role.id === 2020 ? 'LLDIKTI' : 'DIKTI'
  311. }`
  312. alasan = keterangan2
  313. data.alasan_delegasi = keterangan2
  314. if (laporan.jadwal) {
  315. await laporanModel.findByIdAndUpdate(laporan._id, {
  316. $unset: { jadwal: 1 },
  317. })
  318. }
  319. }
  320. if (aktif) {
  321. data.aktif = aktif === 'true'
  322. if (aktif === 'true') {
  323. keterangan = 'Laporan dibuka'
  324. } else {
  325. keterangan = `Laporan ditutup`
  326. alasan = keterangan2
  327. }
  328. }
  329. const update = await laporanModel.findByIdAndUpdate(laporan._id, data)
  330. if (change_role || aktif) {
  331. await pemantauanModel.create({
  332. action: 'UPDATE LAPORAN',
  333. laporan: laporan._id,
  334. pt_id: laporan.pt.id,
  335. user: user._id,
  336. keterangan,
  337. alasan,
  338. for_pt: false,
  339. })
  340. }
  341. await logModel.create({
  342. user: user._id,
  343. aktivitas: `Berhasil update laporan id: ${laporan._id}`,
  344. })
  345. return response.success(res, {
  346. message: 'Berhasil update laporan',
  347. data: update,
  348. })
  349. })