PHP_SMART_HOME_V3/library/ApiController.php
2020-05-13 11:35:54 +02:00

37 lines
931 B
PHP

<?php
class ApiController {
protected $input;
protected $authenticated = false;
function __construct() {
$input = file_get_contents('php://input');
if(empty($input)){
$this->input = NULL;
}else{
$this->input = json_decode($input, true);
if(json_last_error() != JSON_ERROR_NONE){
throw new Exception("Invalid request payload", 400);
}
}
}
protected function requireAuth(){
if (isset($_SERVER['HTTP_AUTHORIZATION'])) {
// TODO: call appropriate class/method
$authManager = new AuthManager();
$this->authenticated = $authManager>validateToken($_SERVER['HTTP_AUTHORIZATION']);
if(!$this->authenticated){
throw new Exception("Authorization required", 401);
}
} else {
throw new Exception("Authorization required", 401);
}
}
protected function response($data = [], $httpCode = '200'){
http_response_code($httpCode);
echo json_encode($data, JSON_UNESCAPED_UNICODE);
}
}