Files
utools/frontend/app/ssl-check.html

141 lines
7.2 KiB
HTML

<!DOCTYPE html>
<html lang="de">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>SSL Certificate Check - uTools</title>
<!-- Tailwind CSS Play CDN -->
<script src="https://cdn.tailwindcss.com"></script>
<!-- Font Awesome (für Icons) -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
<!-- Eigene Styles (ähnlich wie index.html) -->
<style>
/* Einfacher Lade-Spinner (Tailwind animiert) */
.loader {
border: 4px solid rgba(168, 85, 247, 0.3); /* Lila transparent */
border-left-color: #a855f7; /* Lila */
border-radius: 50%;
width: 24px;
height: 24px;
animation: spin 1s linear infinite;
}
@keyframes spin {
to { transform: rotate(360deg); }
}
/* Navigations-Styling (aus index.html übernommen) */
nav ul { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 1rem; }
nav a { color: #c4b5fd; /* purple-300 */ text-decoration: none; white-space: nowrap; }
nav a:hover { color: #a78bfa; /* purple-400 */ text-decoration: underline; }
header { background-color: #374151; /* gray-700 */ padding: 1rem; margin-bottom: 1.5rem; border-radius: 0.5rem; /* rounded-lg */ display: flex; flex-direction: column; align-items: center; gap: 0.5rem; }
@media (min-width: 768px) { /* md breakpoint */
header { flex-direction: row; justify-content: space-between; }
}
header h1 { font-size: 1.5rem; /* text-2xl */ font-weight: bold; color: #e5e7eb; /* gray-200 */ }
/* Ergebnis-Box */
.result-box pre {
white-space: pre-wrap;
word-break: break-all;
font-family: monospace;
background-color: #1f2937; /* Dunkelgrau */
color: #d1d5db; /* Hellgrau */
padding: 1rem;
border-radius: 0.375rem; /* rounded-md */
max-height: 400px;
overflow-y: auto;
font-size: 0.875rem; /* text-sm */
}
/* Score Bar */
.score-bar { height: 20px; background-color: #4b5563; /* gray-600 */ border-radius: 0.25rem; overflow: hidden; }
.score-bar-inner { height: 100%; background-color: #ef4444; /* red-500 */ transition: width 0.5s ease-in-out, background-color 0.5s ease-in-out; }
/* Hilfsklasse zum Verstecken */
.hidden { display: none; }
</style>
</head>
<body class="bg-gray-900 text-gray-200 font-sans p-4 md:p-8">
<header>
<h1><a href="index.html" class="hover:text-purple-300"><i class="fas fa-network-wired mr-2"></i>uTools Network Suite</a></h1>
<nav>
<ul>
<li><a href="index.html">IP Info & Tools</a></li>
<li><a href="subnet-calculator.html">Subnetz Rechner</a></li>
<li><a href="dns-lookup.html">DNS Lookup</a></li>
<li><a href="whois-lookup.html">WHOIS Lookup</a></li>
<li><a href="ssl-check.html" class="text-purple-400 font-bold">SSL Check</a></li> <!-- Aktive Seite hervorheben -->
</ul>
</nav>
</header>
<div class="container mx-auto max-w-4xl bg-gray-800 rounded-lg shadow-xl p-6">
<h1 class="text-3xl font-bold mb-6 text-purple-400 text-center"><i class="fas fa-shield-alt mr-2"></i>SSL Certificate Check</h1>
<p class="text-center text-gray-400 mb-6">Enter a domain name to check its SSL/TLS certificate details and validity.</p>
<form id="ssl-check-form" class="mb-6">
<div class="flex flex-col sm:flex-row gap-2">
<input type="text" id="domain-input" placeholder="e.g., google.com" required
class="flex-grow px-3 py-2 bg-gray-700 border border-gray-600 rounded text-gray-200 focus:outline-none focus:ring-2 focus:ring-purple-500 focus:border-transparent font-mono">
<button type="submit" id="submit-button"
class="bg-purple-600 hover:bg-purple-700 text-white font-bold py-2 px-4 rounded transition duration-150 ease-in-out flex items-center justify-center">
<span id="button-text">Check Certificate</span>
<div id="loading-spinner" class="loader ml-2 hidden"></div>
</button>
</div>
</form>
<!-- Ergebnisbereich -->
<div id="result" class="result-box bg-gray-700 p-4 rounded border border-gray-600 hidden">
<h2 class="text-xl font-semibold text-purple-300 mb-4">Result for <span id="result-domain" class="font-bold font-mono"></span></h2>
<!-- Fehleranzeige -->
<div id="error-message" class="bg-red-800 text-red-100 p-3 rounded mb-4 hidden"></div>
<!-- Auswertung (nur bei Erfolg) -->
<div id="evaluation" class="mb-4 hidden">
<h4 class="text-lg font-semibold text-purple-300 mb-2">Evaluation</h4>
<div class="score-bar mb-2">
<div id="score-bar-inner" class="score-bar-inner"></div>
</div>
<p class="text-sm">Score: <span id="score-value" class="font-bold"></span>/10</p>
<p class="text-sm font-semibold mt-1" id="evaluation-summary"></p>
</div>
<!-- Zertifikatsdetails (nur bei Erfolg) -->
<div id="certificate-details" class="hidden">
<h4 class="text-lg font-semibold text-purple-300 mb-2">Certificate Details</h4>
<pre id="cert-output"></pre>
</div>
</div>
</div>
<!-- Footer (aus index.html übernommen) -->
<footer class="mt-8 pt-4 border-t border-gray-600 text-center text-xs text-gray-500">
<p>&copy; 2025 <a href="https://johanneskr.de" class="text-purple-400 hover:underline">Johannes Krüger</a></p>
<p>Version: <span id="commit-sha" class="font-mono">loading...</span></p> <!-- ID beibehalten für script.js -->
</footer>
<!-- Eigene JS-Logik -->
<script src="/app/ssl-check.js"></script>
<!-- Gemeinsames Skript für Version etc. (falls benötigt, sonst entfernen) -->
<script>
// Minimales Skript, um die Version zu laden (aus index.html's script.js extrahiert)
async function fetchVersion() {
try {
const response = await fetch('/api/version');
if (!response.ok) throw new Error(`HTTP error! status: ${response.status}`);
const data = await response.json();
const commitShaSpan = document.getElementById('commit-sha');
if (commitShaSpan && data.commitSha) {
commitShaSpan.textContent = data.commitSha.substring(0, 7); // Kurze SHA
} else if (commitShaSpan) {
commitShaSpan.textContent = 'N/A';
}
} catch (error) {
console.error('Error fetching version:', error);
const commitShaSpan = document.getElementById('commit-sha');
if (commitShaSpan) commitShaSpan.textContent = 'Error';
}
}
document.addEventListener('DOMContentLoaded', fetchVersion);
</script>
</body>
</html>