2018-02-17 17:18:58 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**************************
|
|
|
|
* API Response *
|
|
|
|
* 08-12-2016 *
|
|
|
|
***************************
|
|
|
|
* Designed & Developed by *
|
|
|
|
* xdrm-brackets *
|
|
|
|
***************************
|
|
|
|
* https://xdrm.io/ *
|
|
|
|
**************************/
|
|
|
|
|
|
|
|
namespace api\core;
|
|
|
|
use \error\core\Error;
|
|
|
|
use \error\core\Err;
|
|
|
|
|
|
|
|
class Response{
|
|
|
|
|
|
|
|
// Attributs prives utiles (initialisation)
|
|
|
|
private $data;
|
|
|
|
public $error;
|
|
|
|
|
|
|
|
|
|
|
|
/* CONSTRUCTEUR D'UNE REPONSE DE MODULE
|
|
|
|
*
|
|
|
|
* @error<ModuleError> Erreur passee par la requete (si existe)
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function __construct($error=null){
|
|
|
|
if( !( $error instanceof Error ) )
|
|
|
|
$error = new Error(Err::Success);
|
|
|
|
|
|
|
|
$this->data = [];
|
|
|
|
$this->error = $error;
|
|
|
|
}
|
|
|
|
/* AJOUTE UNE DONNEE A LA REPONSE
|
|
|
|
|
|
|
|
|
|
|
|
*
|
|
|
|
* @key<String> Le nom de la valeur a ajouter
|
|
|
|
* @value<mixed*> La valeur a ajouter
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function append($key, $value){
|
|
|
|
// Ajoute une entree pour la cle @key et de valeur @value
|
|
|
|
$this->data[$key] = $value;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* AJOUTE TOUTES LES DONNEES A LA REPONSE
|
|
|
|
*
|
|
|
|
* @dataset<Array> Le tableau associatif correspondant a la reponse
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function appendAll($dataset){
|
|
|
|
// Si ce n'est pas un tableau, on ne fais rien
|
|
|
|
if( !is_array($dataset) )
|
|
|
|
return $this;
|
|
|
|
|
|
|
|
// Si une valeur contient une erreur
|
|
|
|
if( array_key_exists('error', $dataset) && $dataset['error'] instanceof Error){
|
|
|
|
// On definit cette erreur
|
|
|
|
$this->error = $dataset['error'];
|
|
|
|
// On enleve cette entree des donnees
|
|
|
|
unset($dataset['error']);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Ajoute une entree pour la cle @key et de valeur @value
|
|
|
|
$this->data = $dataset;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
/* RECUPERE UNE DONNEE DE LA REPONSE
|
|
|
|
|
|
|
|
|
|
|
|
*
|
|
|
|
* @key<String> Le nom de la valeur a recuperer
|
|
|
|
*
|
|
|
|
* @return value<mixed*> La valeur a cette cle
|
|
|
|
* @return error<null> Retourne NULL si aucune valeur pour cette cle
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function get($key){
|
|
|
|
// Si la valeur de cle @key n'existe pas, on retourne NULL
|
|
|
|
if( !isset($this->data[$key]) )
|
|
|
|
return null;
|
|
|
|
|
|
|
|
// Sinon, on retourne la valeur associee
|
|
|
|
return $this->data[$key];
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* RECUPERE TOUTES LES DONNEES DE LA REPONSE
|
|
|
|
*
|
|
|
|
* @return data<Array> Les donnees de la reponse
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function getAll(){
|
|
|
|
// Sinon, on retourne la valeur associee
|
|
|
|
return $this->data;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* SERIALISATION A PARTIR DES DONNEES
|
|
|
|
*
|
|
|
|
* @return json<String> Retourne les donnees serialisees
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function serialize(){
|
|
|
|
|
|
|
|
// Code Http
|
|
|
|
$this->error->setHttpCode();
|
|
|
|
|
|
|
|
// Type de contenu
|
2018-02-17 18:02:00 +00:00
|
|
|
// header('Content-Type: application/json; charset=utf-8');
|
2018-02-17 17:18:58 +00:00
|
|
|
|
|
|
|
// On rajoute l'erreur au message
|
|
|
|
$returnData = array_merge([
|
|
|
|
'error' => $this->error->get(),
|
|
|
|
'ErrorDescription' => $this->error->explicit()
|
|
|
|
],
|
|
|
|
$this->data
|
|
|
|
);
|
|
|
|
|
|
|
|
return json_encode($returnData);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
?>
|