1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
// --- BEGIN COPYRIGHT BLOCK ---
// 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; version 2 of the License.
//
// 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.,
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
//
// (C) 2007 Red Hat, Inc.
// All rights reserved.
// --- END COPYRIGHT BLOCK ---
package com.netscape.admin.certsrv.status;
import java.awt.*;
import java.util.*;
import java.text.*;
import java.io.*;
import java.awt.event.*;
import javax.swing.*;
import com.netscape.admin.certsrv.*;
import com.netscape.certsrv.common.*;
import com.netscape.management.client.util.*;
/**
* Parse the log in the following default format:
* pid.thread - [SIMPLEDATEFORMAT][resource][level][message]
*
*
* @author Jack Pan-Chen
* @version $Revision$, $Date$
* @see com.netscape.admin.certsrv.status
*/
class DefaultLogParser implements ILogParser {
/*==========================================================
* variables
*==========================================================*/
private final String SOURCE_PROPERTY = "LOGCONTENT_COMBOBOX_SOURCE_VALUE_";
private final String LEVEL_PROPERTY = "LOGCONTENT_COMBOBOX_LOGLEVEL_VALUE_";
private final String DATE_PATTERN = "dd/MMM/yyyy:hh:mm:ss z";
protected ResourceBundle mResource;
/*==========================================================
* constructors
*==========================================================*/
public DefaultLogParser() {
mResource = ResourceBundle.getBundle(CMSAdminResources.class.getName());
}
/*==========================================================
* public methods
*==========================================================*/
public Vector parse(Object entry) throws ParseException {
String logEntry = (String)entry;
//parsing the log Entry and return segments
//Debug.println("LogDataModel: DefaultLogParser: parse() -" +logEntry);
int x = logEntry.indexOf("[");
if (x == -1)
throw new ParseException(logEntry,0);
String temp = logEntry.substring(x+1);
x = temp.indexOf("]");
if (x == -1)
throw new ParseException(logEntry,0);
String dateStr = temp.substring(0,x);
//Debug.println("LogDataModel: DefaultLogParser: parse() -"+dateStr+" "+temp);
SimpleDateFormat format = new SimpleDateFormat(DATE_PATTERN);
Date date = format.parse(dateStr);
String dateColumn = DateFormat.getDateInstance().format(date);
String timeColumn = DateFormat.getTimeInstance().format(date);
//Debug.println("LogDataModel: DefaultLogParser: parse() -"+dateColumn+" "+timeColumn);
temp = temp.substring(x+2);
x = temp.indexOf("]");
if (x == -1)
throw new ParseException(logEntry,0);
String source = temp.substring(1,x);
temp = temp.substring(x+2);
x = temp.indexOf("]");
if (x == -1)
throw new ParseException(logEntry,0);
String level = temp.substring(1,x);
temp = temp.substring(x+2);
Vector row = new Vector();
row.addElement(getSourceString(source));
row.addElement(getLevelString(level));
row.addElement(dateColumn);
row.addElement(timeColumn);
JLabel detail = new JLabel(temp);
detail.setToolTipText(temp);
row.addElement(detail);
return row;
}
public String getSourceString(String code) {
try {
return mResource.getString(SOURCE_PROPERTY+code);
} catch (MissingResourceException e) {
return code;
}
}
public String getLevelString(String code) {
try {
return mResource.getString(LEVEL_PROPERTY+code);
} catch (MissingResourceException e) {
return code;
}
}
}
|