use of com.swiftmq.amqp.v100.types.AMQPString in project swiftmq-ce by iitsoftware.
the class TransactionRegistry method addToTransaction.
private void addToTransaction(String txnId, long deliveryId, DeliveryStateIF deliveryStateIF) throws EndWithErrorException {
if (ctx.traceSpace.enabled)
ctx.traceSpace.trace(ctx.amqpSwiftlet.getName(), toString() + "/addToTransaction, txnId=" + txnId + ", deliveryId=" + deliveryId + ", deliveryStateIF=" + deliveryStateIF);
lock.lock();
try {
ActiveTxEntry activeTxEntry = (ActiveTxEntry) activeTx.get(txnId);
if (activeTxEntry == null) {
if (ctx.traceSpace.enabled)
ctx.traceSpace.trace(ctx.amqpSwiftlet.getName(), toString() + "/addToTransaction, txnId=" + txnId + ", not found!");
throw new SessionEndException(TransactionError.UNKNOWN_ID, new AMQPString("Transaction id not found: " + txnId));
}
if (activeTxEntry.outboundTxEntryMap == null)
activeTxEntry.outboundTxEntryMap = new HashMap();
OutboundTxEntry outboundTxEntry = (OutboundTxEntry) activeTxEntry.outboundTxEntryMap.get(deliveryId);
if (outboundTxEntry == null) {
outboundTxEntry = new OutboundTxEntry(null, null, deliveryStateIF);
activeTxEntry.outboundTxEntryMap.put(deliveryId, outboundTxEntry);
} else
outboundTxEntry.deliveryStateIF = deliveryStateIF;
} finally {
lock.unlock();
}
}
use of com.swiftmq.amqp.v100.types.AMQPString in project swiftmq-ce by iitsoftware.
the class ReceiverNonTransactedDurable method main.
public static void main(String[] args) {
if (args.length == 1 && args[0].equals("?")) {
System.out.println();
System.out.println("Usage: <host> <port> <source> <nmsgs> <qos> <containerid> <durablelinkname> <keep> <authanon> [<username> <password>]");
System.out.println(" <qos> ::= AT_LEAST_ONCE | AT_MOST_ONCE | EXACTLY_ONCE");
System.out.println(" Suppress <username> <password> and set <authanon> to false to avoid SASL.");
System.out.println();
System.exit(0);
}
String host = "localhost";
int port = 5672;
String source = "testtopic";
int nMsgs = 100;
String qosS = "EXACTLY_ONCE";
String cid = "testcid";
String durableName = "testdurable";
boolean keepDurable = false;
boolean authAnon = true;
String user = null;
String password = null;
if (args.length >= 1)
host = args[0];
if (args.length >= 2)
port = Integer.parseInt(args[1]);
if (args.length >= 3)
source = args[2];
if (args.length >= 4)
nMsgs = Integer.parseInt(args[3]);
if (args.length >= 5)
qosS = args[4];
if (args.length >= 6)
cid = args[5];
if (args.length >= 7)
durableName = args[6];
if (args.length >= 8)
keepDurable = Boolean.parseBoolean(args[7]);
if (args.length >= 9)
authAnon = Boolean.parseBoolean(args[8]);
if (args.length >= 10)
user = args[9];
if (args.length >= 11)
password = args[10];
System.out.println();
System.out.println("Host : " + host);
System.out.println("Port : " + port);
System.out.println("Source : " + source);
System.out.println("Number Msgs : " + nMsgs);
System.out.println("QoS : " + qosS);
System.out.println("Container Id: " + cid);
System.out.println("Durable Name: " + durableName);
System.out.println("Keep Durable: " + keepDurable);
System.out.println("Auth as Anon: " + authAnon);
System.out.println("User : " + user);
System.out.println("Password : " + password);
System.out.println();
try {
// Create connection and connect
AMQPContext ctx = new AMQPContext(AMQPContext.CLIENT);
Connection connection = null;
if (args.length < 10)
connection = new Connection(ctx, host, port, authAnon);
else
connection = new Connection(ctx, host, port, user, password);
connection.setContainerId(cid);
if (port == 5671) {
System.out.println("Using SSL on port 5671");
connection.setSocketFactory(new JSSESocketFactory());
}
connection.connect();
// Create session and consumer
Session session = connection.createSession(50, 50);
DurableConsumer c = session.createDurableConsumer(durableName, source, 100, toIntQoS(qosS), false, null);
// Receive messages non-transacted
for (int i = 0; i < nMsgs; i++) {
AMQPMessage msg = c.receive();
if (msg == null)
break;
AmqpValue value = msg.getAmqpValue();
System.out.println("Received: " + ((AMQPString) value.getValue()).getValue());
if (!msg.isSettled())
msg.accept();
}
// Close everything down
Thread.sleep(2000);
c.close();
if (!keepDurable)
c.unsubscribe();
session.close();
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
use of com.swiftmq.amqp.v100.types.AMQPString in project swiftmq-client by iitsoftware.
the class OpenFrame method decode.
private void decode() throws Exception {
List l = body.getValue();
AMQPType t = null;
int idx = 0;
// Factory : ./.
if (idx >= l.size())
return;
t = (AMQPType) l.get(idx++);
if (t.getCode() == AMQPTypeDecoder.NULL)
throw new Exception("Mandatory field 'containerId' in 'Open' frame is NULL");
try {
containerId = (AMQPString) t;
} catch (ClassCastException e) {
throw new Exception("Invalid type of field 'containerId' in 'Open' frame: " + e);
}
// Factory : ./.
if (idx >= l.size())
return;
t = (AMQPType) l.get(idx++);
try {
if (t.getCode() != AMQPTypeDecoder.NULL)
hostname = (AMQPString) t;
} catch (ClassCastException e) {
throw new Exception("Invalid type of field 'hostname' in 'Open' frame: " + e);
}
// Factory : ./.
if (idx >= l.size())
return;
t = (AMQPType) l.get(idx++);
try {
if (t.getCode() != AMQPTypeDecoder.NULL)
maxFrameSize = (AMQPUnsignedInt) t;
} catch (ClassCastException e) {
throw new Exception("Invalid type of field 'maxFrameSize' in 'Open' frame: " + e);
}
// Factory : ./.
if (idx >= l.size())
return;
t = (AMQPType) l.get(idx++);
try {
if (t.getCode() != AMQPTypeDecoder.NULL)
channelMax = (AMQPUnsignedShort) t;
} catch (ClassCastException e) {
throw new Exception("Invalid type of field 'channelMax' in 'Open' frame: " + e);
}
// Factory : ./.
if (idx >= l.size())
return;
t = (AMQPType) l.get(idx++);
try {
if (t.getCode() != AMQPTypeDecoder.NULL)
idleTimeOut = new Milliseconds(((AMQPUnsignedInt) t).getValue());
} catch (ClassCastException e) {
throw new Exception("Invalid type of field 'idleTimeOut' in 'Open' frame: " + e);
}
// Factory : ./.
if (idx >= l.size())
return;
t = (AMQPType) l.get(idx++);
try {
if (t.getCode() != AMQPTypeDecoder.NULL)
outgoingLocales = AMQPTypeDecoder.isArray(t.getCode()) ? (AMQPArray) t : singleToArray(t);
} catch (ClassCastException e) {
throw new Exception("Invalid type of field 'outgoingLocales' in 'Open' frame: " + e);
}
// Factory : ./.
if (idx >= l.size())
return;
t = (AMQPType) l.get(idx++);
try {
if (t.getCode() != AMQPTypeDecoder.NULL)
incomingLocales = AMQPTypeDecoder.isArray(t.getCode()) ? (AMQPArray) t : singleToArray(t);
} catch (ClassCastException e) {
throw new Exception("Invalid type of field 'incomingLocales' in 'Open' frame: " + e);
}
// Factory : ./.
if (idx >= l.size())
return;
t = (AMQPType) l.get(idx++);
try {
if (t.getCode() != AMQPTypeDecoder.NULL)
offeredCapabilities = AMQPTypeDecoder.isArray(t.getCode()) ? (AMQPArray) t : singleToArray(t);
} catch (ClassCastException e) {
throw new Exception("Invalid type of field 'offeredCapabilities' in 'Open' frame: " + e);
}
// Factory : ./.
if (idx >= l.size())
return;
t = (AMQPType) l.get(idx++);
try {
if (t.getCode() != AMQPTypeDecoder.NULL)
desiredCapabilities = AMQPTypeDecoder.isArray(t.getCode()) ? (AMQPArray) t : singleToArray(t);
} catch (ClassCastException e) {
throw new Exception("Invalid type of field 'desiredCapabilities' in 'Open' frame: " + e);
}
// Factory : ./.
if (idx >= l.size())
return;
t = (AMQPType) l.get(idx++);
try {
if (t.getCode() != AMQPTypeDecoder.NULL)
properties = new Fields(((AMQPMap) t).getValue());
} catch (ClassCastException e) {
throw new Exception("Invalid type of field 'properties' in 'Open' frame: " + e);
}
}
use of com.swiftmq.amqp.v100.types.AMQPString in project swiftmq-client by iitsoftware.
the class AMQPRepo method remove.
AMQPRepo remove(String appname) throws Exception {
AMQPMessage request = new AMQPMessage();
Map propMap = new HashMap();
propMap.put(new AMQPString("app"), new AMQPString(appname));
propMap.put(new AMQPString("operation"), new AMQPString("remove"));
request.setApplicationProperties(new ApplicationProperties(propMap));
Properties properties = new Properties();
properties.setReplyTo(replyQueue);
request.setProperties(properties);
producer.send(request);
AMQPMessage reply = consumer.receive(TIMEOUT);
if (reply == null)
throw new Exception("Timeout occurred while waiting for a reply!");
AMQPMap body = (AMQPMap) reply.getAmqpValue().getValue();
boolean success = ((AMQPBoolean) (body.getValue().get(new AMQPString("success")))).getValue();
if (success)
System.out.println("Removed repository " + appname);
else {
String result = ((AMQPString) (body.getValue().get(new AMQPString("result")))).getValue();
System.out.println(result);
}
return this;
}
use of com.swiftmq.amqp.v100.types.AMQPString in project swiftmq-ce by iitsoftware.
the class ReceiveTester method test.
public void test() {
try {
Connection connection = Util.createConnection();
Session session = Util.createSession(connection);
Producer producer = session.createProducer(address, qos);
for (int i = 0; i < nMsgs; i++) {
AMQPMessage msg = messageFactory.create(i);
Map map = new HashMap();
map.put(new AMQPString(PROPNAME), new AMQPInt(i));
msg.setApplicationProperties(new ApplicationProperties(map));
producer.send(msg, persistent, 5, -1);
}
Consumer consumer = session.createConsumer(address, 500, qos, true, null);
for (int i = 0; i < nMsgs; i++) {
AMQPMessage msg = consumer.receive(1000);
if (msg != null) {
messageFactory.verify(msg);
if (!msg.isSettled())
msg.accept();
receiveVerifier.add(msg);
} else
throw new Exception("message is null");
}
connection.close();
DeliveryMemory deliveryMemory = consumer.getDeliveryMemory();
System.out.println("Unsettled: " + deliveryMemory.getNumberUnsettled());
connection = Util.createConnection();
session = Util.createSession(connection);
Consumer consumerRecover = session.createConsumer(address, 500, qos, true, null, deliveryMemory);
consumerRecover.close();
session.close();
connection.close();
connection = Util.createConnection();
session = Util.createSession(connection);
consumer = session.createConsumer(address, 500, qos, true, null);
for (; ; ) {
AMQPMessage msg = consumer.receive(1000);
if (msg != null) {
messageFactory.verify(msg);
if (!msg.isSettled())
msg.accept();
receiveVerifier.add(msg);
} else
break;
}
consumer.close();
session.close();
connection.close();
receiveVerifier.verify();
} catch (Exception e) {
e.printStackTrace();
fail("test failed: " + e);
}
}
Aggregations