Using the Sling Resource Merger in AEM using-the-sling-resource-merger-in-aem
Purpose purpose
The Sling Resource Merger provides services to access and merge resources. It provides diff (differencing) mechanisms for both:
- 
                  Overlays of resources using the configured search paths. 
- 
                  Overrides of component dialogs for the touch-enabled UI ( cq:dialog), using the resource type hierarchy (by means of the propertysling:resourceSuperType).
With the Sling Resource Merger, the overlay/override resources and/or properties are merged with the original resources/properties:
- 
                  The content of the customized definition has a higher priority than that of the original (that is, it overlays or overrides it). 
- 
                  Where necessary, properties defined in the customization, indicate how content merged from the original is to be used. 
Goals for AEM goals-for-aem
The goals for using the Sling Resource Merger in AEM are to:
- 
                  ensure that customization changes are not made in /libs.
- 
                  reduce the structure that is replicated from /libs.When using the Sling Resource Merger it is not recommended to copy the entire structure from /libsas this would result in too much information being held in the customization (usually/apps). Duplicating information unnecessarily increases the chance of problems when the system in upgraded in any way.
sling:resourceSuperType to make the connection./apps, as best practice in AEM is to define customizations under /apps; this is because you must not change anything under /libs./libs path./libs is overwritten the next time you upgrade your instance (and may well be overwritten when you apply either a hotfix or feature pack).- 
                  Recreate the required item (that is, as it exists in /libs) under/apps
- 
                  Make any changes within /apps
Properties properties
The resource merger provides the following properties:
- 
                  sling:hideProperties(StringorString[])Specifies the property, or list of properties, to hide. The wildcard *hides all.
- 
                  sling:hideResource(Boolean)Indicates whether the resources should be completely hidden, including its children. 
- 
                  sling:hideChildren(StringorString[])Contains the child node, or list of child nodes, to hide. The properties of the node will be maintained. The wildcard *hides all.
- 
                  sling:orderBefore(String)Contains the name of the sibling node that the current node should be positioned in front of. 
These properties affect how the corresponding/original resources/properties (from /libs) are used by the overlay/override (often in /apps).
Creating the Structure creating-the-structure
To create an overlay or override you need to recreate the original node, with the equivalent structure, under the destination (usually /apps). For example:
- 
                  Overlay - 
                      The definition of the navigation entry for the Sites console, as shown in the rail is defined at: /libs/cq/core/content/nav/sites/jcr:title
- 
                      To overlay this, create the following node: /apps/cq/core/content/nav/sitesThen update the property jcr:titleas required.
 
- 
                      
- 
                  Override - 
                      The definition of the touch-enabled dialog for the Texts console, is defined at: /libs/foundation/components/text/cq:dialog
- 
                      To override this, create the following node - for example: /apps/the-project/components/text/cq:dialog
 
- 
                      
To create either of these you only need to recreate the skeleton structure. To simplify the recreation of the structure all intermediary nodes can be of type nt:unstructured (they do not have to reflect the original node type; for example, in /libs).
So in the above overlay example, the following nodes are needed:
/apps
  /cq
    /core
      /content
        /nav
          /sites
/libs as it would result in too much information being held in /apps. This can cause problems when the system in upgraded in any way.Use Cases use-cases
These, in conjunction with standard functionality, enable you to:
- 
                  Add a property The property does not exist in the /libsdefinition, but is required in the/appsoverlay/override.- Create the corresponding node within /apps
- Create the new property on this node ``
 
- Create the corresponding node within 
- 
                  Redefine a property (not auto-created properties) The property is defined in /libs, but a new value is required in the/appsoverlay/override.- 
                      Create the corresponding node within /apps
- 
                      Create the matching property on this node (under / apps)- 
                          The property will have a priority based on the Sling Resource Resolver configuration. 
- 
                          Changing the property type is supported. If you use a property type different to the one used in /libs, then the property type you define is used.
 
- 
                          
 note note NOTE Changing the property type is supported. 
- 
                      
- 
                  Redefine an auto-created property By default, auto-created properties (such as jcr:primaryType) are not subject to an overlay/override to ensure that the node type currently under/libsis respected. To impose an overlay/override you have to recreate the node in/apps, explicitly hide the property and redefine it:- 
                      Create the corresponding node under /appswith the desiredjcr:primaryType
- 
                      Create the property sling:hidePropertieson that node, with the value set to that of the auto-created property; for example,jcr:primaryTypeThis property, defined under /apps, will now take priority over the one defined under/libs
 
- 
                      
- 
                  Redefine a node and its children The node and its children are defined in /libs, but a new configuration is required in the/appsoverlay/override.- 
                      Combine the actions of: - Hide children of a node (keeping the properties of the node)
- Redefine the property/properties
 
 
- 
                      
- 
                  Hide a property The property is defined in /libs, but not required in the/appsoverlay/override.- 
                      Create the corresponding node within /apps
- 
                      Create a property sling:hidePropertiesof typeStringorString[]. Use this specify the properties to be hidden/ignored. Wildcards can also be used. For example:- *
- ["*"]
- jcr:title
- ["jcr:title", "jcr:description"]
 
 
- 
                      
- 
                  Hide a node and its children The node and its children are defined in /libs, but not required in the/appsoverlay/override.- 
                      Create the corresponding node under /apps 
- 
                      Create a property sling:hideResource- type: Boolean
- value: true
 
- type: 
 
- 
                      
- 
                  Hide children of a node (while keeping the properties of the node) The node, its properties and its children are defined in /libs. The node and its properties are required in the/appsoverlay/override, but some or all the child nodes are not required in the/appsoverlay/override.- 
                      Create the corresponding node under /apps
- 
                      Create the property sling:hideChildren:- type: String[]
- value: a list of the child nodes (as defined in /libs) to hide/ignore
 The wildcard * can be used to hid/ignore all child nodes. 
- type: 
 
- 
                      
- 
                  Reorder nodes The node and its siblings are defined in /libs. A new position is required so the node is recreated in the/appsoverlay/override, where the new position is defined in reference to the appropriate sibling node in/libs.- 
                      Use the sling:orderBeforeproperty:- 
                          Create the corresponding node under /apps
- 
                          Create the property sling:orderBefore:This specifies the node (as in /libs) that the current node should be positioned before:- type: String
- value: <before-SiblingName>
 
- type: 
 
- 
                          
 
- 
                      
Invoking the Sling Resource Merger from your code invoking-the-sling-resource-merger-from-your-code
The Sling Resource Merger includes two custom resource providers - one for overlays and another for overrides. Each of these can be can invoked within your code by using a mount point:
/libs).- 
                  Overlay: - 
                      purpose: merge resources based on their search path 
- 
                      mount point: /mnt/overlay
- 
                      usage: mount point + relative path
- 
                      example: - getResource('/mnt/overlay' + '<relative-path-to-resource>');
 
 
- 
                      
- 
                  Override: - 
                      purpose: merge resources based on their super type 
- 
                      mount point: /mnt/overide
- 
                      usage: mount point + absolute path
- 
                      example: - getResource('/mnt/override' + '<absolute-path-to-resource>');
 
 
- 
                      
Example of Usage example-of-usage
Some examples are covered:
- 
                  Overlay: 
- 
                  Override: