|
|
@@ -0,0 +1,146 @@
|
|
|
+const laporanModel = require('../model/laporan.model')
|
|
|
+const sanksiModel = require('../model/sanksi.model')
|
|
|
+const pelanggaranModel = require('../model/pelanggaran.model')
|
|
|
+const handleError = require('../utils/handleError')
|
|
|
+const response = require('../utils/responseHandler')
|
|
|
+const { addManyDokumen } = require('../utils/dokumenFunction')
|
|
|
+const { validate } = require('../utils/validation')
|
|
|
+
|
|
|
+exports.create = handleError(async (req, res) => {
|
|
|
+ const { no_sanksi, keterangan } = req.body
|
|
|
+ let { pelanggaran_id } = req.body
|
|
|
+ const { laporan_id } = req.params
|
|
|
+ const files = req.files
|
|
|
+ const user = req.user
|
|
|
+
|
|
|
+ const isValid = validate(res, req.body, {
|
|
|
+ no_sanksi: 'string',
|
|
|
+ keterangan: 'string',
|
|
|
+ pelanggaran_id: 'string',
|
|
|
+ })
|
|
|
+ if (!isValid) return
|
|
|
+
|
|
|
+ const laporan = await laporanModel.findOne({
|
|
|
+ _id: laporan_id,
|
|
|
+ evaluasi: { $exists: true, $ne: [] },
|
|
|
+ })
|
|
|
+
|
|
|
+ if (
|
|
|
+ laporan &&
|
|
|
+ !(
|
|
|
+ (user.role.id === 2021 &&
|
|
|
+ laporan.role_data === 'lldikti' &&
|
|
|
+ laporan.pt.pembina.id === user.lembaga.id &&
|
|
|
+ laporan.aktif === true) ||
|
|
|
+ (user.role.id === 2020 &&
|
|
|
+ laporan.role_data === 'dikti' &&
|
|
|
+ laporan.aktif === true)
|
|
|
+ )
|
|
|
+ ) {
|
|
|
+ return response.error(res, {
|
|
|
+ message: 'laporan_id tidak ada',
|
|
|
+ code: 404,
|
|
|
+ })
|
|
|
+ }
|
|
|
+
|
|
|
+ pelanggaran_id = pelanggaran_id.split(',')
|
|
|
+ const pelanggaran = await pelanggaranModel.find({
|
|
|
+ _id: {
|
|
|
+ $in: pelanggaran_id,
|
|
|
+ },
|
|
|
+ })
|
|
|
+ if (!pelanggaran.length)
|
|
|
+ return response.error(res, { message: 'pelanggaran_id tidak ada' })
|
|
|
+ if (!files.length) {
|
|
|
+ return response.error(res, {
|
|
|
+ message: 'dokumen harus ada',
|
|
|
+ })
|
|
|
+ }
|
|
|
+
|
|
|
+ const sanksi = await sanksiModel.findOne({ laporan: laporan_id })
|
|
|
+ if (sanksi) {
|
|
|
+ return response.error(res, {
|
|
|
+ message: 'Sanksi sudah ada',
|
|
|
+ })
|
|
|
+ }
|
|
|
+
|
|
|
+ const dokumen = await addManyDokumen(files)
|
|
|
+ const dokumen_id = dokumen.map((e) => e._id)
|
|
|
+ let data = await sanksiModel.create({
|
|
|
+ no_sanksi,
|
|
|
+ laporan: laporan._id,
|
|
|
+ pt: laporan.pt,
|
|
|
+ pelanggaran: pelanggaran_id,
|
|
|
+ keterangan,
|
|
|
+ dokumen: dokumen_id,
|
|
|
+ })
|
|
|
+ return response.success(res, {
|
|
|
+ message: 'Berhasil membuat Sanksi',
|
|
|
+ data,
|
|
|
+ })
|
|
|
+})
|
|
|
+
|
|
|
+exports.getAll = handleError(async (req, res) => {
|
|
|
+ const user = req.user
|
|
|
+ let data = await sanksiModel
|
|
|
+ .find()
|
|
|
+ .populate({
|
|
|
+ path: 'laporan',
|
|
|
+ select: 'pt role_data aktif',
|
|
|
+ })
|
|
|
+ .populate('dokumen')
|
|
|
+ .populate('pelanggaran')
|
|
|
+ if (user.role.id === 2021) {
|
|
|
+ data = data.filter(
|
|
|
+ (e) =>
|
|
|
+ e.laporan.role_data === 'lldikti' &&
|
|
|
+ e.laporan.pt.pembina.id === user.lembaga.id &&
|
|
|
+ e.laporan.aktif === true
|
|
|
+ )
|
|
|
+ } else if (user.role.id === 2020) {
|
|
|
+ data = data.filter(
|
|
|
+ (e) => e.laporan.role_data === 'dikti' && e.laporan.aktif === true
|
|
|
+ )
|
|
|
+ } else {
|
|
|
+ data = data.filter((e) => e.laporan.pt.id === user.lembaga.id)
|
|
|
+ }
|
|
|
+ return response.success(res, {
|
|
|
+ message: 'Berhasil ambil data Sanksi',
|
|
|
+ data,
|
|
|
+ })
|
|
|
+})
|
|
|
+
|
|
|
+exports.getOne = handleError(async (req, res) => {
|
|
|
+ const user = req.user
|
|
|
+ const { sanksi_id } = req.params
|
|
|
+ let data = await sanksiModel
|
|
|
+ .findOne({ _id: sanksi_id })
|
|
|
+ .populate({
|
|
|
+ path: 'laporan',
|
|
|
+ select: 'pt role_data aktif',
|
|
|
+ })
|
|
|
+ .populate('dokumen')
|
|
|
+ .populate('pelanggaran')
|
|
|
+ if (
|
|
|
+ data &&
|
|
|
+ !(
|
|
|
+ (user.role.id === 2021 &&
|
|
|
+ data.laporan.role_data === 'lldikti' &&
|
|
|
+ data.laporan.pt.pembina.id === user.lembaga.id &&
|
|
|
+ data.laporan.aktif === true) ||
|
|
|
+ (user.role.id === 2020 &&
|
|
|
+ data.laporan.role_data === 'dikti' &&
|
|
|
+ data.laporan.aktif === true) ||
|
|
|
+ (user.role.id === 2022 && data.laporan.pt.id === user.lembaga.id)
|
|
|
+ )
|
|
|
+ ) {
|
|
|
+ return response.error(res, {
|
|
|
+ message: 'laporan_id tidak ada',
|
|
|
+ code: 404,
|
|
|
+ })
|
|
|
+ }
|
|
|
+ return response.success(res, {
|
|
|
+ message: 'Berhasil ambil satu data Sanksi',
|
|
|
+ data,
|
|
|
+ })
|
|
|
+})
|