blob: 2661f1298f3ad63ffd4fed11aa10ea5af00fd334 [file] [log] [blame]
// Copyright 2015 The Chromium Authors. All rights reserved.
// 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/quic/core/quic_packets.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),
connection_info(HttpResponseInfo::CONNECTION_INFO_UNKNOWN),
quic_port_migration_detected(false) {}
NetErrorDetails(bool quic_broken, quic::QuicErrorCode quic_connection_error)
: quic_broken(quic_broken),
quic_connection_error(quic_connection_error),
connection_info(HttpResponseInfo::CONNECTION_INFO_UNKNOWN),
quic_port_migration_detected(false) {}
// 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;
// True if receives a GoAway frame from the server due to connection
// migration with port change.
bool quic_port_migration_detected;
};
} // namespace net
#endif // NET_BASE_NET_ERROR_DETAILS_H_