Package com.sos.VirtualFileSystem.JMS.test

Source Code of com.sos.VirtualFileSystem.JMS.test.FileConsumerTool

/********************************************************* begin of preamble
**
** Copyright (C) 2003-2010 Software- und Organisations-Service GmbH.
** All rights reserved.
**
** This file may be used under the terms of either the
**
**   GNU General Public License version 2.0 (GPL)
**
**   as published by the Free Software Foundation
**   http://www.gnu.org/licenses/gpl-2.0.txt and appearing in the file
**   LICENSE.GPL included in the packaging of this file.
**
** or the
** 
**   Agreement for Purchase and Licensing
**
**   as offered by Software- und Organisations-Service GmbH
**   in the respective terms of supply that ship with this file.
**
** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
** IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
** THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
** PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
** BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
** POSSIBILITY OF SUCH DAMAGE.
********************************************************** end of preamble*/
package com.sos.VirtualFileSystem.JMS.test;
/**
* 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.
*/
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Iterator;

import javax.jms.BytesMessage;
import javax.jms.Connection;
import javax.jms.DeliveryMode;
import javax.jms.Destination;
import javax.jms.ExceptionListener;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageListener;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;
import javax.jms.Topic;

import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
import org.apache.activemq.command.ActiveMQBytesMessage;
import org.apache.activemq.protobuf.compiler.CommandLineSupport;

/**
* A simple tool for consuming messages
*
* @version $Revision: 1.1.1.1 $
*/
public class FileConsumerTool extends Thread implements MessageListener, ExceptionListener {
  private ActiveMQConnection connection;
  private boolean        running;
  private Session        session;
  private Destination      destination;
  private MessageProducer    replyProducer;
  private boolean        pauseBeforeShutdown  = false;
  private boolean        verbose        = true;
  private int          maxiumMessages;
  private static int      parallelThreads    = 1;
  // private String subject = "TOOL.DEFAULT";
  private String        subject        = "SOSDEx.Files";
  private boolean        topic;
  private String        user        = ActiveMQConnection.DEFAULT_USER;
  private String        password      = ActiveMQConnection.DEFAULT_PASSWORD;
  private String        url          = ActiveMQConnection.DEFAULT_BROKER_URL;
  private boolean        transacted;
  private boolean        durable;
  private String        clientId;
  private int          ackMode        = Session.AUTO_ACKNOWLEDGE;
  private String        consumerName    = "James";
  private long        sleepTime;
  private long        receiveTimeOut;
  private FileOutputStream  fos          = null;
  private String strTargetFileNameSave = "";
  public static void main(String[] args) {
    ArrayList<FileConsumerTool> threads = new ArrayList();
    FileConsumerTool consumerTool = new FileConsumerTool();
    String[] unknown = CommandLineSupport.setOptions(consumerTool, args);
    if (unknown.length > 0) {
      System.out.println("Unknown options: " + Arrays.toString(unknown));
      System.exit(-1);
    }
    consumerTool.showParameters();
    for (int threadCount = 1; threadCount <= parallelThreads; threadCount++) {
      consumerTool = new FileConsumerTool();
      CommandLineSupport.setOptions(consumerTool, args);
      consumerTool.start();
      threads.add(consumerTool);
    }
    while (true) {
      Iterator<FileConsumerTool> itr = threads.iterator();
      int running = 0;
      while (itr.hasNext()) {
        FileConsumerTool thread = itr.next();
        if (thread.isAlive()) {
          running++;
        }
      }
      if (running <= 0) {
        System.out.println("All threads completed their work");
        break;
      }
      try {
        Thread.sleep(1000);
      }
      catch (Exception e) {
      }
    }
    Iterator<FileConsumerTool> itr = threads.iterator();
    while (itr.hasNext()) {
      FileConsumerTool thread = itr.next();
    }
  }

  public void showParameters() {
    System.out.println("Connecting to URL: " + url);
    System.out.println("Consuming " + (topic ? "topic" : "queue") + ": " + subject);
    System.out.println("Using a " + (durable ? "durable" : "non-durable") + " subscription");
    System.out.println("Running " + parallelThreads + " parallel threads");
  }

