| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- 'use strict';
- const logger = require('../../logger');
- const { parse } = require('../../xml/event');
- const {
- serialize: serializeDistributeEvent,
- } = require('../../xml/event/distribute-event');
- const {
- serialize: serializeOadrResponse,
- } = require('../../xml/poll/oadr-response');
- const { retrieveEvents, updateOptType } = require('../../processes/event');
- exports.postController = async (req, res) => {
- const xmlRequest = req.body;
- let parsedRequest;
- let xmlResponse;
- let serialize = serializeOadrResponse;
- try {
- parsedRequest = await parse(xmlRequest);
- let response;
- switch (parsedRequest._type) {
- case 'oadrRequestEvent':
- serialize = serializeDistributeEvent;
- response = await retrieveEvents(
- parsedRequest,
- req.clientCertificateCn,
- req.clientCertificateFingerprint,
- );
- break;
- case 'oadrCreatedEvent':
- serialize = serializeOadrResponse;
- response = await updateOptType(
- parsedRequest,
- req.clientCertificateCn,
- req.clientCertificateFingerprint,
- );
- break;
- default:
- throw new Error(`Unknown _type: ${parsedRequest._type}`);
- }
- xmlResponse = serialize(response);
- } catch (e) {
- logger.warn('Error occurred processing', parsedRequest || xmlRequest, e);
- const responseRequestId =
- parsedRequest != null ? parsedRequest.requestId : '';
- xmlResponse = serialize({
- responseCode: e.responseCode || '454',
- responseDescription: e.message || 'Unknown error',
- responseRequestId: responseRequestId || '',
- });
- }
- res.set('Content-Type', 'application/xml');
- res.send(xmlResponse);
- res.end();
- };
- exports.postErrorHandler = (error, next) => {
- logger.warn('Error in EiEvent', { error });
- next(error);
- };
|