upskill-event-manager/includes/zoho/check-permissions.php
bengizmo 37f4180e1c feat: Add massive missing plugin infrastructure to repository
🚨 CRITICAL: Fixed deployment blockers by adding missing core directories:

**Community System (CRITICAL)**
- includes/community/ - Login_Handler and all community classes
- templates/community/ - Community login forms

**Certificate System (CRITICAL)**
- includes/certificates/ - 8+ certificate classes and handlers
- templates/certificates/ - Certificate reports and generation templates

**Core Individual Classes (CRITICAL)**
- includes/class-hvac-event-summary.php
- includes/class-hvac-trainer-profile-manager.php
- includes/class-hvac-master-dashboard-data.php
- Plus 40+ other individual HVAC classes

**Major Feature Systems (HIGH)**
- includes/database/ - Training leads database tables
- includes/find-trainer/ - Find trainer directory and MapGeo integration
- includes/google-sheets/ - Google Sheets integration system
- includes/zoho/ - Complete Zoho CRM integration
- includes/communication/ - Communication templates system

**Template Infrastructure**
- templates/attendee/, templates/email-attendees/
- templates/event-summary/, templates/status/
- templates/template-parts/ - Shared template components

**Impact:**
- 70+ files added covering 10+ missing directories
- Resolves ALL deployment blockers and feature breakdowns
- Plugin activation should now work correctly
- Multi-machine deployment fully supported

🔧 Generated with Claude Code

Co-Authored-By: Ben Reed <ben@tealmaker.com>
2025-08-11 13:30:11 -03:00

144 lines
No EOL
6.1 KiB
PHP

