File: ping_http.php

package info (click to toggle)
serverstats 0.8.2-10
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd, wheezy
  • size: 604 kB
  • ctags: 796
  • sloc: php: 4,238; perl: 90; sh: 15; makefile: 12
file content (101 lines) | stat: -rw-r--r-- 3,007 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
<?php
/**
 * $Id$
 *
 * Author: David Danier, david.danier@team23.de
 * Project: Serverstats, http://serverstats.berlios.de/
 * License: GPL v2 or later (http://www.gnu.org/licenses/gpl.html)
 *
 * Copyright (C) 2005 David Danier
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 */

class ping_http extends source implements source_rrd
{
	private $host;
	private $port;
	private $path;
	private $command;
	private $timeout;
	
	private $ping_time;
	
	public function __construct($host, $port = 80, $path = '/', $command = 'HEAD', $timeout = 1)
	{
		$this->host = $host;
		$this->port = $port;
		$this->path = $path;
		$this->command = $command;
		$this->timeout = $timeout;
	}
	
	public function refreshData()
	{
		$timer = array();
		$timer['start'] = microtime(true);
		$socket = @fsockopen($this->host, $this->port, $errno, $errstr, $this->timeout);
		if (!is_resource($socket))
		{
			throw new Exception('Could not open connection');
		}
		$timer['open'] = microtime(true);
		socket_set_timeout($socket, $this->timeout);
		socket_set_blocking($socket, true); // just to be sure
		if (feof($socket))
		{
			throw new Exception('Connection closed while sending command');
		}
		$http_request = $this->command . ' ' . $this->path . " HTTP/1.1\r\n" . 
			'Host: ' . $this->host . "\r\n" . 
			"User-Agent: Serverstats::ping_http\r\n" . 
			"Connection: close\r\n\r\n";
		fputs($socket, $http_request);
		$timer['send'] = microtime(true);
		while(!feof($socket))
		{
			if (fread($socket, 4096) === false)
			{
				throw new Exception('Communication error, could not fetch result');
			}
		}
		$timer['receive'] = microtime(true);
		fclose($socket);
		$timer['finish'] = microtime(true);
		$this->ping_time = array(
				'time' => $timer['finish'] - $timer['start'],
				'open' => $timer['open'] - $timer['start'],
				'send' => $timer['send'] - $timer['open'],
				'receive' => $timer['receive'] - $timer['send'],
				'close' => $timer['finish'] - $timer['receive']
			);
	}
	
	public function initRRD(rrd $rrd)
	{
		$rrd->addDatasource('time', 'GAUGE', null, 0);
		$rrd->addDatasource('open', 'GAUGE', null, 0);
		$rrd->addDatasource('send', 'GAUGE', null, 0);
		$rrd->addDatasource('receive', 'GAUGE', null, 0);
		$rrd->addDatasource('close', 'GAUGE', null, 0);
	}
	
	public function fetchValues()
	{
		return $this->ping_time;
	}
}

?>