| 
									
										
										
										
											2008-06-18 02:53:20 -04:00
										 |  |  | <?php | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  |  * Laconica - a distributed open-source microblogging tool | 
					
						
							|  |  |  |  * Copyright (C) 2008, Controlez-Vous, Inc. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * 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/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (!defined('LACONICA')) { exit(1); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | require_once(INSTALLDIR.'/lib/settingsaction.php'); | 
					
						
							|  |  |  | require_once(INSTALLDIR.'/lib/openid.php'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:49:23 -05:00
										 |  |  | class OpenidsettingsAction extends SettingsAction | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2008-06-30 13:03:42 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function get_instructions() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05: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:33:23 -05:00
										 |  |  |     function show_form($msg=null, $success=false) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $user = common_current_user(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->form_header(_('OpenID settings'), $msg, $success); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |         $this->elementStart('form', array('method' => 'post', | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                                            'id' => 'openidadd', | 
					
						
							|  |  |  |                                            'action' => | 
					
						
							|  |  |  |                                            common_local_url('openidsettings'))); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |         $this->hidden('token', common_session_token()); | 
					
						
							|  |  |  |         $this->element('h2', null, _('Add OpenID')); | 
					
						
							|  |  |  |         $this->element('p', null, | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                        _('If you want to add an OpenID to your account, ' . | 
					
						
							|  |  |  |                           'enter it in the box below and click "Add".')); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |         $this->elementStart('p'); | 
					
						
							|  |  |  |         $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-15 22:57:15 +00:00
										 |  |  |         $this->element('input', array('type' => 'submit', | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                                       'id' => 'add', | 
					
						
							|  |  |  |                                       'name' => 'add', | 
					
						
							|  |  |  |                                       'class' => 'submit', | 
					
						
							|  |  |  |                                       'value' => _('Add'))); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |         $this->elementEnd('p'); | 
					
						
							|  |  |  |         $this->elementEnd('form'); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $oid = new User_openid(); | 
					
						
							|  |  |  |         $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, | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                                _('Removing your only OpenID would make it impossible to log in! ' . | 
					
						
							|  |  |  |                                   'If you need to remove it, add another OpenID first.')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 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-15 22:57:15 +00:00
										 |  |  |                 $this->element('p', null, | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                                _('You can remove an OpenID from your account '. | 
					
						
							|  |  |  |                                   'by clicking the button marked "Remove".')); | 
					
						
							|  |  |  |                 $idx = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 while ($oid->fetch()) { | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |                     $this->elementStart('form', array('method' => 'POST', | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                                                        'id' => 'openiddelete' . $idx, | 
					
						
							|  |  |  |                                                        'action' => | 
					
						
							|  |  |  |                                                        common_local_url('openidsettings'))); | 
					
						
							| 
									
										
										
										
											2009-01-15 22:57:15 +00:00
										 |  |  |                     $this->elementStart('p'); | 
					
						
							|  |  |  |                     $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-15 22:57:15 +00:00
										 |  |  |                     $this->elementEnd('p'); | 
					
						
							|  |  |  |                     $this->elementEnd('form'); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                     $idx++; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         common_show_footer(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function handle_post() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         # CSRF protection
 | 
					
						
							|  |  |  |         $token = $this->trimmed('token'); | 
					
						
							|  |  |  |         if (!$token || $token != common_session_token()) { | 
					
						
							|  |  |  |             $this->show_form(_('There was a problem with your session token. Try again, please.')); | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($this->arg('add')) { | 
					
						
							|  |  |  |             $result = oid_authenticate($this->trimmed('openid_url'), 'finishaddopenid'); | 
					
						
							|  |  |  |             if (is_string($result)) { # error message
 | 
					
						
							|  |  |  |                 $this->show_form($result); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } else if ($this->arg('remove')) { | 
					
						
							|  |  |  |             $this->remove_openid(); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             $this->show_form(_('Something weird happened.')); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function remove_openid() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $openid_url = $this->trimmed('openid_url'); | 
					
						
							|  |  |  |         $oid = User_openid::staticGet('canonical', $openid_url); | 
					
						
							|  |  |  |         if (!$oid) { | 
					
						
							|  |  |  |             $this->show_form(_('No such OpenID.')); | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $cur = common_current_user(); | 
					
						
							|  |  |  |         if (!$cur || $oid->user_id != $cur->id) { | 
					
						
							|  |  |  |             $this->show_form(_('That OpenID does not belong to you.')); | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $oid->delete(); | 
					
						
							|  |  |  |         $this->show_form(_('OpenID removed.'), true); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-06-30 13:03:42 -04:00
										 |  |  | } |