. * * @category Plugin * @package StatusNet * @author Zach Copley * @copyright 2010 StatusNet, Inc. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 * @link http://status.net/ */ if (!defined('STATUSNET')) { exit(1); } class FacebookloginAction extends Action { function handle($args) { parent::handle($args); if (common_is_real_login()) { $this->clientError(_m('Already logged in.')); } else { $facebook = new Facebook( array( 'appId' => common_config('facebook', 'appid'), 'secret' => common_config('facebook', 'secret'), 'cookie' => true, ) ); $session = $facebook->getSession(); $fbuser = null; if ($session) { try { $fbuid = $facebook->getUser(); $fbuser = $facebook->api('/me'); } catch (FacebookApiException $e) { common_log(LOG_ERROR, $e); } } if (!empty($fbuser)) { common_debug("Found a valid Facebook user", __FILE__); // Check to see if we have a foreign link already $flink = Foreign_link::getByForeignId($fbuid, FACEBOOK_SERVICE); if (empty($flink)) { // See if the user would like to register a new local // account common_redirect( common_local_url('facebookregister'), 303 ); } else { // Log our user in! $user = $flink->getUser(); if (!empty($user)) { common_log( LOG_INFO, sprintf( 'Logged in Facebook user %s as user %s (%s)', $fbuid, $user->id, $user->nickname ), __FILE__ ); common_set_user($user); common_real_login(true); $this->goHome($user->nickname); } } } } $this->showPage(); } function goHome($nickname) { $url = common_get_returnto(); if ($url) { // We don't have to return to it again common_set_returnto(null); } else { $url = common_local_url( 'all', array('nickname' => $nickname) ); } common_redirect($url, 303); } function getInstructions() { // TRANS: Instructions. return _m('Login with your Facebook Account'); } function showPageNotice() { $instr = $this->getInstructions(); $output = common_markup_to_html($instr); $this->elementStart('div', 'instructions'); $this->raw($output); $this->elementEnd('div'); } function title() { // TRANS: Page title. return _m('Login with Facebook'); } function showContent() { $this->elementStart('fieldset'); $attrs = array( //'show-faces' => 'true', //'max-rows' => '4', //'width' => '600', 'perms' => 'user_location,user_website,offline_access,publish_stream' ); $this->element('fb:login-button', $attrs); $this->elementEnd('fieldset'); } function showLocalNav() { $nav = new LoginGroupNav($this); $nav->show(); } }