Update: 2026-05-04 00:27:42
This commit is contained in:
@@ -10,6 +10,7 @@ use App\Middleware\AuthMiddleware;
|
||||
$decoded = AuthMiddleware::check();
|
||||
$db = Database::getInstance();
|
||||
|
||||
try {
|
||||
// 1. Super Admin sees ALL companies
|
||||
if ($decoded['role'] === 'super_admin') {
|
||||
$stmt = $db->prepare("SELECT c.*, t.name as tenant_name
|
||||
@@ -61,3 +62,7 @@ foreach ($companies as &$company) {
|
||||
}
|
||||
|
||||
json_success($companies);
|
||||
|
||||
} catch (\Exception $e) {
|
||||
json_error('SQL Error in Companies List: ' . $e->getMessage(), 500);
|
||||
}
|
||||
|
||||
@@ -14,6 +14,7 @@ if ($decoded['role'] !== 'super_admin') {
|
||||
|
||||
$db = Database::getInstance();
|
||||
|
||||
try {
|
||||
$stmt = $db->query("SELECT id, name, email, phone, status, created_at FROM tenants ORDER BY created_at DESC");
|
||||
$tenants = $stmt->fetchAll();
|
||||
|
||||
@@ -26,3 +27,7 @@ foreach ($tenants as &$t) {
|
||||
}
|
||||
|
||||
json_success($tenants);
|
||||
|
||||
} catch (\Exception $e) {
|
||||
json_error('SQL Error in Tenants List: ' . $e->getMessage(), 500);
|
||||
}
|
||||
|
||||
@@ -14,6 +14,7 @@ $db = Database::getInstance();
|
||||
$role = $decoded['role'];
|
||||
$tenantId = $decoded['tenant_id'] ?? null;
|
||||
|
||||
try {
|
||||
// 2. Build Query based on Role
|
||||
if ($role === 'super_admin') {
|
||||
// Super Admin sees ALL users from ALL tenants
|
||||
@@ -22,6 +23,7 @@ if ($role === 'super_admin') {
|
||||
FROM users u
|
||||
LEFT JOIN tenants t ON u.tenant_id = t.id
|
||||
LEFT JOIN companies c ON u.company_id = c.id
|
||||
ORDER BY u.created_at DESC
|
||||
");
|
||||
} elseif ($role === 'admin') {
|
||||
// Admin sees only users in THEIR tenant (Accounting Office)
|
||||
@@ -31,6 +33,7 @@ if ($role === 'super_admin') {
|
||||
LEFT JOIN tenants t ON u.tenant_id = t.id
|
||||
LEFT JOIN companies c ON u.company_id = c.id
|
||||
WHERE u.tenant_id = ?
|
||||
ORDER BY u.created_at DESC
|
||||
");
|
||||
$stmt->execute([$tenantId]);
|
||||
} else {
|
||||
@@ -50,16 +53,20 @@ foreach ($users as &$user) {
|
||||
$user['email'] = $decryptedEmail !== false ? $decryptedEmail : $user['email'];
|
||||
|
||||
// Decrypt Company Name (if exists)
|
||||
if ($user['company_name']) {
|
||||
if (!empty($user['company_name'])) {
|
||||
$decryptedCompanyName = Encryption::decrypt($user['company_name']);
|
||||
$user['company_name'] = $decryptedCompanyName !== false ? $decryptedCompanyName : $user['company_name'];
|
||||
}
|
||||
|
||||
// Decrypt Tenant Name (if exists)
|
||||
if ($user['tenant_name']) {
|
||||
if (!empty($user['tenant_name'])) {
|
||||
$decryptedTenantName = Encryption::decrypt($user['tenant_name']);
|
||||
$user['tenant_name'] = $decryptedTenantName !== false ? $decryptedTenantName : $user['tenant_name'];
|
||||
}
|
||||
}
|
||||
|
||||
json_success($users);
|
||||
|
||||
} catch (\Exception $e) {
|
||||
json_error('SQL Error in Users List: ' . $e->getMessage(), 500);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user