| 
									
										
										
										
											2008-06-18 02:53:20 -04:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Laconica, the distributed open-source microblogging tool | 
					
						
							| 
									
										
										
										
											2008-06-18 02:53:20 -04:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |  * Settings for OpenID | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * PHP version 5 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * LICENCE: This program is free software: you can redistribute it and/or modify | 
					
						
							| 
									
										
										
										
											2008-06-18 02:53:20 -04:00
										 |  |  |  * it under the terms of the GNU Affero General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU Affero General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @category  Settings | 
					
						
							|  |  |  |  * @package   Laconica | 
					
						
							|  |  |  |  * @author    Evan Prodromou <evan@controlyourself.ca> | 
					
						
							|  |  |  |  * @copyright 2008-2009 Control Yourself, Inc. | 
					
						
							|  |  |  |  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 | 
					
						
							|  |  |  |  * @link      http://laconi.ca/ | 
					
						
							| 
									
										
										
										
											2008-06-18 02:53:20 -04:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  | if (!defined('LACONICA')) { | 
					
						
							|  |  |  |     exit(1); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-06-18 02:53:20 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  | require_once INSTALLDIR.'/lib/settingsaction.php'; | 
					
						
							|  |  |  | require_once INSTALLDIR.'/lib/openid.php'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Settings for OpenID | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Lets users add, edit and delete OpenIDs from their account | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category Settings | 
					
						
							|  |  |  |  * @package  Laconica | 
					
						
							|  |  |  |  * @author   Evan Prodromou <evan@controlyourself.ca> | 
					
						
							|  |  |  |  * @license  http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 | 
					
						
							|  |  |  |  * @link     http://laconi.ca/ | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-06-18 02:53:20 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:49:23 -05:00
										 |  |  | class OpenidsettingsAction extends SettingsAction | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Title of the page | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string Page title | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2008-06-30 13:03:42 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |     function title() | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |         return _('OpenID settings'); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Instructions for use | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string Instructions for use | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function getInstructions() | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |         return _('[OpenID](%%doc.openid%%) lets you log into many sites ' . | 
					
						
							|  |  |  |                  ' with the same user account. '. | 
					
						
							|  |  |  |                  ' Manage your associated OpenIDs from here.'); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Show the form for OpenID management | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * We have one form with a few different submit buttons to do different things. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |     function showContent() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $user = common_current_user(); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |         $this->elementStart('form', array('method' => 'post', | 
					
						
							| 
									
										
										
										
											2009-01-17 00:46:33 +00:00
										 |  |  |                                           'id' => 'form_settings_openid_add', | 
					
						
							| 
									
										
										
										
											2009-01-17 00:06:31 +00:00
										 |  |  |                                           'class' => 'form_settings', | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |                                           'action' => | 
					
						
							|  |  |  |                                           common_local_url('openidsettings'))); | 
					
						
							| 
									
										
										
										
											2009-01-17 00:46:33 +00:00
										 |  |  |         $this->elementStart('fieldset', array('id' => 'settings_openid_add')); | 
					
						
							| 
									
										
										
										
											2009-01-17 00:06:31 +00:00
										 |  |  |         $this->element('legend', null, _('Add OpenID')); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |         $this->hidden('token', common_session_token()); | 
					
						
							| 
									
										
										
										
											2009-01-17 00:06:31 +00:00
										 |  |  |         $this->element('p', 'form_guide', | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                        _('If you want to add an OpenID to your account, ' . | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |                          'enter it in the box below and click "Add".')); | 
					
						
							| 
									
										
										
										
											2009-01-17 00:06:31 +00:00
										 |  |  |         $this->elementStart('ul', 'form_datas'); | 
					
						
							|  |  |  |         $this->elementStart('li'); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |         $this->element('label', array('for' => 'openid_url'), | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                        _('OpenID URL')); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |         $this->element('input', array('name' => 'openid_url', | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                                       'type' => 'text', | 
					
						
							|  |  |  |                                       'id' => 'openid_url')); | 
					
						
							| 
									
										
										
										
											2009-01-17 00:06:31 +00:00
										 |  |  |         $this->elementEnd('li'); | 
					
						
							|  |  |  |         $this->elementEnd('ul'); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |         $this->element('input', array('type' => 'submit', | 
					
						
							| 
									
										
										
										
											2009-01-17 00:46:33 +00:00
										 |  |  |                                       'id' => 'settings_openid_add_action-submit', | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                                       'name' => 'add', | 
					
						
							|  |  |  |                                       'class' => 'submit', | 
					
						
							|  |  |  |                                       'value' => _('Add'))); | 
					
						
							| 
									
										
										
										
											2009-01-17 00:06:31 +00:00
										 |  |  |         $this->elementEnd('fieldset'); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |         $this->elementEnd('form'); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $oid = new User_openid(); | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         $oid->user_id = $user->id; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $cnt = $oid->find(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($cnt > 0) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |             $this->element('h2', null, _('Remove OpenID')); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |             if ($cnt == 1 && !$user->password) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |                 $this->element('p', null, | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |                                _('Removing your only OpenID '. | 
					
						
							|  |  |  |                                  'would make it impossible to log in! ' . | 
					
						
							|  |  |  |                                  'If you need to remove it, '. | 
					
						
							|  |  |  |                                  'add another OpenID first.')); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 if ($oid->fetch()) { | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |                     $this->elementStart('p'); | 
					
						
							|  |  |  |                     $this->element('a', array('href' => $oid->canonical), | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                                    $oid->display); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |                     $this->elementEnd('p'); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             } else { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-17 00:46:33 +00:00
										 |  |  |                 $this->element('p', 'form_guide', | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                                _('You can remove an OpenID from your account '. | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |                                  'by clicking the button marked "Remove".')); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                 $idx = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 while ($oid->fetch()) { | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |                     $this->elementStart('form', | 
					
						
							|  |  |  |                                         array('method' => 'POST', | 
					
						
							| 
									
										
										
										
											2009-01-17 00:46:33 +00:00
										 |  |  |                                               'id' => 'form_settings_openid_delete' . $idx, | 
					
						
							|  |  |  |                                               'class' => 'form_settings', | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |                                               'action' => | 
					
						
							|  |  |  |                                               common_local_url('openidsettings'))); | 
					
						
							| 
									
										
										
										
											2009-01-17 00:46:33 +00:00
										 |  |  |                     $this->elementStart('fieldset'); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |                     $this->hidden('token', common_session_token()); | 
					
						
							|  |  |  |                     $this->element('a', array('href' => $oid->canonical), | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                                    $oid->display); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |                     $this->element('input', array('type' => 'hidden', | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                                                   'id' => 'openid_url'.$idx, | 
					
						
							|  |  |  |                                                   'name' => 'openid_url', | 
					
						
							|  |  |  |                                                   'value' => $oid->canonical)); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |                     $this->element('input', array('type' => 'submit', | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                                                   'id' => 'remove'.$idx, | 
					
						
							|  |  |  |                                                   'name' => 'remove', | 
					
						
							|  |  |  |                                                   'class' => 'submit', | 
					
						
							|  |  |  |                                                   'value' => _('Remove'))); | 
					
						
							| 
									
										
										
										
											2009-01-17 00:46:33 +00:00
										 |  |  |                     $this->elementEnd('fieldset'); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |                     $this->elementEnd('form'); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                     $idx++; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Handle a POST request | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * Muxes to different sub-functions based on which button was pushed | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function handlePost() | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |         // CSRF protection
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         $token = $this->trimmed('token'); | 
					
						
							|  |  |  |         if (!$token || $token != common_session_token()) { | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |             $this->showForm(_('There was a problem with your session token. '. | 
					
						
							|  |  |  |                               'Try again, please.')); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($this->arg('add')) { | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |             $result = oid_authenticate($this->trimmed('openid_url'), | 
					
						
							|  |  |  |                                        'finishaddopenid'); | 
					
						
							|  |  |  |             if (is_string($result)) { // error message
 | 
					
						
							|  |  |  |                 $this->showForm($result); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |             } | 
					
						
							|  |  |  |         } else if ($this->arg('remove')) { | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |             $this->removeOpenid(); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |             $this->showForm(_('Something weird happened.')); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Handles a request to remove an OpenID from the user's account | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * Validates input and, if everything is OK, deletes the OpenID. | 
					
						
							|  |  |  |      * Reloads the form with a success or error notification. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |     function removeOpenid() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         $openid_url = $this->trimmed('openid_url'); | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         $oid = User_openid::staticGet('canonical', $openid_url); | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         if (!$oid) { | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |             $this->showForm(_('No such OpenID.')); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $cur = common_current_user(); | 
					
						
							|  |  |  |         if (!$cur || $oid->user_id != $cur->id) { | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |             $this->showForm(_('That OpenID does not belong to you.')); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $oid->delete(); | 
					
						
							| 
									
										
										
										
											2009-01-16 20:25:46 +00:00
										 |  |  |         $this->showForm(_('OpenID removed.'), true); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-06-30 13:03:42 -04:00
										 |  |  | } |