ob-metaflow-extensions 1.1.147__tar.gz → 1.1.149__tar.gz

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 ob-metaflow-extensions might be problematic. Click here for more details.

Files changed (73) hide show
  1. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/PKG-INFO +1 -1
  2. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/secrets/secrets.py +38 -2
  3. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/snowflake/snowflake.py +44 -4
  4. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/ob_metaflow_extensions.egg-info/PKG-INFO +1 -1
  5. ob-metaflow-extensions-1.1.149/ob_metaflow_extensions.egg-info/requires.txt +3 -0
  6. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/setup.py +2 -2
  7. ob-metaflow-extensions-1.1.147/ob_metaflow_extensions.egg-info/requires.txt +0 -3
  8. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/README.md +0 -0
  9. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/__init__.py +0 -0
  10. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/config/__init__.py +0 -0
  11. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/__init__.py +0 -0
  12. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/apps/__init__.py +0 -0
  13. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/apps/app_utils.py +0 -0
  14. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/apps/consts.py +0 -0
  15. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/apps/deploy_decorator.py +0 -0
  16. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/apps/supervisord_utils.py +0 -0
  17. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/auth_server.py +0 -0
  18. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/card_utilities/__init__.py +0 -0
  19. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/card_utilities/async_cards.py +0 -0
  20. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/card_utilities/extra_components.py +0 -0
  21. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/card_utilities/injector.py +0 -0
  22. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/checkpoint_datastores/__init__.py +0 -0
  23. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/checkpoint_datastores/coreweave.py +0 -0
  24. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/checkpoint_datastores/nebius.py +0 -0
  25. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/fast_bakery/__init__.py +0 -0
  26. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/fast_bakery/docker_environment.py +0 -0
  27. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/fast_bakery/fast_bakery.py +0 -0
  28. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/fast_bakery/fast_bakery_cli.py +0 -0
  29. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/fast_bakery/fast_bakery_decorator.py +0 -0
  30. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/kubernetes/__init__.py +0 -0
  31. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/kubernetes/kubernetes_client.py +0 -0
  32. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/nim/__init__.py +0 -0
  33. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/nim/card.py +0 -0
  34. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/nim/nim_manager.py +0 -0
  35. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/nim/utilities.py +0 -0
  36. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/nvcf/__init__.py +0 -0
  37. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/nvcf/constants.py +0 -0
  38. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/nvcf/exceptions.py +0 -0
  39. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/nvcf/heartbeat_store.py +0 -0
  40. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/nvcf/nvcf.py +0 -0
  41. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/nvcf/nvcf_cli.py +0 -0
  42. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/nvcf/nvcf_decorator.py +0 -0
  43. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/nvcf/utils.py +0 -0
  44. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/ollama/__init__.py +0 -0
  45. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/ollama/ollama.py +0 -0
  46. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/perimeters.py +0 -0
  47. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/profilers/deco_injector.py +0 -0
  48. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/profilers/gpu_profile_decorator.py +0 -0
  49. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/secrets/__init__.py +0 -0
  50. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/snowflake/__init__.py +0 -0
  51. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/snowpark/__init__.py +0 -0
  52. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark.py +0 -0
  53. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark_cli.py +0 -0
  54. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark_client.py +0 -0
  55. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark_decorator.py +0 -0
  56. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark_exceptions.py +0 -0
  57. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark_job.py +0 -0
  58. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark_service_spec.py +0 -0
  59. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/plugins/tensorboard/__init__.py +0 -0
  60. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/profilers/__init__.py +0 -0
  61. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/profilers/gpu.py +0 -0
  62. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/remote_config.py +0 -0
  63. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/toplevel/__init__.py +0 -0
  64. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/toplevel/global_aliases_for_metaflow_package.py +0 -0
  65. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/toplevel/plugins/azure/__init__.py +0 -0
  66. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/toplevel/plugins/gcp/__init__.py +0 -0
  67. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/toplevel/plugins/kubernetes/__init__.py +0 -0
  68. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/toplevel/plugins/ollama/__init__.py +0 -0
  69. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/metaflow_extensions/outerbounds/toplevel/plugins/snowflake/__init__.py +0 -0
  70. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/ob_metaflow_extensions.egg-info/SOURCES.txt +0 -0
  71. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/ob_metaflow_extensions.egg-info/dependency_links.txt +0 -0
  72. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/ob_metaflow_extensions.egg-info/top_level.txt +0 -0
  73. {ob-metaflow-extensions-1.1.147 → ob-metaflow-extensions-1.1.149}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: ob-metaflow-extensions
