Graph API - Получить события от владельца / создателя - PullRequest
13 голосов
/ 09 июня 2010

Можно ли с помощью API Graph Facebook получить список всех событий, созданных одним профилем?Наш клиент создает кучу событий, и мы хотим получить список их всех.Я сказал, что им просто нужно убедиться, что они настроены на участие в мероприятии, потому что тогда я могу легко получить список событий, которые посещает profileId, но мне интересно, есть ли другой способ.Может быть, запрос FQL?Они, похоже, требуют запроса по первичному ключу.И как будет выглядеть этот FQL-запрос, если это способ сделать это?

Ответы [ 4 ]

16 голосов
/ 17 ноября 2011

Я в основном использовал FQL, предоставленный @jhchen. Однако мне потребовалось около 6 часов, чтобы понять, как использовать это FQL. Я решил, что предоставлю вам рабочий сценарий. Это не идеально, поэтому, пожалуйста, обновите его, если найдете ошибку.

  1. Скачать PHPs SDK PHP
  2. Добавить YOUR_APP_ID
  3. Добавить YOUR_APP_SECRET
  4. Добавить PAGE_ID
  5. Внесите изменения в оператор FQL по своему усмотрению. Документация FQL

Кроме того, вам следует идти. Также я установил часовой пояс по умолчанию на America/Los_Angeles. Это, вероятно, вызовет проблемы у некоторых из вас, если у кого-то есть лучший способ обработки часовых поясов, пожалуйста, сообщите мне

PHP код:

<?php
require_once("php/facebook.php");

date_default_timezone_set('America/Los_Angeles');

function display_events()
{
    $app_id = 'YOUR_APP_ID';
    $secret = 'YOUR_APP_SECRET';
    $page_id = 'PAGE_ID';

    $config = array();
    $config['appId'] = $app_id;
    $config['secret'] = $secret;
    $config['fileUpload'] = false; // optional

    $facebook = new Facebook($config);

    $fql = 'SELECT 
                eid, 
                name, 
                pic_square, 
                creator,
                start_time,
                end_time
            FROM event 
            WHERE eid IN 
                (SELECT eid 
                    FROM event_member 
                    WHERE uid='.$page_id.'
                ) 
            AND end_time >= ' . mktime() . '
            ORDER BY start_time ASC
    ';

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

    $html = '';                            
    foreach($ret_obj as $key)
    {
        $facebook_url = 'https://www.facebook.com/event.php?eid=' . $key['eid'];

        $start_time = date('M j, Y \a\t g:i A', $key['start_time']);
        $end_time = date('M j, Y \a\t g:i A', $key['end_time']);

        $html .= '
            <div class="event">
                <a href="'.$facebook_url.'">
                    <img src="'.$key['pic_square'].'" />
                </a>
                <span>
                    <a href="'.$facebook_url.'">
                        <h2>'.$key['name'].'</h2>
                    </a>
                    <p class="time">'.$start_time.'</p>
                    <p class="time">'.$end_time.'</p>
                </span>
            </div>
        ';
    }

    echo $html;
}
12 голосов
/ 19 августа 2010

Вы можете использовать FQL. Простое использование создателя в качестве предложения where не работает, поскольку создатель не индексируется. Однако обходной путь должен включать индексируемое предложение where и добавление в создателя дополнительно. Пример:

ВЫБРАТЬ eid, name, pic, creator ОТ события WHERE EID (ВЫБРАТЬ eid ИЗ event_member WHERE uid = 12345) И создателя = 12345

2 голосов
/ 21 июня 2010

Это одна из тех проблем, «отсюда нет хорошего пути».Вы не можете использовать FQL, поскольку столбец создателя не проиндексирован.Лучшее решение, которое я могу придумать на данный момент, - это использовать Graph API для запроса соединения событий создателя и отфильтровывать любые события, для которых они не являются создателем.Это будет не очень эффективно, так как вы будете загружать информацию обо всех событиях пользователя, даже тех, которые он не создал.Итак, я бы поэкспериментировал с разбивкой на два запроса:

graph.facebook.com/[user_id]/events?fields=id,owner&limit=1000

, а затем, как только вы отфильтровали все события, которые они не создали:

0 голосов
/ 03 июля 2014

Ответ от zechdc идеален, но мне просто нужно было добавить strtotime, чтобы start_time работал.

$start_time = date('M j, Y \a\t g:i A', strtotime($key['start_time']));
$end_time = date('M j, Y \a\t g:i A', strtotime($key['end_time']));
...