blob: 3da3f325aa7e1407ec8055850dc89d3178345579 [file] [log] [blame]
// Copyright 2015 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef NET_BASE_NET_ERROR_DETAILS_H_
#define NET_BASE_NET_ERROR_DETAILS_H_
#include "net/base/net_export.h"
#include "net/http/http_response_info.h"
#include "net/third_party/quiche/src/quiche/quic/core/quic_error_codes.h"
namespace net {
// A record of net errors with granular error specification generated by
// net stack.
struct NET_EXPORT NetErrorDetails {
NetErrorDetails()
: quic_broken(false), quic_connection_error(quic::QUIC_NO_ERROR) {}
NetErrorDetails(bool quic_broken, quic::QuicErrorCode quic_connection_error)
: quic_broken(quic_broken),
quic_connection_error(quic_connection_error) {}
// True if all QUIC alternative services are marked broken for the origin.
bool quic_broken;
// QUIC granular error info.
quic::QuicErrorCode quic_connection_error;
// Early prediction of the connection type that this request attempts to use.
// Will be discarded by upper layers if the connection type can be fetched
// from response header from the server.
HttpResponseInfo::ConnectionInfo connection_info =
HttpResponseInfo::CONNECTION_INFO_UNKNOWN;
// True if receives a GoAway frame from the server due to connection
// migration with port change.
bool quic_port_migration_detected = false;
bool quic_connection_migration_attempted = false;
bool quic_connection_migration_successful = false;
};
} // namespace net
#endif // NET_BASE_NET_ERROR_DETAILS_H_