|
|
|
@ -1,6 +1,5 @@
|
|
|
|
|
<?php |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* EBSCO API class |
|
|
|
|
* |
|
|
|
@ -8,19 +7,17 @@
|
|
|
|
|
* |
|
|
|
|
*/ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* EBSCO API class |
|
|
|
|
*/ |
|
|
|
|
class EBSCOAPI |
|
|
|
|
{ |
|
|
|
|
class EBSCOAPI { |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* The authentication token used for API transactions |
|
|
|
|
* @global string |
|
|
|
|
*/ |
|
|
|
|
private $authenticationToken; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* The session token for API transactions |
|
|
|
|
* @global string |
|
|
|
@ -32,7 +29,6 @@ class EBSCOAPI
|
|
|
|
|
* @global object EBSCOConnector |
|
|
|
|
*/ |
|
|
|
|
private $connector; |
|
|
|
|
|
|
|
|
|
private $config; |
|
|
|
|
|
|
|
|
|
public function __construct($config) { |
|
|
|
@ -48,8 +44,7 @@ class EBSCOAPI
|
|
|
|
|
* @return EBSCOConnector object |
|
|
|
|
* @access public |
|
|
|
|
*/ |
|
|
|
|
public function connector($config) |
|
|
|
|
{ |
|
|
|
|
public function connector($config) { |
|
|
|
|
if (empty($this->connector)) { |
|
|
|
|
$this->connector = new EBSCOConnector($config); |
|
|
|
|
} |
|
|
|
@ -57,7 +52,6 @@ class EBSCOAPI
|
|
|
|
|
return $this->connector; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* Create a new EBSCOResponse object |
|
|
|
|
* |
|
|
|
@ -66,13 +60,11 @@ class EBSCOAPI
|
|
|
|
|
* @return EBSCOResponse object |
|
|
|
|
* @access public |
|
|
|
|
*/ |
|
|
|
|
public function response($response) |
|
|
|
|
{ |
|
|
|
|
public function response($response) { |
|
|
|
|
$responseObj = new EBSCOResponse($response); |
|
|
|
|
return $responseObj; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* Request authentication and session tokens, then send the API request. |
|
|
|
|
* Retry the request if authentication errors occur |
|
|
|
@ -85,8 +77,7 @@ class EBSCOAPI
|
|
|
|
|
* @return array An associative array with results. |
|
|
|
|
* @access protected |
|
|
|
|
*/ |
|
|
|
|
protected function request($action, $params = null, $attempts = 3) |
|
|
|
|
{ |
|
|
|
|
protected function request($action, $params = null, $attempts = 3) { |
|
|
|
|
try { |
|
|
|
|
|
|
|
|
|
$authenticationToken = $this->getAuthToken(); |
|
|
|
@ -156,7 +147,7 @@ class EBSCOAPI
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
private function writeLockFile(){ |
|
|
|
|
private function writeTokenFile() { |
|
|
|
|
$tokenFile = fopen("edstoken.txt", "w+"); |
|
|
|
|
$result = $this->apiAuthenticationToken(); |
|
|
|
|
fwrite($tokenFile, $result['authenticationToken'] . "\n"); |
|
|
|
@ -166,6 +157,12 @@ class EBSCOAPI
|
|
|
|
|
return $result['authenticationToken']; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
private function writeLockFile() { |
|
|
|
|
$lockFile = fopen("edslock.txt", "w+"); |
|
|
|
|
fwrite($lockFile, 'lock'); |
|
|
|
|
fclose($lockFile); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/* |
|
|
|
|
* Get authentication token from appication scop |
|
|
|
|
* Check authToen's expiration |
|
|
|
@ -175,11 +172,17 @@ class EBSCOAPI
|
|
|
|
|
* |
|
|
|
|
* @access public |
|
|
|
|
*/ |
|
|
|
|
|
|
|
|
|
public function getAuthToken() { |
|
|
|
|
$lockFile = fopen("edslock.txt", "r"); |
|
|
|
|
if (empty($lockFile)) { |
|
|
|
|
$this->writeLockFile(); |
|
|
|
|
$lockFile = fopen("edslock.txt", "r"); |
|
|
|
|
} |
|
|
|
|
$tokenFile = fopen("edstoken.txt", "r"); |
|
|
|
|
if (empty($tokenFile)) { |
|
|
|
|
$this->writetokenFile(); |
|
|
|
|
$tokenFile = fopen("edstoken.txt", "r"); |
|
|
|
|
if(empty($lockFile) || empty($tokenFile)){ |
|
|
|
|
return $this->writeLockFile(); |
|
|
|
|
} |
|
|
|
|
while (!feof($tokenFile)) { |
|
|
|
|
$authToken = rtrim(fgets($tokenFile), "\n"); |
|
|
|
@ -197,10 +200,12 @@ class EBSCOAPI
|
|
|
|
|
fwrite($tokenFile, $result['authenticationTimeStamp']); |
|
|
|
|
fclose($tokenFile); |
|
|
|
|
return $result['authenticationToken']; |
|
|
|
|
}else{ |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
return $authToken; |
|
|
|
|
} |
|
|
|
|
}else{ |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
return $authToken; |
|
|
|
|
} |
|
|
|
|
fclose($lockFile); |
|
|
|
@ -213,8 +218,7 @@ class EBSCOAPI
|
|
|
|
|
* |
|
|
|
|
* @access public |
|
|
|
|
*/ |
|
|
|
|
public function apiAuthenticationToken() |
|
|
|
|
{ |
|
|
|
|
public function apiAuthenticationToken() { |
|
|
|
|
$response = $this->connector->requestAuthenticationToken(); |
|
|
|
|
$result = $this->response($response)->result(); |
|
|
|
|
return $result; |
|
|
|
@ -232,35 +236,30 @@ class EBSCOAPI
|
|
|
|
|
$token = ''; |
|
|
|
|
|
|
|
|
|
// Check user's login status |
|
|
|
|
if(isset($_COOKIE['login'])){ |
|
|
|
|
/* if(isset($_COOKIE['login'])){ |
|
|
|
|
if($invalid=='y'){ |
|
|
|
|
$profile = $_SESSION['sessionToken']['profile']; |
|
|
|
|
$sessionToken = $this->apiSessionToken($authenToken, $profile,'n'); |
|
|
|
|
$_SESSION['sessionToken']=$sessionToken; |
|
|
|
|
} |
|
|
|
|
$token = $_SESSION['sessionToken']['sessionToken']; |
|
|
|
|
} |
|
|
|
|
else if(isset($_COOKIE['Guest'])){ |
|
|
|
|
} */ |
|
|
|
|
//else |
|
|
|
|
if (isset($_COOKIE['Guest'])) { |
|
|
|
|
if ($invalid == 'y') { |
|
|
|
|
$profile = $_SESSION['sessionToken']['profile']; |
|
|
|
|
if (empty($profile)) { |
|
|
|
|
$profile = $_COOKIE['Guest']; |
|
|
|
|
} |
|
|
|
|
$sessionToken = $this->apiSessionToken($authenToken, $profile, 'y'); |
|
|
|
|
$_SESSION['sessionToken'] = $sessionToken; |
|
|
|
|
} |
|
|
|
|
$token = $_SESSION['sessionToken']['sessionToken']; |
|
|
|
|
}else{ |
|
|
|
|
//$xml ="Config.xml"; |
|
|
|
|
//$dom = new DOMDocument(); |
|
|
|
|
//$dom->load($xml); |
|
|
|
|
//$EDSCredentials = $dom ->getElementsByTagName('EDSCredentials')->item(0); |
|
|
|
|
//$users = $EDSCredentials -> getElementsByTagName('User'); |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
|
|
|
|
|
$profileId = $this->config['profile']; |
|
|
|
|
//foreach($users as $user){ |
|
|
|
|
// $userType = $user->getElementsByTagName('ClientUser')->item(0)->nodeValue; |
|
|
|
|
// if($userType == 'guest'){ |
|
|
|
|
// $profileId = $user -> getElementsByTagName('EDSProfile')->item(0)->nodeValue; |
|
|
|
|
// break; |
|
|
|
|
// } |
|
|
|
|
//} |
|
|
|
|
|
|
|
|
|
$sessionToken = $this->apiSessionToken($authenToken, $profileId, 'y'); |
|
|
|
|
$_SESSION['profile'] = $profileId; |
|
|
|
|
$_SESSION['sessionToken'] = $sessionToken; |
|
|
|
@ -277,8 +276,7 @@ class EBSCOAPI
|
|
|
|
|
* |
|
|
|
|
* @access public |
|
|
|
|
*/ |
|
|
|
|
public function apiSessionToken($authenToken, $profile, $guest) |
|
|
|
|
{ |
|
|
|
|
public function apiSessionToken($authenToken, $profile, $guest) { |
|
|
|
|
// Add authentication tokens to headers |
|
|
|
|
$headers = array( |
|
|
|
|
'x-authenticationToken: ' . $authenToken |
|
|
|
@ -325,7 +323,6 @@ class EBSCOAPI
|
|
|
|
|
return $results; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* Wrapper for retrieve API call |
|
|
|
|
* |
|
|
|
@ -336,8 +333,7 @@ class EBSCOAPI
|
|
|
|
|
* @return array An associative array of data |
|
|
|
|
* @access public |
|
|
|
|
*/ |
|
|
|
|
public function apiRetrieve($an, $db, $term) |
|
|
|
|
{ |
|
|
|
|
public function apiRetrieve($an, $db, $term) { |
|
|
|
|
// Add the HTTP query params |
|
|
|
|
$params = array( |
|
|
|
|
'an' => $an, |
|
|
|
@ -349,15 +345,13 @@ class EBSCOAPI
|
|
|
|
|
return $result; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* Wrapper for info API call |
|
|
|
|
* |
|
|
|
|
* @return array An associative array of data |
|
|
|
|
* @access public |
|
|
|
|
*/ |
|
|
|
|
public function getInfo() |
|
|
|
|
{ |
|
|
|
|
public function getInfo() { |
|
|
|
|
if (isset($_SESSION['info'])) { |
|
|
|
|
$InfoArray = $_SESSION['info']; |
|
|
|
|
$timestamp = $InfoArray['timestamp']; |
|
|
|
@ -366,10 +360,12 @@ class EBSCOAPI
|
|
|
|
|
$InfoArray = $this->apiInfo(); |
|
|
|
|
$_SESSION['info'] = $InfoArray; |
|
|
|
|
$info = $InfoArray['Info']; |
|
|
|
|
}else{ |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
$info = $InfoArray['Info']; |
|
|
|
|
} |
|
|
|
|
}else{ |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
// Get new Info for the profile |
|
|
|
|
$InfoArray = $this->apiInfo(); |
|
|
|
|
$_SESSION['info'] = $InfoArray; |
|
|
|
@ -387,5 +383,7 @@ class EBSCOAPI
|
|
|
|
|
); |
|
|
|
|
return $Info; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
?> |