1
0
Fork 0
This repository has been archived on 2024-02-17. You can view files and clone it, but cannot push or open issues or pull requests.
letu/sockets/get/agendaGet.js
2020-12-14 22:35:19 +01:00

61 lines
2.3 KiB
JavaScript

const models = require("../../models");
function addWhere(options, index, attr, value) {
if (!options.include[index].where)
options.include[index].where = {};
if (!options.include[index].where[attr])
options.include[index].where[attr] = {};
if (!options.include[index].where[attr][models.Sequelize.Op.or])
options.include[index].where[attr][models.Sequelize.Op.or] = [];
options.include[index].where[attr][models.Sequelize.Op.or].push(value);
options.include[index].require = true;
}
module.exports = socket => {
return async (data) => {
let options = {
where: {},
include: [
{model: models.User, attributes: ["email", "firstName", "lastName"]},
{model: models.Group, include: models.Semester},
{model: models.Semester, include: models.Group}
]
};
if (data && data.startDate)
options.where.startDate = data.startDate;
if (data && data.endDate)
options.where.endDate = data.endDate;
if (data && data.semesters) {
for (let semester of data.semesters) {
let s = await models.Semester.findByPk(semester);
if (!s) {
socket.emit("agendaGet", {error: {message: "semester_not_found"}});
return
} else
addWhere(options, 2, "id", s.id);
}
}
if (data && data.groups) {
for (let group of data.groups) {
let g = await models.Group.findByPk(group);
if (!g) {
socket.emit("agendaGet", {error: {message: "group_not_found"}});
return
} else
addWhere(options, 1, "id", g.id);
}
}
if (data && data.teachers) {
for (let teacher of data.teachers) {
let t = await models.User.findByPk(teacher);
if (!t) {
socket.emit("agendaGet", {error: {message: "teacher_not_found"}});
return
} else
addWhere(options, 0, "email", t.email);
}
}
socket.emit("agendaGet", await models.Event.findAll(options));
}
};