/*
Copyright 2005-2007 Matthew J. Battey
Licensed 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.
This software implements a Java interface to SAFMQ (see http://safmq.sourceforge.net).
Created on Jun 3, 2005
*/
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.net.URI;
import com.safmq.MQBuilder;
import com.safmq.MQException;
import com.safmq.MessageQueue;
import com.safmq.QueueMessage;
import com.safmq.Safmq;
/**
* Note: this example expects a SAFMQ server to be running on the "localhost"
* or same computer as the example is being run. It also expects a user to exist
* with the name "username" and password "password". Additionally there should
* be two queues "query" and "resposne", and the user "username" should have
* read and write access to to this queue.
*
* @author matt
*/
public class RoundTripServer {
static URI queue_name;
static String user_name = "username";
static String password = "password";
static {
try {
queue_name = new URI("safmq://localhost/query");
} catch (Exception e) {
}
}
public static void main(String[] args) {
try {
// Allocate a connection to the query queue, we'll read from this queue
MessageQueue mq = MQBuilder.buildMessageQueue(queue_name,user_name,password);
// Allocate a messaeg so we can read from it.
QueueMessage msg = new QueueMessage();
int error;
// Try and retreive a message from the queue
error = mq.Retreive(true,-1,msg);
// Close the queue we don't need it any more, this release resources on the server
mq.Close();
if (error == Safmq.EC_NOERROR) {
// Output the contents of the emssage
System.out.println("Message Data Follows");
System.out.println("Label: " + msg.getLabel());
InputStream in = msg.getInputStream();
byte data[] = new byte[1024];
int read;
while ( (read=in.read(data)) > 0) {
System.out.write(data,0,read);
}
// allocate a response message
QueueMessage response = new QueueMessage();
// Set the message's body type to give readers a clue to contents
response.setBodyType(Safmq.BT_TEXT);
// Set a name for the message, note this is optional, but some receivers
// may choose an action depending on the name specified here
response.setLabel("Round Trip Response");
// Note the next line is the critical step, it ties the response message
// with the original query message.
response.setReciptID(msg.getMessageID());
// Get the output stream to fill the body.
// In this case wrap it with a PrintWriter so that we can have formated output.
PrintWriter pw = new PrintWriter(new OutputStreamWriter(response.getOutputStream()));
pw.println("This is the response to the round trip client's query");
pw.flush();
// Connect to the response queue
MessageQueue responseQueue = MQBuilder.buildMessageQueue(new URI(msg.getResponseQueueName()),user_name,password);
error = responseQueue.Enqueue(response);
responseQueue.Close();
if (error != Safmq.EC_NOERROR)
System.out.println("Error sending: "+Safmq.errorDecode(error));
} else {
System.out.println("Error retreiving: "+Safmq.errorDecode(error));
}
} catch (MQException mqe) {
mqe.printStackTrace();
} catch (IOException ioe) {
ioe.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
}