3
- Version: 1.1.147
3
+ Version: 1.1.149
4
4
  Summary: Outerbounds Platform Extensions for Metaflow
5
5
  Author: Outerbounds, Inc.
6
6
  License: Commercial
@@ -4,13 +4,48 @@ from typing import Dict
4
4
  import base64
5
5
  import json
6
6
  import requests
7
+ import random
7
8
  import time
9
+ import sys
8
10
 
9
11
 
10
12
  class OuterboundsSecretsException(Exception):
11
13
  pass
12
14
 
13
15
 
16
+ def _api_server_get(*args, conn_error_retries=2, **kwargs):
17
+ """
18
+ There are two categories of errors that we need to handle when dealing with any API server.
19
+ 1. HTTP errors. These are are errors that are returned from the API server.
20
+ - How to handle retries for this case will be application specific.
21
+ 2. Errors when the API server may not be reachable (DNS resolution / network issues)
22
+ - In this scenario, we know that something external to the API server is going wrong causing the issue.
23
+ - Failing pre-maturely in the case might not be the best course of action since critical user jobs might crash on intermittent issues.
24
+ - So in this case, we can just planely retry the request.
25
+
26
+ This function handles the second case. It's a simple wrapper to handle the retry logic for connection errors.
27
+ If this function is provided a `conn_error_retries` of 5, then the last retry will have waited 32 seconds.
28
+ Generally this is a safe enough number of retries after which we can assume that something is really broken. Until then,
29
+ there can be intermittent issues that would resolve themselves if we retry gracefully.
30
+ """
31
+ _num_retries = 0
32
+ noise = random.uniform(-0.5, 0.5)
33
+ while _num_retries < conn_error_retries:
34
+ try:
35
+ return requests.get(*args, **kwargs)
36
+ except requests.exceptions.ConnectionError:
37
+ if _num_retries <= conn_error_retries - 1:
38
+ # Exponential backoff with 2^(_num_retries+1) seconds
39
+ time.sleep((2 ** (_num_retries + 1)) + noise)
40
+ _num_retries += 1
41
+ else:
42
+ print(
43
+ "[@secrets] Failed to connect to the API server. ",
44
+ file=sys.stderr,
45
+ )
46
+ raise
47
+
48
+
14
49
  class OuterboundsSecretsApiResponse:
15
50
  def __init__(self, response):
16
51
  self.response = response
@@ -133,7 +168,9 @@ class OuterboundsSecretsProvider(SecretsProvider):
133
168
  retryable_status_codes = [409]
134
169
  json_payload = json.dumps(payload)
135
170
  for attempt in range(2): # 0 = initial attempt, 1-2 = retries
136
- response = requests.get(url, data=json_payload, headers=request_headers)
171
+ response = _api_server_get(
172
+ url, data=json_payload, headers=request_headers, conn_error_retries=5
173
+ )
137
174
  if response.status_code not in retryable_status_codes:
138
175
  break
139
176
 
@@ -141,7 +178,6 @@ class OuterboundsSecretsProvider(SecretsProvider):
141
178
  sleep_time = 0.5 * (attempt + 1)
142
179
  time.sleep(sleep_time)
143
180
 
144
- response = requests.get(url, data=json_payload, headers=request_headers)
145
181
  self._handle_error_response(response)
146
182
  return OuterboundsSecretsApiResponse(response.json())
147
183
 
@@ -7,9 +7,10 @@ from metaflow.metaflow_config import SERVICE_URL
7
7
  from metaflow.metaflow_config_funcs import init_config
8
8
  from typing import Dict
9
9
  from os import environ
10
-
10
+ import sys
11
11
  import json
12
12
  import requests
13
+ import random
13
14
  import time
14
15
 
15
16
 
@@ -75,7 +76,9 @@ def get_snowflake_token(user: str = "", role: str = "", integration: str = "") -
75
76
  }
76
77
  json_payload = json.dumps(payload)
77
78
  headers = provisioner.get_service_auth_header()
78
- response = requests.get(snowflake_token_url, data=json_payload, headers=headers)
79
+ response = _api_server_get(
80
+ snowflake_token_url, data=json_payload, headers=headers, conn_error_retries=5
81
+ )
79
82
  response.raise_for_status()
