3 * Laconica, the distributed open-source microblogging tool
5 * Plugin to enable Facebook Connect
9 * LICENCE: This program is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU Affero General Public License as published by
11 * the Free Software Foundation, either version 3 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU Affero General Public License for more details.
19 * You should have received a copy of the GNU Affero General Public License
20 * along with this program. If not, see <http://www.gnu.org/licenses/>.
24 * @author Zach Copley <zach@controlyourself.ca>
25 * @copyright 2009 Control Yourself, Inc.
26 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
27 * @link http://laconi.ca/
30 if (!defined('LACONICA')) {
34 require_once INSTALLDIR . '/plugins/FBConnect/FBConnectLogin.php';
35 require_once INSTALLDIR . '/lib/facebookutil.php';
38 * Plugin to enable Facebook Connect
42 * @author Zach Copley <zach@controlyourself.ca>
43 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
44 * @link http://laconi.ca/
47 class FBConnectPlugin extends Plugin
50 function __construct()
52 parent::__construct();
55 // Hook in new actions
56 function onRouterInitialized(&$m) {
57 $m->connect('main/facebookconnect', array('action' => 'fbconnectlogin'));
61 function onStartShowHTML($action)
64 // XXX: This is probably a bad place to do general processing
65 // so maybe I need to make some new events? Maybe in
68 $name = get_class($action);
70 // Avoid a redirect loop
71 if (!in_array($name, array('FBConnectloginAction', 'ClientErrorAction'))) {
73 $this->checkFacebookUser($action);
77 $httpaccept = isset($_SERVER['HTTP_ACCEPT']) ?
78 $_SERVER['HTTP_ACCEPT'] : null;
80 // XXX: allow content negotiation for RDF, RSS, or XRDS
82 $cp = common_accept_to_prefs($httpaccept);
83 $sp = common_accept_to_prefs(PAGE_TYPE_PREFS);
85 $type = common_negotiate_type($cp, $sp);
88 throw new ClientException(_('This page is not available in a '.
89 'media type you accept'), 406);
93 header('Content-Type: '.$type);
95 $action->extraHeaders();
97 $action->startXML('html',
98 '-//W3C//DTD XHTML 1.0 Strict//EN',
99 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd');
101 $language = $action->getLanguage();
103 $action->elementStart('html', array('xmlns' => 'http://www.w3.org/1999/xhtml',
104 'xmlns:fb' => 'http://www.facebook.com/2008/fbml',
105 'xml:lang' => $language,
106 'lang' => $language));
112 function onEndShowLaconicaScripts($action)
115 $action->element('script',
116 array('type' => 'text/javascript',
117 'src' => 'http://static.ak.connect.facebook.com/js/api_lib/v0.4/FeatureLoader.js.php'),
120 $apikey = common_config('facebook', 'apikey');
121 $plugin_path = common_path('plugins/FBConnect');
123 $url = common_get_returnto();
126 // We don't have to return to it again
127 common_set_returnto(null);
129 $url = common_local_url('public');
132 $html = sprintf('<script type="text/javascript">FB.init("%s", "%s/xd_receiver.htm");
134 function refresh_page() {
135 window.location = "%s";
138 </script>', $apikey, $plugin_path, $url);
144 function onStartPrimaryNav($action)
146 $user = common_current_user();
149 $action->menuItem(common_local_url('all', array('nickname' => $user->nickname)),
150 _('Home'), _('Personal profile and friends timeline'), false, 'nav_home');
151 $action->menuItem(common_local_url('profilesettings'),
152 _('Account'), _('Change your email, avatar, password, profile'), false, 'nav_account');
153 if (common_config('xmpp', 'enabled')) {
154 $action->menuItem(common_local_url('imsettings'),
155 _('Connect'), _('Connect to IM, SMS, Twitter'), false, 'nav_connect');
157 $action->menuItem(common_local_url('smssettings'),
158 _('Connect'), _('Connect to SMS, Twitter'), false, 'nav_connect');
160 $action->menuItem(common_local_url('invite'),
162 sprintf(_('Invite friends and colleagues to join you on %s'),
163 common_config('site', 'name')),
164 false, 'nav_invitecontact');
166 // Need to override the Logout link to make it do FB stuff
168 $logout_url = common_local_url('logout');
169 $title = _('Logout from the site');
172 $html = sprintf('<li id="nav_logout"><a href="%s" title="%s" ' .
173 'onclick="FB.Connect.logoutAndRedirect(\'%s\')">%s</a></li>',
174 $logout_url, $title, $logout_url, $text);
180 if (!common_config('site', 'closed')) {
181 $action->menuItem(common_local_url('register'),
182 _('Register'), _('Create an account'), false, 'nav_register');
184 $action->menuItem(common_local_url('openidlogin'),
185 _('OpenID'), _('Login with OpenID'), false, 'nav_openid');
186 $action->menuItem(common_local_url('login'),
187 _('Login'), _('Login to the site'), false, 'nav_login');
190 $action->menuItem(common_local_url('doc', array('title' => 'help')),
191 _('Help'), _('Help me!'), false, 'nav_help');
192 $action->menuItem(common_local_url('peoplesearch'),
193 _('Search'), _('Search for people or text'), false, 'nav_search');
195 // Tack on "Connect with Facebook" button
197 // XXX: Maybe this looks bad and should not go here. Where should it go?
200 $action->elementStart('li');
201 $action->element('fb:login-button', array('onlogin' => 'refresh_page()',
202 'length' => 'long'));
203 $action->elementEnd('li');
209 function checkFacebookUser() {
211 $user = common_current_user();
219 $facebook = getFacebook();
220 $fbuid = $facebook->get_loggedin_user();
222 // If you're a Facebook user and you're logged in do nothing
224 // If you're a Facebook user and you're not logged in
225 // redirect to Facebook connect login page because that means you have clicked
226 // the 'connect with Facebook' button and have cookies
230 if ($facebook->api_client->users_isAppUser($fbuid) ||
231 $facebook->api_client->added) {
233 // user should be connected...
235 common_debug("Facebook user found: $fbuid");
238 common_debug("Facebook user is logged in.");
242 common_debug("Facebook user is NOT logged in.");
243 common_redirect(common_local_url('fbconnectlogin'), 303);
247 common_debug("No Facebook connect user found.");
251 } catch (Exception $e) {
252 common_debug('Expired FB session.');