You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@ignite.apache.org by "Ivan Daschinsky (Jira)" <ji...@apache.org> on 2021/11/16 08:19:00 UTC

[jira] [Commented] (IGNITE-15794) Request attributes for a java service.

    [ https://issues.apache.org/jira/browse/IGNITE-15794?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17444352#comment-17444352 ] 

Ivan Daschinsky commented on IGNITE-15794:
------------------------------------------

[~xtern] Looks good to me. Lets' wait for the bot's visa.

> Request attributes for a java service. 
> ---------------------------------------
>
>                 Key: IGNITE-15794
>                 URL: https://issues.apache.org/jira/browse/IGNITE-15794
>             Project: Ignite
>          Issue Type: Sub-task
>          Components: managed services
>            Reporter: Pavel Pereslegin
>            Assignee: Pavel Pereslegin
>            Priority: Major
>              Labels: iep-79, ise
>          Time Spent: 1h 10m
>  Remaining Estimate: 0h
>
> Implement support for passing implicit "request" attributes from the proxy to the Java service.
> *Implementation notes*.
>  # If no caller attributes are passed - there should be no performance overhead when executing service methods.
>  # Attributes allow only {{string}} and {{byte[]}} values and does not permit nulls in key/values.
>  # Currently, the context should be immutable, but in the future, it should be possible to change it through the interceptor.
>  # {{ServiceResource}} annotation allows to inject service/proxy, we must provide the ability to transparently pass the context to the injected service.
> *Public API changes:*
> New methods in {{IgniteServices}}  to pass caller context to service proxy.
> {code:java}
> public <T> T serviceProxy(String name, Class<? super T> svcItf, boolean sticky, ServiceCallContext callCtx)
> public <T> T serviceProxy(String name, Class<? super T> svcItf, boolean sticky, ServiceCallContext callCtx, long timeout)
> {code}
> New method in {{ServiceContext}} for getting caller context inside the service method.
> {code:java}
> /**
>  * Gets context of the current service call.
>  *
>  * @return Context of the current service call, possibly {@code null}.
>  * @see ServiceCallContext
>  */
> @Nullable public ServiceCallContext currentCallContext();
> {code}
> New interface {{ServiceCallContext}}
> {code:java}
> public interface ServiceCallContext {
>     public String attribute(String name);
>     public byte[] binaryAttribute(String name);
> }
> {code}
> And the builder {{ServiceCallContextBuilder}} for creating {{ServiceCallContext}}.
> New property in {{ServiceResource annotation}}.
> {code:java}
> /**
>  * Flag indicating that the service call context should be passed to the injected service.
>  *
>  * @return {@code True} if the service call context should be passed to the injected service.
>  */
> public boolean forwardCallerContext() default false;
> {code}
>  



--
This message was sent by Atlassian Jira
(v8.20.1#820001)