async file reader restructure part 4
This commit is contained in:
		| @@ -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); | ||||||
|  | 	} | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user