letsgoi / laravel-health-check
Laravel health checker
Installs: 17 248
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 6
Forks: 1
Open Issues: 0
Requires
- php: ^8.3
- ext-json: *
- illuminate/support: ^10.0|^11.0
Requires (Dev)
- letsgoi/php-code-style: ^1.3
- orchestra/testbench: ^9.1
- phpunit/phpunit: ^11.2
README
Package to perform health check analysis based on defined checkers.
Requirements
- PHP >= 8.3
- Laravel >= 10.0
Instalation
- Require package with composer:
composer require letsgoi/laravel-health-check
- Publish configuration:
php artisan vendor:publish --provider="Letsgoi\HealthCheck\HealthCheckServiceProvider" --tag="config"
Service Provider will be automatically registered, however if you want to add it manually, you must add this to your config/app.php
file:
'providers' => [ // ... Letsgoi\HealthCheck\HealthCheckServiceProvider::class, ];
Configuration
You must set all checkers that want to pass your application at checkers array on config file (config/laravel_health_check.php
):
'checkers' => [ ... Letsgoi\HealthCheck\Checkers\DatabaseConnectionChecker::class, Letsgoi\HealthCheck\Checkers\WritablePathsChecker::class, ... ],
You can check any checker without check all, but this configuration is for general check.
Usage
Check individual checker
Use HealthCheck
facade to check an individual checker:
use Letsgoi\HealthCheck\Facades; HealthCheck::check(new Checker());
it will return true
if check pass and it will throw HealthCheckerException
if not.
Check all checkers defined at configuration file
To check all checkers defined at configuration file use healthCheck
method of HealthCheck
facade:
use Letsgoi\HealthCheck\Facades; HealthCheck::healthCheck();
it will return true
if all checks pass and throw HealthCheckerException
with failed checkers if not.
Get check errors
If you want to get all check errors of checkers defined at configuration file, you can use getCheckErrors
method:
use Letsgoi\HealthCheck\Facades; HealthCheck::getCheckErrors();
It returns an array with all errors.
HealthCheck command
You can run the healthcheck with artisan command:
php artisan health-check
It show ok if all checks pass or exceptions if fails.
HealthCheck endpoint
You can configure an endpoint to check the health of your app. Configure it on config file (laravel_health_check
):
... 'endpoint' => [ 'enabled' => env('HEALTH_CHECK_ENDPOINT_ENABLED', true), // Enable/disable endpoint 'path' => env('HEALTH_CHECK_ENDPOINT_PATH', '/health-check'), // Configure path of endpoint 'healthy_message' => env('HEALTH_CHECK_ENDPOINT_HEALTHY_MESSAGE', 'Healthy'), // Set ok message ], ...
It will return the ok message if all check passed or a server error with the array of errors.
Checkers
Available checkers
Those are the available predefined checkers:
Letsgoi\HealthCheck\Checkers\AppKeyChecker
: Checks if there is an app key defined as environment variable.Letsgoi\HealthCheck\Checkers\DatabaseConnectionChecker
: Checks if the app can connect with default database connection.Letsgoi\HealthCheck\Checkers\DatabaseMigrationsChecker
: Checks if all migrations are up to date.Letsgoi\HealthCheck\Checkers\DebugChecker
: Checks if the app is not on debug mode.Letsgoi\HealthCheck\Checkers\EnvFileChecker
: Checks if there is an .env file.Letsgoi\HealthCheck\Checkers\WritablePathsChecker
: Checks if the necessary paths are writable.
Custom checkers
If you need some custom checker (or someone not available yet, PRs are welcome :)), you can do simply implementing the Letsgoi\HealthCheck\Contracts\HealthChecker
contract.
It forces to implement a check
method that returns true
if check pass or false
if not.
Then you can use normally adding to your config file or checking it with individual mode.
Testing
Run tests:
composer test
Contributing
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
Please make sure to update tests as appropriate.