MDL-11075 Now saving to temp file, then outputting using filelib's readfile_chunked...
[moodle-pu.git] / lib / simpletestlib / socket.php
blob4205482080c142fc7495989f8904c66dffaa33cc
1 <?php
2 /**
3 * base include file for SimpleTest
4 * @package SimpleTest
5 * @subpackage MockObjects
6 * @version $Id$
7 */
9 /**#@+
10 * include SimpleTest files
12 require_once(dirname(__FILE__) . '/compatibility.php');
13 /**#@-*/
15 /**
16 * Stashes an error for later. Useful for constructors
17 * until PHP gets exceptions.
18 * @package SimpleTest
19 * @subpackage WebTester
21 class SimpleStickyError {
22 var $_error = 'Constructor not chained';
24 /**
25 * Sets the error to empty.
26 * @access public
28 function SimpleStickyError() {
29 $this->_clearError();
32 /**
33 * Test for an outstanding error.
34 * @return boolean True if there is an error.
35 * @access public
37 function isError() {
38 return ($this->_error != '');
41 /**
42 * Accessor for an outstanding error.
43 * @return string Empty string if no error otherwise
44 * the error message.
45 * @access public
47 function getError() {
48 return $this->_error;
51 /**
52 * Sets the internal error.
53 * @param string Error message to stash.
54 * @access protected
56 function _setError($error) {
57 $this->_error = $error;
60 /**
61 * Resets the error state to no error.
62 * @access protected
64 function _clearError() {
65 $this->_setError('');
69 /**
70 * Wrapper for TCP/IP socket.
71 * @package SimpleTest
72 * @subpackage WebTester
74 class SimpleSocket extends SimpleStickyError {
75 var $_handle;
76 var $_is_open = false;
77 var $_sent = '';
78 var $lock_size;
80 /**
81 * Opens a socket for reading and writing.
82 * @param string $host Hostname to send request to.
83 * @param integer $port Port on remote machine to open.
84 * @param integer $timeout Connection timeout in seconds.
85 * @param integer $block_size Size of chunk to read.
86 * @access public
88 function SimpleSocket($host, $port, $timeout, $block_size = 255) {
89 $this->SimpleStickyError();
90 if (! ($this->_handle = $this->_openSocket($host, $port, $error_number, $error, $timeout))) {
91 $this->_setError("Cannot open [$host:$port] with [$error] within [$timeout] seconds");
92 return;
94 $this->_is_open = true;
95 $this->_block_size = $block_size;
96 SimpleTestCompatibility::setTimeout($this->_handle, $timeout);
99 /**
100 * Writes some data to the socket and saves alocal copy.
101 * @param string $message String to send to socket.
102 * @return boolean True if successful.
103 * @access public
105 function write($message) {
106 if ($this->isError() || ! $this->isOpen()) {
107 return false;
109 $count = fwrite($this->_handle, $message);
110 if (! $count) {
111 if ($count === false) {
112 $this->_setError('Cannot write to socket');
113 $this->close();
115 return false;
117 fflush($this->_handle);
118 $this->_sent .= $message;
119 return true;
123 * Reads data from the socket. The error suppresion
124 * is a workaround for PHP4 always throwing a warning
125 * with a secure socket.
126 * @return integer/boolean Incoming bytes. False
127 * on error.
128 * @access public
130 function read() {
131 if ($this->isError() || ! $this->isOpen()) {
132 return false;
134 $raw = @fread($this->_handle, $this->_block_size);
135 if ($raw === false) {
136 $this->_setError('Cannot read from socket');
137 $this->close();
139 return $raw;
143 * Accessor for socket open state.
144 * @return boolean True if open.
145 * @access public
147 function isOpen() {
148 return $this->_is_open;
152 * Closes the socket preventing further reads.
153 * Cannot be reopened once closed.
154 * @return boolean True if successful.
155 * @access public
157 function close() {
158 $this->_is_open = false;
159 return fclose($this->_handle);
163 * Accessor for content so far.
164 * @return string Bytes sent only.
165 * @access public
167 function getSent() {
168 return $this->_sent;
172 * Actually opens the low level socket.
173 * @param string $host Host to connect to.
174 * @param integer $port Port on host.
175 * @param integer $error_number Recipient of error code.
176 * @param string $error Recipoent of error message.
177 * @param integer $timeout Maximum time to wait for connection.
178 * @access protected
180 function _openSocket($host, $port, &$error_number, &$error, $timeout) {
181 return @fsockopen($host, $port, $error_number, $error, $timeout);
186 * Wrapper for TCP/IP socket over TLS.
187 * @package SimpleTest
188 * @subpackage WebTester
190 class SimpleSecureSocket extends SimpleSocket {
193 * Opens a secure socket for reading and writing.
194 * @param string $host Hostname to send request to.
195 * @param integer $port Port on remote machine to open.
196 * @param integer $timeout Connection timeout in seconds.
197 * @access public
199 function SimpleSecureSocket($host, $port, $timeout) {
200 $this->SimpleSocket($host, $port, $timeout);
204 * Actually opens the low level socket.
205 * @param string $host Host to connect to.
206 * @param integer $port Port on host.
207 * @param integer $error_number Recipient of error code.
208 * @param string $error Recipient of error message.
209 * @param integer $timeout Maximum time to wait for connection.
210 * @access protected
212 function _openSocket($host, $port, &$error_number, &$error, $timeout) {
213 return parent::_openSocket("tls://$host", $port, $error_number, $error, $timeout);