199 lines
8.2 KiB
PHP
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>
|