Spaces:
Runtime error
Runtime error
Commit
·
49f4f70
1
Parent(s):
85378b4
Add CreateTaskTool for creating tasks in Notion database with specified properties
Browse files
agency_ai_demo/agents/NotionProjectAgent/tools/CreateTask.py
ADDED
@@ -0,0 +1,126 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import os
|
2 |
+
from dotenv import load_dotenv
|
3 |
+
from agency_swarm.tools import BaseTool
|
4 |
+
from pydantic import Field
|
5 |
+
from typing import Dict, List, Optional, Any, Union
|
6 |
+
|
7 |
+
load_dotenv()
|
8 |
+
|
9 |
+
notion_integration_secret = os.getenv("NOTION_INTEGRATION_SECRET")
|
10 |
+
notion_database_id = os.getenv("NOTION_DATABASE_ID")
|
11 |
+
|
12 |
+
|
13 |
+
class CreateTaskTool(BaseTool):
|
14 |
+
"""
|
15 |
+
Tool for creating a new task (page) in a Notion database.
|
16 |
+
This tool creates a new page with specified properties and optionally
|
17 |
+
adds content blocks to the page.
|
18 |
+
"""
|
19 |
+
|
20 |
+
# Add example_field with a default value to satisfy BaseTool validation
|
21 |
+
example_field: str = Field(
|
22 |
+
default="notion_create_task",
|
23 |
+
description="Identifier for this tool. Can be left at its default value.",
|
24 |
+
)
|
25 |
+
|
26 |
+
title: str = Field(
|
27 |
+
...,
|
28 |
+
description="The title of the task (required).",
|
29 |
+
)
|
30 |
+
|
31 |
+
status: str = Field(
|
32 |
+
default=None,
|
33 |
+
description="Status of the task. Options: Backlog, In Progress, In Review, Testing, Completed.",
|
34 |
+
)
|
35 |
+
|
36 |
+
priority: str = Field(
|
37 |
+
default=None,
|
38 |
+
description="Priority of the task. Options: High, Medium, Low.",
|
39 |
+
)
|
40 |
+
|
41 |
+
due_date: str = Field(
|
42 |
+
default=None,
|
43 |
+
description="Due date of the task in YYYY-MM-DD format.",
|
44 |
+
)
|
45 |
+
|
46 |
+
assigned_to: List[str] = Field(
|
47 |
+
default=None,
|
48 |
+
description="List of user IDs to assign the task to.",
|
49 |
+
)
|
50 |
+
|
51 |
+
content_blocks: List[Dict[str, Any]] = Field(
|
52 |
+
default=None,
|
53 |
+
description="List of content blocks to add to the page. See Notion API Block documentation for format.",
|
54 |
+
)
|
55 |
+
|
56 |
+
def run(self):
|
57 |
+
"""
|
58 |
+
Create a new task (page) in a Notion database with the specified properties and content.
|
59 |
+
|
60 |
+
Returns:
|
61 |
+
dict: The JSON response from the Notion API containing the created page.
|
62 |
+
"""
|
63 |
+
import requests
|
64 |
+
|
65 |
+
# Use the database ID from the parameter or environment variable
|
66 |
+
database_id = os.getenv("NOTION_DATABASE_ID")
|
67 |
+
|
68 |
+
# Set up the API endpoint
|
69 |
+
url = "https://api.notion.com/v1/pages"
|
70 |
+
|
71 |
+
# Set up the headers
|
72 |
+
headers = {
|
73 |
+
"Authorization": f"Bearer {os.getenv('NOTION_INTEGRATION_SECRET')}",
|
74 |
+
"Notion-Version": "2022-06-28",
|
75 |
+
"Content-Type": "application/json",
|
76 |
+
}
|
77 |
+
|
78 |
+
# Prepare the request body
|
79 |
+
data = {
|
80 |
+
"parent": {"type": "database_id", "database_id": database_id},
|
81 |
+
"properties": self._build_properties(),
|
82 |
+
}
|
83 |
+
|
84 |
+
# Add children blocks if provided
|
85 |
+
if self.content_blocks:
|
86 |
+
data["children"] = self.content_blocks
|
87 |
+
|
88 |
+
# Make the request
|
89 |
+
response = requests.post(url, headers=headers, json=data)
|
90 |
+
|
91 |
+
# Return the JSON response
|
92 |
+
return response.json()
|
93 |
+
|
94 |
+
def _build_properties(self) -> Dict[str, Any]:
|
95 |
+
"""
|
96 |
+
Build the properties object based on provided parameters.
|
97 |
+
|
98 |
+
Returns:
|
99 |
+
dict: A dictionary containing the page properties in Notion API format.
|
100 |
+
"""
|
101 |
+
properties = {}
|
102 |
+
|
103 |
+
# Title is required
|
104 |
+
properties["Task Name"] = {
|
105 |
+
"title": [{"type": "text", "text": {"content": self.title}}]
|
106 |
+
}
|
107 |
+
|
108 |
+
# Add status if provided
|
109 |
+
if self.status:
|
110 |
+
properties["Status"] = {"status": {"name": self.status}}
|
111 |
+
|
112 |
+
# Add priority if provided
|
113 |
+
if self.priority:
|
114 |
+
properties["Priority"] = {"select": {"name": self.priority}}
|
115 |
+
|
116 |
+
# Add due date if provided
|
117 |
+
if self.due_date:
|
118 |
+
properties["Due Date"] = {"date": {"start": self.due_date}}
|
119 |
+
|
120 |
+
# Add assigned people if provided
|
121 |
+
if self.assigned_to:
|
122 |
+
properties["Assigned to"] = {
|
123 |
+
"people": [{"id": user_id} for user_id in self.assigned_to]
|
124 |
+
}
|
125 |
+
|
126 |
+
return properties
|