feat: hash objects for etag value

This commit is contained in:
Huskydog9988
2025-04-09 14:48:13 -04:00
parent e7566a6316
commit c4d8b24295
4 changed files with 59 additions and 15 deletions

View File

@ -12,15 +12,16 @@ export default defineEventHandler(async (h3) => {
throw createError({ statusCode: 404, statusMessage: "Object not found" });
// https://developer.mozilla.org/en-US/docs/Web/HTTP/Reference/Headers/ETag
const etagValue = h3.headers.get("If-None-Match");
if (etagValue !== null) {
const etagRequestValue = h3.headers.get("If-None-Match");
const etagActualValue = await objectHandler.fetchHash(id);
if (etagRequestValue !== null && etagActualValue === etagRequestValue) {
// would compare if etag is valid, but objects should never change
setResponseStatus(h3, 304);
return null;
}
// just return object id has etag since object should never change
setHeader(h3, "ETag", id);
// TODO: fix undefined etagValue
setHeader(h3, "ETag", etagActualValue ?? "");
setHeader(h3, "Content-Type", object.mime);
setHeader(
h3,

View File

@ -13,8 +13,9 @@ export default defineEventHandler(async (h3) => {
throw createError({ statusCode: 404, statusMessage: "Object not found" });
// https://developer.mozilla.org/en-US/docs/Web/HTTP/Reference/Headers/ETag
const etagValue = h3.headers.get("If-None-Match");
if (etagValue !== null) {
const etagRequestValue = h3.headers.get("If-None-Match");
const etagActualValue = await objectHandler.fetchHash(id);
if (etagRequestValue !== null && etagActualValue === etagRequestValue) {
// would compare if etag is valid, but objects should never change
setResponseStatus(h3, 304);
return null;