From 985f5b127685d3d8314004e8ff2701edce9415ac Mon Sep 17 00:00:00 2001 From: Ilja Antipov Date: Thu, 12 Sep 2024 11:45:40 +0200 Subject: [PATCH] add rpc for InsertContainmentTreeEntryForSequenceId --- CHANGELOG.md | 1 + src/t2iapi/device/device_requests.proto | 9 ++++++ src/t2iapi/device/device_responses.proto | 10 +++++++ src/t2iapi/device/service.proto | 37 ++++++++++++++++++++++++ 4 files changed, 57 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 2187369..5b41545 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -20,6 +20,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - manipulation SetSystemContextActivationStateAndContextAssociation for combined settings - manipulation SetMdsUiLanguage for devices - manipulation GetMdsUiSupportedLanguages for devices +- manipulation InsertContainmentTreeEntryForSequenceId for devices ## [4.1.0] - 2024-02-22 diff --git a/src/t2iapi/device/device_requests.proto b/src/t2iapi/device/device_requests.proto index fbdc2f7..314d445 100644 --- a/src/t2iapi/device/device_requests.proto +++ b/src/t2iapi/device/device_requests.proto @@ -94,3 +94,12 @@ message ProvideInformationAboutNextCalibrationRequest { CalibrationState calibration_state = 2; // ComponentCalibrationState value to set as the next calibration // information } + +/* +Request to make available the CONTAINMENT TREE ENTRY(as defined in IEEE Std 11073-10207-2017) that was previously +represented by the descriptor with the provided handle in the device's MDIB with the provided @SequenceId. + */ +message InsertContainmentTreeEntryForSequenceIdRequest { + string handle = 1; // descriptor handle which represented the CONTAINMENT TREE ENTRY + string sequence_id = 2; // @SequenceId of the devices MDIB where the requested CONTAINMENT TREE ENTRY was seen +} diff --git a/src/t2iapi/device/device_responses.proto b/src/t2iapi/device/device_responses.proto index 22fbb8a..58e8773 100644 --- a/src/t2iapi/device/device_responses.proto +++ b/src/t2iapi/device/device_responses.proto @@ -63,3 +63,13 @@ message GetComponentHwVersionResponse { BasicResponse status = 1; // status of the rpc string hardware_version = 2; // Hardware version of the requested device component } + +/* +Response containing the descriptor handle which is representing the requested +CONTAINMENT TREE ENTRY(as defined in IEEE Std 11073-10207-2017 in the device's current MDIB. + */ +message InsertContainmentTreeEntryForSequenceIdResponse{ + BasicResponse status = 1; // status of the rpc + string handle = 2; // descriptor handle which is representing the requested CONTAINMENT TREE ENTRY in + // the device's current MDIB +} diff --git a/src/t2iapi/device/service.proto b/src/t2iapi/device/service.proto index 17c3344..9f75993 100644 --- a/src/t2iapi/device/service.proto +++ b/src/t2iapi/device/service.proto @@ -182,4 +182,41 @@ service DeviceService { */ rpc IndicateTimeOfNextCalibrationToUser (BasicHandleRequest) returns (BasicResponse); + + /* + Make available the CONTAINMENT TREE ENTRY(as defined in IEEE Std 11073-10207-2017) that was previously + represented by the provided handle in the MDIB with the provided @SequenceId. If the CONTAINMENT TREE ENTRY is + absent in the current MDIB, it shall be inserted and its (new) handle shall be returned. If the + CONTAINMENT TREE ENTRY is already present in the current MDIB, only its handle shall be returned, no further + action is required. + + Hint: Devices which use static handles for descriptors do not have to lookup the previous handles since + they stay the same. + + Example 1: returning the same handle for the Metric + - device presented an MDIB with the Metric handle "metric_1" in @SequenceID "123" + - device changes @SequenceID to "789" and presents a new MDIB + - metric with the handle "metric_1" is still present in the current MDIB + - InsertContainmentTreeEntryForSequenceId with handle="metric_1" and sequence_id="123" is executed + - "metric_1" is returned since the descriptor with this handle it is still available in the current MDIB + - no further action from the device is required + + Example 2: returning a new handle for the MDS: + - device presented an MDIB with MDS handle "mds0" in @SequenceID "123" + - device changes @SequenceID to "789" and presents a new MDIB + - MDS with the handle "mds0" is still present in the current MDIB but it's handle changed to "mds10" + - InsertContainmentTreeEntryForSequenceId with handle="mds0" and sequence_id="123" is executed + - "mds10" is returned since the descriptor handle for that MDS has changed + - no further action from the device is required + + Example 3: inserting the Channel into the current MDIB and returning the (new) handle: + - device presented the Channel with handle "channel123" in @SequenceID "123" + - device changes @SequenceID to "789" and presents a new MDIB + - channel with handle "channel123" is no longer present in the current MDIB + - InsertContainmentTreeEntryForSequenceId with handle="channel123" and sequence_id="123" is executed + - channel is inserted into the device's current MDIB + - the (new) handle of the inserted channel is returned + */ + rpc InsertContainmentTreeEntryForSequenceId (InsertContainmentTreeEntryForSequenceIdRequest) + returns (InsertContainmentTreeEntryForSequenceIdResponse); }