1*6777b538SAndroid Build Coastguard Worker // Copyright 2013 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker
5*6777b538SAndroid Build Coastguard Worker #include "net/quic/quic_http_utils.h"
6*6777b538SAndroid Build Coastguard Worker
7*6777b538SAndroid Build Coastguard Worker #include <utility>
8*6777b538SAndroid Build Coastguard Worker
9*6777b538SAndroid Build Coastguard Worker #include "base/metrics/histogram_macros.h"
10*6777b538SAndroid Build Coastguard Worker #include "net/spdy/spdy_log_util.h"
11*6777b538SAndroid Build Coastguard Worker
12*6777b538SAndroid Build Coastguard Worker namespace net {
13*6777b538SAndroid Build Coastguard Worker
ConvertRequestPriorityToQuicPriority(const RequestPriority priority)14*6777b538SAndroid Build Coastguard Worker spdy::SpdyPriority ConvertRequestPriorityToQuicPriority(
15*6777b538SAndroid Build Coastguard Worker const RequestPriority priority) {
16*6777b538SAndroid Build Coastguard Worker DCHECK_GE(priority, MINIMUM_PRIORITY);
17*6777b538SAndroid Build Coastguard Worker DCHECK_LE(priority, MAXIMUM_PRIORITY);
18*6777b538SAndroid Build Coastguard Worker return static_cast<spdy::SpdyPriority>(HIGHEST - priority);
19*6777b538SAndroid Build Coastguard Worker }
20*6777b538SAndroid Build Coastguard Worker
ConvertQuicPriorityToRequestPriority(spdy::SpdyPriority priority)21*6777b538SAndroid Build Coastguard Worker RequestPriority ConvertQuicPriorityToRequestPriority(
22*6777b538SAndroid Build Coastguard Worker spdy::SpdyPriority priority) {
23*6777b538SAndroid Build Coastguard Worker // Handle invalid values gracefully.
24*6777b538SAndroid Build Coastguard Worker return (priority >= 5) ? IDLE
25*6777b538SAndroid Build Coastguard Worker : static_cast<RequestPriority>(HIGHEST - priority);
26*6777b538SAndroid Build Coastguard Worker }
27*6777b538SAndroid Build Coastguard Worker
QuicRequestNetLogParams(quic::QuicStreamId stream_id,const spdy::Http2HeaderBlock * headers,quic::QuicStreamPriority priority,NetLogCaptureMode capture_mode)28*6777b538SAndroid Build Coastguard Worker base::Value::Dict QuicRequestNetLogParams(quic::QuicStreamId stream_id,
29*6777b538SAndroid Build Coastguard Worker const spdy::Http2HeaderBlock* headers,
30*6777b538SAndroid Build Coastguard Worker quic::QuicStreamPriority priority,
31*6777b538SAndroid Build Coastguard Worker NetLogCaptureMode capture_mode) {
32*6777b538SAndroid Build Coastguard Worker base::Value::Dict dict = Http2HeaderBlockNetLogParams(headers, capture_mode);
33*6777b538SAndroid Build Coastguard Worker switch (priority.type()) {
34*6777b538SAndroid Build Coastguard Worker case quic::QuicPriorityType::kHttp: {
35*6777b538SAndroid Build Coastguard Worker auto http_priority = priority.http();
36*6777b538SAndroid Build Coastguard Worker dict.Set("quic_priority_type", "http");
37*6777b538SAndroid Build Coastguard Worker dict.Set("quic_priority_urgency", http_priority.urgency);
38*6777b538SAndroid Build Coastguard Worker dict.Set("quic_priority_incremental", http_priority.incremental);
39*6777b538SAndroid Build Coastguard Worker break;
40*6777b538SAndroid Build Coastguard Worker }
41*6777b538SAndroid Build Coastguard Worker case quic::QuicPriorityType::kWebTransport: {
42*6777b538SAndroid Build Coastguard Worker auto web_transport_priority = priority.web_transport();
43*6777b538SAndroid Build Coastguard Worker dict.Set("quic_priority_type", "web_transport");
44*6777b538SAndroid Build Coastguard Worker const char* stream_type = "invalid";
45*6777b538SAndroid Build Coastguard Worker switch (web_transport_priority.stream_type) {
46*6777b538SAndroid Build Coastguard Worker case quic::WebTransportStreamPriority::StreamType::kData:
47*6777b538SAndroid Build Coastguard Worker stream_type = "data";
48*6777b538SAndroid Build Coastguard Worker break;
49*6777b538SAndroid Build Coastguard Worker case quic::WebTransportStreamPriority::StreamType::kHttp:
50*6777b538SAndroid Build Coastguard Worker stream_type = "http";
51*6777b538SAndroid Build Coastguard Worker break;
52*6777b538SAndroid Build Coastguard Worker case quic::WebTransportStreamPriority::StreamType::kStatic:
53*6777b538SAndroid Build Coastguard Worker stream_type = "static";
54*6777b538SAndroid Build Coastguard Worker break;
55*6777b538SAndroid Build Coastguard Worker }
56*6777b538SAndroid Build Coastguard Worker dict.Set("web_transport_stream_type", stream_type);
57*6777b538SAndroid Build Coastguard Worker // send_order is an int64_t, but base::Value doesn't support that type.
58*6777b538SAndroid Build Coastguard Worker // Case to a double instead. As this is just for diagnostics, some loss of
59*6777b538SAndroid Build Coastguard Worker // precision is acceptable.
60*6777b538SAndroid Build Coastguard Worker dict.Set("web_transport_send_order",
61*6777b538SAndroid Build Coastguard Worker static_cast<double>(web_transport_priority.send_order));
62*6777b538SAndroid Build Coastguard Worker break;
63*6777b538SAndroid Build Coastguard Worker }
64*6777b538SAndroid Build Coastguard Worker }
65*6777b538SAndroid Build Coastguard Worker dict.Set("quic_stream_id", static_cast<int>(stream_id));
66*6777b538SAndroid Build Coastguard Worker return dict;
67*6777b538SAndroid Build Coastguard Worker }
68*6777b538SAndroid Build Coastguard Worker
QuicResponseNetLogParams(quic::QuicStreamId stream_id,bool fin_received,const spdy::Http2HeaderBlock * headers,NetLogCaptureMode capture_mode)69*6777b538SAndroid Build Coastguard Worker base::Value::Dict QuicResponseNetLogParams(
70*6777b538SAndroid Build Coastguard Worker quic::QuicStreamId stream_id,
71*6777b538SAndroid Build Coastguard Worker bool fin_received,
72*6777b538SAndroid Build Coastguard Worker const spdy::Http2HeaderBlock* headers,
73*6777b538SAndroid Build Coastguard Worker NetLogCaptureMode capture_mode) {
74*6777b538SAndroid Build Coastguard Worker base::Value::Dict dict = Http2HeaderBlockNetLogParams(headers, capture_mode);
75*6777b538SAndroid Build Coastguard Worker dict.Set("quic_stream_id", static_cast<int>(stream_id));
76*6777b538SAndroid Build Coastguard Worker dict.Set("fin", fin_received);
77*6777b538SAndroid Build Coastguard Worker return dict;
78*6777b538SAndroid Build Coastguard Worker }
79*6777b538SAndroid Build Coastguard Worker
80*6777b538SAndroid Build Coastguard Worker } // namespace net
81