Skip to content

Latest commit

 

History

History
61 lines (49 loc) · 1.45 KB

UsageExampleV2.md

File metadata and controls

61 lines (49 loc) · 1.45 KB

Usage

<?php
require_once './vendor/autoload.php';

$apiUrl = 'https://api.raygun.com';
$proxy = 'some://proxy';
$apiKey = 'INSERT_API_KEY_HERE';

$httpClient = new GuzzleHttp\Client([
    'base_uri' => $apiUrl,
    'headers' => ['X-ApiKey' => $apiKey],
    'proxy' => $proxy
]);

// If synchronous message delivery is wanted use Raygun4php\Transports\GuzzleSync
$transport = new Raygun4php\Transports\GuzzleAsync($httpClient);
$client = new Raygun4php\RaygunClient($transport);

// Create and register error handlers
function error_handler($errno, $errstr, $errfile, $errline )
{
   global $client;
   $client->SendError($errno, $errstr, $errfile, $errline);
}

function exception_handler($exception)
{
    global $client;
    $client->SendException($exception);
}

function fatal_error()
{
    global $client;
    $last_error = error_get_last();

    if (!is_null($last_error)) {
        $errno = $last_error['type'];
        $errstr = $last_error['message'];
        $errfile = $last_error['file'];
        $errline = $last_error['line'];
        $client->SendError($errno, $errstr, $errfile, $errline);
    }
}

function flush_on_shutdown()
{
    global $transport;
    $transport->wait();
}

set_exception_handler('exception_handler');
set_error_handler("error_handler");
register_shutdown_function("fatal_error");

// This is needed to if guzzleAsync is used as transport to make sure all request are resolved.
register_shutdown_function("flush_on_shutdown");