auth0/wordpress. Cette mesure de sécurité aide à atténuer les attaques CSRF en veillant à ce que la réponse corresponde à une requête lancée par le même utilisateur. Pour en savoir plus, consultez Prevent Attacks and Redirect Users with OAuth 2.0 State Parameter.
Comment fonctionne la validation du paramètre state
- Elle définit un cookie
auth0_statedans le navigateur au moyen de JavaScript lorsque le formulaire de connexion Lock est affiché (surwp-login.phpou sur toute autre page lors de l’utilisation d’un shortcode ou d’un widget). - Elle transmet cette valeur au formulaire de connexion intégré de Lock afin qu’elle soit envoyée avec la requête d’authentification.
- Elle reçoit cette valeur en retour d’Auth0, inchangée, dans un paramètre d’URL
statesi la connexion avec Auth0 a réussi. - Elle vérifie que la valeur reçue correspond à la valeur envoyée et stockée dans le cookie
auth0_state. Si c’est le cas, le processus de connexion se poursuit. Sinon, le processus s’arrête et le message d’erreur « Invalid state » s’affiche. - Elle supprime le cookie, qu’il soit valide ou non.
- Elle utilise les valeurs de l’objet décodé en Base64 pour rediriger l’utilisateur ou effectuer d’autres actions de connexion, si elles sont valides.
Causes courantes de l’erreur « invalid state »
URLs de rappel mises en cache
/index.php dans une installation standard) si elle contient un paramètre d’URL Auth0.
Vérifiez également que l’heure de votre serveur est correctement réglée. L’erreur BeforeValidException peut se produire lorsque le jeton est considéré comme ayant été généré avant l’heure actuelle, ce qui peut arriver si l’heure du serveur est incorrecte. Vous pouvez vérifier l’heure du serveur à l’aide de echo current_time( 'c' ). Comme solution de contournement temporaire, vous pouvez aussi modifier l’extension pour ajouter un décalage horaire si vous ne pouvez pas changer l’heure du serveur, mais le problème devrait être corrigé avant la mise en production.
Si cela ne règle pas le problème, poursuivez avec les étapes de dépannage ci-dessous.
Si vous utilisez un hébergeur géré comme WP-Engine, vous devrez peut-être communiquer avec son équipe d’assistance pour obtenir de l’aide supplémentaire. Des problèmes nous ont été signalés concernant l’accès aux cookies requis sur l’URL de rappel, ainsi que lors de la vérification de l’authentification sur la page finale affichée aux utilisateurs après leur connexion. Plus précisément, demandez l’ajout d’exclusions de cache pour :
- Cookie :
auth0_state - Cookie :
auth0_nonce - Paramètre d’URL/argument :
auth0 - Paramètre d’URL/argument :
code - Paramètre d’URL/argument :
state - Paramètre d’URL/argument :
id_token
Rafraîchissement de la page après un message d’erreur
auth0_state_cookie_name dans votre thème ou une extension personnalisée. Pour en savoir plus sur le filtre auth0_state_cookie_name, consultez Étendre l’extension WordPress Login by Auth0. Pour plus d’informations, consultez le ticket GitHub correspondant et examinez le correctif.
Page Universal Login et création du lien
- Définir un cookie nommé
auth0_stateavec une valeur générée aléatoirement - Transmettre cette valeur dans un paramètre d’URL
state.
wp-login.php, où ce cookie et ce paramètre d’URL seront définis automatiquement.
Accès direct à l’URL de rappel
yourdomain.com/index.php?auth0=1) ou si vous y accédez une deuxième fois après l’échange du code d’autorisation, l’erreur « state invalide » peut s’afficher. Cela indique que le state a déjà été vérifié, puis supprimé.
Dépanner les erreurs de state invalide
- En étant déconnecté de WordPress et d’Auth0, accédez à la page de connexion en cours de test.
-
Vérifiez si le cookie
auth0_stateest défini (dans Chrome, View > Developer > JavaScript Console > onglet Application > Storage à gauche > Cookies > domaine en cours de test; recherchez un cookieauth0_statedont la valeur n’est pas vide).- Si cette valeur n’est pas définie, vérifiez s’il y a des erreurs dans la console JS et assurez-vous que votre navigateur accepte les cookies (la connexion ne fonctionnera pas sans cookies).
- Si la valeur est définie, copiez-la et affichez le code source de la page (dans Chrome, View > Developer > View Source). Recherchez cette valeur; elle devrait apparaître comme valeur associée au paramètre
wpAuth0LockGlobal.settings.auth.params.state(voir un exemple de JSON). Prenez cette valeur en note (vous en aurez besoin à une étape suivante).
- Si la valeur y apparaît et que le formulaire Lock se charge normalement, cela signifie que les étapes 1 et 2 de la première liste ci-dessus fonctionnent correctement.
-
Avant de vous connecter, ajoutez cet extrait de code au début de votre
wp-config.phpafin de pouvoir effectuer un test d’installation. AVERTISSEMENT : cela interrompra la connexion pour le site WordPress en cours de test; utilisez-le uniquement sur une installation hors production. - Connectez-vous normalement.
-
Après avoir été redirigé vers l’URL de rappel de votre site, le processus s’arrêtera. Vous devriez voir une sortie semblable à celle affichée dans le Gist lié à l’étape no 4 ci-dessus. Si vous voyez quelque chose comme
Array()sans valeur supplémentaire, l’une des deux situations suivantes peut se produire :- L’URL de rappel de WordPress est mise en cache. La mise en cache des pages peut se produire de nombreuses façons; nous ne pouvons donc pas fournir d’étapes précises ici. Vérifiez les extensions de mise en cache que vous avez peut-être installées; elles offrent généralement un mécanisme d’exclusion d’URL. Vérifiez aussi auprès de votre hébergeur, car la mise en cache peut être automatique et nécessiter l’intervention du soutien technique.
- Le serveur ne lit pas le cookie Auth0. Pour une solution possible, consultez l’issue GitHub connexe et examinez son correctif.
-
Si les valeurs sont présentes, vérifiez les en-têtes de réponse de l’URL de rappel en cours de chargement (dans Chrome, View > Developer > JavaScript Console > onglet Network, cliquez sur le premier “document” affiché avec un état 500 et cherchez “Response Headers”). Recherchez tout indice de mise en cache, comme un
Cache-Controlavec unmax-agedifférent de zéro, unx-cacheautre queMISS, ou tout autre indice montrant que cette page est servie à partir d’un cache. -
Toujours dans les en-têtes de réponse, vérifiez que
set-cookieinclut une directive commeauth0_state=deletedpour confirmer que le processus de validation a bien lieu. -
Assurez-vous que le paramètre
statedans l’URL correspond à celui enregistré à partir du cookie défini à l’étape no 3 ci-dessus. -
S’il n’y a aucun indice de mise en cache, supprimez l’extrait de débogage de
wp-config.phpet actualisez l’URL de rappel. Vous devriez voir de nouveau le message “Invalid state”. Si des changements liés à la mise en cache ont été apportés, refaites le processus de connexion du début à la fin (assurez-vous d’effacer vos cookies et le cache de votre navigateur pour le site avant de tester).
- Ensuite, nous devons vérifier pourquoi le state est transmis, mais ne correspond pas à la valeur stockée.
-
Dans
lib/WP_Auth0_LoginManager.php, affichez les valeurs du state stocké et du state renvoyé, puis arrêtez le processus. Juste avant la ligne 148, ajoutez :
- Encore une fois, assurez-vous d’être déconnecté, puis effectuez la procédure de connexion.
- Vous devriez voir des valeurs s’afficher lors de la redirection vers l’URL de rappel WordPress.
-
Vérifiez que la valeur
statedans$_REQUESTexiste et qu’elle correspond à la valeurauth0_statedans$_COOKIE.
- Si elle est différente, elle doit correspondre à la valeur d’origine consignée à l’étape 3 ci-dessus. Cela signifie que la valeur
statede$_COOKIEa changé à un moment donné du processus.
wordpress. Incluez également :
- Version de PHP
- Version de WordPress
- Version de l’extension Auth0
- Navigateur et système d’exploitation utilisés pour le test
- Un fichier HAR enregistrant l’ensemble du processus, du chargement de la page contenant le formulaire de connexion jusqu’au message « Invalid state ». Pour en savoir plus sur les fichiers HAR, consultez Generate and Analyze HAR Files.
- Erreur « Invalid state » lors de la redirection d’Auth0 vers WordPress dans la communauté Auth0
- « Invalid state » lorsque l’URL de rappel est consultée directement sur wordpress.org