| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- const laporanModel = require('../model/laporan.model')
- const pelanggaranModel = require('../model/pelanggaran.model')
- const sanksiModel = require('../model/sanksi.model')
- const response = require('../utils/responseHandler')
- exports.cekSatuDataLaporan = async (res, user, laporan_id, where = {}) => {
- const laporan = await laporanModel
- .findOne({ _id: laporan_id, ...where })
- .populate('user')
- .populate('pelanggaran')
- .populate('dokumen')
- .populate('evaluasi.dokumen')
- 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)
- )
- ) {
- response.error(res, {
- message: 'laporan_id tidak ada',
- code: 404,
- })
- return false
- }
- return laporan
- }
- exports.cekBanyakDataLaporan = async (user, where = {}) => {
- let data = await laporanModel
- .find({ aktif: true, ...where })
- .populate('user')
- .populate('pelanggaran')
- .populate('dokumen')
- .populate('evaluasi.dokumen')
- .sort({
- createdAt: -1,
- })
- if (user.role.id !== 2020) {
- data = data.filter(
- (e) => e.role_data === 'lldikti' && e.pt.pembina.id === user.lembaga.id
- )
- } else {
- data = data.filter((e) => e.role_data === 'dikti')
- }
- return data
- }
- exports.cekSatuDataSanksi = async (res, user, sanksi_id, where = {}) => {
- const sanksi = await sanksiModel
- .findOne({ _id: sanksi_id, ...where })
- .populate({
- path: 'laporan',
- select: 'pt role_data aktif',
- })
- .populate('dokumen')
- .populate('pelanggaran')
- if (
- sanksi &&
- !(
- (user.role.id === 2021 &&
- sanksi.laporan.role_data === 'lldikti' &&
- sanksi.pt.pembina.id === user.lembaga.id &&
- sanksi.laporan.aktif === true) ||
- (user.role.id === 2020 &&
- sanksi.laporan.role_data === 'dikti' &&
- sanksi.laporan.aktif === true) ||
- (user.role.id === 2022 && sanksi.pt.id === user.lembaga.id)
- )
- ) {
- response.error(res, {
- message: 'sanksi_id tidak ada',
- code: 404,
- })
- return false
- }
- return sanksi
- }
- exports.cekBanyakDataSanksi = async (user, where = {}) => {
- let data = await sanksiModel
- .find({ ...where })
- .populate({
- path: 'laporan',
- select: 'role_data aktif',
- })
- .populate('dokumen')
- .populate('pelanggaran')
- if (user.role.id === 2021) {
- data = data.filter(
- (e) =>
- e.laporan.role_data === 'lldikti' &&
- e.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.pt.id === user.lembaga.id)
- }
- return data
- }
- exports.cekBanyakDataDokumen = async (res, files) => {
- if (!files.length) {
- response.error(res, {
- message: 'dokumen harus ada',
- })
- return false
- }
- const dokumen = await addManyDokumen(files)
- return dokumen.map((e) => e._id)
- }
- exports.cekBanyakDataPelanggaran = async (res, pelanggaran_id) => {
- id_pelanggaran = pelanggaran_id.split(',')
- const pelanggaran = await pelanggaranModel.find({
- _id: {
- $in: id_pelanggaran,
- },
- })
- if (!pelanggaran.length) {
- response.error(res, { message: 'pelanggaran_id tidak ada' })
- return false
- }
- return pelanggaran.map((e) => e._id)
- }
|