blob: a188bec9dfb520aea9c99ba3ca4b7c878ed35ef6 [file] [log] [blame]
// Copyright (c) 2013 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.
#ifndef CHROME_RENDERER_EXTENSIONS_DOM_ACTIVITY_LOGGER_H_
#define CHROME_RENDERER_EXTENSIONS_DOM_ACTIVITY_LOGGER_H_
#include <string>
#include "base/strings/string_piece.h"
#include "third_party/WebKit/public/platform/WebString.h"
#include "third_party/WebKit/public/platform/WebURL.h"
#include "third_party/WebKit/public/web/WebDOMActivityLogger.h"
#include "url/gurl.h"
#include "v8/include/v8.h"
// Used to log DOM API calls from within WebKit. The events are sent via IPC to
// extensions::ActivityLog for recording and display.
namespace extensions {
class DOMActivityLogger: public WebKit::WebDOMActivityLogger {
public:
static const int kMainWorldId = 0;
explicit DOMActivityLogger(const std::string& extension_id);
// Marshalls the arguments into an ExtensionHostMsg_DOMAction_Params
// and sends it over to the browser (via IPC) for appending it to the
// extension activity log.
// (Overrides the log method in WebKit::WebDOMActivityLogger)
virtual void log(const WebKit::WebString& api_name,
int argc,
const v8::Handle<v8::Value> argv[],
const WebKit::WebString& call_type,
const WebKit::WebURL& url,
const WebKit::WebString& title);
// Check (using the WebKit API) if there is no logger attached to the world
// corresponding to world_id, and if so, construct a new logger and attach it.
// world_id = 0 indicates the main world.
static void AttachToWorld(int world_id,
const std::string& extension_id);
private:
std::string extension_id_;
DISALLOW_COPY_AND_ASSIGN(DOMActivityLogger);
};
} // namespace extensions
#endif // CHROME_RENDERER_EXTENSIONS_DOM_ACTIVITY_LOGGER_H_