ob-metaflow-extensions 1.2.8__tar.gz → 1.2.9rc0__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.
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/PKG-INFO +1 -1
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/aws/assume_role_decorator.py +25 -12
- ob_metaflow_extensions-1.2.9rc0/metaflow_extensions/outerbounds/plugins/checkpoint_datastores/coreweave.py +70 -0
- ob_metaflow_extensions-1.2.9rc0/metaflow_extensions/outerbounds/plugins/checkpoint_datastores/external_chckpt.py +85 -0
- ob_metaflow_extensions-1.2.9rc0/metaflow_extensions/outerbounds/plugins/checkpoint_datastores/nebius.py +73 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/fast_bakery/docker_environment.py +6 -2
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/ob_metaflow_extensions.egg-info/PKG-INFO +1 -1
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/ob_metaflow_extensions.egg-info/SOURCES.txt +1 -0
- ob_metaflow_extensions-1.2.9rc0/ob_metaflow_extensions.egg-info/requires.txt +3 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/setup.py +2 -2
- ob_metaflow_extensions-1.2.8/metaflow_extensions/outerbounds/plugins/checkpoint_datastores/coreweave.py +0 -139
- ob_metaflow_extensions-1.2.8/metaflow_extensions/outerbounds/plugins/checkpoint_datastores/nebius.py +0 -144
- ob_metaflow_extensions-1.2.8/ob_metaflow_extensions.egg-info/requires.txt +0 -3
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/MANIFEST.in +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/README.md +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/config/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/app_cli.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/app_deploy_decorator.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/app_utils.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/consts.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/_state_machine.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/_vendor/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/_vendor/spinner/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/_vendor/spinner/spinners.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/app_cli.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/app_config.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/artifacts.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/capsule.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/click_importer.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/code_package/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/code_package/code_packager.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/code_package/examples.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/config/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/config/cli_generator.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/config/config_utils.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/config/schema_export.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/config/typed_configs.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/config/typed_init_generator.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/config/unified_config.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/config_schema.yaml +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/dependencies.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/deployer.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/experimental/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/perimeters.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/secrets.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/utils.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/core/validations.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/deploy_decorator.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/apps/supervisord_utils.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/auth_server.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/aws/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/aws/assume_role.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/card_utilities/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/card_utilities/async_cards.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/card_utilities/extra_components.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/card_utilities/injector.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/checkpoint_datastores/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/fast_bakery/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/fast_bakery/baker.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/fast_bakery/fast_bakery.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/fast_bakery/fast_bakery_cli.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/fast_bakery/fast_bakery_decorator.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/kubernetes/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/kubernetes/kubernetes_client.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/kubernetes/pod_killer.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nim/card.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nim/nim_decorator.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nim/nim_manager.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nim/utils.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvcf/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvcf/constants.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvcf/exceptions.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvcf/heartbeat_store.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvcf/nvcf.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvcf/nvcf_cli.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvcf/nvcf_decorator.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvcf/utils.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvct/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvct/exceptions.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvct/nvct.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvct/nvct_cli.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvct/nvct_decorator.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvct/nvct_runner.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/nvct/utils.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/ollama/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/ollama/constants.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/ollama/exceptions.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/ollama/ollama.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/ollama/status_card.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/perimeters.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/profilers/deco_injector.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/profilers/gpu_profile_decorator.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/profilers/simple_card_decorator.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/secrets/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/secrets/secrets.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/snowflake/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/snowflake/snowflake.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/snowpark/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark_cli.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark_client.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark_decorator.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark_exceptions.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark_job.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/snowpark/snowpark_service_spec.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/tensorboard/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/torchtune/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/vllm/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/vllm/constants.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/vllm/exceptions.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/vllm/status_card.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/plugins/vllm/vllm_manager.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/profilers/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/profilers/gpu.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/remote_config.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/toplevel/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/toplevel/global_aliases_for_metaflow_package.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/toplevel/ob_internal.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/toplevel/plugins/azure/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/toplevel/plugins/gcp/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/toplevel/plugins/kubernetes/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/toplevel/plugins/ollama/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/toplevel/plugins/snowflake/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/toplevel/plugins/torchtune/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/metaflow_extensions/outerbounds/toplevel/plugins/vllm/__init__.py +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/ob_metaflow_extensions.egg-info/dependency_links.txt +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/ob_metaflow_extensions.egg-info/top_level.txt +0 -0
- {ob_metaflow_extensions-1.2.8 → ob_metaflow_extensions-1.2.9rc0}/setup.cfg +0 -0
|
@@ -1,12 +1,10 @@
|
|
|
1
|
-
from metaflow.
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
CustomFlowDecorator,
|
|
5
|
-
)
|
|
1
|
+
from metaflow.user_decorators.mutable_flow import MutableFlow
|
|
2
|
+
from metaflow.user_decorators.mutable_step import MutableStep
|
|
3
|
+
from metaflow.user_decorators.user_flow_decorator import FlowMutator
|
|
6
4
|
from .assume_role import OBP_ASSUME_ROLE_ARN_ENV_VAR
|
|
7
5
|
|
|
8
6
|
|
|
9
|
-
class assume_role(
|
|
7
|
+
class assume_role(FlowMutator):
|
|
10
8
|
"""
|
|
11
9
|
Flow-level decorator for assuming AWS IAM roles.
|
|
12
10
|
|
|
@@ -42,7 +40,7 @@ class assume_role(CustomFlowDecorator):
|
|
|
42
40
|
"`role_arn` must be a valid AWS IAM role ARN starting with 'arn:aws:iam::'"
|
|
43
41
|
)
|
|
44
42
|
|
|
45
|
-
def
|
|
43
|
+
def pre_mutate(self, mutable_flow: MutableFlow) -> None:
|
|
46
44
|
"""
|
|
47
45
|
This method is called by Metaflow to apply the decorator to the flow.
|
|
48
46
|
It sets up environment variables that will be used by the AWS client
|
|
@@ -51,14 +49,29 @@ class assume_role(CustomFlowDecorator):
|
|
|
51
49
|
# Import environment decorator at runtime to avoid circular imports
|
|
52
50
|
from metaflow import environment
|
|
53
51
|
|
|
52
|
+
def _swap_environment_variables(step: MutableStep, role_arn: str) -> None:
|
|
53
|
+
_step_has_env_set = True
|
|
54
|
+
_env_kwargs = {OBP_ASSUME_ROLE_ARN_ENV_VAR: role_arn}
|
|
55
|
+
for d in step.decorator_specs:
|
|
56
|
+
name, _, _, deco_kwargs = d
|
|
57
|
+
if name == "environment":
|
|
58
|
+
_env_kwargs.update(deco_kwargs["vars"])
|
|
59
|
+
_step_has_env_set = True
|
|
60
|
+
|
|
61
|
+
if _step_has_env_set:
|
|
62
|
+
# remove the environment decorator
|
|
63
|
+
step.remove_decorator("environment")
|
|
64
|
+
|
|
65
|
+
# add the environment decorator
|
|
66
|
+
step.add_decorator(
|
|
67
|
+
environment,
|
|
68
|
+
deco_kwargs=dict(vars=_env_kwargs),
|
|
69
|
+
)
|
|
70
|
+
|
|
54
71
|
# Set the role ARN as an environment variable that will be picked up
|
|
55
72
|
# by the get_aws_client function
|
|
56
73
|
def _setup_role_assumption(step: MutableStep) -> None:
|
|
57
|
-
|
|
58
|
-
# The role will be available through an environment variable
|
|
59
|
-
step.add_decorator(
|
|
60
|
-
environment, vars={OBP_ASSUME_ROLE_ARN_ENV_VAR: self.role_arn}
|
|
61
|
-
)
|
|
74
|
+
_swap_environment_variables(step, self.role_arn)
|
|
62
75
|
|
|
63
76
|
# Apply the role assumption setup to all steps in the flow
|
|
64
77
|
for _, step in mutable_flow.steps:
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
from metaflow.user_decorators.user_flow_decorator import FlowMutator
|
|
2
|
+
from metaflow.user_decorators.mutable_flow import MutableFlow
|
|
3
|
+
from metaflow.user_decorators.mutable_step import MutableStep
|
|
4
|
+
from .external_chckpt import _ExternalCheckpointFlowDeco
|
|
5
|
+
import os
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
class coreweave_checkpoints(_ExternalCheckpointFlowDeco):
|
|
9
|
+
|
|
10
|
+
"""
|
|
11
|
+
|
|
12
|
+
This decorator is used for setting the coreweave object store as the artifact store for checkpoints/models created by the flow.
|
|
13
|
+
|
|
14
|
+
Parameters
|
|
15
|
+
----------
|
|
16
|
+
secrets: list
|
|
17
|
+
A list of secrets to be added to the step. These secrets should contain any secrets that are required globally and the secret
|
|
18
|
+
for the coreweave object store. The secret should contain the following keys:
|
|
19
|
+
- COREWEAVE_ACCESS_KEY
|
|
20
|
+
- COREWEAVE_SECRET_KEY
|
|
21
|
+
|
|
22
|
+
bucket_path: str
|
|
23
|
+
The path to the bucket to store the checkpoints/models.
|
|
24
|
+
|
|
25
|
+
Usage
|
|
26
|
+
-----
|
|
27
|
+
```python
|
|
28
|
+
from metaflow import checkpoint, step, FlowSpec, coreweave_checkpoints
|
|
29
|
+
|
|
30
|
+
@coreweave_checkpoints(secrets=[], bucket_path=None)
|
|
31
|
+
class MyFlow(FlowSpec):
|
|
32
|
+
@checkpoint
|
|
33
|
+
@step
|
|
34
|
+
def start(self):
|
|
35
|
+
# Saves the checkpoint in the coreweave object store
|
|
36
|
+
current.checkpoint.save("./foo.txt")
|
|
37
|
+
|
|
38
|
+
@step
|
|
39
|
+
def end(self):
|
|
40
|
+
pass
|
|
41
|
+
```
|
|
42
|
+
"""
|
|
43
|
+
|
|
44
|
+
def __init__(self, *args, **kwargs):
|
|
45
|
+
super().__init__(*args, **kwargs)
|
|
46
|
+
|
|
47
|
+
def init(self, *args, **kwargs):
|
|
48
|
+
super().init(*args, **kwargs)
|
|
49
|
+
self.coreweave_endpoint_url = f"https://cwobject.com"
|
|
50
|
+
|
|
51
|
+
def pre_mutate(self, mutable_flow: MutableFlow) -> None:
|
|
52
|
+
from metaflow import (
|
|
53
|
+
with_artifact_store,
|
|
54
|
+
)
|
|
55
|
+
|
|
56
|
+
def _coreweave_config():
|
|
57
|
+
return {
|
|
58
|
+
"root": self.bucket_path,
|
|
59
|
+
"client_params": {
|
|
60
|
+
"aws_access_key_id": os.environ.get("COREWEAVE_ACCESS_KEY"),
|
|
61
|
+
"aws_secret_access_key": os.environ.get("COREWEAVE_SECRET_KEY"),
|
|
62
|
+
"endpoint_url": self.coreweave_endpoint_url,
|
|
63
|
+
"config": dict(s3={"addressing_style": "virtual"}),
|
|
64
|
+
},
|
|
65
|
+
}
|
|
66
|
+
mutable_flow.add_decorator(
|
|
67
|
+
with_artifact_store,
|
|
68
|
+
deco_kwargs=dict(type="coreweave", config=_coreweave_config),
|
|
69
|
+
)
|
|
70
|
+
self._swap_secrets(mutable_flow)
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
from metaflow.user_decorators.user_flow_decorator import FlowMutator
|
|
2
|
+
from metaflow.user_decorators.mutable_flow import MutableFlow
|
|
3
|
+
from metaflow.user_decorators.mutable_step import MutableStep
|
|
4
|
+
import os
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
class _ExternalCheckpointFlowDeco(FlowMutator):
|
|
8
|
+
def init(self, *args, **kwargs):
|
|
9
|
+
self.bucket_path = kwargs.get("bucket_path", None)
|
|
10
|
+
|
|
11
|
+
self.secrets = kwargs.get("secrets", [])
|
|
12
|
+
if self.bucket_path is None:
|
|
13
|
+
raise ValueError(
|
|
14
|
+
"`bucket_path` keyword argument is required for the coreweave_datastore"
|
|
15
|
+
)
|
|
16
|
+
if not self.bucket_path.startswith("s3://"):
|
|
17
|
+
raise ValueError(
|
|
18
|
+
"`bucket_path` must start with `s3://` for the coreweave_datastore"
|
|
19
|
+
)
|
|
20
|
+
if self.secrets is None:
|
|
21
|
+
raise ValueError(
|
|
22
|
+
"`secrets` keyword argument is required for the coreweave_datastore"
|
|
23
|
+
)
|
|
24
|
+
|
|
25
|
+
def _swap_secrets(self, mutable_flow: MutableFlow) -> None:
|
|
26
|
+
from metaflow import (
|
|
27
|
+
checkpoint,
|
|
28
|
+
model,
|
|
29
|
+
huggingface_hub,
|
|
30
|
+
secrets,
|
|
31
|
+
with_artifact_store,
|
|
32
|
+
)
|
|
33
|
+
|
|
34
|
+
def _add_secrets(step: MutableStep) -> None:
|
|
35
|
+
decos_to_add = []
|
|
36
|
+
swapping_decos = {
|
|
37
|
+
"huggingface_hub": huggingface_hub,
|
|
38
|
+
"model": model,
|
|
39
|
+
"checkpoint": checkpoint,
|
|
40
|
+
}
|
|
41
|
+
already_has_secrets = False
|
|
42
|
+
secrets_present_in_deco = []
|
|
43
|
+
for d in step.decorator_specs:
|
|
44
|
+
name, _, _, deco_kwargs = d
|
|
45
|
+
if name in swapping_decos:
|
|
46
|
+
decos_to_add.append((name, deco_kwargs))
|
|
47
|
+
elif name == "secrets":
|
|
48
|
+
already_has_secrets = True
|
|
49
|
+
secrets_present_in_deco.extend(deco_kwargs["sources"])
|
|
50
|
+
|
|
51
|
+
# If the step aleady has secrets then take all the sources in
|
|
52
|
+
# the secrets and add the addtional secrets to the existing secrets
|
|
53
|
+
secrets_to_add = self.secrets
|
|
54
|
+
if already_has_secrets:
|
|
55
|
+
secrets_to_add.extend(secrets_present_in_deco)
|
|
56
|
+
|
|
57
|
+
secrets_to_add = list(set(secrets_to_add))
|
|
58
|
+
|
|
59
|
+
if len(decos_to_add) == 0:
|
|
60
|
+
if already_has_secrets:
|
|
61
|
+
step.remove_decorator("secrets")
|
|
62
|
+
|
|
63
|
+
step.add_decorator(
|
|
64
|
+
secrets,
|
|
65
|
+
deco_kwargs=dict(
|
|
66
|
+
sources=secrets_to_add,
|
|
67
|
+
),
|
|
68
|
+
)
|
|
69
|
+
return
|
|
70
|
+
|
|
71
|
+
for d, _ in decos_to_add:
|
|
72
|
+
step.remove_decorator(d)
|
|
73
|
+
|
|
74
|
+
step.add_decorator(
|
|
75
|
+
secrets,
|
|
76
|
+
deco_kwargs=dict(
|
|
77
|
+
sources=secrets_to_add,
|
|
78
|
+
),
|
|
79
|
+
)
|
|
80
|
+
for d, attrs in decos_to_add:
|
|
81
|
+
_deco_to_add = swapping_decos[d]
|
|
82
|
+
step.add_decorator(_deco_to_add, deco_kwargs=attrs)
|
|
83
|
+
|
|
84
|
+
for step_name, step in mutable_flow.steps:
|
|
85
|
+
_add_secrets(step)
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
from metaflow.user_decorators.mutable_flow import MutableFlow
|
|
2
|
+
from .external_chckpt import _ExternalCheckpointFlowDeco
|
|
3
|
+
import os
|
|
4
|
+
|
|
5
|
+
NEBIUS_ENDPOINT_URL = "https://storage.eu-north1.nebius.cloud:443"
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
class nebius_checkpoints(_ExternalCheckpointFlowDeco):
|
|
9
|
+
|
|
10
|
+
"""
|
|
11
|
+
|
|
12
|
+
This decorator is used for setting the nebius's S3 compatible object store as the artifact store for
|
|
13
|
+
checkpoints/models created by the flow.
|
|
14
|
+
|
|
15
|
+
Parameters
|
|
16
|
+
----------
|
|
17
|
+
secrets: list
|
|
18
|
+
A list of secrets to be added to the step. These secrets should contain any secrets that are required globally and the secret
|
|
19
|
+
for the nebius object store. The secret should contain the following keys:
|
|
20
|
+
- NEBIUS_ACCESS_KEY
|
|
21
|
+
- NEBIUS_SECRET_KEY
|
|
22
|
+
|
|
23
|
+
bucket_path: str
|
|
24
|
+
The path to the bucket to store the checkpoints/models.
|
|
25
|
+
|
|
26
|
+
endpoint_url: str
|
|
27
|
+
The endpoint url for the nebius object store. Defaults to `https://storage.eu-north1.nebius.cloud:443`
|
|
28
|
+
|
|
29
|
+
Usage
|
|
30
|
+
-----
|
|
31
|
+
```python
|
|
32
|
+
from metaflow import checkpoint, step, FlowSpec, nebius_checkpoints
|
|
33
|
+
|
|
34
|
+
@nebius_checkpoints(secrets=[], bucket_path=None)
|
|
35
|
+
class MyFlow(FlowSpec):
|
|
36
|
+
@checkpoint
|
|
37
|
+
@step
|
|
38
|
+
def start(self):
|
|
39
|
+
# Saves the checkpoint in the nebius object store
|
|
40
|
+
current.checkpoint.save("./foo.txt")
|
|
41
|
+
|
|
42
|
+
@step
|
|
43
|
+
def end(self):
|
|
44
|
+
pass
|
|
45
|
+
```
|
|
46
|
+
"""
|
|
47
|
+
|
|
48
|
+
def __init__(self, *args, **kwargs):
|
|
49
|
+
super().__init__(*args, **kwargs)
|
|
50
|
+
|
|
51
|
+
def init(self, *args, **kwargs):
|
|
52
|
+
super().init(*args, **kwargs)
|
|
53
|
+
self.nebius_endpoint_url = kwargs.get("endpoint_url", NEBIUS_ENDPOINT_URL)
|
|
54
|
+
|
|
55
|
+
def pre_mutate(self, mutable_flow: MutableFlow) -> None:
|
|
56
|
+
from metaflow import (
|
|
57
|
+
with_artifact_store,
|
|
58
|
+
)
|
|
59
|
+
|
|
60
|
+
def _nebius_config():
|
|
61
|
+
return {
|
|
62
|
+
"root": self.bucket_path,
|
|
63
|
+
"client_params": {
|
|
64
|
+
"aws_access_key_id": os.environ.get("NEBIUS_ACCESS_KEY"),
|
|
65
|
+
"aws_secret_access_key": os.environ.get("NEBIUS_SECRET_KEY"),
|
|
66
|
+
"endpoint_url": self.nebius_endpoint_url,
|
|
67
|
+
},
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
mutable_flow.add_decorator(
|
|
71
|
+
with_artifact_store, deco_kwargs=dict(type="s3", config=_nebius_config)
|
|
72
|
+
)
|
|
73
|
+
self._swap_secrets(mutable_flow)
|
|
@@ -351,12 +351,16 @@ class DockerEnvironment(MetaflowEnvironment):
|
|
|
351
351
|
config.append("--disable=F0401")
|
|
352
352
|
return config
|
|
353
353
|
|
|
354
|
-
def get_package_commands(
|
|
354
|
+
def get_package_commands(
|
|
355
|
+
self, codepackage_url, datastore_type, code_package_metadata=None
|
|
356
|
+
):
|
|
355
357
|
# we must set the skip install flag at this stage in order to skip package downloads,
|
|
356
358
|
# doing so in bootstrap_commands is too late in the lifecycle.
|
|
357
359
|
return [
|
|
358
360
|
"export METAFLOW_SKIP_INSTALL_DEPENDENCIES=$FASTBAKERY_IMAGE",
|
|
359
|
-
] + super().get_package_commands(
|
|
361
|
+
] + super().get_package_commands(
|
|
362
|
+
codepackage_url, datastore_type, code_package_metadata=code_package_metadata
|
|
363
|
+
)
|
|
360
364
|
|
|
361
365
|
def bootstrap_commands(self, step_name, datastore_type):
|
|
362
366
|
if step_name in self.skipped_steps:
|
|
@@ -51,6 +51,7 @@ metaflow_extensions/outerbounds/plugins/card_utilities/extra_components.py
|
|
|
51
51
|
metaflow_extensions/outerbounds/plugins/card_utilities/injector.py
|
|
52
52
|
metaflow_extensions/outerbounds/plugins/checkpoint_datastores/__init__.py
|
|
53
53
|
metaflow_extensions/outerbounds/plugins/checkpoint_datastores/coreweave.py
|
|
54
|
+
metaflow_extensions/outerbounds/plugins/checkpoint_datastores/external_chckpt.py
|
|
54
55
|
metaflow_extensions/outerbounds/plugins/checkpoint_datastores/nebius.py
|
|
55
56
|
metaflow_extensions/outerbounds/plugins/fast_bakery/__init__.py
|
|
56
57
|
metaflow_extensions/outerbounds/plugins/fast_bakery/baker.py
|
|
@@ -2,7 +2,7 @@ from setuptools import setup, find_namespace_packages
|
|
|
2
2
|
from pathlib import Path
|
|
3
3
|
|
|
4
4
|
|
|
5
|
-
version = "1.2.
|
|
5
|
+
version = "1.2.9rc0"
|
|
6
6
|
this_directory = Path(__file__).parent
|
|
7
7
|
long_description = (this_directory / "README.md").read_text()
|
|
8
8
|
|
|
@@ -19,6 +19,6 @@ setup(
|
|
|
19
19
|
install_requires=[
|
|
20
20
|
"boto3",
|
|
21
21
|
"kubernetes",
|
|
22
|
-
"ob-metaflow == 2.
|
|
22
|
+
"ob-metaflow == 2.16.6.5",
|
|
23
23
|
],
|
|
24
24
|
)
|
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
from metaflow.user_configs.config_decorators import (
|
|
2
|
-
MutableFlow,
|
|
3
|
-
MutableStep,
|
|
4
|
-
CustomFlowDecorator,
|
|
5
|
-
)
|
|
6
|
-
import os
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
class coreweave_checkpoints(CustomFlowDecorator):
|
|
10
|
-
|
|
11
|
-
"""
|
|
12
|
-
|
|
13
|
-
This decorator is used for setting the coreweave object store as the artifact store for checkpoints/models created by the flow.
|
|
14
|
-
|
|
15
|
-
Parameters
|
|
16
|
-
----------
|
|
17
|
-
secrets: list
|
|
18
|
-
A list of secrets to be added to the step. These secrets should contain any secrets that are required globally and the secret
|
|
19
|
-
for the coreweave object store. The secret should contain the following keys:
|
|
20
|
-
- COREWEAVE_ACCESS_KEY
|
|
21
|
-
- COREWEAVE_SECRET_KEY
|
|
22
|
-
|
|
23
|
-
bucket_path: str
|
|
24
|
-
The path to the bucket to store the checkpoints/models.
|
|
25
|
-
|
|
26
|
-
Usage
|
|
27
|
-
-----
|
|
28
|
-
```python
|
|
29
|
-
from metaflow import checkpoint, step, FlowSpec, coreweave_checkpoints
|
|
30
|
-
|
|
31
|
-
@coreweave_checkpoints(secrets=[], bucket_path=None)
|
|
32
|
-
class MyFlow(FlowSpec):
|
|
33
|
-
@checkpoint
|
|
34
|
-
@step
|
|
35
|
-
def start(self):
|
|
36
|
-
# Saves the checkpoint in the coreweave object store
|
|
37
|
-
current.checkpoint.save("./foo.txt")
|
|
38
|
-
|
|
39
|
-
@step
|
|
40
|
-
def end(self):
|
|
41
|
-
pass
|
|
42
|
-
```
|
|
43
|
-
"""
|
|
44
|
-
|
|
45
|
-
def __init__(self, *args, **kwargs):
|
|
46
|
-
super().__init__(*args, **kwargs)
|
|
47
|
-
|
|
48
|
-
def init(self, *args, **kwargs):
|
|
49
|
-
self.bucket_path = kwargs.get("bucket_path", None)
|
|
50
|
-
|
|
51
|
-
self.secrets = kwargs.get("secrets", [])
|
|
52
|
-
if self.bucket_path is None:
|
|
53
|
-
raise ValueError(
|
|
54
|
-
"`bucket_path` keyword argument is required for the coreweave_datastore"
|
|
55
|
-
)
|
|
56
|
-
if not self.bucket_path.startswith("s3://"):
|
|
57
|
-
raise ValueError(
|
|
58
|
-
"`bucket_path` must start with `s3://` for the coreweave_datastore"
|
|
59
|
-
)
|
|
60
|
-
|
|
61
|
-
self.coreweave_endpoint_url = f"https://cwobject.com"
|
|
62
|
-
if self.secrets is None:
|
|
63
|
-
raise ValueError(
|
|
64
|
-
"`secrets` keyword argument is required for the coreweave_datastore"
|
|
65
|
-
)
|
|
66
|
-
|
|
67
|
-
def evaluate(self, mutable_flow: MutableFlow) -> None:
|
|
68
|
-
from metaflow import (
|
|
69
|
-
checkpoint,
|
|
70
|
-
model,
|
|
71
|
-
huggingface_hub,
|
|
72
|
-
secrets,
|
|
73
|
-
with_artifact_store,
|
|
74
|
-
)
|
|
75
|
-
|
|
76
|
-
def _add_secrets(step: MutableStep) -> None:
|
|
77
|
-
decos_to_add = []
|
|
78
|
-
swapping_decos = {
|
|
79
|
-
"huggingface_hub": huggingface_hub,
|
|
80
|
-
"model": model,
|
|
81
|
-
"checkpoint": checkpoint,
|
|
82
|
-
}
|
|
83
|
-
already_has_secrets = False
|
|
84
|
-
secrets_present_in_deco = []
|
|
85
|
-
for d in step.decorators:
|
|
86
|
-
if d.name in swapping_decos:
|
|
87
|
-
decos_to_add.append((d.name, d.attributes))
|
|
88
|
-
elif d.name == "secrets":
|
|
89
|
-
already_has_secrets = True
|
|
90
|
-
secrets_present_in_deco.extend(d.attributes["sources"])
|
|
91
|
-
|
|
92
|
-
# If the step aleady has secrets then take all the sources in
|
|
93
|
-
# the secrets and add the addtional secrets to the existing secrets
|
|
94
|
-
secrets_to_add = self.secrets
|
|
95
|
-
if already_has_secrets:
|
|
96
|
-
secrets_to_add.extend(secrets_present_in_deco)
|
|
97
|
-
|
|
98
|
-
secrets_to_add = list(set(secrets_to_add))
|
|
99
|
-
|
|
100
|
-
if len(decos_to_add) == 0:
|
|
101
|
-
if already_has_secrets:
|
|
102
|
-
step.remove_decorator("secrets")
|
|
103
|
-
|
|
104
|
-
step.add_decorator(
|
|
105
|
-
secrets,
|
|
106
|
-
sources=secrets_to_add,
|
|
107
|
-
)
|
|
108
|
-
return
|
|
109
|
-
|
|
110
|
-
for d, _ in decos_to_add:
|
|
111
|
-
step.remove_decorator(d)
|
|
112
|
-
|
|
113
|
-
step.add_decorator(
|
|
114
|
-
secrets,
|
|
115
|
-
sources=secrets_to_add,
|
|
116
|
-
)
|
|
117
|
-
for d, attrs in decos_to_add:
|
|
118
|
-
_deco_to_add = swapping_decos[d]
|
|
119
|
-
step.add_decorator(_deco_to_add, **attrs)
|
|
120
|
-
|
|
121
|
-
def _coreweave_config():
|
|
122
|
-
return {
|
|
123
|
-
"root": self.bucket_path,
|
|
124
|
-
"client_params": {
|
|
125
|
-
"aws_access_key_id": os.environ.get("COREWEAVE_ACCESS_KEY"),
|
|
126
|
-
"aws_secret_access_key": os.environ.get("COREWEAVE_SECRET_KEY"),
|
|
127
|
-
"endpoint_url": self.coreweave_endpoint_url,
|
|
128
|
-
"config": dict(s3={"addressing_style": "virtual"}),
|
|
129
|
-
},
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
mutable_flow.add_decorator(
|
|
133
|
-
with_artifact_store,
|
|
134
|
-
type="coreweave",
|
|
135
|
-
config=_coreweave_config,
|
|
136
|
-
)
|
|
137
|
-
|
|
138
|
-
for step_name, step in mutable_flow.steps:
|
|
139
|
-
_add_secrets(step)
|
ob_metaflow_extensions-1.2.8/metaflow_extensions/outerbounds/plugins/checkpoint_datastores/nebius.py
DELETED
|
@@ -1,144 +0,0 @@
|
|
|
1
|
-
from metaflow.user_configs.config_decorators import (
|
|
2
|
-
MutableFlow,
|
|
3
|
-
MutableStep,
|
|
4
|
-
CustomFlowDecorator,
|
|
5
|
-
)
|
|
6
|
-
import os
|
|
7
|
-
|
|
8
|
-
NEBIUS_ENDPOINT_URL = "https://storage.eu-north1.nebius.cloud:443"
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
class nebius_checkpoints(CustomFlowDecorator):
|
|
12
|
-
|
|
13
|
-
"""
|
|
14
|
-
|
|
15
|
-
This decorator is used for setting the nebius's S3 compatible object store as the artifact store for
|
|
16
|
-
checkpoints/models created by the flow.
|
|
17
|
-
|
|
18
|
-
Parameters
|
|
19
|
-
----------
|
|
20
|
-
secrets: list
|
|
21
|
-
A list of secrets to be added to the step. These secrets should contain any secrets that are required globally and the secret
|
|
22
|
-
for the nebius object store. The secret should contain the following keys:
|
|
23
|
-
- NEBIUS_ACCESS_KEY
|
|
24
|
-
- NEBIUS_SECRET_KEY
|
|
25
|
-
|
|
26
|
-
bucket_path: str
|
|
27
|
-
The path to the bucket to store the checkpoints/models.
|
|
28
|
-
|
|
29
|
-
endpoint_url: str
|
|
30
|
-
The endpoint url for the nebius object store. Defaults to `https://storage.eu-north1.nebius.cloud:443`
|
|
31
|
-
|
|
32
|
-
Usage
|
|
33
|
-
-----
|
|
34
|
-
```python
|
|
35
|
-
from metaflow import checkpoint, step, FlowSpec, nebius_checkpoints
|
|
36
|
-
|
|
37
|
-
@nebius_checkpoints(secrets=[], bucket_path=None)
|
|
38
|
-
class MyFlow(FlowSpec):
|
|
39
|
-
@checkpoint
|
|
40
|
-
@step
|
|
41
|
-
def start(self):
|
|
42
|
-
# Saves the checkpoint in the nebius object store
|
|
43
|
-
current.checkpoint.save("./foo.txt")
|
|
44
|
-
|
|
45
|
-
@step
|
|
46
|
-
def end(self):
|
|
47
|
-
pass
|
|
48
|
-
```
|
|
49
|
-
"""
|
|
50
|
-
|
|
51
|
-
def __init__(self, *args, **kwargs):
|
|
52
|
-
super().__init__(*args, **kwargs)
|
|
53
|
-
|
|
54
|
-
def init(self, *args, **kwargs):
|
|
55
|
-
self.bucket_path = kwargs.get("bucket_path", None)
|
|
56
|
-
|
|
57
|
-
self.secrets = kwargs.get("secrets", [])
|
|
58
|
-
if self.bucket_path is None:
|
|
59
|
-
raise ValueError(
|
|
60
|
-
"`bucket_path` keyword argument is required for the coreweave_datastore"
|
|
61
|
-
)
|
|
62
|
-
if not self.bucket_path.startswith("s3://"):
|
|
63
|
-
raise ValueError(
|
|
64
|
-
"`bucket_path` must start with `s3://` for the coreweave_datastore"
|
|
65
|
-
)
|
|
66
|
-
|
|
67
|
-
self.nebius_endpoint_url = kwargs.get("endpoint_url", NEBIUS_ENDPOINT_URL)
|
|
68
|
-
if self.secrets is None:
|
|
69
|
-
raise ValueError(
|
|
70
|
-
"`secrets` keyword argument is required for the coreweave_datastore"
|
|
71
|
-
)
|
|
72
|
-
|
|
73
|
-
def evaluate(self, mutable_flow: MutableFlow) -> None:
|
|
74
|
-
from metaflow import (
|
|
75
|
-
checkpoint,
|
|
76
|
-
model,
|
|
77
|
-
huggingface_hub,
|
|
78
|
-
secrets,
|
|
79
|
-
with_artifact_store,
|
|
80
|
-
)
|
|
81
|
-
|
|
82
|
-
def _add_secrets(step: MutableStep) -> None:
|
|
83
|
-
decos_to_add = []
|
|
84
|
-
swapping_decos = {
|
|
85
|
-
"huggingface_hub": huggingface_hub,
|
|
86
|
-
"model": model,
|
|
87
|
-
"checkpoint": checkpoint,
|
|
88
|
-
}
|
|
89
|
-
already_has_secrets = False
|
|
90
|
-
secrets_present_in_deco = []
|
|
91
|
-
for d in step.decorators:
|
|
92
|
-
if d.name in swapping_decos:
|
|
93
|
-
decos_to_add.append((d.name, d.attributes))
|
|
94
|
-
elif d.name == "secrets":
|
|
95
|
-
already_has_secrets = True
|
|
96
|
-
secrets_present_in_deco.extend(d.attributes["sources"])
|
|
97
|
-
|
|
98
|
-
# If the step aleady has secrets then take all the sources in
|
|
99
|
-
# the secrets and add the addtional secrets to the existing secrets
|
|
100
|
-
secrets_to_add = self.secrets
|
|
101
|
-
if already_has_secrets:
|
|
102
|
-
secrets_to_add.extend(secrets_present_in_deco)
|
|
103
|
-
|
|
104
|
-
secrets_to_add = list(set(secrets_to_add))
|
|
105
|
-
|
|
106
|
-
if len(decos_to_add) == 0:
|
|
107
|
-
if already_has_secrets:
|
|
108
|
-
step.remove_decorator("secrets")
|
|
109
|
-
|
|
110
|
-
step.add_decorator(
|
|
111
|
-
secrets,
|
|
112
|
-
sources=secrets_to_add,
|
|
113
|
-
)
|
|
114
|
-
return
|
|
115
|
-
|
|
116
|
-
for d, _ in decos_to_add:
|
|
117
|
-
step.remove_decorator(d)
|
|
118
|
-
|
|
119
|
-
step.add_decorator(
|
|
120
|
-
secrets,
|
|
121
|
-
sources=secrets_to_add,
|
|
122
|
-
)
|
|
123
|
-
for d, attrs in decos_to_add:
|
|
124
|
-
_deco_to_add = swapping_decos[d]
|
|
125
|
-
step.add_decorator(_deco_to_add, **attrs)
|
|
126
|
-
|
|
127
|
-
def _nebius_config():
|
|
128
|
-
return {
|
|
129
|
-
"root": self.bucket_path,
|
|
130
|
-
"client_params": {
|
|
131
|
-
"aws_access_key_id": os.environ.get("NEBIUS_ACCESS_KEY"),
|
|
132
|
-
"aws_secret_access_key": os.environ.get("NEBIUS_SECRET_KEY"),
|
|
133
|
-
"endpoint_url": self.nebius_endpoint_url,
|
|
134
|
-
},
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
mutable_flow.add_decorator(
|
|
138
|
-
with_artifact_store,
|
|
139
|
-
type="s3",
|
|
140
|
-
config=_nebius_config,
|
|
141
|
-
)
|
|
142
|
-
|
|
143
|
-
for step_name, step in mutable_flow.steps:
|
|
144
|
-
_add_secrets(step)
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|