Files
old-crm-integration/controllers/doorLock.js

133 lines
6.8 KiB
JavaScript
Raw Normal View History

'use strict';
2019-06-14 17:41:09 +02:00
const { parseDoorLockDataFile, writeDoorLockEvent } = require('../services/doorLock/doorLock');
const { fetchAllBookings, writeBookingReservation } = require('../services/officeRnD/bookings');
2019-06-14 17:41:09 +02:00
const { calculateDoorLockCharges } = require('../services/integration/doorLockCharges');
const { integrationServiceErrors } = require('../constants/constants');
2019-07-25 06:53:32 +02:00
const { checkBookingChanges } = require('../services/integration/checkBookingChange');
2019-07-25 15:36:49 +02:00
const { checkIfProcessing, setStartProcessing, setDoneProcessing } = require('../services/integration/processingStatus');
const IncomingForm = require('formidable').IncomingForm;
const uploadDoorLockData = (req, res) => {
2019-07-25 15:36:49 +02:00
checkIfProcessing()
.then((processing) => {
if (processing){
res.status(500).send(integrationServiceErrors.PROCESSING_TRY_AGAIN);
}else{
const form = new IncomingForm();
const fileParsers = [];
2019-07-25 15:36:49 +02:00
form.on('file', (field, file) => {
if (file && file.type === 'text/csv') {
fileParsers.push(parseDoorLockDataFile(file));
}
});
2019-07-25 15:36:49 +02:00
form.on('end', () => {
Promise.all(fileParsers)
.then((parserResults) => {
const parsedData = [];
const parserErrors = [];
const unknownMembers = [];
2019-07-25 15:36:49 +02:00
parserResults.forEach((parserResult) => {
parsedData.push(...parserResult.parsedData);
parserErrors.push(...parserResult.errors);
2019-06-25 15:44:46 +02:00
2019-07-25 15:36:49 +02:00
parserResult.unknownMembers.forEach((newUnknownMember) => {
// Check if member is already labeled as unknown in different file
if (!unknownMembers.find((unknownMember) => unknownMember.details === newUnknownMember.details)){
unknownMembers.push(newUnknownMember);
}
});
});
2019-07-25 15:36:49 +02:00
const asyncWriteJobs = [];
2019-07-25 15:36:49 +02:00
parsedData.forEach((entry) => asyncWriteJobs.push(writeDoorLockEvent(entry)));
2019-06-14 17:41:09 +02:00
2019-07-25 15:36:49 +02:00
Promise.all(asyncWriteJobs)
.then(() => {
res.json({
parsedData,
parserErrors,
unknownMembers
2019-07-25 06:53:32 +02:00
});
2019-07-25 15:36:49 +02:00
setStartProcessing()
.then(() => {
checkBookingChanges()
.then(() => {
calculateDoorLockCharges()
.then(() => {
setDoneProcessing()
.catch((error) => {
console.log('Error in process done indication');
console.log(error);
})
})
.catch((error) => {
console.log('Error : ', error);
setDoneProcessing();
// res.status(500).send(integrationServiceErrors.IMPORT_SUCCESSFUL_CALCULATION_FAILED);
});
2019-07-25 15:36:49 +02:00
})
.catch((error) => {
console.log('Error : ', error);
setDoneProcessing();
// res.status(500).send(integrationServiceErrors.IMPORT_SUCCESSFUL_CALCULATION_FAILED);
});
})
.catch((error) => {
console.log('Error in processing indicator');
console.log(error);
setDoneProcessing();
});
})
.catch((error) => {
console.log(integrationServiceErrors.FAILED_TO_SAVE_DOOR_LOCK_ENTRIES);
console.log(error);
res.status(500).send(integrationServiceErrors.FAILED_TO_SAVE_DATA_GENERIC);
});
/*fetchAllBookings()
.then((bookingEntries) => {
const asyncJobs = [];
bookingEntries.forEach((bookingEntry) => asyncJobs.push(writeBookingReservation(bookingEntry)));
Promise.all(asyncJobs)
.then(() => {
calculateDoorLockCharges();
})
.catch((error) => {
console.log('Error updating booking reservations : ');
console.log(error);
})
})
.catch((error) => {
console.log(integrationServiceErrors.FAILED_TO_SAVE_BOOKINGS);
console.log(error);
return;
});
*/
})
.catch((error) => {
res.status(500).send(error);
});
});
form.parse(req);
}
})
.catch((error) => {
console.log('Error while checking processing : ');
console.log(error);
res.status(500).send('')
});
};
module.exports = {
uploadDoorLockData,
};