Skip to content

Commit

Permalink
Merge pull request edgexfoundry#779 from lenny-intel/System-Events-fo…
Browse files Browse the repository at this point in the history
…r-Devices-UCR

feat: Create UCR for System Events for Devices
  • Loading branch information
Lenny Goodell authored Jul 11, 2022
2 parents ef30d63 + 52233c7 commit 8198dd9
Show file tree
Hide file tree
Showing 2 changed files with 61 additions and 1 deletion.
9 changes: 8 additions & 1 deletion docs_src/design/TOC.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,11 @@
# ADR Table of Contents
# Use Cases and Design Records

## Use Case Records (UCRs)
| Name/Link | Short Description |
|---------------------------------------------------------------------------|---------------------------------------------------------------|
| [0001 System Events for Devices](./ucr/0001-System-Events-for-Devices.md) | Use Case for System Events for Device add/update/delete |

## Architectural Design Records (ADRs)

| Name/Link | Short Description |
| -------------------------------------------------------------------- | ----------------------------------------------- |
Expand Down
53 changes: 53 additions & 0 deletions docs_src/design/ucr/0001-System-Events-for-Devices.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
## System Events for Devices
### Submitters
- Lenny Goodell (Intel)

### Change Log
- [approved](https://github.com/edgexfoundry/edgex-docs/pull/779) (2022-07-11)

### Market Segments
- All or Any segments that can take advantage of on-boarding/updating/decommissioning of devices in order to auto start/stop/restart some AI/ML processing on the data from the new devices.

### Motivation
When a new camera device is added to the system only Core Metadata and the Device Service managing the new camera device are aware. There are use cases when other parts of the system need to know when a new device has been added to the system. This UCR will focus on the camera management use case which illustrates the need for these new System Events.

### Target Users
- Device User
- Software Deployer
- Software Integrator
- Deployment Customer

### Description
System Events (aka Control Plane Events - CPE) are events generated by the system when there are changes in part of the system that are important for other parts of the system to know about. This UCR will focus on the Device System Events use case as related to camera management. These Device System Events could be utilized by many other use cases in similar manner.

The new EdgeX USB and ONVIF camera Device Services (not yet released) implement auto provisioning which detects when a new camera device has been connected to USB or added to the network. New Device objects are created in Core Metadata for the new camera devices that have been auto provisioned. The auto provisioning also detects existing known camera devices, determines if there have been changes to the device details, such as IP address, and updates the Device object in Core Metadata with any changes. Device objects can also be manually deleted from Core Metadata once camera devices have been permanently disconnected.

A camera management application service needs to know when a new camera has been added so that it can initiate AI/ML processing on the stream from the new camera. The service also needs to know when an existing camera device has been updated so that it can make any needed adjustments such as restarting the AI/ML processing using the new IP address of the camera. Finally the service needs to know when an existing camera device has been removed so that it can stop the AI/ML processing for the removed camera.

### Existing solutions
Parts of the system (i.e. application service) must poll Core Metadata for list of devices to determine if a device has been added, update or deleted. To do this it must keep its own list of Device objects to make these determinations.

As a temporary stop gap for the initial upcoming release of the new ONVIF camera device service, an enhancement was added which publishes an EdgeX Event/Reading when a new camera device has been added, updated or modified. The Reading contains the information about the event type and the device name. This is improper use of the EdgeX Event/Reading which is intended for readings from devices, not System Events. This feature in the ONVIF Camera Device Service will be removed once System Events for Devices are in place.

### Requirements
- Added/Updated/Deleted Device System Events are created and sent in a manner that other parts of the system can subscribe and receive them.
- Subscription shall allow filtering for Device System Events for the following:
- Device Service (i.e. only want Events for which the device is owned by device-onvif-camera)

- Device Profile (i.e. only want Events for which the device is for a specific device profile)

- Event Type, (i.e. only want Add events)

- Each Device System Event must contain at a minimum the following, which is all that is needed to send a command to the device to get the stream URL or stop the AI/ML processing:

- Event Type: Added, Updated or Deleted
- Device Name

!!! note
Other details about the device, if not present in the System Event, can be queried from Core Metadata using the Device Name

### Other Related Issues
- None

### References
- None

0 comments on commit 8198dd9

Please sign in to comment.