package org.jacorb.security.sas;
/*
* JacORB - a free Java ORB
*
* Copyright (C) 2002-2014 Gerald Brose / The JacORB Team.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library 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
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the Free
* Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
import org.jacorb.config.ConfigurationException;
import org.jacorb.orb.standardInterceptors.SASComponentInterceptor;
import org.jacorb.sasPolicy.ATLAS_POLICY_TYPE;
import org.jacorb.sasPolicy.SAS_POLICY_TYPE;
import org.omg.IOP.CodecFactoryPackage.UnknownEncoding;
import org.omg.PortableInterceptor.ORBInitInfo;
import org.omg.PortableInterceptor.ORBInitializer;
import org.omg.PortableInterceptor.ORBInitInfoPackage.DuplicateName;
import org.slf4j.Logger;
/**
* This initializes the SAS Target Security Service (TSS) Interceptor
*
* @author David Robison
*/
public class SASInitializer
extends org.omg.CORBA.LocalObject
implements ORBInitializer
{
private Logger logger = null;
public static final int SecurityAttributeService = 15;
public static int sasPrincipalNamePIC = (-1);
/**
* This method registers the interceptors.
*/
public void post_init( ORBInitInfo info )
{
org.jacorb.orb.ORB orb =
((org.jacorb.orb.portableInterceptor.ORBInitInfoImpl)info).getORB ();
logger =
orb.getConfiguration().getLogger("org.jacorb.security.sas.log.verbosity");
// install the TSS interceptor
try
{
sasPrincipalNamePIC = info.allocate_slot_id();
info.add_server_request_interceptor(new SASTargetInterceptor(info));
}
catch (ConfigurationException ce)
{
if (logger.isErrorEnabled())
logger.error("ConfigurationException", ce);
}
catch (DuplicateName duplicateName)
{
if (logger.isErrorEnabled())
logger.error("TSS DuplicateName", duplicateName);
}
catch (UnknownEncoding unknownEncoding)
{
if (logger.isErrorEnabled())
logger.error("TSS UnknownEncoding", unknownEncoding);
}
// install the CSS interceptor
try
{
info.add_client_request_interceptor(new SASClientInterceptor(info));
}
catch (ConfigurationException ce)
{
logger.error("ConfigurationException", ce);
throw new org.omg.CORBA.INITIALIZE(ce.getMessage());
}
catch (DuplicateName duplicateName)
{
logger.error("CSS DuplicateName", duplicateName);
throw new org.omg.CORBA.INITIALIZE(duplicateName.getMessage());
}
catch (UnknownEncoding unknownEncoding)
{
logger.error("CSS UnknownEncoding", unknownEncoding);
throw new org.omg.CORBA.INITIALIZE(unknownEncoding.getMessage());
}
// install IOR interceptor
try
{
info.add_ior_interceptor(new SASComponentInterceptor(info));
}
catch (DuplicateName duplicateName)
{
logger.error("IOR DuplicateName", duplicateName);
throw new org.omg.CORBA.INITIALIZE(duplicateName.getMessage());
}
// create policy factory
info.register_policy_factory( SAS_POLICY_TYPE.value, new SASPolicyFactory() );
info.register_policy_factory( ATLAS_POLICY_TYPE.value, new ATLASPolicyFactory() );
}
public void pre_init(ORBInitInfo info)
{
}
} // SAS setup Initializer