pydantic-api-sdk-notion


Namepydantic-api-sdk-notion JSON
Version 0.0.33 PyPI version JSON
download
home_pagehttps://github.com/stevieflyer/pydantic-api-sdk-notion
SummaryType Safe SDK For Notion API
upload_time2025-01-03 02:16:09
maintainerNone
docs_urlNone
authorstevieflyer
requires_python<4.0,>=3.8
licenseMIT
keywords notion pydantic api type-safe
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # 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"
}
        
Elapsed time: 9.51462s