1600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang/* 2600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* Conditions Of Use 3600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* 4600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* This software was developed by employees of the National Institute of 5600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* Standards and Technology (NIST), an agency of the Federal Government. 6600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* Pursuant to title 15 Untied States Code Section 105, works of NIST 7600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* employees are not subject to copyright protection in the United States 8600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* and are considered to be in the public domain. As a result, a formal 9600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* license is not needed to use the software. 10600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* 11600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* This software is provided by NIST as a service and is expressly 12600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* provided "AS IS." NIST MAKES NO WARRANTY OF ANY KIND, EXPRESS, IMPLIED 13600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTY OF 14600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, NON-INFRINGEMENT 15600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* AND DATA ACCURACY. NIST does not warrant or make any representations 16600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* regarding the use of the software or the results thereof, including but 17600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* not limited to the correctness, accuracy, reliability or usefulness of 18600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* the software. 19600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* 20600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* Permission to use this software is contingent upon your acceptance 21600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* of the terms of this agreement 22600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* 23600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* . 24600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* 25600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang*/ 26600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang/******************************************************************************* 27600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang* Product of NIST/ITL Advanced Networking Technologies Division (ANTD). * 28600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang*******************************************************************************/ 29600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 30600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wangpackage gov.nist.javax.sip.stack; 31600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 32600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wangimport gov.nist.javax.sip.LogRecord; 33600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 34600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang/** 35600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang * This class stores a message along with some other informations 36600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang * Used to log messages. 37600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang * 38600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang *@version 1.2 $Revision: 1.9 $ $Date: 2009/07/17 18:58:13 $ 39600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang * 40600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang * @author M. Ranganathan <br/> 41600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang * @author Marc Bednarek <br/> 42600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang * 43600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang * 44600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang */ 45600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wangclass MessageLog implements LogRecord { 46600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 47600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang private String message; 48600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 49600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang private String source; 50600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 51600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang private String destination; 52600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 53600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang private long timeStamp; 54600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 55600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang private boolean isSender; 56600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 57600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang private String firstLine; 58600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 59600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang private String tid; 60600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 61600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang private String callId; 62600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 63600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang private long timeStampHeaderValue; 64600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 65600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang /* (non-Javadoc) 66600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang * @see gov.nist.javax.sip.stack.LogRecord#equals(java.lang.Object) 67600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang */ 68600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang public boolean equals(Object other) { 69600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang if (!(other instanceof MessageLog)) { 70600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang return false; 71600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang } else { 72600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang MessageLog otherLog = (MessageLog) other; 73600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang return otherLog.message.equals(message) 74600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang && otherLog.timeStamp == timeStamp; 75600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang } 76600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang } 77600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 78600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang /** 79600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang * Constructor 80600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang */ 81600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 82600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang public MessageLog( 83600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String message, 84600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String source, 85600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String destination, 86600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String timeStamp, 87600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang boolean isSender, 88600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String firstLine, 89600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String tid, 90600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String callId, 91600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang long timeStampHeaderValue) { 92600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang if (message == null || message.equals("")) 93600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang throw new IllegalArgumentException("null msg"); 94600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.message = message; 95600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.source = source; 96600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.destination = destination; 97600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang try { 98600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang long ts = Long.parseLong(timeStamp); 99600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang if (ts < 0) 100600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang throw new IllegalArgumentException("Bad time stamp "); 101600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.timeStamp = ts; 102600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang } catch (NumberFormatException ex) { 103600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang throw new IllegalArgumentException( 104600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang "Bad number format " + timeStamp); 105600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang } 106600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.isSender = isSender; 107600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.firstLine = firstLine; 108600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.tid = tid; 109600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.callId = callId; 110600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.timeStampHeaderValue = timeStampHeaderValue; 111600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang } 112600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 113600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 114600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 115600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang public MessageLog( 116600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String message, 117600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String source, 118600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String destination, 119600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang long timeStamp, 120600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang boolean isSender, 121600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String firstLine, 122600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String tid, 123600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String callId, 124600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang long timestampVal) { 125600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang if (message == null || message.equals("")) 126600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang throw new IllegalArgumentException("null msg"); 127600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.message = message; 128600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.source = source; 129600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.destination = destination; 130600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang if (timeStamp < 0) 131600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang throw new IllegalArgumentException("negative ts"); 132600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.timeStamp = timeStamp; 133600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.isSender = isSender; 134600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.firstLine = firstLine; 135600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.tid = tid; 136600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.callId = callId; 137600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang this.timeStampHeaderValue = timestampVal; 138600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang } 139600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 140600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 141600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang /* (non-Javadoc) 142600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang * @see gov.nist.javax.sip.stack.LogRecord#toString() 143600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang */ 144600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 145600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang public String toString() { 146600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang String log; 147600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 148600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 149600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang log = 150600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang "<message\nfrom=\"" 151600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang + source 152600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang + "\" \nto=\"" 153600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang + destination 154600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang + "\" \ntime=\"" 155600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang + timeStamp 156600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang + "\"" + 157600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang (this.timeStampHeaderValue != 0 ? "\ntimeStamp = \"" + timeStampHeaderValue + "\"": "") 158600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang +"\nisSender=\"" 159600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang + isSender 160600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang + "\" \ntransactionId=\"" 161600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang + tid 162600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang + "\" \ncallId=\"" 163600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang + callId 164600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang + "\" \nfirstLine=\"" 165600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang + firstLine.trim() + "\"" + 166600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang " \n>\n"; 167600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang log += "<![CDATA["; 168600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang log += message; 169600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang log += "]]>\n"; 170600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang log += "</message>\n"; 171600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang 172600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang return log; 173600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang } 174600c7a4bbc7348167293eac928192e695b4ad5baChung-yih Wang} 175