Connexion aux réseaux sociaux avec Facebook et Twitter social-login-with-facebook-and-twitter
La connexion à Social permet de proposer à un visiteur du site l’option de connexion à l’aide de son compte Facebook ou Twitter. Par conséquent, inclure les données Facebook ou Twitter autorisées dans leur profil de membre AEM.
Présentation de la connexion aux réseaux sociaux social-login-overview
Pour inclure la connexion sociale, il est obligatoire de créer des applications Facebook et de Twitter personnalisées.
Bien que l’exemple we-retail fournisse des exemples d’applications Facebook et de Twitter et de services cloud, ils ne sont pas disponibles sur un site web de production.
Les étapes requises sont les suivantes :
-
Activez l’authentification OAuth sur toutes les instances de publication AEM.
Si OAuth n’est pas activé, les tentatives de connexion échouent.
-
Créez une application sociale et un service cloud.
-
Pour prendre en charge la connexion avec Facebook :
- Créez une application Facebook.
- Créez et publiez un service cloud Facebook Connect.
-
Pour prendre en charge la connexion avec le Twitter :
- Créez une application de Twitter.
- Créez et publiez un service cloud Twitter Connect.
-
-
Activez la connexion sociale pour un site communautaire.
Il existe deux concepts de base :
-
Portée (autorisations) spécifie les données que l’application est autorisée à demander.
- Par défaut, les instances Facebook et Twitter Adobe de l’application OAuth Granite et Provider incluent les autorisations de base de l’application dans leur portée.
-
Fields (params) spécifie les données réelles demandées à l’aide des paramètres d’URL.
- Ces champs sont spécifiés dans les Fournisseur OAuth AEM Communities Facebook et Fournisseur OAuth du Twitter AEM Communities.
- Les champs par défaut sont suffisants pour la plupart des cas d’utilisation, mais peuvent être modifiés.
Connexion à facebook facebook-login
Version de l’API facebook facebook-api-version
La connexion sociale et l’exemple de Facebook we-retail ont été développés lorsque l’API Facebook Graph était la version 1.0.
Depuis AEM version 6.4 GA et AEM 6.3 SP1, la connexion sociale a été mise à jour pour fonctionner avec la nouvelle version de l’API Facebook Graph 2.5.
Pour plus d’informations sur la version de l’API Facebook Graph, voir le changelog d’API Facebook.
Création d’une application Facebook create-a-facebook-app
Une application Facebook correctement configurée est requise pour activer la connexion sociale Facebook.
Pour créer une application Facebook, suivez les instructions Facebook à l’adresse https://developers.facebook.com/apps/. Les modifications apportées à leurs instructions ne sont pas répercutées dans les informations suivantes.
En règle générale, à partir de l’API Facebook v2.7 :
-
Ajout d’une nouvelle application Facebook
-
Pour Platform, choisissez Site Web :
- Pour URL du site, saisissez
https://<server>:<port>.
- Pour Nom d’affichage, saisissez un titre à utiliser comme titre du service de connexion Facebook.
- Pour Category, il est recommandé de choisir Apps for Pages, mais cela peut être n’importe quoi.
- Ajouter un produit : connexion Facebook
- Pour URI de redirection OAuth valides, saisissez
https://<server>:<port>.
- Pour URL du site, saisissez
-
Une fois l’application créée, localisez les paramètres ID d’application et Secret d’application . Ces informations sont requises pour la configuration du service cloud Facebook.
Création d’un Cloud Service Facebook Connect create-a-facebook-connect-cloud-service
L’instance Adobe de l’application OAuth et du fournisseur Granite, instanciée par la création d’une configuration de service cloud, identifie l’application Facebook et le ou les groupes de membres auxquels les nouveaux utilisateurs sont ajoutés.
-
Sur l’instance d’auteur AEM, connectez-vous avec les droits d’administrateur.
-
Dans la navigation globale, sélectionnez Outils > Cloud Service > Configuration de connexion à Facebook Social.
-
Sélectionnez la configuration context path.
Chemin d’accès au contexte doit être identique au chemin de configuration du cloud que vous avez sélectionné lors de la création/modification d’un site de communauté.
-
Vérifiez si votre chemin d’accès au contexte est activé pour créer des services cloud en-dessous.
-
Accédez à Outils > Général > Navigateur de configuration. Sélectionnez votre contexte et modifiez les propriétés. Activez les configurations cloud si elles ne sont pas encore activées.
- Pour plus d’informations, consultez la documentation relative à l’Explorateur de configurations.
-
Créer/Modifier Configuration du service cloud Facebook.
- Titre (Obligatoire) Saisissez un titre d’affichage qui identifie l’application Facebook. Utilisez le même nom que le nom d’affichage de l’application Facebook.
- ID d’application/clé API (Obligatoire) Saisissez l’ ID d’application pour l’application Facebook. Cela identifie l’instance Adobe de l’application OAuth et du fournisseur OAuth créée à partir de la boîte de dialogue.
- Secret de l’application (Obligatoire) Saisissez le Secret de l’application pour l’application Facebook.
- Créer des utilisateurs Si cette option est cochée, la connexion à l’aide d’un compte Facebook crée une entrée d’utilisateur AEM et l’ajoute en tant que membre au ou aux groupes d’utilisateurs sélectionnés. La valeur par défaut est cochée (vivement recommandé).
- Masquer les ID utilisateur : laissez cette option désélectionnée.
- Domaine E-mail : l’ID de courrier électronique de l’utilisateur doit être récupéré depuis Facebook.
- Ajouter aux groupes d’utilisateurs sélectionnez Ajouter un groupe d’utilisateurs pour choisir un ou plusieurs groupes de membres pour le site de communauté auquel les utilisateurs seront ajoutés.
note note NOTE Les groupes peuvent être ajoutés ou supprimés à tout moment. Mais les appartenances des utilisateurs existants ne sont pas affectées. L’adhésion automatique s’applique uniquement aux nouveaux utilisateurs créés après la mise à jour de ce champ. Pour les sites où les utilisateurs anonymes sont désactivés, choisissez d’ajouter des utilisateurs au groupe de membres de communauté correspondant destiné à ce site de communauté fermé. - Sélectionnez SAVE.
- Publish.
Le résultat est une instance Adobe Granite OAuth Application et Provider qui ne nécessite pas de modification supplémentaire, sauf si vous ajoutez une portée supplémentaire (autorisations). La portée par défaut est les autorisations standard pour la connexion à Facebook. Si une portée supplémentaire est souhaitée, il est nécessaire de modifier directement la configuration OSGI. Si des modifications sont effectuées directement via le système/la console, évitez de modifier vos configurations de service cloud à partir de l’interface utilisateur tactile afin d’éviter tout écrasement.
Fournisseur OAuth Facebook AEM Communities aem-communities-facebook-oauth-provider
Le fournisseur AEM Communities étend l’instance Adobe Granite OAuth Application et Provider.
Ce fournisseur devra être modifié pour :
-
Autoriser les mises à jour des utilisateurs
-
Ajouter des champs supplémentaires dans scope
- Tous les champs autorisés par défaut ne sont pas inclus par défaut.
Si des modifications sont nécessaires, sur chaque instance de publication AEM :
-
Connectez-vous avec les privilèges d’administrateur.
-
Accédez à la console web. Par exemple, http://localhost:4503/system/console/configMgr.
-
Recherchez le fournisseur OAuth Facebook AEM Communities.
-
Sélectionnez l’icône en forme de crayon à ouvrir pour modification.
-
Identifiant du fournisseur OAuth
(Obligatoire) La valeur par défaut est soco-facebook. Ne modifiez pas.
-
Configuration du Cloud Service
La valeur par défaut est
/etc/ cloudservices / facebookconnect
. Ne modifiez pas. -
Configuration du service de fournisseur OAuth
La valeur par défaut est
/apps/social/facebookprovider/config/
. Ne modifiez pas. -
Activer les balises
Ne modifiez pas.
-
Chemin d’accès utilisateur
Emplacement dans le référentiel où les données utilisateur sont stockées. Pour un site de communauté, afin que les membres puissent afficher leur profil, le chemin doit être le chemin par défaut /home/users/community.
-
Activer les champs
Si cette case est cochée, les champs répertoriés sont spécifiés dans la demande à Facebook pour l’authentification et les informations de l’utilisateur. La valeur par défaut est désélectionnée.
-
Champs
Lorsque les champs sont activés, les champs suivants sont inclus lors de l’appel de l’API Facebook Graph. Les champs doivent être autorisés dans la portée définie dans la configuration du service cloud. Les champs supplémentaires peuvent nécessiter l’approbation de Facebook. Reportez-vous à la section Autorisations de connexion Facebook de la documentation Facebook. Les champs par défaut ajoutés en tant que paramètres sont les suivants :
- id
- name
- first_name
- last_name
- Lien
- paramètres régionaux
- picture
- timezone
- updated_time
- vérifié
Si un champ est ajouté ou modifié, mettez à jour la configuration du gestionnaire de synchronisation par défaut correspondant pour corriger le mappage.
-
Mettre à jour l’utilisateur
Si cette case est cochée, actualise les données utilisateur dans le référentiel à chaque connexion afin de refléter les modifications de profil ou les données supplémentaires demandées. La valeur par défaut est désélectionnée.
-
Étapes suivantes next-steps
Les étapes suivantes sont les mêmes pour Facebook et pour Twitter :
Connexion au twitter twitter-login
Création d’une application de Twitter create-a-twitter-app
Une application de Twitter configurée est requise pour activer la connexion sociale par Twitter.
Suivez les dernières instructions pour créer une application de Twitter à l’adresse https://apps.twitter.com.
En général :
-
Saisissez un nom qui identifiera votre application de Twitter aux utilisateurs de votre site web.
-
Saisissez une Description.
-
Pour website - saisissez
https://<server>
. -
Pour Callback URL - saisissez
https://server
.note note NOTE Il n’est pas nécessaire de spécifier le port. Pour le développement, https://127.0.0.1/ fonctionne. -
Une fois l’application créée, localisez la clé du consommateur (API) et le secret du consommateur (API). Ces informations seront nécessaires pour la configuration du service cloud de Twitter.
Autorisations permissions
Dans la section Autorisations de la gestion des applications de Twitter :
-
Accès : sélectionnez
Read only
.- Les autres options ne sont pas prises en charge
-
Autorisations supplémentaires : Si vous le souhaitez, sélectionnez
Request email addresses from users
.- Si cette option n’est pas sélectionnée, le profil utilisateur dans AEM n’inclut pas son adresse électronique.
- Les instructions du twitter indiquent les autres étapes à suivre.
La seule requête REST effectuée pour la connexion sociale est de GET account/verify credentials.
Création d’un Cloud Service Twitter Connect create-a-twitter-connect-cloud-service
L’instance Adobe de l’application OAuth et du fournisseur OAuth, instanciée par la création d’une configuration de service cloud, identifie l’application de Twitter et le ou les groupes de membres auxquels les nouveaux utilisateurs sont ajoutés.
-
Sur l’instance d’auteur, connectez-vous avec les privilèges d’administrateur.
-
Dans la navigation globale, sélectionnez Outils > Cloud Service > Configuration de connexion à Twitter Social.
-
Sélectionnez la configuration context path .
Le chemin d’accès au contexte doit être identique au chemin de configuration du cloud que vous avez sélectionné lors de la création/modification d’un site de communauté.
-
Vérifiez si votre chemin d’accès au contexte est activé pour créer des services cloud en-dessous.
-
Accédez à Outils > Général > Navigateur de configuration. Sélectionnez votre contexte et modifiez les propriétés. Activez les configurations cloud si elles ne sont pas encore activées.
- Pour plus d’informations, consultez la documentation relative à l’Explorateur de configurations.
-
Créez/modifiez la configuration du service cloud de Twitter.
-
Titre
(Obligatoire) Saisissez un titre d’affichage qui identifie l’application de Twitter. Utilisez le même nom que le Nom d’affichage de l’application de Twitter.
-
Clé client
(Obligatoire) Saisissez la Clé de consommateur (API) pour l’application de Twitter. Cela identifie l’instance Adobe de l’application OAuth et du fournisseur OAuth créée à partir de la boîte de dialogue.
-
Secret du client
(Obligatoire) Saisissez le secret Consumer(API) pour l’application de Twitter.
-
Créer des utilisateurs
Si cette case est cochée, la connexion à l’aide d’un compte de Twitter crée une entrée d’utilisateur AEM et l’ajoute en tant que membre au ou aux groupes d’utilisateurs sélectionnés. La valeur par défaut est cochée (vivement recommandé).
-
Masquer les identifiants utilisateur
Laissez-le désélectionné.
-
Ajouter aux groupes d’utilisateurs
Sélectionnez Ajouter un groupe d’utilisateurs pour choisir un ou plusieurs groupes de membres pour le site de communauté auquel les utilisateurs seront ajoutés.
note note NOTE Les groupes peuvent être ajoutés ou supprimés à tout moment. Mais les appartenances des utilisateurs existants ne sont pas affectées. L’adhésion automatique s’applique uniquement aux nouveaux utilisateurs créés après la mise à jour de ce champ. Pour les sites où les utilisateurs anonymes sont désactivés, ajoutez des utilisateurs au groupe de membres de communauté correspondant destiné à ce site de communauté fermé. -
-
Sélectionnez SAVE et Publish.
Le résultat est une instance Adobe Granite OAuth Application et Provider qui ne nécessite pas de modification supplémentaire. La portée par défaut est les autorisations standard pour la connexion par Twitter.
Fournisseur OAuth du Twitter AEM Communities aem-communities-twitter-oauth-provider
La configuration AEM Communities étend l’instance Adobe Granite OAuth Application et Provider. Ce fournisseur devra être modifié pour autoriser les mises à jour des utilisateurs.
Si des modifications sont nécessaires, sur chaque instance de publication AEM :
-
Connectez-vous avec les privilèges d’administrateur.
-
Accédez à la console web.
Par exemple, http://localhost:4503/system/console/configMgr.
-
Recherchez le fournisseur OAuth du Twitter AEM Communities.
-
Sélectionnez l’icône en forme de crayon à ouvrir pour modification.
- Identifiant du fournisseur OAuth
(Obligatoire) La valeur par défaut est soco-twitter. Ne modifiez pas.
-
Configuration du Cloud Service
La valeur par défaut est conf. Ne modifiez pas.
-
Configuration du service de fournisseur OAuth
La valeur par défaut est
/apps/social/twitterprovider/config/
. Ne modifiez pas. -
Chemin d’accès utilisateur
Emplacement dans le référentiel où les données utilisateur sont stockées. Pour un site de communauté, afin que les membres puissent afficher leur profil, le chemin d’accès doit être le
/home/users/community
par défaut. -
Activer les paramètres - Ne pas modifier
-
Paramètres d’URL - Ne pas modifier
-
Mettre à jour l’utilisateur
Si cette case est cochée, actualise les données utilisateur dans le référentiel à chaque connexion afin de refléter les modifications de profil ou les données supplémentaires demandées. La valeur par défaut est désélectionnée.
Étapes suivantes next-steps-1
Les étapes suivantes sont les mêmes pour Facebook et pour Twitter :
Activation de la connexion aux réseaux sociaux enable-social-login
Console AEM Communities Sites aem-communities-sites-console
Une fois qu’un service cloud est configuré, il peut être activé pour le paramètre Social Login approprié pour un site de la communauté à l’aide du sous-panneau User Management Settings lors de la création ou de la gestion du site de la communauté.
-
Sélectionnez le contexte de configuration de votre site dans lequel vous avez enregistré vos configurations de connexion sociale.
-
Dans l’onglet Général , définissez les configurations cloud.
-
Sur l’onglet Paramètres , activez Connexions aux réseaux sociaux et enregistrez.
Test de la connexion aux réseaux sociaux test-social-login
- Vérifiez que le gestionnaire d’authentification OAuth d’Adobe Granite a été activé sur toutes les instances de publication.
- Assurez-vous que les services cloud ont été publiés.
- Vérifiez que le site de la communauté a été publié.
- Lancez le site publié dans un navigateur.
Par exemple, http://localhost:4503/content/sites/engage/en.html - Sélectionnez Connexion à.
- Sélectionnez Se connecter avec Facebook ou Se connecter avec le Twitter.
- Si vous n’êtes pas encore connecté à Facebook ou Twitter, connectez-vous avec les informations d’identification appropriées.
- Il peut être nécessaire d’accorder une autorisation en fonction de la boîte de dialogue affichée par l’application Facebook ou Twitter.
- Notez que la barre d’outils située en haut de la page est mise à jour pour refléter la connexion réussie.
- Sélectionnez Profil : la page Profil affiche l’avatar, le prénom et le nom de l’utilisateur. Il affiche également les informations du profil Facebook ou Twitter en fonction des champs/paramètres autorisés.
AEM des configurations OAuth de Platform aem-platform-oauth-configurations
Adobe du gestionnaire d’authentification OAuth Granite adobe-granite-oauth-authentication-handler
Adobe Granite OAuth Authentication Handler
n'est pas activé par défaut et doit être activé sur toutes les instances de publication AEM.
Pour activer le gestionnaire d’authentification lors de la publication, ouvrez simplement la configuration OSGi et enregistrez-la :
- Connectez-vous avec les privilèges d’administrateur.
- Accédez à la console web.
Par exemple, http://localhost:4503/system/console/configMgr - Recherchez
Adobe Granite OAuth Authentication Handler
. - Sélectionnez cette option pour ouvrir la configuration à modifier.
- Sélectionnez Enregistrer.
Adobe Application et fournisseur OAuth Granite adobe-granite-oauth-application-and-provider
Lorsqu’un service cloud pour Facebook ou Twitter est créé, une instance de Adobe Granite OAuth Authentication Handler
est créée.
Pour localiser l’instance créée pour une application Facebook ou Twitter :
-
Connectez-vous avec les privilèges d’administrateur.
-
Accédez à la console web.
Par exemple, http://localhost:4503/system/console/configMgr.
-
Localisez l’application et le fournisseur OAuth Adobe Granite.
-
Recherchez l’instance où ID client correspond à l’ ID application.
A l’exception des propriétés suivantes, conservez les autres propriétés de la configuration inchangées :
-
ID de configuration
(Obligatoire) Les identifiants de configuration OAuth doivent être uniques. Généré automatiquement lors de la création du service cloud.
-
ID client
(Obligatoire) ID d’application fourni lors de la création du service cloud.
-
Secret client
(Obligatoire) Le secret d’application fourni lors de la création du service cloud.
-
Portée
(Facultatif) Une plage supplémentaire pour ce qui est autorisé peut être demandée par le fournisseur. La portée par défaut couvre les autorisations nécessaires pour fournir l’authentification sociale et les données de profil.
-
Identifiant du fournisseur
(Obligatoire) L’ID de fournisseur pour AEM Communities est défini lors de la création du service cloud. Ne modifiez pas. Pour Facebook Connect, la valeur est soco-facebook. Pour Twitter Connect, la valeur est soco-twitter.
-
Groupes
(Recommandé) Un ou plusieurs groupes de membres auxquels des utilisateurs créés sont ajoutés. Pour AEM Communities, il est recommandé de répertorier le groupe de membres pour le site de la communauté.
-
URL de rappel
(Facultatif) URL configurée avec les fournisseurs OAuth pour rediriger le client. Utilisez une URL relative pour utiliser l’hôte de la requête d’origine. Laissez vide pour utiliser l’URL demandée d’origine à la place. Le suffixe "/callback/j_security_check" est automatiquement ajouté à cette URL .
note note NOTE Le domaine du rappel doit être enregistré auprès du fournisseur (Facebook ou Twitter). -
Pour chaque configuration du gestionnaire d’authentification OAuth, deux configurations supplémentaires sont créées dans l’instance :
- Gestionnaire de synchronisation par défaut d’Apache Jackrabbit Oak (org.apache.jackrabbit.oak.spi.security.authentication.external.impl.DefaultSyncHandler) - Aucune modification n’est requise, mais vous pouvez examiner la façon dont les champs Facebook sont mappés à un noeud de profil utilisateur CQ. Notez également que "Nom du gestionnaire de synchronisation" correspond à l’ID de configuration de la configuration du fournisseur OAuth.
- Module de connexion externe Apache Jackrabbit Oak (org.apache.jackrabbit.oak.spi.security.authentication.external.impl.ExternalLoginModuleFactory) - Aucune modification n’est requise à cet endroit, mais vous pouvez remarquer que "Nom du fournisseur d’identité" et "Nom du gestionnaire de synchronisation" sont identiques et pointent respectivement vers les configurations OAuth et du gestionnaire de synchronisation correspondantes.
Pour plus d’informations, voir Authentification avec module de connexion externe Apache Oak.
Performances de conversion des utilisateurs OAuth oauth-user-traversal-performance
Pour les sites de la communauté qui voient des centaines de milliers d’utilisateurs s’enregistrer à l’aide de leur connexion Facebook ou Twitter, les performances transversales de la requête effectuée lorsqu’un visiteur du site utilise sa connexion sociale peuvent être améliorées en ajoutant l’index Oak suivant.
Si des avertissements transversaux s’affichent dans les journaux, il est recommandé d’ajouter cet index.
Sur une instance d’auteur, connectez-vous avec les privilèges d’administrateur :
-
Dans la navigation globale : sélectionnez Outils, CRX/DE Lite.
-
Créez un index nommé ntBaseLucene-oauth à partir d’une copie de ntBaseLucene :
- Sous le noeud
/oak:index
- Sélectionner le noeud
ntBaseLucene
- Sélectionnez Copy
- Sélectionnez
/oak:index
. - Sélectionnez Paste
- Renommez Copie de ntBaseLucene en
ntBaseLucene-oauth
.
- Sous le noeud
-
Modifiez les propriétés du noeud ntBaseLucene-oauth :
- indexPath :
/oak:index/ntBaseLucene-oauth
- name:
oauthid-123​**​**
- reindex :
true
- reindexCount :
1
- indexPath :
-
Sous le noeud /oak:index/ntBaseLucene-oauth/indexRules/nt:base/properties :
-
Supprimez tous les noeuds enfants, à l’exception de cqTags.
-
Renommez cqTags en
oauthid-123**​**
. -
Modification des propriétés du noeud
oauthid-123**​**
- name:
oauthid-123​**​**
- name:
-
Sélectionnez Enregistrer tout.
-
-
Pour le nom
oauthid-123
, remplacez 123 par l’ ID d’application de Facebook ou par la clé de consommateur (API) de Twitter qui est la valeur de l’ ID de client dans la configuration Adobe de l’application OAuth et du fournisseur.
Pour plus d’informations et d’outils, voir Requêtes et indexation Oak.
Configuration du Dispatcher dispatcher-configuration
Voir Configuration de Dispatcher pour les communautés.