public void handleFltIdMappingNotification(EntUfisMsgDTO ufisMsgDTO) {
try {
int idFlight = 0;
String intFlId = null;
EntDbFlightIdMapping entDbFlightIdMapping = null;
try{
if ("INTERFACE_FLTID".equalsIgnoreCase(ufisMsgDTO.getBody()
.getActs().get(0).getFld().get(0))) {
intFlId = (String) ufisMsgDTO.getBody().getActs().get(0)
.getData().get(0);
} else {
LOG.warn("fltIdMapping msg from Macs-Flt, field name is not 'INTERFACE_FLTID'. Msg will not be processed");
}
}catch(Exception e){
LOG.error("erro when handleFltIdMappingNotification, {}",e);
return;
}
if (intFlId != null) {
entDbFlightIdMapping = dlFlightMappingBean
.getFlightIdMappingX(intFlId);
} else {
LOG.warn("fltIdMapping msg from Macs-Flt, intFlId is null. Msg will not be processed");
return;
}
// List<String> idFlightList = ufisMsgDTO.getHead().getIdFlight();
if (entDbFlightIdMapping != null
&& entDbFlightIdMapping.getIdFlight() != null) {
idFlight = entDbFlightIdMapping.getIdFlight().intValue();
} else {
LOG.warn("fltIdMapping msg from Macs-Flt, entDbFlightIdMapping or entDbFlightIdMapping.getIdFlight() is null. Msg will not be processed");
return;
}
// main handle logic
if (idFlight != 0 && intFlId != null) {
// update load_pax
List<EntDbLoadPax> loadPaxList = _paxbean
.findByIntFltId(intFlId);
Iterator<EntDbLoadPax> loadPaxListIt = loadPaxList.iterator();
while (loadPaxListIt.hasNext()) {
EntDbLoadPax entDbLoadPax = loadPaxListIt.next();
if (idFlight != entDbLoadPax.getIdFlight()) {
EntDbLoadPax oldEntDbLoadPax = (EntDbLoadPax)SerializationUtils.clone(entDbLoadPax);
entDbLoadPax.setIdFlight(idFlight);
entDbLoadPax
.set_updateUser(HpEKConstants.MACS_PAX_DATA_SOURCE);
entDbLoadPax.set_updatedDate(HpUfisCalendar
.getCurrentUTCTime());
_paxbean.Update(entDbLoadPax);
// send notification
ufisTopicProducer.sendNotification(true, UfisASCommands.URT,
String.valueOf(entDbLoadPax.getIdFlight()), oldEntDbLoadPax, entDbLoadPax);
// update load_pax_connect
EntDbLoadPaxConn entDbLoadPaxConn = _paxConBean
.findByIdLoadPax(entDbLoadPax.getUuid());
if (entDbLoadPaxConn != null
&& idFlight != entDbLoadPaxConn.getIdFlight()) {
EntDbLoadPaxConn oldEntDbLoadPaxConn = (EntDbLoadPaxConn)SerializationUtils.clone(entDbLoadPaxConn);
entDbLoadPaxConn.setIdFlight(idFlight);
entDbLoadPaxConn
.set_updateUser(HpEKConstants.MACS_PAX_DATA_SOURCE);
entDbLoadPaxConn.set_updatedDate(HpUfisCalendar
.getCurrentUTCTime());
// _paxConBean.Update(entDbLoadPaxConn);
// send notification
ufisTopicProducer.sendNotification(true, UfisASCommands.URT,
String.valueOf(entDbLoadPaxConn.getIdFlight()), oldEntDbLoadPaxConn, entDbLoadPaxConn);
}
// update load_bag
List<EntDbLoadBag> loadBagList = dlLoadBagUpdateLocal
.getBagMoveDetailsByIdLoadPax(entDbLoadPax
.getUuid());
Iterator<EntDbLoadBag> loadBagListIt = loadBagList
.iterator();
while (loadBagListIt.hasNext()) {
EntDbLoadBag entDbLoadBag = loadBagListIt.next();
if (idFlight != entDbLoadBag.getIdFlight()) {
EntDbLoadBag oldEntDbLoadBag = (EntDbLoadBag)SerializationUtils.clone(entDbLoadBag);
entDbLoadBag.setIdFlight(idFlight);
entDbLoadBag
.setUpdatedUser(HpEKConstants.MACS_PAX_DATA_SOURCE);
entDbLoadBag.setUpdatedDate(HpUfisCalendar
.getCurrentUTCTime());
// send notification
ufisTopicProducer.sendNotification(true, UfisASCommands.URT,
String.valueOf(entDbLoadBag.getIdFlight()), oldEntDbLoadBag, entDbLoadBag);
}
}
// update serviceReques
List<EntDbServiceRequest> serviceRequestList = _dlPaxServiceRequestBean
.findByidLoadPax(entDbLoadPax.getUuid());
Iterator<EntDbServiceRequest> serviceRequestListIt = serviceRequestList
.iterator();
while (serviceRequestListIt.hasNext()) {
EntDbServiceRequest entDbServiceRequest = serviceRequestListIt
.next();
if (entDbServiceRequest.getIdFlight() != idFlight) {
EntDbServiceRequest oldEntDbServiceRequest = (EntDbServiceRequest)SerializationUtils.clone(entDbServiceRequest);
entDbServiceRequest.setIdFlight(idFlight);
entDbServiceRequest
.set_updateUser(HpEKConstants.MACS_PAX_DATA_SOURCE);
entDbServiceRequest
.set_updatedDate(HpUfisCalendar
.getCurrentUTCTime());
// send notification
ufisTopicProducer.sendNotification(true, UfisASCommands.URT,
String.valueOf(entDbServiceRequest.getIdFlight()), oldEntDbServiceRequest, entDbServiceRequest);
}
}
}
}
// update id_conx_flight for load_pax_conn table
if (entDbFlightIdMapping.getFltNumber() != null
&& entDbFlightIdMapping.getFltDateLocal() != null) {
List<EntDbLoadPaxConn> entDbLoadPaxConnList = _paxConBean
.findByFlnoFltDate(
entDbFlightIdMapping.getFltNumber(),
entDbFlightIdMapping.getFltDateLocal());
Iterator<EntDbLoadPaxConn> entDbLoadPaxConnListIt = entDbLoadPaxConnList
.iterator();
while (entDbLoadPaxConnListIt.hasNext()) {
EntDbLoadPaxConn entDbLoadPaxConn = entDbLoadPaxConnListIt
.next();
if (entDbFlightIdMapping.getIdFlight() != null
&& entDbLoadPaxConn.getIdConxFlight() != entDbFlightIdMapping
.getIdFlight().intValue()) {
EntDbLoadPaxConn oldEntDbLoadPaxConn = (EntDbLoadPaxConn)SerializationUtils.clone(entDbLoadPaxConn);
entDbLoadPaxConn
.setIdConxFlight(entDbFlightIdMapping
.getIdFlight().intValue());
entDbLoadPaxConn
.set_updateUser(HpEKConstants.MACS_PAX_DATA_SOURCE);
entDbLoadPaxConn.set_updatedDate(HpUfisCalendar
.getCurrentUTCTime());