Rev 4 | Go to most recent revision | Details | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
2 | daniel-mar | 1 | #!/usr/bin/php |
2 | <?php |
||
3 | |||
4 | # |
||
5 | # generic Whois - Whois Server Ping Testing Suite |
||
6 | # |
||
7 | # (c) 2013-2014 Daniel Marschall, ViaThinkSoft [www.viathinksoft.de] |
||
8 | # |
||
9 | # Distribution, usage etc. pp. regulated by the current version of GPL. |
||
10 | # |
||
11 | # |
||
12 | # Version 2014-09-12 |
||
13 | # |
||
14 | |||
15 | error_reporting(E_ALL | E_NOTICE | E_STRICT | E_DEPRECATED); |
||
16 | |||
17 | require_once __DIR__ . '/../../../shared/php_includes/common_functions.inc.php'; |
||
18 | require_once __DIR__ . '/whoisping_functions.inc.php'; |
||
19 | require_once __DIR__ . '/config.inc.php'; |
||
20 | |||
21 | $db = new SQLite3(__DIR__.'/../../.cache/whois-server-ping/whoisping.db'); # TODO: in config auslagern |
||
22 | if (!$db) die ($error); |
||
23 | |||
24 | gwitc_initdb($db); |
||
25 | |||
26 | /* |
||
27 | $stm = "SELECT * FROM gwi_tc_whois_ping WHERE server = 'whois.nic.ve'"; |
||
28 | $result = $db->query("SELECT * FROM gwi_tc_whois_ping WHERE server = 'whois.nic.ve'"); |
||
29 | $row = $result->fetchArray(SQLITE3_ASSOC); |
||
30 | print_r($row); |
||
31 | */ |
||
32 | |||
33 | $status=0; |
||
34 | |||
35 | $pattern_servers = array(); |
||
36 | $pattern_files = getpatternfiles(); |
||
37 | foreach ($pattern_files as &$pattern_file) { |
||
38 | $pattern_servers_c = gwitc_list_whois_servers($pattern_file); |
||
39 | $pattern_servers = array_merge($pattern_servers, $pattern_servers_c); |
||
40 | } |
||
41 | |||
42 | $dead_servers = array(); |
||
43 | $dead_servers_raw = file(__DIR__ . '/../../config/dead-servers.list'); |
||
44 | foreach ($dead_servers_raw as &$server) { |
||
45 | $server = trim($server); |
||
46 | if ($server == '') continue; |
||
47 | if ($server[0] == '#') continue; |
||
48 | |||
49 | $dead_servers[] = $server; |
||
50 | } |
||
51 | |||
52 | # $servers = $dead_servers + $pattern_servers |
||
53 | $servers = array(); |
||
54 | foreach ($pattern_servers as &$server) { |
||
55 | if (!in_array($server, $servers)) { |
||
56 | $servers[] = $server; |
||
57 | } |
||
58 | } |
||
59 | foreach ($dead_servers as &$server) { |
||
60 | if (!in_array($server, $servers)) { |
||
61 | $servers[] = $server; |
||
62 | } else { |
||
63 | if (in_array($server, $dead_servers)) { |
||
64 | $status=1; |
||
65 | echo "[ !! ] Attention! $server is in dead-servers.list and pattern. Please remove one instance!\n"; |
||
66 | } |
||
67 | } |
||
68 | } |
||
69 | |||
70 | foreach ($servers as &$server) { |
||
71 | $reborn = gwitc_reborn_val($db, $server); |
||
72 | if ($reborn) { // TODO: also show time since when it is reborn? |
||
73 | if (in_array($server, $dead_servers)) { |
||
74 | $status=1; |
||
75 | echo "[ !! ] Attention: $server is ALIVE again! Please remove from dead-servers.list and add to pattern.\n"; |
||
76 | } |
||
77 | |||
78 | if (in_array($server, $pattern_servers) && (!in_array($server, $dead_servers))) { |
||
79 | gwitc_set_reborn($db, $server, 0); |
||
80 | } |
||
81 | } else { |
||
82 | if (in_array($server, $dead_servers) && (!in_array($server, $pattern_servers))) continue; |
||
83 | |||
84 | $duration = gwitc_fail_duration($db, $server); |
||
85 | if ($duration < WHOIS_SERVER_DEAD_AFTER) continue; |
||
86 | $status=1; |
||
87 | echo "[ !! ] $server down for ".human_timediff($duration)."; first fail: ".date('Y-m-d', gwitc_first_fail($db, $server))."\n"; |
||
88 | } |
||
89 | } |
||
90 | |||
91 | $db->close(); |
||
92 | |||
93 | if ($status == 0) { |
||
94 | echo "[ OK ]\n"; |
||
95 | } |
||
96 | |||
97 | exit($status); |