  public void run() {
    try {
      running = true;
      ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory(user, password, url);
      connection = (ActiveMQConnection) connectionFactory.createConnection();
      if (durable && clientId != null && clientId.length() > 0 && !"null".equals(clientId)) {
        connection.setClientID(clientId);
      }
//      connection.setExceptionListener(this);
      connection.start();
      session = connection.createSession(transacted, ackMode);
      if (topic) {
        destination = session.createTopic(subject);
      }
      else {
        destination = session.createQueue(subject);
      }
      replyProducer = session.createProducer(null);
      replyProducer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
      MessageConsumer consumer = null;
      if (durable && topic) {
        consumer = session.createDurableSubscriber((Topic) destination, consumerName);
      }
      else {
        consumer = session.createConsumer(destination);
      }
      maxiumMessages = 100;
      if (maxiumMessages > 0) {
        consumeMessagesAndClose(connection, session, consumer);
      }
      else {
        receiveTimeOut = 1000;
        if (receiveTimeOut == 0) {
          consumer.setMessageListener(this);
        }
        else {
          consumeMessagesAndClose(connection, session, consumer, receiveTimeOut);
        }
      }
    }
    catch (Exception e) {
      System.out.println("[" + this.getName() + "] Caught: " + e);
      e.printStackTrace();
    }
  }

