Coverage for notion_client/api_endpoints.py: 100%
58 statements
« prev ^ index » next coverage.py v7.6.10, created at 2025-01-15 10:21 +0000
« prev ^ index » next coverage.py v7.6.10, created at 2025-01-15 10:21 +0000
1"""Notion API endpoints.""" # noqa: E501
3from typing import TYPE_CHECKING, Any
5from notion_client.helpers import pick
6from notion_client.typing import SyncAsync
8if TYPE_CHECKING: # pragma: no cover
9 from notion_client.client import BaseClient
12class Endpoint:
13 def __init__(self, parent: "BaseClient") -> None:
14 self.parent = parent
17class BlocksChildrenEndpoint(Endpoint):
18 def append(self, block_id: str, **kwargs: Any) -> SyncAsync[Any]:
19 """Create and append new children blocks to the block using the ID specified.
21 *[🔗 Endpoint documentation](https://developers.notion.com/reference/patch-block-children)*
22 """ # noqa: E501
23 return self.parent.request(
24 path=f"blocks/{block_id}/children",
25 method="PATCH",
26 body=pick(kwargs, "children", "after"),
27 auth=kwargs.get("auth"),
28 )
30 def list(self, block_id: str, **kwargs: Any) -> SyncAsync[Any]:
31 """Return a paginated array of child [block objects](https://developers.notion.com/reference/block) contained in the block.
33 *[🔗 Endpoint documentation](https://developers.notion.com/reference/get-block-children)*
34 """ # noqa: E501
35 return self.parent.request(
36 path=f"blocks/{block_id}/children",
37 method="GET",
38 query=pick(kwargs, "start_cursor", "page_size"),
39 auth=kwargs.get("auth"),
40 )
43class BlocksEndpoint(Endpoint):
44 def __init__(self, *args: Any, **kwargs: Any) -> None:
45 super().__init__(*args, **kwargs)
46 self.children = BlocksChildrenEndpoint(*args, **kwargs)
48 def retrieve(self, block_id: str, **kwargs: Any) -> SyncAsync[Any]:
49 """Retrieve a [Block object](https://developers.notion.com/reference/block) using the ID specified.
51 *[🔗 Endpoint documentation](https://developers.notion.com/reference/retrieve-a-block)*
52 """ # noqa: E501
53 return self.parent.request(
54 path=f"blocks/{block_id}", method="GET", auth=kwargs.get("auth")
55 )
57 def update(self, block_id: str, **kwargs: Any) -> SyncAsync[Any]:
58 """Update the content for the specified `block_id` based on the block type.
60 *[🔗 Endpoint documentation](https://developers.notion.com/reference/update-a-block)*
61 """ # noqa: E501
62 return self.parent.request(
63 path=f"blocks/{block_id}",
64 method="PATCH",
65 body=pick(
66 kwargs,
67 "embed",
68 "type",
69 "archived",
70 "bookmark",
71 "image",
72 "video",
73 "pdf",
74 "file",
75 "audio",
76 "code",
77 "equation",
78 "divider",
79 "breadcrumb",
80 "table_of_contents",
81 "link_to_page",
82 "table_row",
83 "heading_1",
84 "heading_2",
85 "heading_3",
86 "paragraph",
87 "bulleted_list_item",
88 "numbered_list_item",
89 "quote",
90 "to_do",
91 "toggle",
92 "template",
93 "callout",
94 "synced_block",
95 "table",
96 ),
97 auth=kwargs.get("auth"),
98 )
100 def delete(self, block_id: str, **kwargs: Any) -> SyncAsync[Any]:
101 """Set a [Block object](https://developers.notion.com/reference/block), including page blocks, to `archived: true`.
103 *[🔗 Endpoint documentation](https://developers.notion.com/reference/delete-a-block)*
104 """ # noqa: E501
105 return self.parent.request(
106 path=f"blocks/{block_id}",
107 method="DELETE",
108 auth=kwargs.get("auth"),
109 )
112class DatabasesEndpoint(Endpoint):
113 def list(self, **kwargs: Any) -> SyncAsync[Any]: # pragma: no cover
114 """List all [Databases](https://developers.notion.com/reference/database) shared with the authenticated integration.
116 > ⚠️ **Deprecated endpoint**
118 *[🔗 Endpoint documentation](https://developers.notion.com/reference/get-databases)*
119 """ # noqa: E501
120 return self.parent.request(
121 path="databases",
122 method="GET",
123 query=pick(kwargs, "start_cursor", "page_size"),
124 auth=kwargs.get("auth"),
125 )
127 def query(self, database_id: str, **kwargs: Any) -> SyncAsync[Any]:
128 """Get a list of [Pages](https://developers.notion.com/reference/page) contained in the database.
130 *[🔗 Endpoint documentation](https://developers.notion.com/reference/post-database-query)*
131 """ # noqa: E501
132 return self.parent.request(
133 path=f"databases/{database_id}/query",
134 method="POST",
135 query=pick(kwargs, "filter_properties"),
136 body=pick(kwargs, "filter", "sorts", "start_cursor", "page_size"),
137 auth=kwargs.get("auth"),
138 )
140 def retrieve(self, database_id: str, **kwargs: Any) -> SyncAsync[Any]:
141 """Retrieve a [Database object](https://developers.notion.com/reference/database) using the ID specified.
143 *[🔗 Endpoint documentation](https://developers.notion.com/reference/retrieve-a-database)*
144 """ # noqa: E501
145 return self.parent.request(
146 path=f"databases/{database_id}", method="GET", auth=kwargs.get("auth")
147 )
149 def create(self, **kwargs: Any) -> SyncAsync[Any]:
150 """Create a database as a subpage in the specified parent page.
152 *[🔗 Endpoint documentation](https://developers.notion.com/reference/create-a-database)*
153 """ # noqa: E501
154 return self.parent.request(
155 path="databases",
156 method="POST",
157 body=pick(
158 kwargs, "parent", "title", "properties", "icon", "cover", "is_inline"
159 ),
160 auth=kwargs.get("auth"),
161 )
163 def update(self, database_id: str, **kwargs: Any) -> SyncAsync[Any]:
164 """Update an existing database as specified by the parameters.
166 *[🔗 Endpoint documentation](https://developers.notion.com/reference/update-a-database)*
167 """ # noqa: E501
168 return self.parent.request(
169 path=f"databases/{database_id}",
170 method="PATCH",
171 body=pick(
172 kwargs,
173 "properties",
174 "title",
175 "description",
176 "icon",
177 "cover",
178 "is_inline",
179 ),
180 auth=kwargs.get("auth"),
181 )
184class PagesPropertiesEndpoint(Endpoint):
185 def retrieve(self, page_id: str, property_id: str, **kwargs: Any) -> SyncAsync[Any]:
186 """Retrieve a `property_item` object for a given `page_id` and `property_id`.
188 *[🔗 Endpoint documentation](https://developers.notion.com/reference/retrieve-a-page-property)*
189 """ # noqa: E501
190 return self.parent.request(
191 path=f"pages/{page_id}/properties/{property_id}",
192 method="GET",
193 auth=kwargs.get("auth"),
194 query=pick(kwargs, "start_cursor", "page_size"),
195 )
198class PagesEndpoint(Endpoint):
199 def __init__(self, *args: Any, **kwargs: Any) -> None:
200 super().__init__(*args, **kwargs)
201 self.properties = PagesPropertiesEndpoint(*args, **kwargs)
203 def create(self, **kwargs: Any) -> SyncAsync[Any]:
204 """Create a new page in the specified database or as a child of an existing page.
206 *[🔗 Endpoint documentation](https://developers.notion.com/reference/post-page)*
207 """ # noqa: E501
208 return self.parent.request(
209 path="pages",
210 method="POST",
211 body=pick(kwargs, "parent", "properties", "children", "icon", "cover"),
212 auth=kwargs.get("auth"),
213 )
215 def retrieve(self, page_id: str, **kwargs: Any) -> SyncAsync[Any]:
216 """Retrieve a [Page object](https://developers.notion.com/reference/page) using the ID specified.
218 *[🔗 Endpoint documentation](https://developers.notion.com/reference/retrieve-a-page)*
219 """ # noqa: E501
220 return self.parent.request(
221 path=f"pages/{page_id}",
222 method="GET",
223 query=pick(kwargs, "filter_properties"),
224 auth=kwargs.get("auth"),
225 )
227 def update(self, page_id: str, **kwargs: Any) -> SyncAsync[Any]:
228 """Update [page property values](https://developers.notion.com/reference/page#property-value-object) for the specified page.
230 *[🔗 Endpoint documentation](https://developers.notion.com/reference/patch-page)*
231 """ # noqa: E501
232 return self.parent.request(
233 path=f"pages/{page_id}",
234 method="PATCH",
235 body=pick(kwargs, "in_trash", "archived", "properties", "icon", "cover"),
236 auth=kwargs.get("auth"),
237 )
240class UsersEndpoint(Endpoint):
241 def list(self, **kwargs: Any) -> SyncAsync[Any]:
242 """Return a paginated list of [Users](https://developers.notion.com/reference/user) for the workspace.
244 *[🔗 Endpoint documentation](https://developers.notion.com/reference/get-users)*
245 """ # noqa: E501
246 return self.parent.request(
247 path="users",
248 method="GET",
249 query=pick(kwargs, "start_cursor", "page_size"),
250 auth=kwargs.get("auth"),
251 )
253 def retrieve(self, user_id: str, **kwargs: Any) -> SyncAsync[Any]:
254 """Retrieve a [User](https://developers.notion.com/reference/user) using the ID specified.
256 *[🔗 Endpoint documentation](https://developers.notion.com/reference/get-user)*
257 """ # noqa: E501
258 return self.parent.request(
259 path=f"users/{user_id}", method="GET", auth=kwargs.get("auth")
260 )
262 def me(self, **kwargs: Any) -> SyncAsync[Any]:
263 """Retrieve the bot [User](https://developers.notion.com/reference/user) associated with the API token.
265 *[🔗 Endpoint documentation](https://developers.notion.com/reference/get-self)*
266 """ # noqa: E501
267 return self.parent.request(
268 path="users/me", method="GET", auth=kwargs.get("auth")
269 )
272class SearchEndpoint(Endpoint):
273 def __call__(self, **kwargs: Any) -> SyncAsync[Any]:
274 """Search all pages and child pages that are shared with the integration.
276 *[🔗 Endpoint documentation](https://developers.notion.com/reference/post-search)*
277 """ # noqa: E501
278 return self.parent.request(
279 path="search",
280 method="POST",
281 body=pick(kwargs, "query", "sort", "filter", "start_cursor", "page_size"),
282 auth=kwargs.get("auth"),
283 )
286class CommentsEndpoint(Endpoint):
287 def create(self, **kwargs: Any) -> SyncAsync[Any]:
288 """Create a new comment in the specified page or existing discussion thread.
290 *[🔗 Endpoint documentation](https://developers.notion.com/reference/create-a-comment)*
291 """ # noqa: E501
292 return self.parent.request(
293 path="comments",
294 method="POST",
295 body=pick(kwargs, "parent", "discussion_id", "rich_text"),
296 auth=kwargs.get("auth"),
297 )
299 def list(self, **kwargs: Any) -> SyncAsync[Any]:
300 """Retrieve a list of un-resolved [Comment objects](https://developers.notion.com/reference/comment-object) from the specified block.
302 *[🔗 Endpoint documentation](https://developers.notion.com/reference/retrieve-a-comment)*
303 """ # noqa: E501
304 return self.parent.request(
305 path="comments",
306 method="GET",
307 query=pick(kwargs, "block_id", "start_cursor", "page_size"),
308 auth=kwargs.get("auth"),
309 )