36015-vm/index.php
2025-11-22 13:13:06 +00:00

199 lines
8.2 KiB
PHP

<?php
declare(strict_types=1);
@ini_set('display_errors', '1');
@error_reporting(E_ALL);
// Read project preview data from environment
$projectDescription = $_SERVER['PROJECT_DESCRIPTION'] ?? 'Cloud Vulnerability Scanner';
$projectImageUrl = $_SERVER['PROJECT_IMAGE_URL'] ?? '';
?>
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Vulnerability Scanner Dashboard</title>
<?php if ($projectDescription): ?>
<meta name="description" content="<?= htmlspecialchars($projectDescription) ?>" />
<meta property="og:description" content="<?= htmlspecialchars($projectDescription) ?>" />
<meta property="twitter:description" content="<?= htmlspecialchars($projectDescription) ?>" />
<?php endif; ?>
<?php if ($projectImageUrl): ?>
<meta property="og:image" content="<?= htmlspecialchars($projectImageUrl) ?>" />
<meta property="twitter:image" content="<?= htmlspecialchars($projectImageUrl) ?>" />
<?php endif; ?>
<!-- Bootstrap 5.3 CDN -->
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css" rel="stylesheet">
<!-- Font Awesome CDN -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css">
<!-- Google Fonts -->
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;600;700&display=swap" rel="stylesheet">
<!-- Custom CSS -->
<link rel="stylesheet" href="assets/css/custom.css?v=<?php echo time(); ?>">
</head>
<body>
<div class="wrapper">
<!-- Sidebar -->
<nav id="sidebar">
<div class="sidebar-header">
<h3><i class="fas fa-shield-alt"></i> ScanGuard</h3>
</div>
<ul class="list-unstyled components">
<li class="active">
<a href="#"><i class="fas fa-tachometer-alt me-2"></i>Dashboard</a>
</li>
<li>
<a href="#"><i class="fas fa-search me-2"></i>Scans</a>
</li>
<li>
<a href="#"><i class="fas fa-bug me-2"></i>Vulnerabilities</a>
</li>
<li>
<a href="#"><i class="fas fa-cogs me-2"></i>Misconfigurations</a>
</li>
<li>
<a href="#"><i class="fas fa-file-alt me-2"></i>Reports</a>
</li>
</ul>
</nav>
<!-- Page Content -->
<div id="content">
<nav class="navbar navbar-expand-lg navbar-light bg-light mb-4">
<div class="container-fluid">
<button type="button" id="sidebarCollapse" class="btn btn-primary">
<i class="fas fa-align-left"></i>
</button>
<div class="collapse navbar-collapse" id="navbarSupportedContent">
<ul class="navbar-nav ms-auto">
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-bs-toggle="dropdown" aria-expanded="false">
<i class="fas fa-user-circle me-1"></i> John Doe
</a>
<ul class="dropdown-menu dropdown-menu-end" aria-labelledby="navbarDropdown">
<li><a class="dropdown-item" href="#">Settings</a></li>
<li><hr class="dropdown-divider"></li>
<li><a class="dropdown-item" href="#">Logout</a></li>
</ul>
</li>
</ul>
</div>
</div>
</nav>
<h2>Dashboard</h2>
<p>Welcome back! Here's a summary of your security posture.</p>
<div class="row g-4 mb-4">
<div class="col-md-6 col-lg-3">
<div class="card stat-card">
<div class="card-body">
<div>
<h5 class="card-title">Vulnerabilities</h5>
<p class="card-text fs-4 fw-bold">39</p>
</div>
<i class="fas fa-bug"></i>
</div>
</div>
</div>
<div class="col-md-6 col-lg-3">
<div class="card stat-card">
<div class="card-body">
<div>
<h5 class="card-title">Misconfigurations</h5>
<p class="card-text fs-4 fw-bold">15</p>
</div>
<i class="fas fa-cogs"></i>
</div>
</div>
</div>
<div class="col-md-6 col-lg-3">
<div class="card stat-card">
<div class="card-body">
<div>
<h5 class="card-title">Scans Completed</h5>
<p class="card-text fs-4 fw-bold">128</p>
</div>
<i class="fas fa-check-circle"></i>
</div>
</div>
</div>
<div class="col-md-6 col-lg-3">
<div class="card stat-card">
<div class="card-body">
<div>
<h5 class="card-title">Active Projects</h5>
<p class="card-text fs-4 fw-bold">4</p>
</div>
<i class="fas fa-folder"></i>
</div>
</div>
</div>
</div>
<div class="row g-4 mb-4">
<div class="col-lg-6">
<div class="card h-100">
<div class="card-header">Vulnerability Severity</div>
<div class="card-body" style="min-height: 300px;">
<canvas id="vulnerabilityChart"></canvas>
</div>
</div>
</div>
<div class="col-lg-6">
<div class="card h-100">
<div class="card-header">Recent Scans</div>
<div class="card-body">
<table class="table table-hover">
<thead>
<tr>
<th>Scan Name</th>
<th>Status</th>
<th>Date</th>
</tr>
</thead>
<tbody>
<tr>
<td>Production Cluster</td>
<td><span class="badge bg-success">Completed</span></td>
<td>2025-11-21</td>
</tr>
<tr>
<td>Staging Web App</td>
<td><span class="badge bg-success">Completed</span></td>
<td>2025-11-20</td>
</tr>
<tr>
<td>Billing API</td>
<td><span class="badge bg-warning text-dark">In Progress</span></td>
<td>2025-11-22</td>
</tr>
<tr>
<td>Legacy DB</td>
<td><span class="badge bg-danger">Failed</span></td>
<td>2025-11-19</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
</div>
<!-- Bootstrap 5.3 JS Bundle -->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
<!-- Chart.js CDN -->
<script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
<!-- Custom JS -->
<script src="assets/js/main.js?v=<?php echo time(); ?>"></script>
</body>
</html>