From a4682ceae6774956461edd03b2485bbacea445f4 Mon Sep 17 00:00:00 2001 From: mharmsen Date: Tue, 4 Oct 2011 01:17:41 +0000 Subject: Bugzilla Bug #688225 - (dogtagIPAv2.1) TRACKER: of the Dogtag fixes for freeIPA 2.1 git-svn-id: svn+ssh://svn.fedorahosted.org/svn/pki/tags/IPA_v2_RHEL_6_2_20111003@2252 c9f7a03b-bd48-0410-a16d-cbbf54688b0b --- .../admin/certsrv/config/CMSErrorLogPanel.java | 183 +++++++++++++++++++++ 1 file changed, 183 insertions(+) create mode 100644 pki/base/console/src/com/netscape/admin/certsrv/config/CMSErrorLogPanel.java (limited to 'pki/base/console/src/com/netscape/admin/certsrv/config/CMSErrorLogPanel.java') diff --git a/pki/base/console/src/com/netscape/admin/certsrv/config/CMSErrorLogPanel.java b/pki/base/console/src/com/netscape/admin/certsrv/config/CMSErrorLogPanel.java new file mode 100644 index 000000000..484be33dd --- /dev/null +++ b/pki/base/console/src/com/netscape/admin/certsrv/config/CMSErrorLogPanel.java @@ -0,0 +1,183 @@ +// --- 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.config; + +import com.netscape.admin.certsrv.*; +import com.netscape.admin.certsrv.connection.*; +import com.netscape.certsrv.common.*; +import com.netscape.management.client.util.*; +import java.awt.*; +import java.awt.event.*; +import java.util.*; +import javax.swing.*; + +/** + * Error Log Setting Tab to be displayed at the right hand side + * + * @author Christine Ho + * @version $Revision$, $Date$ + */ +public class CMSErrorLogPanel extends CMSBaseLogPanel { + + /*========================================================== + * variables + *==========================================================*/ + private static String PANEL_NAME = "ERRORLOG"; + private CMSTabPanel mParent; + private static final String HELPINDEX = "configuration-logs-error-help"; + + /*========================================================== + * constructors + *==========================================================*/ + public CMSErrorLogPanel(CMSTabPanel parent, boolean isNT) { + super(PANEL_NAME, parent); + mParent = parent; + mHelpToken = HELPINDEX; + mIsNT = isNT; + } + + /*========================================================== + * public methods + *==========================================================*/ + + /** + * Actual Instantiation of the UI components + */ + public void init() { + Debug.println("ErrorLogPanel: init()"); + super.init(); + refresh(); + } + + public void refresh() { + mModel.progressStart(); + NameValuePairs nvp = new NameValuePairs(); + nvp.add(Constants.PR_LOG_ENABLED, ""); + nvp.add(Constants.PR_LOG_LEVEL, ""); + nvp.add(Constants.PR_LOG_BUFFERSIZE, ""); + //nvp.add(Constants.PR_LOG_EXPIRED_TIME, ""); + //nvp.add(Constants.PR_LOG_FILENAME, ""); + //nvp.add(Constants.PR_LOG_FLUSHINTERVAL, ""); + nvp.add(Constants.PR_LOG_MAXFILESIZE, ""); + nvp.add(Constants.PR_LOG_ROLLEROVER_INTERVAL, ""); + + try { + NameValuePairs val = mAdmin.read(DestDef.DEST_LOG_ADMIN, + ScopeDef.SC_ERRORLOG, Constants.RS_ID_CONFIG, nvp); + + parseVals(val); + } catch (EAdminException e) { + showErrorDialog(e.toString()); + mModel.progressStop(); + } + setValues(); + mModel.progressStop(); + clearDirtyFlag(); + mParent.setOKCancel(); + } + + private void parseVals(NameValuePairs nvp) { + if (nvp.getValue(Constants.PR_LOG_ENABLED).equalsIgnoreCase( + Constants.TRUE)) + activateLog.setSelected(true); + else + activateLog.setSelected(false); + mLevel = Integer.parseInt(nvp.getValue(Constants.PR_LOG_LEVEL)); + mlogBufSizTextData = nvp.getValue(Constants.PR_LOG_BUFFERSIZE); + mlogMaxSizTextData = nvp.getValue(Constants.PR_LOG_MAXFILESIZE); + int val = + Integer.parseInt(nvp.getValue(Constants.PR_LOG_ROLLEROVER_INTERVAL)); + mFrequency = getRollOverIndex(val); + } + + /** + * Implementation for saving panel information + * @return true if save successful; otherwise, false. + */ + public boolean applyCallback() { + // check blank fields + if ((mlogMaxSizText.getText().trim().equals("")) || + (mlogBufSizText.getText().trim().equals("")) ) { + showMessageDialog("BLANKFIELD"); + return false; + } + + String bufSize = mlogBufSizText.getText().trim(); + String maxSize = mlogMaxSizText.getText().trim(); + + try { + int val1 = Integer.parseInt(bufSize); + int val2 = Integer.parseInt(maxSize); + if (val1 <= 0 || val2 <= 0) { + showMessageDialog("OUTOFRANGE"); + return false; + } + } catch (NumberFormatException e) { + showMessageDialog("NUMBERFORMAT"); + return false; + } + + NameValuePairs nvp = new NameValuePairs(); + + if (activateLog.isSelected()) + nvp.add(Constants.PR_LOG_ENABLED, Constants.TRUE); + else + nvp.add(Constants.PR_LOG_ENABLED, Constants.FALSE); + String str = "" + mLogLevel.getSelectedIndex(); + nvp.add(Constants.PR_LOG_LEVEL, str); + nvp.add(Constants.PR_LOG_BUFFERSIZE, mlogBufSizText.getText().trim()); + //nvp.add(Constants.PR_LOG_EXPIRED_TIME, ""); + //nvp.add(Constants.PR_LOG_FILENAME, ""); + //nvp.add(Constants.PR_LOG_FLUSHINTERVAL, ""); + nvp.add(Constants.PR_LOG_MAXFILESIZE, mlogMaxSizText.getText().trim()); + + str = "" + getRollOverTime(mlogFQC.getSelectedIndex()); + nvp.add(Constants.PR_LOG_ROLLEROVER_INTERVAL, str); + + mModel.progressStart(); + try { + mAdmin.modify(DestDef.DEST_LOG_ADMIN, + ScopeDef.SC_ERRORLOG, Constants.RS_ID_CONFIG, nvp); + } catch (EAdminException e) { + showErrorDialog(e.toString()); + mModel.progressStop(); + return false; + } + mModel.progressStop(); + clearDirtyFlag(); + return true; + } + + /** + * Implementation for reset values + * @return true if save successful; otherwise, false. + */ + public boolean resetCallback() { + refresh(); + return true; + } + + /*========================================================== + * EVENT HANDLER METHODS + *==========================================================*/ + + //=== ACTIONLISTENER ===================== + public void actionPerformed(ActionEvent e) { + super.actionPerformed(e); + } +} -- cgit