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

Christophe Jelger commented on SLING-6785:
------------------------------------------

[~justinedelson] Actually {{scope="adaptable"}} seems like the current 
situation to me, the model is adapted from the adaptable, period. So I still 
prefer {{scope="request"}} to indicate the "temporal" aspect. But it should 
definitely be a {{String}} to support future values.

[~jebailey] You're right that it's potentially dangerous when adapting from 
{{resources}}, but as Justin wrote, it's up to the model creator to make sure 
that this is done in safe manner. I see many potential benefits for this 
feature: for example, you can have a component that renders a navigation menu 
based on the current page, and then have that {{NavigationModel}} be shared by 
other components on the page (for example in a footer with navigation links) 
without the need to re-instantiate anything.

> Add support for scoped lifecycle of sling models
> ------------------------------------------------
>
>                 Key: SLING-6785
>                 URL: https://issues.apache.org/jira/browse/SLING-6785
>             Project: Sling
>          Issue Type: New Feature
>          Components: Extensions
>            Reporter: Christophe Jelger
>            Priority: Minor
>
> Similar to the scopes of JEE beans 
> (http://docs.oracle.com/javaee/6/tutorial/doc/gjbbk.html), it would be nice 
> to have the possibility to set a scope for sling models.
> For example, a sling model instance could be reused for all the components 
> within the same HTTP request, thus avoiding that multiple instances of the 
> "same" model are created.
> This could be an attribute of the {{@model}} annotation, for example 
> something like:
> {{@model(scope="request")}}
> The {{request}} scope sounds straightforward for a sling model adapted from a 
> request.
> For models adapted from a resource, there are scenarios where the resource 
> itself is not relevant once the model has been instantiated, so it would 
> still be useful to be able to obtain the same model instance for different 
> components and resources within the same HTTP request.
> We could possibly have the same scopes than the JEE beans scope: {{request}}, 
> {{session}}, and {{application}}.



--
This message was sent by Atlassian JIRA
(v6.3.15#6346)

Reply via email to