casedev 0.1.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 (185) hide show
  1. casedev/__init__.py +104 -0
  2. casedev/_base_client.py +1995 -0
  3. casedev/_client.py +560 -0
  4. casedev/_compat.py +219 -0
  5. casedev/_constants.py +14 -0
  6. casedev/_exceptions.py +108 -0
  7. casedev/_files.py +123 -0
  8. casedev/_models.py +857 -0
  9. casedev/_qs.py +150 -0
  10. casedev/_resource.py +43 -0
  11. casedev/_response.py +830 -0
  12. casedev/_streaming.py +333 -0
  13. casedev/_types.py +260 -0
  14. casedev/_utils/__init__.py +64 -0
  15. casedev/_utils/_compat.py +45 -0
  16. casedev/_utils/_datetime_parse.py +136 -0
  17. casedev/_utils/_logs.py +25 -0
  18. casedev/_utils/_proxy.py +65 -0
  19. casedev/_utils/_reflection.py +42 -0
  20. casedev/_utils/_resources_proxy.py +24 -0
  21. casedev/_utils/_streams.py +12 -0
  22. casedev/_utils/_sync.py +58 -0
  23. casedev/_utils/_transform.py +457 -0
  24. casedev/_utils/_typing.py +156 -0
  25. casedev/_utils/_utils.py +421 -0
  26. casedev/_version.py +4 -0
  27. casedev/lib/.keep +4 -0
  28. casedev/py.typed +0 -0
  29. casedev/resources/__init__.py +173 -0
  30. casedev/resources/actions/__init__.py +33 -0
  31. casedev/resources/actions/actions.py +102 -0
  32. casedev/resources/actions/v1.py +640 -0
  33. casedev/resources/compute/__init__.py +33 -0
  34. casedev/resources/compute/compute.py +102 -0
  35. casedev/resources/compute/v1/__init__.py +89 -0
  36. casedev/resources/compute/v1/environments.py +492 -0
  37. casedev/resources/compute/v1/functions.py +278 -0
  38. casedev/resources/compute/v1/invoke.py +216 -0
  39. casedev/resources/compute/v1/runs.py +290 -0
  40. casedev/resources/compute/v1/secrets.py +655 -0
  41. casedev/resources/compute/v1/v1.py +583 -0
  42. casedev/resources/convert/__init__.py +33 -0
  43. casedev/resources/convert/convert.py +102 -0
  44. casedev/resources/convert/v1/__init__.py +33 -0
  45. casedev/resources/convert/v1/jobs.py +254 -0
  46. casedev/resources/convert/v1/v1.py +450 -0
  47. casedev/resources/format/__init__.py +33 -0
  48. casedev/resources/format/format.py +102 -0
  49. casedev/resources/format/v1/__init__.py +33 -0
  50. casedev/resources/format/v1/templates.py +419 -0
  51. casedev/resources/format/v1/v1.py +244 -0
  52. casedev/resources/llm/__init__.py +33 -0
  53. casedev/resources/llm/llm.py +192 -0
  54. casedev/resources/llm/v1/__init__.py +33 -0
  55. casedev/resources/llm/v1/chat.py +243 -0
  56. casedev/resources/llm/v1/v1.py +317 -0
  57. casedev/resources/ocr/__init__.py +33 -0
  58. casedev/resources/ocr/ocr.py +102 -0
  59. casedev/resources/ocr/v1.py +407 -0
  60. casedev/resources/search/__init__.py +33 -0
  61. casedev/resources/search/search.py +102 -0
  62. casedev/resources/search/v1.py +1052 -0
  63. casedev/resources/templates/__init__.py +33 -0
  64. casedev/resources/templates/templates.py +102 -0
  65. casedev/resources/templates/v1.py +633 -0
  66. casedev/resources/vault/__init__.py +47 -0
  67. casedev/resources/vault/graphrag.py +256 -0
  68. casedev/resources/vault/objects.py +571 -0
  69. casedev/resources/vault/vault.py +764 -0
  70. casedev/resources/voice/__init__.py +61 -0
  71. casedev/resources/voice/streaming.py +160 -0
  72. casedev/resources/voice/transcription.py +327 -0
  73. casedev/resources/voice/v1/__init__.py +33 -0
  74. casedev/resources/voice/v1/speak.py +478 -0
  75. casedev/resources/voice/v1/v1.py +290 -0
  76. casedev/resources/voice/voice.py +166 -0
  77. casedev/resources/webhooks/__init__.py +33 -0
  78. casedev/resources/webhooks/v1.py +447 -0
  79. casedev/resources/webhooks/webhooks.py +102 -0
  80. casedev/resources/workflows/__init__.py +33 -0
  81. casedev/resources/workflows/v1.py +1053 -0
  82. casedev/resources/workflows/workflows.py +102 -0
  83. casedev/types/__init__.py +12 -0
  84. casedev/types/actions/__init__.py +8 -0
  85. casedev/types/actions/v1_create_params.py +22 -0
  86. casedev/types/actions/v1_create_response.py +33 -0
  87. casedev/types/actions/v1_execute_params.py +16 -0
  88. casedev/types/actions/v1_execute_response.py +31 -0
  89. casedev/types/compute/__init__.py +7 -0
  90. casedev/types/compute/v1/__init__.py +18 -0
  91. casedev/types/compute/v1/environment_create_params.py +12 -0
  92. casedev/types/compute/v1/environment_create_response.py +34 -0
  93. casedev/types/compute/v1/environment_delete_response.py +11 -0
  94. casedev/types/compute/v1/function_get_logs_params.py +12 -0
  95. casedev/types/compute/v1/function_list_params.py +12 -0
  96. casedev/types/compute/v1/invoke_run_params.py +21 -0
  97. casedev/types/compute/v1/invoke_run_response.py +39 -0
  98. casedev/types/compute/v1/run_list_params.py +18 -0
  99. casedev/types/compute/v1/secret_create_params.py +24 -0
  100. casedev/types/compute/v1/secret_create_response.py +24 -0
  101. casedev/types/compute/v1/secret_delete_group_params.py +18 -0
  102. casedev/types/compute/v1/secret_list_params.py +15 -0
  103. casedev/types/compute/v1/secret_retrieve_group_params.py +12 -0
  104. casedev/types/compute/v1/secret_update_group_params.py +16 -0
  105. casedev/types/compute/v1_deploy_params.py +114 -0
  106. casedev/types/compute/v1_deploy_response.py +30 -0
  107. casedev/types/compute/v1_get_usage_params.py +15 -0
  108. casedev/types/convert/__init__.py +8 -0
  109. casedev/types/convert/v1/__init__.py +3 -0
  110. casedev/types/convert/v1_process_params.py +15 -0
  111. casedev/types/convert/v1_process_response.py +19 -0
  112. casedev/types/convert/v1_webhook_params.py +32 -0
  113. casedev/types/convert/v1_webhook_response.py +13 -0
  114. casedev/types/format/__init__.py +5 -0
  115. casedev/types/format/v1/__init__.py +7 -0
  116. casedev/types/format/v1/template_create_params.py +32 -0
  117. casedev/types/format/v1/template_create_response.py +27 -0
  118. casedev/types/format/v1/template_list_params.py +12 -0
  119. casedev/types/format/v1_create_document_params.py +42 -0
  120. casedev/types/llm/__init__.py +5 -0
  121. casedev/types/llm/v1/__init__.py +6 -0
  122. casedev/types/llm/v1/chat_create_completion_params.py +42 -0
  123. casedev/types/llm/v1/chat_create_completion_response.py +49 -0
  124. casedev/types/llm/v1_create_embedding_params.py +27 -0
  125. casedev/types/ocr/__init__.py +6 -0
  126. casedev/types/ocr/v1_process_params.py +44 -0
  127. casedev/types/ocr/v1_process_response.py +32 -0
  128. casedev/types/search/__init__.py +15 -0
  129. casedev/types/search/v1_answer_params.py +45 -0
  130. casedev/types/search/v1_answer_response.py +35 -0
  131. casedev/types/search/v1_contents_params.py +42 -0
  132. casedev/types/search/v1_contents_response.py +31 -0
  133. casedev/types/search/v1_research_params.py +23 -0
  134. casedev/types/search/v1_research_response.py +20 -0
  135. casedev/types/search/v1_retrieve_research_params.py +15 -0
  136. casedev/types/search/v1_search_params.py +56 -0
  137. casedev/types/search/v1_search_response.py +38 -0
  138. casedev/types/search/v1_similar_params.py +44 -0
  139. casedev/types/search/v1_similar_response.py +33 -0
  140. casedev/types/templates/__init__.py +8 -0
  141. casedev/types/templates/v1_execute_params.py +22 -0
  142. casedev/types/templates/v1_execute_response.py +31 -0
  143. casedev/types/templates/v1_list_params.py +32 -0
  144. casedev/types/templates/v1_search_params.py +18 -0
  145. casedev/types/vault/__init__.py +6 -0
  146. casedev/types/vault/object_create_presigned_url_params.py +22 -0
  147. casedev/types/vault/object_create_presigned_url_response.py +51 -0
  148. casedev/types/vault_create_params.py +20 -0
  149. casedev/types/vault_create_response.py +36 -0
  150. casedev/types/vault_ingest_response.py +26 -0
  151. casedev/types/vault_list_response.py +40 -0
  152. casedev/types/vault_search_params.py +27 -0
  153. casedev/types/vault_search_response.py +53 -0
  154. casedev/types/vault_upload_params.py +26 -0
  155. casedev/types/vault_upload_response.py +39 -0
  156. casedev/types/voice/__init__.py +7 -0
  157. casedev/types/voice/transcription_create_params.py +36 -0
  158. casedev/types/voice/transcription_retrieve_response.py +41 -0
  159. casedev/types/voice/v1/__init__.py +6 -0
  160. casedev/types/voice/v1/speak_create_params.py +59 -0
  161. casedev/types/voice/v1/speak_stream_params.py +58 -0
  162. casedev/types/voice/v1_list_voices_params.py +36 -0
  163. casedev/types/webhooks/__init__.py +6 -0
  164. casedev/types/webhooks/v1_create_params.py +20 -0
  165. casedev/types/webhooks/v1_create_response.py +33 -0
  166. casedev/types/workflows/__init__.py +19 -0
  167. casedev/types/workflows/v1_create_params.py +32 -0
  168. casedev/types/workflows/v1_create_response.py +29 -0
  169. casedev/types/workflows/v1_delete_response.py +13 -0
  170. casedev/types/workflows/v1_deploy_response.py +20 -0
  171. casedev/types/workflows/v1_execute_params.py +12 -0
  172. casedev/types/workflows/v1_execute_response.py +22 -0
  173. casedev/types/workflows/v1_list_executions_params.py +13 -0
  174. casedev/types/workflows/v1_list_executions_response.py +27 -0
  175. casedev/types/workflows/v1_list_params.py +18 -0
  176. casedev/types/workflows/v1_list_response.py +37 -0
  177. casedev/types/workflows/v1_retrieve_execution_response.py +31 -0
  178. casedev/types/workflows/v1_retrieve_response.py +35 -0
  179. casedev/types/workflows/v1_undeploy_response.py +13 -0
  180. casedev/types/workflows/v1_update_params.py +26 -0
  181. casedev/types/workflows/v1_update_response.py +17 -0
  182. casedev-0.1.0.dist-info/METADATA +454 -0
  183. casedev-0.1.0.dist-info/RECORD +185 -0
  184. casedev-0.1.0.dist-info/WHEEL +4 -0
  185. casedev-0.1.0.dist-info/licenses/LICENSE +201 -0
