hubspot by membranedev/application-skills
npx skills add https://github.com/membranedev/application-skills --skill hubspotHubSpot 是一款 CRM 和营销自动化平台,可帮助企业管理工作中的销售、营销和客户服务工作。营销和销售团队使用它来吸引潜在客户、将其培育成客户并提供客户支持。
官方文档:https://developers.hubspot.com/
根据需要使用操作名称和参数。
此技能使用 Membrane CLI 与 HubSpot 交互。Membrane 会自动处理身份验证和凭证刷新——因此您可以专注于集成逻辑,而不是身份验证的底层实现。
安装 Membrane CLI,以便您可以从终端运行 membrane 命令:
npm install -g @membranehq/cli
membrane login --tenant
浏览器窗口将打开以进行身份验证。
无头环境: 运行该命令,复制打印出的 URL 供用户在浏览器中打开,然后使用 membrane login complete <code> 完成验证。
广告位招租
在这里展示您的产品或服务
触达数万 AI 开发者,精准高效
创建新连接:
membrane search hubspot --elementType=connector --json
从 output.items[0].element?.id 获取连接器 ID,然后:
membrane connect --connectorId=CONNECTOR_ID --json
用户在浏览器中完成身份验证。输出包含新的连接 ID。
当您不确定连接是否已存在时:
检查现有连接:
membrane connection list --json
如果存在 HubSpot 连接,请记下其 connectionId。
当您知道要做什么但不知道确切的操作 ID 时:
membrane action list --intent=QUERY --connectionId=CONNECTION_ID --json
这将返回包含 id 和 inputSchema 的操作对象,以便您知道如何运行它。
| 名称 | 键 | 描述 |
|---|---|---|
| 列出联系人 | list-contacts | 从 HubSpot 检索联系人列表,可按属性和关联进行可选筛选。 |
| 列出公司 | list-companies | 从 HubSpot 检索公司列表,可按属性和关联进行可选筛选。 |
| 列出交易 | list-deals | 从 HubSpot 检索交易列表,可按属性和关联进行可选筛选。 |
| 列出工单 | list-tickets | 从 HubSpot 检索工单列表,可进行可选筛选。 |
| 列出任务 | list-tasks | 列出所有任务,支持可选筛选和分页 |
| 列出备注 | list-notes | 列出所有备注,支持可选筛选和分页 |
| 获取联系人 | get-contact | 通过 ID 或电子邮件从 HubSpot 检索单个联系人。 |
| 获取公司 | get-company | 通过 ID 从 HubSpot 检索单个公司。 |
| 获取交易 | get-deal | 通过 ID 从 HubSpot 检索单个交易。 |
| 获取工单 | get-ticket | 通过 ID 从 HubSpot 检索单个工单。 |
| 获取任务 | get-task | 通过 ID 获取任务 |
| 获取备注 | get-note | 通过 ID 获取备注 |
| 创建联系人 | create-contact | 在 HubSpot 中创建具有指定属性和可选关联的新联系人。 |
| 创建公司 | create-company | 在 HubSpot 中创建具有指定属性和可选关联的新公司。 |
| 创建交易 | create-deal | 在 HubSpot 中创建具有指定属性和可选关联的新交易。 |
| 创建工单 | create-ticket | 在 HubSpot 中创建具有指定属性的新工单。 |
| 创建任务 | create-task | 在 HubSpot 中创建新任务 |
| 创建备注 | create-note | 在 HubSpot 中创建新备注 |
| 更新联系人 | update-contact | 在 HubSpot 中更新现有联系人的属性。 |
| 更新公司 | update-company | 在 HubSpot 中更新现有公司的属性。 |
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json
传递 JSON 参数:
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json --input "{ \"key\": \"value\" }"
当可用操作无法满足您的用例时,您可以通过 Membrane 的代理直接向 HubSpot API 发送请求。Membrane 会自动将您提供的路径附加到基础 URL,并注入正确的身份验证头——如果凭证过期,还会透明地刷新凭证。
membrane request CONNECTION_ID /path/to/endpoint
常用选项:
| 标志 | 描述 |
|---|---|
-X, --method | HTTP 方法(GET、POST、PUT、PATCH、DELETE)。默认为 GET |
-H, --header | 添加请求头(可重复),例如 -H "Accept: application/json" |
-d, --data | 请求体(字符串) |
--json | 发送 JSON 请求体并设置 Content-Type: application/json 的简写 |
--rawData | 按原样发送请求体,不做任何处理 |
--query | 查询字符串参数(可重复),例如 --query "limit=10" |
--pathParam | 路径参数(可重复),例如 --pathParam "id=123" |
membrane action list --intent=QUERY(将 QUERY 替换为您的意图)以查找现有操作。预构建的操作处理了原始 API 调用可能遗漏的分页、字段映射和边缘情况。每周安装数
404
代码仓库
GitHub 星标数
18
首次出现
13 天前
安全审计
已安装于
opencode404
gemini-cli404
github-copilot404
codex404
kimi-cli404
amp404
HubSpot is a CRM and marketing automation platform that helps businesses manage their sales, marketing, and customer service efforts. It's used by marketing and sales teams to attract leads, nurture them into customers, and provide customer support.
Official docs: https://developers.hubspot.com/
Use action names and parameters as needed.
This skill uses the Membrane CLI to interact with HubSpot. Membrane handles authentication and credentials refresh automatically — so you can focus on the integration logic rather than auth plumbing.
Install the Membrane CLI so you can run membrane from the terminal:
npm install -g @membranehq/cli
membrane login --tenant
A browser window opens for authentication.
Headless environments: Run the command, copy the printed URL for the user to open in a browser, then complete with membrane login complete <code>.
Create a new connection:
membrane search hubspot --elementType=connector --json
Take the connector ID from output.items[0].element?.id, then:
membrane connect --connectorId=CONNECTOR_ID --json
The user completes authentication in the browser. The output contains the new connection id.
When you are not sure if connection already exists:
Check existing connections:
membrane connection list --json
If a HubSpot connection exists, note its connectionId
When you know what you want to do but not the exact action ID:
membrane action list --intent=QUERY --connectionId=CONNECTION_ID --json
This will return action objects with id and inputSchema in it, so you will know how to run it.
| Name | Key | Description |
|---|---|---|
| List Contacts | list-contacts | Retrieve a list of contacts from HubSpot with optional filtering by properties and associations. |
| List Companies | list-companies | Retrieve a list of companies from HubSpot with optional filtering by properties and associations. |
| List Deals | list-deals | Retrieve a list of deals from HubSpot with optional filtering by properties and associations. |
| List Tickets | list-tickets | Retrieve a list of tickets from HubSpot with optional filtering. |
| List Tasks | list-tasks | List all tasks with optional filtering and pagination |
| List Notes | list-notes | List all notes with optional filtering and pagination |
| Get Contact | get-contact | Retrieve a single contact by ID or email from HubSpot. |
| Get Company | get-company | Retrieve a single company by ID from HubSpot. |
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json
To pass JSON parameters:
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json --input "{ \"key\": \"value\" }"
When the available actions don't cover your use case, you can send requests directly to the HubSpot API through Membrane's proxy. Membrane automatically appends the base URL to the path you provide and injects the correct authentication headers — including transparent credential refresh if they expire.
membrane request CONNECTION_ID /path/to/endpoint
Common options:
| Flag | Description |
|---|---|
-X, --method | HTTP method (GET, POST, PUT, PATCH, DELETE). Defaults to GET |
-H, --header | Add a request header (repeatable), e.g. -H "Accept: application/json" |
-d, --data | Request body (string) |
--json | Shorthand to send a JSON body and set Content-Type: application/json |
--rawData |
membrane action list --intent=QUERY (replace QUERY with your intent) to find existing actions before writing custom API calls. Pre-built actions handle pagination, field mapping, and edge cases that raw API calls miss.Weekly Installs
404
Repository
GitHub Stars
18
First Seen
13 days ago
Security Audits
Gen Agent Trust HubPassSocketPassSnykPass
Installed on
opencode404
gemini-cli404
github-copilot404
codex404
kimi-cli404
amp404
内容策略指南:如何规划可搜索与可分享内容,驱动流量与潜在客户
32,800 周安装
| Get Deal | get-deal | Retrieve a single deal by ID from HubSpot. |
| Get Ticket | get-ticket | Retrieve a single ticket by ID from HubSpot. |
| Get Task | get-task | Get a task by its ID |
| Get Note | get-note | Get a note by its ID |
| Create Contact | create-contact | Create a new contact in HubSpot with specified properties and optional associations. |
| Create Company | create-company | Create a new company in HubSpot with specified properties and optional associations. |
| Create Deal | create-deal | Create a new deal in HubSpot with specified properties and optional associations. |
| Create Ticket | create-ticket | Create a new ticket in HubSpot with specified properties. |
| Create Task | create-task | Create a new task in HubSpot |
| Create Note | create-note | Create a new note in HubSpot |
| Update Contact | update-contact | Update an existing contact's properties in HubSpot. |
| Update Company | update-company | Update an existing company's properties in HubSpot. |
| Send the body as-is without any processing |
--query | Query-string parameter (repeatable), e.g. --query "limit=10" |
--pathParam | Path parameter (repeatable), e.g. --pathParam "id=123" |