user.controller.js 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. const handleError = require('../utils/handleError')
  2. const response = require('../utils/responseHandler')
  3. const userModel = require('../model/user.model')
  4. const { validate } = require('../utils/validation')
  5. const { notifWA2 } = require('../utils/notifFunction')
  6. const axios = require('../utils/axios')
  7. const { addDokumen } = require('../utils/dokumenFunction')
  8. const jwt = require('jsonwebtoken')
  9. exports.addUserPublic = handleError(async (req, res) => {
  10. const { no_laporan, pt_id, nama, email, no_hp, alamat, is_private } = req.body
  11. const no_hp2 =
  12. no_hp.substring(0, 1) === '0' ? '62' + no_hp.substring(1) : no_hp
  13. const isValid = validate(res, req.body, {
  14. no_laporan: 'string',
  15. pt_id: 'string',
  16. nama: 'string',
  17. email: 'email',
  18. no_hp: 'string',
  19. alamat: 'string',
  20. is_private: { type: 'string', enum: ['true', 'false'] },
  21. })
  22. if (!isValid) return
  23. const pt = await axios.get(
  24. `https://api.kemdikbud.go.id:8243/pddikti/1.2/pt/${pt_id}`
  25. )
  26. if (pt.length === 0)
  27. return response.error(res, {
  28. message: 'pt_id tidak ditemukan',
  29. })
  30. const foto = req.file
  31. if (!foto) {
  32. return response.error(res, {
  33. message: 'foto harus ada',
  34. })
  35. }
  36. const foto_id = await addDokumen(foto)
  37. const no_verifikasi = Math.floor(Math.random() * 1000000)
  38. const user = await userModel.create({
  39. nama,
  40. email,
  41. no_hp,
  42. alamat,
  43. isPublic: true,
  44. isPrivate: is_private === 'true',
  45. foto: foto_id,
  46. no_verifikasi,
  47. verified: false,
  48. })
  49. await notifWA2(
  50. '37a9ccba-e1bc-4d02-86e0-3be4c718af2a',
  51. { nama, no_hp: no_hp2 },
  52. [
  53. { key: '1', value: 'pt', value_text: pt[0].nama },
  54. { key: '3', value: 'no_verifikasi', value_text: no_verifikasi },
  55. { key: '2', value: 'no_laporan', value_text: no_laporan },
  56. ]
  57. )
  58. const accessToken = jwt.sign(
  59. { _id: user._id, no_laporan },
  60. process.env.SECRET,
  61. {
  62. expiresIn: '30m',
  63. }
  64. )
  65. const data = {
  66. token: `Bearer ${accessToken}`,
  67. }
  68. return response.success(res, {
  69. data: data,
  70. message: 'Berhasil menambah user',
  71. })
  72. })
  73. exports.get = handleError((req, res) => {
  74. const user = req.user
  75. return response.success(res, {
  76. message: 'Berhasil mengambil data user',
  77. data: user,
  78. })
  79. })