2017-03-13 23:22:20 -04:00
|
|
|
<?php
|
|
|
|
declare(strict_types=1);
|
2017-03-27 23:12:12 -05:00
|
|
|
namespace JKingWeb\Arsse;
|
2017-03-13 23:22:20 -04:00
|
|
|
|
|
|
|
class REST {
|
2017-03-18 22:30:36 -04:00
|
|
|
protected $apis = [
|
|
|
|
// NextCloud News version enumerator
|
|
|
|
'ncn' => [
|
|
|
|
'match' => '/index.php/apps/news/api',
|
|
|
|
'strip' => '/index.php/apps/news/api',
|
|
|
|
'class' => REST\NextCloudNews\Versions::class,
|
|
|
|
],
|
|
|
|
// NextCloud News v1-2 https://github.com/nextcloud/news/blob/master/docs/externalapi/Legacy.md
|
|
|
|
'ncn_v1-2' => [
|
|
|
|
'match' => '/index.php/apps/news/api/v1-2/',
|
|
|
|
'strip' => '/index.php/apps/news/api/v1-2',
|
|
|
|
'class' => REST\NextCloudNews\V1_2::class,
|
|
|
|
],
|
|
|
|
// Other candidates:
|
|
|
|
// NextCloud News v2 https://github.com/nextcloud/news/blob/master/docs/externalapi/External-Api.md
|
|
|
|
// Feedbin v1 https://github.com/feedbin/feedbin-api/commit/86da10aac5f1a57531a6e17b08744e5f9e7db8a9
|
|
|
|
// Feedbin v2 https://github.com/feedbin/feedbin-api
|
|
|
|
// Tiny Tiny RSS https://tt-rss.org/gitlab/fox/tt-rss/wikis/ApiReference
|
|
|
|
// Fever https://feedafever.com/api
|
|
|
|
// NewsBlur http://www.newsblur.com/api
|
2017-07-15 16:44:06 -04:00
|
|
|
// Miniflux https://github.com/miniflux/miniflux/blob/master/docs/json-rpc-api.markdown
|
|
|
|
// CommaFeed https://www.commafeed.com/api/
|
2017-03-18 22:30:36 -04:00
|
|
|
];
|
2017-04-06 21:41:21 -04:00
|
|
|
|
2017-03-28 18:50:00 -04:00
|
|
|
function __construct() {
|
2017-03-18 22:30:36 -04:00
|
|
|
}
|
2017-03-13 23:22:20 -04:00
|
|
|
|
2017-03-18 22:30:36 -04:00
|
|
|
function dispatch(REST\Request $req = null): bool {
|
|
|
|
if($req===null) $req = new REST\Request();
|
2017-04-01 23:06:52 -04:00
|
|
|
$api = $this->apiMatch($req->url, $this->apis);
|
|
|
|
$req->url = substr($req->url,strlen($this->apis[$api]['strip']));
|
|
|
|
$req->refreshURL();
|
2017-03-18 22:30:36 -04:00
|
|
|
$class = $this->apis[$api]['class'];
|
2017-03-28 18:50:00 -04:00
|
|
|
$drv = new $class();
|
2017-04-01 23:06:52 -04:00
|
|
|
$out = $drv->dispatch($req);
|
2017-07-15 16:44:06 -04:00
|
|
|
header("Status: ".$out->code." ".Data::$lang->msg("HTTP.Status.".$out->code));
|
|
|
|
if(!is_null($out->payload)) {
|
|
|
|
header("Content-Type: ".$out->type);
|
|
|
|
switch($out->type) {
|
|
|
|
case REST\Response::T_JSON:
|
|
|
|
$body = json_encode($out->payload,\JSON_PRETTY_PRINT);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$body = (string) $out->payload;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
foreach($out->fields as $field) {
|
|
|
|
header($field);
|
|
|
|
}
|
|
|
|
echo $body;
|
2017-03-18 22:30:36 -04:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
function apiMatch(string $url, array $map): string {
|
|
|
|
// sort the API list so the longest URL prefixes come first
|
|
|
|
uasort($map, function($a, $b) {return (strlen($a['match']) <=> strlen($b['match'])) * -1;});
|
|
|
|
// find a match
|
|
|
|
foreach($map as $id => $api) {
|
|
|
|
if(strpos($url, $api['match'])===0) return $id;
|
|
|
|
}
|
|
|
|
// or throw an exception otherwise
|
2017-07-15 16:44:06 -04:00
|
|
|
throw new REST\Exception501();
|
2017-03-18 22:30:36 -04:00
|
|
|
}
|
2017-03-13 23:22:20 -04:00
|
|
|
}
|