2017-08-04 16:28:16 +02:00
|
|
|
<?php
|
|
|
|
|
2017-08-28 18:15:52 +02:00
|
|
|
function serverError()
|
|
|
|
{
|
2017-08-29 12:42:42 +02:00
|
|
|
$error = error_get_last();
|
|
|
|
if ($error['type'] == E_ERROR) {
|
|
|
|
ob_end_clean();
|
2017-09-04 10:24:44 +02:00
|
|
|
echo API::error('serverError');
|
2017-08-28 18:24:45 +02:00
|
|
|
}
|
2017-08-28 18:15:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Gestione degli errori
|
|
|
|
set_error_handler('serverError');
|
2017-08-28 18:24:45 +02:00
|
|
|
register_shutdown_function('serverError');
|
|
|
|
|
|
|
|
include_once __DIR__.'/../core.php';
|
|
|
|
|
|
|
|
// Disabilta la sessione per l'API
|
|
|
|
session_write_close();
|
2017-08-28 18:15:52 +02:00
|
|
|
|
2017-08-04 16:28:16 +02:00
|
|
|
// Permesso di accesso all'API da ogni dispositivo
|
|
|
|
header('Access-Control-Allow-Origin: *');
|
|
|
|
|
2018-01-12 16:23:26 +01:00
|
|
|
// Attenzione: al momento l'API permette la lettura di tutte le tabelle presenti nel database (non limitate a quelle del progetto)
|
2017-08-04 16:28:16 +02:00
|
|
|
|
|
|
|
try {
|
2017-08-29 12:42:42 +02:00
|
|
|
// Controlli sulla chiave di accesso
|
|
|
|
$api = new API();
|
2017-08-04 16:28:16 +02:00
|
|
|
|
2017-08-29 12:42:42 +02:00
|
|
|
// Lettura delle informazioni
|
|
|
|
$request = API::getRequest();
|
2017-08-28 18:15:52 +02:00
|
|
|
|
2018-01-12 16:23:26 +01:00
|
|
|
// Gestione della richiesta
|
2017-08-28 18:15:52 +02:00
|
|
|
$method = $_SERVER['REQUEST_METHOD'];
|
|
|
|
switch ($method) {
|
2018-01-12 16:23:26 +01:00
|
|
|
// Richiesta PUT (modifica elementi)
|
2017-08-28 18:15:52 +02:00
|
|
|
case 'PUT':
|
2017-08-29 12:42:42 +02:00
|
|
|
$result = $api->update($request);
|
2017-08-28 18:15:52 +02:00
|
|
|
break;
|
2018-01-12 16:23:26 +01:00
|
|
|
|
|
|
|
// Richiesta POST (creazione elementi)
|
2017-08-28 18:15:52 +02:00
|
|
|
case 'POST':
|
2017-08-29 12:42:42 +02:00
|
|
|
$result = $api->create($request);
|
2017-08-28 18:15:52 +02:00
|
|
|
break;
|
2018-01-12 16:23:26 +01:00
|
|
|
|
|
|
|
// Richiesta GET (ottenimento elementi)
|
2017-08-28 18:15:52 +02:00
|
|
|
case 'GET':
|
2018-01-12 16:23:26 +01:00
|
|
|
// Risorsa specificata
|
2018-05-04 18:50:15 +02:00
|
|
|
if (count($request) > 1) {
|
2017-08-29 12:42:42 +02:00
|
|
|
$result = $api->retrieve($request);
|
2018-01-12 16:23:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Risorsa non specificata (lista delle risorse disponibili)
|
|
|
|
else {
|
2017-08-28 18:15:52 +02:00
|
|
|
$result = API::response(API::getResources()['retrieve']);
|
|
|
|
}
|
|
|
|
break;
|
2018-01-12 16:23:26 +01:00
|
|
|
|
|
|
|
// Richiesta DELETE (eliminazione elementi)
|
2017-08-28 18:15:52 +02:00
|
|
|
case 'DELETE':
|
2017-08-29 12:42:42 +02:00
|
|
|
$result = $api->delete($request);
|
2017-08-28 18:15:52 +02:00
|
|
|
break;
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
} catch (InvalidArgumentException $e) {
|
2018-05-15 20:02:34 +02:00
|
|
|
$result = API::error('unauthorized');
|
2017-08-04 16:28:16 +02:00
|
|
|
} catch (Exception $e) {
|
|
|
|
$result = API::error('serverError');
|
|
|
|
}
|
|
|
|
|
2018-06-29 15:57:12 +02:00
|
|
|
json_decode($result);
|
|
|
|
|
|
|
|
// Impostazioni di Content-Type e Charset Header
|
|
|
|
if (json_last_error() == JSON_ERROR_NONE) {
|
|
|
|
header('Content-Type: application/json; charset=UTF-8');
|
|
|
|
} else {
|
|
|
|
header('Content-Type: text/plain; charset=UTF-8');
|
|
|
|
}
|
|
|
|
|
2018-01-12 16:23:26 +01:00
|
|
|
// Stampa dei risultati
|
2017-08-04 16:28:16 +02:00
|
|
|
echo $result;
|