// Copyright 2017 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. #include "net/spdy/spdy_log_util.h" #include #include "base/strings/string_number_conversions.h" #include "base/values.h" #include "net/http/http_log_util.h" namespace net { std::string ElideGoAwayDebugDataForNetLog(NetLogCaptureMode capture_mode, base::StringPiece debug_data) { // Note: this logic should be kept in sync with stripGoAwayDebugData in // chrome/browser/resources/net_internals/log_view_painter.js. if (capture_mode.include_cookies_and_credentials()) { return debug_data.as_string(); } return std::string("[") + base::NumberToString(debug_data.size()) + std::string(" bytes were stripped]"); } std::unique_ptr ElideSpdyHeaderBlockForNetLog( const spdy::SpdyHeaderBlock& headers, NetLogCaptureMode capture_mode) { auto headers_list = std::make_unique(); for (spdy::SpdyHeaderBlock::const_iterator it = headers.begin(); it != headers.end(); ++it) { headers_list->AppendString( it->first.as_string() + ": " + ElideHeaderValueForNetLog(capture_mode, it->first.as_string(), it->second.as_string())); } return headers_list; } std::unique_ptr SpdyHeaderBlockNetLogCallback( const spdy::SpdyHeaderBlock* headers, NetLogCaptureMode capture_mode) { auto dict = std::make_unique(); auto headers_dict = std::make_unique(); for (spdy::SpdyHeaderBlock::const_iterator it = headers->begin(); it != headers->end(); ++it) { headers_dict->SetKey( it->first.as_string(), base::Value(ElideHeaderValueForNetLog( capture_mode, it->first.as_string(), it->second.as_string()))); } dict->Set("headers", std::move(headers_dict)); return std::move(dict); } } // namespace net