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)