casedev/_client.py ADDED
@@ -0,0 +1,560 @@
1
+ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ from __future__ import annotations
4
+
5
+ import os
6
+ from typing import Any, Dict, Mapping, cast
7
+ from typing_extensions import Self, Literal, override
8
+
9
+ import httpx
10
+
11
+ from . import _exceptions
12
+ from ._qs import Querystring
13
+ from ._types import (
14
+ Omit,
15
+ Timeout,
16
+ NotGiven,
17
+ Transport,
18
+ ProxiesTypes,
19
+ RequestOptions,
20
+ not_given,
21
+ )
22
+ from ._utils import is_given, get_async_library
23
+ from ._version import __version__
24
+ from ._streaming import Stream as Stream, AsyncStream as AsyncStream
25
+ from ._exceptions import CasedevError, APIStatusError
26
+ from ._base_client import (
27
+ DEFAULT_MAX_RETRIES,
28
+ SyncAPIClient,
29
+ AsyncAPIClient,
30
+ )
31
+ from .resources.llm import llm
32
+ from .resources.ocr import ocr
33
+ from .resources.vault import vault
34
+ from .resources.voice import voice
35
+ from .resources.format import format
36
+ from .resources.search import search
37
+ from .resources.actions import actions
38
+ from .resources.compute import compute
39
+ from .resources.convert import convert
40
+ from .resources.webhooks import webhooks
41
+ from .resources.templates import templates
42
+ from .resources.workflows import workflows
43
+
44
+ __all__ = [
45
+ "ENVIRONMENTS",
46
+ "Timeout",
47
+ "Transport",
48
+ "ProxiesTypes",
49
+ "RequestOptions",
50
+ "Casedev",
51
+ "AsyncCasedev",
52
+ "Client",
53
+ "AsyncClient",
54
+ ]
55
+
56
+ ENVIRONMENTS: Dict[str, str] = {
57
+ "production": "https://api.case.dev",
58
+ "local": "http://localhost:2728",
59
+ }
60
+
61
+
62
+ class Casedev(SyncAPIClient):
63
+ actions: actions.ActionsResource
64
+ compute: compute.ComputeResource
65
+ convert: convert.ConvertResource
66
+ format: format.FormatResource
67
+ llm: llm.LlmResource
68
+ ocr: ocr.OcrResource
69
+ search: search.SearchResource
70
+ vault: vault.VaultResource
71
+ voice: voice.VoiceResource
72
+ webhooks: webhooks.WebhooksResource
73
+ templates: templates.TemplatesResource
74
+ workflows: workflows.WorkflowsResource
75
+ with_raw_response: CasedevWithRawResponse
76
+ with_streaming_response: CasedevWithStreamedResponse
77
+
78
+ # client options
79
+ api_key: str
80
+
81
+ _environment: Literal["production", "local"] | NotGiven
82
+
83
+ def __init__(
84
+ self,
85
+ *,
86
+ api_key: str | None = None,
87
+ environment: Literal["production", "local"] | NotGiven = not_given,
88
+ base_url: str | httpx.URL | None | NotGiven = not_given,
89
+ timeout: float | Timeout | None | NotGiven = not_given,
90
+ max_retries: int = DEFAULT_MAX_RETRIES,
91
+ default_headers: Mapping[str, str] | None = None,
92
+ default_query: Mapping[str, object] | None = None,
93
+ # Configure a custom httpx client.
94
+ # We provide a `DefaultHttpxClient` class that you can pass to retain the default values we use for `limits`, `timeout` & `follow_redirects`.
95
+ # See the [httpx documentation](https://www.python-httpx.org/api/#client) for more details.
96
+ http_client: httpx.Client | None = None,
97
+ # Enable or disable schema validation for data returned by the API.
98
+ # When enabled an error APIResponseValidationError is raised
99
+ # if the API responds with invalid data for the expected schema.
100
+ #
101
+ # This parameter may be removed or changed in the future.
102
+ # If you rely on this feature, please open a GitHub issue
103
+ # outlining your use-case to help us decide if it should be
104
+ # part of our public interface in the future.
105
+ _strict_response_validation: bool = False,
106
+ ) -> None:
107
+ """Construct a new synchronous Casedev client instance.
108
+
109
+ This automatically infers the `api_key` argument from the `CASEDEV_API_KEY` environment variable if it is not provided.
110
+ """
111
+ if api_key is None:
112
+ api_key = os.environ.get("CASEDEV_API_KEY")
113
+ if api_key is None:
114
+ raise CasedevError(
115
+ "The api_key client option must be set either by passing api_key to the client or by setting the CASEDEV_API_KEY environment variable"
116
+ )
117
+ self.api_key = api_key
118
+
119
+ self._environment = environment
120
+
121
+ base_url_env = os.environ.get("CASEDEV_BASE_URL")
122
+ if is_given(base_url) and base_url is not None:
123
+ # cast required because mypy doesn't understand the type narrowing
124
+ base_url = cast("str | httpx.URL", base_url) # pyright: ignore[reportUnnecessaryCast]
125
+ elif is_given(environment):
126
+ if base_url_env and base_url is not None:
127
+ raise ValueError(
128
+ "Ambiguous URL; The `CASEDEV_BASE_URL` env var and the `environment` argument are given. If you want to use the environment, you must pass base_url=None",
129
+ )
130
+
131
+ try:
132
+ base_url = ENVIRONMENTS[environment]
133
+ except KeyError as exc:
134
+ raise ValueError(f"Unknown environment: {environment}") from exc
135
+ elif base_url_env is not None:
136
+ base_url = base_url_env
137
+ else:
138
+ self._environment = environment = "production"
139
+
140
+ try:
141
+ base_url = ENVIRONMENTS[environment]
142
+ except KeyError as exc:
143
+ raise ValueError(f"Unknown environment: {environment}") from exc
144
+
145
+ super().__init__(
146
+ version=__version__,
147
+ base_url=base_url,
148
+ max_retries=max_retries,
149
+ timeout=timeout,
150
+ http_client=http_client,
151
+ custom_headers=default_headers,
152
+ custom_query=default_query,
153
+ _strict_response_validation=_strict_response_validation,
154
+ )
155
+
156
+ self.actions = actions.ActionsResource(self)
157
+ self.compute = compute.ComputeResource(self)
158
+ self.convert = convert.ConvertResource(self)
159
+ self.format = format.FormatResource(self)
160
+ self.llm = llm.LlmResource(self)
161
+ self.ocr = ocr.OcrResource(self)
162
+ self.search = search.SearchResource(self)
163
+ self.vault = vault.VaultResource(self)
164
+ self.voice = voice.VoiceResource(self)
165
+ self.webhooks = webhooks.WebhooksResource(self)
166
+ self.templates = templates.TemplatesResource(self)
167
+ self.workflows = workflows.WorkflowsResource(self)
168
+ self.with_raw_response = CasedevWithRawResponse(self)
169
+ self.with_streaming_response = CasedevWithStreamedResponse(self)
170
+
171
+ @property
172
+ @override
173
+ def qs(self) -> Querystring:
174
+ return Querystring(array_format="comma")
175
+
176
+ @property
177
+ @override
178
+ def auth_headers(self) -> dict[str, str]:
179
+ api_key = self.api_key
180
+ return {"Authorization": f"Bearer {api_key}"}
181
+
182
+ @property
183
+ @override
184
+ def default_headers(self) -> dict[str, str | Omit]:
185
+ return {
186
+ **super().default_headers,
187
+ "X-Stainless-Async": "false",
188
+ **self._custom_headers,
189
+ }
190
+
191
+ def copy(
192
+ self,
193
+ *,
194
+ api_key: str | None = None,
195
+ environment: Literal["production", "local"] | None = None,
196
+ base_url: str | httpx.URL | None = None,
197
+ timeout: float | Timeout | None | NotGiven = not_given,
198
+ http_client: httpx.Client | None = None,
199
+ max_retries: int | NotGiven = not_given,
200
+ default_headers: Mapping[str, str] | None = None,
201
+ set_default_headers: Mapping[str, str] | None = None,
202
+ default_query: Mapping[str, object] | None = None,
203
+ set_default_query: Mapping[str, object] | None = None,
204
+ _extra_kwargs: Mapping[str, Any] = {},
205
+ ) -> Self:
206
+ """
207
+ Create a new client instance re-using the same options given to the current client with optional overriding.
208
+ """
209
+ if default_headers is not None and set_default_headers is not None:
210
+ raise ValueError("The `default_headers` and `set_default_headers` arguments are mutually exclusive")
211
+
212
+ if default_query is not None and set_default_query is not None:
213
+ raise ValueError("The `default_query` and `set_default_query` arguments are mutually exclusive")
214
+
215
+ headers = self._custom_headers
216
+ if default_headers is not None:
217
+ headers = {**headers, **default_headers}
218
+ elif set_default_headers is not None:
219
+ headers = set_default_headers
220
+
221
+ params = self._custom_query
222
+ if default_query is not None:
223
+ params = {**params, **default_query}
224
+ elif set_default_query is not None:
225
+ params = set_default_query
226
+
227
+ http_client = http_client or self._client
228
+ return self.__class__(
229
+ api_key=api_key or self.api_key,
230
+ base_url=base_url or self.base_url,
231
+ environment=environment or self._environment,
232
+ timeout=self.timeout if isinstance(timeout, NotGiven) else timeout,
233
+ http_client=http_client,
234
+ max_retries=max_retries if is_given(max_retries) else self.max_retries,
235
+ default_headers=headers,
236
+ default_query=params,
237
+ **_extra_kwargs,
238
+ )
239
+
240
+ # Alias for `copy` for nicer inline usage, e.g.
241
+ # client.with_options(timeout=10).foo.create(...)
242
+ with_options = copy
243
+
244
+ @override
245
+ def _make_status_error(
246
+ self,
247
+ err_msg: str,
248
+ *,
249
+ body: object,
250
+ response: httpx.Response,
251
+ ) -> APIStatusError:
252
+ if response.status_code == 400:
253
+ return _exceptions.BadRequestError(err_msg, response=response, body=body)
254
+
255
+ if response.status_code == 401:
256
+ return _exceptions.AuthenticationError(err_msg, response=response, body=body)
257
+
258
+ if response.status_code == 403:
259
+ return _exceptions.PermissionDeniedError(err_msg, response=response, body=body)
260
+
261
+ if response.status_code == 404:
262
+ return _exceptions.NotFoundError(err_msg, response=response, body=body)
263
+
264
+ if response.status_code == 409:
265
+ return _exceptions.ConflictError(err_msg, response=response, body=body)
266
+
267
+ if response.status_code == 422:
268
+ return _exceptions.UnprocessableEntityError(err_msg, response=response, body=body)
269
+
270
+ if response.status_code == 429:
271
+ return _exceptions.RateLimitError(err_msg, response=response, body=body)
272
+
273
+ if response.status_code >= 500:
274
+ return _exceptions.InternalServerError(err_msg, response=response, body=body)
275
+ return APIStatusError(err_msg, response=response, body=body)
276
+
277
+
278
+ class AsyncCasedev(AsyncAPIClient):
279
+ actions: actions.AsyncActionsResource
280
+ compute: compute.AsyncComputeResource
281
+ convert: convert.AsyncConvertResource
282
+ format: format.AsyncFormatResource
283
+ llm: llm.AsyncLlmResource
284
+ ocr: ocr.AsyncOcrResource
285
+ search: search.AsyncSearchResource
286
+ vault: vault.AsyncVaultResource
287
+ voice: voice.AsyncVoiceResource
288
+ webhooks: webhooks.AsyncWebhooksResource
289
+ templates: templates.AsyncTemplatesResource
290
+ workflows: workflows.AsyncWorkflowsResource
291
+ with_raw_response: AsyncCasedevWithRawResponse
292
+ with_streaming_response: AsyncCasedevWithStreamedResponse
293
+
294
+ # client options
295
+ api_key: str
296
+
297
+ _environment: Literal["production", "local"] | NotGiven
298
+
299
+ def __init__(
300
+ self,
301
+ *,
302
+ api_key: str | None = None,
303
+ environment: Literal["production", "local"] | NotGiven = not_given,
304
+ base_url: str | httpx.URL | None | NotGiven = not_given,
305
+ timeout: float | Timeout | None | NotGiven = not_given,
306
+ max_retries: int = DEFAULT_MAX_RETRIES,
307
+ default_headers: Mapping[str, str] | None = None,
308
+ default_query: Mapping[str, object] | None = None,
309
+ # Configure a custom httpx client.
310
+ # We provide a `DefaultAsyncHttpxClient` class that you can pass to retain the default values we use for `limits`, `timeout` & `follow_redirects`.
311
+ # See the [httpx documentation](https://www.python-httpx.org/api/#asyncclient) for more details.
312
+ http_client: httpx.AsyncClient | None = None,
313
+ # Enable or disable schema validation for data returned by the API.
314
+ # When enabled an error APIResponseValidationError is raised
315
+ # if the API responds with invalid data for the expected schema.
316
+ #
317
+ # This parameter may be removed or changed in the future.
318
+ # If you rely on this feature, please open a GitHub issue
319
+ # outlining your use-case to help us decide if it should be
320
+ # part of our public interface in the future.
321
+ _strict_response_validation: bool = False,
322
+ ) -> None:
323
+ """Construct a new async AsyncCasedev client instance.
324
+
325
+ This automatically infers the `api_key` argument from the `CASEDEV_API_KEY` environment variable if it is not provided.
326
+ """
327
+ if api_key is None:
328
+ api_key = os.environ.get("CASEDEV_API_KEY")
329
+ if api_key is None:
330
+ raise CasedevError(
331
+ "The api_key client option must be set either by passing api_key to the client or by setting the CASEDEV_API_KEY environment variable"
332
+ )
333
+ self.api_key = api_key
334
+
335
+ self._environment = environment
336
+
337
+ base_url_env = os.environ.get("CASEDEV_BASE_URL")
338
+ if is_given(base_url) and base_url is not None:
339
+ # cast required because mypy doesn't understand the type narrowing
340
+ base_url = cast("str | httpx.URL", base_url) # pyright: ignore[reportUnnecessaryCast]
341
+ elif is_given(environment):
342
+ if base_url_env and base_url is not None:
343
+ raise ValueError(
344
+ "Ambiguous URL; The `CASEDEV_BASE_URL` env var and the `environment` argument are given. If you want to use the environment, you must pass base_url=None",
345
+ )
346
+
347
+ try:
348
+ base_url = ENVIRONMENTS[environment]
349
+ except KeyError as exc:
350
+ raise ValueError(f"Unknown environment: {environment}") from exc
351
+ elif base_url_env is not None:
352
+ base_url = base_url_env
353
+ else:
354
+ self._environment = environment = "production"
355
+
356
+ try:
357
+ base_url = ENVIRONMENTS[environment]
358
+ except KeyError as exc:
359
+ raise ValueError(f"Unknown environment: {environment}") from exc
360
+
361
+ super().__init__(
362
+ version=__version__,
363
+ base_url=base_url,
364
+ max_retries=max_retries,
365
+ timeout=timeout,
366
+ http_client=http_client,
367
+ custom_headers=default_headers,
368
+ custom_query=default_query,
369
+ _strict_response_validation=_strict_response_validation,
370
+ )
371
+
372
+ self.actions = actions.AsyncActionsResource(self)
373
+ self.compute = compute.AsyncComputeResource(self)
374
+ self.convert = convert.AsyncConvertResource(self)
375
+ self.format = format.AsyncFormatResource(self)
376
+ self.llm = llm.AsyncLlmResource(self)
377
+ self.ocr = ocr.AsyncOcrResource(self)
378
+ self.search = search.AsyncSearchResource(self)
379
+ self.vault = vault.AsyncVaultResource(self)
380
+ self.voice = voice.AsyncVoiceResource(self)
381
+ self.webhooks = webhooks.AsyncWebhooksResource(self)
382
+ self.templates = templates.AsyncTemplatesResource(self)
383
+ self.workflows = workflows.AsyncWorkflowsResource(self)
384
+ self.with_raw_response = AsyncCasedevWithRawResponse(self)
385
+ self.with_streaming_response = AsyncCasedevWithStreamedResponse(self)
386
+
387
+ @property
388
+ @override
389
+ def qs(self) -> Querystring:
390
+ return Querystring(array_format="comma")
391
+
392
+ @property
393
+ @override
394
+ def auth_headers(self) -> dict[str, str]:
395
+ api_key = self.api_key
396
+ return {"Authorization": f"Bearer {api_key}"}
397
+
398
+ @property
399
+ @override
400
+ def default_headers(self) -> dict[str, str | Omit]:
401
+ return {
402
+ **super().default_headers,
403
+ "X-Stainless-Async": f"async:{get_async_library()}",
404
+ **self._custom_headers,
405
+ }
406
+
407
+ def copy(
408
+ self,
409
+ *,
410
+ api_key: str | None = None,
411
+ environment: Literal["production", "local"] | None = None,
412
+ base_url: str | httpx.URL | None = None,
413
+ timeout: float | Timeout | None | NotGiven = not_given,
414
+ http_client: httpx.AsyncClient | None = None,
415
+ max_retries: int | NotGiven = not_given,
416
+ default_headers: Mapping[str, str] | None = None,
417
+ set_default_headers: Mapping[str, str] | None = None,
418
+ default_query: Mapping[str, object] | None = None,
419
+ set_default_query: Mapping[str, object] | None = None,
420
+ _extra_kwargs: Mapping[str, Any] = {},
421
+ ) -> Self:
422
+ """
423
+ Create a new client instance re-using the same options given to the current client with optional overriding.
424
+ """
425
+ if default_headers is not None and set_default_headers is not None:
426
+ raise ValueError("The `default_headers` and `set_default_headers` arguments are mutually exclusive")
427
+
428
+ if default_query is not None and set_default_query is not None:
429
+ raise ValueError("The `default_query` and `set_default_query` arguments are mutually exclusive")
430
+
431
+ headers = self._custom_headers
432
+ if default_headers is not None:
433
+ headers = {**headers, **default_headers}
434
+ elif set_default_headers is not None:
435
+ headers = set_default_headers
436
+
437
+ params = self._custom_query
438
+ if default_query is not None:
439
+ params = {**params, **default_query}
440
+ elif set_default_query is not None:
441
+ params = set_default_query
442
+
443
+ http_client = http_client or self._client
444
+ return self.__class__(
445
+ api_key=api_key or self.api_key,
446
+ base_url=base_url or self.base_url,
447
+ environment=environment or self._environment,
448
+ timeout=self.timeout if isinstance(timeout, NotGiven) else timeout,
449
+ http_client=http_client,
450
+ max_retries=max_retries if is_given(max_retries) else self.max_retries,
451
+ default_headers=headers,
452
+ default_query=params,
453
+ **_extra_kwargs,
454
+ )
455
+
456
+ # Alias for `copy` for nicer inline usage, e.g.
457
+ # client.with_options(timeout=10).foo.create(...)
458
+ with_options = copy
459
+
460
+ @override
461
+ def _make_status_error(
462
+ self,
463
+ err_msg: str,
464
+ *,
465
+ body: object,
466
+ response: httpx.Response,
467
+ ) -> APIStatusError:
468
+ if response.status_code == 400:
469
+ return _exceptions.BadRequestError(err_msg, response=response, body=body)
470
+
471
+ if response.status_code == 401:
472
+ return _exceptions.AuthenticationError(err_msg, response=response, body=body)
473
+
474
+ if response.status_code == 403:
475
+ return _exceptions.PermissionDeniedError(err_msg, response=response, body=body)
476
+
477
+ if response.status_code == 404:
478
+ return _exceptions.NotFoundError(err_msg, response=response, body=body)
479
+
480
+ if response.status_code == 409:
481
+ return _exceptions.ConflictError(err_msg, response=response, body=body)
482
+
483
+ if response.status_code == 422:
484
+ return _exceptions.UnprocessableEntityError(err_msg, response=response, body=body)
485
+
486
+ if response.status_code == 429:
487
+ return _exceptions.RateLimitError(err_msg, response=response, body=body)
488
+
489
+ if response.status_code >= 500:
490
+ return _exceptions.InternalServerError(err_msg, response=response, body=body)
491
+ return APIStatusError(err_msg, response=response, body=body)
492
+
493
+
494
+ class CasedevWithRawResponse:
495
+ def __init__(self, client: Casedev) -> None:
496
+ self.actions = actions.ActionsResourceWithRawResponse(client.actions)
497
+ self.compute = compute.ComputeResourceWithRawResponse(client.compute)
498
+ self.convert = convert.ConvertResourceWithRawResponse(client.convert)
499
+ self.format = format.FormatResourceWithRawResponse(client.format)
500
+ self.llm = llm.LlmResourceWithRawResponse(client.llm)
501
+ self.ocr = ocr.OcrResourceWithRawResponse(client.ocr)
502
+ self.search = search.SearchResourceWithRawResponse(client.search)
503
+ self.vault = vault.VaultResourceWithRawResponse(client.vault)
504
+ self.voice = voice.VoiceResourceWithRawResponse(client.voice)
505
+ self.webhooks = webhooks.WebhooksResourceWithRawResponse(client.webhooks)
506
+ self.templates = templates.TemplatesResourceWithRawResponse(client.templates)
507
+ self.workflows = workflows.WorkflowsResourceWithRawResponse(client.workflows)
508
+
509
+
510
+ class AsyncCasedevWithRawResponse:
511
+ def __init__(self, client: AsyncCasedev) -> None:
512
+ self.actions = actions.AsyncActionsResourceWithRawResponse(client.actions)
513
+ self.compute = compute.AsyncComputeResourceWithRawResponse(client.compute)
514
+ self.convert = convert.AsyncConvertResourceWithRawResponse(client.convert)
515
+ self.format = format.AsyncFormatResourceWithRawResponse(client.format)
516
+ self.llm = llm.AsyncLlmResourceWithRawResponse(client.llm)
517
+ self.ocr = ocr.AsyncOcrResourceWithRawResponse(client.ocr)
518
+ self.search = search.AsyncSearchResourceWithRawResponse(client.search)
519
+ self.vault = vault.AsyncVaultResourceWithRawResponse(client.vault)
520
+ self.voice = voice.AsyncVoiceResourceWithRawResponse(client.voice)
521
+ self.webhooks = webhooks.AsyncWebhooksResourceWithRawResponse(client.webhooks)
522
+ self.templates = templates.AsyncTemplatesResourceWithRawResponse(client.templates)
523
+ self.workflows = workflows.AsyncWorkflowsResourceWithRawResponse(client.workflows)
524
+
525
+
526
+ class CasedevWithStreamedResponse:
527
+ def __init__(self, client: Casedev) -> None:
528
+ self.actions = actions.ActionsResourceWithStreamingResponse(client.actions)
529
+ self.compute = compute.ComputeResourceWithStreamingResponse(client.compute)
530
+ self.convert = convert.ConvertResourceWithStreamingResponse(client.convert)
531
+ self.format = format.FormatResourceWithStreamingResponse(client.format)
532
+ self.llm = llm.LlmResourceWithStreamingResponse(client.llm)
533
+ self.ocr = ocr.OcrResourceWithStreamingResponse(client.ocr)
534
+ self.search = search.SearchResourceWithStreamingResponse(client.search)
535
+ self.vault = vault.VaultResourceWithStreamingResponse(client.vault)
536
+ self.voice = voice.VoiceResourceWithStreamingResponse(client.voice)
537
+ self.webhooks = webhooks.WebhooksResourceWithStreamingResponse(client.webhooks)
538
+ self.templates = templates.TemplatesResourceWithStreamingResponse(client.templates)
539
+ self.workflows = workflows.WorkflowsResourceWithStreamingResponse(client.workflows)
540
+
541
+
542
+ class AsyncCasedevWithStreamedResponse:
543
+ def __init__(self, client: AsyncCasedev) -> None:
544
+ self.actions = actions.AsyncActionsResourceWithStreamingResponse(client.actions)
545
+ self.compute = compute.AsyncComputeResourceWithStreamingResponse(client.compute)
546
+ self.convert = convert.AsyncConvertResourceWithStreamingResponse(client.convert)
547
+ self.format = format.AsyncFormatResourceWithStreamingResponse(client.format)
548
+ self.llm = llm.AsyncLlmResourceWithStreamingResponse(client.llm)
549
+ self.ocr = ocr.AsyncOcrResourceWithStreamingResponse(client.ocr)
550
+ self.search = search.AsyncSearchResourceWithStreamingResponse(client.search)
551
+ self.vault = vault.AsyncVaultResourceWithStreamingResponse(client.vault)
552
+ self.voice = voice.AsyncVoiceResourceWithStreamingResponse(client.voice)
553
+ self.webhooks = webhooks.AsyncWebhooksResourceWithStreamingResponse(client.webhooks)
554
+ self.templates = templates.AsyncTemplatesResourceWithStreamingResponse(client.templates)
555
+ self.workflows = workflows.AsyncWorkflowsResourceWithStreamingResponse(client.workflows)
556
+
557
+
558
+ Client = Casedev
559
+
560
+ AsyncClient = AsyncCasedev