vellum-ai 0.0.21__tar.gz → 0.0.22__tar.gz

Sign up to get free protection for your applications and to get access to all the features.
Files changed (154) hide show
  1. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/PKG-INFO +1 -1
  2. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/pyproject.toml +2 -1
  3. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/client.py +270 -101
  4. vellum_ai-0.0.22/src/vellum/core/__init__.py +17 -0
  5. vellum_ai-0.0.22/src/vellum/core/client_wrapper.py +27 -0
  6. vellum_ai-0.0.22/src/vellum/core/remove_none_from_dict.py +11 -0
  7. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/resources/deployments/client.py +35 -15
  8. vellum_ai-0.0.22/src/vellum/resources/document_indexes/client.py +144 -0
  9. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/resources/documents/client.py +110 -35
  10. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/resources/model_versions/client.py +67 -25
  11. vellum_ai-0.0.22/src/vellum/resources/registered_prompts/client.py +175 -0
  12. vellum_ai-0.0.22/src/vellum/resources/sandboxes/client.py +190 -0
  13. vellum_ai-0.0.22/src/vellum/resources/test_suites/client.py +185 -0
  14. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/deployment_read.py +2 -6
  15. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/document.py +3 -7
  16. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/document_document_to_document_index.py +2 -2
  17. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/document_index_read.py +3 -7
  18. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/enriched_normalized_completion.py +5 -9
  19. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/evaluation_params.py +1 -3
  20. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/evaluation_params_request.py +1 -3
  21. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/generate_error_response.py +1 -1
  22. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/generate_request.py +3 -7
  23. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/generate_result.py +2 -6
  24. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/generate_result_data.py +1 -1
  25. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/generate_result_error.py +1 -1
  26. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/model_version_build_config.py +2 -6
  27. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/model_version_compile_prompt_response.py +1 -1
  28. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/model_version_compiled_prompt.py +2 -4
  29. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/model_version_exec_config.py +3 -3
  30. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/model_version_read.py +6 -10
  31. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/model_version_sandbox_snapshot.py +3 -5
  32. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/prompt_template_block_properties_request.py +2 -2
  33. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/prompt_template_block_request.py +1 -1
  34. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/prompt_template_input_variable.py +1 -1
  35. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/prompt_template_input_variable_request.py +1 -1
  36. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/register_prompt_error_response.py +1 -1
  37. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/register_prompt_prompt.py +2 -2
  38. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/register_prompt_prompt_info_request.py +1 -1
  39. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/register_prompt_response.py +5 -7
  40. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/registered_prompt_deployment.py +3 -3
  41. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/registered_prompt_model_version.py +2 -2
  42. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/registered_prompt_sandbox.py +2 -2
  43. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/registered_prompt_sandbox_snapshot.py +1 -1
  44. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/sandbox_scenario.py +2 -2
  45. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/scenario_input_request.py +1 -1
  46. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/search_error_response.py +1 -1
  47. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/search_filters_request.py +1 -1
  48. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/search_request_options_request.py +4 -6
  49. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/search_response.py +1 -1
  50. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/search_result.py +3 -3
  51. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/search_result_merging_request.py +1 -1
  52. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/search_weights_request.py +2 -2
  53. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/slim_document.py +5 -9
  54. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/submit_completion_actual_request.py +5 -15
  55. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/terminal_node_chat_history_result.py +1 -1
  56. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/terminal_node_json_result.py +1 -1
  57. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/terminal_node_result_output.py +2 -4
  58. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/terminal_node_string_result.py +1 -1
  59. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/test_suite_test_case.py +4 -8
  60. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/upload_document_response.py +1 -1
  61. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_node_result_data.py +7 -11
  62. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_request_chat_history_input_request.py +1 -3
  63. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_request_input_request.py +2 -6
  64. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_request_json_input_request.py +1 -3
  65. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_request_string_input_request.py +1 -3
  66. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_result_event_output_data.py +2 -8
  67. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_result_event_output_data_chat_history.py +3 -0
  68. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_result_event_output_data_json.py +3 -0
  69. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_result_event_output_data_string.py +6 -1
  70. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_stream_event.py +1 -4
  71. vellum_ai-0.0.21/src/vellum/core/__init__.py +0 -8
  72. vellum_ai-0.0.21/src/vellum/core/remove_none_from_headers.py +0 -11
  73. vellum_ai-0.0.21/src/vellum/resources/document_indexes/client.py +0 -96
  74. vellum_ai-0.0.21/src/vellum/resources/registered_prompts/client.py +0 -111
  75. vellum_ai-0.0.21/src/vellum/resources/sandboxes/client.py +0 -125
  76. vellum_ai-0.0.21/src/vellum/resources/test_suites/client.py +0 -120
  77. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/README.md +0 -0
  78. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/__init__.py +19 -19
  79. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/core/api_error.py +0 -0
  80. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/core/datetime_utils.py +0 -0
  81. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/core/jsonable_encoder.py +0 -0
  82. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/environment.py +0 -0
  83. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/errors/__init__.py +0 -0
  84. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/errors/bad_request_error.py +0 -0
  85. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/errors/conflict_error.py +0 -0
  86. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/errors/forbidden_error.py +0 -0
  87. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/errors/internal_server_error.py +0 -0
  88. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/errors/not_found_error.py +0 -0
  89. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/py.typed +0 -0
  90. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/resources/__init__.py +0 -0
  91. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/resources/deployments/__init__.py +0 -0
  92. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/resources/document_indexes/__init__.py +0 -0
  93. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/resources/documents/__init__.py +0 -0
  94. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/resources/model_versions/__init__.py +0 -0
  95. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/resources/registered_prompts/__init__.py +0 -0
  96. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/resources/sandboxes/__init__.py +0 -0
  97. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/resources/test_suites/__init__.py +0 -0
  98. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/__init__.py +0 -0
  99. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/block_type_enum.py +0 -0
  100. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/chat_message.py +0 -0
  101. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/chat_message_request.py +0 -0
  102. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/chat_message_role.py +0 -0
  103. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/conditional_node_result.py +0 -0
  104. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/conditional_node_result_data.py +0 -0
  105. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/content_type.py +0 -0
  106. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/deployment_node_result.py +0 -0
  107. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/deployment_node_result_data.py +0 -0
  108. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/deployment_read_status_enum.py +0 -0
  109. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/document_index_status.py +0 -0
  110. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/environment_enum.py +0 -0
  111. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/finish_reason_enum.py +0 -0
  112. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/generate_options_request.py +0 -0
  113. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/generate_response.py +0 -0
  114. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/generate_stream_response.py +0 -0
  115. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/generate_stream_result.py +0 -0
  116. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/generate_stream_result_data.py +0 -0
  117. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/indexing_state_enum.py +0 -0
  118. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/logprobs_enum.py +0 -0
  119. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/model_type_enum.py +0 -0
  120. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/model_version_exec_config_parameters.py +0 -0
  121. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/model_version_read_status_enum.py +0 -0
  122. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/normalized_log_probs.py +0 -0
  123. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/normalized_token_log_probs.py +0 -0
  124. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/paginated_slim_document_list.py +0 -0
  125. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/processing_failure_reason_enum.py +0 -0
  126. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/processing_state_enum.py +0 -0
  127. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/prompt_node_result.py +0 -0
  128. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/prompt_node_result_data.py +0 -0
  129. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/prompt_template_block.py +0 -0
  130. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/prompt_template_block_data.py +0 -0
  131. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/prompt_template_block_data_request.py +0 -0
  132. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/prompt_template_block_properties.py +0 -0
  133. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/provider_enum.py +0 -0
  134. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/register_prompt_model_parameters_request.py +0 -0
  135. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/sandbox_metric_input_params.py +0 -0
  136. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/sandbox_metric_input_params_request.py +0 -0
  137. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/sandbox_node_result.py +0 -0
  138. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/sandbox_node_result_data.py +0 -0
  139. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/scenario_input.py +0 -0
  140. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/scenario_input_type_enum.py +0 -0
  141. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/search_node_result.py +0 -0
  142. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/search_node_result_data.py +0 -0
  143. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/slim_document_status_enum.py +0 -0
  144. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/submit_completion_actuals_error_response.py +0 -0
  145. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/terminal_node_result.py +0 -0
  146. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/terminal_node_result_data.py +0 -0
  147. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/upload_document_error_response.py +0 -0
  148. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_event_error.py +0 -0
  149. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_execution_event_error_code.py +0 -0
  150. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_execution_node_result_event.py +0 -0
  151. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_execution_workflow_result_event.py +0 -0
  152. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_node_result_event.py +0 -0
  153. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_node_result_event_state.py +0 -0
  154. {vellum_ai-0.0.21 → vellum_ai-0.0.22}/src/vellum/types/workflow_result_event.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: vellum-ai
