use of com.alliander.osgp.adapter.protocol.oslp.elster.device.DeviceMessageStatus in project Protocol-Adapter-OSLP by OSGP.
the class OslpDeviceService method handleOslpResponseGetPowerUsageHistory.
private void handleOslpResponseGetPowerUsageHistory(final GetPowerUsageHistoryDeviceRequest deviceRequest, final OslpEnvelope oslpResponse, final Pager pager, final List<PowerUsageDataDto> powerUsageHistoryData, final DeviceResponseHandler deviceResponseHandler, final String ipAddress, final String domain, final String domainVersion, final String messageType, final int retryCount, final boolean isScheduled) {
this.saveOslpResponseLogEntry(deviceRequest, oslpResponse);
this.updateSequenceNumber(deviceRequest.getDeviceIdentification(), oslpResponse);
// Get response status
DeviceMessageStatus status;
if (oslpResponse.getPayloadMessage().hasGetPowerUsageHistoryResponse()) {
final Oslp.GetPowerUsageHistoryResponse getPowerUsageHistoryResponse = oslpResponse.getPayloadMessage().getGetPowerUsageHistoryResponse();
status = this.mapper.map(getPowerUsageHistoryResponse.getStatus(), DeviceMessageStatus.class);
powerUsageHistoryData.addAll(this.mapper.mapAsList(getPowerUsageHistoryResponse.getPowerUsageDataList(), PowerUsageDataDto.class));
if (pager.getNumberOfPages() == 1 && getPowerUsageHistoryResponse.hasPageInfo()) {
pager.setNumberOfPages(getPowerUsageHistoryResponse.getPageInfo().getTotalPages());
}
} else {
status = DeviceMessageStatus.FAILURE;
}
if (pager.isLastPage() || status != DeviceMessageStatus.OK) {
// Stop processing pages and handle device response.
this.updateSequenceNumber(deviceRequest.getDeviceIdentification(), oslpResponse);
final GetPowerUsageHistoryDeviceResponse deviceResponse = new GetPowerUsageHistoryDeviceResponse(deviceRequest.getOrganisationIdentification(), deviceRequest.getDeviceIdentification(), deviceRequest.getCorrelationUid(), status, powerUsageHistoryData);
deviceResponseHandler.handleResponse(deviceResponse);
} else {
// Process next page
pager.nextPage();
try {
this.processOslpRequestGetPowerUsageHistory(deviceRequest, pager, powerUsageHistoryData, deviceResponseHandler, ipAddress, domain, domainVersion, messageType, retryCount, isScheduled);
} catch (final IOException e) {
LOGGER.error("IOException", e);
final GetPowerUsageHistoryDeviceResponse deviceResponse = new GetPowerUsageHistoryDeviceResponse(deviceRequest.getOrganisationIdentification(), deviceRequest.getDeviceIdentification(), deviceRequest.getCorrelationUid(), DeviceMessageStatus.FAILURE, null);
deviceResponseHandler.handleResponse(deviceResponse);
}
}
}
use of com.alliander.osgp.adapter.protocol.oslp.elster.device.DeviceMessageStatus in project Protocol-Adapter-OSLP by OSGP.
the class OslpDeviceService method handleOslpResponseSetEventNotifications.
private void handleOslpResponseSetEventNotifications(final DeviceRequest deviceRequest, final OslpEnvelope oslpResponse, final DeviceResponseHandler deviceResponseHandler) {
this.saveOslpResponseLogEntry(deviceRequest, oslpResponse);
this.updateSequenceNumber(deviceRequest.getDeviceIdentification(), oslpResponse);
DeviceMessageStatus status;
if (oslpResponse.getPayloadMessage().hasSetEventNotificationsResponse()) {
final Oslp.Status oslpStatus = oslpResponse.getPayloadMessage().getSetEventNotificationsResponse().getStatus();
status = this.mapper.map(oslpStatus, DeviceMessageStatus.class);
} else {
status = DeviceMessageStatus.FAILURE;
}
final DeviceResponse deviceResponse = new EmptyDeviceResponse(deviceRequest.getOrganisationIdentification(), deviceRequest.getDeviceIdentification(), deviceRequest.getCorrelationUid(), status);
deviceResponseHandler.handleResponse(deviceResponse);
}
use of com.alliander.osgp.adapter.protocol.oslp.elster.device.DeviceMessageStatus in project Protocol-Adapter-OSLP by OSGP.
the class OslpDeviceService method buildDeviceResponseGetActualPowerUsage.
private DeviceResponse buildDeviceResponseGetActualPowerUsage(final DeviceRequest deviceRequest, final OslpEnvelope oslpResponse) {
PowerUsageDataDto actualPowerUsageData = null;
DeviceMessageStatus status = null;
if (oslpResponse.getPayloadMessage().hasGetActualPowerUsageResponse()) {
final Oslp.GetActualPowerUsageResponse response = oslpResponse.getPayloadMessage().getGetActualPowerUsageResponse();
actualPowerUsageData = this.mapper.map(response.getPowerUsageData(), PowerUsageDataDto.class);
status = this.mapper.map(response.getStatus(), DeviceMessageStatus.class);
} else {
status = DeviceMessageStatus.FAILURE;
}
return new GetActualPowerUsageDeviceResponse(deviceRequest.getOrganisationIdentification(), deviceRequest.getDeviceIdentification(), deviceRequest.getCorrelationUid(), status, actualPowerUsageData);
}
use of com.alliander.osgp.adapter.protocol.oslp.elster.device.DeviceMessageStatus in project Protocol-Adapter-OSLP by OSGP.
the class OslpDeviceService method handleOslpResponseSetLight.
private void handleOslpResponseSetLight(final DeviceRequest setLightdeviceRequest, final ResumeScheduleDeviceRequest resumeScheduleDeviceRequest, final OslpEnvelope oslpResponse, final DeviceResponseHandler setLightDeviceResponseHandler, final DeviceResponseHandler resumeScheduleDeviceResponseHandler) {
this.saveOslpResponseLogEntry(setLightdeviceRequest, oslpResponse);
this.updateSequenceNumber(setLightdeviceRequest.getDeviceIdentification(), oslpResponse);
DeviceMessageStatus status;
if (oslpResponse.getPayloadMessage().hasSetLightResponse()) {
final Oslp.Status oslpStatus = oslpResponse.getPayloadMessage().getSetLightResponse().getStatus();
status = this.mapper.map(oslpStatus, DeviceMessageStatus.class);
} else {
status = DeviceMessageStatus.FAILURE;
}
// Send response to the message processor's device response handler.
final DeviceResponse deviceResponse = new EmptyDeviceResponse(setLightdeviceRequest.getOrganisationIdentification(), setLightdeviceRequest.getDeviceIdentification(), setLightdeviceRequest.getCorrelationUid(), status);
setLightDeviceResponseHandler.handleResponse(deviceResponse);
if (this.executeResumeScheduleAfterSetLight && status.equals(DeviceMessageStatus.OK)) {
LOGGER.info("Sending ResumeScheduleRequest for device: {}", setLightdeviceRequest.getDeviceIdentification());
this.resumeSchedule(resumeScheduleDeviceRequest);
} else {
LOGGER.info("Not sending ResumeScheduleRequest for device: {} because executeResumeScheduleAfterSetLight is false or DeviceMessageStatus is not OK", setLightdeviceRequest.getDeviceIdentification());
final DeviceResponse emptyDeviceResponse = new EmptyDeviceResponse(setLightdeviceRequest.getOrganisationIdentification(), setLightdeviceRequest.getDeviceIdentification(), setLightdeviceRequest.getCorrelationUid(), status);
resumeScheduleDeviceResponseHandler.handleResponse(emptyDeviceResponse);
}
}
use of com.alliander.osgp.adapter.protocol.oslp.elster.device.DeviceMessageStatus in project Protocol-Adapter-OSLP by OSGP.
the class OslpDeviceService method handleOslpResponseSetSchedulePaged.
private void handleOslpResponseSetSchedulePaged(final SetScheduleDeviceRequest deviceRequest, final OslpEnvelope oslpResponse, final String domain, final String domainVersion, final String messageType, final int retryCount, final boolean isScheduled, final Pager pager, final DeviceResponseHandler deviceResponseHandler) {
this.saveOslpResponseLogEntry(deviceRequest, oslpResponse);
this.updateSequenceNumber(deviceRequest.getDeviceIdentification(), oslpResponse);
// Get response status
DeviceMessageStatus status;
if (oslpResponse.getPayloadMessage().hasSetScheduleResponse()) {
final Oslp.Status oslpStatus = oslpResponse.getPayloadMessage().getSetScheduleResponse().getStatus();
status = this.mapper.map(oslpStatus, DeviceMessageStatus.class);
} else {
status = DeviceMessageStatus.FAILURE;
}
if (pager.isLastPage() || status != DeviceMessageStatus.OK) {
// Stop processing pages and handle device response.
this.updateSequenceNumber(deviceRequest.getDeviceIdentification(), oslpResponse);
final DeviceResponse deviceResponse = new EmptyDeviceResponse(deviceRequest.getOrganisationIdentification(), deviceRequest.getDeviceIdentification(), deviceRequest.getCorrelationUid(), status);
deviceResponseHandler.handleResponse(deviceResponse);
} else {
// Process next page
pager.nextPage();
this.processOslpRequestSetSchedulePaged(deviceRequest, pager);
}
}
Aggregations