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)