From b6cb77df768ab54b1ae3df0b81b2bcf263bdfc6d Mon Sep 17 00:00:00 2001 From: Thomas Sundvoll Date: Mon, 30 Oct 2023 10:38:12 +0100 Subject: [PATCH] Include analysis_type on inspection_result message beeing published at every inspection upload --- src/isar/apis/models/start_mission_definition.py | 1 + src/isar/storage/uploader.py | 15 +++++++++------ 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/src/isar/apis/models/start_mission_definition.py b/src/isar/apis/models/start_mission_definition.py index b5dcd1ef..9160fe4e 100644 --- a/src/isar/apis/models/start_mission_definition.py +++ b/src/isar/apis/models/start_mission_definition.py @@ -32,6 +32,7 @@ class InspectionTypes(str, Enum): class StartMissionInspectionDefinition(BaseModel): type: InspectionTypes = Field(default=InspectionTypes.image) inspection_target: InputPosition + analysis_type: Optional[str] = None duration: Optional[float] = None metadata: Optional[dict] = None id: Optional[str] = None diff --git a/src/isar/storage/uploader.py b/src/isar/storage/uploader.py index 228f9987..edee8455 100644 --- a/src/isar/storage/uploader.py +++ b/src/isar/storage/uploader.py @@ -9,9 +9,9 @@ from isar.config.settings import settings from isar.models.communication.queues import Queues -from robot_interface.models.mission.mission import Mission from isar.storage.storage_interface import StorageException, StorageInterface from robot_interface.models.inspection.inspection import Inspection +from robot_interface.models.mission.mission import Mission from robot_interface.telemetry.mqtt_client import MqttClientInterface from robot_interface.utilities.json_service import EnhancedJSONEncoder @@ -131,26 +131,29 @@ def _upload(self, upload_item: UploaderQueueItem) -> str: def _process_upload_queue(self) -> None: ready_items: List[UploaderQueueItem] = [ - x for x in self._internal_upload_queue if x.is_ready_for_upload() + item for item in self._internal_upload_queue if item.is_ready_for_upload() ] for item in ready_items: inspection_path = self._upload(item) - self._publish_inspection_path( + self._publish_inspection_result( inspection=item.inspection, inspection_path=inspection_path ) - def _publish_inspection_path( + def _publish_inspection_result( self, inspection: Inspection, inspection_path: str ) -> None: - """Publishes the image url to the MQTT Broker""" + """Publishes the reference of the inspection result to the MQTT Broker + along with the analysis type + """ if not self.mqtt_publisher: return payload: str = json.dumps( { "isar_id": settings.ISAR_ID, "robot_name": settings.ROBOT_NAME, - "step_id": inspection.id, + "inspection_id": inspection.id, "inspection_path": inspection_path, + "analysis_type": inspection.metadata.analysis_type, "timestamp": datetime.utcnow(), }, cls=EnhancedJSONEncoder,