Systematic audit and implementation of missing Master Trainer functionality with comprehensive WordPress best practices and security implementation. ## Features Implemented - Master Events Overview (/master-trainer/events/) - KPI dashboard with filtering - Import/Export Data Management (/master-trainer/import-export/) - CSV operations - Communication Templates (/trainer/communication-templates/) - Professional templates - Enhanced Announcements (/master-trainer/announcements/) - Dynamic shortcode integration - Pending Approvals System (/master-trainer/pending-approvals/) - Workflow management ## Navigation & UX Improvements - Removed redundant Events link from top-level navigation menu - Reorganized administrative functions under Tools dropdown - Enhanced navigation clarity and professional appearance - Full responsive design with accessibility compliance ## Architecture & Security - 5 new singleton manager classes following WordPress patterns - Comprehensive role-based access control (hvac_master_trainer) - Complete security implementation (nonces, sanitization, escaping) - Performance optimizations with transient caching and conditional loading - Professional error handling and user feedback systems ## Files Added (16 new files) - 4 manager classes: Import/Export, Events Overview, Pending Approvals, Communication Templates - 4 CSS files with responsive design and accessibility features - 4 JavaScript files with AJAX functionality and error handling - 2 new templates: Import/Export, Pending Approvals - 2 enhanced templates: Events Overview, Communication Templates ## Files Modified (14 files) - Core system integration in Plugin, Page Manager, Scripts/Styles classes - Navigation system cleanup in Master Menu System - Enhanced access control and role management - Template updates for dynamic content integration ## Testing & Deployment - Comprehensive testing with Playwright automation - Successful staging deployment and verification - All 5 missing pages now fully functional - Navigation improvements verified working Resolves master trainer area audit requirements with production-ready implementation. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
223 lines
No EOL
7.2 KiB
PHP
223 lines
No EOL
7.2 KiB
PHP
<?php
|
|
/**
|
|
* Handles custom roles and capabilities for the HVAC Community Events plugin
|
|
*/
|
|
|
|
if (!defined('ABSPATH')) {
|
|
exit;
|
|
}
|
|
|
|
class HVAC_Roles {
|
|
/**
|
|
* Create the hvac_trainer role with all required capabilities
|
|
*/
|
|
public function create_trainer_role() {
|
|
// Check if role already exists
|
|
if (get_role('hvac_trainer')) {
|
|
return true;
|
|
}
|
|
|
|
// Add the role with capabilities
|
|
$result = add_role(
|
|
'hvac_trainer',
|
|
__('HVAC Trainer', 'hvac-community-events'),
|
|
$this->get_trainer_capabilities()
|
|
);
|
|
|
|
return $result !== null;
|
|
}
|
|
|
|
/**
|
|
* Create the hvac_master_trainer role with all required capabilities
|
|
*/
|
|
public function create_master_trainer_role() {
|
|
// Check if role already exists
|
|
if (get_role('hvac_master_trainer')) {
|
|
// Role exists, update it with new capabilities
|
|
return $this->update_master_trainer_role();
|
|
}
|
|
|
|
// Add the role with capabilities
|
|
$result = add_role(
|
|
'hvac_master_trainer',
|
|
__('HVAC Master Trainer', 'hvac-community-events'),
|
|
$this->get_master_trainer_capabilities()
|
|
);
|
|
|
|
return $result !== null;
|
|
}
|
|
|
|
/**
|
|
* Update existing hvac_master_trainer role with new capabilities
|
|
*/
|
|
public function update_master_trainer_role() {
|
|
$role = get_role('hvac_master_trainer');
|
|
if (!$role) {
|
|
return false;
|
|
}
|
|
|
|
// Get all required capabilities
|
|
$required_caps = $this->get_master_trainer_capabilities();
|
|
|
|
// Add any missing capabilities
|
|
foreach ($required_caps as $cap => $grant) {
|
|
if ($grant && !$role->has_cap($cap)) {
|
|
$role->add_cap($cap);
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Remove the hvac_trainer role
|
|
*/
|
|
public function remove_trainer_role() {
|
|
remove_role('hvac_trainer');
|
|
}
|
|
|
|
/**
|
|
* Remove the hvac_master_trainer role
|
|
*/
|
|
public function remove_master_trainer_role() {
|
|
remove_role('hvac_master_trainer');
|
|
}
|
|
|
|
/**
|
|
* Get all capabilities for the trainer role
|
|
*/
|
|
public function get_trainer_capabilities() {
|
|
$caps = array(
|
|
// Basic WordPress capabilities
|
|
'read' => true,
|
|
'upload_files' => true,
|
|
|
|
// Custom HVAC capabilities
|
|
'manage_hvac_events' => true,
|
|
'edit_hvac_profile' => true,
|
|
'view_hvac_dashboard' => true,
|
|
'manage_attendees' => true,
|
|
'email_attendees' => true,
|
|
'hvac_trainer_templates_view' => true,
|
|
|
|
// The Events Calendar capabilities
|
|
'publish_tribe_events' => true,
|
|
'edit_tribe_events' => true,
|
|
'delete_tribe_events' => true,
|
|
'edit_published_tribe_events' => true,
|
|
'delete_published_tribe_events' => true,
|
|
'read_private_tribe_events' => true,
|
|
);
|
|
|
|
// Explicitly deny admin capabilities
|
|
$denied_caps = array(
|
|
'manage_options',
|
|
'moderate_comments',
|
|
'manage_categories',
|
|
'manage_links',
|
|
'edit_others_posts',
|
|
'edit_pages',
|
|
'edit_others_pages',
|
|
'edit_published_pages',
|
|
'publish_pages',
|
|
'delete_pages',
|
|
'delete_others_pages',
|
|
'delete_published_pages',
|
|
'delete_others_posts',
|
|
'import',
|
|
'export',
|
|
'edit_theme_options',
|
|
);
|
|
|
|
foreach ($denied_caps as $cap) {
|
|
$caps[$cap] = false;
|
|
}
|
|
|
|
return $caps;
|
|
}
|
|
|
|
/**
|
|
* Get all capabilities for the master trainer role
|
|
*/
|
|
public function get_master_trainer_capabilities() {
|
|
// Start with all trainer capabilities
|
|
$caps = $this->get_trainer_capabilities();
|
|
|
|
// Add master trainer specific capabilities
|
|
$master_caps = array(
|
|
'view_master_dashboard' => true,
|
|
'view_all_trainer_data' => true,
|
|
'manage_google_sheets_integration' => true,
|
|
'view_global_analytics' => true,
|
|
'manage_communication_templates' => true,
|
|
'manage_communication_schedules' => true,
|
|
|
|
// Missing capabilities that were causing menu filtering
|
|
'view_all_events' => true,
|
|
'hvac_master_events_view' => true,
|
|
'approve_trainers' => true,
|
|
'manage_announcements' => true,
|
|
'import_export_data' => true,
|
|
);
|
|
|
|
// Merge with trainer capabilities
|
|
$caps = array_merge($caps, $master_caps);
|
|
|
|
return $caps;
|
|
}
|
|
|
|
/**
|
|
* Grant administrators access to HVAC dashboard capabilities
|
|
* This prevents redirect loops when admins try to access the dashboard
|
|
*/
|
|
public function grant_admin_dashboard_access() {
|
|
$admin_role = get_role('administrator');
|
|
if ($admin_role) {
|
|
$admin_role->add_cap('view_hvac_dashboard');
|
|
$admin_role->add_cap('manage_hvac_events');
|
|
$admin_role->add_cap('view_master_dashboard');
|
|
$admin_role->add_cap('view_all_trainer_data');
|
|
$admin_role->add_cap('manage_google_sheets_integration');
|
|
$admin_role->add_cap('view_global_analytics');
|
|
$admin_role->add_cap('manage_communication_templates');
|
|
$admin_role->add_cap('manage_communication_schedules');
|
|
$admin_role->add_cap('view_all_events');
|
|
$admin_role->add_cap('hvac_master_events_view');
|
|
$admin_role->add_cap('approve_trainers');
|
|
$admin_role->add_cap('manage_announcements');
|
|
$admin_role->add_cap('import_export_data');
|
|
$admin_role->add_cap('hvac_trainer_templates_view');
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Remove HVAC dashboard capabilities from administrators
|
|
*/
|
|
public function revoke_admin_dashboard_access() {
|
|
$admin_role = get_role('administrator');
|
|
if ($admin_role) {
|
|
$admin_role->remove_cap('view_hvac_dashboard');
|
|
$admin_role->remove_cap('manage_hvac_events');
|
|
$admin_role->remove_cap('view_master_dashboard');
|
|
$admin_role->remove_cap('view_all_trainer_data');
|
|
$admin_role->remove_cap('manage_google_sheets_integration');
|
|
$admin_role->remove_cap('view_global_analytics');
|
|
$admin_role->remove_cap('manage_communication_templates');
|
|
$admin_role->remove_cap('manage_communication_schedules');
|
|
$admin_role->remove_cap('view_all_events');
|
|
$admin_role->remove_cap('approve_trainers');
|
|
$admin_role->remove_cap('manage_announcements');
|
|
$admin_role->remove_cap('import_export_data');
|
|
$admin_role->remove_cap('hvac_trainer_templates_view');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Check if current user has a specific HVAC trainer capability
|
|
*/
|
|
public static function check_trainer_capability($capability) {
|
|
return current_user_can($capability);
|
|
}
|
|
} |