FFNMaster
68b3b402e7
Resolves #74 More tests are needed in order to prove functioning of renewed core
117 lines
3.5 KiB
PHP
117 lines
3.5 KiB
PHP
<?php
|
|
|
|
namespace Module\Api;
|
|
use \FuzeWorks\Module;
|
|
|
|
class RestApi extends Module {
|
|
|
|
public function onLoad() {}
|
|
|
|
/**
|
|
* Property: method
|
|
* The HTTP method this request was made in, either GET, POST, PUT or DELETE
|
|
*/
|
|
public $method = '';
|
|
/**
|
|
* Property: endpoint
|
|
* The Model requested in the URI. eg: /files
|
|
*/
|
|
public $endpoint = '';
|
|
/**
|
|
* Property: verb
|
|
* An optional additional descriptor about the endpoint, used for things that can
|
|
* not be handled by the basic methods. eg: /files/process
|
|
*/
|
|
public $verb = '';
|
|
/**
|
|
* Property: args
|
|
* Any additional URI components after the endpoint and verb have been removed, in our
|
|
* case, an integer ID for the resource. eg: /<endpoint>/<verb>/<arg0>/<arg1>
|
|
* or /<endpoint>/<arg0>
|
|
*/
|
|
public $args = Array();
|
|
/**
|
|
* Property: file
|
|
* Stores the input of the PUT request
|
|
*/
|
|
public $file = Null;
|
|
|
|
/**
|
|
* Request
|
|
* Allow for CORS, assemble and pre-process the data
|
|
*/
|
|
public function request($request) {
|
|
header("Access-Control-Allow-Orgin: *");
|
|
header("Access-Control-Allow-Methods: *");
|
|
header("Content-Type: application/json");
|
|
|
|
$this->args = explode('/', rtrim($request, '/'));
|
|
$this->endpoint = array_shift($this->args);
|
|
if (array_key_exists(0, $this->args) && !is_numeric($this->args[0])) {
|
|
$this->verb = array_shift($this->args);
|
|
}
|
|
|
|
$this->method = $_SERVER['REQUEST_METHOD'];
|
|
if ($this->method == 'POST' && array_key_exists('HTTP_X_HTTP_METHOD', $_SERVER)) {
|
|
if ($_SERVER['HTTP_X_HTTP_METHOD'] == 'DELETE') {
|
|
$this->method = 'DELETE';
|
|
} else if ($_SERVER['HTTP_X_HTTP_METHOD'] == 'PUT') {
|
|
$this->method = 'PUT';
|
|
} else {
|
|
throw new Exception("Unexpected Header");
|
|
}
|
|
}
|
|
|
|
switch($this->method) {
|
|
case 'DELETE':
|
|
case 'POST':
|
|
$this->request = $this->_cleanInputs($_POST);
|
|
break;
|
|
case 'GET':
|
|
$this->request = $this->_cleanInputs($_GET);
|
|
break;
|
|
case 'PUT':
|
|
$this->request = $this->_cleanInputs($_GET);
|
|
$this->file = file_get_contents("php://input");
|
|
break;
|
|
default:
|
|
$this->_response('Invalid Method', 405);
|
|
break;
|
|
}
|
|
}
|
|
|
|
public function processAPI() {
|
|
if ((int)method_exists($this, $this->endpoint) > 0) {
|
|
return $this->_response($this->{$this->endpoint}($this->args));
|
|
}
|
|
return $this->_response("No Endpoint: $this->endpoint", 404);
|
|
}
|
|
|
|
private function _response($data, $status = 200) {
|
|
header("HTTP/1.1 " . $status . " " . $this->_requestStatus($status));
|
|
return json_encode($data);
|
|
}
|
|
|
|
private function _cleanInputs($data) {
|
|
$clean_input = Array();
|
|
if (is_array($data)) {
|
|
foreach ($data as $k => $v) {
|
|
$clean_input[$k] = $this->_cleanInputs($v);
|
|
}
|
|
} else {
|
|
$clean_input = trim(strip_tags($data));
|
|
}
|
|
return $clean_input;
|
|
}
|
|
|
|
private function _requestStatus($code) {
|
|
$status = array(
|
|
200 => 'OK',
|
|
404 => 'Not Found',
|
|
405 => 'Method Not Allowed',
|
|
500 => 'Internal Server Error',
|
|
);
|
|
return ($status[$code])?$status[$code]:$status[500];
|
|
}
|
|
|
|
} |