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/keycert/WCACertRequest1Page.java | 237 +++++++++++++++++++++ 1 file changed, 237 insertions(+) create mode 100644 pki/base/console/src/com/netscape/admin/certsrv/keycert/WCACertRequest1Page.java (limited to 'pki/base/console/src/com/netscape/admin/certsrv/keycert/WCACertRequest1Page.java') diff --git a/pki/base/console/src/com/netscape/admin/certsrv/keycert/WCACertRequest1Page.java b/pki/base/console/src/com/netscape/admin/certsrv/keycert/WCACertRequest1Page.java new file mode 100644 index 000000000..fe5ebd2d7 --- /dev/null +++ b/pki/base/console/src/com/netscape/admin/certsrv/keycert/WCACertRequest1Page.java @@ -0,0 +1,237 @@ +// --- 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.keycert; + +import java.awt.*; +import java.awt.event.*; +import javax.swing.*; +import com.netscape.admin.certsrv.*; +import com.netscape.admin.certsrv.connection.*; +import com.netscape.admin.certsrv.wizard.*; +import com.netscape.certsrv.common.*; + +/** + * Certificate Request from certificate setup wizard. + * + * @author Christine Ho + * @version $Revision$, $Date$ + * @see com.netscape.admin.certsrv.keycert + */ +class WCACertRequest1Page extends WizardBasePanel implements IWizardPanel { + private JTextArea mMethodText; + private JRadioButton mCABtn; + private JRadioButton mSubBtn; + private JRadioButton mExistingKeyBtn; + private JRadioButton mNewKeyBtn; + private JRadioButton mEmailBtn; + private JRadioButton mURLBtn; + private JRadioButton mManualBtn; + private Color mActiveColor; + private static final String PANELNAME = "CACERTREQUESTWIZARD"; + private static final String HELPINDEX = + "configuration-kra-wizard-change-keyscheme-help"; + + WCACertRequest1Page() { + super(PANELNAME); + init(); + } + + public boolean initializePanel(WizardInfo info) { + CertSetupWizardInfo wizardInfo = (CertSetupWizardInfo)info; + if (wizardInfo.getOperationType().equals(wizardInfo.INSTALLTYPE)) + return false; + + if (wizardInfo.getCertType().equals(Constants.PR_CA_SIGNING_CERT)) + return true; + + return false; + } + + public boolean validatePanel() { + return true; + } + + public boolean concludePanel(WizardInfo info) { + return true; + } + + public void callHelp() { + CMSAdminUtil.help(HELPINDEX); + } + + public boolean isLastPage() { + return false; + } + + protected void init() { + GridBagLayout gb = new GridBagLayout(); + GridBagConstraints gbc = new GridBagConstraints(); + setLayout(gb); + + JLabel caLbl = makeJLabel("CATYPE"); + CMSAdminUtil.resetGBC(gbc); + gbc.anchor = gbc.NORTHWEST; + gbc.weightx = 1.0; + gbc.gridwidth = gbc.REMAINDER; + gbc.insets = new Insets(COMPONENT_SPACE,COMPONENT_SPACE, + COMPONENT_SPACE,COMPONENT_SPACE); + add(caLbl, gbc); + + mCABtn = makeJRadioButton("SELFSIGN", true); + CMSAdminUtil.resetGBC(gbc); + gbc.anchor = gbc.NORTHWEST; + gbc.weightx = 1.0; + gbc.insets = new Insets(0,4*COMPONENT_SPACE, + COMPONENT_SPACE,COMPONENT_SPACE); + gbc.gridwidth = gbc.REMAINDER; + add(mCABtn, gbc); + + mSubBtn = makeJRadioButton("SUBORDINATE", false); + CMSAdminUtil.resetGBC(gbc); + gbc.anchor = gbc.NORTHWEST; + gbc.weightx = 1.0; + gbc.insets = new Insets(0,4*COMPONENT_SPACE, + COMPONENT_SPACE,COMPONENT_SPACE); + gbc.gridwidth = gbc.REMAINDER; + add(mSubBtn, gbc); + + ButtonGroup caGroup = new ButtonGroup(); + caGroup.add(mCABtn); + caGroup.add(mSubBtn); + + JLabel keyLbl = makeJLabel("KEYPAIR"); + CMSAdminUtil.resetGBC(gbc); + gbc.anchor = gbc.NORTHWEST; + gbc.weightx = 1.0; + gbc.insets = new Insets(COMPONENT_SPACE,COMPONENT_SPACE, + COMPONENT_SPACE,COMPONENT_SPACE); + gbc.gridwidth = gbc.REMAINDER; + add(keyLbl, gbc); + + mExistingKeyBtn = makeJRadioButton("OLDKEY", true); + CMSAdminUtil.resetGBC(gbc); + gbc.anchor = gbc.NORTHWEST; + gbc.weightx = 1.0; + gbc.insets = new Insets(0, 4*COMPONENT_SPACE, + COMPONENT_SPACE,COMPONENT_SPACE); + gbc.gridwidth = gbc.REMAINDER; + add(mExistingKeyBtn, gbc); + + mNewKeyBtn = makeJRadioButton("NEWKEY", true); + CMSAdminUtil.resetGBC(gbc); + gbc.anchor = gbc.NORTHWEST; + gbc.weightx = 1.0; + gbc.insets = new Insets(0, 4*COMPONENT_SPACE, + COMPONENT_SPACE,COMPONENT_SPACE); + gbc.gridwidth = gbc.REMAINDER; + add(mNewKeyBtn, gbc); + + ButtonGroup keyGroup = new ButtonGroup(); + keyGroup.add(mExistingKeyBtn); + keyGroup.add(mNewKeyBtn); + + mMethodText = createTextArea( + CMSAdminUtil.wrapText(mResource.getString( + "CACERTREQUESTWIZARD_TEXT_METHOD_LABEL"), 100), 1, 100); + mActiveColor = mMethodText.getBackground(); + CMSAdminUtil.resetGBC(gbc); + gbc.anchor = gbc.NORTHWEST; + gbc.weightx = 1.0; + gbc.insets = new Insets(COMPONENT_SPACE,COMPONENT_SPACE, + COMPONENT_SPACE,COMPONENT_SPACE); + gbc.gridwidth = gbc.REMAINDER; + add(mMethodText, gbc); + + mEmailBtn = makeJRadioButton("EMAIL", true); + CMSAdminUtil.resetGBC(gbc); + gbc.anchor = gbc.NORTHWEST; + gbc.weightx = 1.0; + gbc.insets = new Insets(0, 4*COMPONENT_SPACE, + COMPONENT_SPACE,COMPONENT_SPACE); + gbc.gridwidth = gbc.REMAINDER; + add(mEmailBtn, gbc); + + mURLBtn = makeJRadioButton("URL", false); + CMSAdminUtil.resetGBC(gbc); + gbc.anchor = gbc.NORTHWEST; + gbc.weightx = 1.0; + gbc.insets = new Insets(0, 4*COMPONENT_SPACE, + COMPONENT_SPACE,COMPONENT_SPACE); + gbc.gridwidth = gbc.REMAINDER; + add(mURLBtn, gbc); + + mManualBtn = makeJRadioButton("MANUAL", false); + CMSAdminUtil.resetGBC(gbc); + gbc.anchor = gbc.NORTHWEST; + gbc.weightx = 1.0; + gbc.insets = new Insets(0, 4*COMPONENT_SPACE, + COMPONENT_SPACE,COMPONENT_SPACE); + gbc.gridwidth = gbc.REMAINDER; + gbc.weighty = 1.0; + add(mManualBtn, gbc); + + ButtonGroup methodGroup = new ButtonGroup(); + methodGroup.add(mEmailBtn); + methodGroup.add(mURLBtn); + methodGroup.add(mManualBtn); + + enableFields(false, getBackground()); + super.init(); + } + + public void getUpdateInfo(WizardInfo info) { + CertSetupWizardInfo wizardInfo = (CertSetupWizardInfo)info; + + if (mCABtn.isSelected()) + wizardInfo.addEntry(wizardInfo.CA_TYPE, wizardInfo.SELF_SIGNED); + else if (mSubBtn.isSelected()) + wizardInfo.addEntry(wizardInfo.CA_TYPE, wizardInfo.SUBORDINATE_CA); + + if (mNewKeyBtn.isSelected()) + wizardInfo.addEntry(wizardInfo.KEY_MATERIAL, Constants.TRUE); + else if (mExistingKeyBtn.isSelected()) + wizardInfo.addEntry(wizardInfo.KEY_MATERIAL, Constants.FALSE); + + if (mEmailBtn.isSelected()) + wizardInfo.addEntry(wizardInfo.SUBMIT_METHOD, wizardInfo.CA_EMAIL); + else if (mURLBtn.isSelected()) + wizardInfo.addEntry(wizardInfo.SUBMIT_METHOD, wizardInfo.CA_URL); + else if (mManualBtn.isSelected()) + wizardInfo.addEntry(wizardInfo.SUBMIT_METHOD, wizardInfo.MANUAL); + } + + public void actionPerformed(ActionEvent e) { + if (e.getSource().equals(mCABtn)) + if (mCABtn.isSelected()) + enableFields(false, getBackground()); + else + enableFields(true, mActiveColor); + else if (e.getSource().equals(mSubBtn)) + if (mSubBtn.isSelected()) + enableFields(true, mActiveColor); + else + enableFields(false, getBackground()); + } + + private void enableFields(boolean enable, Color color) { + mMethodText.setEnabled(enable); + mEmailBtn.setEnabled(enable); + mURLBtn.setEnabled(enable); + mManualBtn.setEnabled(enable); + } +} -- cgit