001: /*
002: * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
003: *
004: * Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
005: *
006: * The contents of this file are subject to the terms of either the GNU
007: * General Public License Version 2 only ("GPL") or the Common
008: * Development and Distribution License("CDDL") (collectively, the
009: * "License"). You may not use this file except in compliance with the
010: * License. You can obtain a copy of the License at
011: * http://www.netbeans.org/cddl-gplv2.html
012: * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
013: * specific language governing permissions and limitations under the
014: * License. When distributing the software, include this License Header
015: * Notice in each file and include the License file at
016: * nbbuild/licenses/CDDL-GPL-2-CP. Sun designates this
017: * particular file as subject to the "Classpath" exception as provided
018: * by Sun in the GPL Version 2 section of the License file that
019: * accompanied this code. If applicable, add the following below the
020: * License Header, with the fields enclosed by brackets [] replaced by
021: * your own identifying information:
022: * "Portions Copyrighted [year] [name of copyright owner]"
023: *
024: * Contributor(s):
025: *
026: * The Original Software is NetBeans. The Initial Developer of the Original
027: * Software is Sun Microsystems, Inc. Portions Copyright 1997-2006 Sun
028: * Microsystems, Inc. All Rights Reserved.
029: *
030: * If you wish your version of this file to be governed by only the CDDL
031: * or only the GPL Version 2, indicate your decision by adding
032: * "[Contributor] elects to include this software in this distribution
033: * under the [CDDL or GPL Version 2] license." If you do not indicate a
034: * single choice of license, a recipient has the option to distribute
035: * your version of this file under either the CDDL, the GPL Version 2 or
036: * to extend the choice of license to its licensees as provided above.
037: * However, if you add GPL Version 2 code and therefore, elected the GPL
038: * Version 2 license, then the option applies only if the new code is
039: * made subject to such option by the copyright holder.
040: */
041:
042: package org.netbeans.modules.websvc.wsitconf.spi;
043:
044: import javax.swing.undo.UndoManager;
045: import org.netbeans.api.project.Project;
046: import org.netbeans.modules.xml.wsdl.model.WSDLComponent;
047:
048: /**
049: * Security Profile
050: *
051: * @author Martin Grebac
052: */
053: public abstract class SecurityProfile {
054:
055: public static final String CFG_KEYSTORE = "cfgkeystore";
056: public static final String CFG_TRUSTSTORE = "cfgtruststore";
057: public static final String CFG_VALIDATORS = "cfgvalidators";
058:
059: /**
060: * Returns display name to be presented in UI.
061: * @return
062: */
063: public abstract String getDisplayName();
064:
065: /**
066: * Returns a longer description of the profile to be presented in the UI.
067: * @return
068: */
069: public abstract String getDescription();
070:
071: /**
072: * Returns id for sorting the profiles. WSIT default profiles have ids 10, 20, 30, ... to keep space for additional profiles
073: * @return
074: */
075: public abstract int getId();
076:
077: /**
078: * Called when the profile is selected in the combo box.
079: * @param component
080: */
081: public abstract void profileSelected(WSDLComponent component,
082: boolean updateServiceURL);
083:
084: /**
085: * Called when there's another profile selected, or security is disabled at all.
086: * @param component
087: */
088: public abstract void profileDeselected(WSDLComponent component);
089:
090: /**
091: * Should return true if the profile is supported for specific component in the wsdl
092: * @param p
093: * @param component
094: * @return
095: */
096: public boolean isProfileSupported(Project p,
097: WSDLComponent component, boolean sts) {
098: return true;
099: }
100:
101: /**
102: * Should return true if the profile is set on component, false otherwise
103: * @param component
104: * @return
105: */
106: public abstract boolean isCurrentProfile(WSDLComponent component);
107:
108: /**
109: * Should open configuration UI and block until user doesn't close it.
110: * @param component
111: * @param undoManager
112: */
113: public void displayConfig(WSDLComponent component,
114: UndoManager undoManager) {
115: }
116: }
|