Overview

  • Configure AEM OSGi configuration
  • Deploy additional AEM packages
  • Generate configuration content packages

Git project

Introduction

The GIT project contains CONGA configuration definitions and two CONGA example environments:

  • definition/src/main/dev-environments/development.yaml
  • environment/src/main/environments/prod.yaml

The first one is used for testing in the local AEM instance. You will only touch this for this exercise.

The second one is an example for a PROD environment - it is not used in the exercise, but you can have a look what different configuration is generated for the different environment files.

Please not that typically the configuration definition is part of the application Maven module structure and released together with it. For the sake of simplicity no AEM application is included in this training repository, instead the application packages from the wcm.io Sample Application are used, which are available on Maven Central. The wcm.io Sample Application itself also contains a CONGA configuration definition, but this is not used in this exercise.

Exercise

A) Deploy the sample application and predefined configuration

Exercise:

  1. Execute mvn clean install on the root of the training repository
  2. Deploy the application and configuration to your local AEM instance via the script definition/packages-upload.sh
    • This Script uses the CONGA AEM Maven Plugin to deploy the generated AEM packages to your local AEM instance running at port 4502

Validation:

B) Deploy Groovy Console on Author

Exercise:

  1. There is a nice Open Source tool for AEM, the “AEM Groovy Console”: https://github.com/CID15/aem-groovy-console
  2. The AEM ZIP package for deploying it is also available on Maven Central: https://repo1.maven.org/maven2/org/cid15/aem/groovy/console/aem-groovy-console-all/17.0.0/
  3. Please extend the role wcm-io-samples-cms to include a deployment of this Groovy Console Package
  4. Make the deployment of this file conditional using a configuration parameter, similar as it is already done for the sample content in the same role
  5. Deploy the Groovy Console only for the author node of the local environment development.yaml
  6. Redeploy the application and configuration to your local AEM instance

Validation:

C) Restrict Access to Groovy Console to Administrators

Preparation - create two new users:

Exercise:

  1. If you look in http://localhost:4502/system/console/configMgr you will find a configuration “Groovy Console Configuration Service” which has a configuration parameter labeled with “Allowed Groups” - we want to set this to administrators to restrict the access to the Groovy console
  2. Enhance the role wcm-io-samples-cms to generate an additional OSGi configuration for this service that reconfigures this property to the desired value
  3. Redeploy the application and configuration to your local AEM instance

Validation:

def templates = [] as TreeSet
 
getPage("/content/wcm-io-samples/en").recurse { page ->
    def template = page?.template?.path
 
    if (template) {
        templates.add(template)
    }
}
 
templates.each {
    println it
}

D) Add additional logfile for JCR Query Debugging

Exercise:

  1. We want to debug JCR queries by setting DEBUG log level for these two log categories:
    • org.apache.jackrabbit.oak.query
    • org.apache.jackrabbit.oak.plugins.index
  2. In the role wcm-io-samples-cms you will find examples for defining additional loggers for the factory PID org.apache.sling.commons.log.LogManager.factory
  3. Create a new entry with the mentioned log categories, DEBUG log level, and a log file named logs/query.log
  4. Redeploy the application and configuration to your local AEM instance

Validation:

  • Ensure a query.log exists in the local AEM directory crx-quickstart/logs
  • Execute any query in AEM or CRXDE Lite an ensure new log entries are written in this log (please note that several AEM background services also execute queries form time to time, so you will see a log of other messages as well)

E) Make the languages displayed in AEM translator configurable

Exercise:

  1. AEM comes with a translator tool for managing i18n dictionaries: http://localhost:4502/libs/cq/i18n/translator.html
  2. By default it displays all languages. But as described here it is also possible to configure the list of languages displayed in the translator
  • This is possible by creating a node at /etc/languages, node type nt:unstructured, and set a property languages to list of language codes e.g. de,fr,es
  1. Generate an AEM package via CONGA automatically that creates this node and multivalued string property
  2. Add a new configuration parameter to the role wcm-io-samples-cms which contains a list of language codes. Set it to the default value “de”, “en” in the role.
  3. Generate a new AEM package from the role wcm-io-samples-cms based on a Handlebars JSON template. This JSON file defines the content of the langages node. Use Handlebars logic to fill in the language codes defined in the configuration parameter. Use the aem-contentpackage post processor to transform the generated JSON to an AEM package.
  4. You can have a look at the file wcm-io-samples-aem-cms-author-systemusers generated by the same role as example - it uses the same mechanisms but is more complex.
  5. Configure the list of languages for all nodes to “de”, “en”, “fr”, “it” in the environment development.yaml
  6. Redeploy the application and configuration to your local AEM instance

Validation:

F) Add ACLs for translator language configuration

Exercise:

  1. Currently, the updated list of languages in the Translator http://localhost:4502/libs/cq/i18n/translator.html is only visible for admin users - to fix this we need to add proper ACLs to the node to make it visible for other users as well
  2. In the JSON file describing the content of the node add a policy node like this (it applies read privilege to the build-in group content-authors):
    "rep:policy": {
      "jcr:primaryType": "rep:ACL",
      "allow": {
        "jcr:primaryType": "rep:GrantACE",
        "rep:principalName": "content-authors",
        "rep:privileges": [
          "jcr:read"
        ]
      }   
    }
  1. Within the role file you have also set the “Access Control Handling” to “merge” mode for this content package to get the ACL applied - look up the property name in the documentation: https://devops.wcm.io/conga/plugins/aem/extensions.html
  2. Redeploy the application and configuration to your local AEM instance

Validation:

Back to top

Version: 1. Last Published: 2025-01-13.