-
Notifications
You must be signed in to change notification settings - Fork 7
Expand file tree
/
Copy pathpagination.py
More file actions
145 lines (111 loc) · 3.91 KB
/
pagination.py
File metadata and controls
145 lines (111 loc) · 3.91 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
from typing import Any, List, Generic, TypeVar, Optional, cast
from typing_extensions import Protocol, override, runtime_checkable
from ._base_client import BasePage, PageInfo, BaseSyncPage, BaseAsyncPage
__all__ = ["SyncCursorPage", "AsyncCursorPage", "SyncSinglePage", "AsyncSinglePage"]
_T = TypeVar("_T")
@runtime_checkable
class CursorPageItem(Protocol):
token: Optional[str]
class SyncCursorPage(BaseSyncPage[_T], BasePage[_T], Generic[_T]):
data: List[_T]
has_more: bool
@override
def _get_page_items(self) -> List[_T]:
data = self.data
if not data:
return []
return data
@override
def has_next_page(self) -> bool:
has_more = self.has_more
return has_more and super().has_next_page()
@override
def next_page_info(self) -> Optional[PageInfo]:
is_forwards = not self._options.params.get("ending_before", False)
data = self.data
if not data:
return None
if is_forwards:
item = cast(Any, data[-1])
if not isinstance(item, CursorPageItem) or item.token is None:
# TODO emit warning log
return None
return PageInfo(params={"starting_after": item.token})
else:
item = cast(Any, self.data[0])
if not isinstance(item, CursorPageItem) or item.token is None:
# TODO emit warning log
return None
return PageInfo(params={"ending_before": item.token})
class AsyncCursorPage(BaseAsyncPage[_T], BasePage[_T], Generic[_T]):
data: List[_T]
has_more: bool
@override
def _get_page_items(self) -> List[_T]:
data = self.data
if not data:
return []
return data
@override
def has_next_page(self) -> bool:
has_more = self.has_more
return has_more and super().has_next_page()
@override
def next_page_info(self) -> Optional[PageInfo]:
is_forwards = not self._options.params.get("ending_before", False)
data = self.data
if not data:
return None
if is_forwards:
item = cast(Any, data[-1])
if not isinstance(item, CursorPageItem) or item.token is None:
# TODO emit warning log
return None
return PageInfo(params={"starting_after": item.token})
else:
item = cast(Any, self.data[0])
if not isinstance(item, CursorPageItem) or item.token is None:
# TODO emit warning log
return None
return PageInfo(params={"ending_before": item.token})
class SyncSinglePage(BaseSyncPage[_T], BasePage[_T], Generic[_T]):
data: List[_T]
has_more: bool
@override
def _get_page_items(self) -> List[_T]:
data = self.data
if not data:
return []
return data
@override
def has_next_page(self) -> bool:
has_more = self.has_more
return has_more and super().has_next_page()
@override
def next_page_info(self) -> None:
"""
This page represents a response that isn't actually paginated at the API level
so there will never be a next page.
"""
return None
class AsyncSinglePage(BaseAsyncPage[_T], BasePage[_T], Generic[_T]):
data: List[_T]
has_more: bool
@override
def _get_page_items(self) -> List[_T]:
data = self.data
if not data:
return []
return data
@override
def has_next_page(self) -> bool:
has_more = self.has_more
return has_more and super().has_next_page()
@override
def next_page_info(self) -> None:
"""
This page represents a response that isn't actually paginated at the API level
so there will never be a next page.
"""
return None