Skip to content

Commit

Permalink
LibWeb/Fetch: Add a constant for the keepalive maximum size
Browse files Browse the repository at this point in the history
  • Loading branch information
jamierocks authored and tcl3 committed Aug 11, 2024
1 parent c5b8e75 commit 35047de
Show file tree
Hide file tree
Showing 2 changed files with 5 additions and 1 deletion.
2 changes: 1 addition & 1 deletion Userland/Libraries/LibWeb/Fetch/Fetching/Fetching.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1670,7 +1670,7 @@ WebIDL::ExceptionOr<JS::NonnullGCPtr<PendingResponse>> http_network_or_cache_fet
}

// 5. If the sum of contentLength and inflightKeepaliveBytes is greater than 64 kibibytes, then return a network error.
if ((content_length.value() + inflight_keep_alive_bytes) > 65536)
if ((content_length.value() + inflight_keep_alive_bytes) > keepalive_maximum_size)
return PendingResponse::create(vm, request, Infrastructure::Response::network_error(vm, "Keepalive request exceeded maximum allowed size of 64 KiB"sv));

// NOTE: The above limit ensures that requests that are allowed to outlive the environment settings object
Expand Down
4 changes: 4 additions & 0 deletions Userland/Libraries/LibWeb/Fetch/Fetching/Fetching.h
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,10 @@ namespace Web::Fetch::Fetching {
// The document `Accept` header value is `text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8`.
constexpr auto document_accept_header_value = "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8"sv;

// https://fetch.spec.whatwg.org/#http-network-or-cache-fetch
// If the sum of contentLength and inflightKeepaliveBytes is greater than 64 kibibytes, then return a network error.
constexpr auto keepalive_maximum_size = 64 * KiB;

#define ENUMERATE_BOOL_PARAMS \
__ENUMERATE_BOOL_PARAM(IncludeCredentials) \
__ENUMERATE_BOOL_PARAM(IsAuthenticationFetch) \
Expand Down

0 comments on commit 35047de

Please sign in to comment.