'use strict'; const logger = require('../../logger'); const { pollForEvents } = require('../../processes/event'); const { serialize: serializeOadrResponse, } = require('../../xml/poll/oadr-response'); const { serialize: serializeDistributeEvent, } = require('../../xml/event/distribute-event'); exports.postController = async (req, res) => { const parsedRequest = req.xml; let xmlResponse; let serialize = serializeOadrResponse; try { let jsonResponse; switch (parsedRequest._type) { case 'oadrPoll': jsonResponse = await pollForEvents( parsedRequest, req.clientCertificateCn, req.clientCertificateFingerprint, ); break; default: throw new Error(`Unknown _type: ${parsedRequest._type}`); } if (jsonResponse) { serialize = serializeDistributeEvent; } else { serialize = serializeOadrResponse; jsonResponse = { responseCode: '200', responseDescription: 'OK', responseRequestId: parsedRequest.requestId || '', venId: req.clientCertificateFingerprint, }; } xmlResponse = serialize(jsonResponse); } catch (e) { logger.warn('Error occurred processing', parsedRequest, 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 OadrPoll', { error }); next(error); };