function fb_actions_cron_per_user in Drupal for Facebook 5
Same name and namespace in other branches
- 5.2 fb_actions.module \fb_actions_cron_per_user()
- 6.2 contrib/fb_actions.module \fb_actions_cron_per_user()
File
- ./fb_actions.module, line 361
- Actions defined here interact with Facebook's API. This makes it
possible to notify facebook of various activities as they happen.
Code
function fb_actions_cron_per_user($obj, $values) {
foreach ($values['fb_app_nids'] as $nid) {
$fb_app = fb_get_app(array(
'nid' => $nid,
));
$before_fb = $GLOBALS['fb'];
$before_fb_app = $GLOBALS['fb_app'];
$before_user = $GLOBALS['user'];
$result = db_query("SELECT * FROM {fb_user_app} WHERE apikey='%s' AND fbu > 0 AND added > 0 ORDER BY time_cron ASC LIMIT %d", $fb_app->apikey, $values['throttle']);
while ($data = db_fetch_object($result)) {
$account = fb_user_get_local_user($data->fbu, $fb_app);
if (variable_get('fb_actions_verbose', FALSE)) {
watchdog('fb_action_debug', "fb_actions_cron_per_user fbu is {$data->fbu}, local user is " . theme('username', $account), WATCHDOG_ERROR);
}
if (!$account || !$account->uid) {
watchdog('fb cron', t('Facebook user %fbu does not correspond to a local account.', array(
'%fbu' => $data->fbu,
)));
}
else {
$fb = fb_api_init($fb_app, $data->fbu);
if (!$fb || !$fb->api_client
->users_getLoggedInUser()) {
$fb = fb_api_init($fb_app, FB_FBU_INFINITE_SESSION);
}
if (!$fb || !$fb->api_client
->users_getLoggedInUser()) {
watchdog('fb cron', t('Failed to log into %app during cron. Try testing infinite session key.', array(
'%app' => $fb_app->title,
)));
}
else {
$GLOBALS['user'] = $account;
$GLOBALS['fb'] = $fb;
$GLOBALS['fb_app'] = $fb_app;
actions_do($values['actions'], $fb_app);
}
}
db_query("UPDATE {fb_user_app} SET time_cron=%d WHERE apikey='%s' AND fbu=%d", time(), $fb_app->apikey, $data->fbu);
}
$GLOBALS['user'] = $before_user;
$GLOBALS['fb'] = $before_fb;
$GLOBALS['fb_app'] = $before_fb_app;
}
}