3
- Version: 0.0.21
3
+ Version: 0.0.22
4
4
  Summary:
5
5
  Requires-Python: >=3.7,<4.0
6
6
  Classifier: Programming Language :: Python :: 3
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "vellum-ai"
3
- version = "v0.0.21"
3
+ version = "v0.0.22"
4
4
  description = ""
5
5
  readme = "README.md"
6
6
  authors = []
@@ -15,6 +15,7 @@ httpx = "0.23.3"
15
15
 
16
16
  [tool.poetry.dev-dependencies]
17
17
  mypy = "0.971"
18
+ pytest = "^7.4.0"
18
19
 
19
20
  [build-system]
20
21
  requires = ["poetry-core"]
@@ -9,8 +9,8 @@ import httpx
9
9
  import pydantic
10
10
 
11
11
  from .core.api_error import ApiError
12
+ from .core.client_wrapper import AsyncClientWrapper, SyncClientWrapper
12
13
  from .core.jsonable_encoder import jsonable_encoder
13
- from .core.remove_none_from_headers import remove_none_from_headers
14
14
  from .environment import VellumEnvironment
15
15
  from .errors.bad_request_error import BadRequestError
16
16
  from .errors.forbidden_error import ForbiddenError
@@ -39,16 +39,22 @@ OMIT = typing.cast(typing.Any, ...)
39
39
 
40
40
 
41
41
  class Vellum:
42
- def __init__(self, *, environment: VellumEnvironment = VellumEnvironment.PRODUCTION, api_key: str):
42
+ def __init__(
43
+ self,
44
+ *,
45
+ environment: VellumEnvironment = VellumEnvironment.PRODUCTION,
46
+ api_key: str,
47
+ timeout: typing.Optional[float] = None,
48
+ ):
43
49
  self._environment = environment
44
- self.api_key = api_key
45
- self.deployments = DeploymentsClient(environment=self._environment, api_key=self.api_key)
46
- self.document_indexes = DocumentIndexesClient(environment=self._environment, api_key=self.api_key)
47
- self.documents = DocumentsClient(environment=self._environment, api_key=self.api_key)
48
- self.model_versions = ModelVersionsClient(environment=self._environment, api_key=self.api_key)
49
- self.registered_prompts = RegisteredPromptsClient(environment=self._environment, api_key=self.api_key)
50
- self.sandboxes = SandboxesClient(environment=self._environment, api_key=self.api_key)
51
- self.test_suites = TestSuitesClient(environment=self._environment, api_key=self.api_key)
50
+ self._client_wrapper = SyncClientWrapper(api_key=api_key, httpx_client=httpx.Client(timeout=timeout))
51
+ self.deployments = DeploymentsClient(environment=environment, client_wrapper=self._client_wrapper)
52
+ self.document_indexes = DocumentIndexesClient(environment=environment, client_wrapper=self._client_wrapper)
53
+ self.documents = DocumentsClient(environment=environment, client_wrapper=self._client_wrapper)
54
+ self.model_versions = ModelVersionsClient(environment=environment, client_wrapper=self._client_wrapper)
55
+ self.registered_prompts = RegisteredPromptsClient(environment=environment, client_wrapper=self._client_wrapper)
56
+ self.sandboxes = SandboxesClient(environment=environment, client_wrapper=self._client_wrapper)
57
+ self.test_suites = TestSuitesClient(environment=environment, client_wrapper=self._client_wrapper)
52
58
 
53
59
  def execute_workflow_stream(
54
60
  self,
@@ -59,6 +65,22 @@ class Vellum:
59
65
  inputs: typing.List[WorkflowRequestInputRequest],
60
66
  external_id: typing.Optional[str] = OMIT,
61
67
  ) -> typing.Iterator[WorkflowStreamEvent]:
68
+ """
69
+ <strong style="background-color:#ffc107; color:white; padding:4px; border-radius:4px">Unstable</strong>
70
+
71
+ Executes a deployed Workflow and streams back its results.
72
+
73
+ Parameters:
74
+ - workflow_deployment_id: typing.Optional[str]. The ID of the Workflow Deployment. Must provide either this or workflow_deployment_name.
75
+
76
+ - workflow_deployment_name: typing.Optional[str]. The name of the Workflow Deployment. Must provide either this or workflow_deployment_id.
77
+
78
+ - release_tag: typing.Optional[str]. Optionally specify a release tag if you want to pin to a specific release of the Workflow Deployment
79
+
80
+ - inputs: typing.List[WorkflowRequestInputRequest].
81
+
82
+ - external_id: typing.Optional[str]. Optionally include a unique identifier for tracking purposes.
83
+ """
62
84
  _request: typing.Dict[str, typing.Any] = {"inputs": inputs}
63
85
  if workflow_deployment_id is not OMIT:
64
86
  _request["workflow_deployment_id"] = workflow_deployment_id
@@ -68,20 +90,21 @@ class Vellum:
68
90
  _request["release_tag"] = release_tag
69
91
  if external_id is not OMIT:
70
92
  _request["external_id"] = external_id
71
- with httpx.stream(
93
+ with self._client_wrapper.httpx_client.stream(
72
94
  "POST",
73
95
  urllib.parse.urljoin(f"{self._environment.predict}/", "v1/execute-workflow-stream"),
74
96
  json=jsonable_encoder(_request),
75
- headers=remove_none_from_headers({"X_API_KEY": self.api_key}),
97
+ headers=self._client_wrapper.get_headers(),
76
98
  timeout=None,
77
99
  ) as _response:
78
100
  if 200 <= _response.status_code < 300:
79
- for _text in _response.iter_text():
101
+ for _text in _response.iter_lines():
80
102
  if len(_text) == 0:
81
103
  continue
82
104
  yield pydantic.parse_obj_as(WorkflowStreamEvent, json.loads(_text)) # type: ignore
83
105
  return
84
106
  try:
107
+ _response.read()
85
108
  _response_json = _response.json()
86
109
  except JSONDecodeError:
87
110
  raise ApiError(status_code=_response.status_code, body=_response.text)
@@ -95,6 +118,22 @@ class Vellum:
95
118
  requests: typing.List[GenerateRequest],
96
119
  options: typing.Optional[GenerateOptionsRequest] = OMIT,
97
120
  ) -> GenerateResponse:
121
+ """
122
+ <strong style="background-color:#4caf50; color:white; padding:4px; border-radius:4px">Stable</strong>
123
+
124
+ Generate a completion using a previously defined deployment.
125
+
126
+ **Note:** Uses a base url of `https://predict.vellum.ai`.
127
+
128
+ Parameters:
129
+ - deployment_id: typing.Optional[str]. The ID of the deployment. Must provide either this or deployment_name.
130
+
131
+ - deployment_name: typing.Optional[str]. The name of the deployment. Must provide either this or deployment_id.
132
+
133
+ - requests: typing.List[GenerateRequest]. The generation requests to make. Supplying multiple will perform a bulk request to the LLM provided when possible.
134
+
135
+ - options: typing.Optional[GenerateOptionsRequest]. Additional configuration that can be used to control what's included in the response.
136
+ """
98
137
  _request: typing.Dict[str, typing.Any] = {"requests": requests}
