omnata-plugin-runtime 0.4.8__py3-none-any.whl → 0.4.9__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- omnata_plugin_runtime/omnata_plugin.py +6 -3
- omnata_plugin_runtime/rate_limiting.py +28 -2
- {omnata_plugin_runtime-0.4.8.dist-info → omnata_plugin_runtime-0.4.9.dist-info}/METADATA +1 -1
- {omnata_plugin_runtime-0.4.8.dist-info → omnata_plugin_runtime-0.4.9.dist-info}/RECORD +6 -6
- {omnata_plugin_runtime-0.4.8.dist-info → omnata_plugin_runtime-0.4.9.dist-info}/LICENSE +0 -0
- {omnata_plugin_runtime-0.4.8.dist-info → omnata_plugin_runtime-0.4.9.dist-info}/WHEEL +0 -0
@@ -257,7 +257,8 @@ class SyncRequest(ABC):
|
|
257
257
|
def get_ratelimit_retrying_http_session(self,
|
258
258
|
max_retries: int = 5,
|
259
259
|
backoff_factor: int = 1,
|
260
|
-
statuses_to_include: List[int] = [429]
|
260
|
+
statuses_to_include: List[int] = [429],
|
261
|
+
response_time_warning_threshold_ms:Optional[int] = None
|
261
262
|
):
|
262
263
|
"""
|
263
264
|
Returns a requests.Session object which can respond to 429 responses by waiting and retrying.
|
@@ -272,14 +273,16 @@ class SyncRequest(ABC):
|
|
272
273
|
max_retries=max_retries,
|
273
274
|
backoff_factor=0,
|
274
275
|
statuses_to_include=statuses_to_include,
|
275
|
-
respect_retry_after_header=False
|
276
|
+
respect_retry_after_header=False,
|
277
|
+
response_time_warning_threshold_ms=response_time_warning_threshold_ms
|
276
278
|
)
|
277
279
|
return RateLimitedSession(
|
278
280
|
run_deadline=self._run_deadline,
|
279
281
|
thread_cancellation_token=self._thread_cancellation_token,
|
280
282
|
max_retries=max_retries,
|
281
283
|
backoff_factor=backoff_factor,
|
282
|
-
statuses_to_include=statuses_to_include
|
284
|
+
statuses_to_include=statuses_to_include,
|
285
|
+
response_time_warning_threshold_ms=response_time_warning_threshold_ms
|
283
286
|
)
|
284
287
|
|
285
288
|
|
@@ -11,6 +11,7 @@ from logging import getLogger
|
|
11
11
|
from typing import Any, List, Literal, Optional, Dict, Tuple
|
12
12
|
import requests
|
13
13
|
import time
|
14
|
+
import logging
|
14
15
|
from pydantic import Field, root_validator
|
15
16
|
from pydantic.json import pydantic_encoder
|
16
17
|
from .configuration import SubscriptableBaseModel
|
@@ -386,6 +387,27 @@ class RetryWithLogging(Retry):
|
|
386
387
|
if self.thread_cancellation_token.wait(backoff):
|
387
388
|
raise InterruptedWhileWaitingException(message="The sync was interrupted while waiting for rate limiting to expire")
|
388
389
|
|
390
|
+
class LongRequestLoggingAdapter(HTTPAdapter):
|
391
|
+
"""
|
392
|
+
An adapter which wraps HTTPAdapter, and logs a warning if a request takes longer than a specified threshold
|
393
|
+
"""
|
394
|
+
def __init__(self,
|
395
|
+
threshold_ms:int,
|
396
|
+
log_level=logging.WARNING,
|
397
|
+
**kwargs):
|
398
|
+
super().__init__(**kwargs)
|
399
|
+
self.threshold_ms = threshold_ms
|
400
|
+
self.logger = logging.getLogger(__name__)
|
401
|
+
self.log_level = log_level
|
402
|
+
|
403
|
+
def send(self, request, *args, **kwargs):
|
404
|
+
start_time = time.time()
|
405
|
+
response = super().send(request, *args, **kwargs)
|
406
|
+
elapsed_time = (time.time() - start_time) * 1000 # Convert to milliseconds
|
407
|
+
if elapsed_time > self.threshold_ms:
|
408
|
+
self.logger.log(self.log_level, f"Request exceeded response time threshold of {self.threshold_ms}ms, taking {elapsed_time:.2f}ms to respond. URL: {request.url}")
|
409
|
+
return response
|
410
|
+
|
389
411
|
|
390
412
|
class RateLimitedSession(requests.Session):
|
391
413
|
"""
|
@@ -400,7 +422,8 @@ class RateLimitedSession(requests.Session):
|
|
400
422
|
max_retries=5,
|
401
423
|
backoff_factor=1,
|
402
424
|
statuses_to_include:List[int] = [429],
|
403
|
-
respect_retry_after_header:bool = True
|
425
|
+
respect_retry_after_header:bool = True,
|
426
|
+
response_time_warning_threshold_ms:Optional[int] = None):
|
404
427
|
super().__init__()
|
405
428
|
self.max_retries = max_retries
|
406
429
|
self.backoff_factor = backoff_factor
|
@@ -418,7 +441,10 @@ class RateLimitedSession(requests.Session):
|
|
418
441
|
respect_retry_after_header=respect_retry_after_header
|
419
442
|
)
|
420
443
|
retry_strategy.thread_cancellation_token = thread_cancellation_token
|
421
|
-
|
444
|
+
if response_time_warning_threshold_ms is not None:
|
445
|
+
adapter = LongRequestLoggingAdapter(max_retries=retry_strategy, threshold_ms=response_time_warning_threshold_ms)
|
446
|
+
else:
|
447
|
+
adapter = HTTPAdapter(max_retries=retry_strategy)
|
422
448
|
self.mount("https://", adapter)
|
423
449
|
self.mount("http://", adapter)
|
424
450
|
|
@@ -3,10 +3,10 @@ omnata_plugin_runtime/api.py,sha256=W79CsAcl127Dzy-XVS9CzvzsbS3IigVH4QAhFFDkaXg,
|
|
3
3
|
omnata_plugin_runtime/configuration.py,sha256=7cMekoY8CeZAJHpASU6tCMidF55Hzfr7CD74jtebqIY,35742
|
4
4
|
omnata_plugin_runtime/forms.py,sha256=pw_aKVsXSz47EP8PFBI3VDwdSN5IjvZxp8JTjO1V130,18421
|
5
5
|
omnata_plugin_runtime/logging.py,sha256=bn7eKoNWvtuyTk7RTwBS9UARMtqkiICtgMtzq3KA2V0,3272
|
6
|
-
omnata_plugin_runtime/omnata_plugin.py,sha256=
|
6
|
+
omnata_plugin_runtime/omnata_plugin.py,sha256=QyqrEgdJcMqd5UtcnQyFlencqVExq3EqydVudQmI7aM,110348
|
7
7
|
omnata_plugin_runtime/plugin_entrypoints.py,sha256=JAGEdVcy9QEXv7TO5zt7co64LTP8nqGusOc0sJG9GtU,29149
|
8
|
-
omnata_plugin_runtime/rate_limiting.py,sha256=
|
9
|
-
omnata_plugin_runtime-0.4.
|
10
|
-
omnata_plugin_runtime-0.4.
|
11
|
-
omnata_plugin_runtime-0.4.
|
12
|
-
omnata_plugin_runtime-0.4.
|
8
|
+
omnata_plugin_runtime/rate_limiting.py,sha256=BOxyjERDG46iPY7coYu79jdZ9JqHMYPG-BNyXYOIJmk,24678
|
9
|
+
omnata_plugin_runtime-0.4.9.dist-info/LICENSE,sha256=IMF9i4xIpgCADf0U-V1cuf9HBmqWQd3qtI3FSuyW4zE,26526
|
10
|
+
omnata_plugin_runtime-0.4.9.dist-info/METADATA,sha256=FhKPxXu7iq2r_lvANyJiRAsp7K7HRcKugudOPIyeDU4,1638
|
11
|
+
omnata_plugin_runtime-0.4.9.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
|
12
|
+
omnata_plugin_runtime-0.4.9.dist-info/RECORD,,
|
File without changes
|
File without changes
|