2021-08-07 13:37:01 +03:00
|
|
|
<?php
|
|
|
|
|
2023-08-23 15:40:12 +03:00
|
|
|
require_once(__DIR__ . '/../config.php');
|
|
|
|
require_once(__DIR__ . '/../library/icon.php');
|
|
|
|
require_once(__DIR__ . '/../library/sqlite.php');
|
2021-08-07 13:37:01 +03:00
|
|
|
|
2022-10-27 16:25:04 +03:00
|
|
|
$query = isset($_GET['q']) ? preg_replace('/[^\w\s]+/u', '', urldecode($_GET['q'])) : '';
|
|
|
|
$ns = '';
|
|
|
|
$tx = '';
|
|
|
|
$page = 0;
|
2023-07-01 17:55:39 +03:00
|
|
|
$rss = false;
|
2021-08-07 13:37:01 +03:00
|
|
|
|
2022-10-27 16:25:04 +03:00
|
|
|
if (isset($_SERVER['REQUEST_URI'])) {
|
2021-08-07 13:37:01 +03:00
|
|
|
|
2022-10-27 16:25:04 +03:00
|
|
|
$q = explode('/', $_SERVER['REQUEST_URI']);
|
2021-08-07 13:37:01 +03:00
|
|
|
|
|
|
|
if (isset($q[1])) {
|
2022-07-15 19:42:41 +03:00
|
|
|
if ($q[1] == 'rss') {
|
|
|
|
$rss = true;
|
|
|
|
} else if (strlen($q[1]) == 34) {
|
2021-08-07 13:37:01 +03:00
|
|
|
$ns = preg_replace('/[^a-zA-Z0-9]+/', '', $q[1]);
|
2022-10-27 16:25:04 +03:00
|
|
|
} else if (strlen($q[1]) == 64) {
|
2021-08-07 13:37:01 +03:00
|
|
|
$tx = preg_replace('/[^a-zA-Z0-9]+/', '', $q[1]);
|
2022-10-27 16:25:04 +03:00
|
|
|
} else if (preg_match('/[0-9]+/', $q[1])) {
|
2021-08-07 13:37:01 +03:00
|
|
|
$page = (int) $q[1];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($q[2])) {
|
2022-07-15 19:42:41 +03:00
|
|
|
if ($q[2] == 'rss') {
|
|
|
|
$rss = true;
|
|
|
|
} else if (strlen($q[2]) == 34) {
|
2021-08-07 13:37:01 +03:00
|
|
|
$ns = preg_replace('/[^a-zA-Z0-9]+/', '', $q[2]);
|
2022-10-27 16:25:04 +03:00
|
|
|
} else if (preg_match('/[0-9]+/', $q[2])) {
|
2021-08-07 13:37:01 +03:00
|
|
|
$page = (int) $q[2];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-27 16:25:04 +03:00
|
|
|
if ($query) {
|
|
|
|
$rss = isset($_GET['rss']) ? true : false;
|
|
|
|
}
|
|
|
|
|
2021-08-08 13:03:11 +03:00
|
|
|
if ($page > 0) {
|
2021-08-08 13:00:45 +03:00
|
|
|
$limit = PAGE_LIMIT * $page - PAGE_LIMIT;
|
|
|
|
} else {
|
|
|
|
$limit = PAGE_LIMIT * $page;
|
|
|
|
}
|
2021-08-07 13:37:01 +03:00
|
|
|
|
2021-08-08 13:10:00 +03:00
|
|
|
$db = new SQLite(DB_NAME, DB_USERNAME, DB_PASSWORD);
|
2021-08-07 13:37:01 +03:00
|
|
|
|
|
|
|
if ($ns) {
|
2022-05-13 19:41:00 +03:00
|
|
|
|
|
|
|
$namespaceHash = $ns;
|
|
|
|
$namespaceValue = $db->getNamespaceValueByNS($ns);
|
|
|
|
|
|
|
|
} else if ($tx) {
|
|
|
|
|
|
|
|
$namespaceHash = $db->getNamespaceHashByTX($tx);
|
|
|
|
$namespaceValue = $db->getNamespaceValueByNS($namespaceHash);
|
|
|
|
|
2021-08-07 13:37:01 +03:00
|
|
|
} else {
|
2022-05-13 19:41:00 +03:00
|
|
|
|
|
|
|
$namespaceHash = false;
|
2021-08-07 13:37:01 +03:00
|
|
|
$namespaceValue = false;
|
|
|
|
}
|
|
|
|
|
2022-10-27 15:30:31 +03:00
|
|
|
$trends = [];
|
|
|
|
|
|
|
|
if (TRENDS_ENABLED) {
|
|
|
|
|
|
|
|
foreach ($db->getTrends(time() - TRENDS_SECONDS_OFFSET) as $value) {
|
|
|
|
|
|
|
|
foreach ((array) explode(' ', strip_tags(html_entity_decode(nl2br(trim($value['key']))))) as $trend) {
|
|
|
|
|
|
|
|
if (strlen($trend) >= TRENDS_MIN_LENGHT) {
|
|
|
|
|
|
|
|
$trend = strtolower($trend);
|
|
|
|
|
|
|
|
if (isset($trends[$trend])) {
|
|
|
|
$trends[$trend]++;
|
|
|
|
} else {
|
|
|
|
$trends[$trend] = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach ((array) explode(' ', strip_tags(html_entity_decode(nl2br(trim($value['value']))))) as $trend) {
|
|
|
|
|
|
|
|
if (strlen($trend) >= TRENDS_MIN_LENGHT) {
|
|
|
|
|
|
|
|
$trend = strtolower($trend);
|
|
|
|
|
|
|
|
if (isset($trends[$trend])) {
|
|
|
|
$trends[$trend]++;
|
|
|
|
} else {
|
|
|
|
$trends[$trend] = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
arsort($trends);
|
|
|
|
|
|
|
|
$trends = array_slice($trends, 0, TRENDS_LIMIT);
|
|
|
|
|
|
|
|
$trends = array_flip($trends);
|
|
|
|
}
|
|
|
|
|
2021-08-07 13:37:01 +03:00
|
|
|
$data = [];
|
|
|
|
foreach ($db->getData($ns, $tx, $query, $limit, PAGE_LIMIT) as $value) {
|
|
|
|
$data[] = [
|
|
|
|
'namehash' => $value['namehash'],
|
|
|
|
'block' => $value['block'],
|
|
|
|
'txid' => $value['txid'],
|
2022-07-15 17:50:27 +03:00
|
|
|
'time' => date(($rss ? 'r' : 'd-m-Y H:i'), $value['time']),
|
|
|
|
'key' => $rss ? htmlentities(strip_tags(trim($value['key'])), ENT_XML1) : nl2br(trim($value['key'])),
|
|
|
|
'value' => $rss ? htmlentities(strip_tags(trim($value['value'])), ENT_XML1): nl2br(trim($value['value'])),
|
2021-08-07 13:37:01 +03:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2022-07-15 19:56:08 +03:00
|
|
|
$older = false;
|
|
|
|
$newer = false;
|
2021-08-07 13:37:01 +03:00
|
|
|
|
2022-07-15 19:56:08 +03:00
|
|
|
if (!in_array($page, [0, 1])) {
|
|
|
|
if ($page == 2) {
|
|
|
|
$newer = ($ns ? $ns : '');
|
2021-08-07 13:37:01 +03:00
|
|
|
} else {
|
2022-07-15 19:56:08 +03:00
|
|
|
$newer = ($ns ? $ns . '/' . ($page - 1) : ($page - 1));
|
2021-08-07 13:37:01 +03:00
|
|
|
}
|
2022-07-15 20:25:19 +03:00
|
|
|
|
|
|
|
if ($query) {
|
|
|
|
$newer = $newer . '?q=' . $query;
|
|
|
|
}
|
2022-07-15 19:56:08 +03:00
|
|
|
}
|
2021-08-07 13:37:01 +03:00
|
|
|
|
2022-07-15 19:56:08 +03:00
|
|
|
if ($data) {
|
|
|
|
if (in_array($page, [0, 1])) {
|
|
|
|
$older = ($ns ? $ns . '/2' : '2');
|
2021-08-07 13:37:01 +03:00
|
|
|
} else {
|
2022-07-15 19:56:08 +03:00
|
|
|
$older = ($ns ? $ns . '/' . ($page + 1) : ($page + 1));
|
2021-08-07 13:37:01 +03:00
|
|
|
}
|
2022-07-15 20:25:19 +03:00
|
|
|
|
|
|
|
if ($query) {
|
|
|
|
$older = $older . '?q=' . $query;
|
|
|
|
}
|
2021-08-07 13:37:01 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($ns) {
|
|
|
|
if ($page) {
|
|
|
|
$hrefThisPage = $ns . '/' . $page;
|
|
|
|
} else {
|
|
|
|
$hrefThisPage = $ns;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if ($page) {
|
|
|
|
$hrefThisPage = $page;
|
|
|
|
} else {
|
|
|
|
$hrefThisPage = '';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-15 17:50:27 +03:00
|
|
|
if ($rss) {
|
|
|
|
|
|
|
|
header('Content-type: application/xml');
|
|
|
|
require_once('rss.phtml');
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
require_once('index.phtml');
|
|
|
|
|
|
|
|
}
|