-
Notifications
You must be signed in to change notification settings - Fork 85
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
closes #581 Signed-off-by: Leonard Goodell <leonard.goodell@intel.com>
- Loading branch information
Leonard Goodell
committed
Jul 12, 2022
1 parent
8198dd9
commit b523d2f
Showing
2 changed files
with
118 additions
and
24 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
# System Events ADR | ||
### Submitters | ||
- Lenny Goodell (Intel) | ||
|
||
## Change Log | ||
- [pending](https://github.com/edgexfoundry/edgex-docs/pull/795) (2022-07-12) | ||
|
||
## Referenced Use Case(s) | ||
- [System Events for Devices ](https://docs.edgexfoundry.org/2.3/design/ucr/0001-System-Events-for-Devices/) | ||
|
||
## Context | ||
System Events, aka Control Plane Events (CPE), are new to EdgeX. This ADR addresses the [System Events for Devices](https://docs.edgexfoundry.org/2.3/design/ucr/0001-System-Events-for-Devices/) use case with an extensible design that can address other System Event use cases that may be identified in the future. This extensible design approach and the fact that System Events are produced and consumed by different EdgeX services makes it architecturally significant warranting this ADR. | ||
|
||
## Proposed Design | ||
To address the [System Events for Devices ](https://docs.edgexfoundry.org/2.3/design/ucr/0001-System-Events-for-Devices/) use case, Core Metadata will publish a new `SystemEvent` DTO to the EdgeX MessageBus when a device is added, updated or deleted. Consumers of these System Events will subscribe to the MessageBus to receive the new `SystemEvent` DTO . | ||
|
||
#### Data Transfer Object (DTO) | ||
|
||
This new `SystemEvent` DTO will contain the following data describing the System Event: | ||
|
||
- Event Type - i.e. device | ||
- Event Action - i.e. add/update/delete | ||
- Event Source - i.e core-metadata as the publisher | ||
- Event Owner - i.e device-onvif-camera as the device owner | ||
- Optional based on the Event Type | ||
- Event Other- i.e. onvif-camera (profile name) | ||
- Optional based on the Event Type | ||
- Event Details - i.e. Device DTO of newly added device or empty for Delete action. | ||
- Optional and varies based on the Event Type and or Event Action. | ||
|
||
#### MessageBus | ||
|
||
Services that publish System Events (Core Metadata) must connect to the EdgeX MessageBus and have MessageBus configuration similar to that of Core Data's [here](https://github.com/edgexfoundry/edgex-go/blob/main/cmd/core-data/res/configuration.toml#L53-L74). This design assumes that Core Metadata will have this capability and configuration due to planned implementation of Service Metrics. | ||
|
||
For this design, the `publish topic prefix` for System Events will be a constant in the code rather than another configuration item that never changes. | ||
|
||
#### MessageBus Topic | ||
|
||
The new `SystemEvent` DTO will be published to a multi-level topic allowing subscribers to filter by topic. The format of this topic for Device System Events will be: | ||
|
||
`edgex/system-event/{event-type}/{event-action}/{event-source}/{event-owner}/{event-other}` | ||
|
||
where | ||
|
||
- `{event-type}` = device | ||
- `{event-action}` = add, update or delete | ||
- `{event-source}` = core-metadata | ||
- `{event-owner}` = `<device service name>` | ||
- `{event-other}` = `<device profile name>` | ||
|
||
As noted above Event Owner and Event Other are optional based on the Event Type and may not be meaningful in some future use cases. Those use cases will omit the Event Owner and Event Other from the publish topic as appropriate | ||
|
||
This multi-level topic scheme allows consuming services to filter which System Events they receive base of the topic that is subscribed. | ||
|
||
!!! example - "Example - System Event subscription topics" | ||
``` | ||
edgex/system-event/# - All system events | ||
edgex/system-event/device/# - only device system events | ||
edgex/system-event/#/#/core-metadata/# - only system events from Core Metadata | ||
edgex/system-event/device/add/#/device-onvif-camera/# - only add device system events for device-onvif-camera | ||
edgex/system-event/device/#/#/#/onvif-camera - only device system events for devices created for the onvif-camera device profile | ||
``` | ||
|
||
#### Consumers | ||
|
||
Consumers of Device System Events will likely be custom applications service as described in [System Events for Devices ](https://docs.edgexfoundry.org/2.3/design/ucr/0001-System-Events-for-Devices/). No changes are required to the App Functions SDK since it already supports processing of different types via the [Target Type](https://docs.edgexfoundry.org/2.2/microservices/application/AdvancedTopics/#target-type) capability. Developers of custom App Services that consume System Events will need to do the following: | ||
|
||
- Set the Target Type to `&dtos.SystemEvent{}`when creating instance of `ApplicationService` using the [NewAppServiceWithTargetType](https://docs.edgexfoundry.org/2.2/microservices/application/ApplicationServiceAPI/#newappservicewithtargettype) factory function. | ||
- Write custom pipeline function that expects the new `SystemEvent` DTO and process it accordingly. Similar to how the [ToLineProtocol](https://docs.edgexfoundry.org/2.2/microservices/application/BuiltIn/#tolineprotocol) pipeline function expects the Metric DTO. | ||
|
||
### Services/Modules impacted | ||
|
||
- Core Metadata service | ||
- This service is the single point for device Add/Update/Delete and will be the producer of Device System Events. | ||
- Core Contracts module | ||
- The new `SystemEvent` DTO will be added to this repository | ||
- Camera Management App Service Example | ||
- Once Device System Event are implemented, the [Camera Management](https://github.com/edgexfoundry/edgex-examples/tree/main/application-services/custom/camera-management) example can be updated to consume the new Device System Events. | ||
|
||
## Considerations | ||
- This design approach can be used for future use cases, such as `System Events for Device Profiles` and `System Events for Device Services` when/if they are deemed needed. | ||
- Another design approach that was considered is to use Support Notifications to send the System Events via REST. This would require consumers to create subscriptions to receive the Systems Events via REST to some endpoint on the consuming service. This subscription would be created using the existing Support Notifications [subscription](https://app.swaggerhub.com/apis/EdgeXFoundry1/support-notifications/2.2.0#/default/post_subscription) REST API. Likely each subscription would be for a specific Event Type. System Events would be Published by POSTing them to Support Notification [notification](https://app.swaggerhub.com/apis/EdgeXFoundry1/support-notifications/2.2.0#/default/post_notification) REST API, which would them forward them via REST POST to each service subscribed to the particular System Event. The System Event DTO would still be used, just sent via the REST. This approach is more complex, requires consumer services to have new REST endpoint(s) to receive the System Events and relies on REST rather than messaging, thus this approach was not chosen. | ||
|
||
## Decision | ||
This design will satisfy the [System Events for Devices ](https://docs.edgexfoundry.org/2.3/design/ucr/0001-System-Events-for-Devices/) use case as well as most future System Event use cases | ||
|
||
## Other Related ADRs | ||
- [Metric Collection ADR](https://docs.edgexfoundry.org/2.2/design/adr/0006-Metrics-Collection/) - Use of EdgeX MessageBus to publish and subscribe service metrics | ||
- [North-South Messaging ADR](https://docs.edgexfoundry.org/2.2/design/adr/0023-North-South-Messaging/) - Use of EdgeX MessageBus to publish and subscribe commands/responses | ||
|
||
## References | ||
- Control Plane Events (CPE) (aka System Events) were initially proposed as part of the metrics collection ADR as early as March 2020. You may find discussions relevant to CPE in these ADR and other design/architecture discussions since March 2020. | ||
- [initial ADR on EdgeX service level metrics collection for Hanoi](https://github.com/edgexfoundry/edgex-docs/pull/97) |