  public void onMessage(Message message) {
    try {
      if (message instanceof TextMessage) {
        TextMessage txtMsg = (TextMessage) message;
        if (verbose) {
          String msg = txtMsg.getText();
          int length = msg.length();
          if (length > 50) {
            msg = msg.substring(0, 50) + "...";
          }
          System.out.println("[" + this.getName() + "] Received: '" + msg + "' (length " + length + ")");
        }
      }
      else
        if (message instanceof BytesMessage) {
          System.out.println("[" + this.getName() + "] BytesMessage Received: '" + message + "'");
          String strTargetFileName = message.getStringProperty("targetFileName");
          System.out.println("TargetFileName = " + strTargetFileName);
         
          try {
            String messageId = ((ActiveMQBytesMessage) message).getGroupID();
           
            if (strTargetFileName.equalsIgnoreCase(strTargetFileNameSave) == false) {
              if (fos != null) {
                fos.close();
                fos = null;
                System.out.println("filename changed " + strTargetFileName + ", " + strTargetFileNameSave);
              }
            }
           
            if (fos == null) {
              File outFile = new File("c:/temp/", strTargetFileName);
              fos = new FileOutputStream(outFile);
              strTargetFileNameSave = strTargetFileName;
              System.out.println("outfile created " + strTargetFileName);
            }
           
            int intBufSize = 32768;
            byte[] buf = new byte[intBufSize]; // 32k buffer
            int c = 0;
            InputStream in = connection.createInputStream(destination);
            System.out.println("inputStream " + in);
            do {
              c = in.read(buf, 0, intBufSize);
              System.out.println("No of bytes read " + c);
              if (c > 0)
                fos.write(buf, 0, c);
            }
            while (c >= 0);
            in.close();
          }
          catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            throw new RuntimeException("Problems with inputStream");
          }
          finally {
          }
        }
        else {
          if (verbose) {
            System.out.println("[" + this.getName() + "] Received: '" + message + "'");
          }
        }
      if (message.getJMSReplyTo() != null) {
        replyProducer.send(message.getJMSReplyTo(), session.createTextMessage("Reply: " + message.getJMSMessageID()));
      }
      if (transacted) {
        session.commit();
      }
      else
        if (ackMode == Session.CLIENT_ACKNOWLEDGE) {
          message.acknowledge();
        }
    }
    catch (JMSException e) {
      System.out.println("[" + this.getName() + "] Caught: " + e);
      e.printStackTrace();
    }
    finally {
      if (sleepTime > 0) {
        try {
          Thread.sleep(sleepTime);
        }
        catch (InterruptedException e) {
        }
      }
    }
  }

  public synchronized void onException(JMSException ex) {
    System.out.println("[" + this.getName() + "] JMS Exception occured.  Shutting down client.");
    running = false;
  }

  synchronized boolean isRunning() {
    return running;
  }

  protected void consumeMessagesAndClose(ActiveMQConnection connection, Session session, MessageConsumer consumer) throws JMSException, IOException {
    System.out.println("[" + this.getName() + "] We are about to wait until we consume: " + maxiumMessages + " message(s) then we will shutdown");
    for (int i = 0; i < maxiumMessages && isRunning();) {
      Message message = consumer.receive(1000);
      if (message != null) {
        i++;
        onMessage(message);
      }
    }
    System.out.println("[" + this.getName() + "] Closing connection");
    if (fos != null) {
      fos.close();
      fos = null;
      strTargetFileNameSave = "";
    }

    consumer.close();
    session.close();
    connection.close();
    if (pauseBeforeShutdown) {
      System.out.println("[" + this.getName() + "] Press return to shut down");
      System.in.read();
    }
  }

  protected void consumeMessagesAndClose(Connection connection, Session session, MessageConsumer consumer, long timeout) throws JMSException, IOException {
    System.out.println("[" + this.getName() + "] We will consume messages while they continue to be delivered within: " + timeout
        + " ms, and then we will shutdown");
    Message message;
    while ((message = consumer.receive(timeout)) != null) {
      onMessage(message);
    }
    System.out.println("[" + this.getName() + "] Closing connection");
    consumer.close();
    session.close();
    connection.close();
    if (pauseBeforeShutdown) {
      System.out.println("[" + this.getName() + "] Press return to shut down");
      System.in.read();
    }
  }

  public void setAckMode(String ackMode) {
    if ("CLIENT_ACKNOWLEDGE".equals(ackMode)) {
      this.ackMode = Session.CLIENT_ACKNOWLEDGE;
    }
    if ("AUTO_ACKNOWLEDGE".equals(ackMode)) {
      this.ackMode = Session.AUTO_ACKNOWLEDGE;
    }
    if ("DUPS_OK_ACKNOWLEDGE".equals(ackMode)) {
      this.ackMode = Session.DUPS_OK_ACKNOWLEDGE;
    }
    if ("SESSION_TRANSACTED".equals(ackMode)) {
      this.ackMode = Session.SESSION_TRANSACTED;
    }
  }

  public void setClientId(String clientID) {
    this.clientId = clientID;
  }

  public void setConsumerName(String consumerName) {
    this.consumerName = consumerName;
  }

  public void setDurable(boolean durable) {
    this.durable = durable;
  }

  public void setMaxiumMessages(int maxiumMessages) {
    this.maxiumMessages = maxiumMessages;
  }

  public void setPauseBeforeShutdown(boolean pauseBeforeShutdown) {
    this.pauseBeforeShutdown = pauseBeforeShutdown;
  }

  public void setPassword(String pwd) {
    this.password = pwd;
  }

  public void setReceiveTimeOut(long receiveTimeOut) {
    this.receiveTimeOut = receiveTimeOut;
  }

  public void setSleepTime(long sleepTime) {
    this.sleepTime = sleepTime;
  }

  public void setSubject(String subject) {
    this.subject = subject;
  }

  public void setParallelThreads(int parallelThreads) {
    if (parallelThreads < 1) {
      parallelThreads = 1;
    }
    this.parallelThreads = parallelThreads;
  }

  public void setTopic(boolean topic) {
    this.topic = topic;
  }

  public void setQueue(boolean queue) {
    this.topic = !queue;
  }

  public void setTransacted(boolean transacted) {
    this.transacted = transacted;
  }

  public void setUrl(String url) {
    this.url = url;
  }

  public void setUser(String user) {
    this.user = user;
  }

  public void setVerbose(boolean verbose) {
    this.verbose = verbose;
  }
}
TOP

Related Classes of com.sos.VirtualFileSystem.JMS.test.FileConsumerTool

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.