blob: 549f6d07868586e7ac9c8eb8e27089da2ecab5f6 [file] [log] [blame]
// Copyright 2016 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/log/net_log_source.h"
#include <memory>
#include <utility>
#include "base/bind.h"
#include "base/callback.h"
#include "base/check_op.h"
#include "base/values.h"
#include "net/log/net_log_capture_mode.h"
namespace net {
namespace {
base::Value SourceEventParametersCallback(const NetLogSource source) {
if (!source.IsValid())
return base::Value();
base::Value event_params(base::Value::Type::DICTIONARY);
source.AddToEventParameters(&event_params);
return event_params;
}
} // namespace
// LoadTimingInfo requires this be 0.
const uint32_t NetLogSource::kInvalidId = 0;
NetLogSource::NetLogSource()
: NetLogSource(NetLogSourceType::NONE, kInvalidId) {}
NetLogSource::NetLogSource(NetLogSourceType type, uint32_t id)
: NetLogSource(type, id, base::TimeTicks::Now()) {}
NetLogSource::NetLogSource(NetLogSourceType type,
uint32_t id,
base::TimeTicks start_time)
: type(type), id(id), start_time(start_time) {}
bool NetLogSource::IsValid() const {
return id != kInvalidId;
}
void NetLogSource::AddToEventParameters(base::Value* event_params) const {
DCHECK(event_params->is_dict());
base::Value dict(base::Value::Type::DICTIONARY);
dict.SetIntKey("type", static_cast<int>(type));
dict.SetIntKey("id", static_cast<int>(id));
event_params->SetKey("source_dependency", std::move(dict));
}
base::Value NetLogSource::ToEventParameters() const {
return SourceEventParametersCallback(*this);
}
} // namespace net