{"skill":{"slug":"maxhub-threads","displayName":"Maxhub Threads","summary":"Threads 公开社交内容查询与用户分析 skill，通过 MaxHub API 查询帖子、用户资料、评论、搜索、时间线和相关互动数据。适合海外社媒内容研究、账号画像、话题追踪和互动分析。默认 read-only；agent 应从 recipes 匹配用户意图，按 post_id/user_id/keyword...","description":"---\nname: maxhub-threads\ndescription: Threads 公开社交内容查询与用户分析 skill，通过 MaxHub API 查询帖子、用户资料、评论、搜索、时间线和相关互动数据。适合海外社媒内容研究、账号画像、话题追踪和互动分析。默认 read-only；agent 应从 recipes 匹配用户意图，按 post_id/user_id/keyword 等字段流链式调用，并避免过度采集个人社交数据。所有请求发送到 https://www.aconfig.cn。\nlicense: MIT-0\nmetadata:\n  author: maxhub\n  version: 3.8.0\n  openclaw:\n    capability: read_only\n    requires_confirmation:\n    - non_idempotent\n    - cookie_input\n    emoji: 🧵\n    primaryEnv: MAXHUB_API_KEY\n    requires:\n      env:\n      - MAXHUB_API_KEY\n      bins:\n      - curl\n    env:\n    - name: MAXHUB_API_KEY\n      description: API key for MaxHub data APIs. Get one at https://www.aconfig.cn\n      required: true\n      sensitive: true\n    network:\n    - https://www.aconfig.cn\n    riskLevel: low\n    defaultMode: recipes_first_read_only\n    skillClass: maxhub-api-skill\n    platform: threads\n    authType: bearer_env\n    dataSource: MaxHub API via https://www.aconfig.cn\n    agentUse:\n      entrypoint: SKILL.md §4 Agent Decision Tree\n      intentIndex: references/recipes/_index.md\n      chainDetails: references/recipes/<domain>.md\n      fieldFlow: references/param-mappings.md\n      endpointWhitelist: references/endpoints_whitelist.yaml\n      selectionPolicy: recipes_first_then_atoms; longest_trigger_match; ask_on_tie\n      parameterPolicy: use recipe extract/in_map and field-flow dictionary; never invent path or parameters\n    privacy:\n      thirdParty: https://www.aconfig.cn\n      transmits:\n      - MAXHUB_API_KEY\n      - user_supplied_ids\n      - keywords\n      - urls\n      - optional_cookies_or_tokens\n      guidance: Use only for authorized data processing; minimize personal data; do not expose secrets in logs or prompts.\n  hermes:\n    tags:\n    - threads\n    - 帖子\n    - 评论\n    - 用户资料\n    - 时间线\n    - 搜索\n    - 社交媒体\n    category: data-analysis\n    intents:\n    - query\n    - analyze\n    - search\n    - chain\n    - report\n    locale:\n    - zh-CN\n    - en\n---\n\n# Threads 数据助手\n\n## 1. 简介\n\nThreads 数据查询工具，通过 MaxHub API 接入 Meta 旗下文字社交平台 Threads，覆盖帖子详情、评论、用户资料、用户帖子 / 转发 / 回复列表、Top / Recent 搜索、个人主页搜索等核心能力。专注服务于 Threads 内容研究、Meta 社交监控、海外内容创作与跨平台舆情场景，帮助用户快速采集 Threads 数据、识别热门话题与意见领袖，构建 Meta 生态的内容情报。\n\n## 2. 详细功能\n\n### 帖子查询\n\n- 通过帖子 ID 直查帖子详情，含正文、媒体、作者归属与互动量级\n- 支持以原始帖子 URL 直接换取详情，免去先做链接解析的繁琐步骤\n- 拉取帖子的完整作者上下文，定位发布者身份并衔接后续用户画像查询\n\n### 评论追踪\n\n- 拉取帖子下的一级评论列表，还原最直观的讨论氛围与高赞观点\n- 评论结果与帖子主键无缝接力，可以串联到任意上游入口（搜索、用户、URL）\n- 适配整段对话上下文采集，作为情感与共鸣分析的真实样本\n\n### 用户洞察\n\n- 同时支持通过用户名与稳定用户标识两种方式查询用户资料，兼容不同入口\n- 拉取用户对外发布的原创帖子列表，识别其内容主题与发布节奏\n- 拉取用户的转发与回复列表，全面观察其圈层互动与对其他声音的态度\n\n### 搜索三件套\n\n- 按关键词查询热门排序的帖子结果，快速捕捉话题已沉淀下来的代表性内容\n- 按关键词查询最新排序的帖子结果，跟进话题正在发生的最实时进展\n- 按关键词搜索人物档案，精准定位目标用户、KOL 或品牌官方账号\n\n### 游标分页统一\n\n- 全量列表类查询采用统一的游标翻页机制，多次翻页无需切换不同的分页策略\n- 翻页参数与上一页返回结果直接衔接，链路稳定不易踩到边界异常\n- 支持长程持续采集任务，避免在大批量数据回流时丢页或重复\n\n> ### 📋 数据传输与隐私声明（请认真阅读）\n>\n> 1. **第三方传输**：您提供的所有 ID、关键词、链接、cookie 等参数都会通过 HTTPS 发送到 **`https://www.aconfig.cn`**（MaxHub 数据服务）进行处理。\n> 2. **UGC 隐私**：拉回的评论 / 弹幕 / 动态 / 私信 / 联系人等内容可能包含个人信息或敏感 UGC，请勿写入未授权的数据库或公开发布。\n> 3. **凭证保护**：建议使用**独立测试账号**、定期轮换 API Key；**禁止**传入主力生产账号的 cookie 或 session 凭证。\n> 4. **合规责任**：使用方需自行确保符合所在地区的数据保护法律（《个人信息保护法》/ GDPR / 平台 ToS 等），平台账号的合规性由使用方承担。\n\n## 3. 一键安装\n\n### 鉴权\n\n#### 获取 API Key\n\n请前往 [MaxHub 控制台](https://www.aconfig.cn) 注册账号并获取 API Key。\n\n#### 配置 API Key\n\n**方案 1：OpenClaw 配置**\n\n将 `MAXHUB_API_KEY` 添加到 `~/.openclaw/openclaw.json` 中：\n\n```json\n{ \"env\": { \"MAXHUB_API_KEY\": \"ak_xxxx...\" } }\n```\n\n**方案 2：终端环境变量**\n\n```bash\nexport MAXHUB_API_KEY=\"ak_xxxx...\"\n```\n\n### 依赖安装\n\n本 Skill 不需要额外脚本依赖，所有调用通过 `curl` 完成 HTTP 请求即可，无第三方库依赖。\n\n### 环境变量配置\n\n| 环境变量 | 说明 | 是否必填 | 获取方式 |\n|---|---|---|---|\n| `MAXHUB_API_KEY` | MaxHub 数据 API Key | 是 | [MaxHub 控制台](https://www.aconfig.cn) |\n\n## 4. 使用指南\n\n\n### 🤖 Agent Decision Tree（必读 · 决定调用顺序）\n\n> 此小节定义 agent 在每次接到用户请求时的**标准决策流程**。严格按此顺序执行可大幅提升命中率与减少误调用。\n\n#### 1️⃣ 文档加载顺序（按需 · 不要一次性全读）\n| 步骤 | 何时读 | 加载文件 | 估算 token |\n|------|-------|---------|-----------|\n| ① 永远先读 | 接到任何请求时 | `SKILL.md` §0.1（不支持清单）+ §4（本节） | ~1K |\n| ② 选择 recipe | 用户语义清晰时 | `references/recipes/_index.md`（仅索引） | ~1.5K |\n| ③ 加载 recipe 详情 | 匹配到具体 recipe 时 | `references/recipes/<domain>.md` 的对应段落 | ~500/段 |\n| ④ 加载端点详情 | 自定义链路或参数不明时 | `references/<domain>.md` 单文件 | ~3K |\n| ⑤ 路径白名单校验 | 调用前 | `grep '<endpoint_id>' references/endpoints_whitelist.yaml`（**禁止整体读**） | ~50 行 |\n| ⑥ 跨端点字段路由 | 链式调用时 | `references/param-mappings.md` § 字段流字典 | ~1K |\n\n#### 2️⃣ Recipe 匹配规则（核心）\n1. **加载** `references/recipes/_index.md`，扫 `trigger_keywords` 列\n2. **最长匹配优先**：若用户输入同时命中多个 recipe 的 trigger，**选最长 trigger 命中的那个**（最具体）\n3. **平局询问**：若两个 trigger 长度相同且都命中 → 主动询问用户：\"您是想看 A 还是 B？\"\n4. **无命中**：先查 §0.1 不支持清单 → 不在则进入\"自定义链路\"流程（步骤 3）\n\n#### 3️⃣ 自定义链路（无现成 Recipe）\n1. 读 `references/atoms/_index.md`，按 `chain_role` 列定位起点（`starter`）和终点（`terminal`）\n2. **优先用 `⭐⭐⭐ 首选`** 标记的端点；不到必要不用 `⭐ 条件` 端点\n3. 字段流（上游 OUT → 下游 IN）由 `param-mappings.md § 字段流字典` 决定，**禁止**自行猜 json_path\n4. 链路完成后，可向维护方建议把它编排成新 recipe\n\n#### 4️⃣ 调用前自检（按 risk 分级 · 节省 token）\n| 端点 risk | 必做自检 | 步骤数 |\n|----------|---------|-------|\n| `risk: low` | ① 路径在 endpoints_whitelist.yaml | 1 步 |\n| `risk: medium` | ① 路径 ② method ③ 必填参数 ④ 写入确认 | 4 步 |\n| `risk: high` | 4 步 + 显式向用户确认参数与意图 | 5 步 |\n| `risk: critical`（restricted） | 6 步高风险确认流程（详见 §高风险能力清单） | 6 步 |\n\n> 旧 SKILL 强制所有调用都做 4 步——现按 risk 等级简化。`low` 端点（占绝大多数）只校验路径即可。\n\n#### 5️⃣ 错误处理快速决策\n| 现象 | 行动 | 重试 |\n|------|------|------|\n| 404 / 410 | §3.1(A) 5 步防臆造自检 → 通过才 STOP；**禁止**自改路径段重试 | 0 |\n| 400 / 422 | §3.1(B) 6 步防参数臆造自检 → 通过才修参重试 | ≤1 |\n| 401 / 402 / 403 | STOP，告知用户去 https://www.aconfig.cn 处理 | 0 |\n| 429 | 读 `Retry-After` 退避；无该头时指数退避+jitter | ≤2 |\n| 5xx | 等 3 秒重试 → 仍失败走端点级\"降级/替换\" | 1 |\n| HTTP 200 + `code != 0` | 读 `message_zh` 报告用户；**不重试**（业务错误重试无用） | 0 |\n\n#### 6️⃣ 输出契约（与用户对话时）\n1. **数据来源声明**：每次输出明确告知数据来自 `https://www.aconfig.cn` 三方接口\n2. **缺失字段处理**：如某字段链路降级后缺失，**显式说明**\"X 暂不可取\"，不要静默省略\n3. **不要伪造**：用户问的字段若不在响应里 → 说\"未返回\"，禁止用其他端点拼凑模拟\n\n\n\n### 核心约束（强制遵守）\n\n| 规则 | 说明 |\n|------|------|\n| 🔒 只读 | 本技能仅用于数据查询和分析，**不执行写入 / 账户操作** |\n| 🚫 禁止臆造路径 | 仅使用 `references/endpoints_whitelist.yaml` 中的端点，**不得自行拼接、改版本号、加路径段** |\n| 📋 数据流向第三方 | 所有请求发送至 `https://www.aconfig.cn`，请使用独立测试账号并定期轮换 API Key |\n| 🔑 凭证保护 | 不暴露 API Key、Cookie、Token 至日志或对话 |\n\n### 基础使用（4 步完成调用）\n\n**Step 1 — 检查 API Key**\n\n```bash\n[ -n \"${MAXHUB_API_KEY:-}\" ] && echo \"ok\" || echo \"missing\"\n```\n\n若返回 `missing`，停止并提示用户配置 `MAXHUB_API_KEY`。\n\n**Step 2 — 匹配意图 → 选择 reference**\n\n按用户目标从下表选择对应 reference 文件，每个文件自包含其领域的全部端点定义：\n\n| 用户目标 | 加载文件 | 覆盖范围 |\n|---------|---------|---------|\n| 查帖子 / 评论 / 搜索内容 | `references/content.md` | 帖子详情（v1+v2）、评论列表、Top/Recent/Profiles 搜索（6 端点） |\n| 查用户 / 帖子 / 转发 / 回复 | `references/user.md` | 用户资料（username + user_id 双入口）、用户帖子、转发、回复（5 端点） |\n| 跨端点参数查询 / 字段流追溯 | `references/param-mappings.md` | 全局红线 + 端点路由 + 字段流字典 + 错误处理总览 |\n| 路径白名单硬校验 | `references/endpoints_whitelist.yaml` | 11 个端点的硬白名单 + Pre-call 4 步自检协议 |\n| SKILL 版本检查与升级 | `references/update.md` | SkillHub / ClawHub / GitHub 三通道更新 |\n\n**Step 3 — 构建最小调用计划**\n\n- ✅ 优先使用最少端点完成任务，能用一个端点就不用两个\n- ✅ 知道 URL → 优先 `fetch_post_detail_v2`（支持 url 直查）；只有 post_id → 用 `fetch_post_detail`\n- ❌ 禁止\"先 head/tail 试运行\"或\"先调一个看看\"等探索性调用\n\n**Step 4 — 执行并验证**\n\n- 调用前比对 `endpoints_whitelist.yaml` 完成 4 步 Pre-call 自检（路径 → method → 必填 → 写入确认）\n- 收到 **404** → 必须先做防路径臆造自检（5 步）\n- 收到 **400 / 422** → 必须先做防参数臆造自检（6 步）\n- 收到 **业务 code != 0** → 读 `message_zh` 报告用户，**不重试**\n\n### 高级使用\n\n#### 链式调用图谱（Chain Recipes）\n\n| 用户场景 | 链路 | 字段流 |\n|---------|------|-------|\n| 用户名 → 用户帖子 | `fetch_user_info` → `fetch_user_posts` | `username` → `user_id` 接力 |\n| user_id → 全维度内容 | `fetch_user_info_by_id` → `fetch_user_posts` + `fetch_user_reposts` + `fetch_user_replies` | `user_id` 复用 |\n| 帖子详情 + 评论 | `fetch_post_detail` → `fetch_post_comments` | `post_id` 复用 |\n| URL → 帖子详情 | `fetch_post_detail_v2`（url） | URL 直查免接力 |\n| 关键词 → 热门帖 → 详情 | `search_top` → `fetch_post_detail` | `query` → `post_id` |\n| 关键词 → 最新帖 → 详情 | `search_recent` → `fetch_post_detail` | `query` → `post_id` |\n| 用户搜索 → 资料 → 帖子 | `search_profiles` → `fetch_user_info` → `fetch_user_posts` | `query` → `username` → `user_id` |\n\n#### 防臆造自检清单（强制前置步骤）\n\n**收到 404 时（A）**：\n1. 路径白名单逐字符比对 → 不在清单中 STOP\n2. Method 比对 → 不等 STOP\n3. 参数键名比对 → 有清单外参数 STOP\n4. 资源 ID 来源溯源 → Agent 编造的 STOP\n5. 全通过才判定\"上游资源不存在\"\n\n**收到 400 / 422 时（B）**：\n1. 参数名严格比对（`username` / `user_id` / `post_id` / `query` 不可混用）\n2. 必填项齐全 + `fetch_post_detail_v2` 的 `oneOf: [post_id, url]` 二选一逻辑\n3. 类型与格式严格匹配（pattern / enum）\n4. 传参方式正确（query vs body）\n5. 没有 IN 表外的臆造参数\n6. 全通过才按 `message_zh` 排查\n\n#### 端点替换矩阵\n\n| 优先接口 | 降级接口 | 触发条件 |\n|---|---|---|\n| `fetch_post_detail_v2`（url / post_id） | `fetch_post_detail`（post_id） | 仅有 post_id 时直接使用 v1 |\n| `search_top` | `search_recent` | 想要最新内容时切换 |\n\n#### SKILL 版本更新\n\n| 触发条件 | 推荐操作 |\n|---------|---------|\n| 合法路径持续 404 / 410 | `skillhub upgrade maxhub-threads`（国内）或 `clawhub upgrade maxhub-threads`（国际） |\n| 用户问\"版本是多少\" | 当前版本 v3.7.2，访问 https://skillhub.cn/skills/maxhub-threads |\n| 多端点连续 410 | `skillhub upgrade maxhub-threads --force` |\n| 401 / 402 / 403 | **不是版本问题**，去 https://www.aconfig.cn 处理 |\n\n### 常用命令速查表\n\n| 场景 | 命令 |\n|---|---|\n| 查 API Key | `[ -n \"${MAXHUB_API_KEY:-}\" ] && echo \"ok\" \\|\\| echo \"missing\"` |\n| 查用户资料 | `curl -H \"$maxhub_auth_header\" \"https://www.aconfig.cn/api/v1/threads/web/fetch_user_info?username=xxx\"` |\n| 查用户帖子 | `curl -H \"$maxhub_auth_header\" \"https://www.aconfig.cn/api/v1/threads/web/fetch_user_posts?user_id=xxx\"` |\n| 查帖子详情（URL） | `curl -H \"$maxhub_auth_header\" \"https://www.aconfig.cn/api/v1/threads/web/fetch_post_detail_v2?url=https://www.threads.net/@xxx/post/yyy\"` |\n| 关键词搜索热门 | `curl -H \"$maxhub_auth_header\" \"https://www.aconfig.cn/api/v1/threads/web/search_top?query=AI\"` |\n| 检查 SKILL 更新 | `skillhub info maxhub-threads` 或 `clawhub info maxhub-threads` |\n\n\n### 📌 端到端使用示例（agent 快速上手）\n\n**用户输入**：「帮我看 Threads 某个 user 的最近 post」\n\n**Agent 执行步骤**：\n\n1. **匹配 recipe**：读 `references/recipes/_index.md` → 找到 trigger 命中 → 选最长匹配的 recipe\n2. **加载 recipe 详情**：读 `references/recipes/<domain>.md` 中对应段落，拿到 Inputs / Atomic Steps / Output\n3. **路径校验**：对每个 atom 的 endpoint_id，`grep` 一下 `endpoints_whitelist.yaml` 确认存在\n4. **risk: low 的端点直接调用，risk: medium+ 先与用户确认**\n5. **链式传递**：上游响应的 json_path 字段（如 `$.data.bvid`）按 recipe 的 `extract` 列绑定为变量，传给下游端点\n6. **错误处理**：按 §错误处理决策表行动；不要自改路径或瞎加参数\n7. **输出**：组装结果给用户，标明数据来自三方接口；缺失字段显式说\"未取到\"\n\n**反例（agent 不要这么做）**：\n- ❌ 全文加载 `endpoints_whitelist.yaml`（大文件，浪费上下文）\n- ❌ 看到 404 就改路径段重试（会被防臆造规则阻断）\n- ❌ 把没在响应里的字段编一个值返回给用户\n- ❌ 链式调用时忽略 recipe 的 `extract` 列，自己猜 json_path\n\n\n## 5. 使用场景\n\n### 场景一：Threads 内容研究者发掘热门话题\n\n- **角色**：海外社媒研究员\n- **需求**：监测某关键词在 Threads 平台的热度变化与最新 / 热门讨论\n- **使用方式**：`search_top` 拉热门贴 + `search_recent` 拉最新贴 → 取 `post_id` → 链式调 `fetch_post_detail` 提取互动数据\n- **预期收益**：双轨搜索覆盖热度与时效，构建关键词的完整 Threads 讨论画像\n\n### 场景二：Meta 社交监控团队追踪 KOL 动态\n\n- **角色**：品牌社交监控\n- **需求**：定期采集目标 KOL 在 Threads 上的帖子、转发与回复，识别其内容策略\n- **使用方式**：`search_profiles`（用户名搜索）→ `fetch_user_info` → 并行 `fetch_user_posts` + `fetch_user_reposts` + `fetch_user_replies`\n- **预期收益**：KOL 全行为画像（原创 / 转发 / 回复三链路），识别其圈层互动与内容偏好\n\n### 场景三：海外内容创作者寻找 Threads 选题\n\n- **角色**：海外自媒体\n- **需求**：从 Threads 平台借鉴热门选题与表达方式\n- **使用方式**：`search_top` 拉行业关键词热门贴 → `fetch_post_detail` 取完整文本与媒体 → `fetch_post_comments` 看用户共鸣点\n- **预期收益**：从 Threads 采集真实表达样本，提升海外内容选题的本地化与共鸣度\n\n### 场景四：跨平台舆情对比分析\n\n- **角色**：舆情分析师\n- **需求**：对比同一话题在 Threads 与其他社交平台的传播差异\n- **使用方式**：`search_top` + `search_recent` 拉取话题相关帖 → 取 `user_id` 通过 `fetch_user_info_by_id` 反查用户画像 → 输出热度 / 用户层级 / 互动结构对比\n- **预期收益**：跨平台舆情数据对齐，识别 Threads 用户群体与其他平台的差异化特征\n\n## 6. 项目架构\n\n### 目录结构\n\n```\nmaxhub-threads/\n├── SKILL.md                            # Skill 定义与使用文档（本文件）\n├── README.md                           # 英文项目说明\n├── README_CN.md                        # 中文项目说明\n├── _meta.json                          # 版本元信息（version: 3.7.2）\n└── references/\n    ├── endpoints_whitelist.yaml        # 11 端点路径硬白名单 + Pre-call 4 步自检协议\n    ├── param-mappings.md               # 中枢索引（全局红线 + 字段流字典 + 错误处理）\n    ├── content.md                      # 内容域：帖子详情/评论/搜索（6 端点）\n    ├── user.md                         # 用户域：资料/帖子/转发/回复（5 端点）\n    └── update.md                       # SKILL 更新机制（SkillHub / ClawHub / GitHub）\n```\n\n### 技术栈\n\n| 组件 | 技术 | 说明 |\n|------|------|------|\n| 调用方式 | `curl` + Bearer Token | HTTP GET 请求，参数通过 query string 传递 |\n| 数据接口 | MaxHub API | `https://www.aconfig.cn/api/v1/threads/web/*`，通过 `MAXHUB_API_KEY` 鉴权 |\n| 路径校验 | YAML 硬白名单 | `endpoints_whitelist.yaml` 提供 11 端点的逐字符校验 + 4 步 Pre-call 协议 |\n| 错误处理 | 决策表 + 自检清单 | HTTP 状态码权威定义 + 防臆造自检（A/B 双轨）+ 端点替换矩阵 |\n| 输出格式 | JSON Standard MaxHub Response | `{code, message, message_zh, data, cache_url}` |\n| 更新通道 | SkillHub / ClawHub / GitHub | 国内 ⭐⭐⭐ SkillHub（腾讯云 CDN）/ 国际 ⭐⭐⭐ ClawHub / 降级 GitHub |\n\n### API 覆盖范围\n\n| 领域 | 端点数 | Reference 文件 |\n|------|--------|---------------|\n| 内容（Content） | 6 | `content.md` |\n| 用户（User） | 5 | `user.md` |\n| **合计** | **11** | — |\n\n### 关键设计理念\n\n- **防臆造四道闸**：白名单（endpoints_whitelist.yaml）→ 强标记（Full path）→ 禁止规则（Forbidden）→ 错误反馈（STOP）\n- **链式调用图谱**：字段流字典（`username` / `user_id` / `post_id` / `query`）+ Chain Recipes + 跨 reference 链路三层联动\n- **错误处理契约**：HTTP 状态码权威定义 + 防臆造自检清单（A: 5 步 / B: 6 步）+ 端点替换矩阵（v1 ↔ v2）\n","topics":["研究","社交"],"tags":{"latest":"3.8.0"},"stats":{"comments":0,"downloads":1247,"installsAllTime":42,"installsCurrent":2,"stars":0,"versions":27},"createdAt":1778341891841,"updatedAt":1781668932394},"latestVersion":{"version":"3.8.0","createdAt":1781668932394,"changelog":"优化 skill frontmatter 与 agent 使用导航：增强 recipes/chain graph、字段流、加载地图与风险标注；未修改 API 端点定义","license":"MIT-0"},"metadata":{"setup":[{"key":"MAXHUB_API_KEY","required":true}],"os":null,"systems":null},"owner":{"handle":"xiewxx","userId":"s17364s4d8h82mf2cd7m7g71ms869c1h","displayName":"XieWxx","image":"https://avatars.githubusercontent.com/u/128963651?v=4"},"moderation":null}