Skip to main content

Client-agnostic model wrapper for Notion API

Project description

basic-notion

Client-agnostic model wrapper for Notion API.

This library does not do any interaction over the network itself, so it can be used with any existing client that exposes as output and accepts as input raw JSONable data.

Note that this project is in active development, so major changes in its structure and API are quite possible in the near future.

Installation

Just like any other python package out there, it can be installed via pip:

pip install basic-notion

Basic Examples

Defining Models

All of the examples assume that you put the following code in a file and name it models.py:

from basic_notion.page import NotionPage, NotionPageList
from basic_notion.field import SelectField, TitleField, MultiSelectField


class ReadingListItem(NotionPage):
    type = SelectField(property_name='Type')
    name = TitleField(property_name='Name')
    status = SelectField(property_name='Status')
    authors = MultiSelectField(property_name='Author')


class ReadingList(NotionPageList[ReadingListItem]):
    ITEM_CLS = ReadingListItem

All the other examples are using the notion-client package for sending and fetching data. See the package's homepage on GitHub

Fetching a page list from a database

(assuming you put the contents of previous example in models.py)

import asyncio
import os

from notion_client import AsyncClient
from basic_notion.query import Query

from models import ReadingList


async def get_reading_list() -> ReadingList:
    database_id = os.environ['DATABASE_ID']
    notion_token = os.environ['NOTION_TOKEN']
    notion = AsyncClient(auth=notion_token)
    data = await notion.databases.query(
        **Query.database(
            database_id
        ).filter(
            # Construct filter using model's field
            # (only one filter expression is supported)
            ReadingList.item.type.filter.equals('Book')
        ).sorts(
            # And, similarly, the result's sorting
            # (multiple fields can be listed here)
            ReadingList.item.name.sort.ascending
        ).serialize()
    )
    return ReadingList(data=data)


def print_reading_list(reading_list: ReadingList) -> None:
    for item in reading_list.items():
        print(f'[{item.type.name}] {item.name.one_item.content}')


async def main() -> None:
    reading_list = await get_reading_list()
    print_reading_list(reading_list)


asyncio.run(main())

Creating a new page

from notion_client import Client
from models import ReadingListItem

def create_page(client: Client, database_id: str) -> ReadingListItem:
    page = ReadingListItem.make(
        parent={'database_id': database_id},
        type='Book',
        name=['The Best Book Ever'],
        authors=['John Doe'],
    )
    response = client.pages.create(**page.data)
    item = ReadingListItem(data=response)
    # assert len(item.id) == 36
    # assert item.type.name == 'Book'
    # assert item.name.get_text() == 'The Best Book Ever'
    # assert item.authors.get_text() == 'John Doe'
    # assert not item.name[0].bold
    return item

Creating a new database

from notion_client import Client
from basic_notion.database import NotionDatabase
from models import ReadingListItem

def create_database(client: Client, parent_page_id: str) -> NotionDatabase:
    database = NotionDatabase.make(
        title=['My New Shiny Database'],
        parent={'page_id': parent_page_id},
        properties=ReadingListItem.schema,
    )
    response = client.pages.create(**database.data)
    created_database = NotionDatabase(data=response)
    return created_database

You can also see the files in tests/ for more examples and more thorough usage of the various attributes and properties

Development and Testing

Configuring the test environment

Install

pip install -Ue .[testing]

Create file .env with the following content:

NOTION_API_TOKEN=<your-notion-token>
ROOT_PAGE_ID=<your-page-id>

Where:

  • <your-notion-token> is your Notion API developer's token. You will need to create a Notion integration for this: visit https://www.notion.so/my-integrations.
  • <your-page-id> is the ID of a page where the tests will create new child pages and databases. It must have read/write permissions for your access token.

Testing

Run the tests:

pytest tests

And always validate typing:

mypy src/basic_notion

Or simply

make test

(it will run all test commands)

Links

Homepage on GitHub: https://github.com/altvod/basic-notion

Project's page on PyPi: https://pypi.org/project/basic-notion/

Notion API: https://developers.notion.com/

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

basic-notion-0.6.2.tar.gz (17.5 kB view details)

Uploaded Source

Built Distribution

basic_notion-0.6.2-py3-none-any.whl (21.7 kB view details)

Uploaded Python 3

File details

Details for the file basic-notion-0.6.2.tar.gz.

File metadata

  • Download URL: basic-notion-0.6.2.tar.gz
  • Upload date:
  • Size: 17.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.5.0 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for basic-notion-0.6.2.tar.gz
Algorithm Hash digest
SHA256 28218df1f7a8c95ac2b0b6e5534d29722eae41972d78e7e563efefbc44001f3f
MD5 d5ac78ed26a41b790d69d0db7d157f90
BLAKE2b-256 35957dddcc22c7b34e45fb26e8aa718e9a0d785ab2af995d4230f8db7d64ff0d

See more details on using hashes here.

File details

Details for the file basic_notion-0.6.2-py3-none-any.whl.

File metadata

  • Download URL: basic_notion-0.6.2-py3-none-any.whl
  • Upload date:
  • Size: 21.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.5.0 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for basic_notion-0.6.2-py3-none-any.whl
Algorithm Hash digest
SHA256 28347b3abaf03a2b90be58c34abaac821423ffaa43a3b760ff1b3ffa215836bf
MD5 dce6c255af914d4391ec8129d8d6b0a7
BLAKE2b-256 486ca0aa275794a0cc0dfd51e8604af92bc04975ac5e2cfbc3c4342abffd4d38

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page