99
138
  if deployment_id is not OMIT:
100
139
  _request["deployment_id"] = deployment_id
@@ -102,11 +141,11 @@ class Vellum:
102
141
  _request["deployment_name"] = deployment_name
103
142
  if options is not OMIT:
104
143
  _request["options"] = options
105
- _response = httpx.request(
144
+ _response = self._client_wrapper.httpx_client.request(
106
145
  "POST",
107
146
  urllib.parse.urljoin(f"{self._environment.predict}/", "v1/generate"),
108
147
  json=jsonable_encoder(_request),
109
- headers=remove_none_from_headers({"X_API_KEY": self.api_key}),
148
+ headers=self._client_wrapper.get_headers(),
110
149
  timeout=None,
111
150
  )
112
151
  if 200 <= _response.status_code < 300:
@@ -133,6 +172,22 @@ class Vellum:
133
172
  requests: typing.List[GenerateRequest],
134
173
  options: typing.Optional[GenerateOptionsRequest] = OMIT,
135
174
  ) -> typing.Iterator[GenerateStreamResponse]:
175
+ """
176
+ <strong style="background-color:#4caf50; color:white; padding:4px; border-radius:4px">Stable</strong>
177
+
178
+ Generate a stream of completions using a previously defined deployment.
179
+
180
+ **Note:** Uses a base url of `https://predict.vellum.ai`.
181
+
182
+ Parameters:
183
+ - deployment_id: typing.Optional[str]. The ID of the deployment. Must provide either this or deployment_name.
184
+
185
+ - deployment_name: typing.Optional[str]. The name of the deployment. Must provide either this or deployment_id.
186
+
187
+ - requests: typing.List[GenerateRequest]. The generation requests to make. Supplying multiple will perform a bulk request to the LLM provided when possible.
188
+
189
+ - options: typing.Optional[GenerateOptionsRequest]. Additional configuration that can be used to control what's included in the response.
190
+ """
136
191
  _request: typing.Dict[str, typing.Any] = {"requests": requests}
137
192
  if deployment_id is not OMIT:
138
193
  _request["deployment_id"] = deployment_id
@@ -140,15 +195,15 @@ class Vellum:
140
195
  _request["deployment_name"] = deployment_name
141
196
  if options is not OMIT:
142
197
  _request["options"] = options
143
- with httpx.stream(
198
+ with self._client_wrapper.httpx_client.stream(
144
199
  "POST",
145
200
  urllib.parse.urljoin(f"{self._environment.predict}/", "v1/generate-stream"),
146
201
  json=jsonable_encoder(_request),
147
- headers=remove_none_from_headers({"X_API_KEY": self.api_key}),
202
+ headers=self._client_wrapper.get_headers(),
148
203
  timeout=None,
149
204
  ) as _response:
150
205
  if 200 <= _response.status_code < 300:
151
- for _text in _response.iter_text():
206
+ for _text in _response.iter_lines():
152
207
  if len(_text) == 0:
153
208
  continue
154
209
  yield pydantic.parse_obj_as(GenerateStreamResponse, json.loads(_text)) # type: ignore
@@ -162,6 +217,7 @@ class Vellum:
162
217
  if _response.status_code == 500:
163
218
  raise InternalServerError(pydantic.parse_obj_as(typing.Any, _response.json())) # type: ignore
164
219
  try:
220
+ _response.read()
165
221
  _response_json = _response.json()
166
222
  except JSONDecodeError:
167
223
  raise ApiError(status_code=_response.status_code, body=_response.text)
@@ -175,6 +231,22 @@ class Vellum:
175
231
  query: str,
176
232
  options: typing.Optional[SearchRequestOptionsRequest] = OMIT,
177
233
  ) -> SearchResponse:
234
+ """
235
+ <strong style="background-color:#4caf50; color:white; padding:4px; border-radius:4px">Stable</strong>
236
+
237
+ Perform a search against a document index.
238
+
239
+ **Note:** Uses a base url of `https://predict.vellum.ai`.
240
+
241
+ Parameters:
242
+ - index_id: typing.Optional[str]. The ID of the index to search against. Must provide either this or index_name.
243
+
244
+ - index_name: typing.Optional[str]. The name of the index to search against. Must provide either this or index_id.
245
+
246
+ - query: str. The query to search for. <span style="white-space: nowrap">`non-empty`</span>
247
+
248
+ - options: typing.Optional[SearchRequestOptionsRequest]. Configuration options for the search.
249
+ """
178
250
  _request: typing.Dict[str, typing.Any] = {"query": query}
179
251
  if index_id is not OMIT:
180
252
  _request["index_id"] = index_id
@@ -182,11 +254,11 @@ class Vellum:
182
254
  _request["index_name"] = index_name
183
255
  if options is not OMIT:
184
256
  _request["options"] = options
