2017-03-24 17:16:34 +00:00
|
|
|
<?php
|
|
|
|
declare(strict_types=1);
|
2017-03-28 04:12:12 +00:00
|
|
|
namespace JKingWeb\Arsse\REST;
|
2017-03-24 17:16:34 +00:00
|
|
|
|
|
|
|
abstract class AbstractHandler implements Handler {
|
2017-07-07 19:25:47 +00:00
|
|
|
use \JKingWeb\Arsse\Misc\DateFormatter;
|
|
|
|
|
2017-04-07 01:41:21 +00:00
|
|
|
abstract function __construct();
|
|
|
|
abstract function dispatch(Request $req): Response;
|
2017-05-19 03:03:33 +00:00
|
|
|
|
2017-07-07 12:13:03 +00:00
|
|
|
protected function fieldMapNames(array $data, array $map): array {
|
|
|
|
$out = [];
|
|
|
|
foreach($map as $to => $from) {
|
2017-05-19 03:03:33 +00:00
|
|
|
if(array_key_exists($from, $data)) {
|
2017-07-07 12:13:03 +00:00
|
|
|
$out[$to] = $data[$from];
|
2017-05-19 03:03:33 +00:00
|
|
|
}
|
|
|
|
}
|
2017-07-07 12:13:03 +00:00
|
|
|
return $out;
|
2017-05-19 03:03:33 +00:00
|
|
|
}
|
|
|
|
|
2017-07-07 19:25:47 +00:00
|
|
|
protected function fieldMapTypes(array $data, array $map, string $dateFormat = "sql"): array {
|
2017-05-19 03:03:33 +00:00
|
|
|
foreach($map as $key => $type) {
|
2017-07-07 19:25:47 +00:00
|
|
|
if(array_key_exists($key, $data)) {
|
|
|
|
if($type=="datetime" && $dateFormat != "sql") {
|
|
|
|
$data[$key] = $this->dateTransform($data[$key], $dateFormat, "sql");
|
|
|
|
} else {
|
|
|
|
settype($data[$key], $type);
|
|
|
|
}
|
|
|
|
}
|
2017-05-19 03:03:33 +00:00
|
|
|
}
|
|
|
|
return $data;
|
|
|
|
}
|
|
|
|
|
2017-07-07 12:13:03 +00:00
|
|
|
protected function validateInt($id): bool {
|
2017-07-08 01:06:38 +00:00
|
|
|
$ch1 = strval(@intval($id));
|
|
|
|
$ch2 = strval($id);
|
2017-05-19 03:03:33 +00:00
|
|
|
return ($ch1 === $ch2);
|
|
|
|
}
|
|
|
|
|
2017-07-07 19:25:47 +00:00
|
|
|
protected function NormalizeInput(array $data, array $types, string $dateFormat = null): array {
|
2017-07-07 12:13:03 +00:00
|
|
|
$out = [];
|
|
|
|
foreach($data as $key => $value) {
|
|
|
|
if(!isset($types[$key])) {
|
|
|
|
$out[$key] = $value;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if(is_null($value)) {
|
|
|
|
$out[$key] = null;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
switch($types[$key]) {
|
|
|
|
case "int":
|
|
|
|
if($this->validateInt($value)) $out[$key] = (int) $value;
|
|
|
|
break;
|
|
|
|
case "string":
|
|
|
|
$out[$key] = (string) $value;
|
|
|
|
break;
|
|
|
|
case "bool":
|
|
|
|
if(is_bool($value)) {
|
|
|
|
$out[$key] = $value;
|
|
|
|
} else if($this->validateInt($value)) {
|
|
|
|
$value = (int) $value;
|
|
|
|
if($value > -1 && $value < 2) $out[$key] = $value;
|
|
|
|
} else if(is_string($value)) {
|
|
|
|
$value = trim(strtolower($value));
|
|
|
|
if($value=="false") $out[$key] = false;
|
|
|
|
if($value=="true") $out[$key] = true;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case "float":
|
|
|
|
if(is_numeric($value)) $out[$key] = (float) $value;
|
|
|
|
break;
|
|
|
|
case "datetime":
|
2017-07-07 19:25:47 +00:00
|
|
|
$t = $this->dateNormalize($value, $dateFormat);
|
2017-07-07 12:13:03 +00:00
|
|
|
if($t) $out[$key] = $t;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
throw new Exception("typeUnknown", $types[$key]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $out;
|
|
|
|
}
|
2017-03-24 17:16:34 +00:00
|
|
|
}
|