// -*- C++ -*- //============================================================================= /** * @file ClientRequestInfo.h * * $Id$ * * This is the implementation of the * PortableInterceptor::ClientRequestInfo interface. * * @author Ossama Othman */ //============================================================================= #ifndef TAO_CLIENT_REQUEST_INFO_H #define TAO_CLIENT_REQUEST_INFO_H #include /**/ "ace/pre.h" #include "tao/orbconf.h" #if !defined (ACE_LACKS_PRAGMA_ONCE) # pragma once #endif /* ACE_LACKS_PRAGMA_ONCE */ #if (TAO_HAS_INTERCEPTORS == 1) #if defined(_MSC_VER) #pragma warning(push) #pragma warning(disable:4250) #endif /* _MSC_VER */ #include "tao/AnyTypeCode/AnyTypeCode_methods.h" #include "tao/PI/PI_includeC.h" #include "tao/PI/PICurrent_Impl.h" #include "tao/CORBA_methods.h" #include "tao/ORB_Constants.h" #include "tao/LocalObject.h" #include "tao/Invocation_Utils.h" #include "tao/TimeBaseC.h" TAO_BEGIN_VERSIONED_NAMESPACE_DECL class TAO_Service_Context; namespace TAO { class Invocation_Base; } namespace Dynamic { class ParameterList; class ExceptionList; typedef CORBA::StringSeq RequestContext; typedef CORBA::StringSeq ContextList; } namespace Messaging { typedef CORBA::Short SyncScope; } /** * @class TAO_ClientRequestInfo * * @brief Implementation of the PortableInterceptor::ClientRequestInfo * interface. */ class TAO_PI_Export TAO_ClientRequestInfo : public virtual PortableInterceptor::ClientRequestInfo, public virtual ::CORBA::LocalObject { public: TAO_ClientRequestInfo (TAO::Invocation_Base *invocation); /// Return an ID unique to the current request. This request ID may /// or may not be the same as the GIOP request ID. virtual CORBA::ULong request_id (void); /// Return the operation name for the current request. virtual char * operation (void); /// Return the list of arguments passed to the current operation. virtual Dynamic::ParameterList * arguments (void); /// Return the list of exceptions the current operation is capable /// of throwing. virtual Dynamic::ExceptionList * exceptions (void); virtual Dynamic::ContextList * contexts (void); virtual Dynamic::RequestContext * operation_context (void); /// Return the result of the current request. If there is no return /// value then an Any with tk_void TypeCode is returned. This is /// method is not valid for oneway operations. virtual CORBA::Any * result (void); /// Returns true for a two-way operation, and false otherwise. virtual CORBA::Boolean response_expected (void); /// Return the sync_scope policy value for the current one-way /// operation. If the operation is not a one-way, a /// CORBA::BAD_INV_ORDER exception is thrown. virtual Messaging::SyncScope sync_scope (void); /// Return the reply status for the current request. /** * Statuses can be PortableInterceptor::SUCCESSFUL, * SYSTEM_EXCEPTION, USER_EXCEPTION, LOCATION_FORWARD, * TRANSPORT_RETRY, UNKNOWN. */ virtual PortableInterceptor::ReplyStatus reply_status (void); /// If the reply status is PortableInterceptor::LOCATION_FORWARD or /// return the object reference to which the request was forwarded. virtual CORBA::Object_ptr forward_reference (void); virtual CORBA::Any * get_slot (PortableInterceptor::SlotId id); /// Return the IOP::ServiceContext with the given IOP::ServiceId /// from the request service context list. virtual IOP::ServiceContext * get_request_service_context ( IOP::ServiceId id); /// Return the IOP::ServiceContext with the given IOP::ServiceId /// from the reply service context list. virtual IOP::ServiceContext * get_reply_service_context (IOP::ServiceId id); /// Return the (initial, non-forwarded, or permanently forwarded) /// object reference of the target. virtual CORBA::Object_ptr target (void); /// Return the object reference for the current target. The target /// may change in the even of a location forward. virtual CORBA::Object_ptr effective_target (void); virtual IOP::TaggedProfile * effective_profile (void); /// Return an Any containing the received exception, if any. /// Otherwise, throw a CORBA::BAD_INV_ORDER exception. /** * @note There is no trivial way to extract the exception from an Any. */ virtual CORBA::Any * received_exception (void); /// Return the repository ID for the received exception. virtual char * received_exception_id (void); /// Return the first IOP::TaggedComponent that matches the given /// IOP::ComponentId in the object reference for the current /// target. virtual IOP::TaggedComponent * get_effective_component (IOP::ComponentId id); /// Return all IOP::TaggedComponent(s) that match the given /// IOP::ComponentId in the object reference for the current /// target. virtual IOP::TaggedComponentSeq * get_effective_components (IOP::ComponentId id); /// Return the policy of the given type in effect for the current /// request. virtual CORBA::Policy_ptr get_request_policy (CORBA::PolicyType type); /// Add the IOP::ServiceContext to the request (outgoing) /// IOP::ServiceContextList. virtual void add_request_service_context ( const IOP::ServiceContext & service_context, CORBA::Boolean replace); /* * Proprietary accessor methods for the FT retention ID and * request expiration time. */ /// Set the absolute FT expiration time for this request. void tao_ft_expiration_time (TimeBase::TimeT time); /// Get the absolute FT expiration time for this request TimeBase::TimeT tao_ft_expiration_time (void) const; /// Set the FT request retention ID for this request. void tao_ft_retention_id (CORBA::Long request_id); /// Get the FT request retention ID for this request. CORBA::Long tao_ft_retention_id (void) const; /* * End proprietary FT methods. */ private: bool parameter_list (Dynamic::ParameterList ¶m_list); bool exception_list (Dynamic::ExceptionList &exception_list); bool result (CORBA::Any *any); /// Check if this ClientRequestInfo object is called within the /// context of a request. void check_validity (void); /// Setup thread scope and request scope /// PortableInterceptor::Current objects. void setup_picurrent (void); /// Helper method to get the request and response service contexts. IOP::ServiceContext *get_service_context_i ( TAO_Service_Context &service_context_list, IOP::ServiceId id); private: /// Pointer to the invocation object. TAO::Invocation_Base *invocation_; /// The "Request Scope Current" (RSC) object, as required by /// Portable Interceptors. TAO::PICurrent_Impl rs_pi_current_; }; TAO_END_VERSIONED_NAMESPACE_DECL #if defined(_MSC_VER) #pragma warning(pop) #endif /* _MSC_VER */ #endif /* TAO_HAS_INTERCEPTORS == 1 */ #include /**/ "ace/post.h" #endif /* TAO_CLIENT_REQUEST_INFO_H */