185
- _response = httpx.request(
257
+ _response = self._client_wrapper.httpx_client.request(
186
258
  "POST",
187
259
  urllib.parse.urljoin(f"{self._environment.predict}/", "v1/search"),
188
260
  json=jsonable_encoder(_request),
189
- headers=remove_none_from_headers({"X_API_KEY": self.api_key}),
261
+ headers=self._client_wrapper.get_headers(),
190
262
  timeout=None,
191
263
  )
192
264
  if 200 <= _response.status_code < 300:
@@ -210,16 +282,30 @@ class Vellum:
210
282
  deployment_name: typing.Optional[str] = OMIT,
211
283
  actuals: typing.List[SubmitCompletionActualRequest],
212
284
  ) -> None:
285
+ """
286
+ <strong style="background-color:#4caf50; color:white; padding:4px; border-radius:4px">Stable</strong>
287
+
288
+ Used to submit feedback regarding the quality of previously generated completions.
289
+
290
+ **Note:** Uses a base url of `https://predict.vellum.ai`.
291
+
292
+ Parameters:
293
+ - deployment_id: typing.Optional[str]. The ID of the deployment. Must provide either this or deployment_name.
294
+
295
+ - deployment_name: typing.Optional[str]. The name of the deployment. Must provide either this or deployment_id.
296
+
297
+ - actuals: typing.List[SubmitCompletionActualRequest]. Feedback regarding the quality of previously generated completions
298
+ """
213
299
  _request: typing.Dict[str, typing.Any] = {"actuals": actuals}
214
300
  if deployment_id is not OMIT:
215
301
  _request["deployment_id"] = deployment_id
216
302
  if deployment_name is not OMIT:
217
303
  _request["deployment_name"] = deployment_name
