Corrections du modèle de l'API

This commit is contained in:
xdrm-brackets 2016-06-04 11:06:36 +02:00
parent 095a550fc5
commit a68649303a
7 changed files with 35 additions and 30 deletions

View File

@ -5,6 +5,7 @@
use \router\Router; use \router\Router;
use \manager\ResourceDispatcher; use \manager\ResourceDispatcher;
use \manager\ModuleRequest; use \manager\ModuleRequest;
use \manager\ModuleResponse;
use \manager\ManagerError; use \manager\ManagerError;
use \manager\Database; use \manager\Database;
use \manager\MenuManager; use \manager\MenuManager;
@ -21,9 +22,6 @@
define('__REDIRECT__', 'Location: /dashboard/'); define('__REDIRECT__', 'Location: /dashboard/');
/* [x] Gestion des utilisateurs /* [x] Gestion des utilisateurs
=========================================================*/ =========================================================*/
/* (1) Valeurs par defaut */ /* (1) Valeurs par defaut */
@ -103,7 +101,7 @@
$answer = $request->dispatch(); $answer = $request->dispatch();
// Si c'est une réponse // Si c'est une réponse
if( !is_bool($answer) ) if( $answer instanceof ModuleResponse )
echo $answer->serialize(); echo $answer->serialize();
}); });

View File

@ -261,6 +261,7 @@
* *
*/ */
public static function fromPost($url, $post){ public static function fromPost($url, $post){
/* [0] Verification de l'authentification /* [0] Verification de l'authentification
=========================================================*/ =========================================================*/
// On definit le token // On definit le token
@ -270,7 +271,7 @@
/* [1] On verifie que le @path est renseigne /* [1] On verifie que le @path est renseigne
=========================================================*/ =========================================================*/
/* (1) Si le path est dans @url */ /* (1) Si le path est dans @url */
$pathInUrl = strlen($url[0]) > 0 && preg_match('#^([\w_-]+)/([\w_-]+)/?$#', $url[0], $urlMatches); $pathInUrl = is_string($url[0]) && strlen($url[0]) > 0 && preg_match('#^([\w_-]+)/([\w_-]+)/?$#', $url[0], $urlMatches);
// On l'utilise pour le chemin // On l'utilise pour le chemin
if( $pathInUrl ) if( $pathInUrl )
@ -300,7 +301,6 @@
if( !is_null($json) ) if( !is_null($json) )
$params[$name] = $json; $params[$name] = $json;
} }
/* [4] On retourne une instance de <ModuleRequest> /* [4] On retourne une instance de <ModuleRequest>
=========================================================*/ =========================================================*/
// On cree notre requete avec le token // On cree notre requete avec le token
@ -456,10 +456,12 @@
$isFile = isset($paramsdata['type']) && $paramsdata['type'] == 'FILE' && isset($_FILES[$name]); $isFile = isset($paramsdata['type']) && $paramsdata['type'] == 'FILE' && isset($_FILES[$name]);
/* (3) Si le paramètre est obligatoire et qu'il n'est pas donné -> erreur */ /* (3) Si le paramètre est obligatoire et qu'il n'est pas donné -> erreur */
if( !isset($params[$name]) && !$optional && !$isFile ) return false; if( !isset($params[$name]) && !$optional && !$isFile )
return false;
/* (4) Si le type n'est pas defini, on a pas besoin de le vérifier */ /* (4) Si le type n'est pas defini, on a pas besoin de le vérifier */
if( !isset($paramsdata['type']) ) continue; if( !isset($paramsdata['type']) )
continue;
/* (5) Si le paramètre est optionnel et n'est pas donné */ /* (5) Si le paramètre est optionnel et n'est pas donné */
if( $isFile || $optional && (!isset($params[$name]) || is_null($params[$name])) ){ if( $isFile || $optional && (!isset($params[$name]) || is_null($params[$name])) ){
@ -476,7 +478,8 @@
/* (6) Si le paramètre est renseigné */ /* (6) Si le paramètre est renseigné */
}else }else
// Si la verification est fausse, on retourne faux // Si la verification est fausse, on retourne faux
if( !Database::check($paramsdata['type'], $params[$name]) ) return false; if( !Database::check($paramsdata['type'], $params[$name]) )
return false;
} }

View File

