Add DNS monitoring and refresh functionality
Introduce DNS monitoring: add DnsService (comprehensive DNS lookup, crt.sh discovery, Cloudflare detection, IP enrichment) and a new DnsRecord model to persist snapshots, manage diffs, and provide queries/stats. Update DomainController to support a dns_monitoring_enabled flag, refactor WHOIS/DNS refresh logic into performWhoisRefresh/performDnsRefresh, and add endpoints for refreshWhois, refreshDns and refreshAll; send notifications when DNS monitoring is toggled. Add UI templates/tabs for DNS, billing, notifications, overview, SSL and WHOIS and wire DNS data into the domain view; expose cached IP details. Add cron/check_dns.php and migration 027_add_dns_monitoring.sql (and include it in installer migration lists). Other tweaks: safer EmailHelper subject handling, TldRegistry search improvements, domain sorting using an effective status (expiring_soon), Discord channel null-safe fields, settings UI additions (domain_view_template and cron staleness warnings), and route/migration updates. This enables scheduled and manual DNS scans with persistent records and notifications.
This commit is contained in:
@@ -136,6 +136,21 @@ class SettingsController extends Controller
|
||||
// Rollback availability
|
||||
$rollbackAvailable = !empty($updateSettings['update_backup_path']) && file_exists($updateSettings['update_backup_path']);
|
||||
|
||||
// Cron staleness: show warning if last run is overdue
|
||||
$intervalHours = (int)($settings['check_interval_hours'] ?? 24);
|
||||
$domainStaleThreshold = $intervalHours * 1.5; // e.g. 36h for 24h interval
|
||||
$dnsStaleThreshold = 24; // DNS cron runs every 6h, 24h = overdue
|
||||
$domainCronStale = false;
|
||||
$dnsCronStale = false;
|
||||
if (!empty($settings['last_check_run'])) {
|
||||
$hoursSince = (time() - strtotime($settings['last_check_run'])) / 3600;
|
||||
$domainCronStale = $hoursSince > $domainStaleThreshold;
|
||||
}
|
||||
if (!empty($settings['last_dns_check_run'])) {
|
||||
$hoursSince = (time() - strtotime($settings['last_dns_check_run'])) / 3600;
|
||||
$dnsCronStale = $hoursSince > $dnsStaleThreshold;
|
||||
}
|
||||
|
||||
$this->view('settings/index', [
|
||||
'settings' => $settings,
|
||||
'appSettings' => $appSettings,
|
||||
@@ -154,6 +169,8 @@ class SettingsController extends Controller
|
||||
'cachedUpdateAvailable' => $cachedUpdateAvailable,
|
||||
'cachedUpdateData' => $cachedUpdateData,
|
||||
'rollbackAvailable' => $rollbackAvailable,
|
||||
'domainCronStale' => $domainCronStale,
|
||||
'dnsCronStale' => $dnsCronStale,
|
||||
'title' => 'Settings'
|
||||
]);
|
||||
}
|
||||
@@ -316,9 +333,16 @@ class SettingsController extends Controller
|
||||
// Update registration settings
|
||||
$registrationEnabled = isset($_POST['registration_enabled']) ? '1' : '0';
|
||||
$requireEmailVerification = isset($_POST['require_email_verification']) ? '1' : '0';
|
||||
|
||||
|
||||
$this->settingModel->setValue('registration_enabled', $registrationEnabled);
|
||||
$this->settingModel->setValue('require_email_verification', $requireEmailVerification);
|
||||
|
||||
// Update domain view template
|
||||
$viewTemplate = trim($_POST['domain_view_template'] ?? 'detailed');
|
||||
if (!in_array($viewTemplate, ['legacy', 'detailed'])) {
|
||||
$viewTemplate = 'detailed';
|
||||
}
|
||||
$this->settingModel->setValue('domain_view_template', $viewTemplate);
|
||||
|
||||
$_SESSION['success'] = 'Application settings updated successfully';
|
||||
$this->redirect('/settings#app');
|
||||
|
||||
Reference in New Issue
Block a user