illuma-law / healthcheck-mercure
Focused mercure health check for Spatie's Laravel Health package.
Fund package maintenance!
v0.1.2
2026-04-20 18:47 UTC
Requires
- php: ^8.3
- illuminate/contracts: ^11.0||^12.0||^13.0
- illuminate/database: ^11.0||^12.0||^13.0
- illuminate/support: ^11.0||^12.0||^13.0
- spatie/laravel-health: ^1.39
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.8
- orchestra/testbench: ^11.1.0
- pestphp/pest: ^4.0
- pestphp/pest-plugin-arch: ^4.0
- pestphp/pest-plugin-laravel: ^4.0
- phpstan/extension-installer: ^1.4
- phpstan/phpstan-deprecation-rules: ^2.0
- phpstan/phpstan-phpunit: ^2.0
- spatie/laravel-ray: ^1.35
README
A focused mercure health check for Spatie's Laravel Health package.
This package provides a simple, direct health check to verify that your application's Mercure hub is reachable and responding to HTTP requests.
Features
- Reachability Check: Verifies that your Laravel application can successfully connect to the configured Mercure hub URL.
- HTTP Status Validation: Ensures the Mercure hub returns a successful HTTP status code (2xx).
- Configurable Timeout: Respects your configured timeout settings to prevent the health check from hanging.
Installation
Require this package with composer:
composer require illuma-law/healthcheck-mercure
Usage & Integration
Register the check inside your application's health service provider (e.g. AppServiceProvider or a dedicated HealthServiceProvider), alongside your other Spatie Laravel Health checks:
Basic Registration
use IllumaLaw\HealthCheckMercure\MercureCheck; use Spatie\Health\Facades\Health; Health::checks([ MercureCheck::new(), ]);
Expected Result States
The check interacts with the Spatie Health dashboard and JSON endpoints using these states:
- Ok: Mercure hub is reachable and returned a 2xx status code.
- Failed: Mercure hub was unreachable, timed out, or returned an error status code (4xx/5xx).
Testing
Run the test suite:
composer test
License
The MIT License (MIT). Please see License File for more information.