// --- 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.certsrv.common.*; import com.netscape.management.client.util.*; import com.netscape.admin.certsrv.connection.*; import javax.swing.*; import java.awt.*; import java.util.*; import java.awt.event.*; /** * LDAP server setting tab * * @author Christine Ho * @version $Revision$, $Date$ */ public abstract class CMSBaseLDAPPanel extends CMSBaseTab implements ItemListener { private static final String SERVER_CERT_NICKNAME = "Server-Cert"; private JTextField mHostNameText; private JTextField mPortText; //private JTextField mBaseDNText; private JTextField mBindAsText; private JPasswordField mPasswordText; private JCheckBox mSecurePort; private JCheckBox mEnable; private JCheckBox mEnablePublishing; private JCheckBox mEnableQueue; private Color mActiveColor; private JLabel mHostLabel, mPortLabel, mBindAsLabel, mVersionLabel; protected JLabel mPasswordLabel; protected AdminConnection mAdmin; protected CMSBaseResourceModel mModel; private String mServletName; private CMSTabPanel mParent; private boolean mPublishing = true; private boolean mLDAPPublishing = true; private boolean mPublishingQueue = true; private String mPublishingQueuePriorityLevel = "0"; private String mMaxNumberOfPublishingThreads = "3"; private String mPublishingQueuePageSize = "40"; private String mPublishingQueueStatus = "200"; private JLabel mAuthLabel, mCertLabel; private JComboBox mAuthBox, mCertBox; private String mPanelName; private JComboBox mVersionBox; private final static String[] AUTHTYPE = {Constants.PR_BASIC_AUTH, Constants.PR_SSL_AUTH}; private static final String DELIMITER = ","; public CMSBaseLDAPPanel(String panelName, CMSTabPanel parent) { this(panelName, parent, true); mPanelName = panelName; } public CMSBaseLDAPPanel(String panelName, CMSTabPanel parent, boolean flag) { super(panelName, parent); mServletName = getServletName(panelName); mModel = parent.getResourceModel(); mParent = parent; mPublishing = flag; mPublishingQueue = flag; mLDAPPublishing = flag; } public void init() { mAdmin = mModel.getServerInfo().getAdmin(); JPanel serverInfo = new JPanel(); GridBagLayout gb = new GridBagLayout(); GridBagConstraints gbc = new GridBagConstraints(); mCenterPanel.setLayout(gb); mEnablePublishing = makeJCheckBox("ENABLEPUBLISHING"); mEnablePublishing.setSelected(true); CMSAdminUtil.resetGBC(gbc); gbc.anchor = gbc.NORTHWEST; gbc.fill = gbc.NONE; gbc.gridwidth = gbc.REMAINDER; gbc.weightx = 1.0; gbc.insets = new Insets(DIFFERENT_COMPONENT_SPACE, DIFFERENT_COMPONENT_SPACE, 0, DIFFERENT_COMPONENT_SPACE); gb.setConstraints(mEnablePublishing, gbc); mEnablePublishing.addItemListener(this); mCenterPanel.add(mEnablePublishing); //add the enable queue mEnableQueue = makeJCheckBox("ENABLEQUEUE"); mEnableQueue.setSelected(true); CMSAdminUtil.resetGBC(gbc); gbc.anchor = gbc.NORTHWEST; gbc.fill = gbc.NONE; gbc.gridwidth = gbc.REMAINDER; gbc.weightx = 1.0; gbc.insets = new Insets(DIFFERENT_COMPONENT_SPACE, DIFFERENT_COMPONENT_SPACE, 0, DIFFERENT_COMPONENT_SPACE); gb.setConstraints(mEnableQueue, gbc); mEnableQueue.addItemListener(this); mCenterPanel.add(mEnableQueue); //add the enable checkbox mEnable = makeJCheckBox("ENABLE"); mEnable.setSelected(true); CMSAdminUtil.resetGBC(gbc); gbc.anchor = gbc.NORTHWEST; gbc.fill = gbc.NONE; gbc.gridwidth = gbc.REMAINDER; gbc.weightx = 1.0; gbc.insets = new Insets(DIFFERENT_COMPONENT_SPACE, DIFFERENT_COMPONENT_SPACE, 0, DIFFERENT_COMPONENT_SPACE); gb.setConstraints(mEnable, gbc); mEnable.addItemListener(this); if (mLDAPPublishing) mCenterPanel.add(mEnable); //add the destination panel CMSAdminUtil.resetGBC(gbc); gbc.anchor = gbc.NORTH; gbc.gridwidth = gbc.REMAINDER; gbc.gridheight = gbc.REMAINDER; gbc.weightx = 1.0; gbc.weighty = 1.0; gb.setConstraints(serverInfo, gbc); mCenterPanel.add(serverInfo); GridBagLayout gb1 = new GridBagLayout(); serverInfo.setLayout(gb1); if (mLDAPPublishing) serverInfo.setBorder(makeTitledBorder("DESTINATION")); // add host name label and text field CMSAdminUtil.resetGBC(gbc); mHostLabel = makeJLabel("HOST"); mHostNameText = makeJTextField(30); mActiveColor = mHostNameText.getBackground(); CMSAdminUtil.addEntryField(serverInfo, mHostLabel, mHostNameText, gbc); // add port number label CMSAdminUtil.resetGBC(gbc); mPortLabel = makeJLabel("PORT"); gbc.anchor = gbc.EAST; gbc.fill = gbc.NONE; gbc.insets = new Insets(COMPONENT_SPACE,COMPONENT_SPACE,0,0); gb1.setConstraints(mPortLabel, gbc); serverInfo.add(mPortLabel); // add port number text field CMSAdminUtil.resetGBC(gbc); mPortText = makeJTextField(10); gbc.anchor = gbc.WEST; gbc.fill = gbc.HORIZONTAL; gbc.weightx = 0.0; gb1.setConstraints(mPortText, gbc); serverInfo.add(mPortText); // add check box CMSAdminUtil.resetGBC(gbc); mSecurePort = makeJCheckBox("SECUREPORT"); gbc.anchor = gbc.WEST; gbc.fill = gbc.HORIZONTAL; gbc.weightx = 0.0; gbc.gridwidth = gbc.REMAINDER; gbc.insets = new Insets(COMPONENT_SPACE,DIFFERENT_COMPONENT_SPACE - COMPONENT_SPACE,0,COMPONENT_SPACE); gb1.setConstraints(mSecurePort, gbc); serverInfo.add(mSecurePort); /* add base DN label and text field CMSAdminUtil.resetGBC(gbc); JLabel baseDNLabel = makeJLabel("BASEDN"); mBaseDNText = makeJTextField(30); CMSAdminUtil.addEntryField(serverInfo, baseDNLabel, mBaseDNText, gbc); */ // add bind as label and text field CMSAdminUtil.resetGBC(gbc); mBindAsLabel = makeJLabel("BINDAS"); mBindAsText = makeJTextField(30); CMSAdminUtil.addEntryField(serverInfo, mBindAsLabel, mBindAsText, gbc); // add password label and text field CMSAdminUtil.resetGBC(gbc); mPasswordLabel = makeJLabel("PWD"); mPasswordText = makeJPasswordField(20); CMSAdminUtil.addEntryField(serverInfo, mPasswordLabel, mPasswordText, gbc); // add LDAP version CMSAdminUtil.resetGBC(gbc); mVersionLabel = makeJLabel("VERSION"); mVersionBox = makeJComboBox("VERSION"); JLabel dummy = new JLabel(" "); CMSAdminUtil.addEntryField(serverInfo, mVersionLabel, mVersionBox, dummy, gbc); // add cert nickname CMSAdminUtil.resetGBC(gbc); mCertLabel = makeJLabel("CERTLIST"); mCertBox = makeJComboBox("CERTLIST"); JLabel dummy3 = new JLabel(" "); CMSAdminUtil.addEntryField(serverInfo, mCertLabel, mCertBox, dummy3, gbc); // add combo box for authentication type CMSAdminUtil.resetGBC(gbc); mAuthLabel = makeJLabel("AUTHTYPE"); mAuthBox = makeJComboBox("AUTHTYPE"); mAuthBox.addItemListener(this); JLabel dummy4 = new JLabel(" "); CMSAdminUtil.addEntryField(serverInfo, mAuthLabel, mAuthBox, dummy4, gbc); } public void refresh() { mModel.progressStart(); NameValuePairs nvps = new NameValuePairs(); if (mPublishing) nvps.put(Constants.PR_PUBLISHING_ENABLE, ""); if (mLDAPPublishing) nvps.put(Constants.PR_ENABLE, ""); nvps.put(Constants.PR_HOST_NAME, ""); nvps.put(Constants.PR_LDAP_PORT, ""); nvps.put(Constants.PR_SECURE_PORT_ENABLED, ""); //nvps.add(Constants.PR_BASE_DN, ""); nvps.put(Constants.PR_BIND_DN, ""); nvps.put(Constants.PR_LDAP_VERSION, ""); nvps.put(Constants.PR_AUTH_TYPE, ""); nvps.put(Constants.PR_CERT_NAMES, ""); nvps.put(Constants.PR_LDAP_CLIENT_CERT, ""); nvps.put(Constants.PR_PUBLISHING_QUEUE_ENABLE, ""); nvps.put(Constants.PR_PUBLISHING_QUEUE_THREADS, ""); nvps.put(Constants.PR_PUBLISHING_QUEUE_PAGE_SIZE, ""); nvps.put(Constants.PR_PUBLISHING_QUEUE_PRIORITY, ""); nvps.put(Constants.PR_PUBLISHING_QUEUE_STATUS, ""); try { NameValuePairs val = mAdmin.read(mServletName, ScopeDef.SC_LDAP, Constants.RS_ID_CONFIG, nvps); populate(val); } catch (EAdminException e) { showErrorDialog(e.toString()); mModel.progressStop(); } mModel.progressStop(); clearDirtyFlag(); mParent.setOKCancel(); } protected String getServletName(String panelName) { if (panelName.equals("LDAPSETTING")) return DestDef.DEST_SERVER_ADMIN; else if (panelName.equals("CALDAPSETTING")) return DestDef.DEST_CA_PUBLISHER_ADMIN; return DestDef.DEST_RA_PUBLISHER_ADMIN; } protected void populate(NameValuePairs nvps) { String clientCert = ""; int serverCertIndex = -1; String version = ""; for (String name : nvps.keySet()) { String value = nvps.get(name); if (name.equals(Constants.PR_HOST_NAME)) { mHostNameText.setText(value); } else if (name.equals(Constants.PR_LDAP_PORT)) { mPortText.setText(value); } else if (name.equals(Constants.PR_SECURE_PORT_ENABLED)) { if (value.equals(Constants.TRUE)) mSecurePort.setSelected(true); else mSecurePort.setSelected(false); } else if (name.equals(Constants.PR_BIND_DN)) { mBindAsText.setText(value); } else if (name.equals(Constants.PR_PUBLISHING_ENABLE)) { if (value.equals(Constants.TRUE)) mEnablePublishing.setSelected(true); else mEnablePublishing.setSelected(false); } else if (name.equals(Constants.PR_PUBLISHING_QUEUE_ENABLE)) { if (value.equals(Constants.TRUE)) { mEnableQueue.setSelected(true); mPublishingQueue = true; } else { mEnableQueue.setSelected(false); mPublishingQueue = false; } } else if (name.equals(Constants.PR_PUBLISHING_QUEUE_THREADS)) { mMaxNumberOfPublishingThreads = value; } else if (name.equals(Constants.PR_PUBLISHING_QUEUE_PAGE_SIZE)) { mPublishingQueuePageSize = value; } else if (name.equals(Constants.PR_PUBLISHING_QUEUE_PRIORITY)) { mPublishingQueuePriorityLevel = value; } else if (name.equals(Constants.PR_PUBLISHING_QUEUE_STATUS)) { mPublishingQueueStatus = value; } else if (name.equals(Constants.PR_ENABLE)) { if (value.equals(Constants.TRUE)) mEnable.setSelected(true); else mEnable.setSelected(false); } else if (name.equals(Constants.PR_AUTH_TYPE)) { int index = getIndex(value, AUTHTYPE); if (index >= 0) mAuthBox.setSelectedIndex(index); } else if (name.equals(Constants.PR_CERT_NAMES)) { mCertBox.removeAllItems(); String certNames = value; StringTokenizer tokenizer = new StringTokenizer(certNames, DELIMITER); for (int index=0; tokenizer.hasMoreTokens(); index++) { String str = (String)tokenizer.nextToken(); if (str.startsWith(SERVER_CERT_NICKNAME)) serverCertIndex = index; mCertBox.addItem(str); } } else if (name.equals(Constants.PR_LDAP_CLIENT_CERT)) { clientCert = value; } else if (name.equals(Constants.PR_LDAP_VERSION)) { version = value; } } if (version.equals("")) mVersionBox.setSelectedIndex(1); else mVersionBox.setSelectedItem(version); if (clientCert.equals("")) { if (serverCertIndex == -1) mCertBox.setSelectedIndex(0); else mCertBox.setSelectedIndex(serverCertIndex); } else mCertBox.setSelectedItem(clientCert.trim()); if (mEnablePublishing.isSelected()) { enableFieldsAndLDAP(true, mActiveColor); } else { enableFieldsAndLDAP(false, getBackground()); } if (mEnable.isSelected()) enableFields(true, mActiveColor); else enableFields(false, getBackground()); mPasswordText.setText(""); } private int getIndex(String val, String[] array) { for (int i=0; i