Accès à votre contenu grâce aux API de diffusion AEM access-your-content
Dans cette partie du Parcours de développement découplé AEM, vous pouvez apprendre à utiliser les requêtes GraphQL pour accéder au contenu de vos fragments de contenu et le transmettre à votre application (diffusion découplée).
Un peu d’histoire… story-so-far
Dans le document précédent du parcours découplé AEM, Comment modéliser votre contenu, vous avez appris les principes de base de la modélisation de contenu dans AEM. Vous devez donc maintenant comprendre comment modéliser votre structure de contenu, puis réaliser cette structure à l’aide des modèles de fragment de contenu et des fragments de contenu AEM :
- Reconnaître les concepts et la terminologie liés à la modélisation de contenu
- Comprendre pourquoi la modélisation de contenu est nécessaire pour la diffusion de contenu découplé
- Comprendre comment réaliser cette structure à l’aide des modèles de fragment de contenu AEM (et comment créer du contenu avec des fragments de contenu)
- Comprendre comment modéliser votre contenu, les principes comme les exemples de base
Cet article s’appuie sur ces principes de base afin que vous compreniez comment accéder à votre contenu découplé existant dans AEM en utilisant l’API AEM GraphQL.
-
Public : débutant
-
Objectif : apprendre comment accéder au contenu de vos fragments de contenu à l’aide des requêtes GraphQL d’AEM :
- Présentation de GraphQL et de l’API AEM GraphQL.
- Découvrir les détails de l’API AEM GraphQL.
- Regardez quelques exemples de requêtes pour voir comment les choses fonctionnent dans la pratique.
Vous souhaitez accéder à votre contenu ? so-youd-like-to-access-your-content
Vous disposez donc de tout ce contenu soigneusement structuré (dans les fragments de contenu) et qui n’attend plus que d’alimenter votre nouvelle application. La question est : comment faire ?
Vous avez besoin d’un moyen de cibler un contenu spécifique, de sélectionner ce dont vous avez besoin et de le renvoyer à votre application pour un traitement ultérieur.
Avec Adobe Experience Manager (AEM) as a Cloud Service, vous pouvez accéder de manière sélective à vos fragments de contenu, à l’aide de l’API AEM GraphQL, pour renvoyer uniquement le contenu dont vous avez besoin. Cela signifie que vous pouvez réaliser une diffusion découplée d’un contenu structuré pour l’utiliser dans vos applications.
GraphQL – Introduction graphql-introduction
GraphQL est une spécification open source qui fournit les éléments suivants :
- un langage de requête qui permet de sélectionner du contenu spécifique à partir d’objets structurés
- une exécution permettant de répondre à ces requêtes avec votre contenu structuré
GraphQL est une API pour laquelle le type est très important. Cela signifie que tout le contenu doit être clairement structuré et organisé par type, de sorte que GraphQL comprenne ce à quoi accéder et comment. Les champs de données sont définis dans les schémas GraphQL qui définissent ainsi la structure de vos objets de contenu.
Les points d’entrée GraphQL fournissent ensuite les chemins qui répondent aux requêtes GraphQL.
Cela signifie que votre application peut sélectionner précisément, de manière fiable et efficace le contenu dont elle a besoin, ce qui est exactement ce dont vous avez besoin lorsqu’elle est utilisée avec AEM.
API AEM GraphQL aem-graphql-api
L’API AEM GraphQL est une version personnalisée de la spécification standard de l’API GraphQL, spécialement configurée pour vous permettre d’exécuter des requêtes (complexes) sur vos fragments de contenu.
Les fragments de contenu sont utilisés, car le contenu est structuré selon des modèles de ce type de fragment. Elle répond ainsi à une des exigences de base de GraphQL.
- Un modèle de fragment de contenu est constitué d’un ou de plusieurs champs.
- Chaque champ est défini sur un type de données.
- Les modèles de fragment de contenu sont utilisés pour générer les schémas GraphQL AEM correspondants.
Pour vraiment accéder à GraphQL pour AEM (et à son contenu), un point d’entrée est utilisé pour fournir le chemin d’accès.
Le contenu renvoyé, à l’aide de l’API AEM GraphQL, peut ensuite être utilisé par vos applications.
Pour vous aider à saisir et à tester directement des requêtes, une implémentation de l’interface GraphQL standard est également disponible avec GraphQL AEM (qui peut être installée avec AEM). Elle vous offre des fonctionnalités telles que la mise en surbrillance de la syntaxe, la saisie semi-automatique et la suggestion automatique, ainsi qu’un historique et une documentation en ligne.
Fragments de contenu à utiliser avec l’API AEM GraphQL content-fragments-use-with-aem-graphql-api
Les fragments de contenu peuvent servir de base à GraphQL pour les schémas et requêtes AEM car :
- ils vous permettent de concevoir, créer, organiser et publier du contenu indépendant des pages, qui peut être diffusé en toute sécurité ;
- ils sont basés sur un modèle de fragment de contenu, qui prédéfinit la structure du fragment résultant à l’aide d’une sélection de types de données ;
- d’autres couches de structure peuvent être obtenues avec le type de données Référence de fragment, disponible lors de la définition d’un modèle.
Modèles de fragment de contenu content-fragments-models
Ces modèles de fragment de contenu :
- Sont utilisés pour générer les Schémas, une fois Activés.
- fournissent les types de données et les champs requis pour GraphQL ; garantissent que votre application ne demande que ce qui est possible et reçoive ce qui est attendu.
- Le type de données Références de fragments peut être utilisé dans votre modèle pour faire référence à un autre fragment de contenu et introduit ainsi des niveaux de structure supplémentaires.
Références à un fragment fragment-references
La référence à un fragment :
-
est un type de données spécifique disponible lors de la définition d’un modèle de fragment de contenu ;
-
fait référence à un autre fragment, en fonction d’un modèle de fragment de contenu spécifique ;
-
permet de créer, puis de récupérer, des données structurées.
- Lorsqu’elle est définie comme référence à sources multiples, plusieurs sous-fragments peuvent être référencés (récupérés) par le fragment principal.
Prévisualisation JSON json-preview
Pour faciliter la conception et le développement de vos modèles de fragments de contenu, vous pouvez prévisualiser la sortie JSON dans l’éditeur de fragments de contenu.
Utilisation concrète de l’API AEM GraphQL actually-using-aem-graphiql
Configuration initiale initial-setup
Avant de commencer à lancer des requêtes sur votre contenu, suivez les étapes suivantes :
-
Activez votre point d’entrée ;
- Utilisez Outils > Général > GraphQL.
- Activer votre point d’entrée GraphQL
- Cela permet également d’activer l’IDE GraphiQL.
Exemple de structure sample-structure
Pour utiliser l’API AEM GraphQL dans une requête, nous pouvons utiliser les deux structures de modèle de fragment de contenu très basiques :
-
Société
- Nom – Texte
- PDG (Personne) – Référence du fragment
- Employés (personnes) – Références du fragment
-
Personne
- Nom – Texte
- Prénom – Texte
Comme vous pouvez le voir, les champs PDG et Employés font référence aux fragments de personne.
Les modèles de fragment sont utilisés :
- lors de la création du contenu dans l’éditeur de fragment de contenu ;
- pour générer les schémas GraphQL que vous interrogerez.
Où tester vos requêtes where-to-test-your-queries
Les requêtes peuvent être saisies dans l’interface GraphiQL. Vous pouvez accéder à l’éditeur de requêtes à partir de :
- Outils -> Général -> Éditeur de requêtes GraphQL
- directement ; par exemple,
http://localhost:4502/aem/graphiql.html
Prise en main des requêtes getting-Started-with-queries
Une requête simple consiste à renvoyer le nom de toutes les entrées du schéma Société. Vous demandez ici une liste de tous les noms de sociétés :
query {
companyList {
items {
name
}
}
}
Une requête un peu plus complexe consiste à sélectionner toutes les personnes qui n’ont pas de nom « Tâches ». Toutes les personnes qui ne portent pas le nom Tâches seront ainsi filtrées. Ce filtrage est réalisé à l’aide de l’opérateur EQUALS_NOT (il en existe bien d’autres) :
query {
personList(filter: {
name: {
_expressions: [
{
value: "Jobs"
_operator: EQUALS_NOT
}
]
}
}) {
items {
name
firstName
}
}
}
Vous pouvez également créer des requêtes plus complexes. Par exemple, faites une requête pour toutes les sociétés qui ont au moins un employé nommé « Smith ». Cette requête illustre le filtrage pour toute personne portant le nom « Smith », qui renvoie des informations provenant des fragments imbriqués :
query {
companyList(filter: {
employees: {
_match: {
name: {
_expressions: [
{
value: "Smith"
}
]
}
}
}
}) {
items {
name
ceo {
name
firstName
}
employees {
name
firstName
}
}
}
}
Pour obtenir des détails complets sur l’utilisation de l’API AEM GraphQL, ainsi que la configuration des éléments nécessaires, vous pouvez vous référer aux sections suivantes :
- Apprendre à utiliser GraphQL avec AEM ;
- L’exemple de structure de fragment de contenu ;
- Apprendre à utiliser GraphQL avec AEM – Exemple de contenu et de requêtes
Et après ? whats-next
Maintenant que vous avez appris à accéder à votre contenu en mode découplé et à y effectuer des requêtes à l’aide de l’API AEM GraphQL, vous pouvez apprendre à utiliser l’API REST pour accéder au contenu de vos fragments de contenu et le mettre à jour.
Ressources supplémentaires additional-resources
-
Apprendre à utiliser GraphQL avec AEM – Exemple de contenu et de requêtes
-
Activation de la fonctionnalité de fragments de contenu dans l’explorateur de configurations
-
Requêtes persistantes GraphQL – Activation de la mise en cache dans Dispatcher
-
Prise en main d’AEM découplé – Une courte série de tutoriels vidéo qui donne un aperçu de l’utilisation des fonctionnalités d’AEM découplé, notamment la modélisation de contenu et GraphQL.