laporan.controller.js 10 KB

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