| 
									
										
										
										
											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/openid.php'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class FinishaddopenidAction extends Action { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	function handle($args) { | 
					
						
							|  |  |  | 		parent::handle($args); | 
					
						
							|  |  |  | 		if (!common_logged_in()) { | 
					
						
							|  |  |  | 			common_user_error(_t('Not logged in.')); | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			$this->try_login(); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	function try_login() { | 
					
						
							| 
									
										
										
										
											2008-06-18 03:12:07 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-18 09:15:19 -04:00
										 |  |  | 		$consumer =& oid_consumer(); | 
					
						
							| 
									
										
										
										
											2008-06-18 02:53:20 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		$response = $consumer->complete(common_local_url('finishaddopenid')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if ($response->status == Auth_OpenID_CANCEL) { | 
					
						
							|  |  |  | 			$this->message(_t('OpenID authentication cancelled.')); | 
					
						
							|  |  |  | 			return; | 
					
						
							|  |  |  | 		} else if ($response->status == Auth_OpenID_FAILURE) { | 
					
						
							|  |  |  | 			// Authentication failed; display the error message.
 | 
					
						
							|  |  |  | 			$this->message(_t('OpenID authentication failed: ') . $response->message); | 
					
						
							|  |  |  | 		} else if ($response->status == Auth_OpenID_SUCCESS) { | 
					
						
							| 
									
										
										
										
											2008-06-18 17:00:44 -04:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2008-06-18 02:53:20 -04:00
										 |  |  | 			$display = $response->getDisplayIdentifier(); | 
					
						
							| 
									
										
										
										
											2008-06-18 12:27:15 -04:00
										 |  |  | 			$canonical = ($response->endpoint && $response->endpoint->canonicalID) ? | 
					
						
							|  |  |  | 			  $response->endpoint->canonicalID : $display; | 
					
						
							| 
									
										
										
										
											2008-06-18 02:53:20 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			$sreg_resp = Auth_OpenID_SRegResponse::fromSuccessResponse($response); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if ($sreg_resp) { | 
					
						
							|  |  |  | 				$sreg = $sreg_resp->contents(); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-06-18 23:36:19 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-18 17:00:44 -04:00
										 |  |  | 			$cur =& common_current_user(); | 
					
						
							| 
									
										
										
										
											2008-06-19 09:51:48 -04:00
										 |  |  | 			$other = oid_get_user($canonical); | 
					
						
							| 
									
										
										
										
											2008-06-18 23:36:19 -04:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			if ($other) { | 
					
						
							|  |  |  | 				if ($other->id == $cur->id) { | 
					
						
							|  |  |  | 					$this->message(_t('You already have this OpenID!')); | 
					
						
							|  |  |  | 				} else { | 
					
						
							|  |  |  | 					$this->message(_t('Someone else already has this OpenID.')); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				return; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			# start a transaction
 | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			$cur->query('BEGIN'); | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2008-06-18 17:00:44 -04:00
										 |  |  | 			$result = oid_link_user($cur->id, $display, $canonical); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if (!$result) { | 
					
						
							|  |  |  | 				$this->message(_t('Error connecting user.')); | 
					
						
							|  |  |  | 				return; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			if ($sreg) { | 
					
						
							| 
									
										
										
										
											2008-06-19 09:51:48 -04:00
										 |  |  | 				if (!oid_update_user($cur, $sreg)) { | 
					
						
							| 
									
										
										
										
											2008-06-18 17:00:44 -04:00
										 |  |  | 					$this->message(_t('Error updating profile')); | 
					
						
							| 
									
										
										
										
											2008-06-18 03:12:07 -04:00
										 |  |  | 					return; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2008-06-18 02:53:20 -04:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-06-18 23:36:19 -04:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2008-06-18 17:00:44 -04:00
										 |  |  | 			# success!
 | 
					
						
							| 
									
										
										
										
											2008-06-18 23:36:19 -04:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			$cur->query('COMMIT'); | 
					
						
							| 
									
										
										
										
											2008-06-19 09:47:10 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			oid_set_last($display); | 
					
						
							| 
									
										
										
										
											2008-06-18 23:36:19 -04:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2008-06-18 17:00:44 -04:00
										 |  |  | 			common_redirect(common_local_url('openidsettings')); | 
					
						
							| 
									
										
										
										
											2008-06-18 02:53:20 -04:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	function message($msg) { | 
					
						
							|  |  |  | 		common_show_header(_t('OpenID Login')); | 
					
						
							|  |  |  | 		common_element('p', NULL, $msg); | 
					
						
							|  |  |  | 		common_show_footer(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |