lezhnev74 / apideveloperio-laravel
Laravel package to track each http request/response and send them to apideveloper.io
Installs: 13 941
Dependents: 0
Suggesters: 0
Security: 0
Stars: 21
Watchers: 4
Forks: 5
Open Issues: 2
Requires
- php: >=5.6.4
- guzzlehttp/guzzle: ~6.0|~5.0
- illuminate/support: ~5.4|~5.5|~5.6
Requires (Dev)
- orchestra/testbench: ^3.4|^3.5|^3.6
- phpunit/phpunit: ~5.0|~6.0|~7.0
This package is auto-updated.
Last update: 2024-11-29 05:38:59 UTC
README
Laravel package to dump HTTP requests to your Dashboard
Laravel API adapter to track each http request app handled.
Installation
Version Compability
Steps
1. Install the package
composer require "lezhnev74/apideveloperio-laravel=~3.0"
2. Add service provider to your config/app.php
'providers' => [ ... '\HttpAnalyzer\Laravel\HttpAnalyzerServiceProvider' ],
3. Run this this command to publish configuration file to your /config
folder.
php artisan vendor:publish --provider="HttpAnalyzer\Laravel\HttpAnalyzerServiceProvider"
4. Set-up cron command
To dump recorded requests to the Dashboard. Open your app/Console/Kernel.php
and add class to commands list.
#app/Console/Kernel.php .... protected $commands = [ ... '\HttpAnalyzer\Laravel\DumpRecordedRequests', ]; ... protected function schedule(Schedule $schedule) { // you can set how often you want it to dump your requests to the Dashboard // every minute is the most frequent mode $schedule->command('http_analyzer:dump')->everyMinute(); }
5. That's it!
Configuration
After publishing, config file will be located at config/http_analyzer.php
and speaks for himself.
The only required configuration is to put your API Key under api_key
field.
FAQ
How it works?
It hooks into Laravel app and records request, response and other data that you will see in your Dashboard:
- incoming request
- response
- database queries
- log entries
You can tweak which information you would like to send to the Dashboard.
The command http_analyzer:dump
that you have set up will send all recorded requests to your Dashboard.
I see no errors on the screen, but I don't see any requests in my dashboard. Why?
This package is designed to fail silently. If something went wrong while recording your requests - plugin won't interrupt your request lifecycle. Open your log and see if the package appended any critical information in there.
Also check the tmp storage folder if there are any stale dump files.
Suggestions
If user IPs are always 127.0.0.1
That happens due to some Symfony's Request issue. Try using this package - https://github.com/fideloper/TrustedProxy. Should do the trick.
What is the best way to track each request?
When someone refers to particular request/response app cycle, it is best to know it's unique ID. Knowing it you can easily find it in the Dashboard. Just add a middleware (like this one https://github.com/softonic/laravel-middleware-request-id) which will append a unique ID to each response your app provides.
🏆 Contributors
- Owen Melbourne - improved dates conversions
- Mark Topper - added support for Laravel 5.6
Support
Just open a new Issue here and get help.