genesis-flow 1.0.0__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.
- genesis_flow-1.0.0.dist-info/METADATA +822 -0
- genesis_flow-1.0.0.dist-info/RECORD +645 -0
- genesis_flow-1.0.0.dist-info/WHEEL +5 -0
- genesis_flow-1.0.0.dist-info/entry_points.txt +19 -0
- genesis_flow-1.0.0.dist-info/licenses/LICENSE.txt +202 -0
- genesis_flow-1.0.0.dist-info/top_level.txt +1 -0
- mlflow/__init__.py +367 -0
- mlflow/__main__.py +3 -0
- mlflow/ag2/__init__.py +56 -0
- mlflow/ag2/ag2_logger.py +294 -0
- mlflow/anthropic/__init__.py +40 -0
- mlflow/anthropic/autolog.py +129 -0
- mlflow/anthropic/chat.py +144 -0
- mlflow/artifacts/__init__.py +268 -0
- mlflow/autogen/__init__.py +144 -0
- mlflow/autogen/chat.py +142 -0
- mlflow/azure/__init__.py +26 -0
- mlflow/azure/auth_handler.py +257 -0
- mlflow/azure/client.py +319 -0
- mlflow/azure/config.py +120 -0
- mlflow/azure/connection_factory.py +340 -0
- mlflow/azure/exceptions.py +27 -0
- mlflow/azure/stores.py +327 -0
- mlflow/azure/utils.py +183 -0
- mlflow/bedrock/__init__.py +45 -0
- mlflow/bedrock/_autolog.py +202 -0
- mlflow/bedrock/chat.py +122 -0
- mlflow/bedrock/stream.py +160 -0
- mlflow/bedrock/utils.py +43 -0
- mlflow/cli.py +707 -0
- mlflow/client.py +12 -0
- mlflow/config/__init__.py +56 -0
- mlflow/crewai/__init__.py +79 -0
- mlflow/crewai/autolog.py +253 -0
- mlflow/crewai/chat.py +29 -0
- mlflow/data/__init__.py +75 -0
- mlflow/data/artifact_dataset_sources.py +170 -0
- mlflow/data/code_dataset_source.py +40 -0
- mlflow/data/dataset.py +123 -0
- mlflow/data/dataset_registry.py +168 -0
- mlflow/data/dataset_source.py +110 -0
- mlflow/data/dataset_source_registry.py +219 -0
- mlflow/data/delta_dataset_source.py +167 -0
- mlflow/data/digest_utils.py +108 -0
- mlflow/data/evaluation_dataset.py +562 -0
- mlflow/data/filesystem_dataset_source.py +81 -0
- mlflow/data/http_dataset_source.py +145 -0
- mlflow/data/huggingface_dataset.py +258 -0
- mlflow/data/huggingface_dataset_source.py +118 -0
- mlflow/data/meta_dataset.py +104 -0
- mlflow/data/numpy_dataset.py +223 -0
- mlflow/data/pandas_dataset.py +231 -0
- mlflow/data/polars_dataset.py +352 -0
- mlflow/data/pyfunc_dataset_mixin.py +31 -0
- mlflow/data/schema.py +76 -0
- mlflow/data/sources.py +1 -0
- mlflow/data/spark_dataset.py +406 -0
- mlflow/data/spark_dataset_source.py +74 -0
- mlflow/data/spark_delta_utils.py +118 -0
- mlflow/data/tensorflow_dataset.py +350 -0
- mlflow/data/uc_volume_dataset_source.py +81 -0
- mlflow/db.py +27 -0
- mlflow/dspy/__init__.py +17 -0
- mlflow/dspy/autolog.py +197 -0
- mlflow/dspy/callback.py +398 -0
- mlflow/dspy/constant.py +1 -0
- mlflow/dspy/load.py +93 -0
- mlflow/dspy/save.py +393 -0
- mlflow/dspy/util.py +109 -0
- mlflow/dspy/wrapper.py +226 -0
- mlflow/entities/__init__.py +104 -0
- mlflow/entities/_mlflow_object.py +52 -0
- mlflow/entities/assessment.py +545 -0
- mlflow/entities/assessment_error.py +80 -0
- mlflow/entities/assessment_source.py +141 -0
- mlflow/entities/dataset.py +92 -0
- mlflow/entities/dataset_input.py +51 -0
- mlflow/entities/dataset_summary.py +62 -0
- mlflow/entities/document.py +48 -0
- mlflow/entities/experiment.py +109 -0
- mlflow/entities/experiment_tag.py +35 -0
- mlflow/entities/file_info.py +45 -0
- mlflow/entities/input_tag.py +35 -0
- mlflow/entities/lifecycle_stage.py +35 -0
- mlflow/entities/logged_model.py +228 -0
- mlflow/entities/logged_model_input.py +26 -0
- mlflow/entities/logged_model_output.py +32 -0
- mlflow/entities/logged_model_parameter.py +46 -0
- mlflow/entities/logged_model_status.py +74 -0
- mlflow/entities/logged_model_tag.py +33 -0
- mlflow/entities/metric.py +200 -0
- mlflow/entities/model_registry/__init__.py +29 -0
- mlflow/entities/model_registry/_model_registry_entity.py +13 -0
- mlflow/entities/model_registry/model_version.py +243 -0
- mlflow/entities/model_registry/model_version_deployment_job_run_state.py +44 -0
- mlflow/entities/model_registry/model_version_deployment_job_state.py +70 -0
- mlflow/entities/model_registry/model_version_search.py +25 -0
- mlflow/entities/model_registry/model_version_stages.py +25 -0
- mlflow/entities/model_registry/model_version_status.py +35 -0
- mlflow/entities/model_registry/model_version_tag.py +35 -0
- mlflow/entities/model_registry/prompt.py +73 -0
- mlflow/entities/model_registry/prompt_version.py +244 -0
- mlflow/entities/model_registry/registered_model.py +175 -0
- mlflow/entities/model_registry/registered_model_alias.py +35 -0
- mlflow/entities/model_registry/registered_model_deployment_job_state.py +39 -0
- mlflow/entities/model_registry/registered_model_search.py +25 -0
- mlflow/entities/model_registry/registered_model_tag.py +35 -0
- mlflow/entities/multipart_upload.py +74 -0
- mlflow/entities/param.py +49 -0
- mlflow/entities/run.py +97 -0
- mlflow/entities/run_data.py +84 -0
- mlflow/entities/run_info.py +188 -0
- mlflow/entities/run_inputs.py +59 -0
- mlflow/entities/run_outputs.py +43 -0
- mlflow/entities/run_status.py +41 -0
- mlflow/entities/run_tag.py +36 -0
- mlflow/entities/source_type.py +31 -0
- mlflow/entities/span.py +774 -0
- mlflow/entities/span_event.py +96 -0
- mlflow/entities/span_status.py +102 -0
- mlflow/entities/trace.py +317 -0
- mlflow/entities/trace_data.py +71 -0
- mlflow/entities/trace_info.py +220 -0
- mlflow/entities/trace_info_v2.py +162 -0
- mlflow/entities/trace_location.py +173 -0
- mlflow/entities/trace_state.py +39 -0
- mlflow/entities/trace_status.py +68 -0
- mlflow/entities/view_type.py +51 -0
- mlflow/environment_variables.py +866 -0
- mlflow/evaluation/__init__.py +16 -0
- mlflow/evaluation/assessment.py +369 -0
- mlflow/evaluation/evaluation.py +411 -0
- mlflow/evaluation/evaluation_tag.py +61 -0
- mlflow/evaluation/fluent.py +48 -0
- mlflow/evaluation/utils.py +201 -0
- mlflow/exceptions.py +213 -0
- mlflow/experiments.py +140 -0
- mlflow/gemini/__init__.py +81 -0
- mlflow/gemini/autolog.py +186 -0
- mlflow/gemini/chat.py +261 -0
- mlflow/genai/__init__.py +71 -0
- mlflow/genai/datasets/__init__.py +67 -0
- mlflow/genai/datasets/evaluation_dataset.py +131 -0
- mlflow/genai/evaluation/__init__.py +3 -0
- mlflow/genai/evaluation/base.py +411 -0
- mlflow/genai/evaluation/constant.py +23 -0
- mlflow/genai/evaluation/utils.py +244 -0
- mlflow/genai/judges/__init__.py +21 -0
- mlflow/genai/judges/databricks.py +404 -0
- mlflow/genai/label_schemas/__init__.py +153 -0
- mlflow/genai/label_schemas/label_schemas.py +209 -0
- mlflow/genai/labeling/__init__.py +159 -0
- mlflow/genai/labeling/labeling.py +250 -0
- mlflow/genai/optimize/__init__.py +13 -0
- mlflow/genai/optimize/base.py +198 -0
- mlflow/genai/optimize/optimizers/__init__.py +4 -0
- mlflow/genai/optimize/optimizers/base_optimizer.py +38 -0
- mlflow/genai/optimize/optimizers/dspy_mipro_optimizer.py +221 -0
- mlflow/genai/optimize/optimizers/dspy_optimizer.py +91 -0
- mlflow/genai/optimize/optimizers/utils/dspy_mipro_callback.py +76 -0
- mlflow/genai/optimize/optimizers/utils/dspy_mipro_utils.py +18 -0
- mlflow/genai/optimize/types.py +75 -0
- mlflow/genai/optimize/util.py +30 -0
- mlflow/genai/prompts/__init__.py +206 -0
- mlflow/genai/scheduled_scorers.py +431 -0
- mlflow/genai/scorers/__init__.py +26 -0
- mlflow/genai/scorers/base.py +492 -0
- mlflow/genai/scorers/builtin_scorers.py +765 -0
- mlflow/genai/scorers/scorer_utils.py +138 -0
- mlflow/genai/scorers/validation.py +165 -0
- mlflow/genai/utils/data_validation.py +146 -0
- mlflow/genai/utils/enum_utils.py +23 -0
- mlflow/genai/utils/trace_utils.py +211 -0
- mlflow/groq/__init__.py +42 -0
- mlflow/groq/_groq_autolog.py +74 -0
- mlflow/johnsnowlabs/__init__.py +888 -0
- mlflow/langchain/__init__.py +24 -0
- mlflow/langchain/api_request_parallel_processor.py +330 -0
- mlflow/langchain/autolog.py +147 -0
- mlflow/langchain/chat_agent_langgraph.py +340 -0
- mlflow/langchain/constant.py +1 -0
- mlflow/langchain/constants.py +1 -0
- mlflow/langchain/databricks_dependencies.py +444 -0
- mlflow/langchain/langchain_tracer.py +597 -0
- mlflow/langchain/model.py +919 -0
- mlflow/langchain/output_parsers.py +142 -0
- mlflow/langchain/retriever_chain.py +153 -0
- mlflow/langchain/runnables.py +527 -0
- mlflow/langchain/utils/chat.py +402 -0
- mlflow/langchain/utils/logging.py +671 -0
- mlflow/langchain/utils/serialization.py +36 -0
- mlflow/legacy_databricks_cli/__init__.py +0 -0
- mlflow/legacy_databricks_cli/configure/__init__.py +0 -0
- mlflow/legacy_databricks_cli/configure/provider.py +482 -0
- mlflow/litellm/__init__.py +175 -0
- mlflow/llama_index/__init__.py +22 -0
- mlflow/llama_index/autolog.py +55 -0
- mlflow/llama_index/chat.py +43 -0
- mlflow/llama_index/constant.py +1 -0
- mlflow/llama_index/model.py +577 -0
- mlflow/llama_index/pyfunc_wrapper.py +332 -0
- mlflow/llama_index/serialize_objects.py +188 -0
- mlflow/llama_index/tracer.py +561 -0
- mlflow/metrics/__init__.py +479 -0
- mlflow/metrics/base.py +39 -0
- mlflow/metrics/genai/__init__.py +25 -0
- mlflow/metrics/genai/base.py +101 -0
- mlflow/metrics/genai/genai_metric.py +771 -0
- mlflow/metrics/genai/metric_definitions.py +450 -0
- mlflow/metrics/genai/model_utils.py +371 -0
- mlflow/metrics/genai/prompt_template.py +68 -0
- mlflow/metrics/genai/prompts/__init__.py +0 -0
- mlflow/metrics/genai/prompts/v1.py +422 -0
- mlflow/metrics/genai/utils.py +6 -0
- mlflow/metrics/metric_definitions.py +619 -0
- mlflow/mismatch.py +34 -0
- mlflow/mistral/__init__.py +34 -0
- mlflow/mistral/autolog.py +71 -0
- mlflow/mistral/chat.py +135 -0
- mlflow/ml_package_versions.py +452 -0
- mlflow/models/__init__.py +97 -0
- mlflow/models/auth_policy.py +83 -0
- mlflow/models/cli.py +354 -0
- mlflow/models/container/__init__.py +294 -0
- mlflow/models/container/scoring_server/__init__.py +0 -0
- mlflow/models/container/scoring_server/nginx.conf +39 -0
- mlflow/models/dependencies_schemas.py +287 -0
- mlflow/models/display_utils.py +158 -0
- mlflow/models/docker_utils.py +211 -0
- mlflow/models/evaluation/__init__.py +23 -0
- mlflow/models/evaluation/_shap_patch.py +64 -0
- mlflow/models/evaluation/artifacts.py +194 -0
- mlflow/models/evaluation/base.py +1811 -0
- mlflow/models/evaluation/calibration_curve.py +109 -0
- mlflow/models/evaluation/default_evaluator.py +996 -0
- mlflow/models/evaluation/deprecated.py +23 -0
- mlflow/models/evaluation/evaluator_registry.py +80 -0
- mlflow/models/evaluation/evaluators/classifier.py +704 -0
- mlflow/models/evaluation/evaluators/default.py +233 -0
- mlflow/models/evaluation/evaluators/regressor.py +96 -0
- mlflow/models/evaluation/evaluators/shap.py +296 -0
- mlflow/models/evaluation/lift_curve.py +178 -0
- mlflow/models/evaluation/utils/metric.py +123 -0
- mlflow/models/evaluation/utils/trace.py +179 -0
- mlflow/models/evaluation/validation.py +434 -0
- mlflow/models/flavor_backend.py +93 -0
- mlflow/models/flavor_backend_registry.py +53 -0
- mlflow/models/model.py +1639 -0
- mlflow/models/model_config.py +150 -0
- mlflow/models/notebook_resources/agent_evaluation_template.html +235 -0
- mlflow/models/notebook_resources/eval_with_dataset_example.py +22 -0
- mlflow/models/notebook_resources/eval_with_synthetic_example.py +22 -0
- mlflow/models/python_api.py +369 -0
- mlflow/models/rag_signatures.py +128 -0
- mlflow/models/resources.py +321 -0
- mlflow/models/signature.py +662 -0
- mlflow/models/utils.py +2054 -0
- mlflow/models/wheeled_model.py +280 -0
- mlflow/openai/__init__.py +57 -0
- mlflow/openai/_agent_tracer.py +364 -0
- mlflow/openai/api_request_parallel_processor.py +131 -0
- mlflow/openai/autolog.py +509 -0
- mlflow/openai/constant.py +1 -0
- mlflow/openai/model.py +824 -0
- mlflow/openai/utils/chat_schema.py +367 -0
- mlflow/optuna/__init__.py +3 -0
- mlflow/optuna/storage.py +646 -0
- mlflow/plugins/__init__.py +72 -0
- mlflow/plugins/base.py +358 -0
- mlflow/plugins/builtin/__init__.py +24 -0
- mlflow/plugins/builtin/pytorch_plugin.py +150 -0
- mlflow/plugins/builtin/sklearn_plugin.py +158 -0
- mlflow/plugins/builtin/transformers_plugin.py +187 -0
- mlflow/plugins/cli.py +321 -0
- mlflow/plugins/discovery.py +340 -0
- mlflow/plugins/manager.py +465 -0
- mlflow/plugins/registry.py +316 -0
- mlflow/plugins/templates/framework_plugin_template.py +329 -0
- mlflow/prompt/constants.py +20 -0
- mlflow/prompt/promptlab_model.py +197 -0
- mlflow/prompt/registry_utils.py +248 -0
- mlflow/promptflow/__init__.py +495 -0
- mlflow/protos/__init__.py +0 -0
- mlflow/protos/assessments_pb2.py +174 -0
- mlflow/protos/databricks_artifacts_pb2.py +489 -0
- mlflow/protos/databricks_filesystem_service_pb2.py +196 -0
- mlflow/protos/databricks_managed_catalog_messages_pb2.py +95 -0
- mlflow/protos/databricks_managed_catalog_service_pb2.py +86 -0
- mlflow/protos/databricks_pb2.py +267 -0
- mlflow/protos/databricks_trace_server_pb2.py +374 -0
- mlflow/protos/databricks_uc_registry_messages_pb2.py +1249 -0
- mlflow/protos/databricks_uc_registry_service_pb2.py +170 -0
- mlflow/protos/facet_feature_statistics_pb2.py +296 -0
- mlflow/protos/internal_pb2.py +77 -0
- mlflow/protos/mlflow_artifacts_pb2.py +336 -0
- mlflow/protos/model_registry_pb2.py +1073 -0
- mlflow/protos/scalapb/__init__.py +0 -0
- mlflow/protos/scalapb/scalapb_pb2.py +104 -0
- mlflow/protos/service_pb2.py +2600 -0
- mlflow/protos/unity_catalog_oss_messages_pb2.py +457 -0
- mlflow/protos/unity_catalog_oss_service_pb2.py +130 -0
- mlflow/protos/unity_catalog_prompt_messages_pb2.py +447 -0
- mlflow/protos/unity_catalog_prompt_messages_pb2_grpc.py +24 -0
- mlflow/protos/unity_catalog_prompt_service_pb2.py +164 -0
- mlflow/protos/unity_catalog_prompt_service_pb2_grpc.py +785 -0
- mlflow/py.typed +0 -0
- mlflow/pydantic_ai/__init__.py +57 -0
- mlflow/pydantic_ai/autolog.py +173 -0
- mlflow/pyfunc/__init__.py +3844 -0
- mlflow/pyfunc/_mlflow_pyfunc_backend_predict.py +61 -0
- mlflow/pyfunc/backend.py +523 -0
- mlflow/pyfunc/context.py +78 -0
- mlflow/pyfunc/dbconnect_artifact_cache.py +144 -0
- mlflow/pyfunc/loaders/__init__.py +7 -0
- mlflow/pyfunc/loaders/chat_agent.py +117 -0
- mlflow/pyfunc/loaders/chat_model.py +125 -0
- mlflow/pyfunc/loaders/code_model.py +31 -0
- mlflow/pyfunc/loaders/responses_agent.py +112 -0
- mlflow/pyfunc/mlserver.py +46 -0
- mlflow/pyfunc/model.py +1473 -0
- mlflow/pyfunc/scoring_server/__init__.py +604 -0
- mlflow/pyfunc/scoring_server/app.py +7 -0
- mlflow/pyfunc/scoring_server/client.py +146 -0
- mlflow/pyfunc/spark_model_cache.py +48 -0
- mlflow/pyfunc/stdin_server.py +44 -0
- mlflow/pyfunc/utils/__init__.py +3 -0
- mlflow/pyfunc/utils/data_validation.py +224 -0
- mlflow/pyfunc/utils/environment.py +22 -0
- mlflow/pyfunc/utils/input_converter.py +47 -0
- mlflow/pyfunc/utils/serving_data_parser.py +11 -0
- mlflow/pytorch/__init__.py +1171 -0
- mlflow/pytorch/_lightning_autolog.py +580 -0
- mlflow/pytorch/_pytorch_autolog.py +50 -0
- mlflow/pytorch/pickle_module.py +35 -0
- mlflow/rfunc/__init__.py +42 -0
- mlflow/rfunc/backend.py +134 -0
- mlflow/runs.py +89 -0
- mlflow/server/__init__.py +302 -0
- mlflow/server/auth/__init__.py +1224 -0
- mlflow/server/auth/__main__.py +4 -0
- mlflow/server/auth/basic_auth.ini +6 -0
- mlflow/server/auth/cli.py +11 -0
- mlflow/server/auth/client.py +537 -0
- mlflow/server/auth/config.py +34 -0
- mlflow/server/auth/db/__init__.py +0 -0
- mlflow/server/auth/db/cli.py +18 -0
- mlflow/server/auth/db/migrations/__init__.py +0 -0
- mlflow/server/auth/db/migrations/alembic.ini +110 -0
- mlflow/server/auth/db/migrations/env.py +76 -0
- mlflow/server/auth/db/migrations/versions/8606fa83a998_initial_migration.py +51 -0
- mlflow/server/auth/db/migrations/versions/__init__.py +0 -0
- mlflow/server/auth/db/models.py +67 -0
- mlflow/server/auth/db/utils.py +37 -0
- mlflow/server/auth/entities.py +165 -0
- mlflow/server/auth/logo.py +14 -0
- mlflow/server/auth/permissions.py +65 -0
- mlflow/server/auth/routes.py +18 -0
- mlflow/server/auth/sqlalchemy_store.py +263 -0
- mlflow/server/graphql/__init__.py +0 -0
- mlflow/server/graphql/autogenerated_graphql_schema.py +353 -0
- mlflow/server/graphql/graphql_custom_scalars.py +24 -0
- mlflow/server/graphql/graphql_errors.py +15 -0
- mlflow/server/graphql/graphql_no_batching.py +89 -0
- mlflow/server/graphql/graphql_schema_extensions.py +74 -0
- mlflow/server/handlers.py +3217 -0
- mlflow/server/prometheus_exporter.py +17 -0
- mlflow/server/validation.py +30 -0
- mlflow/shap/__init__.py +691 -0
- mlflow/sklearn/__init__.py +1994 -0
- mlflow/sklearn/utils.py +1041 -0
- mlflow/smolagents/__init__.py +66 -0
- mlflow/smolagents/autolog.py +139 -0
- mlflow/smolagents/chat.py +29 -0
- mlflow/store/__init__.py +10 -0
- mlflow/store/_unity_catalog/__init__.py +1 -0
- mlflow/store/_unity_catalog/lineage/__init__.py +1 -0
- mlflow/store/_unity_catalog/lineage/constants.py +2 -0
- mlflow/store/_unity_catalog/registry/__init__.py +6 -0
- mlflow/store/_unity_catalog/registry/prompt_info.py +75 -0
- mlflow/store/_unity_catalog/registry/rest_store.py +1740 -0
- mlflow/store/_unity_catalog/registry/uc_oss_rest_store.py +507 -0
- mlflow/store/_unity_catalog/registry/utils.py +121 -0
- mlflow/store/artifact/__init__.py +0 -0
- mlflow/store/artifact/artifact_repo.py +472 -0
- mlflow/store/artifact/artifact_repository_registry.py +154 -0
- mlflow/store/artifact/azure_blob_artifact_repo.py +275 -0
- mlflow/store/artifact/azure_data_lake_artifact_repo.py +295 -0
- mlflow/store/artifact/cli.py +141 -0
- mlflow/store/artifact/cloud_artifact_repo.py +332 -0
- mlflow/store/artifact/databricks_artifact_repo.py +729 -0
- mlflow/store/artifact/databricks_artifact_repo_resources.py +301 -0
- mlflow/store/artifact/databricks_logged_model_artifact_repo.py +93 -0
- mlflow/store/artifact/databricks_models_artifact_repo.py +216 -0
- mlflow/store/artifact/databricks_sdk_artifact_repo.py +134 -0
- mlflow/store/artifact/databricks_sdk_models_artifact_repo.py +97 -0
- mlflow/store/artifact/dbfs_artifact_repo.py +240 -0
- mlflow/store/artifact/ftp_artifact_repo.py +132 -0
- mlflow/store/artifact/gcs_artifact_repo.py +296 -0
- mlflow/store/artifact/hdfs_artifact_repo.py +209 -0
- mlflow/store/artifact/http_artifact_repo.py +218 -0
- mlflow/store/artifact/local_artifact_repo.py +142 -0
- mlflow/store/artifact/mlflow_artifacts_repo.py +94 -0
- mlflow/store/artifact/models_artifact_repo.py +259 -0
- mlflow/store/artifact/optimized_s3_artifact_repo.py +356 -0
- mlflow/store/artifact/presigned_url_artifact_repo.py +173 -0
- mlflow/store/artifact/r2_artifact_repo.py +70 -0
- mlflow/store/artifact/runs_artifact_repo.py +265 -0
- mlflow/store/artifact/s3_artifact_repo.py +330 -0
- mlflow/store/artifact/sftp_artifact_repo.py +141 -0
- mlflow/store/artifact/uc_volume_artifact_repo.py +76 -0
- mlflow/store/artifact/unity_catalog_models_artifact_repo.py +168 -0
- mlflow/store/artifact/unity_catalog_oss_models_artifact_repo.py +168 -0
- mlflow/store/artifact/utils/__init__.py +0 -0
- mlflow/store/artifact/utils/models.py +148 -0
- mlflow/store/db/__init__.py +0 -0
- mlflow/store/db/base_sql_model.py +3 -0
- mlflow/store/db/db_types.py +10 -0
- mlflow/store/db/utils.py +314 -0
- mlflow/store/db_migrations/__init__.py +0 -0
- mlflow/store/db_migrations/alembic.ini +74 -0
- mlflow/store/db_migrations/env.py +84 -0
- mlflow/store/db_migrations/versions/0584bdc529eb_add_cascading_deletion_to_datasets_from_experiments.py +88 -0
- mlflow/store/db_migrations/versions/0a8213491aaa_drop_duplicate_killed_constraint.py +49 -0
- mlflow/store/db_migrations/versions/0c779009ac13_add_deleted_time_field_to_runs_table.py +24 -0
- mlflow/store/db_migrations/versions/181f10493468_allow_nulls_for_metric_values.py +35 -0
- mlflow/store/db_migrations/versions/27a6a02d2cf1_add_model_version_tags_table.py +38 -0
- mlflow/store/db_migrations/versions/2b4d017a5e9b_add_model_registry_tables_to_db.py +77 -0
- mlflow/store/db_migrations/versions/2d6e25af4d3e_increase_max_param_val_length.py +33 -0
- mlflow/store/db_migrations/versions/3500859a5d39_add_model_aliases_table.py +50 -0
- mlflow/store/db_migrations/versions/39d1c3be5f05_add_is_nan_constraint_for_metrics_tables_if_necessary.py +41 -0
- mlflow/store/db_migrations/versions/400f98739977_add_logged_model_tables.py +123 -0
- mlflow/store/db_migrations/versions/4465047574b1_increase_max_dataset_schema_size.py +38 -0
- mlflow/store/db_migrations/versions/451aebb31d03_add_metric_step.py +35 -0
- mlflow/store/db_migrations/versions/5b0e9adcef9c_add_cascade_deletion_to_trace_tables_fk.py +40 -0
- mlflow/store/db_migrations/versions/6953534de441_add_step_to_inputs_table.py +25 -0
- mlflow/store/db_migrations/versions/728d730b5ebd_add_registered_model_tags_table.py +38 -0
- mlflow/store/db_migrations/versions/7ac759974ad8_update_run_tags_with_larger_limit.py +36 -0
- mlflow/store/db_migrations/versions/7f2a7d5fae7d_add_datasets_inputs_input_tags_tables.py +82 -0
- mlflow/store/db_migrations/versions/84291f40a231_add_run_link_to_model_version.py +26 -0
- mlflow/store/db_migrations/versions/867495a8f9d4_add_trace_tables.py +90 -0
- mlflow/store/db_migrations/versions/89d4b8295536_create_latest_metrics_table.py +169 -0
- mlflow/store/db_migrations/versions/90e64c465722_migrate_user_column_to_tags.py +64 -0
- mlflow/store/db_migrations/versions/97727af70f4d_creation_time_last_update_time_experiments.py +25 -0
- mlflow/store/db_migrations/versions/__init__.py +0 -0
- mlflow/store/db_migrations/versions/a8c4a736bde6_allow_nulls_for_run_id.py +27 -0
- mlflow/store/db_migrations/versions/acf3f17fdcc7_add_storage_location_field_to_model_.py +29 -0
- mlflow/store/db_migrations/versions/bd07f7e963c5_create_index_on_run_uuid.py +26 -0
- mlflow/store/db_migrations/versions/bda7b8c39065_increase_model_version_tag_value_limit.py +38 -0
- mlflow/store/db_migrations/versions/c48cb773bb87_reset_default_value_for_is_nan_in_metrics_table_for_mysql.py +41 -0
- mlflow/store/db_migrations/versions/cbc13b556ace_add_v3_trace_schema_columns.py +31 -0
- mlflow/store/db_migrations/versions/cc1f77228345_change_param_value_length_to_500.py +34 -0
- mlflow/store/db_migrations/versions/cfd24bdc0731_update_run_status_constraint_with_killed.py +78 -0
- mlflow/store/db_migrations/versions/df50e92ffc5e_add_experiment_tags_table.py +38 -0
- mlflow/store/db_migrations/versions/f5a4f2784254_increase_run_tag_value_limit.py +36 -0
- mlflow/store/entities/__init__.py +3 -0
- mlflow/store/entities/paged_list.py +18 -0
- mlflow/store/model_registry/__init__.py +10 -0
- mlflow/store/model_registry/abstract_store.py +1081 -0
- mlflow/store/model_registry/base_rest_store.py +44 -0
- mlflow/store/model_registry/databricks_workspace_model_registry_rest_store.py +37 -0
- mlflow/store/model_registry/dbmodels/__init__.py +0 -0
- mlflow/store/model_registry/dbmodels/models.py +206 -0
- mlflow/store/model_registry/file_store.py +1091 -0
- mlflow/store/model_registry/rest_store.py +481 -0
- mlflow/store/model_registry/sqlalchemy_store.py +1286 -0
- mlflow/store/tracking/__init__.py +23 -0
- mlflow/store/tracking/abstract_store.py +816 -0
- mlflow/store/tracking/dbmodels/__init__.py +0 -0
- mlflow/store/tracking/dbmodels/initial_models.py +243 -0
- mlflow/store/tracking/dbmodels/models.py +1073 -0
- mlflow/store/tracking/file_store.py +2438 -0
- mlflow/store/tracking/postgres_managed_identity.py +146 -0
- mlflow/store/tracking/rest_store.py +1131 -0
- mlflow/store/tracking/sqlalchemy_store.py +2785 -0
- mlflow/system_metrics/__init__.py +61 -0
- mlflow/system_metrics/metrics/__init__.py +0 -0
- mlflow/system_metrics/metrics/base_metrics_monitor.py +32 -0
- mlflow/system_metrics/metrics/cpu_monitor.py +23 -0
- mlflow/system_metrics/metrics/disk_monitor.py +21 -0
- mlflow/system_metrics/metrics/gpu_monitor.py +71 -0
- mlflow/system_metrics/metrics/network_monitor.py +34 -0
- mlflow/system_metrics/metrics/rocm_monitor.py +123 -0
- mlflow/system_metrics/system_metrics_monitor.py +198 -0
- mlflow/tracing/__init__.py +16 -0
- mlflow/tracing/assessment.py +356 -0
- mlflow/tracing/client.py +531 -0
- mlflow/tracing/config.py +125 -0
- mlflow/tracing/constant.py +105 -0
- mlflow/tracing/destination.py +81 -0
- mlflow/tracing/display/__init__.py +40 -0
- mlflow/tracing/display/display_handler.py +196 -0
- mlflow/tracing/export/async_export_queue.py +186 -0
- mlflow/tracing/export/inference_table.py +138 -0
- mlflow/tracing/export/mlflow_v3.py +137 -0
- mlflow/tracing/export/utils.py +70 -0
- mlflow/tracing/fluent.py +1417 -0
- mlflow/tracing/processor/base_mlflow.py +199 -0
- mlflow/tracing/processor/inference_table.py +175 -0
- mlflow/tracing/processor/mlflow_v3.py +47 -0
- mlflow/tracing/processor/otel.py +73 -0
- mlflow/tracing/provider.py +487 -0
- mlflow/tracing/trace_manager.py +200 -0
- mlflow/tracing/utils/__init__.py +616 -0
- mlflow/tracing/utils/artifact_utils.py +28 -0
- mlflow/tracing/utils/copy.py +55 -0
- mlflow/tracing/utils/environment.py +55 -0
- mlflow/tracing/utils/exception.py +21 -0
- mlflow/tracing/utils/once.py +35 -0
- mlflow/tracing/utils/otlp.py +63 -0
- mlflow/tracing/utils/processor.py +54 -0
- mlflow/tracing/utils/search.py +292 -0
- mlflow/tracing/utils/timeout.py +250 -0
- mlflow/tracing/utils/token.py +19 -0
- mlflow/tracing/utils/truncation.py +124 -0
- mlflow/tracing/utils/warning.py +76 -0
- mlflow/tracking/__init__.py +39 -0
- mlflow/tracking/_model_registry/__init__.py +1 -0
- mlflow/tracking/_model_registry/client.py +764 -0
- mlflow/tracking/_model_registry/fluent.py +853 -0
- mlflow/tracking/_model_registry/registry.py +67 -0
- mlflow/tracking/_model_registry/utils.py +251 -0
- mlflow/tracking/_tracking_service/__init__.py +0 -0
- mlflow/tracking/_tracking_service/client.py +883 -0
- mlflow/tracking/_tracking_service/registry.py +56 -0
- mlflow/tracking/_tracking_service/utils.py +275 -0
- mlflow/tracking/artifact_utils.py +179 -0
- mlflow/tracking/client.py +5900 -0
- mlflow/tracking/context/__init__.py +0 -0
- mlflow/tracking/context/abstract_context.py +35 -0
- mlflow/tracking/context/databricks_cluster_context.py +15 -0
- mlflow/tracking/context/databricks_command_context.py +15 -0
- mlflow/tracking/context/databricks_job_context.py +49 -0
- mlflow/tracking/context/databricks_notebook_context.py +41 -0
- mlflow/tracking/context/databricks_repo_context.py +43 -0
- mlflow/tracking/context/default_context.py +51 -0
- mlflow/tracking/context/git_context.py +32 -0
- mlflow/tracking/context/registry.py +98 -0
- mlflow/tracking/context/system_environment_context.py +15 -0
- mlflow/tracking/default_experiment/__init__.py +1 -0
- mlflow/tracking/default_experiment/abstract_context.py +43 -0
- mlflow/tracking/default_experiment/databricks_notebook_experiment_provider.py +44 -0
- mlflow/tracking/default_experiment/registry.py +75 -0
- mlflow/tracking/fluent.py +3595 -0
- mlflow/tracking/metric_value_conversion_utils.py +93 -0
- mlflow/tracking/multimedia.py +206 -0
- mlflow/tracking/registry.py +86 -0
- mlflow/tracking/request_auth/__init__.py +0 -0
- mlflow/tracking/request_auth/abstract_request_auth_provider.py +34 -0
- mlflow/tracking/request_auth/registry.py +60 -0
- mlflow/tracking/request_header/__init__.py +0 -0
- mlflow/tracking/request_header/abstract_request_header_provider.py +36 -0
- mlflow/tracking/request_header/databricks_request_header_provider.py +38 -0
- mlflow/tracking/request_header/default_request_header_provider.py +17 -0
- mlflow/tracking/request_header/registry.py +79 -0
- mlflow/transformers/__init__.py +2982 -0
- mlflow/transformers/flavor_config.py +258 -0
- mlflow/transformers/hub_utils.py +83 -0
- mlflow/transformers/llm_inference_utils.py +468 -0
- mlflow/transformers/model_io.py +301 -0
- mlflow/transformers/peft.py +51 -0
- mlflow/transformers/signature.py +183 -0
- mlflow/transformers/torch_utils.py +55 -0
- mlflow/types/__init__.py +21 -0
- mlflow/types/agent.py +270 -0
- mlflow/types/chat.py +240 -0
- mlflow/types/llm.py +935 -0
- mlflow/types/responses.py +139 -0
- mlflow/types/responses_helpers.py +416 -0
- mlflow/types/schema.py +1505 -0
- mlflow/types/type_hints.py +647 -0
- mlflow/types/utils.py +753 -0
- mlflow/utils/__init__.py +283 -0
- mlflow/utils/_capture_modules.py +256 -0
- mlflow/utils/_capture_transformers_modules.py +75 -0
- mlflow/utils/_spark_utils.py +201 -0
- mlflow/utils/_unity_catalog_oss_utils.py +97 -0
- mlflow/utils/_unity_catalog_utils.py +479 -0
- mlflow/utils/annotations.py +218 -0
- mlflow/utils/arguments_utils.py +16 -0
- mlflow/utils/async_logging/__init__.py +1 -0
- mlflow/utils/async_logging/async_artifacts_logging_queue.py +258 -0
- mlflow/utils/async_logging/async_logging_queue.py +366 -0
- mlflow/utils/async_logging/run_artifact.py +38 -0
- mlflow/utils/async_logging/run_batch.py +58 -0
- mlflow/utils/async_logging/run_operations.py +49 -0
- mlflow/utils/autologging_utils/__init__.py +737 -0
- mlflow/utils/autologging_utils/client.py +432 -0
- mlflow/utils/autologging_utils/config.py +33 -0
- mlflow/utils/autologging_utils/events.py +294 -0
- mlflow/utils/autologging_utils/logging_and_warnings.py +328 -0
- mlflow/utils/autologging_utils/metrics_queue.py +71 -0
- mlflow/utils/autologging_utils/safety.py +1104 -0
- mlflow/utils/autologging_utils/versioning.py +95 -0
- mlflow/utils/checkpoint_utils.py +206 -0
- mlflow/utils/class_utils.py +6 -0
- mlflow/utils/cli_args.py +257 -0
- mlflow/utils/conda.py +354 -0
- mlflow/utils/credentials.py +231 -0
- mlflow/utils/data_utils.py +17 -0
- mlflow/utils/databricks_utils.py +1436 -0
- mlflow/utils/docstring_utils.py +477 -0
- mlflow/utils/doctor.py +133 -0
- mlflow/utils/download_cloud_file_chunk.py +43 -0
- mlflow/utils/env_manager.py +16 -0
- mlflow/utils/env_pack.py +131 -0
- mlflow/utils/environment.py +1009 -0
- mlflow/utils/exception_utils.py +14 -0
- mlflow/utils/file_utils.py +978 -0
- mlflow/utils/git_utils.py +77 -0
- mlflow/utils/gorilla.py +797 -0
- mlflow/utils/import_hooks/__init__.py +363 -0
- mlflow/utils/lazy_load.py +51 -0
- mlflow/utils/logging_utils.py +168 -0
- mlflow/utils/mime_type_utils.py +58 -0
- mlflow/utils/mlflow_tags.py +103 -0
- mlflow/utils/model_utils.py +486 -0
- mlflow/utils/name_utils.py +346 -0
- mlflow/utils/nfs_on_spark.py +62 -0
- mlflow/utils/openai_utils.py +164 -0
- mlflow/utils/os.py +12 -0
- mlflow/utils/oss_registry_utils.py +29 -0
- mlflow/utils/plugins.py +17 -0
- mlflow/utils/process.py +182 -0
- mlflow/utils/promptlab_utils.py +146 -0
- mlflow/utils/proto_json_utils.py +743 -0
- mlflow/utils/pydantic_utils.py +54 -0
- mlflow/utils/request_utils.py +279 -0
- mlflow/utils/requirements_utils.py +704 -0
- mlflow/utils/rest_utils.py +673 -0
- mlflow/utils/search_logged_model_utils.py +127 -0
- mlflow/utils/search_utils.py +2111 -0
- mlflow/utils/secure_loading.py +221 -0
- mlflow/utils/security_validation.py +384 -0
- mlflow/utils/server_cli_utils.py +61 -0
- mlflow/utils/spark_utils.py +15 -0
- mlflow/utils/string_utils.py +138 -0
- mlflow/utils/thread_utils.py +63 -0
- mlflow/utils/time.py +54 -0
- mlflow/utils/timeout.py +42 -0
- mlflow/utils/uri.py +572 -0
- mlflow/utils/validation.py +662 -0
- mlflow/utils/virtualenv.py +458 -0
- mlflow/utils/warnings_utils.py +25 -0
- mlflow/utils/yaml_utils.py +179 -0
- mlflow/version.py +24 -0
File without changes
|
@@ -0,0 +1,482 @@
|
|
1
|
+
# This module is copied from legacy databricks CLI python library
|
2
|
+
# module `databricks_cli.configure.provider`,
|
3
|
+
# but with some modification to make `EnvironmentVariableConfigProvider` supporting
|
4
|
+
# 'DATABRICKS_CLIENT_ID' and 'DATABRICKS_CLIENT_SECRET' environmental variables,
|
5
|
+
# and make ProfileConfigProvider supporting 'databricks-cli' authentication way,
|
6
|
+
# 'databricks-cli' authentication way is for supporting U2M authentication.
|
7
|
+
#
|
8
|
+
# This is the original legacy databricks CLI python library provider module code:
|
9
|
+
# https://github.com/databricks/databricks-cli/blob/0.18.0/databricks_cli/configure/provider.py
|
10
|
+
#
|
11
|
+
# The latest Databricks Runtime does not contain legacy databricks CLI
|
12
|
+
# but MLflow still depends on it.
|
13
|
+
|
14
|
+
import logging
|
15
|
+
import os
|
16
|
+
import sys
|
17
|
+
import time
|
18
|
+
from abc import ABCMeta, abstractmethod
|
19
|
+
from configparser import ConfigParser
|
20
|
+
from os.path import expanduser, join
|
21
|
+
|
22
|
+
_logger = logging.getLogger(__name__)
|
23
|
+
|
24
|
+
_home = expanduser("~")
|
25
|
+
CONFIG_FILE_ENV_VAR = "DATABRICKS_CONFIG_FILE"
|
26
|
+
HOST = "host"
|
27
|
+
USERNAME = "username"
|
28
|
+
PASSWORD = "password"
|
29
|
+
TOKEN = "token"
|
30
|
+
REFRESH_TOKEN = "refresh_token"
|
31
|
+
INSECURE = "insecure"
|
32
|
+
JOBS_API_VERSION = "jobs-api-version"
|
33
|
+
DEFAULT_SECTION = "DEFAULT"
|
34
|
+
CLIENT_ID = "client_id"
|
35
|
+
CLIENT_SECRET = "client_secret"
|
36
|
+
AUTH_TYPE = "auth_type"
|
37
|
+
|
38
|
+
# User-provided override for the DatabricksConfigProvider
|
39
|
+
_config_provider = None
|
40
|
+
|
41
|
+
|
42
|
+
class InvalidConfigurationError(RuntimeError):
|
43
|
+
@staticmethod
|
44
|
+
def for_profile(profile):
|
45
|
+
if profile is None:
|
46
|
+
return InvalidConfigurationError(
|
47
|
+
"You haven't configured the CLI yet! "
|
48
|
+
f"Please configure by entering `{sys.argv[0]} configure`"
|
49
|
+
)
|
50
|
+
return InvalidConfigurationError(
|
51
|
+
f"You haven't configured the CLI yet for the profile {profile}! "
|
52
|
+
"Please configure by entering "
|
53
|
+
f"`{sys.argv[0]} configure --profile {profile}`"
|
54
|
+
)
|
55
|
+
|
56
|
+
|
57
|
+
def _get_path():
|
58
|
+
return os.environ.get(CONFIG_FILE_ENV_VAR, join(_home, ".databrickscfg"))
|
59
|
+
|
60
|
+
|
61
|
+
def _fetch_from_fs():
|
62
|
+
raw_config = ConfigParser()
|
63
|
+
raw_config.read(_get_path())
|
64
|
+
return raw_config
|
65
|
+
|
66
|
+
|
67
|
+
def _create_section_if_absent(raw_config, profile):
|
68
|
+
if not raw_config.has_section(profile) and profile != DEFAULT_SECTION:
|
69
|
+
raw_config.add_section(profile)
|
70
|
+
|
71
|
+
|
72
|
+
def _get_option_if_exists(raw_config, profile, option):
|
73
|
+
if profile == DEFAULT_SECTION:
|
74
|
+
# We must handle the DEFAULT_SECTION differently since it is not in the _sections property
|
75
|
+
# of raw config.
|
76
|
+
return raw_config.get(profile, option) if raw_config.has_option(profile, option) else None
|
77
|
+
# Check if option is defined in the profile.
|
78
|
+
elif option not in raw_config._sections.get(profile, {}).keys():
|
79
|
+
return None
|
80
|
+
return raw_config.get(profile, option)
|
81
|
+
|
82
|
+
|
83
|
+
def _set_option(raw_config, profile, option, value):
|
84
|
+
if value:
|
85
|
+
raw_config.set(profile, option, value)
|
86
|
+
else:
|
87
|
+
raw_config.remove_option(profile, option)
|
88
|
+
|
89
|
+
|
90
|
+
def _overwrite_config(raw_config):
|
91
|
+
config_path = _get_path()
|
92
|
+
# Create config file with owner only rw permissions
|
93
|
+
if not os.path.exists(config_path):
|
94
|
+
file_descriptor = os.open(config_path, os.O_CREAT | os.O_RDWR, 0o600)
|
95
|
+
os.close(file_descriptor)
|
96
|
+
|
97
|
+
# Change file permissions to owner only rw if that's not the case
|
98
|
+
if not os.stat(config_path).st_mode == 0o100600:
|
99
|
+
os.chmod(config_path, 0o600)
|
100
|
+
|
101
|
+
with open(config_path, "w") as cfg:
|
102
|
+
raw_config.write(cfg)
|
103
|
+
|
104
|
+
|
105
|
+
def update_and_persist_config(profile, databricks_config):
|
106
|
+
"""
|
107
|
+
Takes a DatabricksConfig and adds the in memory contents to the persisted version of the
|
108
|
+
config. This will overwrite any other config that was persisted to the file system under the
|
109
|
+
same profile.
|
110
|
+
|
111
|
+
Args:
|
112
|
+
profile: str
|
113
|
+
databricks_config: DatabricksConfig
|
114
|
+
"""
|
115
|
+
profile = profile if profile else DEFAULT_SECTION
|
116
|
+
raw_config = _fetch_from_fs()
|
117
|
+
_create_section_if_absent(raw_config, profile)
|
118
|
+
_set_option(raw_config, profile, HOST, databricks_config.host)
|
119
|
+
_set_option(raw_config, profile, USERNAME, databricks_config.username)
|
120
|
+
_set_option(raw_config, profile, PASSWORD, databricks_config.password)
|
121
|
+
_set_option(raw_config, profile, TOKEN, databricks_config.token)
|
122
|
+
_set_option(raw_config, profile, REFRESH_TOKEN, databricks_config.refresh_token)
|
123
|
+
_set_option(raw_config, profile, INSECURE, databricks_config.insecure)
|
124
|
+
_set_option(raw_config, profile, JOBS_API_VERSION, databricks_config.jobs_api_version)
|
125
|
+
_overwrite_config(raw_config)
|
126
|
+
|
127
|
+
|
128
|
+
def get_config():
|
129
|
+
"""
|
130
|
+
Returns a DatabricksConfig containing the hostname and authentication used to talk to
|
131
|
+
the Databricks API. By default, we leverage the DefaultConfigProvider to get
|
132
|
+
this config, but this behavior may be overridden by calling 'set_config_provider'
|
133
|
+
|
134
|
+
If no DatabricksConfig can be found, an InvalidConfigurationError will be raised.
|
135
|
+
"""
|
136
|
+
if _config_provider:
|
137
|
+
config = _config_provider.get_config()
|
138
|
+
if config:
|
139
|
+
return config
|
140
|
+
raise InvalidConfigurationError(
|
141
|
+
f"Custom provider returned no DatabricksConfig: {_config_provider}"
|
142
|
+
)
|
143
|
+
|
144
|
+
config = DefaultConfigProvider().get_config()
|
145
|
+
if config:
|
146
|
+
return config
|
147
|
+
raise InvalidConfigurationError.for_profile(None)
|
148
|
+
|
149
|
+
|
150
|
+
def get_config_for_profile(profile):
|
151
|
+
"""
|
152
|
+
[Deprecated] Reads from the filesystem and gets a DatabricksConfig for the
|
153
|
+
specified profile. If it does not exist, then return a DatabricksConfig with fields set
|
154
|
+
to None.
|
155
|
+
|
156
|
+
Internal callers should prefer get_config() to use user-specified overrides, and
|
157
|
+
to return appropriate error messages as opposited to invalid configurations.
|
158
|
+
|
159
|
+
If you want to read from a specific profile, please instead use
|
160
|
+
'ProfileConfigProvider(profile).get_config()'.
|
161
|
+
|
162
|
+
This method is maintained for backwards-compatibility. It may be removed in future versions.
|
163
|
+
|
164
|
+
Returns:
|
165
|
+
DatabricksConfig
|
166
|
+
"""
|
167
|
+
profile = profile if profile else DEFAULT_SECTION
|
168
|
+
config = EnvironmentVariableConfigProvider().get_config()
|
169
|
+
if config and config.is_valid:
|
170
|
+
return config
|
171
|
+
|
172
|
+
config = ProfileConfigProvider(profile).get_config()
|
173
|
+
if config:
|
174
|
+
return config
|
175
|
+
return DatabricksConfig.empty()
|
176
|
+
|
177
|
+
|
178
|
+
def set_config_provider(provider):
|
179
|
+
"""
|
180
|
+
Sets a DatabricksConfigProvider that will be used for all future calls to get_config(),
|
181
|
+
used by the Databricks CLI code to discover the user's credentials.
|
182
|
+
"""
|
183
|
+
global _config_provider
|
184
|
+
if provider and not isinstance(provider, DatabricksConfigProvider):
|
185
|
+
raise Exception(f"Must be instance of DatabricksConfigProvider: {_config_provider}")
|
186
|
+
_config_provider = provider
|
187
|
+
|
188
|
+
|
189
|
+
def get_config_provider():
|
190
|
+
"""
|
191
|
+
Returns the current DatabricksConfigProvider.
|
192
|
+
If None, the DefaultConfigProvider will be used.
|
193
|
+
"""
|
194
|
+
return _config_provider
|
195
|
+
|
196
|
+
|
197
|
+
class DatabricksConfigProvider:
|
198
|
+
"""
|
199
|
+
Responsible for providing hostname and authentication information to make
|
200
|
+
API requests against the Databricks REST API.
|
201
|
+
This method should generally return None if it cannot provide credentials, in order
|
202
|
+
to facilitate chanining of providers.
|
203
|
+
"""
|
204
|
+
|
205
|
+
__metaclass__ = ABCMeta
|
206
|
+
|
207
|
+
@abstractmethod
|
208
|
+
def get_config(self):
|
209
|
+
pass
|
210
|
+
|
211
|
+
|
212
|
+
class DefaultConfigProvider(DatabricksConfigProvider):
|
213
|
+
"""Look for credentials in a chain of default locations."""
|
214
|
+
|
215
|
+
def __init__(self):
|
216
|
+
# The order of providers here will be used to determine
|
217
|
+
# the precedence order for the config provider used in `get_config`
|
218
|
+
self._providers = (
|
219
|
+
SparkTaskContextConfigProvider(),
|
220
|
+
EnvironmentVariableConfigProvider(),
|
221
|
+
ProfileConfigProvider(),
|
222
|
+
DatabricksModelServingConfigProvider(),
|
223
|
+
)
|
224
|
+
|
225
|
+
def get_config(self):
|
226
|
+
for provider in self._providers:
|
227
|
+
config = provider.get_config()
|
228
|
+
if config is not None and config.is_valid:
|
229
|
+
return config
|
230
|
+
return None
|
231
|
+
|
232
|
+
|
233
|
+
class SparkTaskContextConfigProvider(DatabricksConfigProvider):
|
234
|
+
"""Loads credentials from Spark TaskContext if running in a Spark Executor."""
|
235
|
+
|
236
|
+
@staticmethod
|
237
|
+
def _get_spark_task_context_or_none():
|
238
|
+
try:
|
239
|
+
from pyspark import TaskContext
|
240
|
+
|
241
|
+
return TaskContext.get()
|
242
|
+
except ImportError:
|
243
|
+
return None
|
244
|
+
|
245
|
+
@staticmethod
|
246
|
+
def set_insecure(x):
|
247
|
+
from pyspark import SparkContext
|
248
|
+
|
249
|
+
new_val = "True" if x else None
|
250
|
+
SparkContext._active_spark_context.setLocalProperty("spark.databricks.ignoreTls", new_val)
|
251
|
+
|
252
|
+
def get_config(self):
|
253
|
+
context = self._get_spark_task_context_or_none()
|
254
|
+
if context is not None:
|
255
|
+
host = context.getLocalProperty("spark.databricks.api.url")
|
256
|
+
token = context.getLocalProperty("spark.databricks.token")
|
257
|
+
insecure = context.getLocalProperty("spark.databricks.ignoreTls")
|
258
|
+
config = DatabricksConfig.from_token(
|
259
|
+
host=host, token=token, refresh_token=None, insecure=insecure, jobs_api_version=None
|
260
|
+
)
|
261
|
+
if config.is_valid:
|
262
|
+
return config
|
263
|
+
return None
|
264
|
+
|
265
|
+
|
266
|
+
class EnvironmentVariableConfigProvider(DatabricksConfigProvider):
|
267
|
+
"""Loads from system environment variables."""
|
268
|
+
|
269
|
+
def get_config(self):
|
270
|
+
host = os.environ.get("DATABRICKS_HOST")
|
271
|
+
username = os.environ.get("DATABRICKS_USERNAME")
|
272
|
+
password = os.environ.get("DATABRICKS_PASSWORD")
|
273
|
+
token = os.environ.get("DATABRICKS_TOKEN")
|
274
|
+
refresh_token = os.environ.get("DATABRICKS_REFRESH_TOKEN")
|
275
|
+
insecure = os.environ.get("DATABRICKS_INSECURE")
|
276
|
+
jobs_api_version = os.environ.get("DATABRICKS_JOBS_API_VERSION")
|
277
|
+
client_id = os.environ.get("DATABRICKS_CLIENT_ID")
|
278
|
+
client_secret = os.environ.get("DATABRICKS_CLIENT_SECRET")
|
279
|
+
|
280
|
+
config = DatabricksConfig(
|
281
|
+
host,
|
282
|
+
username,
|
283
|
+
password,
|
284
|
+
token,
|
285
|
+
refresh_token,
|
286
|
+
insecure,
|
287
|
+
jobs_api_version,
|
288
|
+
client_id=client_id,
|
289
|
+
client_secret=client_secret,
|
290
|
+
)
|
291
|
+
if config.is_valid:
|
292
|
+
return config
|
293
|
+
return None
|
294
|
+
|
295
|
+
|
296
|
+
class ProfileConfigProvider(DatabricksConfigProvider):
|
297
|
+
"""Loads from the databrickscfg file."""
|
298
|
+
|
299
|
+
def __init__(self, profile=None):
|
300
|
+
self.profile = profile or DEFAULT_SECTION
|
301
|
+
|
302
|
+
def get_config(self):
|
303
|
+
raw_config = _fetch_from_fs()
|
304
|
+
host = _get_option_if_exists(raw_config, self.profile, HOST)
|
305
|
+
username = _get_option_if_exists(raw_config, self.profile, USERNAME)
|
306
|
+
password = _get_option_if_exists(raw_config, self.profile, PASSWORD)
|
307
|
+
token = _get_option_if_exists(raw_config, self.profile, TOKEN)
|
308
|
+
refresh_token = _get_option_if_exists(raw_config, self.profile, REFRESH_TOKEN)
|
309
|
+
insecure = _get_option_if_exists(raw_config, self.profile, INSECURE)
|
310
|
+
jobs_api_version = _get_option_if_exists(raw_config, self.profile, JOBS_API_VERSION)
|
311
|
+
client_id = _get_option_if_exists(raw_config, self.profile, CLIENT_ID)
|
312
|
+
client_secret = _get_option_if_exists(raw_config, self.profile, CLIENT_SECRET)
|
313
|
+
auth_type = _get_option_if_exists(raw_config, self.profile, AUTH_TYPE)
|
314
|
+
config = DatabricksConfig(
|
315
|
+
host,
|
316
|
+
username,
|
317
|
+
password,
|
318
|
+
token,
|
319
|
+
refresh_token,
|
320
|
+
insecure,
|
321
|
+
jobs_api_version,
|
322
|
+
client_id=client_id,
|
323
|
+
client_secret=client_secret,
|
324
|
+
auth_type=auth_type,
|
325
|
+
)
|
326
|
+
if config.is_valid:
|
327
|
+
return config
|
328
|
+
return None
|
329
|
+
|
330
|
+
|
331
|
+
class DatabricksModelServingConfigProvider(DatabricksConfigProvider):
|
332
|
+
"""Loads from OAuth credentials in the Databricks Model Serving environment."""
|
333
|
+
|
334
|
+
def get_config(self):
|
335
|
+
from mlflow.utils.databricks_utils import should_fetch_model_serving_environment_oauth
|
336
|
+
|
337
|
+
try:
|
338
|
+
if should_fetch_model_serving_environment_oauth():
|
339
|
+
config = DatabricksModelServingConfigProvider._get_databricks_model_serving_config()
|
340
|
+
if config.is_valid:
|
341
|
+
return config
|
342
|
+
else:
|
343
|
+
return None
|
344
|
+
except Exception as e:
|
345
|
+
_logger.warning("Unexpected error resolving Databricks Model Serving config: %s", e)
|
346
|
+
|
347
|
+
@staticmethod
|
348
|
+
def _get_databricks_model_serving_config():
|
349
|
+
from mlflow.utils.databricks_utils import get_model_dependency_oauth_token
|
350
|
+
|
351
|
+
# Since we do not record OAuth expiration time in OAuth file, perform periodic refresh
|
352
|
+
# of OAuth environment variable cache here. As currently configured (02/24) OAuth token
|
353
|
+
# in model serving environment is guaranteed to have at least 30 min remaining on TTL
|
354
|
+
# at any point in time but refresh at higher rate of every 5 min here to be safe
|
355
|
+
# and conform with refresh logic for Brickstore tables.
|
356
|
+
OAUTH_CACHE_REFRESH_DURATION_SEC = 5 * 60
|
357
|
+
OAUTH_CACHE_ENV_VAR = "DB_DEPENDENCY_OAUTH_CACHE"
|
358
|
+
OAUTH_CACHE_EXPIRATION_ENV_VAR = "DB_DEPENDENCY_OAUTH_CACHE_EXPIRY_TS"
|
359
|
+
MODEL_SERVING_HOST_ENV_VAR = "DATABRICKS_MODEL_SERVING_HOST_URL"
|
360
|
+
DB_MODEL_SERVING_HOST_ENV_VAR = "DB_MODEL_SERVING_HOST_URL"
|
361
|
+
|
362
|
+
# read from DB_MODEL_SERVING_HOST_ENV_VAR if available otherwise MODEL_SERVING_HOST_ENV_VAR
|
363
|
+
host = os.environ.get(DB_MODEL_SERVING_HOST_ENV_VAR) or os.environ.get(
|
364
|
+
MODEL_SERVING_HOST_ENV_VAR
|
365
|
+
)
|
366
|
+
|
367
|
+
# check if dependency is cached in env var before reading from file
|
368
|
+
oauth_token = ""
|
369
|
+
if (
|
370
|
+
OAUTH_CACHE_ENV_VAR in os.environ
|
371
|
+
and OAUTH_CACHE_EXPIRATION_ENV_VAR in os.environ
|
372
|
+
and float(os.environ[OAUTH_CACHE_EXPIRATION_ENV_VAR]) > time.time()
|
373
|
+
):
|
374
|
+
oauth_token = os.environ[OAUTH_CACHE_ENV_VAR]
|
375
|
+
else:
|
376
|
+
oauth_token = get_model_dependency_oauth_token()
|
377
|
+
os.environ[OAUTH_CACHE_ENV_VAR] = oauth_token
|
378
|
+
os.environ[OAUTH_CACHE_EXPIRATION_ENV_VAR] = str(
|
379
|
+
time.time() + OAUTH_CACHE_REFRESH_DURATION_SEC
|
380
|
+
)
|
381
|
+
|
382
|
+
return DatabricksConfig(
|
383
|
+
host=host,
|
384
|
+
token=oauth_token,
|
385
|
+
username=None,
|
386
|
+
password=None,
|
387
|
+
refresh_token=None,
|
388
|
+
insecure=None,
|
389
|
+
jobs_api_version=None,
|
390
|
+
)
|
391
|
+
|
392
|
+
|
393
|
+
class DatabricksConfig:
|
394
|
+
def __init__(
|
395
|
+
self,
|
396
|
+
host,
|
397
|
+
username,
|
398
|
+
password,
|
399
|
+
token,
|
400
|
+
refresh_token=None,
|
401
|
+
insecure=None,
|
402
|
+
jobs_api_version=None,
|
403
|
+
client_id=None,
|
404
|
+
client_secret=None,
|
405
|
+
auth_type=None,
|
406
|
+
):
|
407
|
+
self.host = host
|
408
|
+
self.username = username
|
409
|
+
self.password = password
|
410
|
+
self.token = token
|
411
|
+
self.refresh_token = refresh_token
|
412
|
+
self.insecure = insecure
|
413
|
+
self.jobs_api_version = jobs_api_version
|
414
|
+
self.client_id = client_id
|
415
|
+
self.client_secret = client_secret
|
416
|
+
self.auth_type = auth_type
|
417
|
+
|
418
|
+
@classmethod
|
419
|
+
def from_token(cls, host, token, refresh_token=None, insecure=None, jobs_api_version=None):
|
420
|
+
return DatabricksConfig(
|
421
|
+
host=host,
|
422
|
+
username=None,
|
423
|
+
password=None,
|
424
|
+
token=token,
|
425
|
+
refresh_token=refresh_token,
|
426
|
+
insecure=insecure,
|
427
|
+
jobs_api_version=jobs_api_version,
|
428
|
+
)
|
429
|
+
|
430
|
+
@classmethod
|
431
|
+
def from_password(cls, host, username, password, insecure=None, jobs_api_version=None):
|
432
|
+
return DatabricksConfig(
|
433
|
+
host=host,
|
434
|
+
username=username,
|
435
|
+
password=password,
|
436
|
+
token=None,
|
437
|
+
refresh_token=None,
|
438
|
+
insecure=insecure,
|
439
|
+
jobs_api_version=jobs_api_version,
|
440
|
+
)
|
441
|
+
|
442
|
+
@classmethod
|
443
|
+
def empty(cls):
|
444
|
+
return DatabricksConfig(
|
445
|
+
host=None,
|
446
|
+
username=None,
|
447
|
+
password=None,
|
448
|
+
token=None,
|
449
|
+
refresh_token=None,
|
450
|
+
insecure=None,
|
451
|
+
jobs_api_version=None,
|
452
|
+
)
|
453
|
+
|
454
|
+
@property
|
455
|
+
def is_valid_with_token(self):
|
456
|
+
return self.host is not None and self.token is not None
|
457
|
+
|
458
|
+
@property
|
459
|
+
def is_valid_with_password(self):
|
460
|
+
return self.host is not None and self.username is not None and self.password is not None
|
461
|
+
|
462
|
+
@property
|
463
|
+
def is_valid_with_client_id_secret(self):
|
464
|
+
return self.host and self.client_id and self.client_secret
|
465
|
+
|
466
|
+
@property
|
467
|
+
def is_databricks_cli_auth_type(self):
|
468
|
+
return self.auth_type == "databricks-cli"
|
469
|
+
|
470
|
+
@property
|
471
|
+
def is_azure_cli_auth_type(self):
|
472
|
+
return self.auth_type == "azure-cli"
|
473
|
+
|
474
|
+
@property
|
475
|
+
def is_valid(self):
|
476
|
+
return (
|
477
|
+
self.is_valid_with_token
|
478
|
+
or self.is_valid_with_password
|
479
|
+
or self.is_valid_with_client_id_secret
|
480
|
+
or self.is_databricks_cli_auth_type
|
481
|
+
or self.is_azure_cli_auth_type
|
482
|
+
)
|
@@ -0,0 +1,175 @@
|
|
1
|
+
import importlib.metadata
|
2
|
+
import logging
|
3
|
+
from contextlib import contextmanager
|
4
|
+
from threading import Thread
|
5
|
+
|
6
|
+
from packaging.version import Version
|
7
|
+
|
8
|
+
from mlflow.utils.annotations import experimental
|
9
|
+
from mlflow.utils.autologging_utils import (
|
10
|
+
autologging_integration,
|
11
|
+
safe_patch,
|
12
|
+
)
|
13
|
+
from mlflow.utils.databricks_utils import is_in_databricks_runtime
|
14
|
+
|
15
|
+
FLAVOR_NAME = "litellm"
|
16
|
+
|
17
|
+
_logger = logging.getLogger(__name__)
|
18
|
+
|
19
|
+
|
20
|
+
@experimental(version="2.19.0")
|
21
|
+
def autolog(
|
22
|
+
log_traces: bool = True,
|
23
|
+
disable: bool = False,
|
24
|
+
silent: bool = False,
|
25
|
+
):
|
26
|
+
"""
|
27
|
+
Enables (or disables) and configures autologging from LiteLLM to MLflow. Currently, MLflow
|
28
|
+
only supports autologging for tracing.
|
29
|
+
|
30
|
+
Args:
|
31
|
+
log_traces: If ``True``, traces are logged for LiteLLM calls. If ``False``,
|
32
|
+
no traces are collected during inference. Default to ``True``.
|
33
|
+
disable: If ``True``, disables the LiteLLM autologging integration. If ``False``,
|
34
|
+
enables the LiteLLM autologging integration.
|
35
|
+
silent: If ``True``, suppress all event logs and warnings from MLflow during LiteLLM
|
36
|
+
autologging. If ``False``, show all events and warnings.
|
37
|
+
"""
|
38
|
+
import litellm
|
39
|
+
|
40
|
+
# This needs to be called before doing any safe-patching (otherwise safe-patch will be no-op).
|
41
|
+
# TODO: since this implementation is inconsistent, explore a universal way to solve the issue.
|
42
|
+
_autolog(log_traces=log_traces, disable=disable, silent=silent)
|
43
|
+
|
44
|
+
try:
|
45
|
+
from litellm.integrations.mlflow import MlflowLogger
|
46
|
+
except ImportError:
|
47
|
+
_logger.warning(
|
48
|
+
"MLflow LiteLLM integration is not supported for the installed LiteLLM version. "
|
49
|
+
"Please upgrade to a newer version to enable MLflow LiteLLM autologging."
|
50
|
+
)
|
51
|
+
return
|
52
|
+
|
53
|
+
if log_traces and not disable:
|
54
|
+
litellm.success_callback = _append_mlflow_callbacks(litellm.success_callback)
|
55
|
+
litellm.failure_callback = _append_mlflow_callbacks(litellm.failure_callback)
|
56
|
+
|
57
|
+
# Workaround for https://github.com/BerriAI/litellm/issues/8013
|
58
|
+
# TODO: Add upper bound version check when the issue is fixed.
|
59
|
+
if Version(importlib.metadata.version("litellm")) >= Version("1.59.4"):
|
60
|
+
litellm.failure_callback = [
|
61
|
+
cb if cb != "mlflow" else MlflowLogger() for cb in litellm.failure_callback
|
62
|
+
]
|
63
|
+
|
64
|
+
if is_in_databricks_runtime():
|
65
|
+
# Patch main APIs e.g. completion to inject custom handling for threading.
|
66
|
+
# By default, those API will start a new thread when calling log_success_event()
|
67
|
+
# handler of the logging callbacks and never wait for it to finish. This is
|
68
|
+
# problematic in Databricks notebook, because the inline trace UI display
|
69
|
+
# assumes that the trace is generated synchronously. If the trace is generated
|
70
|
+
# asynchronously, it will be displayed in different later cells.
|
71
|
+
# To workaround this issue, we monkey-patch these APIs to wait for the logging
|
72
|
+
# threads to finish before returning the result.
|
73
|
+
# This is not required for OSS environment where we don't show inline trace UI.
|
74
|
+
for func in [
|
75
|
+
"completion",
|
76
|
+
"embedding",
|
77
|
+
"text_completion",
|
78
|
+
"image_generation",
|
79
|
+
"transcription",
|
80
|
+
"speech",
|
81
|
+
]:
|
82
|
+
_patch_threading_in_function(litellm, func)
|
83
|
+
|
84
|
+
# For streaming case, we need to patch the iterator because traces are generated
|
85
|
+
# when consuming the generator, not when calling the main APIs.
|
86
|
+
_patch_threading_in_function(litellm.utils.CustomStreamWrapper, "__next__")
|
87
|
+
|
88
|
+
# NB: We don't need to patch async function because Databricks notebook waits
|
89
|
+
# for the async task to finish before finishing the cell.
|
90
|
+
else:
|
91
|
+
litellm.success_callback = _remove_mlflow_callbacks(litellm.success_callback)
|
92
|
+
litellm.failure_callback = _remove_mlflow_callbacks(litellm.failure_callback)
|
93
|
+
# Callback also needs to be removed from 'callbacks' as litellm adds
|
94
|
+
# success/failure callbacks to there as well.
|
95
|
+
litellm.callbacks = _remove_mlflow_callbacks(litellm.callbacks)
|
96
|
+
|
97
|
+
|
98
|
+
# This is required by mlflow.autolog()
|
99
|
+
autolog.integration_name = FLAVOR_NAME
|
100
|
+
|
101
|
+
|
102
|
+
# NB: The @autologging_integration annotation must be applied here, and the callback injection
|
103
|
+
# needs to happen outside the annotated function. This is because the annotated function is NOT
|
104
|
+
# executed when disable=True is passed. This prevents us from removing our callback and patching
|
105
|
+
# when autologging is turned off.
|
106
|
+
@autologging_integration(FLAVOR_NAME)
|
107
|
+
def _autolog(
|
108
|
+
log_traces: bool,
|
109
|
+
disable: bool = False,
|
110
|
+
silent: bool = False,
|
111
|
+
):
|
112
|
+
pass
|
113
|
+
|
114
|
+
|
115
|
+
def _patch_threading_in_function(target, function_name: str):
|
116
|
+
"""
|
117
|
+
Apply the threading patch to a synchronous function.
|
118
|
+
|
119
|
+
We capture the threads started by the function using the _patch_thread_start context manager,
|
120
|
+
then join them to ensure they are finished before the notebook cell finishes executing.
|
121
|
+
"""
|
122
|
+
|
123
|
+
def _patch_fn(original, *args, **kwargs):
|
124
|
+
with _patch_thread_start() as logging_threads:
|
125
|
+
result = original(*args, **kwargs)
|
126
|
+
for thread in logging_threads:
|
127
|
+
thread.join()
|
128
|
+
return result
|
129
|
+
|
130
|
+
safe_patch(FLAVOR_NAME, target, function_name, _patch_fn)
|
131
|
+
|
132
|
+
|
133
|
+
@contextmanager
|
134
|
+
def _patch_thread_start():
|
135
|
+
"""
|
136
|
+
A context manager to collect threads started for logging handlers.
|
137
|
+
This is done by monkey-patching the start() method of threading.Thread.
|
138
|
+
Note that failure handlers are executed synchronously, so we don't need to patch them.
|
139
|
+
"""
|
140
|
+
original = Thread.start
|
141
|
+
logging_threads = []
|
142
|
+
|
143
|
+
def patched_thread(self, *args, **kwargs):
|
144
|
+
target = getattr(self, "_target", None)
|
145
|
+
# success_handler is for normal request, and run_success_... is for streaming
|
146
|
+
# - https://github.com/BerriAI/litellm/blob/4f8a3fd4cfc20cf43b38379928b41c2691c85d36/litellm/utils.py#L946
|
147
|
+
# - https://github.com/BerriAI/litellm/blob/4f8a3fd4cfc20cf43b38379928b41c2691c85d36/litellm/utils.py#L7526
|
148
|
+
if target and target.__name__ in [
|
149
|
+
"success_handler",
|
150
|
+
"run_success_logging_and_cache_storage",
|
151
|
+
]:
|
152
|
+
logging_threads.append(self)
|
153
|
+
return original(self, *args, **kwargs)
|
154
|
+
|
155
|
+
Thread.start = patched_thread
|
156
|
+
try:
|
157
|
+
yield logging_threads
|
158
|
+
finally:
|
159
|
+
Thread.start = original
|
160
|
+
|
161
|
+
|
162
|
+
def _append_mlflow_callbacks(callbacks):
|
163
|
+
from litellm.integrations.mlflow import MlflowLogger
|
164
|
+
|
165
|
+
# MLflow callback can be stored as a string or the actual logger object
|
166
|
+
if not any(cb == "mlflow" or isinstance(cb, MlflowLogger) for cb in callbacks):
|
167
|
+
return callbacks + ["mlflow"]
|
168
|
+
|
169
|
+
return callbacks
|
170
|
+
|
171
|
+
|
172
|
+
def _remove_mlflow_callbacks(callbacks):
|
173
|
+
from litellm.integrations.mlflow import MlflowLogger
|
174
|
+
|
175
|
+
return [cb for cb in callbacks if not (cb == "mlflow" or isinstance(cb, MlflowLogger))]
|
@@ -0,0 +1,22 @@
|
|
1
|
+
from mlflow.llama_index.autolog import autolog
|
2
|
+
from mlflow.llama_index.constant import FLAVOR_NAME
|
3
|
+
from mlflow.version import IS_TRACING_SDK_ONLY
|
4
|
+
|
5
|
+
__all__ = ["autolog", "FLAVOR_NAME"]
|
6
|
+
|
7
|
+
# Import model logging APIs only if mlflow skinny or full package is installed,
|
8
|
+
# i.e., skip if only mlflow-tracing package is installed.
|
9
|
+
if not IS_TRACING_SDK_ONLY:
|
10
|
+
from mlflow.llama_index.model import (
|
11
|
+
_load_pyfunc,
|
12
|
+
load_model,
|
13
|
+
log_model,
|
14
|
+
save_model,
|
15
|
+
)
|
16
|
+
|
17
|
+
__all__ += [
|
18
|
+
"load_model",
|
19
|
+
"log_model",
|
20
|
+
"save_model",
|
21
|
+
"_load_pyfunc",
|
22
|
+
]
|