References
- CPS-2067Getting issue details... STATUS
Issues & Decisions
# | Issue | Notes | Decisions |
---|---|---|---|
1 | Use anchor objects instead of just the anchor names. ( this is to make sure the YANG schema is flexible enough and also same in the REST side) | Requires we agree on the REST endpoint and request body and corresponding YANG schema to store the metadata. | |
2 | Wildcard character to subscribe/unsubscribe all the anchors in a given dataspace. | Need to agree on the wildcard character. Propose to have a single ["*"] to subscribe or unsubscribe. | |
Description
We want to implement a granular approach to control cps notifications. it will help in performance improvement by suppressing the unwanted messages in Kafka message stream
Proposal
We propose to implement an admin API to control (Enable/Disable) the Kafka notifications at Anchor level. This API provides below functionalities
- Using this API notification can be subscribed/unsubscribed for an Anchor.
- All the Anchors for a given Dataspace can be enabled/disabled for the notification.
Implementation
API
URL : PUT http://<IP:PORT>/cps/v2/dataspaces/{dataspaceName}/{subscription}
Query Parameters:
Parameter | Description |
---|---|
dataspaceName | Dataspace name |
subscription | subscribe or unsubscribe |
["anhcor01", "anchor02", "anchor03" ...]
Note: To enable all the anchors of the given dataspace, we can use empty request payload
Persistence (without schema)
we propose to persist notification subscription information using two different approaches 1. using an YANG schema and 2. without using schema. this is TBD to decide on best approach.
Information about the subscription of notification will be persisted in Fragment table. For Example, if the notification is subscribed by anchor_id 28, fragment table will have below entry
Note : Since a new xpath "/notification-subscription" is added for notification subscription, we need to ignore this xpath while getting data nodes for root xpath.
The above entry from fragment table will be deleted when anchor is unsubscribed from notification.
Attributes field is empty because we don't need any further granular control of notification. In future if we need to implement further granular control of notification, we can use attributes fields
Persistence using NEW dedicated YANG schema
We can create different dataspace and anchor specially for cps notification to persist notification subscription information. We propose to create below dataspace, schema and anchor for notification subscription.
Entity | Description |
---|---|
Dataspace Name | CPS-Admin |
Anchor Name | cps-notification-subscription |
schema set | cps-notification-subscription |
cps-notification-subscriptions@2024-06-18.yang |
When Notification is subscribed for anchor id "28", fragment table will have below entry
id | xpath | attributes | anchor_id | parent_id | schema_node_id
------+--------------------------------------+------------+------------+------------+----------------
3329 | /cps-notification/anchor[@id=28] | | 6 | |
Schema v/s non-schema persistence
Using Schema | Without Schema |
---|---|
Pros:
Cons:
| Pros:
Cons:
|