4.3k★by byungkyu
clickup – OpenClaw Skill
clickup is an OpenClaw Skills integration for coding workflows. |
Skill Snapshot
| name | clickup |
| description | | OpenClaw Skills integration. |
| owner | byungkyu |
| repository | byungkyu/clickup-api |
| language | Markdown |
| license | MIT |
| topics | |
| security | L1 |
| install | openclaw add @byungkyu/clickup-api |
| last updated | Feb 7, 2026 |
Maintainer

name: clickup description: | ClickUp API integration with managed OAuth. Access tasks, lists, folders, spaces, workspaces, users, and manage webhooks. Use this skill when users want to manage work items, track projects, or integrate with ClickUp workflows. compatibility: Requires network access and valid Maton API key metadata: author: maton version: "1.0"
ClickUp
Access the ClickUp API with managed OAuth authentication. Manage tasks, lists, folders, spaces, workspaces, users, and webhooks for work management.
Quick Start
# List workspaces (teams)
curl -s -X GET 'https://gateway.maton.ai/clickup/api/v2/team' \
-H 'Authorization: Bearer YOUR_API_KEY'
Base URL
https://gateway.maton.ai/clickup/{native-api-path}
Replace {native-api-path} with the actual ClickUp API endpoint path. The gateway proxies requests to api.clickup.com and automatically injects your OAuth token.
Authentication
All requests require the Maton API key in the Authorization header:
Authorization: Bearer YOUR_API_KEY
Environment Variable: Set your API key as MATON_API_KEY:
export MATON_API_KEY="YOUR_API_KEY"
Getting Your API Key
- Sign in or create an account at maton.ai
- Go to maton.ai/settings
- Copy your API key
Connection Management
Manage your ClickUp OAuth connections at https://ctrl.maton.ai.
List Connections
curl -s -X GET 'https://ctrl.maton.ai/connections?app=clickup&status=ACTIVE' \
-H 'Authorization: Bearer YOUR_API_KEY'
Create Connection
curl -s -X POST 'https://ctrl.maton.ai/connections' \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer YOUR_API_KEY' \
-d '{"app": "clickup"}'
Get Connection
curl -s -X GET 'https://ctrl.maton.ai/connections/{connection_id}' \
-H 'Authorization: Bearer YOUR_API_KEY'
Response:
{
"connection": {
"connection_id": "21fd90f9-5935-43cd-b6c8-bde9d915ca80",
"status": "ACTIVE",
"creation_time": "2025-12-08T07:20:53.488460Z",
"last_updated_time": "2026-01-31T20:03:32.593153Z",
"url": "https://connect.maton.ai/?session_token=...",
"app": "clickup",
"metadata": {}
}
}
Open the returned url in a browser to complete OAuth authorization.
Delete Connection
curl -s -X DELETE 'https://ctrl.maton.ai/connections/{connection_id}' \
-H 'Authorization: Bearer YOUR_API_KEY'
Specifying Connection
If you have multiple ClickUp connections, specify which one to use with the Maton-Connection header:
curl -s -X GET 'https://gateway.maton.ai/clickup/api/v2/team' \
-H 'Authorization: Bearer YOUR_API_KEY' \
-H 'Maton-Connection: 21fd90f9-5935-43cd-b6c8-bde9d915ca80'
If omitted, the gateway uses the default (oldest) active connection.
ClickUp Hierarchy
ClickUp organizes data in a hierarchy:
- Workspace (team) → Space → Folder → List → Task
Note: In the API, Workspaces are referred to as "teams".
API Reference
Workspaces (Teams)
Get Authorized Workspaces
GET /clickup/api/v2/team
Example:
curl -s -X GET 'https://gateway.maton.ai/clickup/api/v2/team' \
-H 'Authorization: Bearer YOUR_API_KEY'
Response:
{
"teams": [
{
"id": "1234567",
"name": "Acme Corp",
"color": "#7B68EE",
"avatar": null,
"members": [
{
"user": {
"id": 123,
"username": "Alice Johnson",
"email": "alice@acme.com"
}
}
]
}
]
}
Spaces
Get Spaces
GET /clickup/api/v2/team/{team_id}/space
Query parameters:
archived- Include archived spaces (true/false)
Example:
curl -s -X GET 'https://gateway.maton.ai/clickup/api/v2/team/1234567/space' \
-H 'Authorization: Bearer YOUR_API_KEY'
Response:
{
"spaces": [
{
"id": "90120001",
"name": "Engineering",
"private": false,
"statuses": [
{"status": "to do", "type": "open"},
{"status": "in progress", "type": "custom"},
{"status": "done", "type": "closed"}
]
}
]
}
Get a Space
GET /clickup/api/v2/space/{space_id}
Create a Space
POST /clickup/api/v2/team/{team_id}/space
Example:
curl -s -X POST 'https://gateway.maton.ai/clickup/api/v2/team/1234567/space' \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer YOUR_API_KEY' \
-d '{
"name": "New Space",
"multiple_assignees": true,
"features": {
"due_dates": {"enabled": true},
"time_tracking": {"enabled": true}
}
}'
Update a Space
PUT /clickup/api/v2/space/{space_id}
Delete a Space
DELETE /clickup/api/v2/space/{space_id}
Folders
Get Folders
GET /clickup/api/v2/space/{space_id}/folder
Query parameters:
archived- Include archived folders (true/false)
Example:
curl -s -X GET 'https://gateway.maton.ai/clickup/api/v2/space/90120001/folder' \
-H 'Authorization: Bearer YOUR_API_KEY'
Response:
{
"folders": [
{
"id": "456789",
"name": "Sprint 1",
"orderindex": 0,
"hidden": false,
"space": {"id": "90120001", "name": "Engineering"},
"task_count": "12",
"lists": []
}
]
}
Get a Folder
GET /clickup/api/v2/folder/{folder_id}
Create a Folder
POST /clickup/api/v2/space/{space_id}/folder
Example:
curl -s -X POST 'https://gateway.maton.ai/clickup/api/v2/space/90120001/folder' \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer YOUR_API_KEY' \
-d '{"name": "New Folder"}'
Update a Folder
PUT /clickup/api/v2/folder/{folder_id}
Delete a Folder
DELETE /clickup/api/v2/folder/{folder_id}
Lists
Get Lists
GET /clickup/api/v2/folder/{folder_id}/list
Query parameters:
archived- Include archived lists (true/false)
Example:
curl -s -X GET 'https://gateway.maton.ai/clickup/api/v2/folder/456789/list' \
-H 'Authorization: Bearer YOUR_API_KEY'
Response:
{
"lists": [
{
"id": "901234",
"name": "Backlog",
"orderindex": 0,
"status": {"status": "active", "color": "#87909e"},
"task_count": 25,
"folder": {"id": "456789", "name": "Sprint 1"}
}
]
}
Get Folderless Lists
GET /clickup/api/v2/space/{space_id}/list
Get a List
GET /clickup/api/v2/list/{list_id}
Create a List
POST /clickup/api/v2/folder/{folder_id}/list
Example:
curl -s -X POST 'https://gateway.maton.ai/clickup/api/v2/folder/456789/list' \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer YOUR_API_KEY' \
-d '{"name": "New List"}'
Create Folderless List
POST /clickup/api/v2/space/{space_id}/list
Update a List
PUT /clickup/api/v2/list/{list_id}
Delete a List
DELETE /clickup/api/v2/list/{list_id}
Tasks
Get Tasks
GET /clickup/api/v2/list/{list_id}/task
Query parameters:
archived- Include archived tasks (true/false)page- Page number (0-indexed)order_by- Sort by field (created, updated, due_date)reverse- Reverse sort order (true/false)subtasks- Include subtasks (true/false)statuses[]- Filter by statusinclude_closed- Include closed tasks (true/false)assignees[]- Filter by assignee IDsdue_date_gt- Due date greater than (Unix ms)due_date_lt- Due date less than (Unix ms)
Example:
curl -s -X GET 'https://gateway.maton.ai/clickup/api/v2/list/901234/task?include_closed=true' \
-H 'Authorization: Bearer YOUR_API_KEY'
Response:
{
"tasks": [
{
"id": "abc123",
"name": "Implement login feature",
"status": {"status": "in progress", "type": "custom", "color": "#4194f6"},
"priority": {"id": "2", "priority": "high", "color": "#f9d900"},
"due_date": "1709251200000",
"assignees": [{"id": 123, "username": "Alice Johnson", "email": "alice@acme.com"}],
"description": "Add OAuth login flow",
"date_created": "1707436800000",
"date_updated": "1708646400000"
}
]
}
Get a Task
GET /clickup/api/v2/task/{task_id}
Query parameters:
custom_task_ids- Use custom task IDs (true/false)team_id- Required when using custom_task_idsinclude_subtasks- Include subtasks (true/false)
Example:
curl -s -X GET 'https://gateway.maton.ai/clickup/api/v2/task/abc123' \
-H 'Authorization: Bearer YOUR_API_KEY'
Create a Task
POST /clickup/api/v2/list/{list_id}/task
Content-Type: application/json
{
"name": "Task name",
"description": "Task description",
"assignees": [123],
"status": "to do",
"priority": 2,
"due_date": 1709251200000,
"tags": ["api", "backend"],
"parent": null
}
Fields:
name(required) - Task titledescription- Task description (supports markdown)assignees- Array of user IDsstatus- Status name (must match a status in the list)priority- Priority level (1=urgent, 2=high, 3=normal, 4=low, null=none)due_date- Unix timestamp in millisecondsdue_date_time- Include time in due date (true/false)start_date- Unix timestamp in millisecondstime_estimate- Time estimate in millisecondstags- Array of tag namesparent- Parent task ID (for subtasks)custom_fields- Array of custom field objects
Example:
curl -s -X POST 'https://gateway.maton.ai/clickup/api/v2/list/901234/task' \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer YOUR_API_KEY' \
-d '{
"name": "Complete API integration",
"description": "Integrate with the new payment API",
"priority": 2,
"due_date": 1709251200000,
"assignees": [123]
}'
Update a Task
PUT /clickup/api/v2/task/{task_id}
Example:
curl -s -X PUT 'https://gateway.maton.ai/clickup/api/v2/task/abc123' \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer YOUR_API_KEY' \
-d '{
"status": "complete",
"priority": null
}'
Delete a Task
DELETE /clickup/api/v2/task/{task_id}
Get Filtered Team Tasks
GET /clickup/api/v2/team/{team_id}/task
Query parameters:
page- Page number (0-indexed)order_by- Sort fieldstatuses[]- Filter by statusesassignees[]- Filter by assigneeslist_ids[]- Filter by list IDsspace_ids[]- Filter by space IDsfolder_ids[]- Filter by folder IDs
Users
Get Current User
GET /clickup/api/v2/user
Example:
curl -s -X GET 'https://gateway.maton.ai/clickup/api/v2/user' \
-H 'Authorization: Bearer YOUR_API_KEY'
Response:
{
"user": {
"id": 123,
"username": "Alice Johnson",
"email": "alice@acme.com",
"color": "#7B68EE",
"profilePicture": "https://...",
"initials": "AJ",
"week_start_day": 0,
"timezone": "America/New_York"
}
}
Webhooks
Get Webhooks
GET /clickup/api/v2/team/{team_id}/webhook
Example:
curl -s -X GET 'https://gateway.maton.ai/clickup/api/v2/team/1234567/webhook' \
-H 'Authorization: Bearer YOUR_API_KEY'
Create Webhook
POST /clickup/api/v2/team/{team_id}/webhook
Content-Type: application/json
{
"endpoint": "https://example.com/webhook",
"events": ["taskCreated", "taskUpdated", "taskDeleted"],
"space_id": "90120001",
"folder_id": "456789",
"list_id": "901234",
"task_id": "abc123"
}
Events:
taskCreated,taskUpdated,taskDeletedtaskPriorityUpdated,taskStatusUpdatedtaskAssigneeUpdated,taskDueDateUpdatedtaskTagUpdated,taskMovedtaskCommentPosted,taskCommentUpdatedtaskTimeEstimateUpdated,taskTimeTrackedUpdatedlistCreated,listUpdated,listDeletedfolderCreated,folderUpdated,folderDeletedspaceCreated,spaceUpdated,spaceDeletedgoalCreated,goalUpdated,goalDeletedkeyResultCreated,keyResultUpdated,keyResultDeleted
Example:
curl -s -X POST 'https://gateway.maton.ai/clickup/api/v2/team/1234567/webhook' \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer YOUR_API_KEY' \
-d '{
"endpoint": "https://example.com/webhook",
"events": ["taskCreated", "taskUpdated"]
}'
Response:
{
"id": "webhook123",
"webhook": {
"id": "webhook123",
"userid": 123,
"team_id": "1234567",
"endpoint": "https://example.com/webhook",
"client_id": "...",
"events": ["taskCreated", "taskUpdated"],
"health": {"status": "active", "fail_count": 0},
"secret": "..."
}
}
Update a Webhook
PUT /clickup/api/v2/webhook/{webhook_id}
Delete a Webhook
DELETE /clickup/api/v2/webhook/{webhook_id}
Pagination
ClickUp uses page-based pagination. Use the page parameter (0-indexed):
curl -s -X GET 'https://gateway.maton.ai/clickup/api/v2/list/901234/task?page=0' \
-H 'Authorization: Bearer YOUR_API_KEY'
Responses are limited to 100 tasks per page. The response includes a last_page boolean field. Continue incrementing the page number until last_page is true.
Code Examples
JavaScript
const response = await fetch(
'https://gateway.maton.ai/clickup/api/v2/list/901234/task',
{
headers: {
'Authorization': `Bearer ${process.env.MATON_API_KEY}`
}
}
);
const data = await response.json();
Python
import os
import requests
response = requests.get(
'https://gateway.maton.ai/clickup/api/v2/list/901234/task',
headers={'Authorization': f'Bearer {os.environ["MATON_API_KEY"]}'}
)
data = response.json()
Notes
- Task IDs are strings
- Timestamps are Unix milliseconds
- Priority values: 1=urgent, 2=high, 3=normal, 4=low, null=none
- Workspaces are called "teams" in the API
- Status values must match the exact status names configured in the list
- Responses are limited to 100 items per page
Error Handling
| Status | Meaning |
|---|---|
| 400 | Bad request or missing ClickUp connection |
| 401 | Invalid or missing Maton API key |
| 403 | Forbidden - insufficient permissions |
| 404 | Resource not found |
| 429 | Rate limited |
| 4xx/5xx | Passthrough error from ClickUp API |
Resources
No README available.
Permissions & Security
Security level L1: Low-risk skills with minimal permissions. Review inputs and outputs before running in production.
Requirements
- OpenClaw CLI installed and configured.
- Language: Markdown
- License: MIT
- Topics:
FAQ
How do I install clickup?
Run openclaw add @byungkyu/clickup-api in your terminal. This installs clickup into your OpenClaw Skills catalog.
Does this skill run locally or in the cloud?
OpenClaw Skills execute locally by default. Review the SKILL.md and permissions before running any skill.
Where can I verify the source code?
The source repository is available at https://github.com/openclaw/skills/tree/main/skills/byungkyu/clickup-api. Review commits and README documentation before installing.
