*/
require_once 'HTTP/Request2.php';
require_once 'Wrt3g/HtmlParser.php';
-
+require_once 'Wrt3g/RequestObserver.php';
/**
* Main class to interact with the router.
* 0 - no debug logging
* 1 - show important details (connected URLs)
* 2 - show internal details
+ * 3 - show HTTP requests and responses
*
* @var integer
*/
+ /**
+ * Creates a new HTTP_Request2 object, attaches an observer
+ * if necessary and returns it.
+ *
+ * @return HTTP_Request2
+ */
+ protected function createRequest()
+ {
+ $r = new $this->requestClass();
+ if ($this->verbosity >= 3) {
+ //register observer
+ $r->attach(new Wrt3g_RequestObserver($this));
+ }
+ return $r;
+ }
+
+
+
/**
* Reboots the router.
*
$url = $this->getAuthBaseUrl() . '/apply.cgi';
$this->log('Connecting to ' . $url);
- $r = new $this->requestClass();
+ $r = $this->createRequest();
$r->setMethod(HTTP_Request2::METHOD_POST);
$r->setUrl($url);
$r->addPostParameter('action', 'Reboot');
/**
* Connection status
*/
- $r = new $this->requestClass();
+ $r = $this->createRequest();
$r->setMethod(HTTP_Request2::METHOD_GET);
$r->setUrl($strUrlBase . '/index_wstatus2.asp');
$this->log('Connecting to ' . $strUrlBase . '/index_wstatus2.asp', 1);
$url = $strUrlBase . '/Status_NoAuth.asp';
$this->log('Connecting to ' . $url, 1);
- $r = new $this->requestClass();
+ $r = $this->createRequest();
$r->setMethod(HTTP_Request2::METHOD_GET);
$r->setUrl($url);
$resp = $r->send();
*/
protected function checkResponseStatus(HTTP_Request2_Response $resp)
{
+ $this->log($resp, 3);
+
$nStatus = $resp->getStatus();
$this->log($nStatus . ' ' . $resp->getReasonPhrase(), 1);
if (intval($nStatus / 100) == 2) {
/**
* Log a message to stdout.
*
- * @param string $msg Message to display
- * @param integer $level Log level, see $verbosity
+ * @param string|object $msg Message to display. May even be a response
+ * object
+ * @param integer $level Log level, see $verbosity
*
* @return void
*/
public function log($msg, $level = 1)
{
if ($this->verbosity >= $level) {
+ if ($msg instanceof HTTP_Request2_Response) {
+ echo "HTTP Response:\n";
+ echo $msg->getStatus() . ' ' . $msg->getReasonPhrase() . "\n";
+ echo 'Header: ';
+ var_export($msg->getHeader());
+ echo $msg->getBody() . "\n----\n";
+ return;
+ }
echo $msg . "\n";
}
}