From 03f2583fd34f950a5ef4060a2cbb61bb822d06af Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Wed, 10 Apr 2024 21:53:47 +0000 Subject: [PATCH] feat(api): update via SDK Studio (#280) --- api.md | 10 +-- src/cloudflare/resources/rules/lists/lists.py | 40 ++++++------ src/cloudflare/types/rules/__init__.py | 2 +- .../types/rules/{list.py => rule_list.py} | 6 +- tests/api_resources/rules/test_lists.py | 61 ++++++++++--------- 5 files changed, 61 insertions(+), 58 deletions(-) rename src/cloudflare/types/rules/{list.py => rule_list.py} (93%) diff --git a/api.md b/api.md index e40255dcac4..ca3f10eb557 100644 --- a/api.md +++ b/api.md @@ -4178,16 +4178,16 @@ Methods: Types: ```python -from cloudflare.types.rules import Hostname, List, Redirect, ListDeleteResponse +from cloudflare.types.rules import Hostname, Redirect, RuleList, ListDeleteResponse ``` Methods: -- client.rules.lists.create(\*, account_id, \*\*params) -> Optional -- client.rules.lists.update(list_id, \*, account_id, \*\*params) -> Optional -- client.rules.lists.list(\*, account_id) -> SyncSinglePage[List] +- client.rules.lists.create(\*, account_id, \*\*params) -> Optional +- client.rules.lists.update(list_id, \*, account_id, \*\*params) -> Optional +- client.rules.lists.list(\*, account_id) -> SyncSinglePage[RuleList] - client.rules.lists.delete(list_id, \*, account_id, \*\*params) -> Optional -- client.rules.lists.get(list_id, \*, account_id) -> Optional +- client.rules.lists.get(list_id, \*, account_id) -> Optional ### BulkOperations diff --git a/src/cloudflare/resources/rules/lists/lists.py b/src/cloudflare/resources/rules/lists/lists.py index c0152f80f77..66838e9460e 100644 --- a/src/cloudflare/resources/rules/lists/lists.py +++ b/src/cloudflare/resources/rules/lists/lists.py @@ -2,7 +2,7 @@ from __future__ import annotations -from typing import List, Type, Optional, cast +from typing import Type, Optional, cast from typing_extensions import Literal import httpx @@ -30,7 +30,7 @@ ) from ...._wrappers import ResultWrapper from ....pagination import SyncSinglePage, AsyncSinglePage -from ....types.rules import List, ListDeleteResponse, list_create_params, list_delete_params, list_update_params +from ....types.rules import RuleList, ListDeleteResponse, list_create_params, list_delete_params, list_update_params from ...._base_client import ( AsyncPaginator, make_request_options, @@ -77,7 +77,7 @@ def create( extra_query: Query | None = None, extra_body: Body | None = None, timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, - ) -> Optional[List]: + ) -> Optional[RuleList]: """ Creates a new list of the specified type. @@ -118,7 +118,7 @@ def create( timeout=timeout, post_parser=ResultWrapper._unwrapper, ), - cast_to=cast(Type[Optional[List]], ResultWrapper[List]), + cast_to=cast(Type[Optional[RuleList]], ResultWrapper[RuleList]), ) def update( @@ -133,7 +133,7 @@ def update( extra_query: Query | None = None, extra_body: Body | None = None, timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, - ) -> Optional[List]: + ) -> Optional[RuleList]: """ Updates the description of a list. @@ -166,7 +166,7 @@ def update( timeout=timeout, post_parser=ResultWrapper._unwrapper, ), - cast_to=cast(Type[Optional[List]], ResultWrapper[List]), + cast_to=cast(Type[Optional[RuleList]], ResultWrapper[RuleList]), ) def list( @@ -179,7 +179,7 @@ def list( extra_query: Query | None = None, extra_body: Body | None = None, timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, - ) -> SyncSinglePage[List]: + ) -> SyncSinglePage[RuleList]: """ Fetches all lists in the account. @@ -198,11 +198,11 @@ def list( 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}/rules/lists", - page=SyncSinglePage[List], + page=SyncSinglePage[RuleList], options=make_request_options( extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout ), - model=List, + model=RuleList, ) def delete( @@ -262,7 +262,7 @@ def get( extra_query: Query | None = None, extra_body: Body | None = None, timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, - ) -> Optional[List]: + ) -> Optional[RuleList]: """ Fetches the details of a list. @@ -292,7 +292,7 @@ def get( timeout=timeout, post_parser=ResultWrapper._unwrapper, ), - cast_to=cast(Type[Optional[List]], ResultWrapper[List]), + cast_to=cast(Type[Optional[RuleList]], ResultWrapper[RuleList]), ) @@ -326,7 +326,7 @@ async def create( extra_query: Query | None = None, extra_body: Body | None = None, timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, - ) -> Optional[List]: + ) -> Optional[RuleList]: """ Creates a new list of the specified type. @@ -367,7 +367,7 @@ async def create( timeout=timeout, post_parser=ResultWrapper._unwrapper, ), - cast_to=cast(Type[Optional[List]], ResultWrapper[List]), + cast_to=cast(Type[Optional[RuleList]], ResultWrapper[RuleList]), ) async def update( @@ -382,7 +382,7 @@ async def update( extra_query: Query | None = None, extra_body: Body | None = None, timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, - ) -> Optional[List]: + ) -> Optional[RuleList]: """ Updates the description of a list. @@ -415,7 +415,7 @@ async def update( timeout=timeout, post_parser=ResultWrapper._unwrapper, ), - cast_to=cast(Type[Optional[List]], ResultWrapper[List]), + cast_to=cast(Type[Optional[RuleList]], ResultWrapper[RuleList]), ) def list( @@ -428,7 +428,7 @@ def list( extra_query: Query | None = None, extra_body: Body | None = None, timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, - ) -> AsyncPaginator[List, AsyncSinglePage[List]]: + ) -> AsyncPaginator[RuleList, AsyncSinglePage[RuleList]]: """ Fetches all lists in the account. @@ -447,11 +447,11 @@ def list( 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}/rules/lists", - page=AsyncSinglePage[List], + page=AsyncSinglePage[RuleList], options=make_request_options( extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout ), - model=List, + model=RuleList, ) async def delete( @@ -511,7 +511,7 @@ async def get( extra_query: Query | None = None, extra_body: Body | None = None, timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, - ) -> Optional[List]: + ) -> Optional[RuleList]: """ Fetches the details of a list. @@ -541,7 +541,7 @@ async def get( timeout=timeout, post_parser=ResultWrapper._unwrapper, ), - cast_to=cast(Type[Optional[List]], ResultWrapper[List]), + cast_to=cast(Type[Optional[RuleList]], ResultWrapper[RuleList]), ) diff --git a/src/cloudflare/types/rules/__init__.py b/src/cloudflare/types/rules/__init__.py index 5afdefca7d7..00341b404f2 100644 --- a/src/cloudflare/types/rules/__init__.py +++ b/src/cloudflare/types/rules/__init__.py @@ -2,9 +2,9 @@ from __future__ import annotations -from .list import List as List from .hostname import Hostname as Hostname from .redirect import Redirect as Redirect +from .rule_list import RuleList as RuleList from .hostname_param import HostnameParam as HostnameParam from .redirect_param import RedirectParam as RedirectParam from .list_create_params import ListCreateParams as ListCreateParams diff --git a/src/cloudflare/types/rules/list.py b/src/cloudflare/types/rules/rule_list.py similarity index 93% rename from src/cloudflare/types/rules/list.py rename to src/cloudflare/types/rules/rule_list.py index d5e6b46e413..8c2b3e5e13c 100644 --- a/src/cloudflare/types/rules/list.py +++ b/src/cloudflare/types/rules/rule_list.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 typing_extensions import Literal from ..._models import BaseModel -__all__ = ["List"] +__all__ = ["RuleList"] -class List(BaseModel): +class RuleList(BaseModel): id: Optional[str] = None """The unique ID of the list.""" diff --git a/tests/api_resources/rules/test_lists.py b/tests/api_resources/rules/test_lists.py index f99b2f44efb..6d24dbac266 100644 --- a/tests/api_resources/rules/test_lists.py +++ b/tests/api_resources/rules/test_lists.py @@ -10,7 +10,10 @@ from cloudflare import Cloudflare, AsyncCloudflare from tests.utils import assert_matches_type from cloudflare.pagination import SyncSinglePage, AsyncSinglePage -from cloudflare.types.rules import List, ListDeleteResponse +from cloudflare.types.rules import ( + RuleList, + ListDeleteResponse, +) base_url = os.environ.get("TEST_API_BASE_URL", "http://127.0.0.1:4010") @@ -26,7 +29,7 @@ def test_method_create(self, client: Cloudflare) -> None: kind="ip", name="list1", ) - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -37,7 +40,7 @@ def test_method_create_with_all_params(self, client: Cloudflare) -> None: name="list1", description="This is a note", ) - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -51,7 +54,7 @@ def test_raw_response_create(self, client: Cloudflare) -> None: assert response.is_closed is True assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = response.parse() - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -65,7 +68,7 @@ def test_streaming_response_create(self, client: Cloudflare) -> None: assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = response.parse() - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) assert cast(Any, response.is_closed) is True @@ -86,7 +89,7 @@ def test_method_update(self, client: Cloudflare) -> None: "2c0fc9fa937b11eaa1b71c4d701ab86e", account_id="023e105f4ecef8ad9ca31a8372d0c353", ) - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -96,7 +99,7 @@ def test_method_update_with_all_params(self, client: Cloudflare) -> None: account_id="023e105f4ecef8ad9ca31a8372d0c353", description="This is a note", ) - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -109,7 +112,7 @@ def test_raw_response_update(self, client: Cloudflare) -> None: assert response.is_closed is True assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = response.parse() - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -122,7 +125,7 @@ def test_streaming_response_update(self, client: Cloudflare) -> None: assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = response.parse() - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) assert cast(Any, response.is_closed) is True @@ -147,7 +150,7 @@ def test_method_list(self, client: Cloudflare) -> None: list = client.rules.lists.list( account_id="023e105f4ecef8ad9ca31a8372d0c353", ) - assert_matches_type(SyncSinglePage[List], list, path=["response"]) + assert_matches_type(SyncSinglePage[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -159,7 +162,7 @@ def test_raw_response_list(self, client: Cloudflare) -> None: assert response.is_closed is True assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = response.parse() - assert_matches_type(SyncSinglePage[List], list, path=["response"]) + assert_matches_type(SyncSinglePage[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -171,7 +174,7 @@ def test_streaming_response_list(self, client: Cloudflare) -> None: assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = response.parse() - assert_matches_type(SyncSinglePage[List], list, path=["response"]) + assert_matches_type(SyncSinglePage[RuleList], list, path=["response"]) assert cast(Any, response.is_closed) is True @@ -247,7 +250,7 @@ def test_method_get(self, client: Cloudflare) -> None: "2c0fc9fa937b11eaa1b71c4d701ab86e", account_id="023e105f4ecef8ad9ca31a8372d0c353", ) - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -260,7 +263,7 @@ def test_raw_response_get(self, client: Cloudflare) -> None: assert response.is_closed is True assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = response.parse() - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -273,7 +276,7 @@ def test_streaming_response_get(self, client: Cloudflare) -> None: assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = response.parse() - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) assert cast(Any, response.is_closed) is True @@ -304,7 +307,7 @@ async def test_method_create(self, async_client: AsyncCloudflare) -> None: kind="ip", name="list1", ) - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -315,7 +318,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncCloudflare name="list1", description="This is a note", ) - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -329,7 +332,7 @@ async def test_raw_response_create(self, async_client: AsyncCloudflare) -> None: assert response.is_closed is True assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = await response.parse() - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -343,7 +346,7 @@ async def test_streaming_response_create(self, async_client: AsyncCloudflare) -> assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = await response.parse() - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) assert cast(Any, response.is_closed) is True @@ -364,7 +367,7 @@ async def test_method_update(self, async_client: AsyncCloudflare) -> None: "2c0fc9fa937b11eaa1b71c4d701ab86e", account_id="023e105f4ecef8ad9ca31a8372d0c353", ) - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -374,7 +377,7 @@ async def test_method_update_with_all_params(self, async_client: AsyncCloudflare account_id="023e105f4ecef8ad9ca31a8372d0c353", description="This is a note", ) - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -387,7 +390,7 @@ async def test_raw_response_update(self, async_client: AsyncCloudflare) -> None: assert response.is_closed is True assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = await response.parse() - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -400,7 +403,7 @@ async def test_streaming_response_update(self, async_client: AsyncCloudflare) -> assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = await response.parse() - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) assert cast(Any, response.is_closed) is True @@ -425,7 +428,7 @@ async def test_method_list(self, async_client: AsyncCloudflare) -> None: list = await async_client.rules.lists.list( account_id="023e105f4ecef8ad9ca31a8372d0c353", ) - assert_matches_type(AsyncSinglePage[List], list, path=["response"]) + assert_matches_type(AsyncSinglePage[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -437,7 +440,7 @@ async def test_raw_response_list(self, async_client: AsyncCloudflare) -> None: assert response.is_closed is True assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = await response.parse() - assert_matches_type(AsyncSinglePage[List], list, path=["response"]) + assert_matches_type(AsyncSinglePage[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -449,7 +452,7 @@ async def test_streaming_response_list(self, async_client: AsyncCloudflare) -> N assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = await response.parse() - assert_matches_type(AsyncSinglePage[List], list, path=["response"]) + assert_matches_type(AsyncSinglePage[RuleList], list, path=["response"]) assert cast(Any, response.is_closed) is True @@ -525,7 +528,7 @@ async def test_method_get(self, async_client: AsyncCloudflare) -> None: "2c0fc9fa937b11eaa1b71c4d701ab86e", account_id="023e105f4ecef8ad9ca31a8372d0c353", ) - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -538,7 +541,7 @@ async def test_raw_response_get(self, async_client: AsyncCloudflare) -> None: assert response.is_closed is True assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = await response.parse() - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) @pytest.mark.skip() @parametrize @@ -551,7 +554,7 @@ async def test_streaming_response_get(self, async_client: AsyncCloudflare) -> No assert response.http_request.headers.get("X-Stainless-Lang") == "python" list = await response.parse() - assert_matches_type(Optional[List], list, path=["response"]) + assert_matches_type(Optional[RuleList], list, path=["response"]) assert cast(Any, response.is_closed) is True