Commit 8e6fae0b authored by reillyg's avatar reillyg Committed by Commit bot

Mark HID and USB device connections as non-persistent API resources.

Add an IsPersistent function to mark these resources as non-persistent
so that they will be cleaned up when the extension is suspended. The
default is persistent.

BUG=397234,409759

Review URL: https://codereview.chromium.org/548703003

Cr-Commit-Position: refs/heads/master@{#293626}
parent 7a27d4d6
...@@ -16,9 +16,7 @@ ...@@ -16,9 +16,7 @@
#include "extensions/common/api/hid.h" #include "extensions/common/api/hid.h"
namespace net { namespace net {
class IOBuffer;
class IOBufferWithSize;
} // namespace net } // namespace net
namespace extensions { namespace extensions {
......
...@@ -32,4 +32,8 @@ HidConnectionResource::HidConnectionResource( ...@@ -32,4 +32,8 @@ HidConnectionResource::HidConnectionResource(
HidConnectionResource::~HidConnectionResource() {} HidConnectionResource::~HidConnectionResource() {}
bool HidConnectionResource::IsPersistent() const {
return false;
}
} // namespace extensions } // namespace extensions
...@@ -13,10 +13,17 @@ ...@@ -13,10 +13,17 @@
#include "extensions/browser/api/api_resource.h" #include "extensions/browser/api/api_resource.h"
#include "extensions/browser/api/api_resource_manager.h" #include "extensions/browser/api/api_resource_manager.h"
namespace device {
class HidConnection;
}
namespace extensions { namespace extensions {
class HidConnectionResource : public ApiResource { class HidConnectionResource : public ApiResource {
public: public:
static const content::BrowserThread::ID kThreadId =
content::BrowserThread::FILE;
HidConnectionResource(const std::string& owner_extension_id, HidConnectionResource(const std::string& owner_extension_id,
scoped_refptr<device::HidConnection> connection); scoped_refptr<device::HidConnection> connection);
virtual ~HidConnectionResource(); virtual ~HidConnectionResource();
...@@ -25,10 +32,9 @@ class HidConnectionResource : public ApiResource { ...@@ -25,10 +32,9 @@ class HidConnectionResource : public ApiResource {
return connection_; return connection_;
} }
static const char* service_name() { return "HidConnectionResourceManager"; } virtual bool IsPersistent() const OVERRIDE;
static const content::BrowserThread::ID kThreadId = static const char* service_name() { return "HidConnectionResourceManager"; }
content::BrowserThread::FILE;
private: private:
scoped_refptr<device::HidConnection> connection_; scoped_refptr<device::HidConnection> connection_;
......
...@@ -37,9 +37,11 @@ UsbDeviceResource::UsbDeviceResource(const std::string& owner_extension_id, ...@@ -37,9 +37,11 @@ UsbDeviceResource::UsbDeviceResource(const std::string& owner_extension_id,
} }
UsbDeviceResource::~UsbDeviceResource() { UsbDeviceResource::~UsbDeviceResource() {
BrowserThread::PostTask(BrowserThread::FILE, device_->Close();
FROM_HERE, }
base::Bind(&UsbDeviceHandle::Close, device_));
bool UsbDeviceResource::IsPersistent() const {
return false;
} }
} // namespace extensions } // namespace extensions
...@@ -5,36 +5,35 @@ ...@@ -5,36 +5,35 @@
#ifndef EXTENSIONS_BROWSER_API_USB_USB_DEVICE_RESOURCE_H_ #ifndef EXTENSIONS_BROWSER_API_USB_USB_DEVICE_RESOURCE_H_
#define EXTENSIONS_BROWSER_API_USB_USB_DEVICE_RESOURCE_H_ #define EXTENSIONS_BROWSER_API_USB_USB_DEVICE_RESOURCE_H_
#include <set>
#include <string> #include <string>
#include "base/basictypes.h" #include "base/basictypes.h"
#include "base/memory/linked_ptr.h"
#include "base/memory/ref_counted.h" #include "base/memory/ref_counted.h"
#include "base/synchronization/lock.h" #include "base/synchronization/lock.h"
#include "content/public/browser/browser_thread.h" #include "content/public/browser/browser_thread.h"
#include "device/usb/usb_device_handle.h" #include "device/usb/usb_device_handle.h"
#include "extensions/browser/api/api_resource.h" #include "extensions/browser/api/api_resource.h"
#include "extensions/browser/api/api_resource_manager.h" #include "extensions/browser/api/api_resource_manager.h"
#include "extensions/common/api/usb.h"
namespace net { namespace usb_service {
class IOBuffer; class UsbDeviceHandle;
} // namespace net }
namespace extensions { namespace extensions {
// A UsbDeviceResource is an ApiResource wrapper for a UsbDevice. // A UsbDeviceResource is an ApiResource wrapper for a UsbDevice.
class UsbDeviceResource : public ApiResource { class UsbDeviceResource : public ApiResource {
public: public:
static const content::BrowserThread::ID kThreadId =
content::BrowserThread::FILE;
UsbDeviceResource(const std::string& owner_extension_id, UsbDeviceResource(const std::string& owner_extension_id,
scoped_refptr<device::UsbDeviceHandle> device); scoped_refptr<device::UsbDeviceHandle> device);
virtual ~UsbDeviceResource(); virtual ~UsbDeviceResource();
scoped_refptr<device::UsbDeviceHandle> device() { return device_; } scoped_refptr<device::UsbDeviceHandle> device() { return device_; }
static const content::BrowserThread::ID kThreadId = virtual bool IsPersistent() const OVERRIDE;
content::BrowserThread::FILE;
private: private:
friend class ApiResourceManager<UsbDeviceResource>; friend class ApiResourceManager<UsbDeviceResource>;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment