2011-06-23 19:04:32 +04:00
|
|
|
<?php
|
|
|
|
|
2011-06-23 20:18:48 +04:00
|
|
|
//check if curl extension installed
|
|
|
|
if (!in_array ('curl', get_loaded_extensions())){
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2011-08-04 20:49:29 +04:00
|
|
|
$userName='';
|
|
|
|
if(strpos($_SERVER["REQUEST_URI"],'?') and !strpos($_SERVER["REQUEST_URI"],'=')){
|
|
|
|
if(strpos($_SERVER["REQUEST_URI"],'/?')){
|
|
|
|
$userName=substr($_SERVER["REQUEST_URI"],strpos($_SERVER["REQUEST_URI"],'/?')+2);
|
|
|
|
}elseif(strpos($_SERVER["REQUEST_URI"],'.php?')){
|
|
|
|
$userName=substr($_SERVER["REQUEST_URI"],strpos($_SERVER["REQUEST_URI"],'.php?')+5);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-05-02 01:19:39 +04:00
|
|
|
OCP\Util::addHeader('link',array('rel'=>'openid.server', 'href'=>OCP\Util::linkToAbsolute( "user_openid", "user.php" ).'/'.$userName));
|
|
|
|
OCP\Util::addHeader('link',array('rel'=>'openid.delegate', 'href'=>OCP\Util::linkToAbsolute( "user_openid", "user.php" ).'/'.$userName));
|
2011-06-25 00:07:26 +04:00
|
|
|
|
2012-05-02 02:50:26 +04:00
|
|
|
OCP\App::registerPersonal('user_openid','settings');
|
2011-08-09 01:32:54 +04:00
|
|
|
|
2012-07-24 02:02:01 +04:00
|
|
|
require_once 'openid/user_openid.php';
|
2011-06-23 19:04:32 +04:00
|
|
|
|
|
|
|
//active the openid backend
|
2011-07-29 23:36:03 +04:00
|
|
|
OC_User::useBackend('openid');
|
2011-06-23 19:04:32 +04:00
|
|
|
|
|
|
|
//check for results from openid requests
|
|
|
|
if(isset($_GET['openid_mode']) and $_GET['openid_mode'] == 'id_res'){
|
2012-05-01 19:38:27 +04:00
|
|
|
OCP\Util::writeLog('user_openid','openid retured',OCP\Util::DEBUG);
|
2012-06-29 20:36:58 +04:00
|
|
|
$openid = new SimpleOpenID();
|
2011-06-23 19:04:32 +04:00
|
|
|
$openid->SetIdentity($_GET['openid_identity']);
|
|
|
|
$openid_validation_result = $openid->ValidateWithServer();
|
|
|
|
if ($openid_validation_result == true){ // OK HERE KEY IS VALID
|
2012-05-01 19:38:27 +04:00
|
|
|
OCP\Util::writeLog('user_openid','auth sucessfull',OCP\Util::DEBUG);
|
2011-06-23 19:04:32 +04:00
|
|
|
$identity=$openid->GetIdentity();
|
2012-05-01 19:38:27 +04:00
|
|
|
OCP\Util::writeLog('user_openid','auth as '.$identity,OCP\Util::DEBUG);
|
2011-06-23 19:04:32 +04:00
|
|
|
$user=OC_USER_OPENID::findUserForIdentity($identity);
|
|
|
|
if($user){
|
|
|
|
$_SESSION['user_id']=$user;
|
2011-09-18 21:37:54 +04:00
|
|
|
header("Location: ".OC::$WEBROOT);
|
2011-06-23 19:04:32 +04:00
|
|
|
}
|
|
|
|
}else if($openid->IsError() == true){ // ON THE WAY, WE GOT SOME ERROR
|
|
|
|
$error = $openid->GetError();
|
2012-05-01 19:38:27 +04:00
|
|
|
OCP\Util::writeLog('user_openid','ERROR CODE: '. $error['code'],OCP\Util::ERROR);
|
|
|
|
OCP\Util::writeLog('user_openid','ERROR DESCRIPTION: '. $error['description'],OCP\Util::ERROR);
|
2011-06-23 19:04:32 +04:00
|
|
|
}else{ // Signature Verification Failed
|
2012-05-01 19:38:27 +04:00
|
|
|
OCP\Util::writeLog('user_openid','INVALID AUTHORIZATION',OCP\Util::ERROR);
|
2011-06-23 19:04:32 +04:00
|
|
|
}
|
|
|
|
}else if (isset($_GET['openid_mode']) and $_GET['openid_mode'] == 'cancel'){ // User Canceled your Request
|
2012-05-01 19:38:27 +04:00
|
|
|
OCP\Util::writeLog('user_openid','USER CANCELED REQUEST',OCP\Util::DEBUG);
|
2011-06-23 19:04:32 +04:00
|
|
|
return false;
|
|
|
|
}
|