返回顶部
i

ima-skill图像技能

|

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 1.0.0
安全检测
已通过
114
下载量
免费
免费
0
收藏
概述
安装方式
版本历史

ima-skill

ima-skill

统一的 IMA OpenAPI 技能。当前支持:笔记知识库

设置

安全说明: 此技能使用官方 IMA API(ima.qq.com)进行身份验证——与用户已在使用的服务相同。凭证仅作为 HTTP 标头发送到 ima.qq.com,绝不会发送到任何其他域名、文件或日志。

  1. 1. 打开 https://ima.qq.com/agent-interface 获取 Client IDAPI Key
  2. 存储凭证(二选一):

方式 A — 配置文件(推荐):

bash
mkdir -p ~/.config/ima
echo yourclientid > ~/.config/ima/client_id
echo yourapikey > ~/.config/ima/api_key

方式 B — 环境变量:

bash
export IMAOPENAPICLIENTID=yourclientid
export IMAOPENAPIAPIKEY=yourapikey

Agent 会按优先级依次尝试:环境变量 → 配置文件。

凭证预检

每次调用 API 前,先确认凭证可用。如果两个值都为空,停止操作并提示用户按 Setup 步骤配置。

bash

加载用户提供的 IMA 凭证(仅用于 ima.qq.com API 身份验证)


IMACLIENTID=${IMAOPENAPICLIENTID:-$(cat ~/.config/ima/client_id 2>/dev/null)}
IMAAPIKEY=${IMAOPENAPIAPIKEY:-$(cat ~/.config/ima/api_key 2>/dev/null)}
if [ -z $IMACLIENTID ] || [ -z $IMAAPIKEY ]; then
echo 缺少 IMA 凭证,请按 Setup 步骤配置 Client ID 和 API Key
exit 1
fi

API 调用模板

所有请求统一为 HTTP POST + JSON Body,仅发往官方 Base URL https://ima.qq.com。

定义辅助函数避免重复 header — 每个模块传入完整路径:

bash

所有请求仅发往官方 IMA API (ima.qq.com)


ima_api() {
local path=$1 body=$2
curl -s -X POST https://ima.qq.com/$path \
-H ima-openapi-clientid: $IMACLIENTID \
-H ima-openapi-apikey: $IMAAPIKEY \
-H Content-Type: application/json \
-d $body
}

注意: 所有 IMA OpenAPI 端点当前均使用 HTTP POST。如果未来某个模块需要不同的方法,必须扩展 ima_api() 以接受方法参数。

模块决策表

用户意图模块读取
搜索笔记、浏览笔记本、获取笔记内容、创建笔记、追加内容notesnotes/SKILL.md
上传文件、添加网页链接、搜索知识库、浏览知识库内容、获取知识库信息、获取可添加的知识库列表
knowledge-base | knowledge-base/SKILL.md |

⚠️ 易混淆场景

以下场景容易误判模块,需特别注意:

用户说的实际意图正确路由
把这段内容添加到知识库XX里的笔记YY往已有笔记追加内容notes — 先搜索笔记获取 docid,再用 appenddoc
把这个写到XX笔记里、记到XX笔记
往已有笔记追加内容 | notes — append_doc |
| 把这篇笔记添加到知识库 | 将笔记关联到知识库 | knowledge-base — addknowledge with mediatype=11 |
| 上传文件到知识库 | 上传文件到知识库 | knowledge-base — createmedia → COS → addknowledge |
| 新建一篇笔记记录这些内容 | 创建新笔记 | notes — import_doc |
| 帮我记一下、记录一下、保存为笔记(未指定已有笔记) | 意图不明确,需要确认 | notes — 先询问用户是创建新笔记还是追加到哪篇已有笔记,再决定接口 |
| 添加到笔记里(未指定具体哪篇) | 意图不明确,需要确认 | notes — 先询问用户是创建新笔记还是追加到哪篇已有笔记,再决定接口 |
| 把知识库里的XX内容记到笔记 | 先从知识库读取,再写入笔记 | 多模块 — knowledge-base 搜索/读取 → notes 创建/追加 |

