index.html 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. <!doctype html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1" />
  6. <title>{{ .title }}</title>
  7. <link rel="stylesheet" href="/static/styles.css" />
  8. </head>
  9. <body>
  10. <div class="page-shell">
  11. <aside class="sidebar">
  12. <div>
  13. <p class="eyebrow">Toolkit</p>
  14. <h1>Tools</h1>
  15. <p class="intro">
  16. <!-- Generate local TLS material, inspect DNS records, and fetch live server certificates. -->
  17. </p>
  18. </div>
  19. <nav class="tool-menu" aria-label="Tool menu">
  20. <button class="tool-button active" data-tool="tls-generator">TLS Generator</button>
  21. <button class="tool-button" data-tool="dns-lookup">DNS Lookup</button>
  22. <button class="tool-button" data-tool="ssl-check">SSL Check</button>
  23. <button class="tool-button" data-tool="pem-check">PEM Check</button>
  24. </nav>
  25. </aside>
  26. <main class="content">
  27. <section class="panel active" id="tls-generator">
  28. <div class="panel-header">
  29. <div>
  30. <p class="eyebrow">Certificate Tool</p>
  31. <h2>TLS Generator</h2>
  32. </div>
  33. <p class="panel-copy">Create a self-signed certificate and private key for local testing.</p>
  34. </div>
  35. <form id="tls-form" class="tool-form">
  36. <label>
  37. Common Name
  38. <input type="text" name="commonName" placeholder="example.local" required />
  39. </label>
  40. <label>
  41. Organization
  42. <input type="text" name="organization" placeholder="Example Corp" />
  43. </label>
  44. <label>
  45. Organizational Unit
  46. <input type="text" name="organizationalUnit" placeholder="Engineering" />
  47. </label>
  48. <label>
  49. Locality
  50. <input type="text" name="locality" placeholder="DC" />
  51. </label>
  52. <label>
  53. State / Province
  54. <input type="text" name="state" placeholder="DC" />
  55. </label>
  56. <label>
  57. Country
  58. <input type="text" name="country" placeholder="US" />
  59. </label>
  60. <label>
  61. DNS Names
  62. <input type="text" name="dnsNames" placeholder="example.local, www.example.local" />
  63. </label>
  64. <label>
  65. Valid Days
  66. <input type="number" name="validDays" min="1" value="365" />
  67. </label>
  68. <label>
  69. Key Size
  70. <select name="keySize">
  71. <option value="2048" selected>2048-bit RSA</option>
  72. <option value="3072">3072-bit RSA</option>
  73. <option value="4096">4096-bit RSA</option>
  74. </select>
  75. </label>
  76. <div class="form-actions">
  77. <button type="submit" name="action" value="generate">Generate Certificate</button>
  78. <button type="submit" name="action" value="download" class="secondary-button">Generate and Download</button>
  79. </div>
  80. </form>
  81. <div id="tls-result" class="result-card empty">Run the generator to view the PEM output and metadata.</div>
  82. </section>
  83. <section class="panel" id="dns-lookup">
  84. <div class="panel-header">
  85. <div>
  86. <p class="eyebrow">Resolver Tool</p>
  87. <h2>DNS Lookup</h2>
  88. </div>
  89. <p class="panel-copy">Query common DNS record types for a hostname.</p>
  90. </div>
  91. <form id="dns-form" class="tool-form">
  92. <label>
  93. Hostname
  94. <input type="text" name="host" placeholder="openai.com" required />
  95. </label>
  96. <button type="submit">Lookup Records</button>
  97. </form>
  98. <div id="dns-result" class="result-card empty">Lookups will show A/AAAA, CNAME, MX, NS, and TXT records here.</div>
  99. </section>
  100. <section class="panel" id="ssl-check">
  101. <div class="panel-header">
  102. <div>
  103. <p class="eyebrow">Inspection Tool</p>
  104. <h2>SSL Check</h2>
  105. </div>
  106. <p class="panel-copy">Connect to a TLS endpoint and display the negotiated certificate.</p>
  107. </div>
  108. <form id="ssl-form" class="tool-form">
  109. <label>
  110. URL
  111. <input type="text" name="url" placeholder="https://example.com" required />
  112. </label>
  113. <button type="submit">Retrieve Certificate</button>
  114. </form>
  115. <div id="ssl-result" class="result-card empty">Certificate details and PEM output will appear after a check.</div>
  116. </section>
  117. <section class="panel" id="pem-check">
  118. <div class="panel-header">
  119. <div>
  120. <p class="eyebrow">Parser Tool</p>
  121. <h2>PEM Check</h2>
  122. </div>
  123. <p class="panel-copy">Paste a PEM-encoded certificate, CSR, private key, or public key to inspect it.</p>
  124. </div>
  125. <form id="pem-form" class="tool-form">
  126. <label>
  127. PEM Content
  128. <textarea name="pem" rows="16" placeholder="-----BEGIN CERTIFICATE-----&#10;...&#10;-----END CERTIFICATE-----" required></textarea>
  129. </label>
  130. <button type="submit">Inspect PEM</button>
  131. </form>
  132. <div id="pem-result" class="result-card empty">Parsed PEM blocks and metadata will appear here.</div>
  133. </section>
  134. </main>
  135. </div>
  136. <script src="/static/app.js" defer></script>
  137. </body>
  138. </html>