isar 1.30.3__py3-none-any.whl → 1.30.5__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of isar might be problematic. Click here for more details.
- isar/apis/api.py +40 -3
- isar/apis/models/models.py +4 -4
- isar/config/settings.py +2 -0
- isar/modules.py +11 -10
- isar/script.py +3 -1
- isar/services/utilities/scheduling_utilities.py +10 -1
- isar/state_machine/generic_states/ongoing_mission.py +1 -1
- isar/state_machine/state_machine.py +7 -10
- isar/state_machine/states/stopping.py +2 -2
- isar/state_machine/transitions/functions/start_mission.py +1 -1
- isar/state_machine/transitions/functions/stop.py +44 -1
- isar/state_machine/transitions/mission.py +14 -0
- {isar-1.30.3.dist-info → isar-1.30.5.dist-info}/METADATA +1 -1
- {isar-1.30.3.dist-info → isar-1.30.5.dist-info}/RECORD +19 -19
- robot_interface/telemetry/payloads.py +6 -0
- {isar-1.30.3.dist-info → isar-1.30.5.dist-info}/WHEEL +0 -0
- {isar-1.30.3.dist-info → isar-1.30.5.dist-info}/entry_points.txt +0 -0
- {isar-1.30.3.dist-info → isar-1.30.5.dist-info}/licenses/LICENSE +0 -0
- {isar-1.30.3.dist-info → isar-1.30.5.dist-info}/top_level.txt +0 -0
isar/apis/api.py
CHANGED
|
@@ -1,4 +1,7 @@
|
|
|
1
|
+
import json
|
|
1
2
|
import logging
|
|
3
|
+
import time
|
|
4
|
+
from datetime import datetime, timezone
|
|
2
5
|
from http import HTTPStatus
|
|
3
6
|
from logging import Logger
|
|
4
7
|
from typing import List, Union
|
|
@@ -24,6 +27,9 @@ from isar.config.configuration_error import ConfigurationError
|
|
|
24
27
|
from isar.config.keyvault.keyvault_error import KeyvaultError
|
|
25
28
|
from isar.config.keyvault.keyvault_service import Keyvault
|
|
26
29
|
from isar.config.settings import settings
|
|
30
|
+
from robot_interface.telemetry.mqtt_client import MqttClientInterface
|
|
31
|
+
from robot_interface.telemetry.payloads import StartUpMessagePayload
|
|
32
|
+
from robot_interface.utilities.json_service import EnhancedJSONEncoder
|
|
27
33
|
|
|
28
34
|
HTTP_URL = COMMON_ATTRIBUTES["HTTP_URL"]
|
|
29
35
|
HTTP_STATUS_CODE = COMMON_ATTRIBUTES["HTTP_STATUS_CODE"]
|
|
@@ -37,6 +43,7 @@ class API:
|
|
|
37
43
|
scheduling_controller: SchedulingController,
|
|
38
44
|
robot_controller: RobotController,
|
|
39
45
|
keyvault: Keyvault,
|
|
46
|
+
mqtt_publisher: MqttClientInterface,
|
|
40
47
|
port: int = settings.API_PORT,
|
|
41
48
|
azure_ai_logging_enabled: bool = settings.LOG_HANDLER_APPLICATION_INSIGHTS_ENABLED,
|
|
42
49
|
) -> None:
|
|
@@ -47,22 +54,31 @@ class API:
|
|
|
47
54
|
self.host: str = "0.0.0.0" # Locking uvicorn to use 0.0.0.0
|
|
48
55
|
self.port: int = port
|
|
49
56
|
self.azure_ai_logging_enabled: bool = azure_ai_logging_enabled
|
|
57
|
+
self.mqtt_publisher: MqttClientInterface = mqtt_publisher
|
|
50
58
|
|
|
51
59
|
self.logger: Logger = logging.getLogger("api")
|
|
52
60
|
|
|
53
61
|
self.app: FastAPI = self._create_app()
|
|
62
|
+
self.server = self._setup_server()
|
|
54
63
|
|
|
55
64
|
def get_app(self) -> FastAPI:
|
|
56
65
|
return self.app
|
|
57
66
|
|
|
58
|
-
def
|
|
59
|
-
uvicorn.
|
|
67
|
+
def _setup_server(self) -> uvicorn.Server:
|
|
68
|
+
config = uvicorn.Config(
|
|
60
69
|
self.app,
|
|
61
70
|
port=self.port,
|
|
62
71
|
host=self.host,
|
|
63
72
|
reload=False,
|
|
64
73
|
log_config=None,
|
|
65
74
|
)
|
|
75
|
+
return uvicorn.Server(config)
|
|
76
|
+
|
|
77
|
+
def wait_for_api_server_ready(self) -> None:
|
|
78
|
+
while not self.server.started:
|
|
79
|
+
time.sleep(0.01)
|
|
80
|
+
self.logger.info("Uvicorn server has been started")
|
|
81
|
+
self._publish_startup_message()
|
|
66
82
|
|
|
67
83
|
def _create_app(self) -> FastAPI:
|
|
68
84
|
tags_metadata = [
|
|
@@ -73,7 +89,10 @@ class API:
|
|
|
73
89
|
]
|
|
74
90
|
app = FastAPI(
|
|
75
91
|
openapi_tags=tags_metadata,
|
|
76
|
-
on_startup=[
|
|
92
|
+
on_startup=[
|
|
93
|
+
self.authenticator.load_config,
|
|
94
|
+
self._log_startup_message,
|
|
95
|
+
],
|
|
77
96
|
swagger_ui_oauth2_redirect_url="/oauth2-redirect",
|
|
78
97
|
swagger_ui_init_oauth={
|
|
79
98
|
"usePkceWithAuthorizationCodeGrant": True,
|
|
@@ -349,3 +368,21 @@ class API:
|
|
|
349
368
|
)
|
|
350
369
|
|
|
351
370
|
return response
|
|
371
|
+
|
|
372
|
+
def _publish_startup_message(self) -> None:
|
|
373
|
+
if not self.mqtt_publisher:
|
|
374
|
+
return
|
|
375
|
+
|
|
376
|
+
payload: StartUpMessagePayload = StartUpMessagePayload(
|
|
377
|
+
isar_id=settings.ISAR_ID,
|
|
378
|
+
timestamp=datetime.now(timezone.utc),
|
|
379
|
+
)
|
|
380
|
+
|
|
381
|
+
self.logger.info("Publishing startup message to MQTT broker")
|
|
382
|
+
|
|
383
|
+
self.mqtt_publisher.publish(
|
|
384
|
+
topic=settings.TOPIC_ISAR_STARTUP,
|
|
385
|
+
payload=json.dumps(payload, cls=EnhancedJSONEncoder),
|
|
386
|
+
qos=1,
|
|
387
|
+
retain=True,
|
|
388
|
+
)
|
isar/apis/models/models.py
CHANGED
|
@@ -19,10 +19,10 @@ class StartMissionResponse(BaseModel):
|
|
|
19
19
|
|
|
20
20
|
|
|
21
21
|
class ControlMissionResponse(BaseModel):
|
|
22
|
-
mission_id: str
|
|
23
|
-
mission_status: str
|
|
24
|
-
task_id: str
|
|
25
|
-
task_status: str
|
|
22
|
+
mission_id: Optional[str]
|
|
23
|
+
mission_status: Optional[str]
|
|
24
|
+
task_id: Optional[str]
|
|
25
|
+
task_status: Optional[str]
|
|
26
26
|
|
|
27
27
|
|
|
28
28
|
class RobotInfoResponse(BaseModel):
|
isar/config/settings.py
CHANGED
|
@@ -211,6 +211,7 @@ class Settings(BaseSettings):
|
|
|
211
211
|
TOPIC_ISAR_ROBOT_HEARTBEAT: str = Field(
|
|
212
212
|
default="robot_heartbeat", validate_default=True
|
|
213
213
|
)
|
|
214
|
+
TOPIC_ISAR_STARTUP: str = Field(default="startup", validate_default=True)
|
|
214
215
|
|
|
215
216
|
# Logging
|
|
216
217
|
|
|
@@ -261,6 +262,7 @@ class Settings(BaseSettings):
|
|
|
261
262
|
"TOPIC_ISAR_ROBOT_HEARTBEAT",
|
|
262
263
|
"TOPIC_ISAR_INSPECTION_RESULT",
|
|
263
264
|
"TOPIC_ISAR_INSPECTION_VALUE",
|
|
265
|
+
"TOPIC_ISAR_STARTUP",
|
|
264
266
|
)
|
|
265
267
|
@classmethod
|
|
266
268
|
def prefix_isar_topics(cls, v: Any, info: ValidationInfo):
|
isar/modules.py
CHANGED
|
@@ -45,6 +45,16 @@ class ApplicationContainer(containers.DeclarativeContainer):
|
|
|
45
45
|
)
|
|
46
46
|
robot_utilities = providers.Singleton(RobotUtilities, robot=robot_interface)
|
|
47
47
|
|
|
48
|
+
# Mqtt client
|
|
49
|
+
mqtt_client = (
|
|
50
|
+
providers.Singleton(
|
|
51
|
+
MqttPublisher,
|
|
52
|
+
mqtt_queue=providers.Callable(events.provided.mqtt_queue),
|
|
53
|
+
)
|
|
54
|
+
if settings.MQTT_ENABLED
|
|
55
|
+
else None
|
|
56
|
+
)
|
|
57
|
+
|
|
48
58
|
# API and controllers
|
|
49
59
|
authenticator = providers.Singleton(Authenticator)
|
|
50
60
|
scheduling_utilities = providers.Singleton(
|
|
@@ -65,6 +75,7 @@ class ApplicationContainer(containers.DeclarativeContainer):
|
|
|
65
75
|
scheduling_controller=scheduling_controller,
|
|
66
76
|
robot_controller=robot_controller,
|
|
67
77
|
keyvault=keyvault,
|
|
78
|
+
mqtt_publisher=mqtt_client,
|
|
68
79
|
)
|
|
69
80
|
|
|
70
81
|
# Storage
|
|
@@ -77,16 +88,6 @@ class ApplicationContainer(containers.DeclarativeContainer):
|
|
|
77
88
|
storage_handlers_temp.append(blob_storage)
|
|
78
89
|
storage_handlers = providers.List(*storage_handlers_temp)
|
|
79
90
|
|
|
80
|
-
# Mqtt client
|
|
81
|
-
mqtt_client = (
|
|
82
|
-
providers.Singleton(
|
|
83
|
-
MqttPublisher,
|
|
84
|
-
mqtt_queue=providers.Callable(events.provided.mqtt_queue),
|
|
85
|
-
)
|
|
86
|
-
if settings.MQTT_ENABLED
|
|
87
|
-
else None
|
|
88
|
-
)
|
|
89
|
-
|
|
90
91
|
# State machine
|
|
91
92
|
task_selector = providers.Singleton(
|
|
92
93
|
SequentialTaskSelector
|
isar/script.py
CHANGED
|
@@ -160,13 +160,15 @@ def start() -> None:
|
|
|
160
160
|
threads.extend(publishers)
|
|
161
161
|
|
|
162
162
|
api: API = injector.api()
|
|
163
|
-
api_thread: Thread = Thread(target=api.
|
|
163
|
+
api_thread: Thread = Thread(target=api.server.run, name="ISAR API", daemon=True)
|
|
164
164
|
threads.append(api_thread)
|
|
165
165
|
|
|
166
166
|
for thread in threads:
|
|
167
167
|
thread.start()
|
|
168
168
|
logger.info("Started thread: %s", thread.name)
|
|
169
169
|
|
|
170
|
+
api.wait_for_api_server_ready()
|
|
171
|
+
|
|
170
172
|
while True:
|
|
171
173
|
for thread in threads:
|
|
172
174
|
if not thread.is_alive():
|
|
@@ -22,6 +22,7 @@ from isar.models.communication.queues.queue_timeout_error import QueueTimeoutErr
|
|
|
22
22
|
from isar.services.utilities.queue_utilities import QueueUtilities
|
|
23
23
|
from isar.state_machine.states_enum import States
|
|
24
24
|
from robot_interface.models.mission.mission import Mission
|
|
25
|
+
from robot_interface.models.mission.status import MissionStatus
|
|
25
26
|
|
|
26
27
|
|
|
27
28
|
class SchedulingUtilities:
|
|
@@ -253,13 +254,21 @@ class SchedulingUtilities:
|
|
|
253
254
|
|
|
254
255
|
Raises
|
|
255
256
|
------
|
|
256
|
-
|
|
257
|
+
HTTPException 503 Service Unavailable
|
|
258
|
+
The request was understood, but attempting to stop the mission failed
|
|
259
|
+
HTTPException 408 Request timeout
|
|
257
260
|
If there is a timeout while communicating with the state machine
|
|
258
261
|
"""
|
|
259
262
|
try:
|
|
260
263
|
stop_mission_response: ControlMissionResponse = self._send_command(
|
|
261
264
|
True, self.api_events.stop_mission
|
|
262
265
|
)
|
|
266
|
+
if stop_mission_response.mission_status != MissionStatus.Cancelled.value:
|
|
267
|
+
error_message = "Failed to stop mission"
|
|
268
|
+
self.logger.error(error_message)
|
|
269
|
+
raise HTTPException(
|
|
270
|
+
status_code=HTTPStatus.SERVICE_UNAVAILABLE, detail=error_message
|
|
271
|
+
)
|
|
263
272
|
except QueueTimeoutError:
|
|
264
273
|
error_message = "Internal Server Error - Failed to stop mission"
|
|
265
274
|
self.logger.error(error_message)
|
|
@@ -194,6 +194,7 @@ class StateMachine(object):
|
|
|
194
194
|
self.current_task = None
|
|
195
195
|
self.send_task_status()
|
|
196
196
|
self.current_mission = None
|
|
197
|
+
self.mission_ongoing = False
|
|
197
198
|
|
|
198
199
|
def start_mission(self, mission: Mission):
|
|
199
200
|
"""Starts a scheduled mission."""
|
|
@@ -316,17 +317,13 @@ class StateMachine(object):
|
|
|
316
317
|
self.logger.info("Mission overview:\n%s", log_statement)
|
|
317
318
|
|
|
318
319
|
def _make_control_mission_response(self) -> ControlMissionResponse:
|
|
319
|
-
if self.current_mission is None:
|
|
320
|
-
raise ValueError("No current mission is set")
|
|
321
|
-
|
|
322
|
-
if self.current_task is None:
|
|
323
|
-
raise ValueError("No current task is set")
|
|
324
|
-
|
|
325
320
|
return ControlMissionResponse(
|
|
326
|
-
mission_id=self.current_mission.id,
|
|
327
|
-
mission_status=
|
|
328
|
-
|
|
329
|
-
|
|
321
|
+
mission_id=self.current_mission.id if self.current_mission else None,
|
|
322
|
+
mission_status=(
|
|
323
|
+
self.current_mission.status if self.current_mission else None
|
|
324
|
+
),
|
|
325
|
+
task_id=self.current_task.id if self.current_task else None,
|
|
326
|
+
task_status=self.current_task.status if self.current_task else None,
|
|
330
327
|
)
|
|
331
328
|
|
|
332
329
|
def _queue_empty_response(self) -> None:
|
|
@@ -39,9 +39,9 @@ class Stopping(State):
|
|
|
39
39
|
if error_message is not None:
|
|
40
40
|
self.logger.warning(error_message.error_description)
|
|
41
41
|
if self.stopping_return_home_mission:
|
|
42
|
-
self.state_machine.
|
|
42
|
+
self.state_machine.return_home_mission_stopping_failed() # type: ignore
|
|
43
43
|
else:
|
|
44
|
-
self.state_machine.
|
|
44
|
+
self.state_machine.mission_stopping_failed() # type: ignore
|
|
45
45
|
return True
|
|
46
46
|
return False
|
|
47
47
|
|
|
@@ -18,7 +18,7 @@ def put_start_mission_on_queue(state_machine: "StateMachine") -> bool:
|
|
|
18
18
|
|
|
19
19
|
def initiate_mission(state_machine: "StateMachine") -> bool:
|
|
20
20
|
state_machine.logger.info(
|
|
21
|
-
"
|
|
21
|
+
"Initiating mission:\n"
|
|
22
22
|
f" Mission ID: {state_machine.current_mission.id}\n"
|
|
23
23
|
f" Mission Name: {state_machine.current_mission.name}\n"
|
|
24
24
|
f" Number of Tasks: {len(state_machine.current_mission.tasks)}"
|
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
from typing import TYPE_CHECKING
|
|
2
2
|
|
|
3
|
-
from isar.models.communication.queues.queue_utils import
|
|
3
|
+
from isar.models.communication.queues.queue_utils import (
|
|
4
|
+
check_for_event_without_consumption,
|
|
5
|
+
trigger_event_without_data,
|
|
6
|
+
)
|
|
4
7
|
|
|
5
8
|
if TYPE_CHECKING:
|
|
6
9
|
from isar.state_machine.state_machine import StateMachine
|
|
@@ -39,11 +42,51 @@ def stop_mission_cleanup(state_machine: "StateMachine") -> bool:
|
|
|
39
42
|
return True
|
|
40
43
|
|
|
41
44
|
|
|
45
|
+
def stop_mission_failed(state_machine: "StateMachine") -> bool:
|
|
46
|
+
stopped_mission_response: ControlMissionResponse = (
|
|
47
|
+
state_machine._make_control_mission_response()
|
|
48
|
+
)
|
|
49
|
+
state_machine.events.api_requests.stop_mission.output.put(stopped_mission_response)
|
|
50
|
+
return True
|
|
51
|
+
|
|
52
|
+
|
|
42
53
|
def stop_return_home_mission_cleanup(state_machine: "StateMachine") -> bool:
|
|
43
54
|
if state_machine.current_mission is None:
|
|
44
55
|
state_machine._queue_empty_response()
|
|
45
56
|
state_machine.reset_state_machine()
|
|
46
57
|
return True
|
|
47
58
|
|
|
59
|
+
if not check_for_event_without_consumption(
|
|
60
|
+
state_machine.events.api_requests.start_mission.input
|
|
61
|
+
):
|
|
62
|
+
state_machine.current_mission.status = MissionStatus.Cancelled
|
|
63
|
+
|
|
64
|
+
for task in state_machine.current_mission.tasks:
|
|
65
|
+
if task.status in [
|
|
66
|
+
TaskStatus.NotStarted,
|
|
67
|
+
TaskStatus.InProgress,
|
|
68
|
+
TaskStatus.Paused,
|
|
69
|
+
]:
|
|
70
|
+
task.status = TaskStatus.Cancelled
|
|
71
|
+
|
|
72
|
+
stopped_mission_response: ControlMissionResponse = (
|
|
73
|
+
state_machine._make_control_mission_response()
|
|
74
|
+
)
|
|
75
|
+
state_machine.events.api_requests.stop_mission.output.put(
|
|
76
|
+
stopped_mission_response
|
|
77
|
+
)
|
|
78
|
+
|
|
48
79
|
state_machine._finalize()
|
|
49
80
|
return True
|
|
81
|
+
|
|
82
|
+
|
|
83
|
+
def stop_return_home_mission_failed(state_machine: "StateMachine") -> bool:
|
|
84
|
+
if check_for_event_without_consumption(
|
|
85
|
+
state_machine.events.api_requests.start_mission.input
|
|
86
|
+
):
|
|
87
|
+
return True
|
|
88
|
+
stopped_mission_response: ControlMissionResponse = (
|
|
89
|
+
state_machine._make_control_mission_response()
|
|
90
|
+
)
|
|
91
|
+
state_machine.events.api_requests.stop_mission.output.put(stopped_mission_response)
|
|
92
|
+
return True
|
|
@@ -15,7 +15,9 @@ from isar.state_machine.transitions.functions.start_mission import (
|
|
|
15
15
|
)
|
|
16
16
|
from isar.state_machine.transitions.functions.stop import (
|
|
17
17
|
stop_mission_cleanup,
|
|
18
|
+
stop_mission_failed,
|
|
18
19
|
stop_return_home_mission_cleanup,
|
|
20
|
+
stop_return_home_mission_failed,
|
|
19
21
|
trigger_stop_mission_event,
|
|
20
22
|
)
|
|
21
23
|
from isar.state_machine.transitions.functions.utils import def_transition
|
|
@@ -56,6 +58,18 @@ def get_mission_transitions(state_machine: "StateMachine") -> List[dict]:
|
|
|
56
58
|
"dest": state_machine.await_next_mission_state,
|
|
57
59
|
"before": def_transition(state_machine, stop_mission_cleanup),
|
|
58
60
|
},
|
|
61
|
+
{
|
|
62
|
+
"trigger": "mission_stopping_failed",
|
|
63
|
+
"source": state_machine.stopping_state,
|
|
64
|
+
"dest": state_machine.monitor_state,
|
|
65
|
+
"before": def_transition(state_machine, stop_mission_failed),
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
"trigger": "return_home_mission_stopping_failed",
|
|
69
|
+
"source": state_machine.stopping_state,
|
|
70
|
+
"dest": state_machine.returning_home_state,
|
|
71
|
+
"before": def_transition(state_machine, stop_return_home_mission_failed),
|
|
72
|
+
},
|
|
59
73
|
{
|
|
60
74
|
"trigger": "return_home_mission_stopped",
|
|
61
75
|
"source": state_machine.stopping_state,
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
isar/__init__.py,sha256=cH8p8bVveu3FUL6kBhldcSlLaoHgD82Kd0-SwSNfGXw,87
|
|
2
|
-
isar/modules.py,sha256=
|
|
3
|
-
isar/script.py,sha256=
|
|
2
|
+
isar/modules.py,sha256=QBB1pge1i17HVMLA5n-qd9K3APCrX9bFF2vlfjheOhU,4778
|
|
3
|
+
isar/script.py,sha256=0oUUfytKDOsWrPv4iWemTWl5L3Ug66mQsbvqGqQrVWk,6050
|
|
4
4
|
isar/apis/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
5
|
-
isar/apis/api.py,sha256=
|
|
5
|
+
isar/apis/api.py,sha256=2hggLxcdsHqTYDAfVUMwMIBgpuB-0ba2HWMscHkRGzA,15072
|
|
6
6
|
isar/apis/models/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
7
|
-
isar/apis/models/models.py,sha256=
|
|
7
|
+
isar/apis/models/models.py,sha256=NWXTe5SheVj3QXklWZ1FMliZVHdS4Rjfuin5O4N9MTM,1789
|
|
8
8
|
isar/apis/models/start_mission_definition.py,sha256=S87i_vrgXTY1nTMTiXMJAnx_q5uVxuiRNcrQrAYWKeo,6152
|
|
9
9
|
isar/apis/robot_control/robot_controller.py,sha256=7EVukShJDhYez12wYeGWZXH-BrfQ4Wu2so0-fSWN2Zo,1277
|
|
10
10
|
isar/apis/schedule/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
@@ -15,7 +15,7 @@ isar/config/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
|
15
15
|
isar/config/configuration_error.py,sha256=rO6WOhafX6xvVib8WxV-eY483Z0PpN-9PxGsq5ATfKc,46
|
|
16
16
|
isar/config/log.py,sha256=SzEWbzXU1DpN7YONIRT8k0zBOGm_qVkXlJuuZtb8STc,2300
|
|
17
17
|
isar/config/logging.conf,sha256=mYO1xf27gAopEMHhGzY7-mwyfN16rwRLkPNMvy3zn2g,1127
|
|
18
|
-
isar/config/settings.py,sha256=
|
|
18
|
+
isar/config/settings.py,sha256=dn9fEKX7GpzD9Y7q0TjQxW9Xf0iY-pCl3NV7bkxH1E8,12487
|
|
19
19
|
isar/config/certs/ca-cert.pem,sha256=qoNljfad_qcMxhXJIUMLd7nT-Qwf_d4dYSdoOFEOE8I,2179
|
|
20
20
|
isar/config/keyvault/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
21
21
|
isar/config/keyvault/keyvault_error.py,sha256=zvPCsZLjboxsxthYkxpRERCTFxYV8R5WmACewAUQLwk,41
|
|
@@ -67,13 +67,13 @@ isar/services/service_connections/stid/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JC
|
|
|
67
67
|
isar/services/utilities/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
68
68
|
isar/services/utilities/queue_utilities.py,sha256=Pw3hehSwkXJNeDv-bDVDfs58VOwtt3i5hpiJ2ZpphuQ,1225
|
|
69
69
|
isar/services/utilities/robot_utilities.py,sha256=J3miRs0t74HNBoMIzVMceMCibp5DozP9Ai1_i7B3kWI,573
|
|
70
|
-
isar/services/utilities/scheduling_utilities.py,sha256=
|
|
70
|
+
isar/services/utilities/scheduling_utilities.py,sha256=4HoUl0WQc7RE9Vx4wZmpX9czgcF7xJg_Pn2hwtSju10,10702
|
|
71
71
|
isar/services/utilities/threaded_request.py,sha256=py4G-_RjnIdHljmKFAcQ6ddqMmp-ZYV39Ece-dqRqjs,1874
|
|
72
72
|
isar/state_machine/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
73
|
-
isar/state_machine/state_machine.py,sha256=
|
|
73
|
+
isar/state_machine/state_machine.py,sha256=yRNjzheKZ9PqNQ1G-ZHb8VmYEXTR9XqaJQn_3191Rcw,13157
|
|
74
74
|
isar/state_machine/states_enum.py,sha256=Z3dO6k6JmQAZ1lzcR58oVCxoCky_-ZS9MaL3RSaNbZ4,434
|
|
75
75
|
isar/state_machine/generic_states/idle.py,sha256=T_LSadQ8Eu9egYPgL43WKDYv27MwFu-dqIxDazVE_KU,4359
|
|
76
|
-
isar/state_machine/generic_states/ongoing_mission.py,sha256=
|
|
76
|
+
isar/state_machine/generic_states/ongoing_mission.py,sha256=P3jikXYcpYgvkuwjGGi9krjnUVEVqUwvM_RHeQbN9wc,10814
|
|
77
77
|
isar/state_machine/generic_states/robot_unavailable.py,sha256=pHmed1uRPwCWAR4uBJmdnxi9WX8veTbGG9ephmROhm0,1851
|
|
78
78
|
isar/state_machine/states/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
79
79
|
isar/state_machine/states/await_next_mission.py,sha256=U0oGi-O05S-ZvdhpQRuirrY3ZBbblURo5U95PsscMlQ,573
|
|
@@ -84,9 +84,9 @@ isar/state_machine/states/offline.py,sha256=vZnBMVDnehZ-0gPsHNVRpZtb8OBBFkeEnq2o
|
|
|
84
84
|
isar/state_machine/states/paused.py,sha256=IgnWBM6WXj3wjFZMARAPWIpzWGyUSW35DVBvNHuiNP8,1460
|
|
85
85
|
isar/state_machine/states/returning_home.py,sha256=BBQo3PoNP-THlvJa5gQr0fNBhInh_Ox1L2OeH8evUq8,638
|
|
86
86
|
isar/state_machine/states/robot_standing_still.py,sha256=RbOZSiQz72tWAJID5ksgzcb4lND6OniiG35IE1wMUHk,579
|
|
87
|
-
isar/state_machine/states/stopping.py,sha256=
|
|
87
|
+
isar/state_machine/states/stopping.py,sha256=yJE7KT1aGo_qd1VTETfg1rTrlM-hKKQYKQp7xu4py_Y,2854
|
|
88
88
|
isar/state_machine/states/unknown_status.py,sha256=tOwfHW_4bKKkUTpKD7qc5gIwGT_fTXaCNxXcogGw-wo,2416
|
|
89
|
-
isar/state_machine/transitions/mission.py,sha256=
|
|
89
|
+
isar/state_machine/transitions/mission.py,sha256=_aaHLUXeomHa_m-9pStBQrWmKupsJqb-jC4BDQDBI6o,5490
|
|
90
90
|
isar/state_machine/transitions/return_home.py,sha256=LeOMnckUUQYzBYRidD2ge6M0KdxGDTgo-ioXR7_9r8A,2714
|
|
91
91
|
isar/state_machine/transitions/robot_status.py,sha256=c1ceyWRGCtx-KTDtxHXRD7oPbt8TQ2ej24A0wyim8vc,2720
|
|
92
92
|
isar/state_machine/transitions/functions/fail_mission.py,sha256=_6HqBMALDinFZ4yh5GMpeqqgV5tw5i8OVMj5UDdqesg,495
|
|
@@ -95,8 +95,8 @@ isar/state_machine/transitions/functions/pause.py,sha256=aoDkq2nV6wBY0YQX3KbjvBR
|
|
|
95
95
|
isar/state_machine/transitions/functions/resume.py,sha256=9KQjH_6YBGyxFhb7G5dgDe3WH0xHawhEIw6yTVEm9os,998
|
|
96
96
|
isar/state_machine/transitions/functions/return_home.py,sha256=UlniwYvpz74hxqgN0TyVv3LCmiMsqsosKEtEGLqkNj0,1139
|
|
97
97
|
isar/state_machine/transitions/functions/robot_status.py,sha256=xhKZ5u_X8uDvnhvGnAIABuKaPXeVqFjkgj4H2Om-j_A,1013
|
|
98
|
-
isar/state_machine/transitions/functions/start_mission.py,sha256=
|
|
99
|
-
isar/state_machine/transitions/functions/stop.py,sha256=
|
|
98
|
+
isar/state_machine/transitions/functions/start_mission.py,sha256=ricRfhLH1_lNpqWxneMZcm7ps2YfY6sQGHkiT0Glf6M,2564
|
|
99
|
+
isar/state_machine/transitions/functions/stop.py,sha256=JK4hjGc3QtgSzvCWeOr1YG61SH1QOhmVNjw_jOnahQg,3123
|
|
100
100
|
isar/state_machine/transitions/functions/utils.py,sha256=Wa72Ocq4QT1E6qkpEJZQ3h5o33pGvx7Tlkt2JZ2Grbk,314
|
|
101
101
|
isar/storage/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
102
102
|
isar/storage/blob_storage.py,sha256=Qci6bO508nlTHKPuPtVU5QcvGA4T7mv8cFrKWRcfw4g,3226
|
|
@@ -104,7 +104,7 @@ isar/storage/local_storage.py,sha256=Bnmoi5gyN8r-oRh0aHrOdGqaH3JqRScFKMRXYojW5kY
|
|
|
104
104
|
isar/storage/storage_interface.py,sha256=DYDry4I7aZpDHJhsBF6s8zrgokFAc7fdKJKfA8AvL7o,828
|
|
105
105
|
isar/storage/uploader.py,sha256=HAC3ssuPQCQ1xH4aTQfHIaq-ZoEzKwONWmsAOpNXOzw,9523
|
|
106
106
|
isar/storage/utilities.py,sha256=oLH0Rp7UtrQQdilfITnmXO1Z0ExdeDhBImYHid55vBA,3449
|
|
107
|
-
isar-1.30.
|
|
107
|
+
isar-1.30.5.dist-info/licenses/LICENSE,sha256=3fc2-ebLwHWwzfQbulGNRdcNob3SBQeCfEVUDYxsuqw,14058
|
|
108
108
|
robot_interface/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
109
109
|
robot_interface/robot_interface.py,sha256=Miout0IRX7QniUNu_upyNzkB8KDUWin7GGCqIeMh83E,8195
|
|
110
110
|
robot_interface/test_robot_interface.py,sha256=FV1urn7SbsMyWBIcTKjsBwAG4IsXeZ6pLHE0mA9EGGs,692
|
|
@@ -124,12 +124,12 @@ robot_interface/models/robots/media.py,sha256=8A-CuuubfngzPprs6zWB9hSaqe3jzgsE8r
|
|
|
124
124
|
robot_interface/models/robots/robot_model.py,sha256=-0jNKWPcEgtF_2klb1It3u0SCoAR0hSW9nce58Zq0Co,417
|
|
125
125
|
robot_interface/telemetry/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
126
126
|
robot_interface/telemetry/mqtt_client.py,sha256=ueXdtIFNCwciTj4spvdJj9emd-IOmUuJjpsXQSSWZPY,2987
|
|
127
|
-
robot_interface/telemetry/payloads.py,sha256=
|
|
127
|
+
robot_interface/telemetry/payloads.py,sha256=PpvmV7XeGgfhc_aRUYFOdwBTwV2x8TwTBINJ-rKchVw,2804
|
|
128
128
|
robot_interface/utilities/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
129
129
|
robot_interface/utilities/json_service.py,sha256=qkzVkb60Gi_pto-b5n1vNzCrQze2yqgIJqSLNLYj1Fg,1034
|
|
130
130
|
robot_interface/utilities/uuid_string_factory.py,sha256=_NQIbBQ56w0qqO0MUDP6aPpHbxW7ATRhK8HnQiBSLkc,76
|
|
131
|
-
isar-1.30.
|
|
132
|
-
isar-1.30.
|
|
133
|
-
isar-1.30.
|
|
134
|
-
isar-1.30.
|
|
135
|
-
isar-1.30.
|
|
131
|
+
isar-1.30.5.dist-info/METADATA,sha256=y-vfw6eUN7tOlQjfzG_dD2App6B4A5u2zeSRCC8yGM0,31063
|
|
132
|
+
isar-1.30.5.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
|
|
133
|
+
isar-1.30.5.dist-info/entry_points.txt,sha256=TFam7uNNw7J0iiDYzsH2gfG0u1eV1wh3JTw_HkhgKLk,49
|
|
134
|
+
isar-1.30.5.dist-info/top_level.txt,sha256=UwIML2RtuQKCyJJkatcSnyp6-ldDjboB9k9JgKipO-U,21
|
|
135
|
+
isar-1.30.5.dist-info/RECORD,,
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|