2023-04-23 00:01:51 +00:00
|
|
|
<?php
|
|
|
|
|
2023-04-25 16:35:52 +00:00
|
|
|
// Current version
|
2023-05-10 09:47:36 +00:00
|
|
|
define('API_VERSION', 0.8);
|
2023-04-25 16:35:52 +00:00
|
|
|
|
2023-04-23 00:01:51 +00:00
|
|
|
// Load system dependencies
|
|
|
|
require_once('../config/app.php');
|
|
|
|
require_once('../library/curl.php');
|
|
|
|
require_once('../library/robots.php');
|
|
|
|
require_once('../library/filter.php');
|
|
|
|
require_once('../library/parser.php');
|
|
|
|
require_once('../library/mysql.php');
|
|
|
|
require_once('../library/sphinxql.php');
|
|
|
|
|
2023-04-23 00:25:43 +00:00
|
|
|
if (API_ENABLED) {
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-23 00:25:43 +00:00
|
|
|
// Action
|
|
|
|
switch (!empty($_GET['action']) ? $_GET['action'] : false) {
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-23 00:25:43 +00:00
|
|
|
// Search API
|
|
|
|
case 'search';
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-25 16:35:52 +00:00
|
|
|
if (API_SEARCH_ENABLED) {
|
|
|
|
|
|
|
|
// Connect database
|
|
|
|
$db = new MySQL(DB_HOST, DB_PORT, DB_NAME, DB_USERNAME, DB_PASSWORD);
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-25 16:35:52 +00:00
|
|
|
// Connect Sphinx search server
|
|
|
|
$sphinx = new SphinxQL(SPHINX_HOST, SPHINX_PORT);
|
2023-04-23 00:01:51 +00:00
|
|
|
|
|
|
|
|
2023-04-25 16:35:52 +00:00
|
|
|
// Filter request data
|
2023-05-10 22:45:36 +00:00
|
|
|
$type = !empty($_GET['type']) ? Filter::url($_GET['type']) : 'text';
|
2023-05-01 17:09:28 +00:00
|
|
|
$mode = !empty($_GET['mode']) ? Filter::url($_GET['mode']) : 'default';
|
2023-04-25 16:35:52 +00:00
|
|
|
$query = !empty($_GET['query']) ? Filter::url($_GET['query']) : '';
|
2023-05-01 17:09:28 +00:00
|
|
|
$page = !empty($_GET['page']) ? (int) $_GET['page'] : 1;
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-05-10 09:47:36 +00:00
|
|
|
// Make search request
|
|
|
|
$sphinxResultsTotal = $sphinx->searchHostPagesTotal(Filter::searchQuery($query, $mode), $type);
|
|
|
|
$sphinxResults = $sphinx->searchHostPages(Filter::searchQuery($query, $mode), $type, $page * API_SEARCH_PAGINATION_RESULTS_LIMIT - API_SEARCH_PAGINATION_RESULTS_LIMIT, API_SEARCH_PAGINATION_RESULTS_LIMIT, $sphinxResultsTotal);
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-25 16:35:52 +00:00
|
|
|
// Generate results
|
|
|
|
$dbResults = [];
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-25 16:35:52 +00:00
|
|
|
foreach ($sphinxResults as $i => $sphinxResult) {
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-05-10 09:47:36 +00:00
|
|
|
if ($hostPage = $db->getFoundHostPage($sphinxResult->id)) {
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-05-10 09:47:36 +00:00
|
|
|
$dbResults[$i] = $hostPage;
|
2023-04-25 13:53:13 +00:00
|
|
|
|
2023-05-10 09:47:36 +00:00
|
|
|
$dbResults[$i]->weight = $sphinxResult->weight;
|
2023-04-25 16:35:52 +00:00
|
|
|
}
|
2023-04-23 00:25:43 +00:00
|
|
|
}
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-25 16:35:52 +00:00
|
|
|
// Make response
|
|
|
|
$response = [
|
|
|
|
'status' => true,
|
|
|
|
'totals' => $sphinxResultsTotal,
|
|
|
|
'result' => $dbResults,
|
|
|
|
];
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
$response = [
|
|
|
|
'status' => false,
|
|
|
|
'result' => [],
|
|
|
|
];
|
|
|
|
}
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-23 00:25:43 +00:00
|
|
|
break;
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-23 00:25:43 +00:00
|
|
|
// Host API
|
|
|
|
case 'hosts';
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-25 16:35:52 +00:00
|
|
|
if (API_HOSTS_ENABLED) {
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-25 16:35:52 +00:00
|
|
|
// Connect database
|
|
|
|
$db = new MySQL(DB_HOST, DB_PORT, DB_NAME, DB_USERNAME, DB_PASSWORD);
|
|
|
|
|
|
|
|
$response = [
|
|
|
|
'status' => true,
|
|
|
|
'totals' => $db->getTotalHosts(),
|
|
|
|
'result' => $db->getAPIHosts(API_HOSTS_FIELDS),
|
|
|
|
];
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
$response = [
|
|
|
|
'status' => false,
|
|
|
|
'result' => [],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
// Manifest API
|
|
|
|
case 'manifest';
|
|
|
|
|
|
|
|
if (API_MANIFEST_ENABLED) {
|
|
|
|
|
|
|
|
$response = [
|
|
|
|
'status' => true,
|
|
|
|
'result' => [
|
2023-05-03 02:47:02 +00:00
|
|
|
'config' => [
|
2023-05-03 22:04:39 +00:00
|
|
|
'websiteDomain' => WEBSITE_DOMAIN,
|
|
|
|
'crawlUrlRegexp' => CRAWL_URL_REGEXP,
|
2023-05-09 10:26:19 +00:00
|
|
|
'crawlHostDefaultNsfw' => CRAWL_HOST_DEFAULT_NSFW,
|
2023-05-03 22:04:39 +00:00
|
|
|
'crawlHostDefaultPagesLimit' => CRAWL_HOST_DEFAULT_PAGES_LIMIT,
|
|
|
|
'crawlHostDefaultStatus' => CRAWL_HOST_DEFAULT_STATUS,
|
|
|
|
'crawlHostDefaultMetaOnly' => CRAWL_HOST_DEFAULT_META_ONLY,
|
|
|
|
'crawlHostPageSecondsOffset' => CRAWL_PAGE_SECONDS_OFFSET,
|
2023-05-06 11:03:43 +00:00
|
|
|
'crawlHostPageMime' => CRAWL_PAGE_MIME,
|
2023-05-03 22:04:39 +00:00
|
|
|
'cleanHostSecondsOffset' => CLEAN_HOST_SECONDS_OFFSET,
|
|
|
|
'crawlRobotsDefaultRules' => CRAWL_ROBOTS_DEFAULT_RULES,
|
|
|
|
'crawlRobotsPostfixRules' => CRAWL_ROBOTS_POSTFIX_RULES,
|
2023-05-03 02:47:02 +00:00
|
|
|
],
|
|
|
|
'api' => [
|
|
|
|
'version' => API_VERSION,
|
|
|
|
'manifest' => API_ENABLED && API_MANIFEST_ENABLED ? WEBSITE_DOMAIN . '/api.php?action=manifest' : false,
|
|
|
|
'search' => API_ENABLED && API_SEARCH_ENABLED ? WEBSITE_DOMAIN . '/api.php?action=search' : false,
|
|
|
|
'hosts' => API_ENABLED && API_HOSTS_ENABLED ? WEBSITE_DOMAIN . '/api.php?action=hosts' : false,
|
|
|
|
]
|
2023-04-25 16:35:52 +00:00
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
$response = [
|
|
|
|
'status' => false,
|
|
|
|
'result' => [],
|
|
|
|
];
|
|
|
|
}
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-23 00:25:43 +00:00
|
|
|
break;
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-23 00:25:43 +00:00
|
|
|
default:
|
2023-04-23 00:01:51 +00:00
|
|
|
|
2023-04-23 00:25:43 +00:00
|
|
|
$response = [
|
|
|
|
'status' => false,
|
|
|
|
'message' => _('Undefined API action request.'),
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
$response = [
|
|
|
|
'status' => false,
|
|
|
|
'message' => _('API requests disabled by the node owner.'),
|
|
|
|
];
|
2023-04-23 00:01:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Output
|
|
|
|
header('Content-Type: application/json; charset=utf-8');
|
|
|
|
|
|
|
|
echo json_encode($response);
|