maguro 2005/03/31 10:28:11
Modified: modules/core/src/java/org/openejb/corba/security/config/css
CSSASMechConfig.java
Added: modules/core/src/java/org/openejb/corba/security/config/css
CSSGSSUPMechConfigDynamic.java
CSSGSSUPMechConfigStatic.java
Removed: modules/core/src/java/org/openejb/corba/security/config/css
CSSGSSUPMechConfig.java
Log:
Fleshed out AS Mech group
Revision Changes Path
1.2 +5 -1
openejb/modules/core/src/java/org/openejb/corba/security/config/css/CSSASMechConfig.java
Index: CSSASMechConfig.java
===================================================================
RCS file:
/home/projects/openejb/scm/openejb/modules/core/src/java/org/openejb/corba/security/config/css/CSSASMechConfig.java,v
retrieving revision 1.1
retrieving revision 1.2
diff -u -r1.1 -r1.2
--- CSSASMechConfig.java 8 Mar 2005 04:08:33 -0000 1.1
+++ CSSASMechConfig.java 31 Mar 2005 15:28:11 -0000 1.2
@@ -63,5 +63,9 @@
public boolean canHandle(TSSASMechConfig asMech);
+ /**
+ * Encode the client authentication token
+ * @return the encoded client authentication token
+ */
public byte[] encode();
}
1.1
openejb/modules/core/src/java/org/openejb/corba/security/config/css/CSSGSSUPMechConfigDynamic.java
Index: CSSGSSUPMechConfigDynamic.java
===================================================================
/**
* Redistribution and use of this software and associated documentation
* ("Software"), with or without modification, are permitted provided
* that the following conditions are met:
*
* 1. Redistributions of source code must retain copyright
* statements and notices. Redistributions must also contain a
* copy of this document.
*
* 2. Redistributions in binary form must reproduce the
* above copyright notice, this list of conditions and the
* following disclaimer in the documentation and/or other
* materials provided with the distribution.
*
* 3. The name "OpenEJB" must not be used to endorse or promote
* products derived from this Software without prior written
* permission of The OpenEJB Group. For written permission,
* please contact [EMAIL PROTECTED]
*
* 4. Products derived from this Software may not be called "OpenEJB"
* nor may "OpenEJB" appear in their names without prior written
* permission of The OpenEJB Group. OpenEJB is a registered
* trademark of The OpenEJB Group.
*
* 5. Due credit should be given to the OpenEJB Project
* (http://openejb.sf.net/).
*
* THIS SOFTWARE IS PROVIDED BY THE OPENEJB GROUP AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT
* NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
* THE OPENEJB GROUP OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
* OF THE POSSIBILITY OF SUCH DAMAGE.
*
* Copyright 2005 (C) The OpenEJB Group. All Rights Reserved.
*
* $Id: CSSGSSUPMechConfigDynamic.java,v 1.1 2005/03/31 15:28:11 maguro Exp $
*/
package org.openejb.corba.security.config.css;
import java.security.AccessController;
import java.security.PrivilegedAction;
import java.util.Iterator;
import java.util.Set;
import javax.security.auth.Subject;
import org.apache.geronimo.security.jaas.NamedUsernamePasswordCredential;
import org.openejb.corba.security.config.tss.TSSASMechConfig;
import org.openejb.corba.security.config.tss.TSSGSSUPMechConfig;
import org.openejb.corba.util.Util;
/**
* This GSSUP mechanism obtains its username and password from a named
username
* password credential that is stored in the subject associated w/ the call
* stack.
*
* @version $Revision: 1.1 $ $Date: 2005/03/31 15:28:11 $
*/
public class CSSGSSUPMechConfigDynamic implements CSSASMechConfig {
private final String domain;
private transient byte[] encoding;
public CSSGSSUPMechConfigDynamic(String domain) {
this.domain = domain;
}
public short getSupports() {
return 0;
}
public short getRequires() {
return 0;
}
public boolean canHandle(TSSASMechConfig asMech) {
if (asMech instanceof TSSGSSUPMechConfig) return true;
if (asMech.getRequires() == 0) return true;
return false;
}
public byte[] encode() {
if (encoding == null) {
NamedUsernamePasswordCredential credential = null;
Set creds = (Set) AccessController.doPrivileged(new
PrivilegedAction() {
public Object run() {
Subject subject =
Subject.getSubject(AccessController.getContext());
return
subject.getPrivateCredentials(NamedUsernamePasswordCredential.class);
}
});
if (creds.size() != 0) {
for (Iterator iter = creds.iterator(); iter.hasNext();) {
credential = (NamedUsernamePasswordCredential)
iter.next();
if (credential.getName().equals(domain)) break;
}
encoding = Util.encodeGSSUPToken(Util.getORB(),
Util.getCodec(), credential.getName(), new String(credential.getPassword()),
domain);
}
if (encoding == null) encoding = new byte[0];
}
return encoding;
}
}
1.1
openejb/modules/core/src/java/org/openejb/corba/security/config/css/CSSGSSUPMechConfigStatic.java
Index: CSSGSSUPMechConfigStatic.java
===================================================================
/**
* Redistribution and use of this software and associated documentation
* ("Software"), with or without modification, are permitted provided
* that the following conditions are met:
*
* 1. Redistributions of source code must retain copyright
* statements and notices. Redistributions must also contain a
* copy of this document.
*
* 2. Redistributions in binary form must reproduce the
* above copyright notice, this list of conditions and the
* following disclaimer in the documentation and/or other
* materials provided with the distribution.
*
* 3. The name "OpenEJB" must not be used to endorse or promote
* products derived from this Software without prior written
* permission of The OpenEJB Group. For written permission,
* please contact [EMAIL PROTECTED]
*
* 4. Products derived from this Software may not be called "OpenEJB"
* nor may "OpenEJB" appear in their names without prior written
* permission of The OpenEJB Group. OpenEJB is a registered
* trademark of The OpenEJB Group.
*
* 5. Due credit should be given to the OpenEJB Project
* (http://openejb.sf.net/).
*
* THIS SOFTWARE IS PROVIDED BY THE OPENEJB GROUP AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT
* NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
* THE OPENEJB GROUP OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
* OF THE POSSIBILITY OF SUCH DAMAGE.
*
* Copyright 2005 (C) The OpenEJB Group. All Rights Reserved.
*
* $Id: CSSGSSUPMechConfigStatic.java,v 1.1 2005/03/31 15:28:11 maguro Exp $
*/
package org.openejb.corba.security.config.css;
import org.openejb.corba.security.config.tss.TSSASMechConfig;
import org.openejb.corba.security.config.tss.TSSGSSUPMechConfig;
import org.openejb.corba.util.Util;
/**
* @version $Revision: 1.1 $ $Date: 2005/03/31 15:28:11 $
*/
public class CSSGSSUPMechConfigStatic implements CSSASMechConfig {
private final String username;
private final String password;
private final String domain;
private transient byte[] encoding;
public CSSGSSUPMechConfigStatic(String username, String password, String
domain) {
this.username = username;
this.password = password;
this.domain = domain;
}
public short getSupports() {
return 0;
}
public short getRequires() {
return 0;
}
public boolean canHandle(TSSASMechConfig asMech) {
if (asMech instanceof TSSGSSUPMechConfig) return true;
if (asMech.getRequires() == 0) return true;
return false;
}
public byte[] encode() {
if (encoding == null) {
encoding = Util.encodeGSSUPToken(Util.getORB(), Util.getCodec(),
username, password, domain);
if (encoding == null) encoding = new byte[0];
}
return encoding;
}
}