80
83
  return response.json()["token"]
81
84
 
@@ -150,6 +153,39 @@ def connect(user: str = "", role: str = "", integration: str = "", **kwargs):
150
153
  )
151
154
 
152
155
 
156
+ def _api_server_get(*args, conn_error_retries=2, **kwargs):
157
+ """
158
+ There are two categories of errors that we need to handle when dealing with any API server.
159
+ 1. HTTP errors. These are are errors that are returned from the API server.
160
+ - How to handle retries for this case will be application specific.
161
+ 2. Errors when the API server may not be reachable (DNS resolution / network issues)
162
+ - In this scenario, we know that something external to the API server is going wrong causing the issue.
163
+ - Failing pre-maturely in the case might not be the best course of action since critical user jobs might crash on intermittent issues.
164
+ - So in this case, we can just planely retry the request.
165
+
166
+ This function handles the second case. It's a simple wrapper to handle the retry logic for connection errors.
167
+ If this function is provided a `conn_error_retries` of 5, then the last retry will have waited 32 seconds.
168
+ Generally this is a safe enough number of retries after which we can assume that something is really broken. Until then,
169
+ there can be intermittent issues that would resolve themselves if we retry gracefully.
170
+ """
171
+ _num_retries = 0
172
+ noise = random.uniform(-0.5, 0.5)
173
+ while _num_retries < conn_error_retries:
174
+ try:
175
+ return requests.get(*args, **kwargs)
176
+ except requests.exceptions.ConnectionError:
177
+ if _num_retries <= conn_error_retries - 1:
178
+ # Exponential backoff with 2^(_num_retries+1) seconds
179
+ time.sleep((2 ** (_num_retries + 1)) + noise)
180
+ _num_retries += 1
181
+ else:
182
+ print(
183
+ "[@snowflake] Failed to connect to the API server. ",
184
+ file=sys.stderr,
185
+ )
186
+ raise
187
+
188
+
153
189
  class Snowflake:
154
190
  def __init__(
155
191
  self, user: str = "", role: str = "", integration: str = "", **kwargs
@@ -273,7 +309,9 @@ class SnowflakeIntegrationProvisioner:
273
309
  retryable_status_codes = [409]
274
310
  json_payload = json.dumps(payload)
275
311
  for attempt in range(2): # 0 = initial attempt, 1-2 = retries
276
- response = requests.get(url, data=json_payload, headers=request_headers)
312
+ response = _api_server_get(
313
+ url, data=json_payload, headers=request_headers, conn_error_retries=5
314
+ )
277
315
  if response.status_code not in retryable_status_codes:
278
316
  break
279
317
 
@@ -281,7 +319,9 @@ class SnowflakeIntegrationProvisioner:
281
319
  sleep_time = 0.5 * (attempt + 1)
282
320
  time.sleep(sleep_time)
283
321
 
284
- response = requests.get(url, data=json_payload, headers=request_headers)
322
+ response = _api_server_get(
323
+ url, data=json_payload, headers=request_headers, conn_error_retries=5
324
+ )
285
325
  self._handle_error_response(response)
286
326
  return response.json()
287
327
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: ob-metaflow-extensions
3
- Version: 1.1.147
3
+ Version: 1.1.149
4
4
  Summary: Outerbounds Platform Extensions for Metaflow
5
5
  Author: Outerbounds, Inc.
6
6
  License: Commercial
@@ -0,0 +1,3 @@
1
+ boto3
2
+ kubernetes
3
+ ob-metaflow==2.15.10.1
@@ -2,7 +2,7 @@ from setuptools import setup, find_namespace_packages
2
2
  from pathlib import Path
3
3
 
4
4
 
5
- version = "1.1.147"
5
+ version = "1.1.149"
6
6
  this_directory = Path(__file__).parent
7
7
  long_description = (this_directory / "README.md").read_text()
8
8
 
@@ -18,6 +18,6 @@ setup(
18
18
  install_requires=[
19
19
  "boto3",
20
20
  "kubernetes",
21
- "ob-metaflow == 2.15.7.2",
21
+ "ob-metaflow == 2.15.10.1",
22
22
  ],
23
23
  )
@@ -1,3 +0,0 @@
1
- boto3
2
- kubernetes
3
- ob-metaflow==2.15.7.2