|  | // Copyright (c) 2016 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. | 
|  |  | 
|  | // Decodes the packet HandshakeFailureReason from the chromium histogram | 
|  | // Net.QuicClientHelloRejectReasons | 
|  |  | 
|  | #include <iostream> | 
|  |  | 
|  | #include "absl/strings/numbers.h" | 
|  | #include "quic/core/crypto/crypto_handshake.h" | 
|  | #include "quic/core/crypto/crypto_utils.h" | 
|  | #include "quic/platform/api/quic_flags.h" | 
|  | #include "common/platform/api/quiche_command_line_flags.h" | 
|  | #include "common/quiche_text_utils.h" | 
|  |  | 
|  | using quic::CryptoUtils; | 
|  | using quic::HandshakeFailureReason; | 
|  | using quic::MAX_FAILURE_REASON; | 
|  |  | 
|  | int main(int argc, char* argv[]) { | 
|  | const char* usage = "Usage: quic_reject_reason_decoder <packed_reason>"; | 
|  | std::vector<std::string> args = | 
|  | quiche::QuicheParseCommandLineFlags(usage, argc, argv); | 
|  |  | 
|  | if (args.size() != 1) { | 
|  | std::cerr << usage << std::endl; | 
|  | return 1; | 
|  | } | 
|  |  | 
|  | uint32_t packed_error = 0; | 
|  | if (!absl::SimpleAtoi(args[0], &packed_error)) { | 
|  | std::cerr << "Unable to parse: " << args[0] << "\n"; | 
|  | return 2; | 
|  | } | 
|  |  | 
|  | for (int i = 1; i < MAX_FAILURE_REASON; ++i) { | 
|  | if ((packed_error & (1 << (i - 1))) == 0) { | 
|  | continue; | 
|  | } | 
|  | HandshakeFailureReason reason = static_cast<HandshakeFailureReason>(i); | 
|  | std::cout << CryptoUtils::HandshakeFailureReasonToString(reason) << "\n"; | 
|  | } | 
|  | return 0; | 
|  | } |