ComunicAPI/classes/tokens.php

60 lines
1.4 KiB
PHP
Raw Normal View History

2017-05-17 14:43:12 +02:00
<?php
/**
* Tokens checker class
*
* @author Pierre HUBERT
*/
class Tokens{
/**
2017-05-19 18:07:52 +02:00
* Check request client tokens
2017-05-17 14:43:12 +02:00
*
* @return Boolean Depends of the validity of the tokens
*/
2017-05-19 18:07:52 +02:00
public function checkClientRequestTokens(){
2017-05-17 14:43:12 +02:00
if(!isset($_POST['serviceName']) OR !isset($_POST['serviceToken']))
return false; //No token specified
//Check tokens
2017-05-19 18:07:52 +02:00
if(!$serviceID = $this->validateClientTokens($_POST['serviceName'], $_POST['serviceToken']))
2017-05-17 14:43:12 +02:00
return false;
//Save service ID in a constant
define("APIServiceID", $serviceID);
//Else everything went good
return true;
}
/**
2017-05-19 18:07:52 +02:00
* Check client API credentials (tokens)
2017-05-17 14:43:12 +02:00
*
* @param String $serviceName The name of the service
* @param String $token The service's token
* @return Boolean False or Tokens ID / Depending of validity of credentials
*/
2017-05-19 18:07:52 +02:00
private function validateClientTokens($serviceName, $token){
2017-05-17 14:43:12 +02:00
//Prepare DataBase request
2017-06-07 14:53:58 +02:00
$tableName = CS::get()->config->get("dbprefix")."API_ServicesToken";
2017-05-17 14:43:12 +02:00
$conditions = "WHERE serviceName = ? AND token = ?";
$values = array(
$serviceName,
$token
);
//Make request
$requestResult = CS::get()->db->select($tableName, $conditions, $values);
//Analyse result
if(count($requestResult) == 0){
//There is no available entries
return false;
}
else {
//The API is correctly identified
return $requestResult[0]['ID'];
}
}
}