refactor-login-page #7
@@ -16,9 +16,17 @@
|
|||||||
let inProgress = false;
|
let inProgress = false;
|
||||||
let vorgang = '';
|
let vorgang = '';
|
||||||
const code_len = 8;
|
const code_len = 8;
|
||||||
let zugangscode = Math.random()
|
|
||||||
|
function generate_token() {
|
||||||
|
return Math.random()
|
||||||
.toString(36)
|
.toString(36)
|
||||||
.slice(2, 2 + code_len);
|
.slice(2, 2 + code_len);
|
||||||
|
}
|
||||||
|
let zugangscode = ''
|
||||||
|
let zugangscode_old = ''
|
||||||
|
$: zugangscode_old = generate_token();
|
||||||
|
$: zugangscode = zugangscode_old
|
||||||
|
|
||||||
let case_existing = undefined;
|
let case_existing = undefined;
|
||||||
$: case_existing = false;
|
$: case_existing = false;
|
||||||
|
|
||||||
@@ -152,23 +160,51 @@
|
|||||||
|
|
||||||
// return true or false
|
// return true or false
|
||||||
async function case_exists(case_no) {
|
async function case_exists(case_no) {
|
||||||
console.log('--- fired');
|
|
||||||
// ping `/(angemeldet)/view` with caseNumber in POST body
|
// ping `/(angemeldet)/view` with caseNumber in POST body
|
||||||
let url = '/view';
|
let url = '/view';
|
||||||
let data = new FormData();
|
let data = new FormData();
|
||||||
data.append('caseNumber', case_no);
|
data.append('caseNumber', case_no);
|
||||||
|
|
||||||
|
// fetch code in parallel
|
||||||
|
const code = get_code(case_no);
|
||||||
|
|
||||||
const response = await fetch(url, { method: 'POST', body: data });
|
const response = await fetch(url, { method: 'POST', body: data });
|
||||||
|
|
||||||
const code = response.status;
|
const res_json = await response.json();
|
||||||
|
const status = res_json.status;
|
||||||
|
|
||||||
console.log(`+++ ${response.redirected}`);
|
// aktualisiere Zugangscode mit
|
||||||
|
if (status == 303) {
|
||||||
|
case_existing = true;
|
||||||
|
|
||||||
|
const res = await code;
|
||||||
|
|
||||||
|
|
||||||
|
if (res != -1) {
|
||||||
|
// Code vorhanden
|
||||||
|
zugangscode = res;
|
||||||
|
}
|
||||||
|
|
||||||
if (code == 303) {
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case_existing = false;
|
||||||
|
zugangscode = zugangscode_old;
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async function get_code(case_no) {
|
||||||
|
let url = `/api/list/${case_no}/code`
|
||||||
|
const response = await fetch(url);
|
||||||
|
|
||||||
|
if (response.status == 200) {
|
||||||
|
return response.text();
|
||||||
|
} else {
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="mx-auto max-w-2xl">
|
<div class="mx-auto max-w-2xl">
|
||||||
@@ -219,8 +255,8 @@
|
|||||||
|
|
||||||
<div>
|
<div>
|
||||||
<label for="name" class="block text-sm font-medium leading-6 text-gray-900"
|
<label for="name" class="block text-sm font-medium leading-6 text-gray-900"
|
||||||
><span class="flex"
|
><span class="flex"
|
||||||
>{#if formErrors?.name}
|
>{#if formErrors?.name}
|
||||||
<span class="inline-block mr-1"><Exclamation /></span>
|
<span class="inline-block mr-1"><Exclamation /></span>
|
||||||
{/if} Name</span
|
{/if} Name</span
|
||||||
></label
|
></label
|
||||||
@@ -261,9 +297,18 @@
|
|||||||
type="text"
|
type="text"
|
||||||
name="zugangscode"
|
name="zugangscode"
|
||||||
id="zugangscode"
|
id="zugangscode"
|
||||||
|
on:input="{ (ev) => { zugangscode_old = ev.target.value }}"
|
||||||
class="block flex-1 border-0 bg-transparent py-1.5 pl-1 text-gray-900 placeholder:text-gray-400 focus:ring-0 sm:text-sm sm:leading-6"
|
class="block flex-1 border-0 bg-transparent py-1.5 pl-1 text-gray-900 placeholder:text-gray-400 focus:ring-0 sm:text-sm sm:leading-6"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
<button
|
||||||
|
class="rounded-md bg-blue-500 px-3 py-2 text-sm font-semibold text-white shadow-sm hover:bg-indigo-500 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-indigo-600"
|
||||||
|
on:click="{() => {
|
||||||
|
zugangscode = generate_token(); }}"
|
||||||
|
type="button">
|
||||||
|
Generiere Zugangscode
|
||||||
|
</button>
|
||||||
</div>
|
</div>
|
||||||
{#if formErrors?.code}
|
{#if formErrors?.code}
|
||||||
<p class="block text-sm leading-6 text-red-900 mt-2">{formErrors.code}</p>
|
<p class="block text-sm leading-6 text-red-900 mt-2">{formErrors.code}</p>
|
||||||
|
|||||||
28
src/routes/api/list/[[vorgang]]/code/+server.js
Normal file
28
src/routes/api/list/[[vorgang]]/code/+server.js
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
import { json } from '@sveltejs/kit';
|
||||||
|
import { client } from '$lib/minio';
|
||||||
|
import { Readable } from 'stream';
|
||||||
|
import { Buffer } from 'buffer';
|
||||||
|
|
||||||
|
/** @type {import('./$types').RequestHandler} */
|
||||||
|
export async function GET({ params }) {
|
||||||
|
const prefix = params.vorgang ? `${params.vorgang}` : '';
|
||||||
|
|
||||||
|
const code_name = '__perm__';
|
||||||
|
const obj_path = `${prefix}/${code_name}`;
|
||||||
|
|
||||||
|
let result = null;
|
||||||
|
|
||||||
|
try {
|
||||||
|
result = await client.getObject('tatort', obj_path);
|
||||||
|
} catch (error) {
|
||||||
|
if (error.name == 'S3Error') {
|
||||||
|
result = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (result != null) {
|
||||||
|
return new Response(result, { status: 200 });
|
||||||
|
} else {
|
||||||
|
return new Response(null, { status: 404 });
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user