218
- _response = httpx.request(
304
+ _response = self._client_wrapper.httpx_client.request(
219
305
  "POST",
220
306
  urllib.parse.urljoin(f"{self._environment.predict}/", "v1/submit-completion-actuals"),
221
307
  json=jsonable_encoder(_request),
222
- headers=remove_none_from_headers({"X_API_KEY": self.api_key}),
308
+ headers=self._client_wrapper.get_headers(),
223
309
  timeout=None,
224
310
  )
225
311
  if 200 <= _response.status_code < 300:
@@ -238,16 +324,24 @@ class Vellum:
238
324
 
239
325
 
240
326
  class AsyncVellum:
241
- def __init__(self, *, environment: VellumEnvironment = VellumEnvironment.PRODUCTION, api_key: str):
327
+ def __init__(
328
+ self,
329
+ *,
330
+ environment: VellumEnvironment = VellumEnvironment.PRODUCTION,
331
+ api_key: str,
332
+ timeout: typing.Optional[float] = None,
333
+ ):
242
334
  self._environment = environment
243
- self.api_key = api_key
244
- self.deployments = AsyncDeploymentsClient(environment=self._environment, api_key=self.api_key)
245
- self.document_indexes = AsyncDocumentIndexesClient(environment=self._environment, api_key=self.api_key)
246
- self.documents = AsyncDocumentsClient(environment=self._environment, api_key=self.api_key)
247
- self.model_versions = AsyncModelVersionsClient(environment=self._environment, api_key=self.api_key)
248
- self.registered_prompts = AsyncRegisteredPromptsClient(environment=self._environment, api_key=self.api_key)
249
- self.sandboxes = AsyncSandboxesClient(environment=self._environment, api_key=self.api_key)
250
- self.test_suites = AsyncTestSuitesClient(environment=self._environment, api_key=self.api_key)
335
+ self._client_wrapper = AsyncClientWrapper(api_key=api_key, httpx_client=httpx.AsyncClient(timeout=timeout))
336
+ self.deployments = AsyncDeploymentsClient(environment=environment, client_wrapper=self._client_wrapper)
337
+ self.document_indexes = AsyncDocumentIndexesClient(environment=environment, client_wrapper=self._client_wrapper)
338
+ self.documents = AsyncDocumentsClient(environment=environment, client_wrapper=self._client_wrapper)
339
+ self.model_versions = AsyncModelVersionsClient(environment=environment, client_wrapper=self._client_wrapper)
340
+ self.registered_prompts = AsyncRegisteredPromptsClient(
341
+ environment=environment, client_wrapper=self._client_wrapper
342
+ )
343
+ self.sandboxes = AsyncSandboxesClient(environment=environment, client_wrapper=self._client_wrapper)
344
+ self.test_suites = AsyncTestSuitesClient(environment=environment, client_wrapper=self._client_wrapper)
251
345
 
252
346
  async def execute_workflow_stream(
253
347
  self,
@@ -258,6 +352,22 @@ class AsyncVellum:
258
352
  inputs: typing.List[WorkflowRequestInputRequest],
259
353
  external_id: typing.Optional[str] = OMIT,
260
354
  ) -> typing.AsyncIterator[WorkflowStreamEvent]:
355
+ """
356
+ <strong style="background-color:#ffc107; color:white; padding:4px; border-radius:4px">Unstable</strong>
357
+
358
+ Executes a deployed Workflow and streams back its results.
359
+
360
+ Parameters:
361
+ - workflow_deployment_id: typing.Optional[str]. The ID of the Workflow Deployment. Must provide either this or workflow_deployment_name.
362
+
363
+ - workflow_deployment_name: typing.Optional[str]. The name of the Workflow Deployment. Must provide either this or workflow_deployment_id.
364
+
365
+ - release_tag: typing.Optional[str]. Optionally specify a release tag if you want to pin to a specific release of the Workflow Deployment
366
+
367
+ - inputs: typing.List[WorkflowRequestInputRequest].
368
+
369
+ - external_id: typing.Optional[str]. Optionally include a unique identifier for tracking purposes.
370
+ """
261
371
  _request: typing.Dict[str, typing.Any] = {"inputs": inputs}
262
372
  if workflow_deployment_id is not OMIT:
263
373
  _request["workflow_deployment_id"] = workflow_deployment_id
@@ -267,25 +377,25 @@ class AsyncVellum:
267
377
  _request["release_tag"] = release_tag
268
378
  if external_id is not OMIT:
269
379
  _request["external_id"] = external_id
270
- async with httpx.AsyncClient() as _client:
271
- async with _client.stream(
272
- "POST",
273
- urllib.parse.urljoin(f"{self._environment.predict}/", "v1/execute-workflow-stream"),
274
- json=jsonable_encoder(_request),
275
- headers=remove_none_from_headers({"X_API_KEY": self.api_key}),
276
- timeout=None,
277
- ) as _response:
278
- if 200 <= _response.status_code < 300:
279
- async for _text in _response.aiter_text():
280
- if len(_text) == 0:
281
- continue
282
- yield pydantic.parse_obj_as(WorkflowStreamEvent, json.loads(_text)) # type: ignore
283
- return
284
- try:
285
- _response_json = _response.json()
286
- except JSONDecodeError:
287
- raise ApiError(status_code=_response.status_code, body=_response.text)
288
- raise ApiError(status_code=_response.status_code, body=_response_json)
380
+ async with self._client_wrapper.httpx_client.stream(
381
+ "POST",
382
+ urllib.parse.urljoin(f"{self._environment.predict}/", "v1/execute-workflow-stream"),
383
+ json=jsonable_encoder(_request),
384
+ headers=self._client_wrapper.get_headers(),
385
+ timeout=None,
386
+ ) as _response:
387
+ if 200 <= _response.status_code < 300:
388
+ async for _text in _response.aiter_lines():
389
+ if len(_text) == 0:
390
+ continue
391
+ yield pydantic.parse_obj_as(WorkflowStreamEvent, json.loads(_text)) # type: ignore
392
+ return
393
+ try:
394
+ await _response.aread()
395
+ _response_json = _response.json()
396
+ except JSONDecodeError:
397
+ raise ApiError(status_code=_response.status_code, body=_response.text)
398
+ raise ApiError(status_code=_response.status_code, body=_response_json)
289
399
 
290
400
  async def generate(
291
401
  self,
@@ -295,6 +405,22 @@ class AsyncVellum:
295
405
  requests: typing.List[GenerateRequest],
296
406
  options: typing.Optional[GenerateOptionsRequest] = OMIT,
297
407
  ) -> GenerateResponse:
408
+ """
409
+ <strong style="background-color:#4caf50; color:white; padding:4px; border-radius:4px">Stable</strong>
410
+
411
+ Generate a completion using a previously defined deployment.
412
+
413
+ **Note:** Uses a base url of `https://predict.vellum.ai`.
414
+
415
+ Parameters:
416
+ - deployment_id: typing.Optional[str]. The ID of the deployment. Must provide either this or deployment_name.
417
+
418
+ - deployment_name: typing.Optional[str]. The name of the deployment. Must provide either this or deployment_id.
419
+
420
+ - requests: typing.List[GenerateRequest]. The generation requests to make. Supplying multiple will perform a bulk request to the LLM provided when possible.
421
+
422
+ - options: typing.Optional[GenerateOptionsRequest]. Additional configuration that can be used to control what's included in the response.
423
+ """
298
424
  _request: typing.Dict[str, typing.Any] = {"requests": requests}
299
425
  if deployment_id is not OMIT:
300
426
  _request["deployment_id"] = deployment_id
@@ -302,14 +428,13 @@ class AsyncVellum:
302
428
  _request["deployment_name"] = deployment_name
303
429
  if options is not OMIT:
304
430
  _request["options"] = options
305
- async with httpx.AsyncClient() as _client:
306
- _response = await _client.request(
307
- "POST",
308
- urllib.parse.urljoin(f"{self._environment.predict}/", "v1/generate"),
309
- json=jsonable_encoder(_request),
310
- headers=remove_none_from_headers({"X_API_KEY": self.api_key}),
311
- timeout=None,
312
- )
431
+ _response = await self._client_wrapper.httpx_client.request(
432
+ "POST",
433
+ urllib.parse.urljoin(f"{self._environment.predict}/", "v1/generate"),
434
+ json=jsonable_encoder(_request),
435
+ headers=self._client_wrapper.get_headers(),
436
+ timeout=None,
437
+ )
313
438
  if 200 <= _response.status_code < 300:
314
439
  return pydantic.parse_obj_as(GenerateResponse, _response.json()) # type: ignore
315
440
  if _response.status_code == 400:
@@ -334,6 +459,22 @@ class AsyncVellum:
334
459
  requests: typing.List[GenerateRequest],
335
460
  options: typing.Optional[GenerateOptionsRequest] = OMIT,
336
461
  ) -> typing.AsyncIterator[GenerateStreamResponse]:
