kopia lustrzana https://github.com/robinmoisson/staticrypt
				
				
				
			
		
			
				
	
	
		
			168 wiersze
		
	
	
		
			4.7 KiB
		
	
	
	
		
			HTML
		
	
	
			
		
		
	
	
			168 wiersze
		
	
	
		
			4.7 KiB
		
	
	
	
		
			HTML
		
	
	
| <!doctype html>
 | |
| <html class="staticrypt-html">
 | |
| <head>
 | |
|     <meta charset="utf-8">
 | |
|     <title>{title}</title>
 | |
|     <meta name="viewport" content="width=device-width, initial-scale=1">
 | |
| 
 | |
|     <!-- do not cache this page -->
 | |
|     <meta http-equiv="cache-control" content="max-age=0"/>
 | |
|     <meta http-equiv="cache-control" content="no-cache"/>
 | |
|     <meta http-equiv="expires" content="0"/>
 | |
|     <meta http-equiv="expires" content="Tue, 01 Jan 1980 1:00:00 GMT"/>
 | |
|     <meta http-equiv="pragma" content="no-cache"/>
 | |
| 
 | |
|     <style>
 | |
|         .staticrypt-hr {
 | |
|             margin-top: 20px;
 | |
|             margin-bottom: 20px;
 | |
|             border: 0;
 | |
|             border-top: 1px solid #eee;
 | |
|         }
 | |
| 
 | |
|         .staticrypt-page {
 | |
|             width: 360px;
 | |
|             padding: 8% 0 0;
 | |
|             margin: auto;
 | |
|             box-sizing: border-box;
 | |
|         }
 | |
| 
 | |
|         .staticrypt-form {
 | |
|             position: relative;
 | |
|             z-index: 1;
 | |
|             background: #FFFFFF;
 | |
|             max-width: 360px;
 | |
|             margin: 0 auto 100px;
 | |
|             padding: 45px;
 | |
|             text-align: center;
 | |
|             box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.2), 0 5px 5px 0 rgba(0, 0, 0, 0.24);
 | |
|         }
 | |
| 
 | |
|         .staticrypt-form input {
 | |
|             outline: 0;
 | |
|             background: #f2f2f2;
 | |
|             width: 100%;
 | |
|             border: 0;
 | |
|             margin: 0 0 15px;
 | |
|             padding: 15px;
 | |
|             box-sizing: border-box;
 | |
|             font-size: 14px;
 | |
|         }
 | |
| 
 | |
|         .staticrypt-form .staticrypt-decrypt-button {
 | |
|             text-transform: uppercase;
 | |
|             outline: 0;
 | |
|             background: #4CAF50;
 | |
|             width: 100%;
 | |
|             border: 0;
 | |
|             padding: 15px;
 | |
|             color: #FFFFFF;
 | |
|             font-size: 14px;
 | |
|             cursor: pointer;
 | |
|         }
 | |
| 
 | |
|         .staticrypt-form .staticrypt-decrypt-button:hover, .staticrypt-form .staticrypt-decrypt-button:active, .staticrypt-form .staticrypt-decrypt-button:focus {
 | |
|             background: #43A047;
 | |
|         }
 | |
| 
 | |
|         .staticrypt-html {
 | |
|             height: 100%;
 | |
|         }
 | |
| 
 | |
|         .staticrypt-body {
 | |
|             margin-bottom: 1em;
 | |
|             background: #76b852; /* fallback for old browsers */
 | |
|             background: -webkit-linear-gradient(right, #76b852, #8DC26F);
 | |
|             background: -moz-linear-gradient(right, #76b852, #8DC26F);
 | |
|             background: -o-linear-gradient(right, #76b852, #8DC26F);
 | |
|             background: linear-gradient(to left, #76b852, #8DC26F);
 | |
|             font-family: "Arial", sans-serif;
 | |
|             -webkit-font-smoothing: antialiased;
 | |
|             -moz-osx-font-smoothing: grayscale;
 | |
|         }
 | |
| 
 | |
|         .staticrypt-instructions {
 | |
|             margin-top: -1em;
 | |
|             margin-bottom: 1em;
 | |
|         }
 | |
| 
 | |
|         .staticrypt-title {
 | |
|             font-size: 1.5em;
 | |
|         }
 | |
| 
 | |
|         .staticrypt-footer {
 | |
|             position: fixed;
 | |
|             height: 20px;
 | |
|             font-size: 16px;
 | |
|             padding: 2px;
 | |
|             bottom: 0;
 | |
|             left: 0;
 | |
|             right: 0;
 | |
|             margin-bottom: 0;
 | |
|         }
 | |
| 
 | |
|         .staticrypt-footer p {
 | |
|             margin: 2px;
 | |
|             text-align: center;
 | |
|             float: right;
 | |
|         }
 | |
| 
 | |
|         .staticrypt-footer a {
 | |
|             text-decoration: none;
 | |
|         }
 | |
|     </style>
 | |
| </head>
 | |
| 
 | |
| <body class="staticrypt-body">
 | |
| <div class="staticrypt-page">
 | |
|     <div class="staticrypt-form">
 | |
|         <div class="staticrypt-instructions">
 | |
|             <p class="staticrypt-title">{title}</p>
 | |
|             <p>{instructions}</p>
 | |
|         </div>
 | |
| 
 | |
|         <hr class="staticrypt-hr">
 | |
| 
 | |
|         <form id="staticrypt-form" action="#" method="post">
 | |
|             <input id="staticrypt-password"
 | |
|                    type="password"
 | |
|                    name="password"
 | |
|                    placeholder="passphrase"
 | |
|                    autofocus/>
 | |
| 
 | |
|             <input type="submit" class="staticrypt-decrypt-button" value="DECRYPT"/>
 | |
|         </form>
 | |
|     </div>
 | |
| 
 | |
| </div>
 | |
| <footer class="staticrypt-footer">
 | |
|     <p class="pull-right">Created with <a href="https://robinmoisson.github.io/staticrypt">StatiCrypt</a></p>
 | |
| </footer>
 | |
| 
 | |
| 
 | |
| {crypto_tag}
 | |
| 
 | |
| <script>
 | |
|     document.getElementById('staticrypt-form').addEventListener('submit', function(e) {
 | |
|         e.preventDefault();
 | |
| 
 | |
|         var passphrase = document.getElementById('staticrypt-password').value,
 | |
|             encryptedMsg = '{encrypted}',
 | |
|             encryptedHMAC = encryptedMsg.substring(0, 64),
 | |
|             encryptedHTML = encryptedMsg.substring(64),
 | |
|             decryptedHMAC = CryptoJS.HmacSHA256(encryptedHTML, CryptoJS.SHA256(passphrase)).toString();
 | |
| 
 | |
|         if (decryptedHMAC !== encryptedHMAC) {
 | |
|             alert('Bad passphrase !');
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         var plainHTML = CryptoJS.AES.decrypt(encryptedHTML, passphrase).toString(CryptoJS.enc.Utf8);
 | |
| 
 | |
|         document.write(plainHTML);
 | |
|         document.close();
 | |
|     });
 | |
| </script>
 | |
| </body>
 | |
| </html>
 |