<?php
/**
* Zoho CRM File & Permissions Diagnostic Tool
*
* This script checks file permissions and directory access
* that might affect the Zoho CRM integration.
*
* Access with: ?run_check=true
*/
// Security check
if (!isset($_GET['run_check']) || $_GET['run_check'] !== 'true') {
die('Access denied. Use ?run_check=true parameter.');
}
// Set headers
header('Content-Type: text/plain');
echo "=== Zoho CRM File & Permissions Check ===\n\n";
echo "Date: " . date('Y-m-d H:i:s') . "\n";
echo "Server: " . $_SERVER['SERVER_NAME'] . "\n";
echo "PHP Version: " . phpversion() . "\n\n";
// Check plugin directory
$plugin_dir = dirname(dirname(dirname(__FILE__)));
echo "Plugin Directory: $plugin_dir\n";
echo "Exists: " . (file_exists($plugin_dir) ? 'Yes' : 'No') . "\n";
echo "Readable: " . (is_readable($plugin_dir) ? 'Yes' : 'No') . "\n";
echo "Writable: " . (is_writable($plugin_dir) ? 'Yes' : 'No') . "\n";
echo "Permissions: " . substr(sprintf('%o', fileperms($plugin_dir)), -4) . "\n\n";
// Check Zoho directory
$zoho_dir = dirname(__FILE__);
echo "Zoho Directory: $zoho_dir\n";
echo "Exists: " . (file_exists($zoho_dir) ? 'Yes' : 'No') . "\n";
echo "Readable: " . (is_readable($zoho_dir) ? 'Yes' : 'No') . "\n";
echo "Writable: " . (is_writable($zoho_dir) ? 'Yes' : 'No') . "\n";
echo "Permissions: " . substr(sprintf('%o', fileperms($zoho_dir)), -4) . "\n\n";
// Check logs directory
$logs_dir = dirname(dirname(__FILE__)) . '/logs';
echo "Logs Directory: $logs_dir\n";
echo "Exists: " . (file_exists($logs_dir) ? 'Yes' : 'No') . "\n";
// Create logs directory if it doesn't exist
if (!file_exists($logs_dir)) {
echo "Trying to create logs directory...\n";
$result = @mkdir($logs_dir, 0755, true);
echo "Creation result: " . ($result ? 'Success' : 'Failed') . "\n";
if ($result) {
echo "Readable: " . (is_readable($logs_dir) ? 'Yes' : 'No') . "\n";
echo "Writable: " . (is_writable($logs_dir) ? 'Yes' : 'No') . "\n";
echo "Permissions: " . substr(sprintf('%o', fileperms($logs_dir)), -4) . "\n";
}
} else {
echo "Readable: " . (is_readable($logs_dir) ? 'Yes' : 'No') . "\n";
echo "Writable: " . (is_writable($logs_dir) ? 'Yes' : 'No') . "\n";
echo "Permissions: " . substr(sprintf('%o', fileperms($logs_dir)), -4) . "\n";
}
echo "\n";
// Check zoho-config.php
$config_file = $zoho_dir . '/zoho-config.php';
echo "Config File: $config_file\n";
echo "Exists: " . (file_exists($config_file) ? 'Yes' : 'No') . "\n";
echo "Readable: " . (is_readable($config_file) ? 'Yes' : 'No') . "\n";
echo "Writable: " . (is_writable($config_file) ? 'Yes' : 'No') . "\n";
echo "Size: " . (file_exists($config_file) ? filesize($config_file) . ' bytes' : 'N/A') . "\n";
echo "Permissions: " . (file_exists($config_file) ? substr(sprintf('%o', fileperms($config_file)), -4) : 'N/A') . "\n\n";
// Check class-zoho-crm-auth.php
$auth_file = $zoho_dir . '/class-zoho-crm-auth.php';
echo "Auth Class: $auth_file\n";
echo "Exists: " . (file_exists($auth_file) ? 'Yes' : 'No') . "\n";
echo "Readable: " . (is_readable($auth_file) ? 'Yes' : 'No') . "\n";
echo "Size: " . (file_exists($auth_file) ? filesize($auth_file) . ' bytes' : 'N/A') . "\n";
echo "Permissions: " . (file_exists($auth_file) ? substr(sprintf('%o', fileperms($auth_file)), -4) : 'N/A') . "\n\n";
// Test log file writing
$test_log_file = $logs_dir . '/test-permissions.log';
echo "Testing log file writing: $test_log_file\n";
$write_result = @file_put_contents($test_log_file, date('Y-m-d H:i:s') . " Test log entry\n", FILE_APPEND);
echo "Write result: " . ($write_result !== false ? 'Success (' . $write_result . ' bytes)' : 'Failed') . "\n";
if ($write_result !== false) {
echo "File exists after write: " . (file_exists($test_log_file) ? 'Yes' : 'No') . "\n";
echo "File permissions: " . substr(sprintf('%o', fileperms($test_log_file)), -4) . "\n";
}
echo "\n";
// Check if we can load WordPress
echo "Checking WordPress integration...\n";
$loaded_wp = false;
// Try to load WordPress
if (!function_exists('get_option')) {
// Try to find and load WordPress
$wp_load_path = dirname(dirname(dirname(dirname(dirname(__FILE__))))) . '/wp-load.php';
if (file_exists($wp_load_path)) {
echo "Found wp-load.php at: $wp_load_path\n";
require_once $wp_load_path;
$loaded_wp = function_exists('get_option');
echo "WordPress loaded: " . ($loaded_wp ? 'Yes' : 'No') . "\n";
} else {
echo "Could not find wp-load.php\n";
}
} else {
$loaded_wp = true;
echo "WordPress already loaded\n";
}
if ($loaded_wp) {
// Check if plugin is active
if (function_exists('is_plugin_active')) {
$plugin_active = is_plugin_active('hvac-community-events/hvac-community-events.php');
echo "Plugin active: " . ($plugin_active ? 'Yes' : 'No') . "\n";
} else {
echo "Could not check if plugin is active (is_plugin_active function not available)\n";
}
// Check WordPress options
echo "\nChecking WordPress options...\n";
echo "Site URL: " . get_option('siteurl') . "\n";
echo "Home URL: " . get_option('home') . "\n";
// Check if Zoho credentials are stored in options
echo "\nChecking Zoho credentials in WordPress options...\n";
echo "Access token option exists: " . (get_option('hvac_zoho_access_token') !== false ? 'Yes' : 'No') . "\n";
echo "Refresh token option exists: " . (get_option('hvac_zoho_refresh_token') !== false ? 'Yes' : 'No') . "\n";
echo "Token expiry option exists: " . (get_option('hvac_zoho_token_expiry') !== false ? 'Yes' : 'No') . "\n";
// Check user capabilities
echo "\nChecking current user capabilities...\n";
if (function_exists('current_user_can') && function_exists('wp_get_current_user')) {
echo "Current user: " . wp_get_current_user()->user_login . "\n";
echo "Can manage options: " . (current_user_can('manage_options') ? 'Yes' : 'No') . "\n";
} else {
echo "Could not check user capabilities\n";
}
}
echo "\n=== Check Completed ===\n";
echo "If you see any 'Failed' or 'No' responses, they may indicate issues with your Zoho CRM integration.\n";
echo "See the diagnostic log for more details about the connection test failures.";