voidgraphics / laravel-pageview-counter
There is no license information available for the latest version (v0.1.0) of this package.
A stupid simple analytics tool to keep track of page views
v0.1.0
2024-08-19 21:25 UTC
Requires
- laravel/framework: ^11.0
README
A stupid simple analytics tool to keep track of page views in Laravel projects. It logs requests to a database table and you can access the data with an Eloquent model.
Based on this article by Bastiaan Rudolf.
Installation
composer require voidgraphics/laravel-pageview-counter
You need to publish the migration that will add the pageviews table:
php artisan vendor:publish --tag=pageview-counter-migrations
Then run the migrations
php artisan migrate
After this, register the LogRequest
middleware. You can do it globally or on specific routes. Here's how to install it globally in Laravel 11
// bootstrap/app.php <?php use Illuminate\Foundation\Application; use Illuminate\Foundation\Configuration\Exceptions; use Illuminate\Foundation\Configuration\Middleware; use PageviewCounter\Middleware\LogRequest; return Application::configure(basePath: dirname(__DIR__)) // ... ->withMiddleware(function (Middleware $middleware) { $middleware->append(LogRequest::class); }) // ... ->create();
Accessing the data
Every request hitting those routes will now be logged. You can access that data using the PageviewCounter\Models\Pageview
model. It has 3 scopes to help you query the data.
Pageview::daily()->get(); // Returns the number of views grouped by date and path. /* Illuminate\Database\Eloquent\Collection { all: [ PageviewCounter\Models\Pageview { views: 156, path: "/", date: "2024-07-18", }, PageviewCounter\Models\Pageview { views: 68, path: "about", date: "2024-07-18", } PageviewCounter\Models\Pageview { views: 289, path: "/", date: "2024-07-17", }, PageviewCounter\Models\Pageview { views: 32, path: "about", date: "2024-07-17", } ], } */
Pageview::byPage()->get(); // Get pageviews, grouped by page Illuminate\Database\Eloquent\Collection {#3604 all: [ App\Models\Pageview {#3603 views: 230, path: "/", unique_visitors: 178, latest_visit: "2024-07-23 12:59:19", }, App\Models\Pageview {#3601 views: 132, path: "about", unique_visitors: 129, latest_visit: "2024-07-20 14:27:38", }, ], }
Pageview::withoutBots()->get(); // Exclude most popular bots by user-agent /* Shorthand for: $query->where('useragent', 'not like', '%bot%') ->where('useragent', 'not like', '%python-requests%') ->where('useragent', 'not like', '%http%') ->where('useragent', 'not like', '%node-fetch%') ->where('useragent', 'not like', '%postman%') ->where('useragent', 'not like', '%curl%') */
Pageview::uniqueVisitors()->get(); // Returns the count of unique visitors, grouped by date /* Illuminate\Database\Eloquent\Collection { all: [ PageviewCounter\Models\Pageview { unique_visitors: 176, date: "2024-07-18", }, PageviewCounter\Models\Pageview { unique_visitors: 302, date: "2024-07-17", } ], } */