report.php 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. <?php
  2. require_once "./SleekDB/SleekDB.php";
  3. require_once "./config.php";
  4. function maskLastSegment($ip) {
  5. $ipaddr = inet_pton($ip);
  6. if (strlen($ipaddr) == 4) {
  7. $ipaddr[3] = chr(0);
  8. } else {
  9. $ipaddr[14] = chr(0);
  10. $ipaddr[15] = chr(0);
  11. }
  12. return rtrim(inet_ntop($ipaddr),"0")."*";
  13. }
  14. $store = \SleekDB\SleekDB::store('speedlogs', './',[
  15. 'auto_cache' => false,
  16. 'timeout' => 120
  17. ]);
  18. $reportData = [
  19. "ip" => maskLastSegment(filter_var($_POST['ip'], FILTER_SANITIZE_STRING)),
  20. "isp" => filter_var($_POST['isp'], FILTER_SANITIZE_STRING),
  21. "addr" => filter_var($_POST['addr'], FILTER_SANITIZE_STRING),
  22. "dspeed" => (double) filter_var($_POST['dspeed'], FILTER_SANITIZE_STRING),
  23. "uspeed" => (double) filter_var($_POST['uspeed'], FILTER_SANITIZE_STRING),
  24. "ping" => (double) filter_var($_POST['ping'], FILTER_SANITIZE_STRING),
  25. "jitter" => (double) filter_var($_POST['jitter'], FILTER_SANITIZE_STRING),
  26. "created" => date('Y-m-d H:i:s', time()),
  27. ];
  28. if (empty($reportData['ip'])) exit;
  29. $oldLog = $store->where('ip', '=', $reportData['ip'])->fetch();
  30. if (is_array($oldLog) && empty($oldLog)) {
  31. $results = $store->insert($reportData);
  32. if ($results['_id'] > MAX_LOG_COUNT) {
  33. $store->where('_id', '=', $results['_id'] - MAX_LOG_COUNT)->delete();
  34. }
  35. } else {
  36. $ip = $reportData['ip'];
  37. unset($reportData['ip']);
  38. $store->where('ip', '=', $ip)->update($reportData);
  39. }