You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@sling.apache.org by "Dirk Rudolph (JIRA)" <ji...@apache.org> on 2018/02/21 19:53:00 UTC

[jira] [Commented] (SLING-7508) StackOverflowError adapting ServletResource to Sling Mode with impl picker

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

Dirk Rudolph commented on SLING-7508:
-------------------------------------

As far as I can see the issue is caused by the [ResourceTypeBasedResourcePicker.java#L46|https://github.com/apache/sling-org-apache-sling-models-impl/blob/master/src/main/java/org/apache/sling/models/impl/ResourceTypeBasedResourcePicker.java#L46] calling [AdapterImplementations#getModelClassForResource()| https://github.com/apache/sling-org-apache-sling-models-impl/blob/master/src/main/java/org/apache/sling/models/impl/AdapterImplementations.java#L321] which walks up the resourceType hierarchy until it finds an implementation. For the SerlvetResource in that case the resourceSuperTypes are "sling/bundle/resource" and null, so it ends up getting the resource of the originalResourceType of the ServletResource which is again the ServletResource causing the endless loop.

> StackOverflowError adapting ServletResource to Sling Mode with impl picker
> --------------------------------------------------------------------------
>
>                 Key: SLING-7508
>                 URL: https://issues.apache.org/jira/browse/SLING-7508
>             Project: Sling
>          Issue Type: Bug
>          Components: Extensions
>    Affects Versions: Sling Models Impl 1.4.8
>            Reporter: Dirk Rudolph
>            Priority: Major
>
> Adapting a {{SlingHttpServletRequest}} to a servlet that is registered using sling.servlet.paths to a {{@Model}} fails in the following StackOverflowError:
> {code}
> java.lang.StackOverflowError: null
>         ...
>         at org.apache.sling.models.impl.AdapterImplementations.getModelClassForResource(AdapterImplementations.java:318)
>         at org.apache.sling.models.impl.AdapterImplementations.getModelClassForResource(AdapterImplementations.java:322)
>         at org.apache.sling.models.impl.AdapterImplementations.getModelClassForResource(AdapterImplementations.java:322)
> {code}
> See for example the following pseudo code:
> {code}
> class MyServlet extends SlingSafeMethodsServlet {
>  doGet(request) { request.adaptTo(Model.class); }
> }
> interface Model {
>  ...
> }
> @Model(adaptables = SlingHttpServletRequest.class, adapters = {ModelImpl.class, Model.class})
> class ModelImpl implements Model {
>  ...
> }
> {code}



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)