perfectwebteam / craft-ohdear-application-health
Oh Dear Application Health checker for Craft CMS.
Installs: 390
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
Type:craft-plugin
pkg:composer/perfectwebteam/craft-ohdear-application-health
Requires
- php: ^8.0.2
- craftcms/cms: ^4.0|^5.0
- ohdearapp/health-check-results: ^1.0
This package is not auto-updated.
Last update: 2025-10-15 09:44:04 UTC
README
Oh Dear Application Health checker for Craft CMS
This plugin provides an Oh Dear Application Health checker for Craft CMS.
🚦 Health Checks Overview
This plugin performs the following health checks and provides a JSON feed at /application-health.json
for Oh Dear.
The response is cached for 5 minutes.
âś… Updates
Checks if updates are available for Craft CMS and installed plugins, including critical ones.
âś… Queue Status
Monitors the number of jobs in the queue and detects failed, reserved, or delayed jobs using configurable thresholds.
âś… Pending Migrations
Verifies if there are any unapplied database migrations.
âś… Error Logs
Counts recent errors in today’s log files (web.log
, queue.log
, console.log
).
âś… Git Repository Status
Checks if a .git
repository exists and whether there are uncommitted changes.
âś… Security Headers
Fetches site headers and verifies the presence of key security headers (e.g., CSP, HSTS, X-Frame-Options).
âś… Project Config Status
Confirms if the project configuration is fully synchronized.
âś… PHP Version
Reports the active PHP version running on the server and verifies it against a minimum required version.
âś… Admin Users
Lists all admin users and flags users who haven’t logged in for a configurable period.
âś… Disk Usage
Monitors disk space usage and flags if usage exceeds a configurable threshold.
(Disabled by default to avoid noise on shared servers.)
Requirements
This plugin requires Craft CMS 4.0.0+ or 5.0.0+.
Installation
You can install this plugin from the Plugin Store or with Composer.
From the Plugin Store
Go to the Plugin Store in your project’s Control Panel and search for “Oh Dear Application Health”. Then click on the “Install” button in its modal window.
With Composer
Open your terminal and run the following commands:
# Go to the project directory cd /path/to/my-project.test # Tell Composer to load the plugin composer require perfectwebteam/craft-ohdear-application-health # Tell Craft to install the plugin ./craft plugin/install ohdear-application-health
Setup
Once Oh Dear Application Health is installed:
- Go to your site in Oh Dear and activate the Application health check.
- Set the Health Report URL to
https://www.yourdomain.com/application-health.json
. - Copy the Health Report Secret value and set it as value for
OH_DEAR_HEALTH_REPORT_SECRET=
in your.env
file. - Optionally add a
config/ohdear-application-health.php
configuration file in which you can override the default settings.
Example configuration:
<?php return [ 'checks' => [ 'addUpdateCheck' => true, 'addQueueCheck' => true, 'addPendingMigrationsCheck' => true, 'addProjectConfigCheck' => true, 'addErrorLogCheck' => true, 'addGitChangesCheck' => true, 'addSecurityHeadersCheck' => true, 'addPhpVersionCheck' => true, 'addAdminUsersCheck' => true, 'addDiskUsageCheck' => false, ], 'oldestUpdateWarningDays' => 30, 'minimumPhpVersion' => '8.1.0', 'requiredSecurityHeaders' => [ 'Content-Security-Policy', 'X-Frame-Options', 'Strict-Transport-Security', 'X-Content-Type-Options', 'Referrer-Policy', 'Permissions-Policy', ], 'inactiveAdminThreshold' => '-1 year', 'gitRepoPath' => '@root', 'queueTotalThreshold' => 10, 'queueFailedThreshold' => 2, 'diskUsagePath' => '/', 'diskUsageThreshold' => 90, ];
Brought to you by Perfect Web Team