From 55a5f9fe4597ee8bf0d81ac8ea83336a360dd267 Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Thu, 20 Jun 2024 05:01:03 +0000 Subject: [PATCH] feat(api): update via SDK Studio (#1089) --- .stats.yml | 2 +- api.md | 50 +- .../resources/ai_gateway/ai_gateway.py | 1 + .../resources/ai_gateway/logs/__init__.py | 47 ++ .../resources/ai_gateway/{ => logs}/logs.py | 206 +++++++- .../resources/ai_gateway/logs/request.py | 158 ++++++ .../resources/ai_gateway/logs/response.py | 158 ++++++ .../stream/captions/language/language.py | 110 +++++ .../resources/zero_trust/gateway/__init__.py | 14 + .../zero_trust/gateway/certificates.py | 450 ++++++++++++++++++ .../resources/zero_trust/gateway/gateway.py | 32 ++ src/cloudflare/types/ai_gateway/__init__.py | 3 +- .../types/ai_gateway/log_get_response.py | 9 +- .../{log_get_params.py => log_list_params.py} | 4 +- .../types/ai_gateway/log_list_response.py | 46 ++ .../types/ai_gateway/logs/__init__.py | 3 + .../types/zero_trust/gateway/__init__.py | 5 + .../gateway/certificate_create_params.py | 17 + .../gateway/certificate_create_response.py | 31 ++ .../gateway/certificate_delete_response.py | 31 ++ .../gateway/certificate_get_response.py | 31 ++ .../gateway/certificate_list_response.py | 31 ++ .../api_resources/ai_gateway/logs/__init__.py | 1 + .../ai_gateway/logs/test_request.py | 141 ++++++ .../ai_gateway/logs/test_response.py | 141 ++++++ tests/api_resources/ai_gateway/test_logs.py | 155 +++++- .../stream/captions/test_language.py | 120 +++++ .../zero_trust/gateway/test_certificates.py | 388 +++++++++++++++ 28 files changed, 2336 insertions(+), 49 deletions(-) create mode 100644 src/cloudflare/resources/ai_gateway/logs/__init__.py rename src/cloudflare/resources/ai_gateway/{ => logs}/logs.py (51%) create mode 100644 src/cloudflare/resources/ai_gateway/logs/request.py create mode 100644 src/cloudflare/resources/ai_gateway/logs/response.py create mode 100644 src/cloudflare/resources/zero_trust/gateway/certificates.py rename src/cloudflare/types/ai_gateway/{log_get_params.py => log_list_params.py} (89%) create mode 100644 src/cloudflare/types/ai_gateway/log_list_response.py create mode 100644 src/cloudflare/types/ai_gateway/logs/__init__.py create mode 100644 src/cloudflare/types/zero_trust/gateway/certificate_create_params.py create mode 100644 src/cloudflare/types/zero_trust/gateway/certificate_create_response.py create mode 100644 src/cloudflare/types/zero_trust/gateway/certificate_delete_response.py create mode 100644 src/cloudflare/types/zero_trust/gateway/certificate_get_response.py create mode 100644 src/cloudflare/types/zero_trust/gateway/certificate_list_response.py create mode 100644 tests/api_resources/ai_gateway/logs/__init__.py create mode 100644 tests/api_resources/ai_gateway/logs/test_request.py create mode 100644 tests/api_resources/ai_gateway/logs/test_response.py create mode 100644 tests/api_resources/zero_trust/gateway/test_certificates.py diff --git a/.stats.yml b/.stats.yml index 0df12874625..83a45871666 100644 --- a/.stats.yml +++ b/.stats.yml @@ -1,2 +1,2 @@ -configured_endpoints: 1348 +configured_endpoints: 1356 openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/cloudflare%2Fcloudflare-08b201ef13ebb4bdf13a4d2e2165229fc6e5a369c64cf4a108835b65996cd957.yml diff --git a/api.md b/api.md index bc3718ff6b4..fa00c410812 100644 --- a/api.md +++ b/api.md @@ -4637,6 +4637,7 @@ from cloudflare.types.stream.captions import LanguageDeleteResponse Methods: +- client.stream.captions.language.create(language, \*, account_id, identifier) -> Optional - client.stream.captions.language.update(language, \*, account_id, identifier, \*\*params) -> Optional - client.stream.captions.language.delete(language, \*, account_id, identifier) -> str - client.stream.captions.language.get(language, \*, account_id, identifier) -> Optional @@ -6165,6 +6166,26 @@ Methods: - client.zero_trust.gateway.rules.delete(rule_id, \*, account_id) -> Optional - client.zero_trust.gateway.rules.get(rule_id, \*, account_id) -> Optional +### Certificates + +Types: + +```python +from cloudflare.types.zero_trust.gateway import ( + CertificateCreateResponse, + CertificateListResponse, + CertificateDeleteResponse, + CertificateGetResponse, +) +``` + +Methods: + +- client.zero_trust.gateway.certificates.create(\*, account_id, \*\*params) -> Optional +- client.zero_trust.gateway.certificates.list(\*, account_id) -> SyncSinglePage[CertificateListResponse] +- client.zero_trust.gateway.certificates.delete(certificate_id, \*, account_id) -> Optional +- client.zero_trust.gateway.certificates.get(certificate_id, \*, account_id) -> Optional + ## Networks ### Routes @@ -7865,12 +7886,37 @@ Methods: Types: ```python -from cloudflare.types.ai_gateway import LogGetResponse +from cloudflare.types.ai_gateway import LogListResponse, LogGetResponse +``` + +Methods: + +- client.ai_gateway.logs.list(id, \*, account_id, \*\*params) -> SyncV4PagePaginationArray[LogListResponse] +- client.ai_gateway.logs.get(log_id, \*, account_id, id) -> LogGetResponse + +### Request + +Types: + +```python +from cloudflare.types.ai_gateway.logs import RequestGetResponse +``` + +Methods: + +- client.ai_gateway.logs.request.get(log_id, \*, account_id, id) -> object + +### Response + +Types: + +```python +from cloudflare.types.ai_gateway.logs import ResponseGetResponse ``` Methods: -- client.ai_gateway.logs.get(id, \*, account_id, \*\*params) -> LogGetResponse +- client.ai_gateway.logs.response.get(log_id, \*, account_id, id) -> object # IAM diff --git a/src/cloudflare/resources/ai_gateway/ai_gateway.py b/src/cloudflare/resources/ai_gateway/ai_gateway.py index ac5a9237f0b..2d11d809968 100644 --- a/src/cloudflare/resources/ai_gateway/ai_gateway.py +++ b/src/cloudflare/resources/ai_gateway/ai_gateway.py @@ -21,6 +21,7 @@ async_maybe_transform, ) from ..._compat import cached_property +from .logs.logs import LogsResource, AsyncLogsResource from ..._resource import SyncAPIResource, AsyncAPIResource from ..._response import ( to_raw_response_wrapper, diff --git a/src/cloudflare/resources/ai_gateway/logs/__init__.py b/src/cloudflare/resources/ai_gateway/logs/__init__.py new file mode 100644 index 00000000000..cd50acd99fc --- /dev/null +++ b/src/cloudflare/resources/ai_gateway/logs/__init__.py @@ -0,0 +1,47 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from .logs import ( + LogsResource, + AsyncLogsResource, + LogsResourceWithRawResponse, + AsyncLogsResourceWithRawResponse, + LogsResourceWithStreamingResponse, + AsyncLogsResourceWithStreamingResponse, +) +from .request import ( + RequestResource, + AsyncRequestResource, + RequestResourceWithRawResponse, + AsyncRequestResourceWithRawResponse, + RequestResourceWithStreamingResponse, + AsyncRequestResourceWithStreamingResponse, +) +from .response import ( + ResponseResource, + AsyncResponseResource, + ResponseResourceWithRawResponse, + AsyncResponseResourceWithRawResponse, + ResponseResourceWithStreamingResponse, + AsyncResponseResourceWithStreamingResponse, +) + +__all__ = [ + "RequestResource", + "AsyncRequestResource", + "RequestResourceWithRawResponse", + "AsyncRequestResourceWithRawResponse", + "RequestResourceWithStreamingResponse", + "AsyncRequestResourceWithStreamingResponse", + "ResponseResource", + "AsyncResponseResource", + "ResponseResourceWithRawResponse", + "AsyncResponseResourceWithRawResponse", + "ResponseResourceWithStreamingResponse", + "AsyncResponseResourceWithStreamingResponse", + "LogsResource", + "AsyncLogsResource", + "LogsResourceWithRawResponse", + "AsyncLogsResourceWithRawResponse", + "LogsResourceWithStreamingResponse", + "AsyncLogsResourceWithStreamingResponse", +] diff --git a/src/cloudflare/resources/ai_gateway/logs.py b/src/cloudflare/resources/ai_gateway/logs/logs.py similarity index 51% rename from src/cloudflare/resources/ai_gateway/logs.py rename to src/cloudflare/resources/ai_gateway/logs/logs.py index 01650e97aa3..2176d77bef7 100644 --- a/src/cloudflare/resources/ai_gateway/logs.py +++ b/src/cloudflare/resources/ai_gateway/logs/logs.py @@ -8,30 +8,54 @@ import httpx -from ..._types import NOT_GIVEN, Body, Query, Headers, NotGiven -from ..._utils import ( - maybe_transform, - async_maybe_transform, +from .request import ( + RequestResource, + AsyncRequestResource, + RequestResourceWithRawResponse, + AsyncRequestResourceWithRawResponse, + RequestResourceWithStreamingResponse, + AsyncRequestResourceWithStreamingResponse, ) -from ..._compat import cached_property -from ..._resource import SyncAPIResource, AsyncAPIResource -from ..._response import ( +from .response import ( + ResponseResource, + AsyncResponseResource, + ResponseResourceWithRawResponse, + AsyncResponseResourceWithRawResponse, + ResponseResourceWithStreamingResponse, + AsyncResponseResourceWithStreamingResponse, +) +from ...._types import NOT_GIVEN, Body, Query, Headers, NotGiven +from ...._utils import maybe_transform +from ...._compat import cached_property +from ...._resource import SyncAPIResource, AsyncAPIResource +from ...._response import ( to_raw_response_wrapper, to_streamed_response_wrapper, async_to_raw_response_wrapper, async_to_streamed_response_wrapper, ) -from ..._wrappers import ResultWrapper -from ..._base_client import ( +from ...._wrappers import ResultWrapper +from ....pagination import SyncV4PagePaginationArray, AsyncV4PagePaginationArray +from ...._base_client import ( + AsyncPaginator, make_request_options, ) -from ...types.ai_gateway import log_get_params -from ...types.ai_gateway.log_get_response import LogGetResponse +from ....types.ai_gateway import log_list_params +from ....types.ai_gateway.log_get_response import LogGetResponse +from ....types.ai_gateway.log_list_response import LogListResponse __all__ = ["LogsResource", "AsyncLogsResource"] class LogsResource(SyncAPIResource): + @cached_property + def request(self) -> RequestResource: + return RequestResource(self._client) + + @cached_property + def response(self) -> ResponseResource: + return ResponseResource(self._client) + @cached_property def with_raw_response(self) -> LogsResourceWithRawResponse: return LogsResourceWithRawResponse(self) @@ -40,7 +64,7 @@ def with_raw_response(self) -> LogsResourceWithRawResponse: def with_streaming_response(self) -> LogsResourceWithStreamingResponse: return LogsResourceWithStreamingResponse(self) - def get( + def list( self, id: str, *, @@ -60,7 +84,7 @@ def get( extra_query: Query | None = None, extra_body: Body | None = None, timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, - ) -> LogGetResponse: + ) -> SyncV4PagePaginationArray[LogListResponse]: """ List Gateway Logs @@ -79,8 +103,9 @@ def get( raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") if not id: raise ValueError(f"Expected a non-empty value for `id` but received {id!r}") - return self._get( + return self._get_api_list( f"/accounts/{account_id}/ai-gateway/gateways/{id}/logs", + page=SyncV4PagePaginationArray[LogListResponse], options=make_request_options( extra_headers=extra_headers, extra_query=extra_query, @@ -98,8 +123,52 @@ def get( "start_date": start_date, "success": success, }, - log_get_params.LogGetParams, + log_list_params.LogListParams, ), + ), + model=LogListResponse, + ) + + def get( + self, + log_id: str, + *, + account_id: str, + id: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> LogGetResponse: + """ + Get Gateway Log Detail + + Args: + id: gateway id + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not id: + raise ValueError(f"Expected a non-empty value for `id` but received {id!r}") + if not log_id: + raise ValueError(f"Expected a non-empty value for `log_id` but received {log_id!r}") + return self._get( + f"/accounts/{account_id}/ai-gateway/gateways/{id}/logs/{log_id}", + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, post_parser=ResultWrapper[LogGetResponse]._unwrapper, ), cast_to=cast(Type[LogGetResponse], ResultWrapper[LogGetResponse]), @@ -107,6 +176,14 @@ def get( class AsyncLogsResource(AsyncAPIResource): + @cached_property + def request(self) -> AsyncRequestResource: + return AsyncRequestResource(self._client) + + @cached_property + def response(self) -> AsyncResponseResource: + return AsyncResponseResource(self._client) + @cached_property def with_raw_response(self) -> AsyncLogsResourceWithRawResponse: return AsyncLogsResourceWithRawResponse(self) @@ -115,7 +192,7 @@ def with_raw_response(self) -> AsyncLogsResourceWithRawResponse: def with_streaming_response(self) -> AsyncLogsResourceWithStreamingResponse: return AsyncLogsResourceWithStreamingResponse(self) - async def get( + def list( self, id: str, *, @@ -135,7 +212,7 @@ async def get( extra_query: Query | None = None, extra_body: Body | None = None, timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, - ) -> LogGetResponse: + ) -> AsyncPaginator[LogListResponse, AsyncV4PagePaginationArray[LogListResponse]]: """ List Gateway Logs @@ -154,14 +231,15 @@ async def get( raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") if not id: raise ValueError(f"Expected a non-empty value for `id` but received {id!r}") - return await self._get( + return self._get_api_list( f"/accounts/{account_id}/ai-gateway/gateways/{id}/logs", + page=AsyncV4PagePaginationArray[LogListResponse], options=make_request_options( extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout, - query=await async_maybe_transform( + query=maybe_transform( { "cached": cached, "direction": direction, @@ -173,8 +251,52 @@ async def get( "start_date": start_date, "success": success, }, - log_get_params.LogGetParams, + log_list_params.LogListParams, ), + ), + model=LogListResponse, + ) + + async def get( + self, + log_id: str, + *, + account_id: str, + id: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> LogGetResponse: + """ + Get Gateway Log Detail + + Args: + id: gateway id + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not id: + raise ValueError(f"Expected a non-empty value for `id` but received {id!r}") + if not log_id: + raise ValueError(f"Expected a non-empty value for `log_id` but received {log_id!r}") + return await self._get( + f"/accounts/{account_id}/ai-gateway/gateways/{id}/logs/{log_id}", + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, post_parser=ResultWrapper[LogGetResponse]._unwrapper, ), cast_to=cast(Type[LogGetResponse], ResultWrapper[LogGetResponse]), @@ -185,33 +307,77 @@ class LogsResourceWithRawResponse: def __init__(self, logs: LogsResource) -> None: self._logs = logs + self.list = to_raw_response_wrapper( + logs.list, + ) self.get = to_raw_response_wrapper( logs.get, ) + @cached_property + def request(self) -> RequestResourceWithRawResponse: + return RequestResourceWithRawResponse(self._logs.request) + + @cached_property + def response(self) -> ResponseResourceWithRawResponse: + return ResponseResourceWithRawResponse(self._logs.response) + class AsyncLogsResourceWithRawResponse: def __init__(self, logs: AsyncLogsResource) -> None: self._logs = logs + self.list = async_to_raw_response_wrapper( + logs.list, + ) self.get = async_to_raw_response_wrapper( logs.get, ) + @cached_property + def request(self) -> AsyncRequestResourceWithRawResponse: + return AsyncRequestResourceWithRawResponse(self._logs.request) + + @cached_property + def response(self) -> AsyncResponseResourceWithRawResponse: + return AsyncResponseResourceWithRawResponse(self._logs.response) + class LogsResourceWithStreamingResponse: def __init__(self, logs: LogsResource) -> None: self._logs = logs + self.list = to_streamed_response_wrapper( + logs.list, + ) self.get = to_streamed_response_wrapper( logs.get, ) + @cached_property + def request(self) -> RequestResourceWithStreamingResponse: + return RequestResourceWithStreamingResponse(self._logs.request) + + @cached_property + def response(self) -> ResponseResourceWithStreamingResponse: + return ResponseResourceWithStreamingResponse(self._logs.response) + class AsyncLogsResourceWithStreamingResponse: def __init__(self, logs: AsyncLogsResource) -> None: self._logs = logs + self.list = async_to_streamed_response_wrapper( + logs.list, + ) self.get = async_to_streamed_response_wrapper( logs.get, ) + + @cached_property + def request(self) -> AsyncRequestResourceWithStreamingResponse: + return AsyncRequestResourceWithStreamingResponse(self._logs.request) + + @cached_property + def response(self) -> AsyncResponseResourceWithStreamingResponse: + return AsyncResponseResourceWithStreamingResponse(self._logs.response) diff --git a/src/cloudflare/resources/ai_gateway/logs/request.py b/src/cloudflare/resources/ai_gateway/logs/request.py new file mode 100644 index 00000000000..05a85c72ef3 --- /dev/null +++ b/src/cloudflare/resources/ai_gateway/logs/request.py @@ -0,0 +1,158 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +import httpx + +from ...._types import NOT_GIVEN, Body, Query, Headers, NotGiven +from ...._compat import cached_property +from ...._resource import SyncAPIResource, AsyncAPIResource +from ...._response import ( + to_raw_response_wrapper, + to_streamed_response_wrapper, + async_to_raw_response_wrapper, + async_to_streamed_response_wrapper, +) +from ...._base_client import ( + make_request_options, +) + +__all__ = ["RequestResource", "AsyncRequestResource"] + + +class RequestResource(SyncAPIResource): + @cached_property + def with_raw_response(self) -> RequestResourceWithRawResponse: + return RequestResourceWithRawResponse(self) + + @cached_property + def with_streaming_response(self) -> RequestResourceWithStreamingResponse: + return RequestResourceWithStreamingResponse(self) + + def get( + self, + log_id: str, + *, + account_id: str, + id: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> object: + """ + Get Gateway Log Request + + Args: + id: gateway id + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not id: + raise ValueError(f"Expected a non-empty value for `id` but received {id!r}") + if not log_id: + raise ValueError(f"Expected a non-empty value for `log_id` but received {log_id!r}") + return self._get( + f"/accounts/{account_id}/ai-gateway/gateways/{id}/logs/{log_id}/request", + options=make_request_options( + extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout + ), + cast_to=object, + ) + + +class AsyncRequestResource(AsyncAPIResource): + @cached_property + def with_raw_response(self) -> AsyncRequestResourceWithRawResponse: + return AsyncRequestResourceWithRawResponse(self) + + @cached_property + def with_streaming_response(self) -> AsyncRequestResourceWithStreamingResponse: + return AsyncRequestResourceWithStreamingResponse(self) + + async def get( + self, + log_id: str, + *, + account_id: str, + id: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> object: + """ + Get Gateway Log Request + + Args: + id: gateway id + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not id: + raise ValueError(f"Expected a non-empty value for `id` but received {id!r}") + if not log_id: + raise ValueError(f"Expected a non-empty value for `log_id` but received {log_id!r}") + return await self._get( + f"/accounts/{account_id}/ai-gateway/gateways/{id}/logs/{log_id}/request", + options=make_request_options( + extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout + ), + cast_to=object, + ) + + +class RequestResourceWithRawResponse: + def __init__(self, request: RequestResource) -> None: + self._request = request + + self.get = to_raw_response_wrapper( + request.get, + ) + + +class AsyncRequestResourceWithRawResponse: + def __init__(self, request: AsyncRequestResource) -> None: + self._request = request + + self.get = async_to_raw_response_wrapper( + request.get, + ) + + +class RequestResourceWithStreamingResponse: + def __init__(self, request: RequestResource) -> None: + self._request = request + + self.get = to_streamed_response_wrapper( + request.get, + ) + + +class AsyncRequestResourceWithStreamingResponse: + def __init__(self, request: AsyncRequestResource) -> None: + self._request = request + + self.get = async_to_streamed_response_wrapper( + request.get, + ) diff --git a/src/cloudflare/resources/ai_gateway/logs/response.py b/src/cloudflare/resources/ai_gateway/logs/response.py new file mode 100644 index 00000000000..e70ec94a87b --- /dev/null +++ b/src/cloudflare/resources/ai_gateway/logs/response.py @@ -0,0 +1,158 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +import httpx + +from ...._types import NOT_GIVEN, Body, Query, Headers, NotGiven +from ...._compat import cached_property +from ...._resource import SyncAPIResource, AsyncAPIResource +from ...._response import ( + to_raw_response_wrapper, + to_streamed_response_wrapper, + async_to_raw_response_wrapper, + async_to_streamed_response_wrapper, +) +from ...._base_client import ( + make_request_options, +) + +__all__ = ["ResponseResource", "AsyncResponseResource"] + + +class ResponseResource(SyncAPIResource): + @cached_property + def with_raw_response(self) -> ResponseResourceWithRawResponse: + return ResponseResourceWithRawResponse(self) + + @cached_property + def with_streaming_response(self) -> ResponseResourceWithStreamingResponse: + return ResponseResourceWithStreamingResponse(self) + + def get( + self, + log_id: str, + *, + account_id: str, + id: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> object: + """ + Get Gateway Log Response + + Args: + id: gateway id + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not id: + raise ValueError(f"Expected a non-empty value for `id` but received {id!r}") + if not log_id: + raise ValueError(f"Expected a non-empty value for `log_id` but received {log_id!r}") + return self._get( + f"/accounts/{account_id}/ai-gateway/gateways/{id}/logs/{log_id}/response", + options=make_request_options( + extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout + ), + cast_to=object, + ) + + +class AsyncResponseResource(AsyncAPIResource): + @cached_property + def with_raw_response(self) -> AsyncResponseResourceWithRawResponse: + return AsyncResponseResourceWithRawResponse(self) + + @cached_property + def with_streaming_response(self) -> AsyncResponseResourceWithStreamingResponse: + return AsyncResponseResourceWithStreamingResponse(self) + + async def get( + self, + log_id: str, + *, + account_id: str, + id: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> object: + """ + Get Gateway Log Response + + Args: + id: gateway id + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not id: + raise ValueError(f"Expected a non-empty value for `id` but received {id!r}") + if not log_id: + raise ValueError(f"Expected a non-empty value for `log_id` but received {log_id!r}") + return await self._get( + f"/accounts/{account_id}/ai-gateway/gateways/{id}/logs/{log_id}/response", + options=make_request_options( + extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout + ), + cast_to=object, + ) + + +class ResponseResourceWithRawResponse: + def __init__(self, response: ResponseResource) -> None: + self._response = response + + self.get = to_raw_response_wrapper( + response.get, + ) + + +class AsyncResponseResourceWithRawResponse: + def __init__(self, response: AsyncResponseResource) -> None: + self._response = response + + self.get = async_to_raw_response_wrapper( + response.get, + ) + + +class ResponseResourceWithStreamingResponse: + def __init__(self, response: ResponseResource) -> None: + self._response = response + + self.get = to_streamed_response_wrapper( + response.get, + ) + + +class AsyncResponseResourceWithStreamingResponse: + def __init__(self, response: AsyncResponseResource) -> None: + self._response = response + + self.get = async_to_streamed_response_wrapper( + response.get, + ) diff --git a/src/cloudflare/resources/stream/captions/language/language.py b/src/cloudflare/resources/stream/captions/language/language.py index 34ca70cdff5..3c1bfec470e 100644 --- a/src/cloudflare/resources/stream/captions/language/language.py +++ b/src/cloudflare/resources/stream/captions/language/language.py @@ -51,6 +51,55 @@ def with_raw_response(self) -> LanguageResourceWithRawResponse: def with_streaming_response(self) -> LanguageResourceWithStreamingResponse: return LanguageResourceWithStreamingResponse(self) + def create( + self, + language: str, + *, + account_id: str, + identifier: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> Optional[Caption]: + """ + Generate captions or subtitles for provided language via AI. + + Args: + account_id: Identifier + + identifier: A Cloudflare-generated unique identifier for a media item. + + language: The language tag in BCP 47 format. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not identifier: + raise ValueError(f"Expected a non-empty value for `identifier` but received {identifier!r}") + if not language: + raise ValueError(f"Expected a non-empty value for `language` but received {language!r}") + return self._post( + f"/accounts/{account_id}/stream/{identifier}/captions/{language}/generate", + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper[Optional[Caption]]._unwrapper, + ), + cast_to=cast(Type[Optional[Caption]], ResultWrapper[Caption]), + ) + def update( self, language: str, @@ -217,6 +266,55 @@ def with_raw_response(self) -> AsyncLanguageResourceWithRawResponse: def with_streaming_response(self) -> AsyncLanguageResourceWithStreamingResponse: return AsyncLanguageResourceWithStreamingResponse(self) + async def create( + self, + language: str, + *, + account_id: str, + identifier: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> Optional[Caption]: + """ + Generate captions or subtitles for provided language via AI. + + Args: + account_id: Identifier + + identifier: A Cloudflare-generated unique identifier for a media item. + + language: The language tag in BCP 47 format. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not identifier: + raise ValueError(f"Expected a non-empty value for `identifier` but received {identifier!r}") + if not language: + raise ValueError(f"Expected a non-empty value for `language` but received {language!r}") + return await self._post( + f"/accounts/{account_id}/stream/{identifier}/captions/{language}/generate", + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper[Optional[Caption]]._unwrapper, + ), + cast_to=cast(Type[Optional[Caption]], ResultWrapper[Caption]), + ) + async def update( self, language: str, @@ -374,6 +472,9 @@ class LanguageResourceWithRawResponse: def __init__(self, language: LanguageResource) -> None: self._language = language + self.create = to_raw_response_wrapper( + language.create, + ) self.update = to_raw_response_wrapper( language.update, ) @@ -393,6 +494,9 @@ class AsyncLanguageResourceWithRawResponse: def __init__(self, language: AsyncLanguageResource) -> None: self._language = language + self.create = async_to_raw_response_wrapper( + language.create, + ) self.update = async_to_raw_response_wrapper( language.update, ) @@ -412,6 +516,9 @@ class LanguageResourceWithStreamingResponse: def __init__(self, language: LanguageResource) -> None: self._language = language + self.create = to_streamed_response_wrapper( + language.create, + ) self.update = to_streamed_response_wrapper( language.update, ) @@ -431,6 +538,9 @@ class AsyncLanguageResourceWithStreamingResponse: def __init__(self, language: AsyncLanguageResource) -> None: self._language = language + self.create = async_to_streamed_response_wrapper( + language.create, + ) self.update = async_to_streamed_response_wrapper( language.update, ) diff --git a/src/cloudflare/resources/zero_trust/gateway/__init__.py b/src/cloudflare/resources/zero_trust/gateway/__init__.py index e121dd0022f..dd71429636f 100644 --- a/src/cloudflare/resources/zero_trust/gateway/__init__.py +++ b/src/cloudflare/resources/zero_trust/gateway/__init__.py @@ -56,6 +56,14 @@ CategoriesResourceWithStreamingResponse, AsyncCategoriesResourceWithStreamingResponse, ) +from .certificates import ( + CertificatesResource, + AsyncCertificatesResource, + CertificatesResourceWithRawResponse, + AsyncCertificatesResourceWithRawResponse, + CertificatesResourceWithStreamingResponse, + AsyncCertificatesResourceWithStreamingResponse, +) from .configurations import ( ConfigurationsResource, AsyncConfigurationsResource, @@ -136,6 +144,12 @@ "AsyncRulesResourceWithRawResponse", "RulesResourceWithStreamingResponse", "AsyncRulesResourceWithStreamingResponse", + "CertificatesResource", + "AsyncCertificatesResource", + "CertificatesResourceWithRawResponse", + "AsyncCertificatesResourceWithRawResponse", + "CertificatesResourceWithStreamingResponse", + "AsyncCertificatesResourceWithStreamingResponse", "GatewayResource", "AsyncGatewayResource", "GatewayResourceWithRawResponse", diff --git a/src/cloudflare/resources/zero_trust/gateway/certificates.py b/src/cloudflare/resources/zero_trust/gateway/certificates.py new file mode 100644 index 00000000000..8e9b8b954f2 --- /dev/null +++ b/src/cloudflare/resources/zero_trust/gateway/certificates.py @@ -0,0 +1,450 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing import Type, Optional, cast + +import httpx + +from ...._types import NOT_GIVEN, Body, Query, Headers, NotGiven +from ...._utils import ( + maybe_transform, + async_maybe_transform, +) +from ...._compat import cached_property +from ...._resource import SyncAPIResource, AsyncAPIResource +from ...._response import ( + to_raw_response_wrapper, + to_streamed_response_wrapper, + async_to_raw_response_wrapper, + async_to_streamed_response_wrapper, +) +from ...._wrappers import ResultWrapper +from ....pagination import SyncSinglePage, AsyncSinglePage +from ...._base_client import ( + AsyncPaginator, + make_request_options, +) +from ....types.zero_trust.gateway import certificate_create_params +from ....types.zero_trust.gateway.certificate_get_response import CertificateGetResponse +from ....types.zero_trust.gateway.certificate_list_response import CertificateListResponse +from ....types.zero_trust.gateway.certificate_create_response import CertificateCreateResponse +from ....types.zero_trust.gateway.certificate_delete_response import CertificateDeleteResponse + +__all__ = ["CertificatesResource", "AsyncCertificatesResource"] + + +class CertificatesResource(SyncAPIResource): + @cached_property + def with_raw_response(self) -> CertificatesResourceWithRawResponse: + return CertificatesResourceWithRawResponse(self) + + @cached_property + def with_streaming_response(self) -> CertificatesResourceWithStreamingResponse: + return CertificatesResourceWithStreamingResponse(self) + + def create( + self, + *, + account_id: str, + validity_period_days: int | NotGiven = NOT_GIVEN, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> Optional[CertificateCreateResponse]: + """ + Creates a new Zero Trust certificate. + + Args: + validity_period_days: Number of days the generated certificate will be valid, minimum 1 day and + maximum 30 years. Defaults to 5 years. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + return self._post( + f"/accounts/{account_id}/gateway/certificates", + body=maybe_transform( + {"validity_period_days": validity_period_days}, certificate_create_params.CertificateCreateParams + ), + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper[Optional[CertificateCreateResponse]]._unwrapper, + ), + cast_to=cast(Type[Optional[CertificateCreateResponse]], ResultWrapper[CertificateCreateResponse]), + ) + + def list( + self, + *, + account_id: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> SyncSinglePage[CertificateListResponse]: + """ + Fetches all Zero Trust certificates for an account. + + Args: + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + return self._get_api_list( + f"/accounts/{account_id}/gateway/certificates", + page=SyncSinglePage[CertificateListResponse], + options=make_request_options( + extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout + ), + model=CertificateListResponse, + ) + + def delete( + self, + certificate_id: str, + *, + account_id: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> Optional[CertificateDeleteResponse]: + """ + Deletes a gateway-managed Zero Trust certificate. + + Args: + certificate_id: Certificate UUID tag. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not certificate_id: + raise ValueError(f"Expected a non-empty value for `certificate_id` but received {certificate_id!r}") + return self._delete( + f"/accounts/{account_id}/gateway/certificates/{certificate_id}", + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper[Optional[CertificateDeleteResponse]]._unwrapper, + ), + cast_to=cast(Type[Optional[CertificateDeleteResponse]], ResultWrapper[CertificateDeleteResponse]), + ) + + def get( + self, + certificate_id: str, + *, + account_id: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> Optional[CertificateGetResponse]: + """ + Fetches a single Zero Trust certificate. + + Args: + certificate_id: Certificate UUID tag. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not certificate_id: + raise ValueError(f"Expected a non-empty value for `certificate_id` but received {certificate_id!r}") + return self._get( + f"/accounts/{account_id}/gateway/certificates/{certificate_id}", + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper[Optional[CertificateGetResponse]]._unwrapper, + ), + cast_to=cast(Type[Optional[CertificateGetResponse]], ResultWrapper[CertificateGetResponse]), + ) + + +class AsyncCertificatesResource(AsyncAPIResource): + @cached_property + def with_raw_response(self) -> AsyncCertificatesResourceWithRawResponse: + return AsyncCertificatesResourceWithRawResponse(self) + + @cached_property + def with_streaming_response(self) -> AsyncCertificatesResourceWithStreamingResponse: + return AsyncCertificatesResourceWithStreamingResponse(self) + + async def create( + self, + *, + account_id: str, + validity_period_days: int | NotGiven = NOT_GIVEN, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> Optional[CertificateCreateResponse]: + """ + Creates a new Zero Trust certificate. + + Args: + validity_period_days: Number of days the generated certificate will be valid, minimum 1 day and + maximum 30 years. Defaults to 5 years. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + return await self._post( + f"/accounts/{account_id}/gateway/certificates", + body=await async_maybe_transform( + {"validity_period_days": validity_period_days}, certificate_create_params.CertificateCreateParams + ), + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper[Optional[CertificateCreateResponse]]._unwrapper, + ), + cast_to=cast(Type[Optional[CertificateCreateResponse]], ResultWrapper[CertificateCreateResponse]), + ) + + def list( + self, + *, + account_id: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> AsyncPaginator[CertificateListResponse, AsyncSinglePage[CertificateListResponse]]: + """ + Fetches all Zero Trust certificates for an account. + + Args: + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + return self._get_api_list( + f"/accounts/{account_id}/gateway/certificates", + page=AsyncSinglePage[CertificateListResponse], + options=make_request_options( + extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout + ), + model=CertificateListResponse, + ) + + async def delete( + self, + certificate_id: str, + *, + account_id: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> Optional[CertificateDeleteResponse]: + """ + Deletes a gateway-managed Zero Trust certificate. + + Args: + certificate_id: Certificate UUID tag. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not certificate_id: + raise ValueError(f"Expected a non-empty value for `certificate_id` but received {certificate_id!r}") + return await self._delete( + f"/accounts/{account_id}/gateway/certificates/{certificate_id}", + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper[Optional[CertificateDeleteResponse]]._unwrapper, + ), + cast_to=cast(Type[Optional[CertificateDeleteResponse]], ResultWrapper[CertificateDeleteResponse]), + ) + + async def get( + self, + certificate_id: str, + *, + account_id: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> Optional[CertificateGetResponse]: + """ + Fetches a single Zero Trust certificate. + + Args: + certificate_id: Certificate UUID tag. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not certificate_id: + raise ValueError(f"Expected a non-empty value for `certificate_id` but received {certificate_id!r}") + return await self._get( + f"/accounts/{account_id}/gateway/certificates/{certificate_id}", + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper[Optional[CertificateGetResponse]]._unwrapper, + ), + cast_to=cast(Type[Optional[CertificateGetResponse]], ResultWrapper[CertificateGetResponse]), + ) + + +class CertificatesResourceWithRawResponse: + def __init__(self, certificates: CertificatesResource) -> None: + self._certificates = certificates + + self.create = to_raw_response_wrapper( + certificates.create, + ) + self.list = to_raw_response_wrapper( + certificates.list, + ) + self.delete = to_raw_response_wrapper( + certificates.delete, + ) + self.get = to_raw_response_wrapper( + certificates.get, + ) + + +class AsyncCertificatesResourceWithRawResponse: + def __init__(self, certificates: AsyncCertificatesResource) -> None: + self._certificates = certificates + + self.create = async_to_raw_response_wrapper( + certificates.create, + ) + self.list = async_to_raw_response_wrapper( + certificates.list, + ) + self.delete = async_to_raw_response_wrapper( + certificates.delete, + ) + self.get = async_to_raw_response_wrapper( + certificates.get, + ) + + +class CertificatesResourceWithStreamingResponse: + def __init__(self, certificates: CertificatesResource) -> None: + self._certificates = certificates + + self.create = to_streamed_response_wrapper( + certificates.create, + ) + self.list = to_streamed_response_wrapper( + certificates.list, + ) + self.delete = to_streamed_response_wrapper( + certificates.delete, + ) + self.get = to_streamed_response_wrapper( + certificates.get, + ) + + +class AsyncCertificatesResourceWithStreamingResponse: + def __init__(self, certificates: AsyncCertificatesResource) -> None: + self._certificates = certificates + + self.create = async_to_streamed_response_wrapper( + certificates.create, + ) + self.list = async_to_streamed_response_wrapper( + certificates.list, + ) + self.delete = async_to_streamed_response_wrapper( + certificates.delete, + ) + self.get = async_to_streamed_response_wrapper( + certificates.get, + ) diff --git a/src/cloudflare/resources/zero_trust/gateway/gateway.py b/src/cloudflare/resources/zero_trust/gateway/gateway.py index a2e994272d9..9d43923083a 100644 --- a/src/cloudflare/resources/zero_trust/gateway/gateway.py +++ b/src/cloudflare/resources/zero_trust/gateway/gateway.py @@ -65,6 +65,14 @@ async_to_streamed_response_wrapper, ) from ...._wrappers import ResultWrapper +from .certificates import ( + CertificatesResource, + AsyncCertificatesResource, + CertificatesResourceWithRawResponse, + AsyncCertificatesResourceWithRawResponse, + CertificatesResourceWithStreamingResponse, + AsyncCertificatesResourceWithStreamingResponse, +) from .configurations import ( ConfigurationsResource, AsyncConfigurationsResource, @@ -135,6 +143,10 @@ def proxy_endpoints(self) -> ProxyEndpointsResource: def rules(self) -> RulesResource: return RulesResource(self._client) + @cached_property + def certificates(self) -> CertificatesResource: + return CertificatesResource(self._client) + @cached_property def with_raw_response(self) -> GatewayResourceWithRawResponse: return GatewayResourceWithRawResponse(self) @@ -255,6 +267,10 @@ def proxy_endpoints(self) -> AsyncProxyEndpointsResource: def rules(self) -> AsyncRulesResource: return AsyncRulesResource(self._client) + @cached_property + def certificates(self) -> AsyncCertificatesResource: + return AsyncCertificatesResource(self._client) + @cached_property def with_raw_response(self) -> AsyncGatewayResourceWithRawResponse: return AsyncGatewayResourceWithRawResponse(self) @@ -385,6 +401,10 @@ def proxy_endpoints(self) -> ProxyEndpointsResourceWithRawResponse: def rules(self) -> RulesResourceWithRawResponse: return RulesResourceWithRawResponse(self._gateway.rules) + @cached_property + def certificates(self) -> CertificatesResourceWithRawResponse: + return CertificatesResourceWithRawResponse(self._gateway.certificates) + class AsyncGatewayResourceWithRawResponse: def __init__(self, gateway: AsyncGatewayResource) -> None: @@ -433,6 +453,10 @@ def proxy_endpoints(self) -> AsyncProxyEndpointsResourceWithRawResponse: def rules(self) -> AsyncRulesResourceWithRawResponse: return AsyncRulesResourceWithRawResponse(self._gateway.rules) + @cached_property + def certificates(self) -> AsyncCertificatesResourceWithRawResponse: + return AsyncCertificatesResourceWithRawResponse(self._gateway.certificates) + class GatewayResourceWithStreamingResponse: def __init__(self, gateway: GatewayResource) -> None: @@ -481,6 +505,10 @@ def proxy_endpoints(self) -> ProxyEndpointsResourceWithStreamingResponse: def rules(self) -> RulesResourceWithStreamingResponse: return RulesResourceWithStreamingResponse(self._gateway.rules) + @cached_property + def certificates(self) -> CertificatesResourceWithStreamingResponse: + return CertificatesResourceWithStreamingResponse(self._gateway.certificates) + class AsyncGatewayResourceWithStreamingResponse: def __init__(self, gateway: AsyncGatewayResource) -> None: @@ -528,3 +556,7 @@ def proxy_endpoints(self) -> AsyncProxyEndpointsResourceWithStreamingResponse: @cached_property def rules(self) -> AsyncRulesResourceWithStreamingResponse: return AsyncRulesResourceWithStreamingResponse(self._gateway.rules) + + @cached_property + def certificates(self) -> AsyncCertificatesResourceWithStreamingResponse: + return AsyncCertificatesResourceWithStreamingResponse(self._gateway.certificates) diff --git a/src/cloudflare/types/ai_gateway/__init__.py b/src/cloudflare/types/ai_gateway/__init__.py index e34365f10eb..afc8501bed2 100644 --- a/src/cloudflare/types/ai_gateway/__init__.py +++ b/src/cloudflare/types/ai_gateway/__init__.py @@ -2,8 +2,9 @@ from __future__ import annotations -from .log_get_params import LogGetParams as LogGetParams +from .log_list_params import LogListParams as LogListParams from .log_get_response import LogGetResponse as LogGetResponse +from .log_list_response import LogListResponse as LogListResponse from .ai_gateway_list_params import AIGatewayListParams as AIGatewayListParams from .ai_gateway_get_response import AIGatewayGetResponse as AIGatewayGetResponse from .ai_gateway_create_params import AIGatewayCreateParams as AIGatewayCreateParams diff --git a/src/cloudflare/types/ai_gateway/log_get_response.py b/src/cloudflare/types/ai_gateway/log_get_response.py index c78976e56d4..ff80ce3414d 100644 --- a/src/cloudflare/types/ai_gateway/log_get_response.py +++ b/src/cloudflare/types/ai_gateway/log_get_response.py @@ -1,14 +1,14 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import List, Optional +from typing import Optional from datetime import datetime from ..._models import BaseModel -__all__ = ["LogGetResponse", "LogGetResponseItem"] +__all__ = ["LogGetResponse"] -class LogGetResponseItem(BaseModel): +class LogGetResponse(BaseModel): id: str cached: bool @@ -44,6 +44,3 @@ class LogGetResponseItem(BaseModel): status_code: Optional[int] = None step: Optional[int] = None - - -LogGetResponse = List[LogGetResponseItem] diff --git a/src/cloudflare/types/ai_gateway/log_get_params.py b/src/cloudflare/types/ai_gateway/log_list_params.py similarity index 89% rename from src/cloudflare/types/ai_gateway/log_get_params.py rename to src/cloudflare/types/ai_gateway/log_list_params.py index c6503dfd736..3f3bbe5efa6 100644 --- a/src/cloudflare/types/ai_gateway/log_get_params.py +++ b/src/cloudflare/types/ai_gateway/log_list_params.py @@ -8,10 +8,10 @@ from ..._utils import PropertyInfo -__all__ = ["LogGetParams"] +__all__ = ["LogListParams"] -class LogGetParams(TypedDict, total=False): +class LogListParams(TypedDict, total=False): account_id: Required[str] cached: bool diff --git a/src/cloudflare/types/ai_gateway/log_list_response.py b/src/cloudflare/types/ai_gateway/log_list_response.py new file mode 100644 index 00000000000..54366ffe597 --- /dev/null +++ b/src/cloudflare/types/ai_gateway/log_list_response.py @@ -0,0 +1,46 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import Optional +from datetime import datetime + +from ..._models import BaseModel + +__all__ = ["LogListResponse"] + + +class LogListResponse(BaseModel): + id: str + + cached: bool + + created_at: datetime + + duration: int + + model: str + + path: str + + provider: str + + request: str + + response: str + + success: bool + + tokens_in: int + + tokens_out: int + + metadata: Optional[str] = None + + request_content_type: Optional[str] = None + + request_type: Optional[str] = None + + response_content_type: Optional[str] = None + + status_code: Optional[int] = None + + step: Optional[int] = None diff --git a/src/cloudflare/types/ai_gateway/logs/__init__.py b/src/cloudflare/types/ai_gateway/logs/__init__.py new file mode 100644 index 00000000000..f8ee8b14b1c --- /dev/null +++ b/src/cloudflare/types/ai_gateway/logs/__init__.py @@ -0,0 +1,3 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations diff --git a/src/cloudflare/types/zero_trust/gateway/__init__.py b/src/cloudflare/types/zero_trust/gateway/__init__.py index c462d3ec6af..e0f7ea5cf69 100644 --- a/src/cloudflare/types/zero_trust/gateway/__init__.py +++ b/src/cloudflare/types/zero_trust/gateway/__init__.py @@ -43,17 +43,22 @@ from .location_network_param import LocationNetworkParam as LocationNetworkParam from .location_update_params import LocationUpdateParams as LocationUpdateParams from .extended_email_matching import ExtendedEmailMatching as ExtendedEmailMatching +from .certificate_get_response import CertificateGetResponse as CertificateGetResponse from .dns_resolver_settings_v4 import DNSResolverSettingsV4 as DNSResolverSettingsV4 from .dns_resolver_settings_v6 import DNSResolverSettingsV6 as DNSResolverSettingsV6 from .location_delete_response import LocationDeleteResponse as LocationDeleteResponse from .protocol_detection_param import ProtocolDetectionParam as ProtocolDetectionParam from .anti_virus_settings_param import AntiVirusSettingsParam as AntiVirusSettingsParam from .block_page_settings_param import BlockPageSettingsParam as BlockPageSettingsParam +from .certificate_create_params import CertificateCreateParams as CertificateCreateParams +from .certificate_list_response import CertificateListResponse as CertificateListResponse from .configuration_edit_params import ConfigurationEditParams as ConfigurationEditParams from .browser_isolation_settings import BrowserIsolationSettings as BrowserIsolationSettings from .configuration_get_response import ConfigurationGetResponse as ConfigurationGetResponse from .proxy_endpoint_edit_params import ProxyEndpointEditParams as ProxyEndpointEditParams from .activity_log_settings_param import ActivityLogSettingsParam as ActivityLogSettingsParam +from .certificate_create_response import CertificateCreateResponse as CertificateCreateResponse +from .certificate_delete_response import CertificateDeleteResponse as CertificateDeleteResponse from .configuration_edit_response import ConfigurationEditResponse as ConfigurationEditResponse from .configuration_update_params import ConfigurationUpdateParams as ConfigurationUpdateParams from .custom_certificate_settings import CustomCertificateSettings as CustomCertificateSettings diff --git a/src/cloudflare/types/zero_trust/gateway/certificate_create_params.py b/src/cloudflare/types/zero_trust/gateway/certificate_create_params.py new file mode 100644 index 00000000000..1de699e498c --- /dev/null +++ b/src/cloudflare/types/zero_trust/gateway/certificate_create_params.py @@ -0,0 +1,17 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing_extensions import Required, TypedDict + +__all__ = ["CertificateCreateParams"] + + +class CertificateCreateParams(TypedDict, total=False): + account_id: Required[str] + + validity_period_days: int + """ + Number of days the generated certificate will be valid, minimum 1 day and + maximum 30 years. Defaults to 5 years. + """ diff --git a/src/cloudflare/types/zero_trust/gateway/certificate_create_response.py b/src/cloudflare/types/zero_trust/gateway/certificate_create_response.py new file mode 100644 index 00000000000..f80dc62369e --- /dev/null +++ b/src/cloudflare/types/zero_trust/gateway/certificate_create_response.py @@ -0,0 +1,31 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import Optional +from datetime import datetime +from typing_extensions import Literal + +from ...._models import BaseModel + +__all__ = ["CertificateCreateResponse"] + + +class CertificateCreateResponse(BaseModel): + id: Optional[str] = None + """Certificate UUID tag.""" + + binding_status: Optional[Literal["pending_deployment", "active", "pending_deletion", "inactive"]] = None + """The deployment status of the certificate on Cloudflare's edge.""" + + created_at: Optional[datetime] = None + + enabled: Optional[bool] = None + """Use this certificate for Gateway TLS interception""" + + expires_on: Optional[datetime] = None + + type: Optional[Literal["custom", "gateway_managed"]] = None + """The type of certificate, either BYO-PKI (custom) or Gateway-managed.""" + + updated_at: Optional[datetime] = None + + uploaded_on: Optional[datetime] = None diff --git a/src/cloudflare/types/zero_trust/gateway/certificate_delete_response.py b/src/cloudflare/types/zero_trust/gateway/certificate_delete_response.py new file mode 100644 index 00000000000..b8e44b1a35b --- /dev/null +++ b/src/cloudflare/types/zero_trust/gateway/certificate_delete_response.py @@ -0,0 +1,31 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import Optional +from datetime import datetime +from typing_extensions import Literal + +from ...._models import BaseModel + +__all__ = ["CertificateDeleteResponse"] + + +class CertificateDeleteResponse(BaseModel): + id: Optional[str] = None + """Certificate UUID tag.""" + + binding_status: Optional[Literal["pending_deployment", "active", "pending_deletion", "inactive"]] = None + """The deployment status of the certificate on Cloudflare's edge.""" + + created_at: Optional[datetime] = None + + enabled: Optional[bool] = None + """Use this certificate for Gateway TLS interception""" + + expires_on: Optional[datetime] = None + + type: Optional[Literal["custom", "gateway_managed"]] = None + """The type of certificate, either BYO-PKI (custom) or Gateway-managed.""" + + updated_at: Optional[datetime] = None + + uploaded_on: Optional[datetime] = None diff --git a/src/cloudflare/types/zero_trust/gateway/certificate_get_response.py b/src/cloudflare/types/zero_trust/gateway/certificate_get_response.py new file mode 100644 index 00000000000..6a702b1122f --- /dev/null +++ b/src/cloudflare/types/zero_trust/gateway/certificate_get_response.py @@ -0,0 +1,31 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import Optional +from datetime import datetime +from typing_extensions import Literal + +from ...._models import BaseModel + +__all__ = ["CertificateGetResponse"] + + +class CertificateGetResponse(BaseModel): + id: Optional[str] = None + """Certificate UUID tag.""" + + binding_status: Optional[Literal["pending_deployment", "active", "pending_deletion", "inactive"]] = None + """The deployment status of the certificate on Cloudflare's edge.""" + + created_at: Optional[datetime] = None + + enabled: Optional[bool] = None + """Use this certificate for Gateway TLS interception""" + + expires_on: Optional[datetime] = None + + type: Optional[Literal["custom", "gateway_managed"]] = None + """The type of certificate, either BYO-PKI (custom) or Gateway-managed.""" + + updated_at: Optional[datetime] = None + + uploaded_on: Optional[datetime] = None diff --git a/src/cloudflare/types/zero_trust/gateway/certificate_list_response.py b/src/cloudflare/types/zero_trust/gateway/certificate_list_response.py new file mode 100644 index 00000000000..322c092fcaf --- /dev/null +++ b/src/cloudflare/types/zero_trust/gateway/certificate_list_response.py @@ -0,0 +1,31 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import Optional +from datetime import datetime +from typing_extensions import Literal + +from ...._models import BaseModel + +__all__ = ["CertificateListResponse"] + + +class CertificateListResponse(BaseModel): + id: Optional[str] = None + """Certificate UUID tag.""" + + binding_status: Optional[Literal["pending_deployment", "active", "pending_deletion", "inactive"]] = None + """The deployment status of the certificate on Cloudflare's edge.""" + + created_at: Optional[datetime] = None + + enabled: Optional[bool] = None + """Use this certificate for Gateway TLS interception""" + + expires_on: Optional[datetime] = None + + type: Optional[Literal["custom", "gateway_managed"]] = None + """The type of certificate, either BYO-PKI (custom) or Gateway-managed.""" + + updated_at: Optional[datetime] = None + + uploaded_on: Optional[datetime] = None diff --git a/tests/api_resources/ai_gateway/logs/__init__.py b/tests/api_resources/ai_gateway/logs/__init__.py new file mode 100644 index 00000000000..fd8019a9a1a --- /dev/null +++ b/tests/api_resources/ai_gateway/logs/__init__.py @@ -0,0 +1 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. diff --git a/tests/api_resources/ai_gateway/logs/test_request.py b/tests/api_resources/ai_gateway/logs/test_request.py new file mode 100644 index 00000000000..d7a2c3da764 --- /dev/null +++ b/tests/api_resources/ai_gateway/logs/test_request.py @@ -0,0 +1,141 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +import os +from typing import Any, cast + +import pytest + +from cloudflare import Cloudflare, AsyncCloudflare +from tests.utils import assert_matches_type + +base_url = os.environ.get("TEST_API_BASE_URL", "http://127.0.0.1:4010") + + +class TestRequest: + parametrize = pytest.mark.parametrize("client", [False, True], indirect=True, ids=["loose", "strict"]) + + @parametrize + def test_method_get(self, client: Cloudflare) -> None: + request = client.ai_gateway.logs.request.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) + assert_matches_type(object, request, path=["response"]) + + @parametrize + def test_raw_response_get(self, client: Cloudflare) -> None: + response = client.ai_gateway.logs.request.with_raw_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + request = response.parse() + assert_matches_type(object, request, path=["response"]) + + @parametrize + def test_streaming_response_get(self, client: Cloudflare) -> None: + with client.ai_gateway.logs.request.with_streaming_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + request = response.parse() + assert_matches_type(object, request, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + def test_path_params_get(self, client: Cloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + client.ai_gateway.logs.request.with_raw_response.get( + "string", + account_id="", + id="my-gateway", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `id` but received ''"): + client.ai_gateway.logs.request.with_raw_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `log_id` but received ''"): + client.ai_gateway.logs.request.with_raw_response.get( + "", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) + + +class TestAsyncRequest: + parametrize = pytest.mark.parametrize("async_client", [False, True], indirect=True, ids=["loose", "strict"]) + + @parametrize + async def test_method_get(self, async_client: AsyncCloudflare) -> None: + request = await async_client.ai_gateway.logs.request.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) + assert_matches_type(object, request, path=["response"]) + + @parametrize + async def test_raw_response_get(self, async_client: AsyncCloudflare) -> None: + response = await async_client.ai_gateway.logs.request.with_raw_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + request = await response.parse() + assert_matches_type(object, request, path=["response"]) + + @parametrize + async def test_streaming_response_get(self, async_client: AsyncCloudflare) -> None: + async with async_client.ai_gateway.logs.request.with_streaming_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + request = await response.parse() + assert_matches_type(object, request, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + async def test_path_params_get(self, async_client: AsyncCloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + await async_client.ai_gateway.logs.request.with_raw_response.get( + "string", + account_id="", + id="my-gateway", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `id` but received ''"): + await async_client.ai_gateway.logs.request.with_raw_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `log_id` but received ''"): + await async_client.ai_gateway.logs.request.with_raw_response.get( + "", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) diff --git a/tests/api_resources/ai_gateway/logs/test_response.py b/tests/api_resources/ai_gateway/logs/test_response.py new file mode 100644 index 00000000000..f66bf7c2449 --- /dev/null +++ b/tests/api_resources/ai_gateway/logs/test_response.py @@ -0,0 +1,141 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +import os +from typing import Any, cast + +import pytest + +from cloudflare import Cloudflare, AsyncCloudflare +from tests.utils import assert_matches_type + +base_url = os.environ.get("TEST_API_BASE_URL", "http://127.0.0.1:4010") + + +class TestResponse: + parametrize = pytest.mark.parametrize("client", [False, True], indirect=True, ids=["loose", "strict"]) + + @parametrize + def test_method_get(self, client: Cloudflare) -> None: + response = client.ai_gateway.logs.response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) + assert_matches_type(object, response, path=["response"]) + + @parametrize + def test_raw_response_get(self, client: Cloudflare) -> None: + http_response = client.ai_gateway.logs.response.with_raw_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) + + assert http_response.is_closed is True + assert http_response.http_request.headers.get("X-Stainless-Lang") == "python" + response = http_response.parse() + assert_matches_type(object, response, path=["response"]) + + @parametrize + def test_streaming_response_get(self, client: Cloudflare) -> None: + with client.ai_gateway.logs.response.with_streaming_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) as http_response: + assert not http_response.is_closed + assert http_response.http_request.headers.get("X-Stainless-Lang") == "python" + + response = http_response.parse() + assert_matches_type(object, response, path=["response"]) + + assert cast(Any, http_response.is_closed) is True + + @parametrize + def test_path_params_get(self, client: Cloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + client.ai_gateway.logs.response.with_raw_response.get( + "string", + account_id="", + id="my-gateway", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `id` but received ''"): + client.ai_gateway.logs.response.with_raw_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `log_id` but received ''"): + client.ai_gateway.logs.response.with_raw_response.get( + "", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) + + +class TestAsyncResponse: + parametrize = pytest.mark.parametrize("async_client", [False, True], indirect=True, ids=["loose", "strict"]) + + @parametrize + async def test_method_get(self, async_client: AsyncCloudflare) -> None: + response = await async_client.ai_gateway.logs.response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) + assert_matches_type(object, response, path=["response"]) + + @parametrize + async def test_raw_response_get(self, async_client: AsyncCloudflare) -> None: + http_response = await async_client.ai_gateway.logs.response.with_raw_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) + + assert http_response.is_closed is True + assert http_response.http_request.headers.get("X-Stainless-Lang") == "python" + response = await http_response.parse() + assert_matches_type(object, response, path=["response"]) + + @parametrize + async def test_streaming_response_get(self, async_client: AsyncCloudflare) -> None: + async with async_client.ai_gateway.logs.response.with_streaming_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) as http_response: + assert not http_response.is_closed + assert http_response.http_request.headers.get("X-Stainless-Lang") == "python" + + response = await http_response.parse() + assert_matches_type(object, response, path=["response"]) + + assert cast(Any, http_response.is_closed) is True + + @parametrize + async def test_path_params_get(self, async_client: AsyncCloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + await async_client.ai_gateway.logs.response.with_raw_response.get( + "string", + account_id="", + id="my-gateway", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `id` but received ''"): + await async_client.ai_gateway.logs.response.with_raw_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `log_id` but received ''"): + await async_client.ai_gateway.logs.response.with_raw_response.get( + "", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) diff --git a/tests/api_resources/ai_gateway/test_logs.py b/tests/api_resources/ai_gateway/test_logs.py index 78439db3a89..485dc79d148 100644 --- a/tests/api_resources/ai_gateway/test_logs.py +++ b/tests/api_resources/ai_gateway/test_logs.py @@ -10,7 +10,8 @@ from cloudflare import Cloudflare, AsyncCloudflare from tests.utils import assert_matches_type from cloudflare._utils import parse_datetime -from cloudflare.types.ai_gateway import LogGetResponse +from cloudflare.pagination import SyncV4PagePaginationArray, AsyncV4PagePaginationArray +from cloudflare.types.ai_gateway import LogGetResponse, LogListResponse base_url = os.environ.get("TEST_API_BASE_URL", "http://127.0.0.1:4010") @@ -19,16 +20,16 @@ class TestLogs: parametrize = pytest.mark.parametrize("client", [False, True], indirect=True, ids=["loose", "strict"]) @parametrize - def test_method_get(self, client: Cloudflare) -> None: - log = client.ai_gateway.logs.get( + def test_method_list(self, client: Cloudflare) -> None: + log = client.ai_gateway.logs.list( "my-gateway", account_id="0d37909e38d3e99c29fa2cd343ac421a", ) - assert_matches_type(LogGetResponse, log, path=["response"]) + assert_matches_type(SyncV4PagePaginationArray[LogListResponse], log, path=["response"]) @parametrize - def test_method_get_with_all_params(self, client: Cloudflare) -> None: - log = client.ai_gateway.logs.get( + def test_method_list_with_all_params(self, client: Cloudflare) -> None: + log = client.ai_gateway.logs.list( "my-gateway", account_id="0d37909e38d3e99c29fa2cd343ac421a", cached=True, @@ -41,13 +42,63 @@ def test_method_get_with_all_params(self, client: Cloudflare) -> None: start_date=parse_datetime("2019-12-27T18:11:19.117Z"), success=True, ) + assert_matches_type(SyncV4PagePaginationArray[LogListResponse], log, path=["response"]) + + @parametrize + def test_raw_response_list(self, client: Cloudflare) -> None: + response = client.ai_gateway.logs.with_raw_response.list( + "my-gateway", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + log = response.parse() + assert_matches_type(SyncV4PagePaginationArray[LogListResponse], log, path=["response"]) + + @parametrize + def test_streaming_response_list(self, client: Cloudflare) -> None: + with client.ai_gateway.logs.with_streaming_response.list( + "my-gateway", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + log = response.parse() + assert_matches_type(SyncV4PagePaginationArray[LogListResponse], log, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + def test_path_params_list(self, client: Cloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + client.ai_gateway.logs.with_raw_response.list( + "my-gateway", + account_id="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `id` but received ''"): + client.ai_gateway.logs.with_raw_response.list( + "", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + ) + + @parametrize + def test_method_get(self, client: Cloudflare) -> None: + log = client.ai_gateway.logs.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) assert_matches_type(LogGetResponse, log, path=["response"]) @parametrize def test_raw_response_get(self, client: Cloudflare) -> None: response = client.ai_gateway.logs.with_raw_response.get( - "my-gateway", + "string", account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", ) assert response.is_closed is True @@ -58,8 +109,9 @@ def test_raw_response_get(self, client: Cloudflare) -> None: @parametrize def test_streaming_response_get(self, client: Cloudflare) -> None: with client.ai_gateway.logs.with_streaming_response.get( - "my-gateway", + "string", account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", ) as response: assert not response.is_closed assert response.http_request.headers.get("X-Stainless-Lang") == "python" @@ -73,14 +125,23 @@ def test_streaming_response_get(self, client: Cloudflare) -> None: def test_path_params_get(self, client: Cloudflare) -> None: with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): client.ai_gateway.logs.with_raw_response.get( - "my-gateway", + "string", account_id="", + id="my-gateway", ) with pytest.raises(ValueError, match=r"Expected a non-empty value for `id` but received ''"): + client.ai_gateway.logs.with_raw_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `log_id` but received ''"): client.ai_gateway.logs.with_raw_response.get( "", account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", ) @@ -88,16 +149,16 @@ class TestAsyncLogs: parametrize = pytest.mark.parametrize("async_client", [False, True], indirect=True, ids=["loose", "strict"]) @parametrize - async def test_method_get(self, async_client: AsyncCloudflare) -> None: - log = await async_client.ai_gateway.logs.get( + async def test_method_list(self, async_client: AsyncCloudflare) -> None: + log = await async_client.ai_gateway.logs.list( "my-gateway", account_id="0d37909e38d3e99c29fa2cd343ac421a", ) - assert_matches_type(LogGetResponse, log, path=["response"]) + assert_matches_type(AsyncV4PagePaginationArray[LogListResponse], log, path=["response"]) @parametrize - async def test_method_get_with_all_params(self, async_client: AsyncCloudflare) -> None: - log = await async_client.ai_gateway.logs.get( + async def test_method_list_with_all_params(self, async_client: AsyncCloudflare) -> None: + log = await async_client.ai_gateway.logs.list( "my-gateway", account_id="0d37909e38d3e99c29fa2cd343ac421a", cached=True, @@ -110,13 +171,63 @@ async def test_method_get_with_all_params(self, async_client: AsyncCloudflare) - start_date=parse_datetime("2019-12-27T18:11:19.117Z"), success=True, ) + assert_matches_type(AsyncV4PagePaginationArray[LogListResponse], log, path=["response"]) + + @parametrize + async def test_raw_response_list(self, async_client: AsyncCloudflare) -> None: + response = await async_client.ai_gateway.logs.with_raw_response.list( + "my-gateway", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + log = await response.parse() + assert_matches_type(AsyncV4PagePaginationArray[LogListResponse], log, path=["response"]) + + @parametrize + async def test_streaming_response_list(self, async_client: AsyncCloudflare) -> None: + async with async_client.ai_gateway.logs.with_streaming_response.list( + "my-gateway", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + log = await response.parse() + assert_matches_type(AsyncV4PagePaginationArray[LogListResponse], log, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + async def test_path_params_list(self, async_client: AsyncCloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + await async_client.ai_gateway.logs.with_raw_response.list( + "my-gateway", + account_id="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `id` but received ''"): + await async_client.ai_gateway.logs.with_raw_response.list( + "", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + ) + + @parametrize + async def test_method_get(self, async_client: AsyncCloudflare) -> None: + log = await async_client.ai_gateway.logs.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", + ) assert_matches_type(LogGetResponse, log, path=["response"]) @parametrize async def test_raw_response_get(self, async_client: AsyncCloudflare) -> None: response = await async_client.ai_gateway.logs.with_raw_response.get( - "my-gateway", + "string", account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", ) assert response.is_closed is True @@ -127,8 +238,9 @@ async def test_raw_response_get(self, async_client: AsyncCloudflare) -> None: @parametrize async def test_streaming_response_get(self, async_client: AsyncCloudflare) -> None: async with async_client.ai_gateway.logs.with_streaming_response.get( - "my-gateway", + "string", account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", ) as response: assert not response.is_closed assert response.http_request.headers.get("X-Stainless-Lang") == "python" @@ -142,12 +254,21 @@ async def test_streaming_response_get(self, async_client: AsyncCloudflare) -> No async def test_path_params_get(self, async_client: AsyncCloudflare) -> None: with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): await async_client.ai_gateway.logs.with_raw_response.get( - "my-gateway", + "string", account_id="", + id="my-gateway", ) with pytest.raises(ValueError, match=r"Expected a non-empty value for `id` but received ''"): + await async_client.ai_gateway.logs.with_raw_response.get( + "string", + account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `log_id` but received ''"): await async_client.ai_gateway.logs.with_raw_response.get( "", account_id="0d37909e38d3e99c29fa2cd343ac421a", + id="my-gateway", ) diff --git a/tests/api_resources/stream/captions/test_language.py b/tests/api_resources/stream/captions/test_language.py index 15caab5410b..cdcc495bcd5 100644 --- a/tests/api_resources/stream/captions/test_language.py +++ b/tests/api_resources/stream/captions/test_language.py @@ -17,6 +17,66 @@ class TestLanguage: parametrize = pytest.mark.parametrize("client", [False, True], indirect=True, ids=["loose", "strict"]) + @parametrize + def test_method_create(self, client: Cloudflare) -> None: + language = client.stream.captions.language.create( + "tr", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + identifier="ea95132c15732412d22c1476fa83f27a", + ) + assert_matches_type(Optional[Caption], language, path=["response"]) + + @parametrize + def test_raw_response_create(self, client: Cloudflare) -> None: + response = client.stream.captions.language.with_raw_response.create( + "tr", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + identifier="ea95132c15732412d22c1476fa83f27a", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + language = response.parse() + assert_matches_type(Optional[Caption], language, path=["response"]) + + @parametrize + def test_streaming_response_create(self, client: Cloudflare) -> None: + with client.stream.captions.language.with_streaming_response.create( + "tr", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + identifier="ea95132c15732412d22c1476fa83f27a", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + language = response.parse() + assert_matches_type(Optional[Caption], language, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + def test_path_params_create(self, client: Cloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + client.stream.captions.language.with_raw_response.create( + "tr", + account_id="", + identifier="ea95132c15732412d22c1476fa83f27a", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `identifier` but received ''"): + client.stream.captions.language.with_raw_response.create( + "tr", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + identifier="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `language` but received ''"): + client.stream.captions.language.with_raw_response.create( + "", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + identifier="ea95132c15732412d22c1476fa83f27a", + ) + @pytest.mark.skip(reason="TODO: investigate broken test") @parametrize def test_method_update(self, client: Cloudflare) -> None: @@ -211,6 +271,66 @@ def test_path_params_get(self, client: Cloudflare) -> None: class TestAsyncLanguage: parametrize = pytest.mark.parametrize("async_client", [False, True], indirect=True, ids=["loose", "strict"]) + @parametrize + async def test_method_create(self, async_client: AsyncCloudflare) -> None: + language = await async_client.stream.captions.language.create( + "tr", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + identifier="ea95132c15732412d22c1476fa83f27a", + ) + assert_matches_type(Optional[Caption], language, path=["response"]) + + @parametrize + async def test_raw_response_create(self, async_client: AsyncCloudflare) -> None: + response = await async_client.stream.captions.language.with_raw_response.create( + "tr", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + identifier="ea95132c15732412d22c1476fa83f27a", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + language = await response.parse() + assert_matches_type(Optional[Caption], language, path=["response"]) + + @parametrize + async def test_streaming_response_create(self, async_client: AsyncCloudflare) -> None: + async with async_client.stream.captions.language.with_streaming_response.create( + "tr", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + identifier="ea95132c15732412d22c1476fa83f27a", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + language = await response.parse() + assert_matches_type(Optional[Caption], language, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + async def test_path_params_create(self, async_client: AsyncCloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + await async_client.stream.captions.language.with_raw_response.create( + "tr", + account_id="", + identifier="ea95132c15732412d22c1476fa83f27a", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `identifier` but received ''"): + await async_client.stream.captions.language.with_raw_response.create( + "tr", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + identifier="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `language` but received ''"): + await async_client.stream.captions.language.with_raw_response.create( + "", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + identifier="ea95132c15732412d22c1476fa83f27a", + ) + @pytest.mark.skip(reason="TODO: investigate broken test") @parametrize async def test_method_update(self, async_client: AsyncCloudflare) -> None: diff --git a/tests/api_resources/zero_trust/gateway/test_certificates.py b/tests/api_resources/zero_trust/gateway/test_certificates.py new file mode 100644 index 00000000000..c84aaa00883 --- /dev/null +++ b/tests/api_resources/zero_trust/gateway/test_certificates.py @@ -0,0 +1,388 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +import os +from typing import Any, Optional, cast + +import pytest + +from cloudflare import Cloudflare, AsyncCloudflare +from tests.utils import assert_matches_type +from cloudflare.pagination import SyncSinglePage, AsyncSinglePage +from cloudflare.types.zero_trust.gateway import ( + CertificateGetResponse, + CertificateListResponse, + CertificateCreateResponse, + CertificateDeleteResponse, +) + +base_url = os.environ.get("TEST_API_BASE_URL", "http://127.0.0.1:4010") + + +class TestCertificates: + parametrize = pytest.mark.parametrize("client", [False, True], indirect=True, ids=["loose", "strict"]) + + @parametrize + def test_method_create(self, client: Cloudflare) -> None: + certificate = client.zero_trust.gateway.certificates.create( + account_id="699d98642c564d2e855e9661899b7252", + ) + assert_matches_type(Optional[CertificateCreateResponse], certificate, path=["response"]) + + @parametrize + def test_method_create_with_all_params(self, client: Cloudflare) -> None: + certificate = client.zero_trust.gateway.certificates.create( + account_id="699d98642c564d2e855e9661899b7252", + validity_period_days=1826, + ) + assert_matches_type(Optional[CertificateCreateResponse], certificate, path=["response"]) + + @parametrize + def test_raw_response_create(self, client: Cloudflare) -> None: + response = client.zero_trust.gateway.certificates.with_raw_response.create( + account_id="699d98642c564d2e855e9661899b7252", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + certificate = response.parse() + assert_matches_type(Optional[CertificateCreateResponse], certificate, path=["response"]) + + @parametrize + def test_streaming_response_create(self, client: Cloudflare) -> None: + with client.zero_trust.gateway.certificates.with_streaming_response.create( + account_id="699d98642c564d2e855e9661899b7252", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + certificate = response.parse() + assert_matches_type(Optional[CertificateCreateResponse], certificate, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + def test_path_params_create(self, client: Cloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + client.zero_trust.gateway.certificates.with_raw_response.create( + account_id="", + ) + + @parametrize + def test_method_list(self, client: Cloudflare) -> None: + certificate = client.zero_trust.gateway.certificates.list( + account_id="699d98642c564d2e855e9661899b7252", + ) + assert_matches_type(SyncSinglePage[CertificateListResponse], certificate, path=["response"]) + + @parametrize + def test_raw_response_list(self, client: Cloudflare) -> None: + response = client.zero_trust.gateway.certificates.with_raw_response.list( + account_id="699d98642c564d2e855e9661899b7252", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + certificate = response.parse() + assert_matches_type(SyncSinglePage[CertificateListResponse], certificate, path=["response"]) + + @parametrize + def test_streaming_response_list(self, client: Cloudflare) -> None: + with client.zero_trust.gateway.certificates.with_streaming_response.list( + account_id="699d98642c564d2e855e9661899b7252", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + certificate = response.parse() + assert_matches_type(SyncSinglePage[CertificateListResponse], certificate, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + def test_path_params_list(self, client: Cloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + client.zero_trust.gateway.certificates.with_raw_response.list( + account_id="", + ) + + @parametrize + def test_method_delete(self, client: Cloudflare) -> None: + certificate = client.zero_trust.gateway.certificates.delete( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="699d98642c564d2e855e9661899b7252", + ) + assert_matches_type(Optional[CertificateDeleteResponse], certificate, path=["response"]) + + @parametrize + def test_raw_response_delete(self, client: Cloudflare) -> None: + response = client.zero_trust.gateway.certificates.with_raw_response.delete( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="699d98642c564d2e855e9661899b7252", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + certificate = response.parse() + assert_matches_type(Optional[CertificateDeleteResponse], certificate, path=["response"]) + + @parametrize + def test_streaming_response_delete(self, client: Cloudflare) -> None: + with client.zero_trust.gateway.certificates.with_streaming_response.delete( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="699d98642c564d2e855e9661899b7252", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + certificate = response.parse() + assert_matches_type(Optional[CertificateDeleteResponse], certificate, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + def test_path_params_delete(self, client: Cloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + client.zero_trust.gateway.certificates.with_raw_response.delete( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `certificate_id` but received ''"): + client.zero_trust.gateway.certificates.with_raw_response.delete( + "", + account_id="699d98642c564d2e855e9661899b7252", + ) + + @parametrize + def test_method_get(self, client: Cloudflare) -> None: + certificate = client.zero_trust.gateway.certificates.get( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="699d98642c564d2e855e9661899b7252", + ) + assert_matches_type(Optional[CertificateGetResponse], certificate, path=["response"]) + + @parametrize + def test_raw_response_get(self, client: Cloudflare) -> None: + response = client.zero_trust.gateway.certificates.with_raw_response.get( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="699d98642c564d2e855e9661899b7252", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + certificate = response.parse() + assert_matches_type(Optional[CertificateGetResponse], certificate, path=["response"]) + + @parametrize + def test_streaming_response_get(self, client: Cloudflare) -> None: + with client.zero_trust.gateway.certificates.with_streaming_response.get( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="699d98642c564d2e855e9661899b7252", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + certificate = response.parse() + assert_matches_type(Optional[CertificateGetResponse], certificate, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + def test_path_params_get(self, client: Cloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + client.zero_trust.gateway.certificates.with_raw_response.get( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `certificate_id` but received ''"): + client.zero_trust.gateway.certificates.with_raw_response.get( + "", + account_id="699d98642c564d2e855e9661899b7252", + ) + + +class TestAsyncCertificates: + parametrize = pytest.mark.parametrize("async_client", [False, True], indirect=True, ids=["loose", "strict"]) + + @parametrize + async def test_method_create(self, async_client: AsyncCloudflare) -> None: + certificate = await async_client.zero_trust.gateway.certificates.create( + account_id="699d98642c564d2e855e9661899b7252", + ) + assert_matches_type(Optional[CertificateCreateResponse], certificate, path=["response"]) + + @parametrize + async def test_method_create_with_all_params(self, async_client: AsyncCloudflare) -> None: + certificate = await async_client.zero_trust.gateway.certificates.create( + account_id="699d98642c564d2e855e9661899b7252", + validity_period_days=1826, + ) + assert_matches_type(Optional[CertificateCreateResponse], certificate, path=["response"]) + + @parametrize + async def test_raw_response_create(self, async_client: AsyncCloudflare) -> None: + response = await async_client.zero_trust.gateway.certificates.with_raw_response.create( + account_id="699d98642c564d2e855e9661899b7252", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + certificate = await response.parse() + assert_matches_type(Optional[CertificateCreateResponse], certificate, path=["response"]) + + @parametrize + async def test_streaming_response_create(self, async_client: AsyncCloudflare) -> None: + async with async_client.zero_trust.gateway.certificates.with_streaming_response.create( + account_id="699d98642c564d2e855e9661899b7252", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + certificate = await response.parse() + assert_matches_type(Optional[CertificateCreateResponse], certificate, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + async def test_path_params_create(self, async_client: AsyncCloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + await async_client.zero_trust.gateway.certificates.with_raw_response.create( + account_id="", + ) + + @parametrize + async def test_method_list(self, async_client: AsyncCloudflare) -> None: + certificate = await async_client.zero_trust.gateway.certificates.list( + account_id="699d98642c564d2e855e9661899b7252", + ) + assert_matches_type(AsyncSinglePage[CertificateListResponse], certificate, path=["response"]) + + @parametrize + async def test_raw_response_list(self, async_client: AsyncCloudflare) -> None: + response = await async_client.zero_trust.gateway.certificates.with_raw_response.list( + account_id="699d98642c564d2e855e9661899b7252", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + certificate = await response.parse() + assert_matches_type(AsyncSinglePage[CertificateListResponse], certificate, path=["response"]) + + @parametrize + async def test_streaming_response_list(self, async_client: AsyncCloudflare) -> None: + async with async_client.zero_trust.gateway.certificates.with_streaming_response.list( + account_id="699d98642c564d2e855e9661899b7252", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + certificate = await response.parse() + assert_matches_type(AsyncSinglePage[CertificateListResponse], certificate, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + async def test_path_params_list(self, async_client: AsyncCloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + await async_client.zero_trust.gateway.certificates.with_raw_response.list( + account_id="", + ) + + @parametrize + async def test_method_delete(self, async_client: AsyncCloudflare) -> None: + certificate = await async_client.zero_trust.gateway.certificates.delete( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="699d98642c564d2e855e9661899b7252", + ) + assert_matches_type(Optional[CertificateDeleteResponse], certificate, path=["response"]) + + @parametrize + async def test_raw_response_delete(self, async_client: AsyncCloudflare) -> None: + response = await async_client.zero_trust.gateway.certificates.with_raw_response.delete( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="699d98642c564d2e855e9661899b7252", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + certificate = await response.parse() + assert_matches_type(Optional[CertificateDeleteResponse], certificate, path=["response"]) + + @parametrize + async def test_streaming_response_delete(self, async_client: AsyncCloudflare) -> None: + async with async_client.zero_trust.gateway.certificates.with_streaming_response.delete( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="699d98642c564d2e855e9661899b7252", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + certificate = await response.parse() + assert_matches_type(Optional[CertificateDeleteResponse], certificate, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + async def test_path_params_delete(self, async_client: AsyncCloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + await async_client.zero_trust.gateway.certificates.with_raw_response.delete( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `certificate_id` but received ''"): + await async_client.zero_trust.gateway.certificates.with_raw_response.delete( + "", + account_id="699d98642c564d2e855e9661899b7252", + ) + + @parametrize + async def test_method_get(self, async_client: AsyncCloudflare) -> None: + certificate = await async_client.zero_trust.gateway.certificates.get( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="699d98642c564d2e855e9661899b7252", + ) + assert_matches_type(Optional[CertificateGetResponse], certificate, path=["response"]) + + @parametrize + async def test_raw_response_get(self, async_client: AsyncCloudflare) -> None: + response = await async_client.zero_trust.gateway.certificates.with_raw_response.get( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="699d98642c564d2e855e9661899b7252", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + certificate = await response.parse() + assert_matches_type(Optional[CertificateGetResponse], certificate, path=["response"]) + + @parametrize + async def test_streaming_response_get(self, async_client: AsyncCloudflare) -> None: + async with async_client.zero_trust.gateway.certificates.with_streaming_response.get( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="699d98642c564d2e855e9661899b7252", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + certificate = await response.parse() + assert_matches_type(Optional[CertificateGetResponse], certificate, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @parametrize + async def test_path_params_get(self, async_client: AsyncCloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + await async_client.zero_trust.gateway.certificates.with_raw_response.get( + "f174e90a-fafe-4643-bbbc-4a0ed4fc8415", + account_id="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `certificate_id` but received ''"): + await async_client.zero_trust.gateway.certificates.with_raw_response.get( + "", + account_id="699d98642c564d2e855e9661899b7252", + )