Facebook Open Graph - узнайте, зарегистрировался ли пользователь в определенном месте - PullRequest
0 голосов
/ 27 мая 2011

есть ли способ проверить, регистрировался ли пользователь в определенном месте в любое время в прошлом?

с php sdk, я могу получить информацию о месте, например:

$place = $facebook->api('/placeIDhere');
var_dump($place['checkins'])

это дает мне счет регистрации.

чтобы получить последние проверки пользователя, которые я могу сделать

$usercheckins = $facebook->api('/search?type=checkin');
var_dump($usercheckins[0]['place']['name']);

это дает мне последнюю регистрацию по имени

но есть ли способ проверить, зарегистрирован ли пользователь в специальном месте? /search?type=checkin дает мне очень небольшое количество недавних проверок, и если проверка старше ~ 2-3 недель, она даже не появляется.

спасибо за помощь.

Ответы [ 2 ]

1 голос
/ 28 мая 2011

Вот как заставить ответ bkaid работать с PHP SDK ( см. На github ).

Сначала вы должны проверить, вошел ли пользователь в систему или нет:

require "facebook.php";
$facebook = new Facebook(array(
    'appId'  => YOUR_APP_ID,
    'secret' => YOUR_APP_SECRET,
));

$user = $facebook->getUser();

if ($user) {
    try {
        $user_profile = $facebook->api('/me');
    } catch (FacebookApiException $e) {
        $user = null;
    }
}

Вы делаете ссылку, чтобы заставить его войти в систему, если он не. И если он есть, вы можете сделать вызов API:

if (!$user) {
    echo '<a href="' . $facebook->getLoginUrl() . '">Login with Facebook</a>';
} else {
    $fql = "SELECT post_id, message FROM checkin
            WHERE author_uid = me() AND page_id = THE_PAGE_ID";

    $response = $facebook->api(array(
        'method' => 'fql.query',
        'query' => $fql,
    ));
}

Надеюсь, это поможет!

0 голосов
/ 27 мая 2011

Выполните запрос FQL к таблице checkin . Что-то вроде:

    SELECT coords,tagged_uids,author_uid,page_id,app_id,post_id,timestamp,message 
    FROM checkin 
    WHERE author_uid = me() and page_id = 'placeID'
...