|
|
@@ -1,53 +1,43 @@
|
|
|
+const axios = require('../utils/axios')
|
|
|
const handleError = require('../utils/handleError')
|
|
|
const response = require('../utils/responseHandler')
|
|
|
const laporanModel = require('../model/laporan.model')
|
|
|
-const userModel = require('../model/user.model')
|
|
|
+const pelanggaranModel = require('../model/pelanggaran.model')
|
|
|
const { validate } = require('../utils/validation')
|
|
|
-const axios = require('axios')
|
|
|
-const https = require('https')
|
|
|
const { addManyDokumen } = require('../utils/dokumenFunction')
|
|
|
-const pelanggaranModel = require('../model/pelanggaran.model')
|
|
|
|
|
|
exports.create = handleError(async (req, res) => {
|
|
|
- const httpsAgent = new https.Agent({
|
|
|
- rejectUnauthorized: false,
|
|
|
- })
|
|
|
- req.body.dokumen = req.files
|
|
|
const isValid = validate(res, req.body, {
|
|
|
no_laporan: 'string',
|
|
|
pt_id: 'string',
|
|
|
pelanggaran_id: 'string',
|
|
|
keterangan: 'string',
|
|
|
- dokumen: { type: 'array', items: 'object' },
|
|
|
+ role_data: { type: 'string', optional: true, enum: ['lldikti', 'dikti'] },
|
|
|
})
|
|
|
if (!isValid) return
|
|
|
|
|
|
const { no_laporan, pt_id, keterangan, pelanggaran_id, role_data } = req.body
|
|
|
|
|
|
- const url = `https://api.kemdikbud.go.id:8243/pddikti/1.2/pt/${pt_id}`
|
|
|
-
|
|
|
- const responseAxios = await axios.get(url, {
|
|
|
- headers: {
|
|
|
- Authorization: `Bearer ${process.env.TOKEN}`,
|
|
|
- },
|
|
|
- httpsAgent,
|
|
|
- })
|
|
|
-
|
|
|
- const pt = responseAxios.data[0]
|
|
|
+ const pt = await axios.get(
|
|
|
+ `https://api.kemdikbud.go.id:8243/pddikti/1.2/pt/${pt_id}`
|
|
|
+ )
|
|
|
if (!pt)
|
|
|
return response.error(res, {
|
|
|
message: 'pt_id tidak ditemukan',
|
|
|
})
|
|
|
|
|
|
- const dokumen = await addManyDokumen(req.files)
|
|
|
- const dokumen_id = dokumen.map((e) => e._id)
|
|
|
+ const files = req.files
|
|
|
+ let dokumen_id = []
|
|
|
+ if (files.length) {
|
|
|
+ const dokumen = await addManyDokumen(files)
|
|
|
+ dokumen_id = dokumen.map((e) => e._id)
|
|
|
+ }
|
|
|
|
|
|
const pelanggaran = await pelanggaranModel.find({
|
|
|
_id: {
|
|
|
$in: pelanggaran_id.split(',').map((e) => e),
|
|
|
},
|
|
|
})
|
|
|
-
|
|
|
if (!pelanggaran.length)
|
|
|
return response.error(res, { message: 'pelanggaran_id tidak ada' })
|
|
|
|
|
|
@@ -73,10 +63,14 @@ exports.create = handleError(async (req, res) => {
|
|
|
exports.getAll = handleError(async (req, res) => {
|
|
|
const user = req.user
|
|
|
let data = await laporanModel
|
|
|
- .find()
|
|
|
+ .find({ aktif: true })
|
|
|
.populate('user')
|
|
|
.populate('pelanggaran')
|
|
|
.populate('dokumen')
|
|
|
+ .populate('evaluasi.dokumen')
|
|
|
+ .sort({
|
|
|
+ createdAt: -1,
|
|
|
+ })
|
|
|
|
|
|
if (!data) {
|
|
|
return response.error(res, {
|
|
|
@@ -87,9 +81,10 @@ exports.getAll = handleError(async (req, res) => {
|
|
|
|
|
|
if (user.role.id !== 2020) {
|
|
|
data = data.filter(
|
|
|
- (e) =>
|
|
|
- e.user.role.id === user.role.id && e.pt.pembina.id === user.lembaga.id
|
|
|
+ (e) => e.role_data === 'lldikti' && e.pt.pembina.id === user.lembaga.id
|
|
|
)
|
|
|
+ } else {
|
|
|
+ data = data.filter((e) => e.role_data === 'dikti')
|
|
|
}
|
|
|
|
|
|
return response.success(res, {
|
|
|
@@ -106,10 +101,11 @@ exports.getOne = handleError(async (req, res) => {
|
|
|
.populate('user')
|
|
|
.populate('pelanggaran')
|
|
|
.populate('dokumen')
|
|
|
+ .populate('evaluasi.dokumen')
|
|
|
|
|
|
if (!data) {
|
|
|
return response.error(res, {
|
|
|
- message: 'Not Found',
|
|
|
+ message: 'Laporan Id tidak ada',
|
|
|
code: 404,
|
|
|
})
|
|
|
}
|