liveteched / request-logs
Store request/response data and headers from receiving API calls
v1.0.1
2021-05-10 14:57 UTC
Requires
- php: ^8.0
- ext-json: *
- illuminate/contracts: ^8.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.0
- orchestra/testbench: ^6.0
- phpunit/phpunit: ^9
This package is auto-updated.
Last update: 2024-04-24 21:01:38 UTC
README
The liveteched/request-logs
package provides way to store API call request/response data with headers and custom attributes
The Package stores all requests in the request_logs
table with ability to define polymorphic relationships in request_log_relations
table.
The Package doesn't provide views to see logs, you can do that yourself if you need it.
There are two optional fields in request_logs
table
channel
- used to set unique channel name for API. Ex:client1-api
action
- used to set API action. Ex:login
,retrieve
,event_modified
etc
Both are used for easier searching/handling DB records
Installation:
$ composer require shambou/request-logs
$ php artisan requestlogs:install
$ php artisan migrate
Configuration:
return [
/*
* Currently supports only json and soap channels
* Keep in mind that all channels must be defined in single dimension:
* ex: 'json' => ['client-api', 'second-client-api']
*
* Used to parse request/response data from DB
* ex:
* {
* "data1": "something",
* "data2": "something",
* "data3": "something"
* }
*
* will become:
*
* data1: something\n
* data2: something\n
* data3: something
*
* This is attached automatically to \Models\RequestLog parsed_request and parsed_response attributes
*/
'channels' => [
'json' => [],
'soap' => []
]
];
Example usage 1: REST
$startTime = microtime(true);
$response = response()->json([
'success' => true
]);
$relation = User::find(1);
RequestLogFactory::createForRest($request)
->setJsonResponse($response)
->setAction('login')
->setChannel('client-api')
->setExectionTime(microtime(true) - $startTime)
->setCustomData([
'transaction_id' => 'ecfe78cc-10ce-49d2-bb31-29b01da03fc6'
])
->storeLog($relation);
Example usage 2: SOAP
$wsdlUrl = 'https://api.example.com/soap/V10023.ASMX?WSDL'
$startTime = microtime(true);
$relation = User::find(1);
RequestLogFactory::createForSoap($wdsUrl, $soapClient)
->setAction('login')
->setChannel('client-soap-api')
->setExectionTime(microtime(true) - $startTime)
->setCustomData([
'transaction_id' => 'ecfe78cc-10ce-49d2-bb31-29b01da03fc6'
])
->storeLog($relation);