web-dev-qa-db-fra.com

wp_set_auth_cookie () ne fonctionne pas dans l'appel Ajax

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();
}
6
user9909

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}
});
0
Michał Mazur