# Type-Safe Notion API SDK
A Python SDK for interacting with the Notion API, featuring **complete IntelliSense support**. Always **up-to-date** with the latest Notion API documentation.
---
## Installation
Install the SDK using pip:
```bash
pip install pydantic-api-sdk-notion
```
## Quick Start
```python
# Import the NotionClient object from the SDK
from pydantic_api.notion.sdk import NotionClient
# Import all Notion-API related types from pydantic_api.notion.models
from pydantic_api.notion.models import (
TitleDatabaseProperty,
NumberDatabaseProperty,
PeopleDatabaseProperty,
RichTextDatabaseProperty,
# The SDK provides Factory classes for quick instantiation of Notion API objects
SortObjectFactory,
ParentObjectFactory,
RichTextObjectFactory,
)
# Instantiate a Notion client
notion_api_key = '<your-notion-api-key>'
client = NotionClient(auth=notion_api_key)
# List users
list_user_response = client.users.list(page_size=5) # Returns `NotionPaginatedData[UserObject]`
print(type(list_user_response.results[0])) # Prints 'PersonUserObject' or 'BotUserObject'
# Create a new database
new_database = client.databases.create(
parent=ParentObjectFactory.new_page_parent(
page_id="13e6c6f3f38d80269039f0186aaf95bb"
),
title=[
RichTextObjectFactory.new_text(content="🌿 Magical Plant Database"),
],
properties={
"Plant": TitleDatabaseProperty.define(),
"Scientific Name": RichTextDatabaseProperty.define(),
"Price ($)": NumberDatabaseProperty.define(format="dollar"),
"Discovered By": PeopleDatabaseProperty.define(),
},
)
# Query the database
records = client.databases.query(
database_id=new_database.id,
sorts=[
SortObjectFactory.new_property_sort(
property="Price", direction="descending"
)
],
page_size=3,
)
```
## Additional Notes
The **types used in this SDK** are maintained in a separate GitHub repository:
[https://github.com/stevieflyer/pydantic-api-models-notion](https://github.com/stevieflyer/pydantic-api-models-notion)
This repository ensures type definitions stay **in sync with the latest Notion API updates**. Developers can directly use these types for their own projects, even without the SDK.
Raw data
{
"_id": null,
"home_page": "https://github.com/stevieflyer/pydantic-api-sdk-notion",
"name": "pydantic-api-sdk-notion",
"maintainer": null,
"docs_url": null,
"requires_python": "<4.0,>=3.8",
"maintainer_email": null,
"keywords": "notion, pydantic, api, type-safe",
"author": "stevieflyer",
"author_email": null,
"download_url": "https://files.pythonhosted.org/packages/56/c6/6f77289204d083f96fac53f61a8f7d67d953123a98eef9ff5d7de584d7c0/pydantic_api_sdk_notion-0.0.33.tar.gz",
"platform": null,
"description": "# Type-Safe Notion API SDK\n\nA Python SDK for interacting with the Notion API, featuring **complete IntelliSense support**. Always **up-to-date** with the latest Notion API documentation.\n\n---\n\n## Installation\n\nInstall the SDK using pip:\n\n```bash\npip install pydantic-api-sdk-notion\n```\n\n## Quick Start\n\n```python\n# Import the NotionClient object from the SDK\nfrom pydantic_api.notion.sdk import NotionClient\n\n# Import all Notion-API related types from pydantic_api.notion.models\nfrom pydantic_api.notion.models import (\n TitleDatabaseProperty,\n NumberDatabaseProperty,\n PeopleDatabaseProperty,\n RichTextDatabaseProperty,\n # The SDK provides Factory classes for quick instantiation of Notion API objects\n SortObjectFactory,\n ParentObjectFactory,\n RichTextObjectFactory,\n)\n\n# Instantiate a Notion client\nnotion_api_key = '<your-notion-api-key>'\nclient = NotionClient(auth=notion_api_key)\n\n# List users\nlist_user_response = client.users.list(page_size=5) # Returns `NotionPaginatedData[UserObject]`\nprint(type(list_user_response.results[0])) # Prints 'PersonUserObject' or 'BotUserObject'\n\n# Create a new database\nnew_database = client.databases.create(\n parent=ParentObjectFactory.new_page_parent(\n page_id=\"13e6c6f3f38d80269039f0186aaf95bb\"\n ),\n title=[\n RichTextObjectFactory.new_text(content=\"\ud83c\udf3f Magical Plant Database\"),\n ],\n properties={\n \"Plant\": TitleDatabaseProperty.define(),\n \"Scientific Name\": RichTextDatabaseProperty.define(),\n \"Price ($)\": NumberDatabaseProperty.define(format=\"dollar\"),\n \"Discovered By\": PeopleDatabaseProperty.define(),\n },\n)\n\n# Query the database\nrecords = client.databases.query(\n database_id=new_database.id,\n sorts=[\n SortObjectFactory.new_property_sort(\n property=\"Price\", direction=\"descending\"\n )\n ],\n page_size=3,\n)\n```\n\n## Additional Notes\n\nThe **types used in this SDK** are maintained in a separate GitHub repository: \n[https://github.com/stevieflyer/pydantic-api-models-notion](https://github.com/stevieflyer/pydantic-api-models-notion)\n\nThis repository ensures type definitions stay **in sync with the latest Notion API updates**. Developers can directly use these types for their own projects, even without the SDK.\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Type Safe SDK For Notion API",
"version": "0.0.33",
"project_urls": {
"Homepage": "https://github.com/stevieflyer/pydantic-api-sdk-notion",
"Repository": "https://github.com/stevieflyer/pydantic-api-sdk-notion"
},
"split_keywords": [
"notion",
" pydantic",
" api",
" type-safe"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "6b6288b5c44c02f87c8f22b79422bbce5fea4a6a566ed5ab5c409d9b7b6c4c42",
"md5": "7c002a1aa2bb279ba5dea063c295947d",
"sha256": "11e9b84ae51f01e5ac938a67e775827cd2f1ca8d7fd11a2c0502195e184026a8"
},
"downloads": -1,
"filename": "pydantic_api_sdk_notion-0.0.33-py3-none-any.whl",
"has_sig": false,
"md5_digest": "7c002a1aa2bb279ba5dea063c295947d",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0,>=3.8",
"size": 15370,
"upload_time": "2025-01-03T02:16:07",
"upload_time_iso_8601": "2025-01-03T02:16:07.015488Z",
"url": "https://files.pythonhosted.org/packages/6b/62/88b5c44c02f87c8f22b79422bbce5fea4a6a566ed5ab5c409d9b7b6c4c42/pydantic_api_sdk_notion-0.0.33-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "56c66f77289204d083f96fac53f61a8f7d67d953123a98eef9ff5d7de584d7c0",
"md5": "0042bdbf10c197422f8302ab932279a4",
"sha256": "dc474a2a3afbff409f06fe648c2df99d501a98a31acf02669c7852e7623d0141"
},
"downloads": -1,
"filename": "pydantic_api_sdk_notion-0.0.33.tar.gz",
"has_sig": false,
"md5_digest": "0042bdbf10c197422f8302ab932279a4",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0,>=3.8",
"size": 10662,
"upload_time": "2025-01-03T02:16:09",
"upload_time_iso_8601": "2025-01-03T02:16:09.608233Z",
"url": "https://files.pythonhosted.org/packages/56/c6/6f77289204d083f96fac53f61a8f7d67d953123a98eef9ff5d7de584d7c0/pydantic_api_sdk_notion-0.0.33.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-03 02:16:09",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "stevieflyer",
"github_project": "pydantic-api-sdk-notion",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "pydantic-api-sdk-notion"
}