Les configurations AEM permettent de gérer les paramètres dans AEM et servent d’espaces de travail.
Une configuration peut être considérée sous deux angles différents.
En résumé, du point de vue d’un administrateur, les configurations sont la manière dont vous créez des espaces de travail pour gérer les paramètres dans AEM, tandis que le développeur doit comprendre comment AEM utilise et gère ces configurations dans le référentiel.
Quelle que soit votre perspective, les configurations répondent à deux objectifs principaux dans AEM :
L’administrateur AEM ainsi que les auteurs peuvent considérer les configurations comme des espaces de travail. Ces espaces de travail peuvent être utilisés pour rassembler des groupes de paramètres ainsi que leur contenu associé à des fins d’organisation en implémentant des droits d’accès pour ces fonctionnalités.
Des configurations peuvent être créées pour de nombreuses fonctionnalités différentes dans AEM.
Par exemple, un administrateur peut créer deux configurations pour les modèles modifiables.
L’administrateur peut alors créer des modèles de page généraux à l’aide de la configuration WKND-General, puis des modèles spécifiques au magazine sous WKND-Magazine.
L’administrateur peut alors associer le WKND-General à tout le contenu du site WKND. Cependant, la configuration WKND-Magazine ne serait associée qu’au site du magazine.
En procédant comme suit :
Des configurations similaires sont possibles non seulement pour les modèles modifiables, mais également pour les configurations de cloud, les segments ContextHub et les modèles de fragments de contenu.
L’explorateur de configurations permet à un administrateur de créer, gérer et configurer facilement des droits d’accès aux configurations dans AEM.
Il n’est possible de créer des configurations à l’aide de l’explorateur de configurations que si votre utilisateur dispose des droits admin
. Les droits admin
sont également requis pour attribuer des droits d’accès à la configuration ou pour apporter une autre modification à une configuration.
Il est très simple de créer une nouvelle configuration dans AEM à l’aide de l’explorateur de configurations.
Connectez-vous à AEM as a Cloud Service et dans le menu principal, sélectionnez Outils -> Général -> Explorateur de configurations.
Appuyez ou cliquez sur Créer.
Indiquez un Titre et un Nom pour votre configuration.
Vérifiez le type de configuration que vous souhaitez autoriser.
Appuyez ou cliquez sur Créer.
Les configurations peuvent être imbriquées.
Si vous considérez les configurations comme des espaces de travail, les droits d’accès peuvent être définis sur ces configurations afin de définir qui peut ou non accéder à ces espaces de travail.
Il n’est pas possible de désélectionner une fonction une fois la configuration créée.
En tant que développeur, il est important de savoir comment AEM as a Cloud Service fonctionne avec les configurations et traite la résolution de configurations.
Bien que l’administrateur et les utilisateurs puissent considérer les configurations comme des espaces de travail pour gérer différents paramètres et contenus, il est important de comprendre que les configurations et le contenu sont stockés et gérés séparément par AEM dans le référentiel.
/content
abrite tout le contenu./conf
abrite l’ensemble de la configuration.Le contenu fait référence à sa configuration associée par le biais d’une propriété cq:conf
. AEM effectue une recherche en fonction du contenu et de sa propriété contextuelle cq:conf
pour trouver la configuration appropriée.
Dans cet exemple, supposons que vous ayez du code d’application concernant les paramètres de la gestion des actifs numériques.
Conf conf = resource.adaptTo(Conf.class);
ValueMap imageServerSettings = conf.getItem("dam/imageserver");
String bgkcolor = imageServerSettings.get("bgkcolor", "FFFFFF");
Le point de départ de toute recherche de configuration est une ressource de contenu, généralement située sous /content
. Il peut s’agir d’une page, d’un composant au sein d’une page, d’une ressource ou d’un dossier de la gestion des actifs numériques. Le contenu réel pour lequel nous recherchons la configuration appropriée s’applique dans ce contexte.
Maintenant, avec l’objet Conf
, nous pouvons récupérer l’élément de configuration spécifique qui nous intéresse. Dans ce cas, il s’agit de dam/imageserver
, qui est un ensemble de paramètres associés à imageserver
. L’appel getItem
renvoie une ValueMap
. Nous lisons ensuite une propriété de chaîne bgkcolor
et fournissons une valeur par défaut de « FFFFFF » au cas où la propriété (ou l’élément de configuration complet) ne serait pas présent.
Examinons maintenant le contenu JCR correspondant :
/content/dam/wknd
+ jcr:content
- cq:conf = "/conf/wknd"
+ image.png [dam:Asset]
/conf/wknd
+ settings
+ dam
+ imageserver [cq:Page]
+ jcr:content
- bgkcolor = "FF0000"
Dans cet exemple, nous supposons un dossier de la gestion des actifs numériques spécifique à WKND et une configuration correspondante. À partir de ce dossier /content/dam/wknd
, nous verrons qu’il existe une propriété de chaîne nommée cq:conf
qui fait référence à la configuration qui doit s’appliquer à la sous-arborescence. La propriété est généralement définie sur le jcr:content
d’une page ou d’un dossier de ressources. Ces liens conf
sont explicites. Il est donc facile de les suivre en regardant simplement le contenu dans CRXDE.
En passant dans /conf
, nous suivons la référence et voyons qu’il y a un nœud /conf/wknd
. Il s’agit d’une configuration. Sa recherche est totalement transparente par rapport au code d’application. L’exemple de code n’a jamais de référence dédiée. Il est masqué derrière l’objet Conf
. La configuration qui s’applique est entièrement contrôlée par le contenu JCR.
Nous voyons que la configuration contient un nœud settings
de nom fixe qui contient les éléments réels, y compris dam/imageserver
dont nous avons besoin dans notre cas. Un tel élément peut être considéré comme un « document de paramètres » et est généralement représenté par une cq:Page
avec un jcr:content
contenant le contenu réel.
Nous voyons ensuite la propriété bgkcolor
dont notre exemple de code a besoin. La ValueMap
que nous récupérons dans getItem
repose sur le nœud jcr:content
de la page.
L’exemple de base ci-dessus montrait une configuration unique. Mais dans de nombreux cas, on a besoin de différentes configurations, comme une configuration globale par défaut, une configuration différente pour chaque marque et peut-être une configuration spécifique pour les sous-projets.
Pour ce faire, la recherche de configuration dans AEM dispose d’un mécanisme d’héritage et de repli dans l’ordre de préférence suivant :
/conf/<siteconfig>/<parentconfig>/<myconfig>
cq:conf
quelque part dans /content
/conf/<siteconfig>/<parentconfig>
/conf/<siteconfig>
/conf/global
admin
/apps
/libs
Les configurations dans AEM reposent sur les configurations basées sur le contexte Sling. Les lots Sling fournissent une API de service qui peut être utilisée pour obtenir des configurations basées sur le contexte. Les configurations basées sur le contexte sont des configurations qui sont liées à une ressource de contenu ou à une arborescence de ressources, comme décrit dans l’exemple précédent.
Pour plus d’informations sur les configurations basées sur le contexte, des exemples et leur utilisation, consultez la documentation Sling.
À des fins de débogage et de test, une console Web ConfMgr dans https://<host>:<port>/system/console/conf
peut afficher des configurations pour un chemin/élément donné.
Indiquez simplement :
Cliquez sur Resolve (Résoudre) pour voir quelles configurations sont résolues et recevoir un exemple de code qui résoudra ces configurations.
À des fins de débogage et de test, une console Web de configuration basée sur le contexte dans https://<host>:<port>/system/console/slingcaconfig
permet d’interroger des configurations basées sur le contexte dans le référentiel et d’afficher leurs propriétés.
Indiquez simplement :
Cliquez sur Resolve (Résoudre) pour récupérer les chemins d’accès au contexte et propriétés associés pour la configuration sélectionnée.