462
+ """
463
+ <strong style="background-color:#4caf50; color:white; padding:4px; border-radius:4px">Stable</strong>
464
+
465
+ Generate a stream of completions using a previously defined deployment.
466
+
467
+ **Note:** Uses a base url of `https://predict.vellum.ai`.
468
+
469
+ Parameters:
470
+ - deployment_id: typing.Optional[str]. The ID of the deployment. Must provide either this or deployment_name.
471
+
472
+ - deployment_name: typing.Optional[str]. The name of the deployment. Must provide either this or deployment_id.
473
+
474
+ - requests: typing.List[GenerateRequest]. The generation requests to make. Supplying multiple will perform a bulk request to the LLM provided when possible.
475
+
476
+ - options: typing.Optional[GenerateOptionsRequest]. Additional configuration that can be used to control what's included in the response.
477
+ """
337
478
  _request: typing.Dict[str, typing.Any] = {"requests": requests}
338
479
  if deployment_id is not OMIT:
339
480
  _request["deployment_id"] = deployment_id
@@ -341,33 +482,33 @@ class AsyncVellum:
341
482
  _request["deployment_name"] = deployment_name
342
483
  if options is not OMIT:
343
484
  _request["options"] = options
344
- async with httpx.AsyncClient() as _client:
345
- async with _client.stream(
346
- "POST",
347
- urllib.parse.urljoin(f"{self._environment.predict}/", "v1/generate-stream"),
348
- json=jsonable_encoder(_request),
349
- headers=remove_none_from_headers({"X_API_KEY": self.api_key}),
350
- timeout=None,
351
- ) as _response:
352
- if 200 <= _response.status_code < 300:
353
- async for _text in _response.aiter_text():
354
- if len(_text) == 0:
355
- continue
356
- yield pydantic.parse_obj_as(GenerateStreamResponse, json.loads(_text)) # type: ignore
357
- return
358
- if _response.status_code == 400:
359
- raise BadRequestError(pydantic.parse_obj_as(typing.Any, _response.json())) # type: ignore
360
- if _response.status_code == 403:
361
- raise ForbiddenError(pydantic.parse_obj_as(GenerateErrorResponse, _response.json())) # type: ignore
362
- if _response.status_code == 404:
363
- raise NotFoundError(pydantic.parse_obj_as(typing.Any, _response.json())) # type: ignore
364
- if _response.status_code == 500:
365
- raise InternalServerError(pydantic.parse_obj_as(typing.Any, _response.json())) # type: ignore
366
- try:
367
- _response_json = _response.json()
368
- except JSONDecodeError:
369
- raise ApiError(status_code=_response.status_code, body=_response.text)
370
- raise ApiError(status_code=_response.status_code, body=_response_json)
485
+ async with self._client_wrapper.httpx_client.stream(
486
+ "POST",
487
+ urllib.parse.urljoin(f"{self._environment.predict}/", "v1/generate-stream"),
488
+ json=jsonable_encoder(_request),
489
+ headers=self._client_wrapper.get_headers(),
490
+ timeout=None,
491
+ ) as _response:
492
+ if 200 <= _response.status_code < 300:
493
+ async for _text in _response.aiter_lines():
494
+ if len(_text) == 0:
495
+ continue
496
+ yield pydantic.parse_obj_as(GenerateStreamResponse, json.loads(_text)) # type: ignore
497
+ return
498
+ if _response.status_code == 400:
499
+ raise BadRequestError(pydantic.parse_obj_as(typing.Any, _response.json())) # type: ignore
500
+ if _response.status_code == 403:
501
+ raise ForbiddenError(pydantic.parse_obj_as(GenerateErrorResponse, _response.json())) # type: ignore
502
+ if _response.status_code == 404:
503
+ raise NotFoundError(pydantic.parse_obj_as(typing.Any, _response.json())) # type: ignore
504
+ if _response.status_code == 500:
505
+ raise InternalServerError(pydantic.parse_obj_as(typing.Any, _response.json())) # type: ignore
506
+ try:
507
+ await _response.aread()
508
+ _response_json = _response.json()
509
+ except JSONDecodeError:
510
+ raise ApiError(status_code=_response.status_code, body=_response.text)
511
+ raise ApiError(status_code=_response.status_code, body=_response_json)
371
512
 
372
513
  async def search(
373
514
  self,
@@ -377,6 +518,22 @@ class AsyncVellum:
377
518
  query: str,
378
519
  options: typing.Optional[SearchRequestOptionsRequest] = OMIT,
379
520
  ) -> SearchResponse:
521
+ """
522
+ <strong style="background-color:#4caf50; color:white; padding:4px; border-radius:4px">Stable</strong>
523
+
524
+ Perform a search against a document index.
525
+
526
+ **Note:** Uses a base url of `https://predict.vellum.ai`.
527
+
528
+ Parameters:
529
+ - index_id: typing.Optional[str]. The ID of the index to search against. Must provide either this or index_name.
530
+
531
+ - index_name: typing.Optional[str]. The name of the index to search against. Must provide either this or index_id.
532
+
533
+ - query: str. The query to search for. <span style="white-space: nowrap">`non-empty`</span>
534
+
535
+ - options: typing.Optional[SearchRequestOptionsRequest]. Configuration options for the search.
536
+ """
380
537
  _request: typing.Dict[str, typing.Any] = {"query": query}
381
538
  if index_id is not OMIT:
382
539
  _request["index_id"] = index_id
@@ -384,14 +541,13 @@ class AsyncVellum:
384
541
  _request["index_name"] = index_name
