docs: Notion List Pages instructions

This commit is contained in:
Cezar Vasconcelos 2024-05-22 19:22:30 -03:00
commit 28ddd5a28e
3 changed files with 156 additions and 0 deletions

View file

@ -0,0 +1,156 @@
import Admonition from "@theme/Admonition";
import ThemedImage from "@theme/ThemedImage";
import useBaseUrl from "@docusaurus/useBaseUrl";
import ZoomableImage from "/src/theme/ZoomableImage.js";
# NotionDatabaseQuery Component in Langflow
Langflow allows you to extend its functionality with custom components. The `NotionDatabaseQuery` component is designed to query a Notion database with filtering and sorting. It provides a convenient way to integrate Notion database querying capabilities into your Langflow workflows.
> **Tip**:
>
> ### Component Functionality
>
> The `NotionDatabaseQuery` component enables you to:
>
> - Query a Notion database with custom filters and sorting options
> - Retrieve specific pages from a Notion database based on the provided criteria
> - Integrate Notion database data seamlessly into your Langflow workflows
## Component Usage
To use the `NotionDatabaseQuery` component in a Langflow flow, follow these steps:
1. **Add the `NotionDatabaseQuery` component to your flow.**
2. **Configure the component by providing the required parameters:**
- `notion_secret`: The Notion integration token for authentication.
- `database_id`: The ID of the Notion database you want to query.
- `query_payload`: A JSON string containing the filters and sorting options for the query.
3. **Connect the `NotionDatabaseQuery` component to other components in your flow as needed.**
### Example Component Code
```python
import requests
from typing import Dict, Any
from langchain.agents import Tool
from langflow.base.tools.base import build_status_from_tool
from langflow.custom import CustomComponent
class NotionDatabaseQuery(CustomComponent):
display_name = "List Pages [Notion]"
description = (
"Query a Notion database with filtering and sorting. "
"The input should be a JSON string containing the 'filter' and 'sorts' objects. "
"Example input:\n"
'{"filter": {"property": "Status", "select": {"equals": "Done"}}, "sorts": [{"timestamp": "created_time", "direction": "descending"}]}'
)
documentation: str = "https://developers.notion.com/reference/post-database-query"
icon = "NotionDirectoryLoader"
def build_config(self):
return {
"notion_secret": {
"display_name": "Notion Secret",
"field_type": "str",
"info": "The Notion integration token.",
"password": True,
},
"database_id": {
"display_name": "Database ID",
"field_type": "str",
"info": "The ID of the Notion database to query.",
},
"query_payload": {
"display_name": "Database query",
"field_type": "str",
"info": "A JSON string containing the filters that will be used for querying the database. EG: {'filter': {'property': 'Status', 'status': {'equals': 'In progress'}}}",
},
}
def build(
self,
notion_secret: str,
database_id: str,
query_payload: str,
) -> str:
try:
query_data = json.loads(query_payload)
filter_obj = query_data.get("filter")
sorts = query_data.get("sorts", [])
url = f"https://api.notion.com/v1/databases/{database_id}/query"
headers = {
"Authorization": f"Bearer {notion_secret}",
"Content-Type": "application/json",
"Notion-Version": "2022-06-28",
}
data = {
"sorts": sorts,
}
if filter_obj:
data["filter"] = filter_obj
response = requests.post(url, headers=headers, json=data)
response.raise_for_status()
results = response.json()
output = f"Pages found: {len(results['results'])}\n\n"
for page in results["results"]:
output += f"Page ID: {page['id']}\n"
output += f"Page URL: {page['url']}\n"
output += f"Created At: {page['created_time']}\n"
output += f"Updated At: {page['last_edited_time']}\n"
output += f"Properties: {json.dumps(page['properties'], indent=2)}\n\n"
return output
except Exception as e:
return f"An error occurred: {str(e)}"
```
## Example Usage
Here's an example of how you can use the `NotionDatabaseQuery` component in a Langflow flow and passing to the Prompt component:
<ZoomableImage
alt="NotionDatabaseQuery Flow Example"
sources={{
light: "img/notion/NotionDatabaseQuery_flow_example.png",
dark: "img/notion/NotionDatabaseQuery_flow_example_dark.png",
}}
style={{ width: "100%", margin: "20px 0" }}
/>
In this example, the `NotionDatabaseQuery` component is used to retrieve specific pages from a Notion database based on the provided filters and sorting options. The retrieved data can then be processed further in the subsequent components of the flow.
## Best Practices
> **Tip**:
>
> ### Best Practices
>
> When using the `NotionDatabaseQuery` component, consider the following best practices:
>
> - Ensure that you have a valid Notion integration token with the necessary permissions to query the desired database.
> - Construct the `query_payload` JSON string carefully, following the Notion API documentation for filtering and sorting options.
## Troubleshooting
> **Warning**:
>
> ### Troubleshooting
>
> If you encounter any issues while using the `NotionDatabaseQuery` component, consider the following:
>
> - Double-check that the `notion_secret` and `database_id` are correct and valid.
> - Verify that the `query_payload` JSON string is properly formatted and contains valid filtering and sorting options.
> - Check the Notion API documentation for any updates or changes that may affect the component's functionality.
The `NotionDatabaseQuery` component provides a powerful way to integrate Notion database querying capabilities into your Langflow workflows. By leveraging this component, you can easily retrieve specific pages from a Notion database based on custom filters and sorting options, enabling you to build more dynamic and data-driven flows.
We encourage you to explore the capabilities of the `NotionDatabaseQuery` component further and experiment with different querying scenarios to unlock the full potential of integrating Notion databases into your Langflow workflows.

Binary file not shown.

After

Width:  |  Height:  |  Size: 62 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 61 KiB