15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Copyright (c) 2012 The Chromium Authors. All rights reserved. 25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be 35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// found in the LICENSE file. 45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "net/spdy/spdy_header_block.h" 65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/values.h" 85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "net/http/http_log_util.h" 95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace net { 115d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) 125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)base::Value* SpdyHeaderBlockNetLogCallback( 135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const SpdyHeaderBlock* headers, 145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) NetLog::LogLevel log_level) { 155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue* dict = new base::DictionaryValue(); 165d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) base::DictionaryValue* headers_dict = new base::DictionaryValue(); 175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) for (SpdyHeaderBlock::const_iterator it = headers->begin(); 185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) it != headers->end(); ++it) { 195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) headers_dict->SetWithoutPathExpansion( 20cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) it->first, 21cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) new base::StringValue( 225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) ElideHeaderValueForNetLog(log_level, it->first, it->second))); 235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 24cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) dict->Set("headers", headers_dict); 25cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) return dict; 26cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)} 27cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) 28cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)bool SpdyHeaderBlockFromNetLogParam( 29cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) const base::Value* event_param, 30cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) SpdyHeaderBlock* headers) { 31cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) headers->clear(); 32cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) 33cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) const base::DictionaryValue* dict = NULL; 34cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) const base::DictionaryValue* header_dict = NULL; 35cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) 36cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) if (!event_param || 37cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) !event_param->GetAsDictionary(&dict) || 38cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles) !dict->GetDictionary("headers", &header_dict)) { 395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return false; 405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) for (base::DictionaryValue::Iterator it(*header_dict); !it.IsAtEnd(); 435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) it.Advance()) { 445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (!it.value().GetAsString(&(*headers)[it.key()])) { 455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) headers->clear(); 465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return false; 475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return true; 505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} // namespace net 535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)