Browse Source

update code

* update domain add code
* update add page
* update disabling logic in export script

Signed-off-by: r4sas <r4sas@i2pmail.org>
master
R4SAS 4 years ago
parent
commit
66edea3e9f
Signed by: r4sas
GPG Key ID: 66F6C87B98EBCFE2
  1. 4
      config.php.dist
  2. 50
      export.php
  3. 2
      fetch.php
  4. 2
      import.php
  5. 44
      lib/utils.php
  6. 8
      templates/add.twig
  7. 9
      templates/home.twig
  8. 4
      templates/latest.twig
  9. 54
      views/add.php
  10. 14
      views/alive.php
  11. 4
      views/home.php
  12. 2
      views/latest.php

4
config.php.dist

@ -29,8 +29,10 @@ $options = [
'approveseen' => 3, // host must be seen lesser than this amount of hours for approving (hours) 'approveseen' => 3, // host must be seen lesser than this amount of hours for approving (hours)
'newdays' => 14, // assume host as new for that amout of days 'newdays' => 14, // assume host as new for that amout of days
'olddays' => 45, // assume host as approved if seen less than that amount of days, and stable if seen more than that amount of days
'delnewdays' => 3, // if new host not seen more than X days, disable it and disapprove 'delnewdays' => 3, // if new host not seen more than X days, disable it and disapprove
'delolddays' => 45, // same as above, but for old hosts 'delapprdays' => 45, // same as above, but for old hosts
'delstabdays' => 180, // same as above, but for old hosts
'hidedays' => 3, // days before domain will be marked as hidden in period before disabling 'hidedays' => 3, // days before domain will be marked as hidden in period before disabling

50
export.php

@ -11,38 +11,39 @@ $util = new App\Utils;
$STH = $pdo->query ("SELECT `host`, `base64`, `base32`, `add_date`, `last_seen`, `approved`, `initial`, `disabled`, `hidden` FROM hosts"); $STH = $pdo->query ("SELECT `host`, `base64`, `base32`, `add_date`, `last_seen`, `approved`, `initial`, `disabled`, `hidden` FROM hosts");
$hosts = $STH->fetchAll(PDO::FETCH_ASSOC); $hosts = $STH->fetchAll(PDO::FETCH_ASSOC);
$curr_time = time();
// for automatic approving // for automatic approving
$approffs = date ("Y-m-d H:i:s", strtotime ("-" . $options["approvedelay"] . " hour")); // approval offset $approffs = $options["approvedelay"] * 3600;
$apprseen = date ("Y-m-d H:i:s", strtotime ("-" . $options["approveseen"] . " hour")); // approval maxseen offset $apprseen = $options["approveseen"] * 3600;
// for managing export and disabling
$newregoffs = $options["newdays"] * 86400;
$oldregoffs = $options["olddays"] * 86400;
$newregoffs = date ("Y-m-d H:i:s", strtotime ("-" . $options["newdays"] . " day")); $newseenlim = $options["delnewdays"] * 86400;
$newseenlim = date ("Y-m-d H:i:s", strtotime ("-" . $options["delnewdays"] . " day")); $appseenlim = $options["delapprdays"] * 86400;
$oldseenlim = date ("Y-m-d H:i:s", strtotime ("-" . $options["delolddays"] . " day")); $staseenlim = $options["delstabdays"] * 86400;
$hideoffs = date ("Y-m-d H:i:s", strtotime ("-" . $options["hidedays"] . " day")); // hide offset $hideoffs = $options["hidedays"] * 86400;
$export_full = $export_live = $export_init = []; $export_full = $export_live = $export_init = [];
$export_addr_full = $export_addr_live = $export_addr_init = []; $export_addr_full = $export_addr_live = $export_addr_init = [];
foreach ($hosts as $host) foreach ($hosts as $host)
{ {
/* Convert UFT-8 domains to Punycode */ /* Convert UTF-8 domains to Punycode */
$domain = $util->isASCII ($host["host"]) ? $host["host"] : idn_to_ascii ($host["host"]); $domain = $util->isASCII ($host["host"]) ? $host["host"] : idn_to_ascii ($host["host"]);
$add_date = strtotime ($host["add_date"]);
$last_seen = strtotime ($host["last_seen"]);
array_push($export_full, $domain . "=" . $host["base64"]); array_push($export_full, $domain . "=" . $host["base64"]);
array_push($export_addr_full, $domain . "," . $host["base32"]); array_push($export_addr_full, $domain . "," . $host["base32"]);
if ( if (($options["approval"] == false || $host["approved"] == 1) && $host["hidden"] == 0 && $host["disabled"] == 0)
($options["approval"] == false || $host["approved"] == 1) && $host["hidden"] == 0 &&
($host["disabled"] == 0 ||
(
($host["add_date"] > $newregoffs && $host["last_seen"] > $newseenlim) ||
($host["add_date"] < $newregoffs && $host["last_seen"] > $oldseenlim) // is seen till disabling date
)
)
)
{ {
if ($host["last_seen"] > $hideoffs) { // if seen not earlier than hide offset if (($last_seen + $hideoffs) > $curr_time) {
array_push($export_live, $domain . "=" . $host["base64"]); array_push($export_live, $domain . "=" . $host["base64"]);
array_push($export_addr_live, $domain . "," . $host["base32"]); array_push($export_addr_live, $domain . "," . $host["base32"]);
@ -52,14 +53,14 @@ foreach ($hosts as $host)
array_push($export_addr_init, $domain . "," . $host["base32"]); array_push($export_addr_init, $domain . "," . $host["base32"]);
} }
} }
else // hide because not available for "hidedays" days else // hide because not available for X days
{ {
$pdo->exec ("UPDATE `hosts` SET `hidden` = 1 WHERE `host` = '" . $host["host"] . "'"); $pdo->exec ("UPDATE `hosts` SET `hidden` = 1 WHERE `host` = '" . $host["host"] . "'");
} }
} }
else if ( else if (
$host["approved"] == 0 && ( $host["approved"] == 0 && (
($host["add_date"] < $approffs && $host["last_seen"] > $apprseen) // if host were registered more then X days ago and seen lesser than X hours ago (($add_date + $approffs) < $curr_time && ($last_seen + $apprseen) > $curr_time)
) )
) )
{ {
@ -70,8 +71,11 @@ foreach ($hosts as $host)
if ( if (
$host["disabled"] == 0 && $host["disabled"] == 0 &&
($host["add_date"] > $newregoffs && $host["last_seen"] < $newseenlim) || (
($host["add_date"] < $newregoffs && $host["last_seen"] < $oldseenlim) // is seen more that disabling period days (($last_seen - $add_date) < $newregoffs && ($last_seen + $newseenlim) < $curr_time) ||
(($last_seen - $add_date) < $oldregoffs && ($last_seen + $appseenlim) < $curr_time) ||
(($last_seen - $add_date) > $oldregoffs && ($last_seen + $staseenlim) < $curr_time)
)
) )
{ {
$pdo->exec ("UPDATE `hosts` SET `disabled` = 1 WHERE `host` = '" . $host["host"] . "'"); $pdo->exec ("UPDATE `hosts` SET `disabled` = 1 WHERE `host` = '" . $host["host"] . "'");
@ -85,10 +89,10 @@ $pdo = null;
/* Sort records */ /* Sort records */
sort ($export_full); sort ($export_full);
sort ($export_addr_full); sort ($export_addr_full);
//
sort ($export_live); sort ($export_live);
sort ($export_addr_live); sort ($export_addr_live);
//
sort ($export_init); sort ($export_init);
sort ($export_addr_init); sort ($export_addr_init);

2
fetch.php

@ -55,7 +55,7 @@ foreach ($lists as $list) {
$domain = ""; $domain = "";
$record = $util->parseHostRecord($buffer); $record = $util->parseHostRecord($buffer);
if (!$util->isValidAddress($record['host'], $error)) { if (!$util->isValidDomain($record['host'], $error)) {
echo "Error while validating " . $record['host'] . ": " . $error . PHP_EOL; echo "Error while validating " . $record['host'] . ": " . $error . PHP_EOL;
continue; continue;

2
import.php

@ -20,7 +20,7 @@ if ($f) {
$domain = ""; $domain = "";
$record = $util->parseHostRecord($buffer); $record = $util->parseHostRecord($buffer);
if (!$util->isValidAddress($record['host'], $error)) { if (!$util->isValidDomain($record['host'], $error)) {
echo "Error while validating " . $record['host'] . ": " . $error . PHP_EOL; echo "Error while validating " . $record['host'] . ": " . $error . PHP_EOL;
continue; continue;

44
lib/utils.php

@ -144,41 +144,6 @@ class Utils {
return self::b32encode(hash('sha256', self::b64decode($data), true)); return self::b32encode(hash('sha256', self::b64decode($data), true));
} }
/**
* Domain validation function for registration.
* @param string $data
* @return bool
*/
public static function isValidAddress(string $data, string &$result): bool
{
$len = strlen($data);
if($len < 5 || $len > 255) // rfc2181, section 11
{
$result = "Domain must be longer than 5 and lesser than 255 chars.";
return false;
}
if(preg_match('/\.b32\.i2p$/', $data))
{
$result = "Domain can't end with .b32.i2p.";
return false;
}
if(filter_var($data, FILTER_VALIDATE_DOMAIN) !== false && preg_match('/\.i2p$/', $data)
&& (static::isPunycodeDomain($data) || static::isAscii($data)))
{
return true;
}
else
{
$result = "Domain is not valid. Check if you domain label is lesser than 63 chars, and uses only ASCII or Punycode format.";
return false;
}
return false;
}
/** /**
* Domain validation function. * Domain validation function.
* @param string $data * @param string $data
@ -204,12 +169,8 @@ class Utils {
{ {
return true; return true;
} }
else
{
$result = "Inputed data or domain is not valid.";
return false;
}
$result = "Domain is not valid. Check if you domain label is lesser than 63 chars and it ends with .i2p.";
return false; return false;
} }
@ -217,6 +178,9 @@ class Utils {
{ {
$retval = null; $retval = null;
if (strpos($data, "&") !== false)
return false; // registration string can't have ampersands
$cmd = dirname(__FILE__) . "/../bin/verifyhost '" . $data . "'"; $cmd = dirname(__FILE__) . "/../bin/verifyhost '" . $data . "'";
exec($cmd, $output, $retval); exec($cmd, $output, $retval);

8
templates/add.twig

@ -13,7 +13,15 @@
{% else %} {% else %}
<div class="adder__succ"> <div class="adder__succ">
<div class="adder__succ-body"> <div class="adder__succ-body">
{% if result.command == 'addname' %}
<h3 class="adder__title title">Domain alias successfuly added</h3>
{% elseif result.command == 'addsubdomain' %}
<h3 class="adder__title title">Subdomain successfuly added</h3>
{% elseif result.command == 'changedest' %}
<h3 class="adder__title title">Domain destination successfuly changed</h3>
{% else %}
<h3 class="adder__title title">Domain successfuly added</h3> <h3 class="adder__title title">Domain successfuly added</h3>
{% endif %}
<div class="adder__line line adder__line_reshost"> <div class="adder__line line adder__line_reshost">
<span> <span>
Domain: Domain:

9
templates/home.twig

@ -15,6 +15,7 @@
<li>adding of hosts for 2LD domains (example.i2p)</li> <li>adding of hosts for 2LD domains (example.i2p)</li>
<li>adding subdomains (addsubdomain)</li> <li>adding subdomains (addsubdomain)</li>
<li>adding/changing destination (adddest, changedest) - destination is replaced with the new one, old destination is purged</li> <li>adding/changing destination (adddest, changedest) - destination is replaced with the new one, old destination is purged</li>
<li>adding domain alias (addname) - alias must be 2LD (example.i2p). For registering subdomains as aliases please use addsubdomain command</li>
</ul> </ul>
</p> </p>
@ -38,11 +39,11 @@
<p> <p>
<b>Rules:</b><br> <b>Rules:</b><br>
Although there are no specific rules for domain registration, we do have the policy on dead domain records.<br> Although there are no specific rules for domain registration, we do have the policy on dead domain records.<br>
Your domain will become open for registration again if it is dead for: Your domain will become open for registration again (disabled) if it is dead for:
<ul> <ul>
<li>{{ delnewdays }} days if registered less than {{ newdays }} days ago</li> <li>{{ delnewdays }} days if last seen less than {{ newdays }} days since registration</li>
<li>{{ delolddays }} days if registered more than {{ newdays }} days ago</li> <li>{{ delapprdays }} days if last seen less than {{ olddays }} days since registration</li>
<li>1 year if registered more than {{ delolddays }} days ago</li> <li>{{ delstabdays }} days if last seen more than {{ olddays }} days since registration</li>
</ul> </ul>
Domains that are inaccessible before the disabling date for {{ hidedays }} days, will be hidden from <a href="/alive">alive</a> list, removed from export lists, but will still be checked every hour.<br> Domains that are inaccessible before the disabling date for {{ hidedays }} days, will be hidden from <a href="/alive">alive</a> list, removed from export lists, but will still be checked every hour.<br>
When domain dead for amount days stated above, it will be marked as disabled, opened for registration and will be checked once a day for availability at {{ fullhour }} o'clock UTC. When domain dead for amount days stated above, it will be marked as disabled, opened for registration and will be checked once a day for availability at {{ fullhour }} o'clock UTC.

4
templates/latest.twig

@ -16,7 +16,7 @@
<th class="table__cell"><abbr title="Address Helper">AH</abbr></th> <th class="table__cell"><abbr title="Address Helper">AH</abbr></th>
<th class="table__cell"><abbr title="Base32 address">B32</abbr></th> <th class="table__cell"><abbr title="Base32 address">B32</abbr></th>
<th class="table__cell table__cell_full-b32">Full Base32</th> <th class="table__cell table__cell_full-b32">Full Base32</th>
<th class="table__cell">Added</th> <th class="table__cell"><abbr title="Hover to see last seen time">Added</abbr></th>
</tr> </tr>
</thead> </thead>
<tbody class="table__body"> <tbody class="table__body">
@ -30,7 +30,7 @@
<td class="table__cell table__cell_center-bold"><a href="http://{{ host.host }}/?i2paddresshelper={{ host.base64 }}" rel="external nofollow noopener noreferrer" target="_blank">A</a></td> <td class="table__cell table__cell_center-bold"><a href="http://{{ host.host }}/?i2paddresshelper={{ host.base64 }}" rel="external nofollow noopener noreferrer" target="_blank">A</a></td>
<td class="table__cell table__cell_center-bold"><a href="http://{{ host.base32 }}.b32.i2p/" rel="external nofollow noopener noreferrer" target="_blank">B</a></td> <td class="table__cell table__cell_center-bold"><a href="http://{{ host.base32 }}.b32.i2p/" rel="external nofollow noopener noreferrer" target="_blank">B</a></td>
<td class="table__cell table__cell_full-b32 table__cell_long-ass">{{ host.base32 }}.b32.i2p</td> <td class="table__cell table__cell_full-b32 table__cell_long-ass">{{ host.base32 }}.b32.i2p</td>
<td class="table__cell">{{ host.add_date }}</td> <td class="table__cell" title="{{ host.last_seen }}">{{ host.add_date }}</td>
</tr> </tr>
{% endfor %} {% endfor %}
</tbody> </tbody>

54
views/add.php

@ -28,7 +28,7 @@ if (isset($_POST["record"]) && !empty($_POST["record"])) {
$parsed = $util->parseHostRecord($record); $parsed = $util->parseHostRecord($record);
if (!$util->isValidAddress($parsed['host'], $error)) { if (!$util->isValidDomain($parsed['host'], $error)) {
$result["error"] = "Error while validating: " . $error; $result["error"] = "Error while validating: " . $error;
} else { } else {
if ($util->isPunycodeDomain($parsed['host'])) { if ($util->isPunycodeDomain($parsed['host'])) {
@ -37,13 +37,6 @@ if (isset($_POST["record"]) && !empty($_POST["record"])) {
$domain = $parsed['host']; $domain = $parsed['host'];
} }
/* Check if such domain name already registered */
$STH = $pdo->query("SELECT COUNT(*) FROM `hosts` WHERE `host` = '" . $domain . "' LIMIT 1");
if($STH->fetchColumn() == 1) {
$result["error"] = "Error while validating: That domain is already registered.";
} else {
if (!isset($parsed["commands"]) || !isset($parsed["commands"]["sig"])) { if (!isset($parsed["commands"]) || !isset($parsed["commands"]["sig"])) {
$result["error"] = "Error while validating: No extended record fields or signature is found."; $result["error"] = "Error while validating: No extended record fields or signature is found.";
@ -51,10 +44,16 @@ if (isset($_POST["record"]) && !empty($_POST["record"])) {
$result["error"] = "Error while validating: " . $error[0]; $result["error"] = "Error while validating: " . $error[0];
} else { } else {
/* Check if such domain name already registered */
$STH = $pdo->query("SELECT COUNT(*) FROM `hosts` WHERE `host` = '" . $domain . "' LIMIT 1");
if (isset($parsed["commands"]["action"])) { if (isset($parsed["commands"]["action"])) {
switch ($parsed["commands"]["action"]) { switch ($parsed["commands"]["action"]) {
case 'addsubdomain': case 'addsubdomain':
if (!isset($parsed["commands"]["oldname"]) || !isset($parsed["commands"]["olddest"]) || !isset($parsed["commands"]["oldsig"])) { if ($STH->fetchColumn() == 1) {
$result["error"] = "Error while validating: That subdomain is already registered.";
} else if (!isset($parsed["commands"]["oldname"]) || !isset($parsed["commands"]["olddest"]) || !isset($parsed["commands"]["oldsig"])) {
$result["error"] = "Error while validating: required fields not found. Re-check your registration string."; $result["error"] = "Error while validating: required fields not found. Re-check your registration string.";
} else { } else {
@ -82,6 +81,7 @@ if (isset($_POST["record"]) && !empty($_POST["record"])) {
$result["error"] = "Error happened while inserting record to database. Please try again later."; $result["error"] = "Error happened while inserting record to database. Please try again later.";
} else { } else {
$result["command"] = 'addsubdomain';
$result["host"] = $domain; $result["host"] = $domain;
$result["base64"] = $parsed["b64"]; $result["base64"] = $parsed["b64"];
$result["base32"] = $base32; $result["base32"] = $base32;
@ -91,7 +91,10 @@ if (isset($_POST["record"]) && !empty($_POST["record"])) {
break; break;
case 'adddest': case 'adddest':
case 'changedest': case 'changedest':
if (!isset($parsed["commands"]["olddest"]) || !isset($parsed["commands"]["oldsig"])) { if($STH->fetchColumn() == 0) {
$result["error"] = "Error while validating: That domain is not registered.";
} else if (!isset($parsed["commands"]["olddest"]) || !isset($parsed["commands"]["oldsig"])) {
$result["error"] = "Error while validating: required fields not found. Re-check your registration string."; $result["error"] = "Error while validating: required fields not found. Re-check your registration string.";
} else { } else {
@ -104,6 +107,7 @@ if (isset($_POST["record"]) && !empty($_POST["record"])) {
$result["error"] = "Error happened while updating record in database. Please try again later."; $result["error"] = "Error happened while updating record in database. Please try again later.";
} else { } else {
$result["command"] = 'changedest';
$result["host"] = $domain; $result["host"] = $domain;
$result["base64"] = $parsed["b64"]; $result["base64"] = $parsed["b64"];
$result["base32"] = $base32; $result["base32"] = $base32;
@ -112,19 +116,34 @@ if (isset($_POST["record"]) && !empty($_POST["record"])) {
} }
break; break;
case 'addname': case 'addname':
if (!isset($parsed["commands"]["olddest"]) || !isset($parsed["commands"]["oldsig"])) { if($STH->fetchColumn() == 1) {
$result["error"] = "Error while validating: That domain is already registered.";
/* Getting domain level (2LD, 3LD and etc.) and validating that domain at higher level is registered (2LD if registering 3LD). */
} else if (sizeof(explode(".", $domain)) > 2) {
$result["error"] = "Error while validating: you can't register subdomain (sub.example.i2p) as domain alias using addname action.";
} else if (!isset($parsed["commands"]["oldname"])) {
$result["error"] = "Error while validating: required fields not found. Re-check your registration string."; $result["error"] = "Error while validating: required fields not found. Re-check your registration string.";
} else { } else {
if (!$pdo->query("SELECT COUNT(*) FROM `hosts` WHERE `host` = '" . $domain . "' AND `base64` = '" . $parsed["commands"]["olddest"] . "' LIMIT 1")->fetchColumn()) { if ($util->isPunycodeDomain($parsed["commands"]["oldname"])) {
$result["error"] = "Error while validating: old base64 and value in olddest field does not match.."; $olddomain = idn_to_utf8($parsed["commands"]["oldname"], 0, INTL_IDNA_VARIANT_UTS46);
} else {
$olddomain = $parsed["commands"]["oldname"];
}
if (!$pdo->query("SELECT COUNT(*) FROM `hosts` WHERE `host` = '" . $olddomain . "' AND `base64` = '" . parsed["b64"] . "' LIMIT 1")->fetchColumn()) {
$result["error"] = "Error while validating: base64 does not match for domain in oldname field...";
} else { } else {
$base32 = $util->b32from64($parsed["b64"]); $base32 = $util->b32from64($parsed["b64"]);
if (!$pdo->exec("UPDATE `hosts` SET `base64` = '" . $parsed["b64"] . "', `base32` = '" . $base32 . "' WHERE `host` = '" . $domain . "'")) { if (!$pdo->exec("INSERT INTO `hosts` (`host`, `base64`, `base32`) VALUES ('" . $domain . "', '" . $parsed["b64"] . "', '" . $base32 . "')")) {
$result["error"] = "Error happened while updating record in database. Please try again later."; $result["error"] = "Error happened while updating record in database. Please try again later.";
} else { } else {
$result["command"] = 'addname';
$result["host"] = $domain; $result["host"] = $domain;
$result["base64"] = $parsed["b64"]; $result["base64"] = $parsed["b64"];
$result["base32"] = $base32; $result["base32"] = $base32;
@ -133,10 +152,14 @@ if (isset($_POST["record"]) && !empty($_POST["record"])) {
} }
break; break;
default: default:
$result["error"] = "Error while validating: extended record fields are NOT supported for now."; $result["error"] = "Error while validating: extended record fields are NOT supported.";
break; break;
} }
} else {
if($STH->fetchColumn() == 1) {
$result["error"] = "Error while validating: That domain is already registered.";
} else { } else {
if (isset($parsed["commands"]["oldname"]) || isset($parsed["commands"]["olddest"]) || isset($parsed["commands"]["oldsig"])) { if (isset($parsed["commands"]["oldname"]) || isset($parsed["commands"]["olddest"]) || isset($parsed["commands"]["oldsig"])) {
$result["error"] = "Error while validating: unexpected fields found."; $result["error"] = "Error while validating: unexpected fields found.";
@ -152,6 +175,7 @@ if (isset($_POST["record"]) && !empty($_POST["record"])) {
$result["error"] = "Error happened while inserting record to database. Please try again later."; $result["error"] = "Error happened while inserting record to database. Please try again later.";
} else { } else {
$result["command"] = 'added';
$result["host"] = $domain; $result["host"] = $domain;
$result["base64"] = $parsed["b64"]; $result["base64"] = $parsed["b64"];
$result["base32"] = $base32; $result["base32"] = $base32;

14
views/alive.php

@ -11,18 +11,12 @@ $twig = new \Twig\Environment($loader, [
]); ]);
$offset = $options["tableitems"] * ($page - 1); $offset = $options["tableitems"] * ($page - 1);
$newregoffs = date ("Y-m-d H:i:s", strtotime ("-7 day"));
$newseenlim = date ("Y-m-d H:i:s", strtotime ("-3 day"));
$oldseenlim = date ("Y-m-d H:i:s", strtotime ("-7 day"));
$pdo = (new App\DB($options))->pdo; $pdo = (new App\DB($options))->pdo;
/* Get records amount */ /* Get records amount */
$STH = $pdo->query ("SELECT COUNT(*) as `count` FROM `hosts` " . $STH = $pdo->query ("SELECT COUNT(*) as `count` FROM `hosts` " .
"WHERE `approved` = 1 AND `disabled` = 0 AND `hidden` = 0 AND (" . "WHERE `approved` = 1 AND `disabled` = 0 AND `hidden` = 0");
" (`add_date` < '" . $newregoffs . "' AND `last_seen` > '" . $oldseenlim . "') OR" .
" (`add_date` > '" . $newregoffs . "' AND `last_seen` > '" . $newseenlim . "')" .
")");
$STH->setFetchMode (PDO::FETCH_ASSOC); $STH->setFetchMode (PDO::FETCH_ASSOC);
$records = $STH->fetch()["count"]; $records = $STH->fetch()["count"];
@ -30,10 +24,8 @@ $pages = intdiv($records, $options["tableitems"]) + 1;
/* Get records with limit */ /* Get records with limit */
$STH = $pdo->query ("SELECT `host`, `base64`, `base32`, `last_seen` FROM `hosts` " . $STH = $pdo->query ("SELECT `host`, `base64`, `base32`, `last_seen` FROM `hosts` " .
"WHERE `approved` = 1 AND `disabled` = 0 AND `hidden` = 0 AND (" . "WHERE `approved` = 1 AND `disabled` = 0 AND `hidden` = 0 " .
" (`add_date` < '" . $newregoffs . "' AND `last_seen` > '" . $oldseenlim . "') OR" . "LIMIT " . $offset . ", " . $options["tableitems"]);
" (`add_date` > '" . $newregoffs . "' AND `last_seen` > '" . $newseenlim . "')" .
") LIMIT " . $offset . ", " . $options["tableitems"]);
$STH->setFetchMode(PDO::FETCH_ASSOC); $STH->setFetchMode(PDO::FETCH_ASSOC);
$rows = $STH->fetchAll(); $rows = $STH->fetchAll();

4
views/home.php

@ -25,8 +25,10 @@ $vars = array(
'apprdelay' => $options['approvedelay'], 'apprdelay' => $options['approvedelay'],
'apprseen' => $options['approveseen'], 'apprseen' => $options['approveseen'],
'newdays' => $options['newdays'], 'newdays' => $options['newdays'],
'olddays' => $options['olddays'],
'delnewdays' => $options['delnewdays'], 'delnewdays' => $options['delnewdays'],
'delolddays' => $options['delolddays'], 'delapprdays' => $options['delapprdays'],
'delstabdays' => $options['delstabdays'],
'hidedays' => $options['hidedays'], 'hidedays' => $options['hidedays'],
'fullhour' => $options['fullhour'], 'fullhour' => $options['fullhour'],
'fetcher' => $options['fetcher'], 'fetcher' => $options['fetcher'],

2
views/latest.php

@ -13,7 +13,7 @@ $twig = new \Twig\Environment($loader, [
$pdo = (new App\DB($options))->pdo; $pdo = (new App\DB($options))->pdo;
/* Get records with limit */ /* Get records with limit */
$STH = $pdo->query ("SELECT `host`, `base64`, `base32`, `add_date` FROM `hosts` WHERE `disabled` = 0 ORDER BY `add_date` DESC LIMIT " . $options["tableitems"]); $STH = $pdo->query ("SELECT `host`, `base64`, `base32`, `add_date`, `last_seen` FROM `hosts` WHERE `disabled` = 0 ORDER BY `add_date` DESC LIMIT " . $options["tableitems"]);
$STH->setFetchMode(PDO::FETCH_ASSOC); $STH->setFetchMode(PDO::FETCH_ASSOC);
$rows = $STH->fetchAll(); $rows = $STH->fetchAll();

Loading…
Cancel
Save