Package org.apache.geronimo.corba.security.config.tss

Source Code of org.apache.geronimo.corba.security.config.tss.TSSSASMechConfig

/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements.  See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License.  You may obtain a copy of the License at
*
*     http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.geronimo.corba.security.config.tss;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import javax.security.auth.Subject;

import org.omg.CORBA.ORB;
import org.omg.CSI.EstablishContext;
import org.omg.CSI.ITTPrincipalName;
import org.omg.CSI.IdentityToken;
import org.omg.CSIIOP.DelegationByClient;
import org.omg.CSIIOP.IdentityAssertion;
import org.omg.CSIIOP.SAS_ContextSec;
import org.omg.CSIIOP.ServiceConfiguration;
import org.omg.IOP.Codec;
import org.apache.geronimo.corba.security.SASException;
import org.apache.geronimo.corba.security.config.ConfigUtil;
import org.apache.geronimo.corba.util.Util;


/**
* @version $Rev: 503274 $ $Date: 2007-02-03 10:19:18 -0800 (Sat, 03 Feb 2007) $
*/
public class TSSSASMechConfig implements Serializable {

    private short supports;
    private short requires;
    private boolean required;
    private final ArrayList privilegeAuthorities = new ArrayList();
    private final Map idTokens = new HashMap();

    public TSSSASMechConfig() {
    }

    public TSSSASMechConfig(SAS_ContextSec context) throws Exception {
        supports = context.target_supports;
        requires = context.target_requires;

        ServiceConfiguration[] c = context.privilege_authorities;
        for (int i = 0; i < c.length; i++) {
            privilegeAuthorities.add(TSSServiceConfigurationConfig.decodeIOR(c[i]));
        }

        byte[][] n = context.supported_naming_mechanisms;
        for (int i = 0; i < n.length; i++) {
            String oid = Util.decodeOID(n[i]);

            //TODO is this needed?
            if (TSSITTPrincipalNameGSSUP.OID.equals(oid)) {
                //TODO this doesn't make sense if we plan to use this for identity check.
                addIdentityToken(new TSSITTPrincipalNameGSSUP(null, null, null));
            }
        }

        supports = context.target_supports;
        requires = context.target_requires;
    }

    public void addServiceConfigurationConfig(TSSServiceConfigurationConfig config) {
        privilegeAuthorities.add(config);

        supports |= DelegationByClient.value;
        if (required) requires = DelegationByClient.value;
    }

    public TSSServiceConfigurationConfig serviceConfigurationAt(int i) {
        return (TSSServiceConfigurationConfig) privilegeAuthorities.get(i);
    }

    public int paSize() {
        return privilegeAuthorities.size();
    }

    public void addIdentityToken(TSSSASIdentityToken token) {
        idTokens.put(new Integer(token.getType()), token);

        if (token.getType() > 0) supports |= IdentityAssertion.value;
    }

    public short getSupports() {
        return supports;
    }

    public short getRequires() {
        return requires;
    }

    public boolean isRequired() {
        return required;
    }

    public void setRequired(boolean required) {
        this.required = required;
        if (required) requires |= (short) (supports & DelegationByClient.value);
    }

    public SAS_ContextSec encodeIOR(ORB orb, Codec codec) throws Exception {

        SAS_ContextSec result = new SAS_ContextSec();

        int i = 0;
        result.privilege_authorities = new ServiceConfiguration[privilegeAuthorities.size()];
        for (Iterator iter = privilegeAuthorities.iterator(); iter.hasNext();) {
            result.privilege_authorities[i++] = ((TSSServiceConfigurationConfig) iter.next()).generateServiceConfiguration();
        }

        ArrayList list = new ArrayList();
        for (Iterator iter = idTokens.values().iterator(); iter.hasNext();) {
            TSSSASIdentityToken token = (TSSSASIdentityToken) iter.next();

            if (token.getType() == ITTPrincipalName.value) {
                list.add(token);
            }
            result.supported_identity_types |= token.getType();
        }

        i = 0;
        result.supported_naming_mechanisms = new byte[list.size()][];
        for (Iterator iter = list.iterator(); iter.hasNext();) {
            TSSSASIdentityToken token = (TSSSASIdentityToken) iter.next();

            result.supported_naming_mechanisms[i++] = Util.encodeOID(token.getOID());
        }

        result.target_supports = supports;
        result.target_requires = requires;

        return result;
    }

    public Subject check(EstablishContext msg) throws SASException {
        if (msg.identity_token != null) {
            IdentityToken identityToken = msg.identity_token;
            int discriminator = identityToken.discriminator();
            TSSSASIdentityToken tssIdentityToken = (TSSSASIdentityToken) idTokens.get(new Integer(discriminator));
            if (tssIdentityToken == null) {
                throw new SASException(1, new Exception("Unsupported IdentityTokenType: " + discriminator));
            } else {
                return tssIdentityToken.check(identityToken);
            }
        } else {
            return null;
        }
    }

    public String toString() {
        StringBuffer buf = new StringBuffer();
        toString("", buf);
        return buf.toString();
    }

    void toString(String spaces, StringBuffer buf) {
        String moreSpaces = spaces + "  ";
        buf.append(spaces).append(getName()).append(": [\n");
        buf.append(moreSpaces).append("required: ").append(required).append("\n");
        buf.append(moreSpaces).append("SUPPORTS: ").append(ConfigUtil.flags(supports)).append("\n");
        buf.append(moreSpaces).append("REQUIRES: ").append(ConfigUtil.flags(requires)).append("\n");
        for (Iterator iterator = privilegeAuthorities.iterator(); iterator.hasNext();) {
            TSSServiceConfigurationConfig tssServiceConfigurationConfig = (TSSServiceConfigurationConfig) iterator.next();
            tssServiceConfigurationConfig.toString(moreSpaces, buf);
        }
        buf.append("\n");
        for (Iterator iterator = idTokens.values().iterator(); iterator.hasNext();) {
            TSSSASIdentityToken identityToken = (TSSSASIdentityToken) iterator.next();
            identityToken.toString(moreSpaces, buf);
        }
        buf.append(spaces).append("]\n");
    }

    protected String getName() {
        return "TSSSASMechConfig";
    }
   
}
TOP

Related Classes of org.apache.geronimo.corba.security.config.tss.TSSSASMechConfig

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.