Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type DeviceServiceSDK ¶
type DeviceServiceSDK interface { // AddDeviceAutoEvent adds a new AutoEvent to the Device with given name AddDeviceAutoEvent(deviceName string, event models.AutoEvent) error // RemoveDeviceAutoEvent removes an AutoEvent from the Device with given name RemoveDeviceAutoEvent(deviceName string, event models.AutoEvent) error // AddDevice adds a new Device to the Device Service and Core Metadata // Returns new Device id or non-nil error. AddDevice(device models.Device) (string, error) // Devices return all managed Devices from cache Devices() []models.Device // GetDeviceByName returns the Device by its name if it exists in the cache, or returns an error. GetDeviceByName(name string) (models.Device, error) // DriverConfigs retrieves the driver specific configuration DriverConfigs() map[string]string // SetDeviceOpState sets the operating state of device SetDeviceOpState(name string, state models.OperatingState) error // RemoveDeviceByName removes the specified Device by name from the cache and ensures that the // instance in Core Metadata is also removed. RemoveDeviceByName(name string) error // UpdateDevice updates the Device in the cache and ensures that the // copy in Core Metadata is also updated. UpdateDevice(device models.Device) error // UpdateDeviceOperatingState updates the Device's OperatingState with given name // in Core Metadata and device service cache. UpdateDeviceOperatingState(deviceName string, state string) error // AddDeviceProfile adds a new DeviceProfile to the Device Service and Core Metadata // Returns new DeviceProfile id or non-nil error. AddDeviceProfile(profile models.DeviceProfile) (string, error) // DeviceProfiles return all managed DeviceProfiles from cache DeviceProfiles() []models.DeviceProfile // GetProfileByName returns the Profile by its name if it exists in the cache, or returns an error. GetProfileByName(name string) (models.DeviceProfile, error) // RemoveDeviceProfileByName removes the specified DeviceProfile by name from the cache and ensures that the // instance in Core Metadata is also removed. RemoveDeviceProfileByName(name string) error // UpdateDeviceProfile updates the DeviceProfile in the cache and ensures that the // copy in Core Metadata is also updated. UpdateDeviceProfile(profile models.DeviceProfile) error // DeviceCommand retrieves the specific DeviceCommand instance from cache according to // the Device name and Command name DeviceCommand(deviceName string, commandName string) (models.DeviceCommand, bool) // DeviceResource retrieves the specific DeviceResource instance from cache according to // the Device name and Device Resource name DeviceResource(deviceName string, deviceResource string) (models.DeviceResource, bool) // AddProvisionWatcher adds a new Watcher to the cache and Core Metadata // Returns new Watcher id or non-nil error. AddProvisionWatcher(watcher models.ProvisionWatcher) (string, error) // ProvisionWatchers return all managed Watchers from cache ProvisionWatchers() []models.ProvisionWatcher // GetProvisionWatcherByName returns the Watcher by its name if it exists in the cache, or returns an error. GetProvisionWatcherByName(name string) (models.ProvisionWatcher, error) // RemoveProvisionWatcher removes the specified Watcher by name from the cache and ensures that the // instance in Core Metadata is also removed. RemoveProvisionWatcher(name string) error // UpdateProvisionWatcher updates the Watcher in the cache and ensures that the // copy in Core Metadata is also updated. UpdateProvisionWatcher(watcher models.ProvisionWatcher) error // Name returns the name of this Device Service Name() string // Version returns the version number of this Device Service Version() string // AsyncReadings returns a bool value to indicate whether the asynchronous reading is enabled. AsyncReadings() bool // DeviceDiscovery returns a bool value to indicate whether device discovery is enabled. DeviceDiscovery() bool // AddRoute allows leveraging the existing internal web server to add routes specific to Device Service. AddRoute(route string, handler func(http.ResponseWriter, *http.Request), methods ...string) error // Stop shuts down the Service Stop(force bool) // LoadCustomConfig uses the Config Processor from go-mod-bootstrap to attempt to load service's // custom configuration. It uses the same command line flags to process the custom config in the same manner // as the standard configuration. LoadCustomConfig(customConfig service.UpdatableConfig, sectionName string) error // ListenForCustomConfigChanges uses the Config Processor from go-mod-bootstrap to attempt to listen for // changes to the specified custom configuration section. LoadCustomConfig must be called previously so that // the instance of sdkService.configProcessor has already been set. ListenForCustomConfigChanges(configToWatch interface{}, sectionName string, changedCallback func(interface{})) error // GetLoggingClient returns the logger.LoggingClient. The name was chosen to avoid conflicts // with service.DeviceService.LoggingClient struct field. GetLoggingClient() logger.LoggingClient // GetSecretProvider returns the interfaces.SecretProvider. The name was chosen to avoid conflicts // with service.DeviceService.SecretProvider struct field. GetSecretProvider() interfaces.SecretProvider }
DeviceServiceSDK defines the interface for an Edgex Device Service SDK
func Service ¶
func Service() DeviceServiceSDK
Service returns the device service SDK instance as an interface This provides the ability for device service's unit tests to mock the SDK calls allowing for more code coverage.
Click to show internal directories.
Click to hide internal directories.