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;
      }
  }
  
  
  

Reply via email to