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.
Files changed (645) hide show
  1. genesis_flow-1.0.0.dist-info/METADATA +822 -0
  2. genesis_flow-1.0.0.dist-info/RECORD +645 -0
  3. genesis_flow-1.0.0.dist-info/WHEEL +5 -0
  4. genesis_flow-1.0.0.dist-info/entry_points.txt +19 -0
  5. genesis_flow-1.0.0.dist-info/licenses/LICENSE.txt +202 -0
  6. genesis_flow-1.0.0.dist-info/top_level.txt +1 -0
  7. mlflow/__init__.py +367 -0
  8. mlflow/__main__.py +3 -0
  9. mlflow/ag2/__init__.py +56 -0
  10. mlflow/ag2/ag2_logger.py +294 -0
  11. mlflow/anthropic/__init__.py +40 -0
  12. mlflow/anthropic/autolog.py +129 -0
  13. mlflow/anthropic/chat.py +144 -0
  14. mlflow/artifacts/__init__.py +268 -0
  15. mlflow/autogen/__init__.py +144 -0
  16. mlflow/autogen/chat.py +142 -0
  17. mlflow/azure/__init__.py +26 -0
  18. mlflow/azure/auth_handler.py +257 -0
  19. mlflow/azure/client.py +319 -0
  20. mlflow/azure/config.py +120 -0
  21. mlflow/azure/connection_factory.py +340 -0
  22. mlflow/azure/exceptions.py +27 -0
  23. mlflow/azure/stores.py +327 -0
  24. mlflow/azure/utils.py +183 -0
  25. mlflow/bedrock/__init__.py +45 -0
  26. mlflow/bedrock/_autolog.py +202 -0
  27. mlflow/bedrock/chat.py +122 -0
  28. mlflow/bedrock/stream.py +160 -0
  29. mlflow/bedrock/utils.py +43 -0
  30. mlflow/cli.py +707 -0
  31. mlflow/client.py +12 -0
  32. mlflow/config/__init__.py +56 -0
  33. mlflow/crewai/__init__.py +79 -0
  34. mlflow/crewai/autolog.py +253 -0
  35. mlflow/crewai/chat.py +29 -0
  36. mlflow/data/__init__.py +75 -0
  37. mlflow/data/artifact_dataset_sources.py +170 -0
  38. mlflow/data/code_dataset_source.py +40 -0
  39. mlflow/data/dataset.py +123 -0
  40. mlflow/data/dataset_registry.py +168 -0
  41. mlflow/data/dataset_source.py +110 -0
  42. mlflow/data/dataset_source_registry.py +219 -0
  43. mlflow/data/delta_dataset_source.py +167 -0
  44. mlflow/data/digest_utils.py +108 -0
  45. mlflow/data/evaluation_dataset.py +562 -0
  46. mlflow/data/filesystem_dataset_source.py +81 -0
  47. mlflow/data/http_dataset_source.py +145 -0
  48. mlflow/data/huggingface_dataset.py +258 -0
  49. mlflow/data/huggingface_dataset_source.py +118 -0
  50. mlflow/data/meta_dataset.py +104 -0
  51. mlflow/data/numpy_dataset.py +223 -0
  52. mlflow/data/pandas_dataset.py +231 -0
  53. mlflow/data/polars_dataset.py +352 -0
  54. mlflow/data/pyfunc_dataset_mixin.py +31 -0
  55. mlflow/data/schema.py +76 -0
  56. mlflow/data/sources.py +1 -0
  57. mlflow/data/spark_dataset.py +406 -0
  58. mlflow/data/spark_dataset_source.py +74 -0
  59. mlflow/data/spark_delta_utils.py +118 -0
  60. mlflow/data/tensorflow_dataset.py +350 -0
  61. mlflow/data/uc_volume_dataset_source.py +81 -0
  62. mlflow/db.py +27 -0
  63. mlflow/dspy/__init__.py +17 -0
  64. mlflow/dspy/autolog.py +197 -0
  65. mlflow/dspy/callback.py +398 -0
  66. mlflow/dspy/constant.py +1 -0
  67. mlflow/dspy/load.py +93 -0
  68. mlflow/dspy/save.py +393 -0
  69. mlflow/dspy/util.py +109 -0
  70. mlflow/dspy/wrapper.py +226 -0
  71. mlflow/entities/__init__.py +104 -0
  72. mlflow/entities/_mlflow_object.py +52 -0
  73. mlflow/entities/assessment.py +545 -0
  74. mlflow/entities/assessment_error.py +80 -0
  75. mlflow/entities/assessment_source.py +141 -0
  76. mlflow/entities/dataset.py +92 -0
  77. mlflow/entities/dataset_input.py +51 -0
  78. mlflow/entities/dataset_summary.py +62 -0
  79. mlflow/entities/document.py +48 -0
  80. mlflow/entities/experiment.py +109 -0
  81. mlflow/entities/experiment_tag.py +35 -0
  82. mlflow/entities/file_info.py +45 -0
  83. mlflow/entities/input_tag.py +35 -0
  84. mlflow/entities/lifecycle_stage.py +35 -0
  85. mlflow/entities/logged_model.py +228 -0
  86. mlflow/entities/logged_model_input.py +26 -0
  87. mlflow/entities/logged_model_output.py +32 -0
  88. mlflow/entities/logged_model_parameter.py +46 -0
  89. mlflow/entities/logged_model_status.py +74 -0
  90. mlflow/entities/logged_model_tag.py +33 -0
  91. mlflow/entities/metric.py +200 -0
  92. mlflow/entities/model_registry/__init__.py +29 -0
  93. mlflow/entities/model_registry/_model_registry_entity.py +13 -0
  94. mlflow/entities/model_registry/model_version.py +243 -0
  95. mlflow/entities/model_registry/model_version_deployment_job_run_state.py +44 -0
  96. mlflow/entities/model_registry/model_version_deployment_job_state.py +70 -0
  97. mlflow/entities/model_registry/model_version_search.py +25 -0
  98. mlflow/entities/model_registry/model_version_stages.py +25 -0
  99. mlflow/entities/model_registry/model_version_status.py +35 -0
  100. mlflow/entities/model_registry/model_version_tag.py +35 -0
  101. mlflow/entities/model_registry/prompt.py +73 -0
  102. mlflow/entities/model_registry/prompt_version.py +244 -0
  103. mlflow/entities/model_registry/registered_model.py +175 -0
  104. mlflow/entities/model_registry/registered_model_alias.py +35 -0
  105. mlflow/entities/model_registry/registered_model_deployment_job_state.py +39 -0
  106. mlflow/entities/model_registry/registered_model_search.py +25 -0
  107. mlflow/entities/model_registry/registered_model_tag.py +35 -0
  108. mlflow/entities/multipart_upload.py +74 -0
  109. mlflow/entities/param.py +49 -0
  110. mlflow/entities/run.py +97 -0
  111. mlflow/entities/run_data.py +84 -0
  112. mlflow/entities/run_info.py +188 -0
  113. mlflow/entities/run_inputs.py +59 -0
  114. mlflow/entities/run_outputs.py +43 -0
  115. mlflow/entities/run_status.py +41 -0
  116. mlflow/entities/run_tag.py +36 -0
  117. mlflow/entities/source_type.py +31 -0
  118. mlflow/entities/span.py +774 -0
  119. mlflow/entities/span_event.py +96 -0
  120. mlflow/entities/span_status.py +102 -0
  121. mlflow/entities/trace.py +317 -0
  122. mlflow/entities/trace_data.py +71 -0
  123. mlflow/entities/trace_info.py +220 -0
  124. mlflow/entities/trace_info_v2.py +162 -0
  125. mlflow/entities/trace_location.py +173 -0
  126. mlflow/entities/trace_state.py +39 -0
  127. mlflow/entities/trace_status.py +68 -0
  128. mlflow/entities/view_type.py +51 -0
  129. mlflow/environment_variables.py +866 -0
  130. mlflow/evaluation/__init__.py +16 -0
  131. mlflow/evaluation/assessment.py +369 -0
  132. mlflow/evaluation/evaluation.py +411 -0
  133. mlflow/evaluation/evaluation_tag.py +61 -0
  134. mlflow/evaluation/fluent.py +48 -0
  135. mlflow/evaluation/utils.py +201 -0
  136. mlflow/exceptions.py +213 -0
  137. mlflow/experiments.py +140 -0
  138. mlflow/gemini/__init__.py +81 -0
  139. mlflow/gemini/autolog.py +186 -0
  140. mlflow/gemini/chat.py +261 -0
  141. mlflow/genai/__init__.py +71 -0
  142. mlflow/genai/datasets/__init__.py +67 -0
  143. mlflow/genai/datasets/evaluation_dataset.py +131 -0
  144. mlflow/genai/evaluation/__init__.py +3 -0
  145. mlflow/genai/evaluation/base.py +411 -0
  146. mlflow/genai/evaluation/constant.py +23 -0
  147. mlflow/genai/evaluation/utils.py +244 -0
  148. mlflow/genai/judges/__init__.py +21 -0
  149. mlflow/genai/judges/databricks.py +404 -0
  150. mlflow/genai/label_schemas/__init__.py +153 -0
  151. mlflow/genai/label_schemas/label_schemas.py +209 -0
  152. mlflow/genai/labeling/__init__.py +159 -0
  153. mlflow/genai/labeling/labeling.py +250 -0
  154. mlflow/genai/optimize/__init__.py +13 -0
  155. mlflow/genai/optimize/base.py +198 -0
  156. mlflow/genai/optimize/optimizers/__init__.py +4 -0
  157. mlflow/genai/optimize/optimizers/base_optimizer.py +38 -0
  158. mlflow/genai/optimize/optimizers/dspy_mipro_optimizer.py +221 -0
  159. mlflow/genai/optimize/optimizers/dspy_optimizer.py +91 -0
  160. mlflow/genai/optimize/optimizers/utils/dspy_mipro_callback.py +76 -0
  161. mlflow/genai/optimize/optimizers/utils/dspy_mipro_utils.py +18 -0
  162. mlflow/genai/optimize/types.py +75 -0
  163. mlflow/genai/optimize/util.py +30 -0
  164. mlflow/genai/prompts/__init__.py +206 -0
  165. mlflow/genai/scheduled_scorers.py +431 -0
  166. mlflow/genai/scorers/__init__.py +26 -0
  167. mlflow/genai/scorers/base.py +492 -0
  168. mlflow/genai/scorers/builtin_scorers.py +765 -0
  169. mlflow/genai/scorers/scorer_utils.py +138 -0
  170. mlflow/genai/scorers/validation.py +165 -0
  171. mlflow/genai/utils/data_validation.py +146 -0
  172. mlflow/genai/utils/enum_utils.py +23 -0
  173. mlflow/genai/utils/trace_utils.py +211 -0
  174. mlflow/groq/__init__.py +42 -0
  175. mlflow/groq/_groq_autolog.py +74 -0
  176. mlflow/johnsnowlabs/__init__.py +888 -0
  177. mlflow/langchain/__init__.py +24 -0
  178. mlflow/langchain/api_request_parallel_processor.py +330 -0
  179. mlflow/langchain/autolog.py +147 -0
  180. mlflow/langchain/chat_agent_langgraph.py +340 -0
  181. mlflow/langchain/constant.py +1 -0
  182. mlflow/langchain/constants.py +1 -0
  183. mlflow/langchain/databricks_dependencies.py +444 -0
  184. mlflow/langchain/langchain_tracer.py +597 -0
  185. mlflow/langchain/model.py +919 -0
  186. mlflow/langchain/output_parsers.py +142 -0
  187. mlflow/langchain/retriever_chain.py +153 -0
  188. mlflow/langchain/runnables.py +527 -0
  189. mlflow/langchain/utils/chat.py +402 -0
  190. mlflow/langchain/utils/logging.py +671 -0
  191. mlflow/langchain/utils/serialization.py +36 -0
  192. mlflow/legacy_databricks_cli/__init__.py +0 -0
  193. mlflow/legacy_databricks_cli/configure/__init__.py +0 -0
  194. mlflow/legacy_databricks_cli/configure/provider.py +482 -0
  195. mlflow/litellm/__init__.py +175 -0
  196. mlflow/llama_index/__init__.py +22 -0
  197. mlflow/llama_index/autolog.py +55 -0
  198. mlflow/llama_index/chat.py +43 -0
  199. mlflow/llama_index/constant.py +1 -0
  200. mlflow/llama_index/model.py +577 -0
  201. mlflow/llama_index/pyfunc_wrapper.py +332 -0
  202. mlflow/llama_index/serialize_objects.py +188 -0
  203. mlflow/llama_index/tracer.py +561 -0
  204. mlflow/metrics/__init__.py +479 -0
  205. mlflow/metrics/base.py +39 -0
  206. mlflow/metrics/genai/__init__.py +25 -0
  207. mlflow/metrics/genai/base.py +101 -0
  208. mlflow/metrics/genai/genai_metric.py +771 -0
  209. mlflow/metrics/genai/metric_definitions.py +450 -0
  210. mlflow/metrics/genai/model_utils.py +371 -0
  211. mlflow/metrics/genai/prompt_template.py +68 -0
  212. mlflow/metrics/genai/prompts/__init__.py +0 -0
  213. mlflow/metrics/genai/prompts/v1.py +422 -0
  214. mlflow/metrics/genai/utils.py +6 -0
  215. mlflow/metrics/metric_definitions.py +619 -0
  216. mlflow/mismatch.py +34 -0
  217. mlflow/mistral/__init__.py +34 -0
  218. mlflow/mistral/autolog.py +71 -0
  219. mlflow/mistral/chat.py +135 -0
  220. mlflow/ml_package_versions.py +452 -0
  221. mlflow/models/__init__.py +97 -0
  222. mlflow/models/auth_policy.py +83 -0
  223. mlflow/models/cli.py +354 -0
  224. mlflow/models/container/__init__.py +294 -0
  225. mlflow/models/container/scoring_server/__init__.py +0 -0
  226. mlflow/models/container/scoring_server/nginx.conf +39 -0
  227. mlflow/models/dependencies_schemas.py +287 -0
  228. mlflow/models/display_utils.py +158 -0
  229. mlflow/models/docker_utils.py +211 -0
  230. mlflow/models/evaluation/__init__.py +23 -0
  231. mlflow/models/evaluation/_shap_patch.py +64 -0
  232. mlflow/models/evaluation/artifacts.py +194 -0
  233. mlflow/models/evaluation/base.py +1811 -0
  234. mlflow/models/evaluation/calibration_curve.py +109 -0
  235. mlflow/models/evaluation/default_evaluator.py +996 -0
  236. mlflow/models/evaluation/deprecated.py +23 -0
  237. mlflow/models/evaluation/evaluator_registry.py +80 -0
  238. mlflow/models/evaluation/evaluators/classifier.py +704 -0
  239. mlflow/models/evaluation/evaluators/default.py +233 -0
  240. mlflow/models/evaluation/evaluators/regressor.py +96 -0
  241. mlflow/models/evaluation/evaluators/shap.py +296 -0
  242. mlflow/models/evaluation/lift_curve.py +178 -0
  243. mlflow/models/evaluation/utils/metric.py +123 -0
  244. mlflow/models/evaluation/utils/trace.py +179 -0
  245. mlflow/models/evaluation/validation.py +434 -0
  246. mlflow/models/flavor_backend.py +93 -0
  247. mlflow/models/flavor_backend_registry.py +53 -0
  248. mlflow/models/model.py +1639 -0
  249. mlflow/models/model_config.py +150 -0
  250. mlflow/models/notebook_resources/agent_evaluation_template.html +235 -0
  251. mlflow/models/notebook_resources/eval_with_dataset_example.py +22 -0
  252. mlflow/models/notebook_resources/eval_with_synthetic_example.py +22 -0
  253. mlflow/models/python_api.py +369 -0
  254. mlflow/models/rag_signatures.py +128 -0
  255. mlflow/models/resources.py +321 -0
  256. mlflow/models/signature.py +662 -0
  257. mlflow/models/utils.py +2054 -0
  258. mlflow/models/wheeled_model.py +280 -0
  259. mlflow/openai/__init__.py +57 -0
  260. mlflow/openai/_agent_tracer.py +364 -0
  261. mlflow/openai/api_request_parallel_processor.py +131 -0
  262. mlflow/openai/autolog.py +509 -0
  263. mlflow/openai/constant.py +1 -0
  264. mlflow/openai/model.py +824 -0
  265. mlflow/openai/utils/chat_schema.py +367 -0
  266. mlflow/optuna/__init__.py +3 -0
  267. mlflow/optuna/storage.py +646 -0
  268. mlflow/plugins/__init__.py +72 -0
  269. mlflow/plugins/base.py +358 -0
  270. mlflow/plugins/builtin/__init__.py +24 -0
  271. mlflow/plugins/builtin/pytorch_plugin.py +150 -0
  272. mlflow/plugins/builtin/sklearn_plugin.py +158 -0
  273. mlflow/plugins/builtin/transformers_plugin.py +187 -0
  274. mlflow/plugins/cli.py +321 -0
  275. mlflow/plugins/discovery.py +340 -0
  276. mlflow/plugins/manager.py +465 -0
  277. mlflow/plugins/registry.py +316 -0
  278. mlflow/plugins/templates/framework_plugin_template.py +329 -0
  279. mlflow/prompt/constants.py +20 -0
  280. mlflow/prompt/promptlab_model.py +197 -0
  281. mlflow/prompt/registry_utils.py +248 -0
  282. mlflow/promptflow/__init__.py +495 -0
  283. mlflow/protos/__init__.py +0 -0
  284. mlflow/protos/assessments_pb2.py +174 -0
  285. mlflow/protos/databricks_artifacts_pb2.py +489 -0
  286. mlflow/protos/databricks_filesystem_service_pb2.py +196 -0
  287. mlflow/protos/databricks_managed_catalog_messages_pb2.py +95 -0
  288. mlflow/protos/databricks_managed_catalog_service_pb2.py +86 -0
  289. mlflow/protos/databricks_pb2.py +267 -0
  290. mlflow/protos/databricks_trace_server_pb2.py +374 -0
  291. mlflow/protos/databricks_uc_registry_messages_pb2.py +1249 -0
  292. mlflow/protos/databricks_uc_registry_service_pb2.py +170 -0
  293. mlflow/protos/facet_feature_statistics_pb2.py +296 -0
  294. mlflow/protos/internal_pb2.py +77 -0
  295. mlflow/protos/mlflow_artifacts_pb2.py +336 -0
  296. mlflow/protos/model_registry_pb2.py +1073 -0
  297. mlflow/protos/scalapb/__init__.py +0 -0
  298. mlflow/protos/scalapb/scalapb_pb2.py +104 -0
  299. mlflow/protos/service_pb2.py +2600 -0
  300. mlflow/protos/unity_catalog_oss_messages_pb2.py +457 -0
  301. mlflow/protos/unity_catalog_oss_service_pb2.py +130 -0
  302. mlflow/protos/unity_catalog_prompt_messages_pb2.py +447 -0
  303. mlflow/protos/unity_catalog_prompt_messages_pb2_grpc.py +24 -0
  304. mlflow/protos/unity_catalog_prompt_service_pb2.py +164 -0
  305. mlflow/protos/unity_catalog_prompt_service_pb2_grpc.py +785 -0
  306. mlflow/py.typed +0 -0
  307. mlflow/pydantic_ai/__init__.py +57 -0
  308. mlflow/pydantic_ai/autolog.py +173 -0
  309. mlflow/pyfunc/__init__.py +3844 -0
  310. mlflow/pyfunc/_mlflow_pyfunc_backend_predict.py +61 -0
  311. mlflow/pyfunc/backend.py +523 -0
  312. mlflow/pyfunc/context.py +78 -0
  313. mlflow/pyfunc/dbconnect_artifact_cache.py +144 -0
  314. mlflow/pyfunc/loaders/__init__.py +7 -0
  315. mlflow/pyfunc/loaders/chat_agent.py +117 -0
  316. mlflow/pyfunc/loaders/chat_model.py +125 -0
  317. mlflow/pyfunc/loaders/code_model.py +31 -0
  318. mlflow/pyfunc/loaders/responses_agent.py +112 -0
  319. mlflow/pyfunc/mlserver.py +46 -0
  320. mlflow/pyfunc/model.py +1473 -0
  321. mlflow/pyfunc/scoring_server/__init__.py +604 -0
  322. mlflow/pyfunc/scoring_server/app.py +7 -0
  323. mlflow/pyfunc/scoring_server/client.py +146 -0
  324. mlflow/pyfunc/spark_model_cache.py +48 -0
  325. mlflow/pyfunc/stdin_server.py +44 -0
  326. mlflow/pyfunc/utils/__init__.py +3 -0
  327. mlflow/pyfunc/utils/data_validation.py +224 -0
  328. mlflow/pyfunc/utils/environment.py +22 -0
  329. mlflow/pyfunc/utils/input_converter.py +47 -0
  330. mlflow/pyfunc/utils/serving_data_parser.py +11 -0
  331. mlflow/pytorch/__init__.py +1171 -0
  332. mlflow/pytorch/_lightning_autolog.py +580 -0
  333. mlflow/pytorch/_pytorch_autolog.py +50 -0
  334. mlflow/pytorch/pickle_module.py +35 -0
  335. mlflow/rfunc/__init__.py +42 -0
  336. mlflow/rfunc/backend.py +134 -0
  337. mlflow/runs.py +89 -0
  338. mlflow/server/__init__.py +302 -0
  339. mlflow/server/auth/__init__.py +1224 -0
  340. mlflow/server/auth/__main__.py +4 -0
  341. mlflow/server/auth/basic_auth.ini +6 -0
  342. mlflow/server/auth/cli.py +11 -0
  343. mlflow/server/auth/client.py +537 -0
  344. mlflow/server/auth/config.py +34 -0
  345. mlflow/server/auth/db/__init__.py +0 -0
  346. mlflow/server/auth/db/cli.py +18 -0
  347. mlflow/server/auth/db/migrations/__init__.py +0 -0
  348. mlflow/server/auth/db/migrations/alembic.ini +110 -0
  349. mlflow/server/auth/db/migrations/env.py +76 -0
  350. mlflow/server/auth/db/migrations/versions/8606fa83a998_initial_migration.py +51 -0
  351. mlflow/server/auth/db/migrations/versions/__init__.py +0 -0
  352. mlflow/server/auth/db/models.py +67 -0
  353. mlflow/server/auth/db/utils.py +37 -0
  354. mlflow/server/auth/entities.py +165 -0
  355. mlflow/server/auth/logo.py +14 -0
  356. mlflow/server/auth/permissions.py +65 -0
  357. mlflow/server/auth/routes.py +18 -0
  358. mlflow/server/auth/sqlalchemy_store.py +263 -0
  359. mlflow/server/graphql/__init__.py +0 -0
  360. mlflow/server/graphql/autogenerated_graphql_schema.py +353 -0
  361. mlflow/server/graphql/graphql_custom_scalars.py +24 -0
  362. mlflow/server/graphql/graphql_errors.py +15 -0
  363. mlflow/server/graphql/graphql_no_batching.py +89 -0
  364. mlflow/server/graphql/graphql_schema_extensions.py +74 -0
  365. mlflow/server/handlers.py +3217 -0
  366. mlflow/server/prometheus_exporter.py +17 -0
  367. mlflow/server/validation.py +30 -0
  368. mlflow/shap/__init__.py +691 -0
  369. mlflow/sklearn/__init__.py +1994 -0
  370. mlflow/sklearn/utils.py +1041 -0
  371. mlflow/smolagents/__init__.py +66 -0
  372. mlflow/smolagents/autolog.py +139 -0
  373. mlflow/smolagents/chat.py +29 -0
  374. mlflow/store/__init__.py +10 -0
  375. mlflow/store/_unity_catalog/__init__.py +1 -0
  376. mlflow/store/_unity_catalog/lineage/__init__.py +1 -0
  377. mlflow/store/_unity_catalog/lineage/constants.py +2 -0
  378. mlflow/store/_unity_catalog/registry/__init__.py +6 -0
  379. mlflow/store/_unity_catalog/registry/prompt_info.py +75 -0
  380. mlflow/store/_unity_catalog/registry/rest_store.py +1740 -0
  381. mlflow/store/_unity_catalog/registry/uc_oss_rest_store.py +507 -0
  382. mlflow/store/_unity_catalog/registry/utils.py +121 -0
  383. mlflow/store/artifact/__init__.py +0 -0
  384. mlflow/store/artifact/artifact_repo.py +472 -0
  385. mlflow/store/artifact/artifact_repository_registry.py +154 -0
  386. mlflow/store/artifact/azure_blob_artifact_repo.py +275 -0
  387. mlflow/store/artifact/azure_data_lake_artifact_repo.py +295 -0
  388. mlflow/store/artifact/cli.py +141 -0
  389. mlflow/store/artifact/cloud_artifact_repo.py +332 -0
  390. mlflow/store/artifact/databricks_artifact_repo.py +729 -0
  391. mlflow/store/artifact/databricks_artifact_repo_resources.py +301 -0
  392. mlflow/store/artifact/databricks_logged_model_artifact_repo.py +93 -0
  393. mlflow/store/artifact/databricks_models_artifact_repo.py +216 -0
  394. mlflow/store/artifact/databricks_sdk_artifact_repo.py +134 -0
  395. mlflow/store/artifact/databricks_sdk_models_artifact_repo.py +97 -0
  396. mlflow/store/artifact/dbfs_artifact_repo.py +240 -0
  397. mlflow/store/artifact/ftp_artifact_repo.py +132 -0
  398. mlflow/store/artifact/gcs_artifact_repo.py +296 -0
  399. mlflow/store/artifact/hdfs_artifact_repo.py +209 -0
  400. mlflow/store/artifact/http_artifact_repo.py +218 -0
  401. mlflow/store/artifact/local_artifact_repo.py +142 -0
  402. mlflow/store/artifact/mlflow_artifacts_repo.py +94 -0
  403. mlflow/store/artifact/models_artifact_repo.py +259 -0
  404. mlflow/store/artifact/optimized_s3_artifact_repo.py +356 -0
  405. mlflow/store/artifact/presigned_url_artifact_repo.py +173 -0
  406. mlflow/store/artifact/r2_artifact_repo.py +70 -0
  407. mlflow/store/artifact/runs_artifact_repo.py +265 -0
  408. mlflow/store/artifact/s3_artifact_repo.py +330 -0
  409. mlflow/store/artifact/sftp_artifact_repo.py +141 -0
  410. mlflow/store/artifact/uc_volume_artifact_repo.py +76 -0
  411. mlflow/store/artifact/unity_catalog_models_artifact_repo.py +168 -0
  412. mlflow/store/artifact/unity_catalog_oss_models_artifact_repo.py +168 -0
  413. mlflow/store/artifact/utils/__init__.py +0 -0
  414. mlflow/store/artifact/utils/models.py +148 -0
  415. mlflow/store/db/__init__.py +0 -0
  416. mlflow/store/db/base_sql_model.py +3 -0
  417. mlflow/store/db/db_types.py +10 -0
  418. mlflow/store/db/utils.py +314 -0
  419. mlflow/store/db_migrations/__init__.py +0 -0
  420. mlflow/store/db_migrations/alembic.ini +74 -0
  421. mlflow/store/db_migrations/env.py +84 -0
  422. mlflow/store/db_migrations/versions/0584bdc529eb_add_cascading_deletion_to_datasets_from_experiments.py +88 -0
  423. mlflow/store/db_migrations/versions/0a8213491aaa_drop_duplicate_killed_constraint.py +49 -0
  424. mlflow/store/db_migrations/versions/0c779009ac13_add_deleted_time_field_to_runs_table.py +24 -0
  425. mlflow/store/db_migrations/versions/181f10493468_allow_nulls_for_metric_values.py +35 -0
  426. mlflow/store/db_migrations/versions/27a6a02d2cf1_add_model_version_tags_table.py +38 -0
  427. mlflow/store/db_migrations/versions/2b4d017a5e9b_add_model_registry_tables_to_db.py +77 -0
  428. mlflow/store/db_migrations/versions/2d6e25af4d3e_increase_max_param_val_length.py +33 -0
  429. mlflow/store/db_migrations/versions/3500859a5d39_add_model_aliases_table.py +50 -0
  430. mlflow/store/db_migrations/versions/39d1c3be5f05_add_is_nan_constraint_for_metrics_tables_if_necessary.py +41 -0
  431. mlflow/store/db_migrations/versions/400f98739977_add_logged_model_tables.py +123 -0
  432. mlflow/store/db_migrations/versions/4465047574b1_increase_max_dataset_schema_size.py +38 -0
  433. mlflow/store/db_migrations/versions/451aebb31d03_add_metric_step.py +35 -0
  434. mlflow/store/db_migrations/versions/5b0e9adcef9c_add_cascade_deletion_to_trace_tables_fk.py +40 -0
  435. mlflow/store/db_migrations/versions/6953534de441_add_step_to_inputs_table.py +25 -0
  436. mlflow/store/db_migrations/versions/728d730b5ebd_add_registered_model_tags_table.py +38 -0
  437. mlflow/store/db_migrations/versions/7ac759974ad8_update_run_tags_with_larger_limit.py +36 -0
  438. mlflow/store/db_migrations/versions/7f2a7d5fae7d_add_datasets_inputs_input_tags_tables.py +82 -0
  439. mlflow/store/db_migrations/versions/84291f40a231_add_run_link_to_model_version.py +26 -0
  440. mlflow/store/db_migrations/versions/867495a8f9d4_add_trace_tables.py +90 -0
  441. mlflow/store/db_migrations/versions/89d4b8295536_create_latest_metrics_table.py +169 -0
  442. mlflow/store/db_migrations/versions/90e64c465722_migrate_user_column_to_tags.py +64 -0
  443. mlflow/store/db_migrations/versions/97727af70f4d_creation_time_last_update_time_experiments.py +25 -0
  444. mlflow/store/db_migrations/versions/__init__.py +0 -0
  445. mlflow/store/db_migrations/versions/a8c4a736bde6_allow_nulls_for_run_id.py +27 -0
  446. mlflow/store/db_migrations/versions/acf3f17fdcc7_add_storage_location_field_to_model_.py +29 -0
  447. mlflow/store/db_migrations/versions/bd07f7e963c5_create_index_on_run_uuid.py +26 -0
  448. mlflow/store/db_migrations/versions/bda7b8c39065_increase_model_version_tag_value_limit.py +38 -0
  449. mlflow/store/db_migrations/versions/c48cb773bb87_reset_default_value_for_is_nan_in_metrics_table_for_mysql.py +41 -0
  450. mlflow/store/db_migrations/versions/cbc13b556ace_add_v3_trace_schema_columns.py +31 -0
  451. mlflow/store/db_migrations/versions/cc1f77228345_change_param_value_length_to_500.py +34 -0
  452. mlflow/store/db_migrations/versions/cfd24bdc0731_update_run_status_constraint_with_killed.py +78 -0
  453. mlflow/store/db_migrations/versions/df50e92ffc5e_add_experiment_tags_table.py +38 -0
  454. mlflow/store/db_migrations/versions/f5a4f2784254_increase_run_tag_value_limit.py +36 -0
  455. mlflow/store/entities/__init__.py +3 -0
  456. mlflow/store/entities/paged_list.py +18 -0
  457. mlflow/store/model_registry/__init__.py +10 -0
  458. mlflow/store/model_registry/abstract_store.py +1081 -0
  459. mlflow/store/model_registry/base_rest_store.py +44 -0
  460. mlflow/store/model_registry/databricks_workspace_model_registry_rest_store.py +37 -0
  461. mlflow/store/model_registry/dbmodels/__init__.py +0 -0
  462. mlflow/store/model_registry/dbmodels/models.py +206 -0
  463. mlflow/store/model_registry/file_store.py +1091 -0
  464. mlflow/store/model_registry/rest_store.py +481 -0
  465. mlflow/store/model_registry/sqlalchemy_store.py +1286 -0
  466. mlflow/store/tracking/__init__.py +23 -0
  467. mlflow/store/tracking/abstract_store.py +816 -0
  468. mlflow/store/tracking/dbmodels/__init__.py +0 -0
  469. mlflow/store/tracking/dbmodels/initial_models.py +243 -0
  470. mlflow/store/tracking/dbmodels/models.py +1073 -0
  471. mlflow/store/tracking/file_store.py +2438 -0
  472. mlflow/store/tracking/postgres_managed_identity.py +146 -0
  473. mlflow/store/tracking/rest_store.py +1131 -0
  474. mlflow/store/tracking/sqlalchemy_store.py +2785 -0
  475. mlflow/system_metrics/__init__.py +61 -0
  476. mlflow/system_metrics/metrics/__init__.py +0 -0
  477. mlflow/system_metrics/metrics/base_metrics_monitor.py +32 -0
  478. mlflow/system_metrics/metrics/cpu_monitor.py +23 -0
  479. mlflow/system_metrics/metrics/disk_monitor.py +21 -0
  480. mlflow/system_metrics/metrics/gpu_monitor.py +71 -0
  481. mlflow/system_metrics/metrics/network_monitor.py +34 -0
  482. mlflow/system_metrics/metrics/rocm_monitor.py +123 -0
  483. mlflow/system_metrics/system_metrics_monitor.py +198 -0
  484. mlflow/tracing/__init__.py +16 -0
  485. mlflow/tracing/assessment.py +356 -0
  486. mlflow/tracing/client.py +531 -0
  487. mlflow/tracing/config.py +125 -0
  488. mlflow/tracing/constant.py +105 -0
  489. mlflow/tracing/destination.py +81 -0
  490. mlflow/tracing/display/__init__.py +40 -0
  491. mlflow/tracing/display/display_handler.py +196 -0
  492. mlflow/tracing/export/async_export_queue.py +186 -0
  493. mlflow/tracing/export/inference_table.py +138 -0
  494. mlflow/tracing/export/mlflow_v3.py +137 -0
  495. mlflow/tracing/export/utils.py +70 -0
  496. mlflow/tracing/fluent.py +1417 -0
  497. mlflow/tracing/processor/base_mlflow.py +199 -0
  498. mlflow/tracing/processor/inference_table.py +175 -0
  499. mlflow/tracing/processor/mlflow_v3.py +47 -0
  500. mlflow/tracing/processor/otel.py +73 -0
  501. mlflow/tracing/provider.py +487 -0
  502. mlflow/tracing/trace_manager.py +200 -0
  503. mlflow/tracing/utils/__init__.py +616 -0
  504. mlflow/tracing/utils/artifact_utils.py +28 -0
  505. mlflow/tracing/utils/copy.py +55 -0
  506. mlflow/tracing/utils/environment.py +55 -0
  507. mlflow/tracing/utils/exception.py +21 -0
  508. mlflow/tracing/utils/once.py +35 -0
  509. mlflow/tracing/utils/otlp.py +63 -0
  510. mlflow/tracing/utils/processor.py +54 -0
  511. mlflow/tracing/utils/search.py +292 -0
  512. mlflow/tracing/utils/timeout.py +250 -0
  513. mlflow/tracing/utils/token.py +19 -0
  514. mlflow/tracing/utils/truncation.py +124 -0
  515. mlflow/tracing/utils/warning.py +76 -0
  516. mlflow/tracking/__init__.py +39 -0
  517. mlflow/tracking/_model_registry/__init__.py +1 -0
  518. mlflow/tracking/_model_registry/client.py +764 -0
  519. mlflow/tracking/_model_registry/fluent.py +853 -0
  520. mlflow/tracking/_model_registry/registry.py +67 -0
  521. mlflow/tracking/_model_registry/utils.py +251 -0
  522. mlflow/tracking/_tracking_service/__init__.py +0 -0
  523. mlflow/tracking/_tracking_service/client.py +883 -0
  524. mlflow/tracking/_tracking_service/registry.py +56 -0
  525. mlflow/tracking/_tracking_service/utils.py +275 -0
  526. mlflow/tracking/artifact_utils.py +179 -0
  527. mlflow/tracking/client.py +5900 -0
  528. mlflow/tracking/context/__init__.py +0 -0
  529. mlflow/tracking/context/abstract_context.py +35 -0
  530. mlflow/tracking/context/databricks_cluster_context.py +15 -0
  531. mlflow/tracking/context/databricks_command_context.py +15 -0
  532. mlflow/tracking/context/databricks_job_context.py +49 -0
  533. mlflow/tracking/context/databricks_notebook_context.py +41 -0
  534. mlflow/tracking/context/databricks_repo_context.py +43 -0
  535. mlflow/tracking/context/default_context.py +51 -0
  536. mlflow/tracking/context/git_context.py +32 -0
  537. mlflow/tracking/context/registry.py +98 -0
  538. mlflow/tracking/context/system_environment_context.py +15 -0
  539. mlflow/tracking/default_experiment/__init__.py +1 -0
  540. mlflow/tracking/default_experiment/abstract_context.py +43 -0
  541. mlflow/tracking/default_experiment/databricks_notebook_experiment_provider.py +44 -0
  542. mlflow/tracking/default_experiment/registry.py +75 -0
  543. mlflow/tracking/fluent.py +3595 -0
  544. mlflow/tracking/metric_value_conversion_utils.py +93 -0
  545. mlflow/tracking/multimedia.py +206 -0
  546. mlflow/tracking/registry.py +86 -0
  547. mlflow/tracking/request_auth/__init__.py +0 -0
  548. mlflow/tracking/request_auth/abstract_request_auth_provider.py +34 -0
  549. mlflow/tracking/request_auth/registry.py +60 -0
  550. mlflow/tracking/request_header/__init__.py +0 -0
  551. mlflow/tracking/request_header/abstract_request_header_provider.py +36 -0
  552. mlflow/tracking/request_header/databricks_request_header_provider.py +38 -0
  553. mlflow/tracking/request_header/default_request_header_provider.py +17 -0
  554. mlflow/tracking/request_header/registry.py +79 -0
  555. mlflow/transformers/__init__.py +2982 -0
  556. mlflow/transformers/flavor_config.py +258 -0
  557. mlflow/transformers/hub_utils.py +83 -0
  558. mlflow/transformers/llm_inference_utils.py +468 -0
  559. mlflow/transformers/model_io.py +301 -0
  560. mlflow/transformers/peft.py +51 -0
  561. mlflow/transformers/signature.py +183 -0
  562. mlflow/transformers/torch_utils.py +55 -0
  563. mlflow/types/__init__.py +21 -0
  564. mlflow/types/agent.py +270 -0
  565. mlflow/types/chat.py +240 -0
  566. mlflow/types/llm.py +935 -0
  567. mlflow/types/responses.py +139 -0
  568. mlflow/types/responses_helpers.py +416 -0
  569. mlflow/types/schema.py +1505 -0
  570. mlflow/types/type_hints.py +647 -0
  571. mlflow/types/utils.py +753 -0
  572. mlflow/utils/__init__.py +283 -0
  573. mlflow/utils/_capture_modules.py +256 -0
  574. mlflow/utils/_capture_transformers_modules.py +75 -0
  575. mlflow/utils/_spark_utils.py +201 -0
  576. mlflow/utils/_unity_catalog_oss_utils.py +97 -0
  577. mlflow/utils/_unity_catalog_utils.py +479 -0
  578. mlflow/utils/annotations.py +218 -0
  579. mlflow/utils/arguments_utils.py +16 -0
  580. mlflow/utils/async_logging/__init__.py +1 -0
  581. mlflow/utils/async_logging/async_artifacts_logging_queue.py +258 -0
  582. mlflow/utils/async_logging/async_logging_queue.py +366 -0
  583. mlflow/utils/async_logging/run_artifact.py +38 -0
  584. mlflow/utils/async_logging/run_batch.py +58 -0
  585. mlflow/utils/async_logging/run_operations.py +49 -0
  586. mlflow/utils/autologging_utils/__init__.py +737 -0
  587. mlflow/utils/autologging_utils/client.py +432 -0
  588. mlflow/utils/autologging_utils/config.py +33 -0
  589. mlflow/utils/autologging_utils/events.py +294 -0
  590. mlflow/utils/autologging_utils/logging_and_warnings.py +328 -0
  591. mlflow/utils/autologging_utils/metrics_queue.py +71 -0
  592. mlflow/utils/autologging_utils/safety.py +1104 -0
  593. mlflow/utils/autologging_utils/versioning.py +95 -0
  594. mlflow/utils/checkpoint_utils.py +206 -0
  595. mlflow/utils/class_utils.py +6 -0
  596. mlflow/utils/cli_args.py +257 -0
  597. mlflow/utils/conda.py +354 -0
  598. mlflow/utils/credentials.py +231 -0
  599. mlflow/utils/data_utils.py +17 -0
  600. mlflow/utils/databricks_utils.py +1436 -0
  601. mlflow/utils/docstring_utils.py +477 -0
  602. mlflow/utils/doctor.py +133 -0
  603. mlflow/utils/download_cloud_file_chunk.py +43 -0
  604. mlflow/utils/env_manager.py +16 -0
  605. mlflow/utils/env_pack.py +131 -0
  606. mlflow/utils/environment.py +1009 -0
  607. mlflow/utils/exception_utils.py +14 -0
  608. mlflow/utils/file_utils.py +978 -0
  609. mlflow/utils/git_utils.py +77 -0
  610. mlflow/utils/gorilla.py +797 -0
  611. mlflow/utils/import_hooks/__init__.py +363 -0
  612. mlflow/utils/lazy_load.py +51 -0
  613. mlflow/utils/logging_utils.py +168 -0
  614. mlflow/utils/mime_type_utils.py +58 -0
  615. mlflow/utils/mlflow_tags.py +103 -0
  616. mlflow/utils/model_utils.py +486 -0
  617. mlflow/utils/name_utils.py +346 -0
  618. mlflow/utils/nfs_on_spark.py +62 -0
  619. mlflow/utils/openai_utils.py +164 -0
  620. mlflow/utils/os.py +12 -0
  621. mlflow/utils/oss_registry_utils.py +29 -0
  622. mlflow/utils/plugins.py +17 -0
  623. mlflow/utils/process.py +182 -0
  624. mlflow/utils/promptlab_utils.py +146 -0
  625. mlflow/utils/proto_json_utils.py +743 -0
  626. mlflow/utils/pydantic_utils.py +54 -0
  627. mlflow/utils/request_utils.py +279 -0
  628. mlflow/utils/requirements_utils.py +704 -0
  629. mlflow/utils/rest_utils.py +673 -0
  630. mlflow/utils/search_logged_model_utils.py +127 -0
  631. mlflow/utils/search_utils.py +2111 -0
  632. mlflow/utils/secure_loading.py +221 -0
  633. mlflow/utils/security_validation.py +384 -0
  634. mlflow/utils/server_cli_utils.py +61 -0
  635. mlflow/utils/spark_utils.py +15 -0
  636. mlflow/utils/string_utils.py +138 -0
  637. mlflow/utils/thread_utils.py +63 -0
  638. mlflow/utils/time.py +54 -0
  639. mlflow/utils/timeout.py +42 -0
  640. mlflow/utils/uri.py +572 -0
  641. mlflow/utils/validation.py +662 -0
  642. mlflow/utils/virtualenv.py +458 -0
  643. mlflow/utils/warnings_utils.py +25 -0
  644. mlflow/utils/yaml_utils.py +179 -0
  645. 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
+ ]