blob: 6b971305bf54f9be960b767d4e27e3e50443cf0a [file] [log] [blame]
// 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/disk_cache/net_log_parameters.h"
#include <utility>
#include "base/bind.h"
#include "base/logging.h"
#include "base/strings/string_number_conversions.h"
#include "base/values.h"
#include "net/base/net_errors.h"
#include "net/disk_cache/disk_cache.h"
#include "net/log/net_log_capture_mode.h"
#include "net/log/net_log_source.h"
namespace {
std::unique_ptr<base::Value> NetLogParametersEntryCreationCallback(
const disk_cache::Entry* entry,
bool created,
net::NetLogCaptureMode /* capture_mode */) {
std::unique_ptr<base::DictionaryValue> dict(new base::DictionaryValue());
dict->SetString("key", entry->GetKey());
dict->SetBoolean("created", created);
return std::move(dict);
}
std::unique_ptr<base::Value> NetLogReadWriteDataCallback(
int index,
int offset,
int buf_len,
bool truncate,
net::NetLogCaptureMode /* capture_mode */) {
std::unique_ptr<base::DictionaryValue> dict(new base::DictionaryValue());
dict->SetInteger("index", index);
dict->SetInteger("offset", offset);
dict->SetInteger("buf_len", buf_len);
if (truncate)
dict->SetBoolean("truncate", truncate);
return std::move(dict);
}
std::unique_ptr<base::Value> NetLogReadWriteCompleteCallback(
int bytes_copied,
net::NetLogCaptureMode /* capture_mode */) {
DCHECK_NE(bytes_copied, net::ERR_IO_PENDING);
std::unique_ptr<base::DictionaryValue> dict(new base::DictionaryValue());
if (bytes_copied < 0) {
dict->SetInteger("net_error", bytes_copied);
} else {
dict->SetInteger("bytes_copied", bytes_copied);
}
return std::move(dict);
}
std::unique_ptr<base::Value> NetLogSparseOperationCallback(
int64_t offset,
int buf_len,
net::NetLogCaptureMode /* capture_mode */) {
std::unique_ptr<base::DictionaryValue> dict(new base::DictionaryValue());
// Values can only be created with at most 32-bit integers. Using a string
// instead circumvents that restriction.
dict->SetString("offset", base::Int64ToString(offset));
dict->SetInteger("buf_len", buf_len);
return std::move(dict);
}
std::unique_ptr<base::Value> NetLogSparseReadWriteCallback(
const net::NetLogSource& source,
int child_len,
net::NetLogCaptureMode /* capture_mode */) {
std::unique_ptr<base::DictionaryValue> dict(new base::DictionaryValue());
source.AddToEventParameters(dict.get());
dict->SetInteger("child_len", child_len);
return std::move(dict);
}
std::unique_ptr<base::Value> NetLogGetAvailableRangeResultCallback(
int64_t start,
int result,
net::NetLogCaptureMode /* capture_mode */) {
std::unique_ptr<base::DictionaryValue> dict(new base::DictionaryValue());
if (result > 0) {
dict->SetInteger("length", result);
dict->SetString("start", base::Int64ToString(start));
} else {
dict->SetInteger("net_error", result);
}
return std::move(dict);
}
} // namespace
namespace disk_cache {
net::NetLogParametersCallback CreateNetLogParametersEntryCreationCallback(
const Entry* entry,
bool created) {
DCHECK(entry);
return base::Bind(&NetLogParametersEntryCreationCallback, entry, created);
}
net::NetLogParametersCallback CreateNetLogReadWriteDataCallback(int index,
int offset,
int buf_len,
bool truncate) {
return base::Bind(&NetLogReadWriteDataCallback,
index, offset, buf_len, truncate);
}
net::NetLogParametersCallback CreateNetLogReadWriteCompleteCallback(
int bytes_copied) {
return base::Bind(&NetLogReadWriteCompleteCallback, bytes_copied);
}
net::NetLogParametersCallback CreateNetLogSparseOperationCallback(
int64_t offset,
int buf_len) {
return base::Bind(&NetLogSparseOperationCallback, offset, buf_len);
}
net::NetLogParametersCallback CreateNetLogSparseReadWriteCallback(
const net::NetLogSource& source,
int child_len) {
return base::Bind(&NetLogSparseReadWriteCallback, source, child_len);
}
net::NetLogParametersCallback CreateNetLogGetAvailableRangeResultCallback(
int64_t start,
int result) {
return base::Bind(&NetLogGetAvailableRangeResultCallback, start, result);
}
} // namespace disk_cache