Package org.goobi.mq

Source Code of org.goobi.mq.WebServiceResult

/**
* This file is part of the Goobi Application - a Workflow tool for the support of mass digitization.
*
* Visit the websites for more information.
*         - http://www.goobi.org
*         - http://launchpad.net/goobi-production
*         - http://gdz.sub.uni-goettingen.de
*       - http://www.intranda.com
*       - http://digiverso.com
*
* This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free
* Software Foundation; either version 2 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59
* Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Linking this library statically or dynamically with other modules is making a combined work based on this library. Thus, the terms and conditions
* of the GNU General Public License cover the whole combination. As a special exception, the copyright holders of this library give you permission to
* link this library with independent modules to produce an executable, regardless of the license terms of these independent modules, and to copy and
* distribute the resulting executable under terms of your choice, provided that you also meet, for each linked independent module, the terms and
* conditions of the license of that module. An independent module is a module which is not derived from or based on this library. If you modify this
* library, you may extend this exception to your version of the library, but you are not obliged to do so. If you do not wish to do so, delete this
* exception statement from your version.
*/

package org.goobi.mq;

import javax.jms.MapMessage;

import org.apache.log4j.Level;
import org.apache.log4j.Logger;
import org.joda.time.DateTime;
import org.joda.time.format.DateTimeFormatter;
import org.joda.time.format.ISODateTimeFormat;

import de.sub.goobi.helper.enums.ReportLevel;

public class WebServiceResult {
  private static final Logger logger = Logger.getLogger(ActiveMQDirector.class);
 
  private String queueName;
  private String id;
  private ReportLevel level;
  private String message = null;
 
  public WebServiceResult(String queueName, String id, ReportLevel level,
      String message){
    this.queueName = queueName;
    this.id = id;
    this.level = level;
    this.message = message;
  }
 
  public WebServiceResult(String queueName, String id, ReportLevel level){
    this.queueName = queueName;
    this.id = id;
    this.level = level;
  }
 
  public void send() {
    if (ActiveMQDirector.getResultsTopic() == null) {

      // If reporting to ActiveMQ is disabled, write log message
      logger.log(level == ReportLevel.SUCCESS ? Level.INFO : Level.WARN,
          "Processing message \"" + id + '@' + queueName
              + "\" reports " + level.toLowerCase() + "."
              + (message != null ? " (" + message + ")" : ""));
    } else {
      try {
        MapMessage report = ActiveMQDirector.getSession().createMapMessage();

        DateTime now = new DateTime();
        DateTimeFormatter iso8601formatter = ISODateTimeFormat.dateTime();
        report.setString("timestamp", iso8601formatter.print(now));
        report.setString("queue", queueName);
        report.setString("id", id);
        report.setString("level", level.toLowerCase());
        if (message != null)
          report.setString("message", message);

        ActiveMQDirector.getResultsTopic().send(report);

      } catch (Exception exce) {
        logger.fatal("Error sending report  for \"" + id + '@'
            + queueName + "\" (" + level.toLowerCase()
            + (message != null ? ": " + message : "")
            + "): Giving up.", exce);
      }
    }
  }
}
TOP

Related Classes of org.goobi.mq.WebServiceResult

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.