J'essaie de créer une fonctionnalité de connexion automatique basée sur le JS-SDK de Facebook. Lorsque l'utilisateur est "connecté", il transmet FbID et d'autres données d'utilisateur à une fonction ajax qui crée le cookie de session. Un cookie est créé (je peux voir "wordpress_logged_in_.... cookie"
dans l'inspecteur du navigateur), mais lorsque je recharge la page, l'utilisateur est toujours déconnecté.
Avez-vous une idée pourquoi?
JavaScript
function ajaxloginFB(uid,email,first_name,last_name) {
data = "uid=" + uid + "&" + "name=" + last_name + " " + first_name + "&" + "email=" + email + "&" + $.param({ action: 'facebook_login', nonce: ajax_object.ajaxnonce });
$.ajax({
url : ajax_object.ajaxurl,
type: "post",
data : data,
success:function(response){
var response = $.parseJSON(response);
if (response.success == true){
window.location.reload();
}
}
});
}
PHP
add_action( 'wp_ajax_facebook_login', 'facebook_ajax_login_or_register' );
add_action( 'wp_ajax_nopriv_facebook_login', 'facebook_ajax_login_or_register' );
function facebook_ajax_login_or_register(){
$uid = sanitize_text_field( $_POST['uid'] );
$args = array(
'meta_key' => 'fbuid',
'meta_value' => $uid,
'meta_compare' => '=',
);
$fb_user = get_users($args);
$current_user_id = $fb_user[0];
wp_set_auth_cookie( $current_user_id, true );
$response[success] = true;
echo json_encode($response);
die();
}
J'ajoute une fonction wp_set_current_user pour configurer l'utilisateur actuel.
add_action( 'wp_ajax_facebook_login', 'facebook_ajax_login_or_register' );
add_action( 'wp_ajax_nopriv_facebook_login', 'facebook_ajax_login_or_register' );
function facebook_ajax_login_or_register(){
$uid = sanitize_text_field( $_POST['uid'] );
$args = array(
'meta_key' => 'fbuid',
'meta_value' => $uid,
'meta_compare' => '=',
);
$fb_user = get_users($args);
$current_user_id = $fb_user[0];
wp_set_current_user($current_user_id);//Set current user
wp_set_auth_cookie( $current_user_id, true );
$response[success] = true;
echo json_encode($response);
die();
}
Je ne suis pas testé, faites-le moi savoir si vous faites toujours face au même problème.
J'utilise ajax avec l'en-tête d'authentification xhr pour mon identifiant wp personnalisé
$.ajax({
url : ajax_object.ajaxurl,
type: "post",
data: data,
contentType: 'application/x-www-form-urlencoded',
xhrFields: {withCredentials: true}
});