Device Service SDK - Device System Events
The Device Service SDK offers APIs for publishing device system events, which provide updates on various device processes. A System Event DTO is published to the EdgeX MessageBus to provide updates on the status of the device (device discovery progress, profile scan progress, etc.).
When these processes are initiated, the SDK publishes a system event with a status of 0, indicating that the operation has started. When the process finishes successfully, the SDK publishes a system event with a status of 100, indicating the process has been finished without issues. If an error occurs, the SDK reports a system event with a status of -1 to show failure.
Note
SDK provides PublishDeviceDiscoveryProgressSystemEvent
API, allowing the Device Service implementation to publish discovery
system events that include the number of discovered devices.
System Event DTO
EdgeX 4.0
System Event actions discovery
, and profilescan
are new in EdgeX 4.0
The System Event DTO for the Device Service SDK APIs has the following properties:
Property | Description | Value |
---|---|---|
Type | Type of System Event | device |
Action | System Event action | discovery , profilescan , or or any custom user-defined actions |
Source | Source of the System Event | the name of the device service |
Owner | Owner of the data in the System Event | the name of the device service that owns the device |
Details | The data object representing the device's status or the event details | the progress percentage (0 to 100) in this case. A value of -1 indicates an error. |
Timestamp | Date and time of the System Event | timestamp in nanoseconds |
Example Device System Event
An example decoded from base64 format for the discovery
event payload:
{
"apiVersion":"v3",
"type":"device",
"action":"discovery",
"source":"device-simple",
"owner":"device-simple",
"tags":null,
"details":{
"requestId":"86302e94-89dc-4a65-91fa-c4f393733a87",
"progress":0
},
"timestamp":1725867193294918132
}
Publish Topic
The Device System Events is published to the topic specified by the MessageQueue.PublishTopicPrefix
configuration setting above, which has a default of edgex/system-events
, plus the following data items, which are added to allow receivers to filter by subscription.
- source = [device service name]
- type = device
- action = discovery/profilescan
- owner = [device service name which owns the device]
Example Device System Event publish topics
edgex/system-events/device-simple/device/discovery/device-simple
edgex/system-events/device-simple/device/profilescan/device-simple