skills$openclaw/clickup
byungkyu4.3k

by byungkyu

clickup – OpenClaw Skill

clickup is an OpenClaw Skills integration for coding workflows. |

4.3k stars1.7k forksSecurity L1
Updated Feb 7, 2026Created Feb 7, 2026coding

Skill Snapshot

nameclickup
description| OpenClaw Skills integration.
ownerbyungkyu
repositorybyungkyu/clickup-api
languageMarkdown
licenseMIT
topics
securityL1
installopenclaw add @byungkyu/clickup-api
last updatedFeb 7, 2026

Maintainer

byungkyu

byungkyu

Maintains clickup in the OpenClaw Skills directory.

View GitHub profile
File Explorer
3 files
.
_meta.json
272 B
LICENSE.txt
1.0 KB
SKILL.md
15.2 KB
SKILL.md

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

  1. Sign in or create an account at maton.ai
  2. Go to maton.ai/settings
  3. 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) → SpaceFolderListTask

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 status
  • include_closed - Include closed tasks (true/false)
  • assignees[] - Filter by assignee IDs
  • due_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_ids
  • include_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 title
  • description - Task description (supports markdown)
  • assignees - Array of user IDs
  • status - 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 milliseconds
  • due_date_time - Include time in due date (true/false)
  • start_date - Unix timestamp in milliseconds
  • time_estimate - Time estimate in milliseconds
  • tags - Array of tag names
  • parent - 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 field
  • statuses[] - Filter by statuses
  • assignees[] - Filter by assignees
  • list_ids[] - Filter by list IDs
  • space_ids[] - Filter by space IDs
  • folder_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, taskDeleted
  • taskPriorityUpdated, taskStatusUpdated
  • taskAssigneeUpdated, taskDueDateUpdated
  • taskTagUpdated, taskMoved
  • taskCommentPosted, taskCommentUpdated
  • taskTimeEstimateUpdated, taskTimeTrackedUpdated
  • listCreated, listUpdated, listDeleted
  • folderCreated, folderUpdated, folderDeleted
  • spaceCreated, spaceUpdated, spaceDeleted
  • goalCreated, goalUpdated, goalDeleted
  • keyResultCreated, 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

StatusMeaning
400Bad request or missing ClickUp connection
401Invalid or missing Maton API key
403Forbidden - insufficient permissions
404Resource not found
429Rate limited
4xx/5xxPassthrough error from ClickUp API

Resources

README.md

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.