Приложение FB не может запросить разрешения у iOS после удаления приложения на FB.com - PullRequest
3 голосов
/ 13 декабря 2011

Мы обнаружили странный набор обстоятельств, которые могут вызвать ошибку при публикации в Facebook из нашего приложения для iOS. Я пытаюсь выяснить, может ли это быть просто ошибкой в ​​том, как Facebook реагирует на этот набор событий, или, возможно, есть способ избежать этого.

По сути, наше приложение для iOS не запрашивает разрешения после того, как пользователь отозвал разрешения с веб-сайта FB. Мы ожидали, что наше приложение будет повторно запрашивать, но вместо этого оно пытается поделиться контентом, а затем отказывает с общим сообщением об ошибке. У пользователя нет возможности снова предоставить разрешение.

Точный набор обстоятельств:

  1. Пользователь хочет поделиться контентом из приложения iOS, подключенное к нему приложение FB запрашивает разрешения, и все работает.
  2. Пользователь удаляет приложение из своего профиля с настройками приложения FB.com.
  3. Пользователь снова обменивается контентом из приложения iOS, и приложение FB отправляет, но затем возвращает ошибку, а не повторно запрашивает разрешения.

Джереми

Ответы [ 2 ]

2 голосов
/ 13 декабря 2011

Тестеры выяснили, что они не дают приложению достаточно времени для очистки его кеша на устройстве, поэтому было несоответствие между разрешениями на устройстве и разрешениями на Facebook.

Ранее они удаляли разрешенияна FB.com, а затем сразу же попытаться поделиться из приложения для iOS.Теперь они сообщают, что, если они подождут час, приложение будет нормально запрашивать разрешения.

Спасибо!

0 голосов
/ 13 декабря 2011

Я не знаю, что вызывает вашу проблему, но у меня может быть решение для вас: установите деавторизованный URL обратного вызова в дополнительных настройках приложения.Таким образом, вы можете поймать каждого пользователя, который деавторизовал ваше приложение и сохранить его в своей базе данных или что-то еще.URL может ссылаться на файл php, который выглядит следующим образом:

<?php

$secretKey = "APP_SECRET_KEY";
$data = parse_signed_request($_REQUEST['signed_request'], $secretKey);
$fbUserId = $data['user_id'];
// do with the user id whatever you want

function parse_signed_request($signed_request, $secret) {
    list($encoded_sig, $payload) = explode('.', $signed_request, 2);

    // decode the data
    $sig = base64_url_decode($encoded_sig);
    $data = json_decode(base64_url_decode($payload), true);

    if (strtoupper($data['algorithm']) !== 'HMAC-SHA256') {
        error_log('Unknown algorithm. Expected HMAC-SHA256');
        return null;
    }

    // check sig
    $expected_sig = hash_hmac('sha256', $payload, $secret, $raw = true);
    if ($sig !== $expected_sig) {
        error_log('Bad Signed JSON signature!');
        return null;
    }

    return $data;
}

function base64_url_decode($input) {
    return base64_decode(strtr($input, '-_', '+/'));
}

?>
...