me-shaon / laravel-request-analytics
Simple request data analytics package for Laravel projects
Fund package maintenance!
me-shaon
Requires
- php: ^8.1 | ^8.2 | ^8.3
- illuminate/contracts: ^10.0 | ^11.0 | ^12.0
- spatie/laravel-package-tools: ^1.14.0
Requires (Dev)
- laravel/pint: ^1.0
- mockery/mockery: ^1.6
- nunomaduro/collision: ^7.8 | ^8.1
- orchestra/workbench: ^8.0 | ^9.0 | ^10.0
- phpunit/phpunit: ^10.5 | ^11.0
- rector/rector: ^1.0.0
- dev-main
- v1.2.0
- v1.1.2
- v1.1.1
- v1.1.0
- v1.0.0
- v0.1.0
- dev-fix/country-icon
- dev-feat/calendar-filter
- dev-dependabot/composer/rector/rector-tw-2.1.6
- dev-dependabot/github_actions/actions/checkout-5
- dev-feature/package-improvements
- dev-datbase-config
- dev-theihasan-laravel-12-support
- dev-Access-controll
- dev-schedule-data-purning
- dev-fix-middleware-not-trigraing-issue
- dev-dashboard
- dev-store-requests
- dev-middleware
- dev-fixed/replace-icons-with-assets
- dev-feat/add-blade-components
- dev-fix/publishing-migration
- dev-migration
This package is auto-updated.
Last update: 2025-09-09 18:31:50 UTC
README
Overview
Laravel Request Analytics is a comprehensive web analytics solution designed specifically for Laravel applications. This package provides detailed insights into your application's traffic patterns, user behavior, and performance metrics through an intuitive dashboard and powerful API endpoints.
Built with performance and privacy in mind, the package offers intelligent bot detection, IP geolocation services, and GDPR-compliant data handling. Whether you're running a small blog or a large-scale application, Laravel Request Analytics provides the tools you need to understand your audience and optimize user experience.
Installation
Requirements
- PHP 8.1 or higher
- Laravel 10.0 or higher
- MySQL 5.7+ / PostgreSQL 10+ / SQLite 3.8+
Install via Composer
Install the package using Composer:
composer require me-shaon/laravel-request-analytics
Database Setup
Publish and run the migrations:
php artisan vendor:publish --tag="request-analytics-migrations"
php artisan migrate
Configuration
Publish the configuration file:
php artisan vendor:publish --tag="request-analytics-config"
The configuration file will be published to config/request-analytics.php
with the following options:
return [ 'database' => [ 'connection' => env('REQUEST_ANALYTICS_DB_CONNECTION', null), // Use default connection if null 'table' => env('REQUEST_ANALYTICS_TABLE_NAME', 'request_analytics'), ], 'route' => [ 'name' => 'request.analytics', 'pathname' => env('REQUEST_ANALYTICS_PATHNAME', 'analytics'), ], 'capture' => [ 'web' => true, 'api' => true, 'bots' => false, // Set to true to capture bot traffic ], 'middleware' => [ 'web' => [ 'web', // 'auth', // Uncomment if using web authentication 'request-analytics.access', ], 'api' => [ 'api', // 'auth:sanctum', // Uncomment if using Sanctum authentication 'request-analytics.access', ], ], 'queue' => [ 'enabled' => env('REQUEST_ANALYTICS_QUEUE_ENABLED', false), ], 'ignore-paths' => [ env('REQUEST_ANALYTICS_PATHNAME', 'analytics'), ], 'pruning' => [ 'enabled' => env('REQUEST_ANALYTICS_PRUNING_ENABLED', true), 'days' => env('REQUEST_ANALYTICS_PRUNING_DAYS', 90), ], 'geolocation' => [ 'enabled' => env('REQUEST_ANALYTICS_GEO_ENABLED', true), 'provider' => env('REQUEST_ANALYTICS_GEO_PROVIDER', 'ipapi'), // ipapi, ipgeolocation, maxmind 'api_key' => env('REQUEST_ANALYTICS_GEO_API_KEY'), // MaxMind specific configuration 'maxmind' => [ 'type' => env('REQUEST_ANALYTICS_MAXMIND_TYPE', 'webservice'), // webservice or database 'user_id' => env('REQUEST_ANALYTICS_MAXMIND_USER_ID'), 'license_key' => env('REQUEST_ANALYTICS_MAXMIND_LICENSE_KEY'), 'database_path' => env('REQUEST_ANALYTICS_MAXMIND_DB_PATH', storage_path('app/GeoLite2-City.mmdb')), ], ], 'privacy' => [ 'anonymize_ip' => env('REQUEST_ANALYTICS_ANONYMIZE_IP', false), 'respect_dnt' => env('REQUEST_ANALYTICS_RESPECT_DNT', true), // Respect Do Not Track header ], 'cache' => [ 'ttl' => env('REQUEST_ANALYTICS_CACHE_TTL', 5), // Cache TTL in minutes ], ];
Assets & Views
Publish dashboard assets:
php artisan vendor:publish --tag="request-analytics-assets"
Optionally, publish the views for customization:
php artisan vendor:publish --tag="request-analytics-views"
Automated Data Pruning
The package includes automatic data cleanup to manage database size. Configure pruning in your scheduler:
Laravel 11+
Add to routes/console.php
:
use Illuminate\Support\Facades\Schedule; Schedule::command('model:prune', [ '--model' => 'MeShaon\RequestAnalytics\Models\RequestAnalytics', ])->daily();
Or in bootstrap/app.php
:
use Illuminate\Console\Scheduling\Schedule; ->withSchedule(function (Schedule $schedule) { $schedule->command('model:prune', [ '--model' => 'MeShaon\RequestAnalytics\Models\RequestAnalytics', ])->daily(); })
Laravel 10 and below
Add to app/Console/Kernel.php
:
protected function schedule(Schedule $schedule): void { $schedule->command('model:prune', [ '--model' => 'MeShaon\RequestAnalytics\Models\RequestAnalytics', ])->daily(); }
Key Features
Analytics & Reporting
- Real-time Dashboard: Interactive charts and metrics with responsive design
- Comprehensive Metrics: Page views, unique visitors, bounce rates, and session duration
- Traffic Analysis: Detailed breakdown of traffic sources and user pathways
- Performance Insights: Load times and user interaction patterns
Privacy & Compliance
- GDPR Compliance: Built-in privacy controls and data anonymization
- IP Anonymization: Configurable IP address masking for user privacy
- Do Not Track Support: Respects browser DNT headers automatically
- Data Retention: Configurable automatic data pruning and cleanup
Intelligence & Detection
- Advanced Bot Detection: Filters search engines, social bots, and crawlers
- Device Recognition: Browser, OS, and device type identification
- Geolocation Services: Multiple provider support (IP-API, IPGeolocation, MaxMind)
- Visitor Tracking: Cookie-based unique visitor identification
Performance & Integration
- High Performance: Optimized database queries with intelligent caching
- Queue Support: Background processing for high-traffic applications
- REST API: Complete programmatic access to analytics data
- Laravel Integration: Seamless integration with Laravel's authentication and middleware systems
Usage
Configuration Options
Route Configuration
route.name
: Named route identifier (default:request.analytics
)route.pathname
: URL path for dashboard access (default:analytics
)
Data Capture Settings
capture.web
: Track web requests (default:true
)capture.api
: Track API requests (default:true
)capture.bots
: Include bot traffic in analytics (default:false
)
Queue Processing
queue.enabled
: Process analytics data in background jobs for better performance
Path Filtering
ignore-paths
: Array of paths to exclude from tracking (e.g., admin routes, health checks)
Data Retention
pruning.enabled
: Automatic data cleanup (default:true
)pruning.days
: Days to retain data (default: 90)
Geolocation Services
The package supports multiple geolocation providers:
IP-API (Default - Free)
'geolocation' => [ 'enabled' => true, 'provider' => 'ipapi', 'api_key' => null, // Not required ]
- No API key required
- 45 requests per minute limit
- Includes country, region, city, timezone
IPGeolocation
'geolocation' => [ 'enabled' => true, 'provider' => 'ipgeolocation', 'api_key' => env('REQUEST_ANALYTICS_GEO_API_KEY'), ]
- Requires API key from ipgeolocation.io
- Higher rate limits and accuracy
- Additional ISP and threat intelligence data
MaxMind
'geolocation' => [ 'enabled' => true, 'provider' => 'maxmind', 'api_key' => env('REQUEST_ANALYTICS_GEO_API_KEY'), ]
- Requires GeoIP2 database or web service account
- Highest accuracy and performance
- Enterprise-grade IP intelligence
Privacy & Compliance
'privacy' => [ 'anonymize_ip' => env('REQUEST_ANALYTICS_ANONYMIZE_IP', false), 'respect_dnt' => env('REQUEST_ANALYTICS_RESPECT_DNT', true), ]
- IP Anonymization: Masks the last octet of IPv4 addresses (192.168.1.xxx)
- Do Not Track: Automatically respects browser DNT headers
Bot Detection
Advanced bot detection includes:
- Search Engines: Google, Bing, Yahoo, DuckDuckGo, Baidu
- Social Media: Facebook, Twitter, LinkedIn, Pinterest crawlers
- SEO Tools: Ahrefs, SEMrush, Moz, Screaming Frog
- Monitoring: Pingdom, UptimeRobot, StatusCake
- Development: curl, wget, Postman, Insomnia
Dashboard Access & Usage
Dashboard Access
The analytics dashboard is available at /analytics
by default. Access the dashboard through your configured route after authentication.
Access Control
Implement the CanAccessAnalyticsDashboard
interface in your User model to control dashboard access:
<?php namespace App\Models; use Illuminate\Foundation\Auth\User as Authenticatable; use MeShaon\RequestAnalytics\Contracts\CanAccessAnalyticsDashboard; class User extends Authenticatable implements CanAccessAnalyticsDashboard { public function canAccessAnalyticsDashboard(): bool { // Example: Only allow admin users return $this->role === 'admin'; // Or check specific permissions // return $this->can('view-analytics'); // Or allow all authenticated users // return true; } }
Dashboard Features
- Real-time Metrics: Live visitor count, page views, and bounce rate
- Interactive Charts: Traffic trends, geographic distribution, device breakdown
- Top Pages: Most visited pages with performance metrics
- Visitor Insights: Browser, OS, and device analytics
- Traffic Sources: Referrer analysis and search engine traffic
- Performance Data: Page load times and user engagement metrics
API Documentation
The package provides a comprehensive REST API for programmatic access to analytics data.
Endpoints
GET /api/v1/analytics/overview
Retrieve comprehensive analytics overview with summary statistics and chart data.
Parameters:
date_range
(optional): Number of days to look back (1-365, default: 30)start_date
(optional): Start date (YYYY-MM-DD format)end_date
(optional): End date (YYYY-MM-DD format, must be after start_date)with_percentages
(optional): Include percentage data for applicable fields (true/false)
Response:
{ "data": { "summary": { "views": 15420, "visitors": 8760, "bounce_rate": "65.4%", "average_visit_time": "3m 2s" }, "chart": { "labels": ["Jan 01", "Jan 02", "Jan 03"], "datasets": [ {"label": "Views", "data": [120, 150, 180]}, {"label": "Visitors", "data": [85, 95, 110]} ] }, "top_pages": [ {"path": "/home", "views": 1250}, {"path": "/products", "views": 890} ], "top_referrers": [ {"domain": "google.com", "visits": 450}, {"domain": "facebook.com", "visits": 280} ], "browsers": [ {"browser": "Chrome", "count": 5420}, {"browser": "Firefox", "count": 2180} ], "devices": [ {"name": "Desktop", "count": 8760, "percentage": 65.2}, {"name": "Mobile", "count": 4680, "percentage": 34.8} ], "countries": [ {"name": "United States", "count": 5420, "percentage": 40.2, "code": "us"}, {"name": "Canada", "count": 2180, "percentage": 16.1, "code": "ca"} ], "operating_systems": [ {"name": "Windows", "count": 6840, "percentage": 50.8}, {"name": "macOS", "count": 3920, "percentage": 29.1} ] }, "date_range": { "start": "2024-01-01T00:00:00.000000Z", "end": "2024-01-31T23:59:59.000000Z", "days": 30, "key": "2024-01-01_2024-01-31" } }
GET /api/v1/analytics/visitors
Get paginated visitor data with detailed information.
Parameters:
date_range
(optional): Number of days to look back (1-365, default: 30)page
(optional): Page number for pagination (default: 1)per_page
(optional): Items per page, max 100 (default: 50)
Response:
{ "data": { "current_page": 1, "data": [ { "visitor_id": "abc123xyz", "page_views": 15, "sessions": 3, "first_visit": "2024-01-10T10:30:00.000000Z", "last_visit": "2024-01-15T14:30:00.000000Z", "unique_pages": 8 } ], "total": 8760, "per_page": 50, "last_page": 176 } }
GET /api/v1/analytics/page-views
Retrieve paginated page view data with performance metrics.
Parameters:
date_range
(optional): Number of days to look back (1-365, default: 30)path
(optional): Filter by specific path pattern (partial match)page
(optional): Page number for pagination (default: 1)per_page
(optional): Items per page, max 100 (default: 50)
Response:
{ "data": { "current_page": 1, "data": [ { "id": 1, "path": "/products/smartphone", "page_title": "Latest Smartphones", "ip_address": "192.168.1.***", "operating_system": "Windows 10", "browser": "Chrome", "device": "Desktop", "screen": "1920x1080", "referrer": "https://google.com", "country": "US", "city": "New York", "language": "en-US", "query_params": "{\"utm_source\":\"google\"}", "session_id": "abc123xyz", "visitor_id": "def456uvw", "user_id": 42, "http_method": "GET", "request_category": "web", "response_time": 1250, "visited_at": "2024-01-15T14:30:00.000000Z" } ], "total": 15420, "per_page": 50 } }
Error Handling
API responses follow consistent error format:
{ "success": false, "message": "Validation failed", "errors": { "period": ["The selected period is invalid."] } }
Common HTTP Status Codes:
200
: Success400
: Bad Request (validation errors)401
: Unauthorized (invalid or missing token)403
: Forbidden (insufficient permissions)429
: Too Many Requests (rate limited)500
: Internal Server Error
Testing
vendor/bin/phpunit --no-coverage
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.