Send and execute functions get empty data array by default, not null.

Extract code for setting up the request params into a new function.
parent e85bf7bc
...@@ -132,7 +132,7 @@ class Request ...@@ -132,7 +132,7 @@ class Request
* *
* @return array Fake response data * @return array Fake response data
*/ */
public static function generateGeneralFakeServerResponse(array $data = null) public static function generateGeneralFakeServerResponse(array $data = [])
{ {
//PARAM BINDED IN PHPUNIT TEST FOR TestServerResponse.php //PARAM BINDED IN PHPUNIT TEST FOR TestServerResponse.php
//Maybe this is not the best possible implementation //Maybe this is not the best possible implementation
...@@ -142,7 +142,7 @@ class Request ...@@ -142,7 +142,7 @@ class Request
$fake_response = ['ok' => true]; // :) $fake_response = ['ok' => true]; // :)
if ($data === null) { if ($data === []) {
$fake_response['result'] = true; $fake_response['result'] = true;
} }
...@@ -164,25 +164,14 @@ class Request ...@@ -164,25 +164,14 @@ class Request
} }
/** /**
* Execute HTTP Request * Properly set up the request params
* *
* @param string $action Action to execute * @param array $data
* @param array|null $data Data to attach to the execution
* *
* @return mixed Result of the HTTP Request * @return array
* @throws \Longman\TelegramBot\Exception\TelegramException
*/ */
public static function execute($action, array $data = null) private static function setUpRequestParams(array $data)
{ {
$debug_handle = TelegramLog::getDebugLogTempStream();
//Fix so that the keyboard markup is a string, not an object
if (isset($data['reply_markup']) && !is_string($data['reply_markup'])) {
$data['reply_markup'] = (string)$data['reply_markup'];
}
$request_params = ['debug' => $debug_handle];
//Check for resources in data //Check for resources in data
$contains_resource = false; $contains_resource = false;
foreach ($data as $item) { foreach ($data as $item) {
...@@ -192,6 +181,7 @@ class Request ...@@ -192,6 +181,7 @@ class Request
} }
} }
$request_params = [];
//Reformat data array in multipart way //Reformat data array in multipart way
if ($contains_resource) { if ($contains_resource) {
foreach ($data as $key => $item) { foreach ($data as $key => $item) {
...@@ -201,18 +191,36 @@ class Request ...@@ -201,18 +191,36 @@ class Request
$request_params['form_params'] = $data; $request_params['form_params'] = $data;
} }
$result = ''; return $request_params;
}
/**
* Execute HTTP Request
*
* @param string $action Action to execute
* @param array $data Data to attach to the execution
*
* @return mixed Result of the HTTP Request
* @throws \Longman\TelegramBot\Exception\TelegramException
*/
public static function execute($action, array $data = [])
{
//Fix so that the keyboard markup is a string, not an object
if (isset($data['reply_markup'])) {
$data['reply_markup'] = (string)$data['reply_markup'];
}
$request_params = self::setUpRequestParams($data);
$debug_handle = TelegramLog::getDebugLogTempStream();
$request_params['debug'] = $debug_handle;
try { try {
$result = (string)self::$client->post( $response = self::$client->post(
'/bot' . self::$telegram->getApiKey() . '/' . $action, '/bot' . self::$telegram->getApiKey() . '/' . $action,
$request_params $request_params
)->getBody(); );
} catch (RequestException $e) { $result = (string)$response->getBody();
throw new TelegramException($e->getMessage());
} finally {
//Logging verbose debug output
TelegramLog::endDebugLogTempStream("Verbose HTTP Request output:\n%s\n");
}
//Logging getUpdates Update //Logging getUpdates Update
if ($action === 'getUpdates') { if ($action === 'getUpdates') {
...@@ -220,6 +228,12 @@ class Request ...@@ -220,6 +228,12 @@ class Request
} }
return $result; return $result;
} catch (RequestException $e) {
throw new TelegramException($e->getMessage());
} finally {
//Logging verbose debug output
TelegramLog::endDebugLogTempStream("Verbose HTTP Request output:\n%s\n");
}
} }
/** /**
...@@ -283,12 +297,12 @@ class Request ...@@ -283,12 +297,12 @@ class Request
* @todo Fake response doesn't need json encoding? * @todo Fake response doesn't need json encoding?
* *
* @param string $action * @param string $action
* @param array|null $data * @param array $data
* *
* @return \Longman\TelegramBot\Entities\ServerResponse * @return \Longman\TelegramBot\Entities\ServerResponse
* @throws \Longman\TelegramBot\Exception\TelegramException * @throws \Longman\TelegramBot\Exception\TelegramException
*/ */
public static function send($action, array $data = null) public static function send($action, array $data = [])
{ {
self::ensureValidAction($action); self::ensureValidAction($action);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment