mirror of
https://github.com/daledavies/jump.git
synced 2026-01-14 03:12:06 +01:00
Refactor APIs to use routing
This commit is contained in:
39
jumpapp/classes/API/AbstractAPI.php
Normal file
39
jumpapp/classes/API/AbstractAPI.php
Normal file
@@ -0,0 +1,39 @@
|
||||
<?php
|
||||
|
||||
namespace Jump\API;
|
||||
|
||||
abstract class AbstractAPI {
|
||||
|
||||
public function __construct(
|
||||
protected \Jump\Config $config,
|
||||
protected \Jump\Cache $cache,
|
||||
protected \Nette\Http\Session $session,
|
||||
protected ?array $routeparams
|
||||
){}
|
||||
|
||||
protected function send_json_header(): void {
|
||||
header('Content-Type: application/json; charset=utf-8');
|
||||
}
|
||||
|
||||
protected function validate_token(): void {
|
||||
$this->send_json_header();
|
||||
|
||||
// Get a Nette session section for CSRF data.
|
||||
$csrfsection = $this->session->getSection('csrf');
|
||||
|
||||
// Has a CSRF token been set up for the session yet?
|
||||
if (!$csrfsection->offsetExists('token')){
|
||||
http_response_code(401);
|
||||
die(json_encode(['error' => 'Session not fully set up']));
|
||||
}
|
||||
|
||||
// Check CSRF token saved in session against token provided via request.
|
||||
if (!isset($this->routeparams['token']) || !hash_equals($csrfsection->get('token'), $this->routeparams['token'])) {
|
||||
http_response_code(401);
|
||||
die(json_encode(['error' => 'API token is incorrect or missing']));
|
||||
}
|
||||
}
|
||||
|
||||
abstract protected function get_output(): string;
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user