@ -128,42 +128,45 @@
$content .= "+ Parameters\n\n"; $content .= "+ Parameters\n\n";
foreach($method['parameters'] as $argName=>$argument){ foreach($method['parameters'] as $argName=>$argument){
$optional = isset($argument['optional']) && $argument['optional'] === true; $optional = isset($argument['optional']) && $argument['optional'] === true;
$content .= " + _${argName}_ (${argument['type']}, ".( $optional ? 'optional' : 'required' ).") - ${argument['description']}\n"; $content .= " + $argName (${argument['type']}, ".( $optional ? 'optional' : 'required' ).") - ${argument['description']}\n";
} }
$content .= "\n"; $content .= "\n";
} }
/* (2) Requête */ /* (2) Requête */
$content .= "+ Request (multipart/form-data)\n\n"; $content .= "+ Request (multipart/form-data; boundary=xxxBOUNDARYxxx)\n\n";
// Header // Header
$content .= " + Headers\n\n"; $content .= " + Headers\n\n";
$content.= " Authorization: Digest {yourAccessToken}\n\n"; $content .= " Authorization: Digest {yourAccessToken}\n";
$content .= " Cache-Control: no-cache\n";
if( isset($method['parameters']) && count($method['parameters']) > 0 ){ if( isset($method['parameters']) && count($method['parameters']) > 0 ){
// Body // Body
$content .= " + Body\n\n"; $content .= " + Body\n\n";
$c = 0;
foreach($method['parameters'] as $argName=>$argument){ foreach($method['parameters'] as $argName=>$argument){
if( $c > 0 ) $content .= '&';
$content .= "$argName=_${argName}_"; $content .= " --xxxBOUNDARYxxx\n";
$c++; $content .= " Content-Disposition: form-data; name=\"$argName\"\n";
$content .= " Content-Type: application/json\n\n";
$content .= " @$argName\n";
} }
$content .= "\n\n"; $content .= " --xxxBOUNDARYxxx--\n";
// Schema // Schema
$content .= " + Schema\n\n"; $content .= " + Schema\n\n";
$content .= " {\n"; $content .= " {\n";
foreach($method['parameters'] as $argName=>$argData) foreach($method['parameters'] as $argName=>$argData)
$content .= " \"$argName\": _${argName}_\n"; $content .= " \"$argName\": @$argName\n";
$content .= " }\n\n"; $content .= " }\n";
} }
/* (3) Réponse */ /* (3) Réponse */
$content .= "+ Response 200 (application/json)\n\n"; $content .= "\n+ Response 200 (application/json)\n\n";
if( isset($method['output']) && count($method['output']) > 0 ){ if( isset($method['output']) && count($method['output']) > 0 ){
// Body // Body
@ -171,14 +174,14 @@
$content .= " {\n"; $content .= " {\n";
foreach($method['output'] as $outName=>$outData) foreach($method['output'] as $outName=>$outData)
$content .= " \"$outName\": @$outName\n"; $content .= " \"$outName\": @$outName\n";
$content .= " }\n\n"; $content .= " }\n";
// Schema // Schema
$content .= " + Schema\n\n"; $content .= " + Schema\n\n";
$content .= " {\n"; $content .= " {\n";
foreach($method['output'] as $outName=>$outData) foreach($method['output'] as $outName=>$outData)
$content .= " \"$outName\": @$outName\n"; $content .= " \"$outName\": @$outName\n";
$content .= " }\n\n"; $content .= " }\n";
// On explicite tous les paramètres // On explicite tous les paramètres
$content .= " + Attributes (object)\n\n"; $content .= " + Attributes (object)\n\n";

File diff suppressed because one or more lines are too long

View File

@ -1 +1 @@
{"1":{"line":0,"hash":"10a358a685d0fbdff78068d891fdd08f06011be4"},"2":{"line":1,"hash":"dad8b6bc0c54a329075ae2a5f55e188dc1fd13fa"}} {"1":{"line":0,"hash":"10a358a685d0fbdff78068d891fdd08f06011be4"},"2":{"line":1,"hash":"dad8b6bc0c54a329075ae2a5f55e188dc1fd13fa"},"":{"line":2,"hash":"847db4a9bf7f5397425f60a0c596910216ab8f7c"}}

View File

@ -1 +1 @@
349 361

View File

@ -22,11 +22,11 @@
<section data-sublink='presentation'> <section data-sublink='presentation'>
<center> <center>
<img src='/subfolder/f/svg/icon/st'/> <img src='/f/svg/icon/st'/>
<img src='/subfolder/f/svg/sms/st/credits'/> <img src='/f/svg/sms/st/credits'/>
<img src='/subfolder/f/jpg/cnrs/st/credits'/> <img src='/f/jpg/cnrs/st/credits'/>
<img src='/subfolder/f/png/univ_midi/st/credits'/> <img src='/f/png/univ_midi/st/credits'/>
<img src='/subfolder/f/png/ut2/st/credits'/> <img src='/f/png/ut2/st/credits'/>
</center> </center>
<p>Bienvenue sur la Web Application dévéloppée par des chercheurs du CNRS appartenant au LabEx SMS (Structuration des Mondes Sociaux) de l'université de Toulouse.</p> <p>Bienvenue sur la Web Application dévéloppée par des chercheurs du CNRS appartenant au LabEx SMS (Structuration des Mondes Sociaux) de l'université de Toulouse.</p>