A quick tip if you want to see/log the raw HTTP responses when interfacing with a PHP library that does not expose the responses.
Default Situation
Imagine you want to request some video details from the YouTube API but also want to inspect some headers of the response.
$service = new \Google\Service\YouTube(
app(\Google\Client::class)
);
$response = $service->videos->listVideos([
'part' => 'snippet,contentDetails,status',
], [
'id' => 'dQw4w9WgXcQ',
]);
// $response->getHttpResponse() ??? doesn't exist...
The Google/YouTube PHP library does not allow you to do so.
Add Guzzle Middleware
Instead, we simply add a history middleware to the HTTP client, in our case Guzzle.
$service = new \Google\Service\YouTube(
app(\Google\Client::class)
);
// Create a array accessible stack which guzzle pushes req/res to
$history = [];
$handlerStack = \GuzzleHttp\HandlerStack::create();
$handlerStack->push(
\GuzzleHttp\Middleware::history($history) // pass by ref
);
// Create a new HTTP client. We need to set the 'base_uri' to the YouTube configured base path.
$httpClient = new \GuzzleHttp\Client([
'base_uri' => $service->getClient()->getConfig('base_path'),
'debug' => true,
'handler' => $handlerStack,
]);
// Replace the default HTTP client with our HTTP client
$service->getClient()->setHttpClient($httpClient);
$response = $service->videos->listVideos([
'part' => 'snippet,contentDetails,status',
], [
'id' => 'dQw4w9WgXcQ',
]);
// Dump the history stack
dd($history);
It's that easy.
Read more...
data:image/s3,"s3://crabby-images/9b7f6/9b7f63788883dc33e3c4f545d9f751f4f5041993" alt="Get TTS with natural Voices on macOS without external Tools"
Get TTS with natural Voices on macOS without external Tools
You don't need fancy tool to get Text-to-Speech on macOS, even baked into Firefox
data:image/s3,"s3://crabby-images/2ea9e/2ea9e296cd9e0f5788e03f49727991a157166507" alt="Stop all Adobe & Creative Cloud Processes on macOS via Script"
Stop all Adobe & Creative Cloud Processes on macOS via Script
Installing any Adobe Software on your computer comes with a huge load of bloatware. Stop all of this with a simple shell script.
Comments