blob: fdeb2973b8a58b3f7838d70c5029ebae7d430ffd [file] [log] [blame]
/* IORInfoOperations.java --
Copyright (C) 2005 Free Software Foundation, Inc.
This file is part of GNU Classpath.
GNU Classpath is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
GNU Classpath 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
General Public License for more details.
You should have received a copy of the GNU General Public License
along with GNU Classpath; see the file COPYING. If not, write to the
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 USA.
Linking this library statically or dynamically with other modules is
making a combined work based on this library. Thus, the terms and
conditions of the GNU General Public License cover the whole
combination.
As a special exception, the copyright holders of this library give you
permission to link this library with independent modules to produce an
executable, regardless of the license terms of these independent
modules, and to copy and distribute the resulting executable under
terms of your choice, provided that you also meet, for each linked
independent module, the terms and conditions of the license of that
module. An independent module is a module which is not derived from
or based on this library. If you modify this library, you may extend
this exception to your version of the library, but you are not
obligated to do so. If you do not wish to do so, delete this
exception statement from your version. */
package org.omg.PortableInterceptor;
import org.omg.CORBA.Policy;
import org.omg.IOP.TaggedComponent;
/**
* The ORB service uses this interface to add the service specific components to
* the new IOR being constructed. The interface provides also possibility to get
* the POA policies the apply to the IOR being constructed.
*
* @author Audrius Meskauskas, Lithuania (AudriusA@Bioinformatics.org)
*/
public interface IORInfoOperations
{
/**
* Adds a service-specific component to the IOR profile being constructed.
*
* @param tagged_component a tagged component being added.
*
* @param profile_id the IOR profile to that the component must be added.
* The 0 value ({@link org.omg.IOP.TAG_INTERNET_IOP#value}) adds to the
* Internet profile where host and port are stored by default.
*/
void add_ior_component_to_profile(TaggedComponent tagged_component,
int profile_id
);
/**
* Adds a service-specific component to the IOR profile being constructed.
* The specified component will be included in all profiles, present in the
* IOR being constructed.
*
* @param tagged_component a tagged component being added.
*/
void add_ior_component(TaggedComponent tagged_component);
/**
* Get the server side policy for an IOR being constructed. The method returns
* policies applying for POA where the object, represented by this IOR, is
* connected.
*
* @param policy_type the type of the policy.
*
* @return the policy of the given type that applies to the IOR being
* constructed.
*
* @see org.omg.PortableServer.POAOperations#create_POA
*/
Policy get_effective_policy(int policy_type);
/**
* Get the adapter template that is associated with the object POA.
* The template is also a reference factory and can produce the new object
* references.
*
* @since 1.5
*/
public ObjectReferenceTemplate adapter_template();
/**
* The current_factory is the factory, used by the adapter to create
* object references. This factory is initially the same as the
* adapter_template.
*
* @since 1.5
*/
public ObjectReferenceFactory current_factory();
/**
* Set the current object reference factory, used to produce the new objects.
*
* The current factory can only be set during the call to the
* {@link IORInterceptor_3_0Operations#components_established(IORInfo)}.
*
* @since 1.5
*/
public void current_factory(ObjectReferenceFactory factory);
/**
* Get the POA manager Id.
*
* @return Id that uniquely refers to the poa manager, used by this POA.
*
* @since 1.5
*
* @see IORInterceptor_3_0Operations#adapter_manager_state_changed
*/
public int manager_id();
/**
* Get the state of the adapter manager.
*
* @since 1.5
*
* @return the state of the adapters to that the IOR being created belongs.
* One of the {@link HOLDING#value}, {@link DISCARDING#value},
* {@link INACTIVE#value} or {@link NON_EXISTENT#value}.
*/
short state();
}