No description
  • PHP 93.8%
  • Nix 6.2%
Find a file
2024-08-03 23:11:22 +10:00
.github/workflows Initial Commit 2024-07-19 14:12:18 +10:00
config Add missing table names 2024-07-19 18:22:40 +10:00
database/migrations Small typing improvements and fix wrong column call 2024-07-19 19:38:49 +10:00
src Don't load migrations, users should publish them 2024-08-03 22:58:57 +10:00
tests Fix missing migrations in tests 2024-08-03 23:06:01 +10:00
.editorconfig Initial Commit 2024-07-19 14:12:18 +10:00
.envrc Initial Commit 2024-07-19 14:12:18 +10:00
.gitignore Ignore PHPStan cache 2024-07-19 17:43:18 +10:00
CHANGELOG.md Initial Commit 2024-07-19 14:12:18 +10:00
composer.json Fix versioning 2024-08-03 23:11:22 +10:00
devenv.nix Initial Commit 2024-07-19 14:12:18 +10:00
devenv.yaml Initial Commit 2024-07-19 14:12:18 +10:00
LICENSE.md Update README and add a license file 2024-07-19 19:23:32 +10:00
phpstan.neon Initial Commit 2024-07-19 14:12:18 +10:00
phpunit.xml Initial Commit 2024-07-19 14:12:18 +10:00
pint.json Space around parenthesis for functions 2024-07-19 18:25:57 +10:00
README.md Don't load migrations, users should publish them 2024-08-03 22:58:57 +10:00

Laravel Analytics

🚧 This package is still a work in progress

A simple, extremely lightweight analytics package.

Requirements

  • Laravel 10+

Installation

Install using Composer:

composer require rvxlab/laravel-analytics

Publish and run the migrations:

php artisan vendor:publish --tag="analytics-migrations"

php artisan migrate

Optional: Publish the config file:

php artisan vendor:publish --tag="analytics-config"

Setting up

There are 2 ways of setting up analytics:

  1. Globally
  2. In a route group

Globally (Laravel 11)

Add the RVxLab\Analytics\Middleware\RecordPageView middleware by calling append or appendToGroup on the Illuminate\Foundation\Configuration\Middlewares parameter of the withMiddleware call:

use Illuminate\Foundation\Application;
use Illuminate\Foundation\Configuration\Middleware;
use RVxLab\Analytics\Middleware\RecordPageView;

return Application::configure(basePath: dirname(__DIR__))
    ->withMiddleware(function (Middleware $middleware) {
        $middleware->append([RecordPageView::class]);
        // OR
        $middleware->appendToGroup('<middlewareGroup>', [RecordPageView::class]);
    })->create();

Globally (Laravel 10 and 11 without the new slim skeleton)

Add the RVxLab\Analytics\Middleware\RecordPageView middleware to the end of your middleware array or the relevant group in your middlewareGroups array of your App\Http\Kernel:

namespace App\Http;

use RVxLab\Analytics\Middleware\RecordPageView;

class Kernel 
{
    protected $middleware = [
        // --snip--
        RecordPageView::class,
    ];

    protected $middlewareGroups = [
        'web' => [
            // --snip--
            RecordPageView::class,
        ],
    ];
}

Per route

You can add the RVxLab\Analytics\Middleware\RecordPageView middleware to a single route or to a group of routes:

use App\Http\Controllers\HomeController;
use RVxLab\Analytics\Middleware\RecordPageView;

Route::get('/', HomeController::class)->middleware([RecordPageView::class]);

// OR

Route::middleware([RecordPageView::class])->group(function () {
    Route::get('/', HomeController::class);
});

Dealing with proxies

If your application is behind a proxy, make sure that proxy is defined in the trusted proxies.

Not doing so will cause the address in your analytics to always be 127.0.0.1.

For example, if you use a simple site provisioned through Laravel Forge, you will want to add '127.0.0.1' to your trusted proxies. If you're behind a load balance through AWS or go through CloudFlare, you may not know what IP the request will come from. In that case, just add '*' to your trusted proxies.

See the Laravel documentation on trusted proxies for more information.

Using a separate database

If you wish to use a separate database for analytics, add an ANALYTICS_DB_CONNECTION environment variable and set it to the connection you want to use. Make sure it exists in your config/database.php file.

Changelog

Please see the Changelog for more information on what has changed recently.

License

The MIT License (MIT). Please see the License File for more information.