-
- All Superinterfaces:
InterceptorOperations
- All Known Subinterfaces:
ServerRequestInterceptor
public interface ServerRequestInterceptorOperations extends InterceptorOperations
Server-side request interceptor.A request Interceptor is designed to intercept the flow of a request/reply sequence through the ORB at specific points so that services can query the request information and manipulate the service contexts which are propagated between clients and servers. The primary use of request Interceptors is to enable ORB services to transfer context information between clients and servers. There are two types of request Interceptors: client-side and server-side.
To write a server-side Interceptor, implement the ServerRequestInterceptor interface.
- See Also:
ServerRequestInfo
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description voidreceive_request(ServerRequestInfo ri)Allows an Interceptor to query request information after all the information, including operation parameters, are available.voidreceive_request_service_contexts(ServerRequestInfo ri)Allows the interceptor to process service context information.voidsend_exception(ServerRequestInfo ri)Allows an Interceptor to query the exception information and modify the reply service context before the exception is thrown to the client.voidsend_other(ServerRequestInfo ri)Allows an Interceptor to query the information available when a request results in something other than a normal reply or an exception.voidsend_reply(ServerRequestInfo ri)Allows an Interceptor to query reply information and modify the reply service context after the target operation has been invoked and before the reply is returned to the client.-
Methods inherited from interface org.omg.PortableInterceptor.InterceptorOperations
destroy, name
-
-
-
-
Method Detail
-
receive_request_service_contexts
void receive_request_service_contexts(ServerRequestInfo ri) throws ForwardRequest
Allows the interceptor to process service context information.At this interception point, Interceptors must get their service context information from the incoming request transfer it to
PortableInterceptor.Current's slots.This interception point is called before the servant manager is called. Operation parameters are not yet available at this point. This interception point may or may not execute in the same thread as the target invocation.
This interception point may throw a system exception. If it does, no other Interceptors'
receive_request_service_contextsoperations are called. Those Interceptors on the Flow Stack are popped and theirsend_exceptioninterception points are called.This interception point may also throw a
ForwardRequestexception. If an Interceptor throws this exception, no other Interceptors'receive_request_service_contextsoperations are called. Those Interceptors on the Flow Stack are popped and theirsend_otherinterception points are called.Compliant Interceptors shall properly follow
completion_statussemantics if they throw a system exception from this interception point. Thecompletion_statusshall be COMPLETED_NO.- Parameters:
ri- Information about the current request being intercepted.- Throws:
ForwardRequest- If thrown, indicates to the ORB that a retry of the request should occur with the new object given in the exception.
-
receive_request
void receive_request(ServerRequestInfo ri) throws ForwardRequest
Allows an Interceptor to query request information after all the information, including operation parameters, are available. This interception point shall execute in the same thread as the target invocation.In the DSI model, since the parameters are first available when the user code calls
arguments,receive_requestis called from withinarguments. It is possible thatargumentsis not called in the DSI model. The target may callset_exceptionbefore callingarguments. The ORB shall guarantee thatreceive_requestis called once, either throughargumentsor throughset_exception. If it is called throughset_exception, requesting the arguments will result inNO_RESOURCESbeing thrown with a standard minor code of 1.This interception point may throw a system exception. If it does, no other Interceptors'
receive_requestoperations are called. Those Interceptors on the Flow Stack are popped and theirsend_exceptioninterception points are called.This interception point may also throw a
ForwardRequestexception. If an Interceptor throws this exception, no other Interceptors'receive_requestoperations are called. Those Interceptors on the Flow Stack are popped and theirsend_otherinterception points are called.Compliant Interceptors shall properly follow
completion_statussemantics if they throw a system exception from this interception point. Thecompletion_statusshall beCOMPLETED_NO.- Parameters:
ri- Information about the current request being intercepted.- Throws:
ForwardRequest- If thrown, indicates to the ORB that a retry of the request should occur with the new object given in the exception.
-
send_reply
void send_reply(ServerRequestInfo ri)
Allows an Interceptor to query reply information and modify the reply service context after the target operation has been invoked and before the reply is returned to the client. This interception point shall execute in the same thread as the target invocation.This interception point may throw a system exception. If it does, no other Interceptors'
send_replyoperations are called. The remaining Interceptors in the Flow Stack shall have theirsend_exceptioninterception point called.Compliant Interceptors shall properly follow
completion_statussemantics if they throw a system exception from this interception point. Thecompletion_statusshall beCOMPLETED_YES.- Parameters:
ri- Information about the current request being intercepted.
-
send_exception
void send_exception(ServerRequestInfo ri) throws ForwardRequest
Allows an Interceptor to query the exception information and modify the reply service context before the exception is thrown to the client. When an exception occurs, this interception point is called. This interception point shall execute in the same thread as the target invocation.This interception point may throw a system exception. This has the effect of changing the exception which successive Interceptors popped from the Flow Stack receive on their calls to
send_exception. The exception thrown to the client will be the last exception thrown by an Interceptor, or the original exception if no Interceptor changes the exception.This interception point may also throw a
ForwardRequestexception. If an Interceptor throws this exception, no other Interceptors'send_exceptionoperations are called. The remaining Interceptors in the Flow Stack shall have theirsend_otherinterception points called.If the
completion_statusof the exception is notCOMPLETED_NO, then it is inappropriate for this interception point to throw aForwardRequestexception. The request's at-most-once semantics would be lost.Compliant Interceptors shall properly follow
completion_statussemantics if they throw a system exception from this interception point. If the original exception is a system exception, thecompletion_statusof the new exception shall be the same as on the original. If the original exception is a user exception, then thecompletion_statusof the new exception shall beCOMPLETED_YES.- Parameters:
ri- Information about the current request being intercepted.- Throws:
ForwardRequest- If thrown, indicates to the ORB that a retry of the request should occur with the new object given in the exception.
-
send_other
void send_other(ServerRequestInfo ri) throws ForwardRequest
Allows an Interceptor to query the information available when a request results in something other than a normal reply or an exception. For example, a request could result in a retry (e.g., a GIOP Reply with aLOCATION_FORWARDstatus was received). This interception point shall execute in the same thread as the target invocation.This interception point may throw a system exception. If it does, no other Interceptors'
send_otheroperations are called. The remaining Interceptors in the Flow Stack shall have theirsend_exceptioninterception points called.This interception point may also throw a
ForwardRequestexception. If an Interceptor throws this exception, successive Interceptors'send_otheroperations are called with the new information provided by theForwardRequestexception.Compliant Interceptors shall properly follow
completion_statussemantics if they throw a system exception from this interception point. Thecompletion_statusshall beCOMPLETED_NO.- Parameters:
ri- Information about the current request being intercepted.- Throws:
ForwardRequest- If thrown, indicates to the ORB that a retry of the request should occur with the new object given in the exception.
-
-