diff options
| author | Rajith Muditha Attapattu <rajith@apache.org> | 2007-04-18 21:48:48 +0000 |
|---|---|---|
| committer | Rajith Muditha Attapattu <rajith@apache.org> | 2007-04-18 21:48:48 +0000 |
| commit | 6bad3035d6b23cc239b88bd71410cb627055b794 (patch) | |
| tree | 16f43ee30c10637492d7f47001d92e8a437220c4 /java | |
| parent | afda7906499d1ab997fe9b2d3cddd66d0328a055 (diff) | |
| download | qpid-python-6bad3035d6b23cc239b88bd71410cb627055b794.tar.gz | |
initial commit for distribution transaction support
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/branches/client_restructure@530171 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'java')
4 files changed, 152 insertions, 2 deletions
diff --git a/java/newclient/src/main/java/org/apache/qpid/nclient/amqp/AMQPDtxCoordination.java b/java/newclient/src/main/java/org/apache/qpid/nclient/amqp/AMQPDtxCoordination.java new file mode 100644 index 0000000000..7cef9f1edd --- /dev/null +++ b/java/newclient/src/main/java/org/apache/qpid/nclient/amqp/AMQPDtxCoordination.java @@ -0,0 +1,52 @@ +/* + * + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * 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.apache.qpid.nclient.amqp; + +import org.apache.qpid.framing.DtxCoordinationCommitBody; +import org.apache.qpid.framing.DtxCoordinationCommitOkBody; +import org.apache.qpid.framing.DtxCoordinationForgetBody; +import org.apache.qpid.framing.DtxCoordinationForgetOkBody; +import org.apache.qpid.framing.DtxCoordinationGetTimeoutBody; +import org.apache.qpid.framing.DtxCoordinationGetTimeoutOkBody; +import org.apache.qpid.framing.DtxCoordinationPrepareBody; +import org.apache.qpid.framing.DtxCoordinationPrepareOkBody; +import org.apache.qpid.framing.DtxCoordinationRecoverBody; +import org.apache.qpid.framing.DtxCoordinationRecoverOkBody; +import org.apache.qpid.framing.DtxCoordinationRollbackBody; +import org.apache.qpid.framing.DtxCoordinationRollbackOkBody; +import org.apache.qpid.nclient.core.AMQPException; + +public interface AMQPDtxCoordination +{ + public DtxCoordinationCommitOkBody commit(DtxCoordinationCommitBody dtxCoordinationCommitBody) throws AMQPException; + + public DtxCoordinationForgetOkBody forget(DtxCoordinationForgetBody dtxCoordinationForgetBody) throws AMQPException; + + public DtxCoordinationGetTimeoutOkBody getTimeOut(DtxCoordinationGetTimeoutBody dtxCoordinationGetTimeoutBody) throws AMQPException; + + public DtxCoordinationPrepareOkBody prepare(DtxCoordinationPrepareBody dtxCoordinationPrepareBody) throws AMQPException; + + public DtxCoordinationRecoverOkBody recover(DtxCoordinationRecoverBody dtxCoordinationRecoverBody) throws AMQPException; + + public DtxCoordinationRollbackOkBody getTimeOut(DtxCoordinationRollbackBody dtxCoordinationRollbackBody) throws AMQPException; + + //public DtxCoordinationSetTimeoutOkBody getTimeOut(DtxCoordinationSetTimeoutBody dtxCoordinationSetTimeoutBody) throws AMQPException; +} diff --git a/java/newclient/src/main/java/org/apache/qpid/nclient/amqp/AMQPDtxDemarcation.java b/java/newclient/src/main/java/org/apache/qpid/nclient/amqp/AMQPDtxDemarcation.java new file mode 100644 index 0000000000..41f1414205 --- /dev/null +++ b/java/newclient/src/main/java/org/apache/qpid/nclient/amqp/AMQPDtxDemarcation.java @@ -0,0 +1,38 @@ +/* + * + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * 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.apache.qpid.nclient.amqp; + +import org.apache.qpid.framing.DtxDemarcationEndBody; +import org.apache.qpid.framing.DtxDemarcationEndOkBody; +import org.apache.qpid.framing.DtxDemarcationSelectBody; +import org.apache.qpid.framing.DtxDemarcationSelectOkBody; +import org.apache.qpid.framing.DtxDemarcationStartBody; +import org.apache.qpid.framing.DtxDemarcationStartOkBody; +import org.apache.qpid.nclient.core.AMQPException; + +public interface AMQPDtxDemarcation +{ + public DtxDemarcationSelectOkBody select(DtxDemarcationSelectBody dtxDemarcationSelectBody) throws AMQPException; + + public DtxDemarcationStartOkBody start(DtxDemarcationStartBody dtxDemarcationStartBody) throws AMQPException; + + public DtxDemarcationEndOkBody end(DtxDemarcationEndBody dtxDemarcationEndBody) throws AMQPException; +} diff --git a/java/newclient/src/main/java/org/apache/qpid/nclient/amqp/qpid/QpidAMQPChannel.java b/java/newclient/src/main/java/org/apache/qpid/nclient/amqp/qpid/QpidAMQPChannel.java index b73aa8e6fa..928780353d 100644 --- a/java/newclient/src/main/java/org/apache/qpid/nclient/amqp/qpid/QpidAMQPChannel.java +++ b/java/newclient/src/main/java/org/apache/qpid/nclient/amqp/qpid/QpidAMQPChannel.java @@ -21,7 +21,6 @@ package org.apache.qpid.nclient.amqp.qpid; -import java.util.concurrent.TimeUnit; import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; @@ -36,7 +35,6 @@ import org.apache.qpid.framing.ChannelOkBody; import org.apache.qpid.framing.ChannelOpenBody; import org.apache.qpid.framing.ChannelOpenOkBody; import org.apache.qpid.framing.ChannelResumeBody; -import org.apache.qpid.framing.ConnectionCloseBody; import org.apache.qpid.nclient.amqp.AMQPChannel; import org.apache.qpid.nclient.amqp.event.AMQPMethodEvent; import org.apache.qpid.nclient.amqp.event.AMQPMethodListener; diff --git a/java/newclient/src/main/java/org/apache/qpid/nclient/amqp/qpid/QpidAMQPDtxDemarcation.java b/java/newclient/src/main/java/org/apache/qpid/nclient/amqp/qpid/QpidAMQPDtxDemarcation.java new file mode 100644 index 0000000000..a418de7ff6 --- /dev/null +++ b/java/newclient/src/main/java/org/apache/qpid/nclient/amqp/qpid/QpidAMQPDtxDemarcation.java @@ -0,0 +1,62 @@ +package org.apache.qpid.nclient.amqp.qpid; + +import java.util.concurrent.locks.Lock; +import java.util.concurrent.locks.ReentrantLock; + +import org.apache.log4j.Logger; +import org.apache.qpid.framing.DtxDemarcationEndBody; +import org.apache.qpid.framing.DtxDemarcationEndOkBody; +import org.apache.qpid.framing.DtxDemarcationSelectBody; +import org.apache.qpid.framing.DtxDemarcationSelectOkBody; +import org.apache.qpid.framing.DtxDemarcationStartBody; +import org.apache.qpid.framing.DtxDemarcationStartOkBody; +import org.apache.qpid.nclient.amqp.AMQPDtxDemarcation; +import org.apache.qpid.nclient.amqp.state.AMQPState; +import org.apache.qpid.nclient.amqp.state.AMQPStateManager; +import org.apache.qpid.nclient.core.AMQPException; +import org.apache.qpid.nclient.core.Phase; + +public class QpidAMQPDtxDemarcation implements AMQPDtxDemarcation +{ + private static final Logger _logger = Logger.getLogger(QpidAMQPDtxDemarcation.class); + + // the channelId assigned for this channel + private int _channelId; + + private Phase _phase; + + private AMQPState _currentState; + + private AMQPStateManager _stateManager; + + private final AMQPState[] _validCloseStates = new AMQPState[] + { AMQPState.CHANNEL_OPENED, AMQPState.CHANNEL_SUSPEND }; + + private final AMQPState[] _validResumeStates = new AMQPState[] + { AMQPState.CHANNEL_CLOSED, AMQPState.CHANNEL_NOT_OPENED }; + + // The wait period until a server sends a respond + private long _serverTimeOut = 1000; + + private final Lock _lock = new ReentrantLock(); + + + public DtxDemarcationEndOkBody end(DtxDemarcationEndBody dtxDemarcationEndBody) throws AMQPException + { + // TODO Auto-generated method stub + return null; + } + + public DtxDemarcationSelectOkBody select(DtxDemarcationSelectBody dtxDemarcationSelectBody) throws AMQPException + { + // TODO Auto-generated method stub + return null; + } + + public DtxDemarcationStartOkBody start(DtxDemarcationStartBody dtxDemarcationStartBody) throws AMQPException + { + // TODO Auto-generated method stub + return null; + } + +} |
