From 08dfca659546aac8184383259fb9bec583a88927 Mon Sep 17 00:00:00 2001 From: Robert Gemmell Date: Fri, 9 Apr 2010 14:16:42 +0000 Subject: QPID-2379: add ability to respond to method requests with non-zero status codes, use to signal unimplemented methods. git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@932430 13f79535-47bb-0310-9956-ffa450edef68 --- .../apache/qpid/qmf/QMFMethodResponseCommand.java | 43 +++++++++++++++++++--- .../main/java/org/apache/qpid/qmf/QMFService.java | 21 +++++------ qpid/java/broker/src/xsl/qmf.xsl | 30 ++++++++++++++- 3 files changed, 76 insertions(+), 18 deletions(-) (limited to 'qpid/java/broker/src') diff --git a/qpid/java/broker/src/main/java/org/apache/qpid/qmf/QMFMethodResponseCommand.java b/qpid/java/broker/src/main/java/org/apache/qpid/qmf/QMFMethodResponseCommand.java index 529b04ebdb..5fea014ad8 100644 --- a/qpid/java/broker/src/main/java/org/apache/qpid/qmf/QMFMethodResponseCommand.java +++ b/qpid/java/broker/src/main/java/org/apache/qpid/qmf/QMFMethodResponseCommand.java @@ -20,24 +20,57 @@ */ package org.apache.qpid.qmf; -import org.apache.qpid.server.virtualhost.VirtualHost; -import org.apache.qpid.server.message.ServerMessage; import org.apache.qpid.transport.codec.BBEncoder; public class QMFMethodResponseCommand extends QMFCommand { - public QMFMethodResponseCommand(final QMFMethodRequestCommand cmd) + private CompletionCode _status = null; + private String _msg = null; + + public QMFMethodResponseCommand(final QMFMethodRequestCommand cmd, + CompletionCode status, + String msg) { super( new QMFCommandHeader(cmd.getHeader().getVersion(), cmd.getHeader().getSeq(), QMFOperation.METHOD_RESPONSE)); + + if(status == null) + { + _status = CompletionCode.OK; + } + else + { + _status = status; + } + + _msg = msg; + } + + public CompletionCode getStatus() + { + return _status; + } + + public String getStatusText() + { + return _msg; } @Override public void encode(final BBEncoder encoder) { super.encode(encoder); - encoder.writeUint32(0); - encoder.writeStr16("OK"); + + encoder.writeUint32(_status.ordinal()); + + if(_msg == null) + { + encoder.writeStr16(_status.toString()); + } + else + { + encoder.writeStr16(_msg); + } } } diff --git a/qpid/java/broker/src/main/java/org/apache/qpid/qmf/QMFService.java b/qpid/java/broker/src/main/java/org/apache/qpid/qmf/QMFService.java index 4491f3f7d5..1a9766c5b2 100644 --- a/qpid/java/broker/src/main/java/org/apache/qpid/qmf/QMFService.java +++ b/qpid/java/broker/src/main/java/org/apache/qpid/qmf/QMFService.java @@ -679,8 +679,8 @@ public class QMFService implements ConfigStore.ConfigEventListener final String destQueue, final Long qty) { - // todo - throw new UnsupportedOperationException(); + // TODO + return factory.createResponseCommand(CompletionCode.NOT_IMPLEMENTED); } public UUID getId() @@ -1056,7 +1056,7 @@ public class QMFService implements ConfigStore.ConfigEventListener final String exchange) { //TODO - return factory.createResponseCommand(); + return factory.createResponseCommand(CompletionCode.NOT_IMPLEMENTED); } @@ -1319,20 +1319,20 @@ public class QMFService implements ConfigStore.ConfigEventListener public BrokerSchema.SessionClass.SolicitAckMethodResponseCommand solicitAck(final BrokerSchema.SessionClass.SolicitAckMethodResponseCommandFactory factory) { - //todo - throw new UnsupportedOperationException(); + //TODO + return factory.createResponseCommand(CompletionCode.NOT_IMPLEMENTED); } public BrokerSchema.SessionClass.DetachMethodResponseCommand detach(final BrokerSchema.SessionClass.DetachMethodResponseCommandFactory factory) { - //todo - throw new UnsupportedOperationException(); + //TODO + return factory.createResponseCommand(CompletionCode.NOT_IMPLEMENTED); } public BrokerSchema.SessionClass.ResetLifespanMethodResponseCommand resetLifespan(final BrokerSchema.SessionClass.ResetLifespanMethodResponseCommandFactory factory) { - //todo - throw new UnsupportedOperationException(); + //TODO + return factory.createResponseCommand(CompletionCode.NOT_IMPLEMENTED); } public BrokerSchema.SessionClass.CloseMethodResponseCommand close(final BrokerSchema.SessionClass.CloseMethodResponseCommandFactory factory) @@ -1343,8 +1343,7 @@ public class QMFService implements ConfigStore.ConfigEventListener } catch (AMQException e) { - // TODO Auto-generated catch block - e.printStackTrace(); + return factory.createResponseCommand(CompletionCode.EXCEPTION, e.getMessage()); } return factory.createResponseCommand(); diff --git a/qpid/java/broker/src/xsl/qmf.xsl b/qpid/java/broker/src/xsl/qmf.xsl index b7690d233a..3a7e10dac8 100644 --- a/qpid/java/broker/src/xsl/qmf.xsl +++ b/qpid/java/broker/src/xsl/qmf.xsl @@ -540,6 +540,16 @@ public class extends QMFPackage _requestCmd = cmd; } + public ResponseCommand createResponseCommand(CompletionCode status) + { + return new ResponseCommand(_requestCmd, status, null); + } + + public ResponseCommand createResponseCommand(CompletionCode status, String msg) + { + return new ResponseCommand(_requestCmd, status, msg); + } + public ResponseCommand createResponseCommand( yesO ) { return new ResponseCommand(_requestCmd, O); @@ -551,17 +561,29 @@ public class extends QMFPackage private ResponseCommand(QMFMethodRequestCommand cmd, yesO) { - super(cmd); + super(cmd, CompletionCode.OK, "OK"); } + private ResponseCommand(QMFMethodRequestCommand cmd, CompletionCode status, String msg) + { + super(cmd, status, msg); + + + } + @Override public void encode(final BBEncoder encoder) { super.encode(encoder); - + + if(getStatus().equals(CompletionCode.OK)) + { + + } + } } @@ -600,6 +622,10 @@ public class extends QMFPackage _ = ; + + _ = null; + + _Class, _EventClass, -- cgit v1.2.1