Files
headroom/frontend/node_modules/happy-dom/lib/fetch/utilities/FetchResponseHeaderUtility.js
Santhosh Janardhanan de2d83092e feat: Reinitialize frontend with SvelteKit and TypeScript
- Delete old Vite+Svelte frontend
- Initialize new SvelteKit project with TypeScript
- Configure Tailwind CSS v4 + DaisyUI
- Implement JWT authentication with auto-refresh
- Create login page with form validation (Zod)
- Add protected route guards
- Update Docker configuration for single-stage build
- Add E2E tests with Playwright (6/11 passing)
- Fix Svelte 5 reactivity with $state() runes

Known issues:
- 5 E2E tests failing (timing/async issues)
- Token refresh implementation needs debugging
- Validation error display timing
2026-02-17 16:19:59 -05:00

42 lines
1.4 KiB
JavaScript

import CookieStringUtility from '../../cookie/urilities/CookieStringUtility.js';
import Headers from '../Headers.js';
/**
* Fetch request validation utility.
*/
export default class FetchResponseHeaderUtility {
/**
* Appends headers to response.
*
* @param nodeResponse HTTP request.
* @param options
* @param options.browserFrame
* @param options.requestURL
* @param options.rawHeaders
* @returns Headers.
*/
static parseResponseHeaders(options) {
const headers = new Headers();
let key = null;
for (const header of options.rawHeaders) {
if (!key) {
key = header;
}
else {
const lowerName = key.toLowerCase();
// Handles setting cookie headers to the document.
// "Set-Cookie" and "Set-Cookie2" are not allowed in response headers according to spec.
if (lowerName === 'set-cookie' || lowerName === 'set-cookie2') {
options.browserFrame.page.context.cookieContainer.addCookies([
CookieStringUtility.stringToCookie(options.requestURL, header)
]);
}
else {
headers.append(key, header);
}
key = null;
}
}
return headers;
}
}
//# sourceMappingURL=FetchResponseHeaderUtility.js.map