// Copyright 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 CONTENT_PUBLIC_BROWSER_DEVTOOLS_TARGET_H_
#define CONTENT_PUBLIC_BROWSER_DEVTOOLS_TARGET_H_
#include <string>
#include "base/basictypes.h"
#include "base/memory/ref_counted.h"
#include "base/time/time.h"
#include "content/common/content_export.h"
#include "url/gurl.h"
namespace content {
class DevToolsAgentHost;
// DevToolsTarget represents an inspectable target and can be used to
// manipulate the target and query its details.
// Instantiation and discovery of DevToolsTarget instances is the responsibility
// of DevToolsHttpHandlerDelegate.
class DevToolsTarget {
public:
virtual ~DevToolsTarget() {}
// Returns the unique target id.
virtual std::string GetId() const = 0;
// Returns the target type.
virtual std::string GetType() const = 0;
// Returns the target title.
virtual std::string GetTitle() const = 0;
// Returns the target description.
virtual std::string GetDescription() const = 0;
// Returns the url associated with this target.
virtual GURL GetUrl() const = 0;
// Returns the favicon url for this target.
virtual GURL GetFaviconUrl() const = 0;
// Returns the time when the target was last active.
virtual base::TimeTicks GetLastActivityTime() const = 0;
// Returns true if the debugger is attached to the target.
virtual bool IsAttached() const = 0;
// Returns the agent host for this target.
virtual scoped_refptr<DevToolsAgentHost> GetAgentHost() const = 0;
// Activates the target. Returns false if the operation failed.
virtual bool Activate() const = 0;
// Closes the target. Returns false if the operation failed.
virtual bool Close() const = 0;
};
} // namespace content
#endif // CONTENT_PUBLIC_BROWSER_DEVTOOLS_TARGET_H_