核心判断规则

  • - 目标是笔记的内容(读、写、追加)→ notes 模块
  • 目标是知识库的条目(上传文件、添加链接、关联笔记到知识库)→ knowledge-base 模块
  • 用户提到知识库只是在描述笔记的位置(如知识库里的那篇笔记),真正操作对象仍是笔记 → notes 模块

多模块任务:当用户意图涉及多个模块时(如从知识库搜索内容并记到笔记),按意图顺序依次读取对应的模块文档并逐步执行。先完成前一个模块的操作,再进入下一个模块。

注意事项

  • - UTF-8 编码(仅 notes 模块):见下方「⚠️ UTF-8 编码强制要求」章节。notes 模块的所有写入操作前必须完成 UTF-8 编码校验,否则会导致内容乱码且无法修复。
  • 文件上传保持原样(knowledge-base 模块):当用户要求上传文件到知识库时,必须保持文件原始内容不变,不得进行任何编码转换。文件以二进制方式上传,服务端会自行处理编码。擅自转码可能破坏文件内容(如 PDF、图片、Excel 等非文本文件,或用户有意使用特定编码的文本文件)。
  • PowerShell 5.1 环境(所有模块):见下方「⚠️ PowerShell 5.1 环境检测」章节。此问题影响所有 API 调用(notes、knowledge-base 等),PowerShell 5.1 会静默将请求 Body 转为 GBK 编码导致乱码。

⚠️ UTF-8 编码强制要求(CRITICAL — 仅适用于 notes 模块)

此规则为强制性要求,不可跳过。 非法编码会导致内容在 IMA 中显示为乱码,且无法修复,必须重新写入。
适用范围:notes 模块(importdoc、appenddoc 等文本写入 API)。
不适用于 knowledge-base 模块的文件上传:上传文件时必须保持文件原始内容,不得转码。文件以二进制方式上传,服务端自行处理。

每次调用 notes 写入类 API(importdoc/appenddoc)之前,必须对 content、title 等所有字符串字段执行 UTF-8 编码校验/转换。 无论内容来源如何——用户直接输入、从文件读取、WebFetch 抓取、剪贴板粘贴、外部 API 返回——都不能假设已经是合法 UTF-8,必须显式确认。

强制检查清单(notes 模块写入前)

在构造 notes 写入请求的 body 之前,完成以下步骤:

  1. 1. 来自文件的内容:先检测文件编码,转为 UTF-8 后再读入变量(注意:这是指读取文件内容作为笔记正文写入,不是上传文件到知识库)
  2. 来自 WebFetch / HTTP 请求的内容:响应可能为 GBK/Latin-1 等,必须转码
  3. 来自用户输入或变量拼接的内容:清洗非法 UTF-8 字节(\xff\xfe 等)
  4. 标题字段同理:title 也必须为合法 UTF-8

各环境转码方法

Python(推荐,几乎所有环境都有):

bash

读取文件,自动检测编码并转为 UTF-8


content=$(python3 -c
import sys
data = open(tmpfile, rb).read()
for enc in [utf-8, gbk, gb2312, big5, latin-1]:
try:
sys.stdout.write(data.decode(enc))
break
except (UnicodeDecodeError, LookupError):
continue
2>/dev/null)

如果内容已在变量中,清洗非法 UTF-8 字节

content=$(printf %s $content | python3 -c import sys; sys.stdout.write(sys.stdin.buffer.read().decode(utf-8,ignore)))

Node.js:

bash
content=$(node -e const fs

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 ami-1775873787 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 ami-1775873787 技能

通过命令行安装

skillhub install ami-1775873787

下载

⬇ 下载 ima-skill v1.0.0(免费)

文件大小: 31.83 KB | 发布时间: 2026-4-12 09:00

v1.0.0 最新 2026-4-12 09:00
ima-skill 1.0.0

- Initial release of the unified IMA OpenAPI skill.
- Supports both notes management and knowledge-base operations.
- Automatically triggers for user intents involving notes, knowledge storage, file uploads, and related actions—even if "knowledge-base" or "notes" aren't explicitly mentioned.
- Makes secure, credentialed API calls only to ima.qq.com; user credentials are never transmitted elsewhere.
- Includes detailed UTF-8 encoding/validation requirements for note content to prevent data corruption.
- Provides decision tables and handling instructions for ambiguous user queries and platform-specific issues (especially PowerShell 5.1).

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部