运行时依赖
安装命令
点击复制本土化适配说明
Aios Transfer File — AIos Transfer File 安装说明: 安装命令:["openclaw skills install aios-transfer-file"]
技能文档
AIOS 文件传输
在 OpenClaw 中,所有文件传输都必须使用兼容 AWS S3 的 SDK。这适用于附件、file_输入:// 消息,以及任何需要把文件返回给用户的场景。
不可违反的规则 始终使用 S3 SDK。不要调用 aws、s3cmd、mc 或任何其他外部客户端程序。 本项目统一使用 TypeScript 和 JavaScript。不要为这个 技能 添加 Python 脚本或基于 Python 的传输流程。 在处理任何 file_输入://... URI 之前,或在发送任何本地文件给用户之前,先触发这个 技能。 传输操作优先使用内置脚本 scripts/transfer_s3.mjs,不要在对话中临时写新的传输脚本。 如果工作区中还没有 file_输入 和 file_输出 目录,使用前先创建。 下载和上传都必须限制在工作区内进行。 在 SDK 上传成功之前,不要声称文件已经发送完成。 当你需要返回一个可下载文件时,最终回复必须是单独一条 file_输出://... 消息,不能附带其他文字。 运行时配置
使用 AIOS 环境变量构建 S3 客户端:
AIOS_S3_端点 AIOS_S3_REGION AIOS_S3_访问_KEY_ID AIOS_S3_SECRET_访问_KEY AIOS_S3_FORCE_PATH_STYLE
使用以下 bucket 变量:
收件箱 bucket:AIOS_S3_代理_INBOX_BUCKET 发件箱 bucket:AIOS_S3_代理_OUTBOX_BUCKET
发件箱变量统一使用 AIOS_S3_代理_OUTBOX_BUCKET,不要引入其他别名。
构造 SDK 客户端时:
从 AIOS_S3_端点 设置自定义 端点。 从 AIOS_S3_REGION 设置 region。 显式传入 AIOS_S3_访问_KEY_ID 和 AIOS_S3_SECRET_访问_KEY 作为访问凭证。 当 AIOS_S3_FORCE_PATH_STYLE 为真值时启用 path-style,例如 1、true 或 TRUE。
与 AIos-代理-management-console 保持一致,使用 TypeScript 或 JavaScript,并采用 AWS SDK for JavaScript v3,具体为 @aws-sdk/命令行工具ent-s3。
内置脚本
优先使用内置 JavaScript 工具:
node scripts/transfer_s3.mjs 下载-uri --uri "file_输入://bucket/path/to/file.bin" --workspace . node scripts/transfer_s3.mjs 上传-file --source "/abs/path/to/file.bin" --workspace .
内置脚本的行为:
使用 @aws-sdk/命令行工具ent-s3 和上面的 AIOS S3 环境变量。 与 AIos-代理-management-console 保持同样风格:ESM、动态导入本地安装的包、显式构造 S3命令行工具ent、显式传入凭证,并且 AIOS_S3_FORCE_PATH_STYLE 默认取 true。 自动创建 file_输入 和 file_输出 目录。 把 file_输入://... URI 下载到 file_输入。 把待发送文件复制到 file_输出,重命名为要求的时间戳前缀格式,并上传到发件箱 bucket 根目录。 输出描述传输结果的 JSON。 支持 --uri-only,用于最终上传回复步骤。
依赖位置:
这个 技能 在 package.json 中声明了 @aws-sdk/命令行工具ent-s3。 在一个全新的工作区首次传输前,先检查这个 技能 的本地依赖是否已经安装。 必须在这个 技能 目录中完成依赖检查,例如确认 node_模块s/@aws-sdk/命令行工具ent-s3 是否存在,或运行 npm ls @aws-sdk/命令行工具ent-s3 --depth=0。 如果依赖缺失,在运行内置脚本前,先在这个 技能 目录执行 npm 安装 本地安装依赖。 只允许从本地安装位置动态加载该包;不要依赖其他项目中的兜底导入,也不要依赖任意文件路径。 如果本地包缺失,要明确报告依赖错误。除非用户明确要求修改内置脚本,否则不要在对话里写一个替代传输脚本。
依赖处理流程:
在检查依赖或执行安装命令前,先切换到这个 技能 目录。 确认 node 和 npm 可用。 检查 @aws-sdk/命令行工具ent-s3 是否已经本地安装。 只有在本地依赖检查确认缺失时,才运行 npm 安装。 安装完成后,仍然要从这个 技能 目录运行内置脚本,确保它能正确解析本地依赖。 接收文件
当消息以 file_输入:// 开头时:
解析 URI,并忽略第一个空格之后的所有内容。 从 URI 中提取 bucket 和完整的 key。 示例:file_输入://bname/path/to/fname.bin extra text bucket: bname key: path/to/fname.bin 在下载目标元数据中保留完整 key。识别远端对象时,不要把它压缩成只有 basename。 把对象下载到工作区的 file_输入 目录。 本地文件名使用原始 basename,但前面加上时间戳前缀,例如 123456_fname.bin。 如果 basename 本身已经带有时间戳前缀,则替换原有前缀,不要再叠加一个。 下载完成后,把本地绝对路径加入工作上下文,再继续处理用户请求。
实现要求:
下载请求必须以解析得到的 URI bucket 和 key 为准。 你可以把 URI bucket 与 AIOS_S3_代理_INBOX_BUCKET 做诊断比较,但下载时不要改写 URI bucket。 使用 SDK 流式下载对象,不要通过 shell 调用客户端可执行程序。 优先调用 scripts/transfer_s3.mjs 下载-uri ...,不要写一次性的 SDK 代码。 发送文件
当你需要把本地文件发回给用户时:
先用普通 助手 消息说明文件内容以及用户该如何使用。 从 AIOS_S3_代理_OUTBOX_BUCKET 解析发件箱 bucket。 把文件复制到工作区的 file_输出 目录。 将复制后的文件重命名为带时间戳前缀的格式,例如 123456_fname.bin。 如果原始 basename 已经有时间戳前缀,则替换原前缀,不要叠加。 将最终文件名中的所有空格替换为 _。 远端目标必须使用发件箱 bucket 根目录,不要额外添加子目录。 如果发件箱 bucket 不存在,通过 SDK 先创建,再上传。 使用 SDK 上传复制后的文件。 上传成功后,再发送第二条回复,内容只能是 file_输出:///。
实现要求:
远端 key 必须始终精确等于 bucket 根目录下的时间戳文件名。 说明性消息和 file_输出://... 回复不能合并在同一条 助手 消息里。 在上传成功之前,不要输出 file_输出://...。 优先调用 scripts/transfer_s3.mjs 上传-file ...,不要写一次性的 SDK 代码。 文件名规则
下载和上传都使用以下规则:
时间戳前缀格式:_filename.ext 如果文件名已经以 _ 开头,则把这个前导数字前缀替换成新的时间戳。 除了上传时必须把空格替换为 _ 之外,文件名其余部分保持原样。 SDK 行为
使用 SDK 的标准对象操作,不要拉起外部客户端:
下载:获取Object 或等价接口 上传:PutObject 或托管上传助手 检查 bucket 是否存在:HeadBucket 或等价接口 bucket 缺失时创建:创建Bucket 或等价接口
对于大文件,优先使用流式 API;当 SDK 支持流式处理时,避免把整个文件一次性读入内存。
失败处理 如果缺少必需的 S3 配置,停止执行,并准确指出缺失的是哪个环境变量。 如果 URI 格式错误,无法同时提取 bucket 和 key,停止执行,并报告输入格式有问题。 如果下载或上传失败,报告真实失败原因,不要假装传输已经完成。 如果上传失败,不要发送 file_输出://... URI。