2024-11-01 11:58:27 +01:00
|
|
|
<!DOCTYPE html>
|
|
|
|
<html lang="en">
|
|
|
|
<head>
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0">
|
|
|
|
<title>Password required</title>
|
2024-11-17 16:26:40 +01:00
|
|
|
<link rel="icon" href="/share/static/favicon.ico" type="image/x-icon">
|
|
|
|
<link type="text/css" rel="stylesheet" href="/share/static/lg/lightgallery-bundle.min.css"/>
|
|
|
|
<link type="text/css" rel="stylesheet" href="/share/static/pico.min.css"/>
|
2024-11-01 11:58:27 +01:00
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<header></header>
|
|
|
|
<main class="container">
|
|
|
|
<div class="grid">
|
|
|
|
<div></div>
|
|
|
|
<div>
|
|
|
|
<form id="unlock" method="post">
|
|
|
|
<input
|
|
|
|
type="password"
|
|
|
|
name="password"
|
|
|
|
placeholder="Password"
|
|
|
|
aria-label="Password"
|
|
|
|
required
|
|
|
|
/>
|
|
|
|
<input
|
|
|
|
type="hidden"
|
|
|
|
name="key"
|
|
|
|
value="<%- key %>"
|
|
|
|
/>
|
|
|
|
<button type="submit">
|
|
|
|
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none"
|
|
|
|
stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"
|
|
|
|
class="lucide lucide-lock-open">
|
|
|
|
<rect width="18" height="11" x="3" y="11" rx="2" ry="2"/>
|
|
|
|
<path d="M7 11V7a5 5 0 0 1 9.9-1"/>
|
|
|
|
</svg>
|
|
|
|
Unlock
|
|
|
|
</button>
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
<div></div>
|
|
|
|
</div>
|
|
|
|
</main>
|
2024-11-17 16:26:40 +01:00
|
|
|
<script src="/share/static/web.js"></script>
|
2024-11-01 11:58:27 +01:00
|
|
|
<script>
|
2024-11-01 12:18:13 +01:00
|
|
|
async function submitForm (formElement) {
|
2024-11-01 11:58:27 +01:00
|
|
|
const formData = new FormData(formElement)
|
2024-11-01 12:18:13 +01:00
|
|
|
try {
|
2025-01-13 06:36:05 +01:00
|
|
|
// Validate password
|
2024-11-17 16:26:40 +01:00
|
|
|
const res = await fetch('/share/unlock', {
|
2024-11-01 12:18:13 +01:00
|
|
|
method: 'POST',
|
|
|
|
headers: { 'Content-Type': 'application/json' },
|
|
|
|
body: JSON.stringify(Object.fromEntries(formData.entries()))
|
2024-11-01 11:58:27 +01:00
|
|
|
})
|
2024-11-01 12:18:13 +01:00
|
|
|
if (res.status === 200) {
|
2025-01-13 06:36:05 +01:00
|
|
|
// Valid password - redirect to the gallery
|
2025-01-10 07:11:49 +01:00
|
|
|
const params = await res.json()
|
2025-01-13 06:36:05 +01:00
|
|
|
window.location = window.location.href.split('?')[0] + '?' + new URLSearchParams(params).toString()
|
2024-11-01 12:18:13 +01:00
|
|
|
}
|
|
|
|
} catch (e) { }
|
2024-11-01 11:58:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
document.getElementById('unlock')
|
|
|
|
.addEventListener('submit', function (e) {
|
|
|
|
e.preventDefault()
|
|
|
|
submitForm(this)
|
|
|
|
})
|
|
|
|
</script>
|
2024-11-17 16:26:40 +01:00
|
|
|
<script src="/share/static/lg/lightgallery.min.js"></script>
|
|
|
|
<script src="/share/static/lg/lg-fullscreen.min.js"></script>
|
|
|
|
<script src="/share/static/lg/lg-thumbnail.min.js"></script>
|
|
|
|
<script src="/share/static/lg/lg-video.min.js"></script>
|
|
|
|
<script src="/share/static/lg/lg-zoom.min.js"></script>
|
2024-11-01 11:58:27 +01:00
|
|
|
</body>
|
|
|
|
</html>
|