diff --git a/.github/license-check/header-MIT-draeger-java-and-proto.txt b/.github/license-check/header-MIT-draeger-java-and-proto.txt new file mode 100644 index 0000000..13d9ec2 --- /dev/null +++ b/.github/license-check/header-MIT-draeger-java-and-proto.txt @@ -0,0 +1,6 @@ +/\* +This Source Code Form is subject to the terms of the MIT License. +Copyright \(c\) (?:([0-9]{4}-[0-9]{4})|([0-9]{4}))(?:, (?:([0-9]{4}-[0-9]{4})|([0-9]{4})))* Draegerwerk AG & Co. KGaA. + +SPDX-License-Identifier: MIT +\*/ \ No newline at end of file diff --git a/.github/license-check/header-MIT-draeger-java.txt b/.github/license-check/header-MIT-draeger-java.txt deleted file mode 100644 index 1f21077..0000000 --- a/.github/license-check/header-MIT-draeger-java.txt +++ /dev/null @@ -1,6 +0,0 @@ -/* -This Source Code Form is subject to the terms of the MIT License. -Copyright (c) %year% Draegerwerk AG & Co. KGaA. - -SPDX-License-Identifier: MIT -*/ \ No newline at end of file diff --git a/.github/license-check/header-MIT-draeger-proto.txt b/.github/license-check/header-MIT-draeger-proto.txt deleted file mode 100644 index 1f21077..0000000 --- a/.github/license-check/header-MIT-draeger-proto.txt +++ /dev/null @@ -1,6 +0,0 @@ -/* -This Source Code Form is subject to the terms of the MIT License. -Copyright (c) %year% Draegerwerk AG & Co. KGaA. - -SPDX-License-Identifier: MIT -*/ \ No newline at end of file diff --git a/.github/license-check/header-MIT-draeger-python.txt b/.github/license-check/header-MIT-draeger-python.txt index 2a1d894..65798e1 100644 --- a/.github/license-check/header-MIT-draeger-python.txt +++ b/.github/license-check/header-MIT-draeger-python.txt @@ -1,4 +1,4 @@ # This Source Code Form is subject to the terms of the MIT License. # -# Copyright (c) %year% Draegerwerk AG & Co. KGaA. -# SPDX-License-Identifier: MIT \ No newline at end of file +# Copyright \(c\) (?:([0-9]{4}-[0-9]{4})|([0-9]{4}))(?:, (?:([0-9]{4}-[0-9]{4})|([0-9]{4})))* Draegerwerk AG & Co. KGaA. +# SPDX-License-Identifier: MIT diff --git a/.github/license-check/license-config b/.github/license-check/license-config new file mode 100644 index 0000000..d68b861 --- /dev/null +++ b/.github/license-check/license-config @@ -0,0 +1,23 @@ +[DraegerLicenseMITJava] +file_name_pattern: tests/java/src/**/*.java +file_header_encoding: utf-8 +header_regex_file: .github/license-check/header-MIT-draeger-java-and-proto.txt +header_regex_file_encoding: utf-8 + +[DraegerLicenseMITProto] +file_name_pattern: src/**/*.proto +file_header_encoding: utf-8 +header_regex_file: .github/license-check/header-MIT-draeger-java-and-proto.txt +header_regex_file_encoding: utf-8 + +[DraegerLicenseMITPythonTests] +file_name_pattern: tests/python/**/*.py +file_header_encoding: utf-8 +header_regex_file: .github/license-check/header-MIT-draeger-python.txt +header_regex_file_encoding: utf-8 + +[DraegerLicenseMITPythonSetup] +file_name_pattern: python/**/*.py +file_header_encoding: utf-8 +header_regex_file: .github/license-check/header-MIT-draeger-python.txt +header_regex_file_encoding: utf-8 diff --git a/.github/license-check/license-config.json b/.github/license-check/license-config.json deleted file mode 100644 index f9c572c..0000000 --- a/.github/license-check/license-config.json +++ /dev/null @@ -1,25 +0,0 @@ -[ - { - "include": [ - "src/**/*.proto" - ], - "exclude": [ - "src/buf.yaml" - ], - "license": "./.github/license-check/header-MIT-draeger-proto.txt" - }, - { - "include": [ - "tests/java/src/**/*.java" - ], - "license": "./.github/license-check/header-MIT-draeger-java.txt" - }, - - { - "include": [ - "python/**/*.py", - "tests/python/**/*.py" - ], - "license": "./.github/license-check/header-MIT-draeger-python.txt" - } -] \ No newline at end of file diff --git a/.github/workflows/license-check.yml b/.github/workflows/license-check.yml index 4f25065..8eafae9 100644 --- a/.github/workflows/license-check.yml +++ b/.github/workflows/license-check.yml @@ -10,8 +10,8 @@ jobs: steps: # Run `git checkout` - uses: actions/checkout@v4 - - uses: viperproject/check-license-header@v1 + - uses: maximilianpilz/file-header-check@v1 with: - path: . - config: .github/license-check/license-config.json - strict: false # + config: '.github/license-check/license-config' + config-encoding: 'utf-8' + log-level: 'DEBUG' diff --git a/CHANGELOG.md b/CHANGELOG.md index 6fcf522..c82bca5 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,8 +8,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Added +- manipulation PhysicallyDisconnectRemovableSubsystemAfterSettingActivationStateOnOrStndBy +- manipulation GetComponentHwVersion for devices - manipulation GetAvailableDeviceMetaData for device - manipulation AssociateValidateAndChangeIdentificationOfPatientOrLocationContextState for contexts +- manipulation GetComponentSwVersion for devices - manipulation ProvideInformationAboutLastCalibration for devices - manipulation ProvideInformationAboutNextCalibration for devices - manipulation SetSystemContextActivationStateAndContextAssociation for combined settings diff --git a/src/t2iapi/combined/service.proto b/src/t2iapi/combined/service.proto index 8b9861d..2beb5fe 100644 --- a/src/t2iapi/combined/service.proto +++ b/src/t2iapi/combined/service.proto @@ -1,6 +1,6 @@ /* This Source Code Form is subject to the terms of the MIT License. -Copyright (c) 2023 Draegerwerk AG & Co. KGaA. +Copyright (c) 2023, 2024 Draegerwerk AG & Co. KGaA. SPDX-License-Identifier: MIT */ @@ -11,6 +11,7 @@ package t2iapi.combined; import "t2iapi/combined/combined_requests.proto"; import "t2iapi/context/context_responses.proto"; +import "t2iapi/basic_requests.proto"; import "t2iapi/basic_responses.proto"; option java_package = "com.draeger.medical.t2iapi.combined"; @@ -73,4 +74,23 @@ service CombinedService { rpc SetSystemContextActivationStateAndContextAssociation ( t2iapi.combined.SetSystemContextActivationStateAndContextAssociationRequest) returns (BasicResponse); + + /* + Request to set the pm:AbstractDeviceComponentState/@ActivationState corresponding to the specified handle to + a value in { "On", "StndBy" } and + physically disconnect the removable subsystem being represented by the + corresponding pm:AbstractDeviceComponentDescriptor all while persisting the aforementioned ActivationState except when + it is necessary to change it due to the physical disconnection by means other than this manipulation. + + The ActivationState as requested shall be persisted in all cases except (indirectly) + as a result of the physical disconnection. + Reasons other than the physical disconnection constitute a RESULT_NOT_SUPPORTED or RESULT_FAIL. + In case the ActivationState is not going to be persisted it shall not be a direct result of this manipulation, i.e. + this manipulation shall not directly change the ActivationState in a way not described here. + + In case the pm:AbstractDeviceComponentDescriptor with the specified handle does not represent a removable subsystem + it shall return RESULT_NOT_SUPPORTED. + */ + rpc PhysicallyDisconnectRemovableSubsystemAfterSettingActivationStateOnOrStndBy (BasicHandleRequest) + returns (BasicResponse); } diff --git a/src/t2iapi/device/device_responses.proto b/src/t2iapi/device/device_responses.proto index 6f3cd02..facc890 100644 --- a/src/t2iapi/device/device_responses.proto +++ b/src/t2iapi/device/device_responses.proto @@ -46,4 +46,20 @@ Response containing the available device metadata. message AvailableDeviceMetaDataResponse { BasicResponse status = 1; t2iapi.biceps.MetaDataMsg meta_data = 2; // available device metadata -} \ No newline at end of file +} + +/* +Response containing the software version of the requested pm:AbstractDeviceComponentDescriptor handle when supported. + */ +message GetComponentSwVersionResponse { + BasicResponse status = 1; // status of the rpc + string software_version = 2; // Software version of the requested device component +} + +/* +Response containing the hardware version of the requested pm:AbstractDeviceComponentDescriptor handle when supported. + */ +message GetComponentHwVersionResponse { + BasicResponse status = 1; // status of the rpc + string hardware_version = 2; // Hardware version of the requested device component +} diff --git a/src/t2iapi/device/service.proto b/src/t2iapi/device/service.proto index ac62d62..bb162b9 100644 --- a/src/t2iapi/device/service.proto +++ b/src/t2iapi/device/service.proto @@ -155,4 +155,18 @@ service DeviceService { user's opinion, must be present for this device. */ rpc GetAvailableDeviceMetaData(BasicHandleRequest) returns (AvailableDeviceMetaDataResponse); + + /* + Get the software version of the requested pm:AbstractDeviceComponentDescriptor handle if it is representing + a component with a software version. + */ + rpc GetComponentSwVersion (BasicHandleRequest) + returns (t2iapi.device.GetComponentSwVersionResponse); + + /* + Get the hardware version of the requested pm:AbstractDeviceComponentDescriptor handle if it is representing + a component with a hardware version. + */ + rpc GetComponentHwVersion (BasicHandleRequest) + returns (t2iapi.device.GetComponentHwVersionResponse); }