revised backend service getObjects
This commit is contained in:
@@ -1,17 +1,73 @@
|
|||||||
import { fail, redirect } from '@sveltejs/kit';
|
import { fail } from '@sveltejs/kit';
|
||||||
import { BUCKET, client, TOKENFILENAME } from '$lib/minio';
|
import { BUCKET, client, TOKENFILENAME } from '$lib/minio';
|
||||||
import { checkIfExactDirectoryExists } from './s3ClientService';
|
import { checkIfExactDirectoryExists } from './s3ClientService';
|
||||||
|
|
||||||
|
export const getVorgangByCaseId = async (caseId: string, token: string) => {
|
||||||
|
const isValidCase = await checkIfVorgangExists(caseId);
|
||||||
|
const isValidToken = await hasValidToken(caseId, token);
|
||||||
|
|
||||||
|
// const prefix = params.vorgang ? `${params.vorgang}/` : '';
|
||||||
|
|
||||||
|
// const stream = client.listObjectsV2(BUCKET, caseId, false, '');
|
||||||
|
// let files: any[] = [];
|
||||||
|
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
const stream = client.listObjectsV2(BUCKET, caseId, false, '');
|
||||||
|
const result = [];
|
||||||
|
|
||||||
|
stream.on('data', (item) => {
|
||||||
|
result.push(item);
|
||||||
|
});
|
||||||
|
|
||||||
|
stream.on('end', () => {
|
||||||
|
resolve(result);
|
||||||
|
});
|
||||||
|
|
||||||
|
stream.on('error', (err) => {
|
||||||
|
reject(err);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
// const readableStream = new ReadableStream({
|
||||||
|
// start(controller) {
|
||||||
|
// stream.on('data', (data) => {
|
||||||
|
// if (caseId === '') {
|
||||||
|
// if (data.prefix)
|
||||||
|
// controller.enqueue(`${JSON.stringify({ ...data, name: data.prefix.slice(0, -1) })}\n`);
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
|
|
||||||
|
// const name = data?.name?.slice(caseId.length);
|
||||||
|
// if (name === 'config.json') return;
|
||||||
|
// // zugangscode datei
|
||||||
|
// if (name === '__perm__') return;
|
||||||
|
|
||||||
|
// controller.enqueue(`${JSON.stringify({ ...data, name, caseId })}\n`);
|
||||||
|
// });
|
||||||
|
// stream.on('end', () => {
|
||||||
|
// controller.close();
|
||||||
|
// });
|
||||||
|
// },
|
||||||
|
// cancel() {
|
||||||
|
// stream.destroy();
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
|
||||||
|
// return files;
|
||||||
|
|
||||||
|
// return new Response(result, {
|
||||||
|
// headers: {
|
||||||
|
// 'content-type': 'text/event-stream'
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks if Vorgang exists and token is valid.
|
* Checks if Vorgang exists and token is valid.
|
||||||
* @param request
|
* @param request
|
||||||
* @returns redirect to /list/caseId or error
|
* @returns redirect to /list/caseId or error
|
||||||
*/
|
*/
|
||||||
export const redirectIfVorgangExists = async (request: Request) => {
|
const checkIfVorgangExists = async (caseId) => {
|
||||||
const data = await request.formData();
|
|
||||||
const caseId = data.get('case-id');
|
|
||||||
const caseToken = data.get('case-token');
|
|
||||||
|
|
||||||
if (!caseId) {
|
if (!caseId) {
|
||||||
return fail(400, {
|
return fail(400, {
|
||||||
success: false,
|
success: false,
|
||||||
@@ -28,55 +84,22 @@ export const redirectIfVorgangExists = async (request: Request) => {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
const isTokenValid = await hasValidToken(caseId, caseToken);
|
return true;
|
||||||
|
|
||||||
if (!isTokenValid) {
|
// const isTokenValid = await hasValidToken(caseId, caseToken);
|
||||||
return fail(400, {
|
|
||||||
success: false,
|
|
||||||
caseId,
|
|
||||||
error: { message: 'Der Token ist ungültig.' }
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
redirect(303, `/list/${caseId}?token=${caseToken}`);
|
// if (!isTokenValid) {
|
||||||
|
// return fail(400, {
|
||||||
|
// success: false,
|
||||||
|
// caseId,
|
||||||
|
// error: { message: 'Der Token ist ungültig.' }
|
||||||
|
// });
|
||||||
|
// }
|
||||||
|
|
||||||
|
// redirect(303, `/list/${caseId}?token=${caseToken}`);
|
||||||
};
|
};
|
||||||
|
|
||||||
export const getVorgangByCaseId = ({ params }) => {
|
const hasValidToken = async (caseId: string, caseToken: string) => {
|
||||||
const prefix = params.vorgang ? `${params.vorgang}/` : '';
|
|
||||||
const stream = client.listObjectsV2(BUCKET, prefix, false, '');
|
|
||||||
const result = new ReadableStream({
|
|
||||||
start(controller) {
|
|
||||||
stream.on('data', (data) => {
|
|
||||||
if (prefix === '') {
|
|
||||||
if (data.prefix)
|
|
||||||
controller.enqueue(`${JSON.stringify({ ...data, name: data.prefix.slice(0, -1) })}\n`);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const name = data.name.slice(prefix.length);
|
|
||||||
if (name === 'config.json') return;
|
|
||||||
// zugangscode datei
|
|
||||||
if (name === '__perm__') return;
|
|
||||||
|
|
||||||
controller.enqueue(`${JSON.stringify({ ...data, name, prefix })}\n`);
|
|
||||||
});
|
|
||||||
stream.on('end', () => {
|
|
||||||
controller.close();
|
|
||||||
});
|
|
||||||
},
|
|
||||||
cancel() {
|
|
||||||
stream.destroy();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return new Response(result, {
|
|
||||||
headers: {
|
|
||||||
'content-type': 'text/event-stream'
|
|
||||||
}
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
export const hasValidToken = async (caseId: string, caseToken: string) => {
|
|
||||||
const objPath = `${caseId}/${TOKENFILENAME}`;
|
const objPath = `${caseId}/${TOKENFILENAME}`;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@@ -84,9 +107,17 @@ export const hasValidToken = async (caseId: string, caseToken: string) => {
|
|||||||
|
|
||||||
const res = await client.getObject(BUCKET, objPath);
|
const res = await client.getObject(BUCKET, objPath);
|
||||||
|
|
||||||
const savedToken = await new Response(res).text();
|
const token = await new Response(res).text();
|
||||||
|
|
||||||
return savedToken === caseToken ? true : false;
|
if (!token) {
|
||||||
|
return fail(400, {
|
||||||
|
success: false,
|
||||||
|
caseId,
|
||||||
|
error: { message: 'Der Token ist ungültig.' }
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return token === caseToken ? true : false;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
if (error.name == 'S3Error') {
|
if (error.name == 'S3Error') {
|
||||||
console.log(error);
|
console.log(error);
|
||||||
|
|||||||
@@ -1,9 +1,15 @@
|
|||||||
import { loginUser, logoutUser } from '$lib/server/authService';
|
import { loginUser, logoutUser } from '$lib/server/authService';
|
||||||
import { redirectIfVorgangExists } from '$lib/server/vorgangService.js';
|
import { getVorgangByCaseId } from '$lib/server/vorgangService.js';
|
||||||
|
|
||||||
|
|
||||||
export const actions = {
|
export const actions = {
|
||||||
login: ({ request, cookies }) => loginUser({request, cookies}),
|
login: ({ request, cookies }) => loginUser({ request, cookies }),
|
||||||
logout: (event) => logoutUser(event),
|
logout: (event) => logoutUser(event),
|
||||||
redirectToVorgang: ({request}) => redirectIfVorgangExists(request)
|
getVorgangById: async ({ request }) => {
|
||||||
|
const data = await request.formData();
|
||||||
|
const caseId = data.get('case-id');
|
||||||
|
const caseToken = data.get('case-token');
|
||||||
|
const result = await getVorgangByCaseId(caseId, caseToken);
|
||||||
|
|
||||||
|
console.log(result);
|
||||||
|
}
|
||||||
} as const;
|
} as const;
|
||||||
|
|||||||
@@ -24,7 +24,7 @@
|
|||||||
<div class="w-full max-w-sm mx-auto">
|
<div class="w-full max-w-sm mx-auto">
|
||||||
<div class="relative mt-5 bg-gray-50 rounded-xl shadow-xl p-3 pt-1">
|
<div class="relative mt-5 bg-gray-50 rounded-xl shadow-xl p-3 pt-1">
|
||||||
<div class="mt-10">
|
<div class="mt-10">
|
||||||
<form action="?/redirectToVorgang" method="POST">
|
<form action="?/getVorgangById" method="POST">
|
||||||
<BaseInputField
|
<BaseInputField
|
||||||
id="case-id"
|
id="case-id"
|
||||||
name="case-id"
|
name="case-id"
|
||||||
|
|||||||
Reference in New Issue
Block a user