// Copyright (c) 2018 GitHub, Inc. // Use of this source code is governed by the MIT license that can be // found in the LICENSE file. #include "atom/browser/api/atom_api_net_log.h" #include "atom/browser/atom_browser_client.h" #include "atom/common/native_mate_converters/callback.h" #include "atom/common/native_mate_converters/file_path_converter.h" #include "base/callback.h" #include "content/public/common/content_switches.h" #include "native_mate/dictionary.h" #include "native_mate/handle.h" #include "atom/common/node_includes.h" namespace atom { namespace api { NetLog::NetLog(v8::Isolate* isolate) { Init(isolate); net_log_ = atom::AtomBrowserClient::Get()->GetNetLog(); } NetLog::~NetLog() {} // static v8::Local NetLog::Create(v8::Isolate* isolate) { return mate::CreateHandle(isolate, new NetLog(isolate)).ToV8(); } void NetLog::StartLogging(mate::Arguments* args) { base::FilePath log_path; if (!args->GetNext(&log_path) || log_path.empty()) { args->ThrowError("The first parameter must be a valid string"); return; } net_log_->StartDynamicLogging(log_path); } bool NetLog::IsCurrentlyLogging() { return net_log_->IsDynamicLogging(); } base::FilePath::StringType NetLog::GetCurrentlyLoggingPath() { return net_log_->GetDynamicLoggingPath().value(); } void NetLog::StopLogging(mate::Arguments* args) { base::OnceClosure callback; args->GetNext(&callback); net_log_->StopDynamicLogging(std::move(callback)); } // static void NetLog::BuildPrototype(v8::Isolate* isolate, v8::Local prototype) { prototype->SetClassName(mate::StringToV8(isolate, "NetLog")); mate::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate()) .SetProperty("currentlyLogging", &NetLog::IsCurrentlyLogging) .SetProperty("currentlyLoggingPath", &NetLog::GetCurrentlyLoggingPath) .SetMethod("startLogging", &NetLog::StartLogging) .SetMethod("_stopLogging", &NetLog::StopLogging); } } // namespace api } // namespace atom namespace { using atom::api::NetLog; void Initialize(v8::Local exports, v8::Local unused, v8::Local context, void* priv) { v8::Isolate* isolate = context->GetIsolate(); mate::Dictionary dict(isolate, exports); dict.Set("netLog", NetLog::Create(isolate)); dict.Set("NetLog", NetLog::GetConstructor(isolate)->GetFunction()); } } // namespace NODE_BUILTIN_MODULE_CONTEXT_AWARE(atom_browser_net_log, Initialize)