/* $Id: USBProxyService.h $ */ /** @file * VirtualBox USB Proxy Service (base) class. */ /* * Copyright (C) 2005-2020 Oracle Corporation * * This file is part of VirtualBox Open Source Edition (OSE), as * available from http://www.virtualbox.org. This file is free software; * you can redistribute it and/or modify it under the terms of the GNU * General Public License (GPL) as published by the Free Software * Foundation, in version 2 as it comes in the "COPYING" file of the * VirtualBox OSE distribution. VirtualBox OSE is distributed in the * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. */ #ifndef MAIN_INCLUDED_USBProxyService_h #define MAIN_INCLUDED_USBProxyService_h #ifndef RT_WITHOUT_PRAGMA_ONCE # pragma once #endif #include #include #include "VirtualBoxBase.h" #include "VirtualBoxImpl.h" #include "HostUSBDeviceImpl.h" #include "USBProxyBackend.h" class Host; namespace settings { struct USBDeviceSource; typedef std::list USBDeviceSourcesList; } /** * Base class for the USB Proxy service. */ class USBProxyService : public VirtualBoxTranslatable { public: USBProxyService(Host *aHost); virtual HRESULT init(void); virtual ~USBProxyService(); /** * Override of the default locking class to be used for validating lock * order with the standard member lock handle. */ virtual VBoxLockingClass getLockingClass() const { // the USB proxy service uses the Host object lock, so return the // same locking class as the host return LOCKCLASS_HOSTOBJECT; } void uninit(void); bool isActive(void); int getLastError(void); RWLockHandle *lockHandle() const; /** @name Interface for the USBController and the Host object. * @{ */ void *insertFilter(PCUSBFILTER aFilter); void removeFilter(void *aId); /** @} */ /** @name Host Interfaces * @{ */ HRESULT getDeviceCollection(std::vector > &aUSBDevices); HRESULT addUSBDeviceSource(const com::Utf8Str &aBackend, const com::Utf8Str &aId, const com::Utf8Str &aAddress, const std::vector &aPropertyNames, const std::vector &aPropertyValues); HRESULT removeUSBDeviceSource(const com::Utf8Str &aId); /** @} */ /** @name SessionMachine Interfaces * @{ */ HRESULT captureDeviceForVM(SessionMachine *aMachine, IN_GUID aId, const com::Utf8Str &aCaptureFilename); HRESULT detachDeviceFromVM(SessionMachine *aMachine, IN_GUID aId, bool aDone); HRESULT autoCaptureDevicesForVM(SessionMachine *aMachine); HRESULT detachAllDevicesFromVM(SessionMachine *aMachine, bool aDone, bool aAbnormal); /** @} */ typedef std::list< ComObjPtr > USBDeviceFilterList; HRESULT i_loadSettings(const settings::USBDeviceSourcesList &llUSBDeviceSources); HRESULT i_saveSettings(settings::USBDeviceSourcesList &llUSBDeviceSources); void i_deviceAdded(ComObjPtr &aDevice, PUSBDEVICE aUSBDevice); void i_deviceRemoved(ComObjPtr &aDevice); void i_updateDeviceState(ComObjPtr &aDevice, PUSBDEVICE aUSBDevice, bool fFakeUpdate); protected: ComObjPtr findDeviceById(IN_GUID aId); static HRESULT setError(HRESULT aResultCode, const char *aText, ...); USBProxyBackend *findUsbProxyBackendById(const com::Utf8Str &strId); HRESULT createUSBDeviceSource(const com::Utf8Str &aBackend, const com::Utf8Str &aId, const com::Utf8Str &aAddress, const std::vector &aPropertyNames, const std::vector &aPropertyValues, bool fLoadingSettings); private: HRESULT runAllFiltersOnDevice(ComObjPtr &aDevice, SessionMachinesList &llOpenedMachines, SessionMachine *aIgnoreMachine); bool runMachineFilters(SessionMachine *aMachine, ComObjPtr &aDevice); void deviceChanged(ComObjPtr &aDevice, bool fRunFilters, SessionMachine *aIgnoreMachine); /** Pointer to the Host object. */ Host *mHost; /** List of smart HostUSBDevice pointers. */ typedef std::list > HostUSBDeviceList; /** List of the known USB devices. */ HostUSBDeviceList mDevices; /** List of USBProxyBackend pointers. */ typedef std::list > USBProxyBackendList; /** List of active USB backends. */ USBProxyBackendList mBackends; int mLastError; }; #endif /* !MAIN_INCLUDED_USBProxyService_h */ /* vi: set tabstop=4 shiftwidth=4 expandtab: */