omnata-plugin-runtime 0.3.24a73__tar.gz → 0.3.24a74__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {omnata_plugin_runtime-0.3.24a73 → omnata_plugin_runtime-0.3.24a74}/PKG-INFO +1 -1
- {omnata_plugin_runtime-0.3.24a73 → omnata_plugin_runtime-0.3.24a74}/pyproject.toml +1 -1
- {omnata_plugin_runtime-0.3.24a73 → omnata_plugin_runtime-0.3.24a74}/src/omnata_plugin_runtime/omnata_plugin.py +9 -8
- {omnata_plugin_runtime-0.3.24a73 → omnata_plugin_runtime-0.3.24a74}/LICENSE +0 -0
- {omnata_plugin_runtime-0.3.24a73 → omnata_plugin_runtime-0.3.24a74}/README.md +0 -0
- {omnata_plugin_runtime-0.3.24a73 → omnata_plugin_runtime-0.3.24a74}/src/omnata_plugin_runtime/__init__.py +0 -0
- {omnata_plugin_runtime-0.3.24a73 → omnata_plugin_runtime-0.3.24a74}/src/omnata_plugin_runtime/api.py +0 -0
- {omnata_plugin_runtime-0.3.24a73 → omnata_plugin_runtime-0.3.24a74}/src/omnata_plugin_runtime/configuration.py +0 -0
- {omnata_plugin_runtime-0.3.24a73 → omnata_plugin_runtime-0.3.24a74}/src/omnata_plugin_runtime/forms.py +0 -0
- {omnata_plugin_runtime-0.3.24a73 → omnata_plugin_runtime-0.3.24a74}/src/omnata_plugin_runtime/logging.py +0 -0
- {omnata_plugin_runtime-0.3.24a73 → omnata_plugin_runtime-0.3.24a74}/src/omnata_plugin_runtime/plugin_entrypoints.py +0 -0
- {omnata_plugin_runtime-0.3.24a73 → omnata_plugin_runtime-0.3.24a74}/src/omnata_plugin_runtime/rate_limiting.py +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
[tool.poetry]
|
2
2
|
name = "omnata-plugin-runtime"
|
3
|
-
version = "0.3.24-
|
3
|
+
version = "0.3.24-a74"
|
4
4
|
description = "Classes and common runtime components for building and running Omnata Plugins"
|
5
5
|
authors = ["James Weakley <james.weakley@omnata.com>"]
|
6
6
|
readme = "README.md"
|
@@ -215,6 +215,7 @@ class SyncRequest(ABC):
|
|
215
215
|
self._apply_results_task = None
|
216
216
|
self._cancel_checking_task = None
|
217
217
|
self._rate_limit_update_task = None
|
218
|
+
self._last_stream_progress_update = None
|
218
219
|
|
219
220
|
threading.excepthook = self.thread_exception_hook
|
220
221
|
if self.development_mode is False:
|
@@ -301,7 +302,7 @@ class SyncRequest(ABC):
|
|
301
302
|
self.apply_cancellation()
|
302
303
|
except Exception as e:
|
303
304
|
logger.error(f"Error checking cancellation: {e}")
|
304
|
-
cancellation_token.wait(
|
305
|
+
cancellation_token.wait(20)
|
305
306
|
logger.info("cancel checking worker exiting")
|
306
307
|
|
307
308
|
@abstractmethod
|
@@ -949,16 +950,18 @@ class InboundSyncRequest(SyncRequest):
|
|
949
950
|
|
950
951
|
def apply_progress_updates(self):
|
951
952
|
"""
|
952
|
-
Sends a message to the plugin with the current progress of the sync run.
|
953
|
+
Sends a message to the plugin with the current progress of the sync run, if it has changed since last time.
|
953
954
|
"""
|
954
|
-
|
955
|
-
self._plugin_message(
|
956
|
-
message=PluginMessageStreamProgressUpdate(
|
955
|
+
new_progress_update = PluginMessageStreamProgressUpdate(
|
957
956
|
stream_total_counts=self._stream_record_counts,
|
958
957
|
completed_streams=self._completed_streams,
|
959
958
|
stream_errors=self._omnata_log_handler.stream_global_errors
|
960
959
|
)
|
961
|
-
|
960
|
+
if self._last_stream_progress_update is None or new_progress_update != self._last_stream_progress_update:
|
961
|
+
self._plugin_message(
|
962
|
+
message=new_progress_update
|
963
|
+
)
|
964
|
+
self._last_stream_progress_update = new_progress_update
|
962
965
|
|
963
966
|
def apply_cancellation(self):
|
964
967
|
"""
|
@@ -1223,8 +1226,6 @@ class InboundSyncRequest(SyncRequest):
|
|
1223
1226
|
raise ValueError(
|
1224
1227
|
f"Primary key field '{primary_key_field}' was not present in all records for stream {stream_name}"
|
1225
1228
|
)
|
1226
|
-
# TODO: handle the scenario where the primary key field is a list, and concatenate the values to form the APP_IDENTIFIER
|
1227
|
-
# Currently this is only implemented in the java runtime, since it's typically databases that use composite keys
|
1228
1229
|
results_df["APP_IDENTIFIER"] = results_df["RECORD_DATA"].apply(lambda x: get_nested_value(dict(x),primary_key_field))
|
1229
1230
|
# ensure APP_IDENTIFIER is a string
|
1230
1231
|
results_df["APP_IDENTIFIER"] = results_df["APP_IDENTIFIER"].apply(str)
|
File without changes
|
File without changes
|
File without changes
|
{omnata_plugin_runtime-0.3.24a73 → omnata_plugin_runtime-0.3.24a74}/src/omnata_plugin_runtime/api.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|