действительно нужна ваша помощь при входе в систему с функцией facebook, которую я пытаюсь реализовать на своем веб-сайте.
В основном, я пытаюсь добиться следующего:
-
если пользователь ранее подтвердил приложение и нажал кнопку входа FB на моем веб-сайте они регистрируются на веб-сайте (с веб-сайта пользователя учетная запись, связанная с идентификатором пользователя Facebook)
-
если пользователь еще не подтвердил это приложение, в журнале FB (и подписке на приложение) они перенаправляются на страницу регистрации веб-сайта. Здесь форма заполняется пользовательскими данными через Facebook и процесс регистрации становятся проще и быстрее.
Я использую код ниже.
<body>
<div id="fb-root"></div>
<script>
window.fbAsyncInit = function() {
FB.init({
appId: 'xxxxxxxx',
status: true,
cookie: true,
xfbml: true,
oauth: true
});
FB.Event.subscribe('auth.login', function(response) {
if (response.status === 'connected') {
var uid = response.authResponse.userID;
var accessToken = response.authResponse.accessToken;
if ((parseFloat(uid) == parseInt(uid)) && !isNaN(uid)) {
$.ajax({
url: '/user_actions/prep_facebook_registration',
cache: false,
type: 'POST',
data: { 'uid': uid, 'token': accessToken },
dataType: 'json',
success: function(data) {
if (data.success=='true') {
if ((typeof(data.redirect) != 'undefined')) {
window.location=data.redirect;
}
}
}
});
}
}
});
FB.Event.subscribe('auth.logout', function(response) {
FB.getLoginStatus(function(res) {
if (!res.authResponse) {
window.location='/access/logout';
}
});
});
FB.getLoginStatus(function(response) {
if (response.status === 'connected') {
var uid = response.authResponse.userID;
var accessToken = response.authResponse.accessToken;
//not doing anything so far
}
});
};
(function(d, s, id) {
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) {return;}
js = d.createElement(s); js.id = id;
js.src = "//connect.facebook.net/en_US/all.js#xfbml=1";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));
</script>
Кнопка входа в систему располагается на веб-сайте:
<div class="fb-login-button" autologoutlink="true" data-show-faces="false" data-width="166" data-max-rows="1" style="position: absolute; top: 5px; right: 0;" scope="email"></div>
Проблема заключается в том, что FB.Event.subscribe('auth.login') запускает не только кнопку входа в систему FB, но также, если пользователь зарегистрировался в Facebook и только после этого приходит на мой сайт. Это вызывает перенаправление на страницу регистрации или текущую перезагрузку страницы, даже если пользователь не нажал кнопку входа в систему!
'/user_actions/prep_facebook_registration' содержит script, который проверяет, должен ли элемент быть перенаправлен на страницу регистрации или должен быть зарегистрирован в локальной учетной записи. Он возвращает URL-адрес для перенаправления.
Что я делаю неправильно? Как я могу избежать запуска FB.Event.subscribe('auth.login') вне кнопки входа в систему?