/*
 * Copyright 2003 Federal Chancellery Austria
 * MOA-ID has been developed in a cooperation between BRZ, the Federal
 * Chancellery Austria - ICT staff unit, and Graz University of Technology.
 *
 * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by
 * the European Commission - subsequent versions of the EUPL (the "Licence");
 * You may not use this work except in compliance with the Licence.
 * You may obtain a copy of the Licence at:
 * http://www.osor.eu/eupl/
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the Licence is distributed on an "AS IS" basis,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the Licence for the specific language governing permissions and
 * limitations under the Licence.
 *
 * This product combines work with different licenses. See the "NOTICE" text
 * file for details on the various modules and licenses.
 * The "NOTICE" text file is part of the distribution. Any derivative works
 * that you distribute must include a readable copy of the "NOTICE" text file.
 */
package at.gv.egovernment.moa.logging;
/**
 * A unified message type to log messages from inside the MOA subsystem.
 * 
 * @author Patrick Peck
 * @version $Id$
 */
public class LogMsg {
  /** The message to log. */
  private Object message;
  /**
   * Create a LogMsg object.
   * 
   * @param message The actual message to log. May be null. 
   */
  public LogMsg(Object message) {
    this.message = message;
  }
  /**
   * Convert this log message to a String.
   * 
   * @return The String representation of this log message. 
   */
  public String toString() {
    StringBuffer msg = new StringBuffer();
    LoggingContext ctx =
      LoggingContextManager.getInstance().getLoggingContext();
    String tid = ctx != null ? ctx.getTransactionID() : null;
    String nodeId = ctx != null ? ctx.getNodeID() : null;
    
    msg.append("TID=");
    msg.append(tid != null ? tid : "");
    msg.append(" NID=");
    msg.append(nodeId != null ? nodeId : "");
    msg.append(" MSG=");
    msg.append(message != null ? message.toString() : "");
    return msg.toString();
  }
}