001: /*
002: * File : $Source: /usr/local/cvs/opencms/src/org/opencms/monitor/CmsMemoryMonitorConfiguration.java,v $
003: * Date : $Date: 2008-02-27 12:05:49 $
004: * Version: $Revision: 1.9 $
005: *
006: * This library is part of OpenCms -
007: * the Open Source Content Management System
008: *
009: * Copyright (c) 2002 - 2008 Alkacon Software GmbH (http://www.alkacon.com)
010: *
011: * This library is free software; you can redistribute it and/or
012: * modify it under the terms of the GNU Lesser General Public
013: * License as published by the Free Software Foundation; either
014: * version 2.1 of the License, or (at your option) any later version.
015: *
016: * This library is distributed in the hope that it will be useful,
017: * but WITHOUT ANY WARRANTY; without even the implied warranty of
018: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
019: * Lesser General Public License for more details.
020: *
021: * For further information about Alkacon Software GmbH, please see the
022: * company website: http://www.alkacon.com
023: *
024: * For further information about OpenCms, please see the
025: * project website: http://www.opencms.org
026: *
027: * You should have received a copy of the GNU Lesser General Public
028: * License along with this library; if not, write to the Free Software
029: * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
030: */
031:
032: package org.opencms.monitor;
033:
034: import java.util.ArrayList;
035: import java.util.Collections;
036: import java.util.List;
037:
038: /**
039: * Memory Monitor configuration class.<p>
040: *
041: * @author Armen Markarian
042: *
043: * @version $Revision: 1.9 $
044: *
045: * @since 6.0.0
046: */
047: public class CmsMemoryMonitorConfiguration {
048:
049: /** The memory monitor class name. */
050: private String m_className;
051:
052: /** The interval to use for sending emails. */
053: private int m_emailInterval;
054:
055: /** Receivers for status emails. */
056: private List m_emailReceiver;
057:
058: /** Sender for status emails. */
059: private String m_emailSender;
060:
061: /** The interval to use for the logging. */
062: private int m_logInterval;
063:
064: /** Memory limit that triggers a warning. */
065: private int m_maxUsagePercent;
066:
067: /** The interval to use for warnings if status is disabled. */
068: private int m_warningInterval;
069:
070: /**
071: * Constructor with default values.<p>
072: */
073: public CmsMemoryMonitorConfiguration() {
074:
075: m_emailReceiver = new ArrayList();
076: }
077:
078: /**
079: * Sets the emailReceiver.<p>
080: *
081: * @param emailReceiver the emailReceiver to set
082: */
083: public void addEmailReceiver(String emailReceiver) {
084:
085: m_emailReceiver.add(emailReceiver);
086: }
087:
088: /**
089: * Returns the name of the memory monitor class.<p>
090: *
091: * @return the name of the memory monitor class
092: */
093: public String getClassName() {
094:
095: return m_className;
096: }
097:
098: /**
099: * Returns the intervalEmail.<p>
100: *
101: * @return the intervalEmail
102: */
103: public int getEmailInterval() {
104:
105: return m_emailInterval;
106: }
107:
108: /**
109: * Returns a List of receiver.<p>
110: *
111: * @return a List of receiver
112: */
113: public List getEmailReceiver() {
114:
115: Collections.sort(m_emailReceiver);
116: return m_emailReceiver;
117: }
118:
119: /**
120: * Returns the emailSender.<p>
121: *
122: * @return the emailSender
123: */
124: public String getEmailSender() {
125:
126: return m_emailSender;
127: }
128:
129: /**
130: * Returns the intervalLog.<p>
131: *
132: * @return the intervalLog
133: */
134: public int getLogInterval() {
135:
136: return m_logInterval;
137: }
138:
139: /**
140: * Returns the maxUsagePercent.<p>
141: *
142: * @return the maxUsagePercent
143: */
144: public int getMaxUsagePercent() {
145:
146: return m_maxUsagePercent;
147: }
148:
149: /**
150: * Returns the intervalWarning.<p>
151: *
152: * @return the intervalWarning
153: */
154: public int getWarningInterval() {
155:
156: return m_warningInterval;
157: }
158:
159: /**
160: * Initializes the configuration with the required parameters.<p>
161: *
162: * @param className the name of the memory monitor class
163: * @param maxUsagePercent the max usage percent value
164: * @param logInterval the interval to log
165: * @param emailInterval the interval to send email
166: * @param warningInterval the interval to warn
167: */
168: public void initialize(String className, String maxUsagePercent,
169: String logInterval, String emailInterval,
170: String warningInterval) {
171:
172: m_className = className;
173: m_maxUsagePercent = Integer.parseInt(maxUsagePercent);
174: m_logInterval = Integer.parseInt(logInterval);
175: m_emailInterval = Integer.parseInt(emailInterval);
176: m_warningInterval = Integer.parseInt(warningInterval);
177: }
178:
179: /**
180: * Sets the emailSender.<p>
181: *
182: * @param emailSender the emailSender to set
183: */
184: public void setEmailSender(String emailSender) {
185:
186: m_emailSender = emailSender;
187: }
188: }
|