org.jumpmind.symmetric.service.impl.AcknowledgeService Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of symmetric-ds Show documentation
Show all versions of symmetric-ds Show documentation
SymmetricDS is an open source database synchronization solution. It is platform-independent,
web-enabled, and database-agnostic. SymmetricDS was first built to replicate changes between 'retail store'
databases and ad centralized 'corporate' database.
The newest version!
/*
* Licensed to JumpMind Inc under one or more contributor
* license agreements. See the NOTICE file distributed
* with this work for additional information regarding
* copyright ownership. JumpMind Inc licenses this file
* to you under the GNU Lesser General Public License (the
* "License"); you may not use this file except in compliance
* with the License.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, see
* .
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.jumpmind.symmetric.service.impl;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import org.jumpmind.symmetric.model.BatchInfo;
import org.jumpmind.symmetric.model.OutgoingBatch;
import org.jumpmind.symmetric.model.OutgoingBatch.Status;
import org.jumpmind.symmetric.service.IAcknowledgeService;
import org.jumpmind.symmetric.service.IOutgoingBatchService;
import org.jumpmind.symmetric.service.IRegistrationService;
import org.jumpmind.symmetric.transport.IAcknowledgeEventListener;
import org.springframework.jdbc.core.RowCallbackHandler;
import org.springframework.transaction.annotation.Transactional;
/**
*
*
*
*/
public class AcknowledgeService extends AbstractService implements IAcknowledgeService {
private IOutgoingBatchService outgoingBatchService;
private List batchEventListeners;
private IRegistrationService registrationService;
@Transactional
public void ack(final BatchInfo batch) {
if (batchEventListeners != null) {
for (IAcknowledgeEventListener batchEventListener : batchEventListeners) {
batchEventListener.onAcknowledgeEvent(batch);
}
}
if (batch.getBatchId() == BatchInfo.VIRTUAL_BATCH_FOR_REGISTRATION) {
if (batch.isOk()) {
registrationService.markNodeAsRegistered(batch.getNodeId());
}
} else {
OutgoingBatch outgoingBatch = outgoingBatchService.findOutgoingBatch(batch.getBatchId());
Status status = batch.isOk() ? Status.OK : Status.ER;
if (outgoingBatch != null) {
// Allow an outside system/user to indicate that a batch
// is OK.
if (outgoingBatch.getStatus() != Status.OK) {
outgoingBatch.setStatus(status);
outgoingBatch.setErrorFlag(!batch.isOk());
} else {
// clearing the error flag in case the user set the batch status to OK
outgoingBatch.setErrorFlag(false);
log.warn("AckNotUpdatingBatchState", batch.getBatchId(), status.name());
}
outgoingBatch.setByteCount(batch.getByteCount());
outgoingBatch.setNetworkMillis(batch.getNetworkMillis());
outgoingBatch.setFilterMillis(batch.getFilterMillis());
outgoingBatch.setLoadMillis(batch.getDatabaseMillis());
if (!batch.isOk() && batch.getErrorLine() != 0) {
CallBackHandler handler = new CallBackHandler(batch
.getErrorLine());
jdbcTemplate.query(getSql("selectDataIdSql"),
new Object[] { outgoingBatch.getBatchId() },
handler);
outgoingBatch.setFailedDataId(handler.getDataId());
outgoingBatch.setSqlCode(batch.getSqlCode());
outgoingBatch.setSqlState(batch.getSqlState());
outgoingBatch.setSqlMessage(batch.getSqlMessage());
}
if (status == Status.ER) {
log.error("AckReceivedError", outgoingBatch.getNodeId(), outgoingBatch.getBatchId());
}
outgoingBatchService.updateOutgoingBatch(outgoingBatch);
} else {
log.error("BatchNotFoundForAck", batch.getBatchId(), status
.name());
}
}
}
class CallBackHandler implements RowCallbackHandler {
int index = 0;
long dataId = -1;
long rowNumber;
CallBackHandler(long rowNumber) {
this.rowNumber = rowNumber;
}
public void processRow(ResultSet rs) throws SQLException {
if (++index == rowNumber) {
dataId = rs.getLong(1);
}
}
public long getDataId() {
return dataId;
}
}
public void setOutgoingBatchService(IOutgoingBatchService outgoingBatchService) {
this.outgoingBatchService = outgoingBatchService;
}
public void setRegistrationService(IRegistrationService registrationService) {
this.registrationService = registrationService;
}
public void addAcknowledgeEventListener(
IAcknowledgeEventListener statusChangeListner) {
if (batchEventListeners == null) {
batchEventListeners = new ArrayList();
}
batchEventListeners.add(statusChangeListner);
}
}