001 /** 002 * 003 * Copyright 2003-2004 The Apache Software Foundation 004 * 005 * Licensed under the Apache License, Version 2.0 (the "License"); 006 * you may not use this file except in compliance with the License. 007 * You may obtain a copy of the License at 008 * 009 * http://www.apache.org/licenses/LICENSE-2.0 010 * 011 * Unless required by applicable law or agreed to in writing, software 012 * distributed under the License is distributed on an "AS IS" BASIS, 013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 014 * See the License for the specific language governing permissions and 015 * limitations under the License. 016 */ 017 package org.apache.geronimo.system.logging; 018 019 import java.io.Serializable; 020 021 /** 022 * @version $Rev: 355877 $ $Date: 2005-12-10 18:48:27 -0800 (Sat, 10 Dec 2005) $ 023 */ 024 public interface SystemLog { 025 /** 026 * The most search lines that will ever be returned, no matter what you 027 * ask for. This is to conserve memory and transfer bandwidth. 028 */ 029 public final static int MAX_SEARCH_RESULTS = 1000; 030 /** 031 * Gets the name of the file that configures the log system 032 */ 033 String getConfigFileName(); 034 /** 035 * Sets the name of the file that the log system should configure itself from. 036 */ 037 void setConfigFileName(String fileName); 038 /** 039 * Gets the name of the log level used for the root logger. 040 */ 041 String getRootLoggerLevel(); 042 /** 043 * Sets the name of the log level used for the root logger. Legal values 044 * are defined in GeronimoLogging.java (currently TRACE, DEBUG, INFO, 045 * WARN, ERROR, FATAL) 046 */ 047 void setRootLoggerLevel(String level); 048 /** 049 * Indicates how often the log system should check to see if its 050 * configuration file has been updated. 051 */ 052 int getRefreshPeriodSeconds(); 053 /** 054 * Sets how often the log system should check to see if its 055 * configuration file has been updated. 056 */ 057 void setRefreshPeriodSeconds(int seconds); 058 /** 059 * Gets the name of all log files used by this log system. Typically there 060 * is only one, but specialized cases may use more. 061 */ 062 String[] getLogFileNames(); 063 /** 064 * Searches the log for records matching the specified parameters. The 065 * maximum results returned will be the lesser of 1000 and the 066 * provided maxResults argument. 067 * 068 * @see #MAX_SEARCH_RESULTS 069 */ 070 SearchResults getMatchingItems(String logFile, Integer firstLine, Integer lastLine, String minLevel, 071 String regex, int maxResults, boolean includeStackTraces); 072 073 public static class LogMessage implements Serializable { 074 private final int lineNumber; 075 private final String lineContent; 076 077 public LogMessage(int lineNumber, String lineContent) { 078 this.lineNumber = lineNumber; 079 this.lineContent = lineContent; 080 } 081 082 public int getLineNumber() { 083 return lineNumber; 084 } 085 086 public String getLineContent() { 087 return lineContent; 088 } 089 } 090 091 public static class SearchResults implements Serializable { 092 private final int lineCount; // total lines in file 093 private final LogMessage[] results; 094 private final boolean capped; 095 096 public SearchResults(int lineCount, LogMessage[] results, boolean capped) { 097 this.lineCount = lineCount; 098 this.results = results; 099 this.capped = capped; 100 } 101 102 public int getLineCount() { 103 return lineCount; 104 } 105 106 public LogMessage[] getResults() { 107 return results; 108 } 109 110 public boolean isCapped() { 111 return capped; 112 } 113 } 114 }