385
542
  if options is not OMIT:
386
543
  _request["options"] = options
387
- async with httpx.AsyncClient() as _client:
388
- _response = await _client.request(
389
- "POST",
390
- urllib.parse.urljoin(f"{self._environment.predict}/", "v1/search"),
391
- json=jsonable_encoder(_request),
392
- headers=remove_none_from_headers({"X_API_KEY": self.api_key}),
393
- timeout=None,
394
- )
544
+ _response = await self._client_wrapper.httpx_client.request(
545
+ "POST",
546
+ urllib.parse.urljoin(f"{self._environment.predict}/", "v1/search"),
547
+ json=jsonable_encoder(_request),
548
+ headers=self._client_wrapper.get_headers(),
549
+ timeout=None,
550
+ )
395
551
  if 200 <= _response.status_code < 300:
396
552
  return pydantic.parse_obj_as(SearchResponse, _response.json()) # type: ignore
397
553
  if _response.status_code == 400:
@@ -413,19 +569,32 @@ class AsyncVellum:
413
569
  deployment_name: typing.Optional[str] = OMIT,
414
570
  actuals: typing.List[SubmitCompletionActualRequest],
415
571
  ) -> None:
572
+ """
573
+ <strong style="background-color:#4caf50; color:white; padding:4px; border-radius:4px">Stable</strong>
574
+
575
+ Used to submit feedback regarding the quality of previously generated completions.
576
+
577
+ **Note:** Uses a base url of `https://predict.vellum.ai`.
578
+
579
+ Parameters:
580
+ - deployment_id: typing.Optional[str]. The ID of the deployment. Must provide either this or deployment_name.
581
+
582
+ - deployment_name: typing.Optional[str]. The name of the deployment. Must provide either this or deployment_id.
583
+
584
+ - actuals: typing.List[SubmitCompletionActualRequest]. Feedback regarding the quality of previously generated completions
585
+ """
416
586
  _request: typing.Dict[str, typing.Any] = {"actuals": actuals}
417
587
  if deployment_id is not OMIT:
418
588
  _request["deployment_id"] = deployment_id
419
589
  if deployment_name is not OMIT:
420
590
  _request["deployment_name"] = deployment_name
421
- async with httpx.AsyncClient() as _client:
422
- _response = await _client.request(
423
- "POST",
424
- urllib.parse.urljoin(f"{self._environment.predict}/", "v1/submit-completion-actuals"),
425
- json=jsonable_encoder(_request),
426
- headers=remove_none_from_headers({"X_API_KEY": self.api_key}),
427
- timeout=None,
428
- )
591
+ _response = await self._client_wrapper.httpx_client.request(
592
+ "POST",
593
+ urllib.parse.urljoin(f"{self._environment.predict}/", "v1/submit-completion-actuals"),
594
+ json=jsonable_encoder(_request),
595
+ headers=self._client_wrapper.get_headers(),
596
+ timeout=None,
597
+ )
429
598
  if 200 <= _response.status_code < 300:
430
599
  return
431
600
  if _response.status_code == 400:
@@ -0,0 +1,17 @@
1
+ # This file was auto-generated by Fern from our API Definition.
2
+
3
+ from .api_error import ApiError
4
+ from .client_wrapper import AsyncClientWrapper, BaseClientWrapper, SyncClientWrapper
5
+ from .datetime_utils import serialize_datetime
6
+ from .jsonable_encoder import jsonable_encoder
7
+ from .remove_none_from_dict import remove_none_from_dict
8
+
9
+ __all__ = [
10
+ "ApiError",
11
+ "AsyncClientWrapper",
12
+ "BaseClientWrapper",
13
+ "SyncClientWrapper",
14
+ "jsonable_encoder",
15
+ "remove_none_from_dict",
16
+ "serialize_datetime",
17
+ ]
@@ -0,0 +1,27 @@
1
+ # This file was auto-generated by Fern from our API Definition.
2
+
3
+ import typing
4
+
5
+ import httpx
6
+
7
+
8
+ class BaseClientWrapper:
9
+ def __init__(self, *, api_key: str):
10
+ self.api_key = api_key
11
+
12
+ def get_headers(self) -> typing.Dict[str, str]:
13
+ headers: typing.Dict[str, str] = {}
14
+ headers["X_API_KEY"] = self.api_key
15
+ return headers
16
+
17
+
18
+ class SyncClientWrapper(BaseClientWrapper):
19
+ def __init__(self, *, api_key: str, httpx_client: httpx.Client):
20
+ super().__init__(api_key=api_key)
21
+ self.httpx_client = httpx_client
22
+
23
+
24
+ class AsyncClientWrapper(BaseClientWrapper):
25
+ def __init__(self, *, api_key: str, httpx_client: httpx.AsyncClient):
26
+ super().__init__(api_key=api_key)
27
+ self.httpx_client = httpx_client
@@ -0,0 +1,11 @@
1
+ # This file was auto-generated by Fern from our API Definition.
2
+
3
+ from typing import Any, Dict, Optional
4
+
5
+
6
+ def remove_none_from_dict(original: Dict[str, Optional[Any]]) -> Dict[str, Any]:
7
+ new: Dict[str, Any] = {}
8
+ for key, value in original.items():
9
+ if value is not None:
10
+ new[key] = value
11
+ return new