async file reader restructure part 4
This commit is contained in:
parent
fed08286ee
commit
67239cd1a9
@ -5,6 +5,7 @@
|
|||||||
namespace ManiaControl\Files;
|
namespace ManiaControl\Files;
|
||||||
|
|
||||||
use cURL\Event;
|
use cURL\Event;
|
||||||
|
use cURL\Request;
|
||||||
use ManiaControl\ManiaControl;
|
use ManiaControl\ManiaControl;
|
||||||
|
|
||||||
class AsyncHttpRequest {
|
class AsyncHttpRequest {
|
||||||
@ -23,7 +24,28 @@ class AsyncHttpRequest {
|
|||||||
$this->url = $url;
|
$this->url = $url;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new cURL Request for the given URL
|
||||||
|
*
|
||||||
|
* @param string $url
|
||||||
|
* @return Request
|
||||||
|
*/
|
||||||
|
private function newRequest($url) {
|
||||||
|
$request = new Request($url);
|
||||||
|
$request->getOptions()->set(CURLOPT_TIMEOUT, 60)->set(CURLOPT_HEADER, false)// don't display response header
|
||||||
|
->set(CURLOPT_CRLF, true)// linux line feed
|
||||||
|
->set(CURLOPT_ENCODING, '')// accept encoding
|
||||||
|
->set(CURLOPT_USERAGENT, 'ManiaControl v' . ManiaControl::VERSION)// user-agent
|
||||||
|
->set(CURLOPT_RETURNTRANSFER, true); // return instead of output content
|
||||||
|
return $request;
|
||||||
|
}
|
||||||
|
|
||||||
//TODO merge loadFile / postData
|
//TODO merge loadFile / postData
|
||||||
|
/**
|
||||||
|
* Carry out a GetData Request
|
||||||
|
*
|
||||||
|
* @param int $keepAlive
|
||||||
|
*/
|
||||||
public function getData($keepAlive = 0) {
|
public function getData($keepAlive = 0) {
|
||||||
array_push($this->headers, 'Content-Type: ' . $this->contentType);
|
array_push($this->headers, 'Content-Type: ' . $this->contentType);
|
||||||
if ($keepAlive) {
|
if ($keepAlive) {
|
||||||
@ -31,8 +53,7 @@ class AsyncHttpRequest {
|
|||||||
array_push($headers, 'Connection: Keep-Alive');
|
array_push($headers, 'Connection: Keep-Alive');
|
||||||
}
|
}
|
||||||
|
|
||||||
$fileReader = new AsynchronousFileReader($this->maniaControl);
|
$request = $this->newRequest($this->url);
|
||||||
$request = $fileReader->newRequest($this->url);
|
|
||||||
$request->getOptions()->set(CURLOPT_AUTOREFERER, true)// accept link reference
|
$request->getOptions()->set(CURLOPT_AUTOREFERER, true)// accept link reference
|
||||||
->set(CURLOPT_HTTPHEADER, $this->headers); // headers
|
->set(CURLOPT_HTTPHEADER, $this->headers); // headers
|
||||||
|
|
||||||
@ -47,10 +68,14 @@ class AsyncHttpRequest {
|
|||||||
call_user_func($function, $content, $error);
|
call_user_func($function, $content, $error);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$fileReader = new AsynchronousFileReader($this->maniaControl);
|
||||||
$fileReader->addRequest($request);
|
$fileReader->addRequest($request);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Carry out a PostData Request
|
||||||
|
*/
|
||||||
public function postData() {
|
public function postData() {
|
||||||
array_push($this->headers, 'Content-Type: ' . $this->contentType);
|
array_push($this->headers, 'Content-Type: ' . $this->contentType);
|
||||||
array_push($this->headers, 'Keep-Alive: timeout=600, max=2000');
|
array_push($this->headers, 'Keep-Alive: timeout=600, max=2000');
|
||||||
@ -63,9 +88,7 @@ class AsyncHttpRequest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$fileReader = new AsynchronousFileReader($this->maniaControl);
|
$request = $this->newRequest($this->url);
|
||||||
|
|
||||||
$request = $fileReader->newRequest($this->url);
|
|
||||||
$request->getOptions()->set(CURLOPT_POST, true)// post method
|
$request->getOptions()->set(CURLOPT_POST, true)// post method
|
||||||
->set(CURLOPT_POSTFIELDS, $content)// post content field
|
->set(CURLOPT_POSTFIELDS, $content)// post content field
|
||||||
->set(CURLOPT_HTTPHEADER, $this->headers) // headers
|
->set(CURLOPT_HTTPHEADER, $this->headers) // headers
|
||||||
@ -81,6 +104,7 @@ class AsyncHttpRequest {
|
|||||||
call_user_func($function, $content, $error);
|
call_user_func($function, $content, $error);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$fileReader = new AsynchronousFileReader($this->maniaControl);
|
||||||
$fileReader->addRequest($request);
|
$fileReader->addRequest($request);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -66,6 +66,7 @@ class AsynchronousFileReader {
|
|||||||
* @param string $contentType
|
* @param string $contentType
|
||||||
* @param int $keepAlive
|
* @param int $keepAlive
|
||||||
* @param array $headers Additional Headers
|
* @param array $headers Additional Headers
|
||||||
|
* @deprecated @see ManiaControl\Files\AsyncHttpRequest
|
||||||
*/
|
*/
|
||||||
public function loadFile($url, callable $function, $contentType = 'UTF-8', $keepAlive = 0, $headers = array()) {
|
public function loadFile($url, callable $function, $contentType = 'UTF-8', $keepAlive = 0, $headers = array()) {
|
||||||
$httpRequest = new AsyncHttpRequest($this->maniaControl, $url);
|
$httpRequest = new AsyncHttpRequest($this->maniaControl, $url);
|
||||||
@ -73,32 +74,6 @@ class AsynchronousFileReader {
|
|||||||
$httpRequest->getData($keepAlive);
|
$httpRequest->getData($keepAlive);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Create a new cURL Request for the given URL, DO NOT CALL MANUALLY!
|
|
||||||
*
|
|
||||||
* @param string $url
|
|
||||||
* @return Request
|
|
||||||
*/
|
|
||||||
public function newRequest($url) {
|
|
||||||
$request = new Request($url);
|
|
||||||
$request->getOptions()->set(CURLOPT_TIMEOUT, 60)->set(CURLOPT_HEADER, false)// don't display response header
|
|
||||||
->set(CURLOPT_CRLF, true)// linux line feed
|
|
||||||
->set(CURLOPT_ENCODING, '')// accept encoding
|
|
||||||
->set(CURLOPT_USERAGENT, 'ManiaControl v' . ManiaControl::VERSION)// user-agent
|
|
||||||
->set(CURLOPT_RETURNTRANSFER, true); // return instead of output content
|
|
||||||
return $request;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Add a Request to the queue, DO NOT CALL MANUALLY!
|
|
||||||
*
|
|
||||||
* @param Request $request
|
|
||||||
*/
|
|
||||||
public function addRequest(Request $request) {
|
|
||||||
array_push($this->requests, $request);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send Data via POST Method
|
* Send Data via POST Method
|
||||||
*
|
*
|
||||||
@ -108,10 +83,20 @@ class AsynchronousFileReader {
|
|||||||
* @param bool $compression
|
* @param bool $compression
|
||||||
* @param string $contentType
|
* @param string $contentType
|
||||||
* @param array $headers Additional Headers
|
* @param array $headers Additional Headers
|
||||||
|
* @deprecated @see ManiaControl\Files\AsyncHttpRequest
|
||||||
*/
|
*/
|
||||||
public function postData($url, callable $function, $content, $compression = false, $contentType = 'text/xml; charset=UTF-8;', $headers = array()) {
|
public function postData($url, callable $function, $content, $compression = false, $contentType = 'text/xml; charset=UTF-8;', $headers = array()) {
|
||||||
$httpRequest = new AsyncHttpRequest($this->maniaControl, $url);
|
$httpRequest = new AsyncHttpRequest($this->maniaControl, $url);
|
||||||
$httpRequest->setCallable($function)->setContent($content)->setCompression($compression)->setContentType($contentType)->setHeaders($headers);
|
$httpRequest->setCallable($function)->setContent($content)->setCompression($compression)->setContentType($contentType)->setHeaders($headers);
|
||||||
$httpRequest->postData();
|
$httpRequest->postData();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add a Request to the queue, DO NOT CALL MANUALLY!
|
||||||
|
*
|
||||||
|
* @param Request $request
|
||||||
|
*/
|
||||||
|
public function addRequest(Request $request) {
|
||||||
|
array_push($this->requests, $request);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user