// Copyright (c) 2012 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/websockets/websocket_net_log_params.h"
#include "base/strings/stringprintf.h"
#include "base/values.h"
namespace net {
base::Value* NetLogWebSocketHandshakeCallback(
const std::string* headers,
NetLog::LogLevel /* log_level */) {
base::DictionaryValue* dict = new base::DictionaryValue();
base::ListValue* header_list = new base::ListValue();
size_t last = 0;
size_t headers_size = headers->size();
size_t pos = 0;
while (pos <= headers_size) {
if (pos == headers_size ||
((*headers)[pos] == '\r' &&
pos + 1 < headers_size && (*headers)[pos + 1] == '\n')) {
std::string entry = headers->substr(last, pos - last);
pos += 2;
last = pos;
header_list->Append(new base::StringValue(entry));
if (entry.empty()) {
// Dump WebSocket key3.
std::string key;
for (; pos < headers_size; ++pos) {
key += base::StringPrintf("\\x%02x", (*headers)[pos] & 0xff);
}
header_list->Append(new base::StringValue(key));
break;
}
} else {
++pos;
}
}
dict->Set("headers", header_list);
return dict;
}
} // namespace net