You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@cxf.apache.org by "Andriy Redko (Jira)" <ji...@apache.org> on 2021/06/22 00:18:00 UTC

[jira] [Assigned] (CXF-8556) Null AbstractEndpointFactory Properties Interferes with Class-Level PathParam When Creating Proxies with Defined ClientState

     [ https://issues.apache.org/jira/browse/CXF-8556?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Andriy Redko reassigned CXF-8556:
---------------------------------

    Assignee: Andriy Redko

> Null AbstractEndpointFactory Properties Interferes with Class-Level PathParam When Creating Proxies with Defined ClientState
> ----------------------------------------------------------------------------------------------------------------------------
>
>                 Key: CXF-8556
>                 URL: https://issues.apache.org/jira/browse/CXF-8556
>             Project: CXF
>          Issue Type: Bug
>          Components: JAX-RS
>    Affects Versions: 3.4.4
>            Reporter: Noah Rickles
>            Assignee: Andriy Redko
>            Priority: Major
>              Labels: Bug
>
> A service in question needs to be reachable via multiple paths. The {{@Path}} param allows for regex matching on a class-level like the following: {{@Path("/\{a:cat|dog}")}}. The class in which this annotation is used will correctly take requests at either {{/cat}} or {{/dog}}. A class-level {{@PathParam}} is created by the name of {{a}}.
>  
> The issue comes when creating a proxy for this service through the {{JAXRSClientFactoryBean.java}} create method shown below:
> {code:java}
> // @param varValues optional list of values which will be used to substitute
> //                  template variables specified in the class-level JAX-RS Path annotations
> public <T> T create(Class<T> cls, Object... varValues)
> { return cls.cast(createWithValues(varValues)); }{code}
> To define the value of the {{@PathParam a}} that this proxy should use, it appears as if the {{Object... varValues}} needs to be populated. The {{ClientProxyImpl}} is created with the following, after the {{ClientState}} is retrieved:
> {code:java}
> protected ClientProxyImpl createClientProxy(ClassResourceInfo cri, boolean isRoot,
>                                             ClientState actualState, Object[] varValues) {
>     if (actualState == null) {
>         return new ClientProxyImpl(URI.create(getAddress()), proxyLoader, cri, isRoot,
>                                 inheritHeaders, getProperties(), varValues);
>     } else {
>         return new ClientProxyImpl(actualState, proxyLoader, cri, isRoot,
>                                 inheritHeaders, getProperties(), varValues);
>     }
> }
> {code}
> In this scenario, {{actualState}} is defined, and {{getProperties()}} returns {{null}}. {{varValues}} is populated with one entry, "dog". The constructor for the {{ClientProxyImpl}} in this situation is:
> {code:java}
> public ClientProxyImpl(ClientState initialState,
>  ClassLoader loader,
>  ClassResourceInfo cri,
>  boolean isRoot,
>  boolean inheritHeaders,
>  Object... varValues) { ... }
> {code}
> The key here is that the result of {{getProperties()}} will be the first entry in the {{Object[]}} created by the var args.
> After the {{initValuesMap(Object... varValues)}} is called, I would expect the {{valuesMap}} to have one entry, a mapping of "a" to "dog" so that when the proxy is used, it will populate the {{@PathParam a}} with "dog" automatically. What ends up happening is because the {{null }}{{properties}} is being passed as part of the {{Object... varValues}} to the {{ClientProxyImpl}} constructor, the {{varValues}} turns into an array of [null, "dog"] instead of the expected ["dog"]. The proxy creates successfully but does not work because the {{valuesMap}} ends up mapping "a" to {{null}}. This breaks the URI builder implementation with an {{IllegalArgumentException}}:
> {code:java}
> private URI doBuild(boolean fromEncoded, boolean encodePathSlash, Object... values) {
>     if (values == null) {
>         throw new IllegalArgumentException("Template parameter values are set to null");
>     }
>     for (int i = 0; i < values.length; i++) {
>         if (values[i] == null) {
>             throw new IllegalArgumentException("Template parameter value at position " + i + " is set to null");
>         }
>     }
>     ...
> }
> {code}
>  
> This change to the {{createClientProxy}} method was made here: [https://github.com/apache/cxf/pull/572|https://github.com/apache/cxf/pull/572.] and maybe needs to be addressed.



--
This message was sent by Atlassian Jira
(v8.3.4#803005)