和 TypeScript / Node 交互

和 TypeScript / Node 交互

AgentScript 的重点是描述 agent workflow 和模型上下文,而不是替代 JavaScript /

TypeScript 生态。遇到普通编程任务时,可以通过 import tool 调用显式授权的

Node 内置模块,或宿主项目里已经安装的 npm 包。

这篇教程使用 Node 内置模块,因此在当前仓库里不需要额外安装依赖就能运行。

完整源码:../../../tutorials/typescript-interop.as

1. Capability Registry

node:npm: import 默认拒绝。workspace 必须通过

agentscript.npm.json 显式授权:

json 复制代码
{

"allow": {

"node": ["crypto"],

"npm": {}

}

}

这份文件应该保持小而可审计。它表示当前 workspace 允许 AgentScript 程序调用

Node 的 crypto 模块,但还没有授权任何 npm 包。

2. 程序

创建 typescript-interop.as,或者直接打开仓库里的

tutorials/typescript-interop.as

ts 复制代码
import tool Crypto from "node:crypto"

  


main agent TypeScriptInterop {

role "Interop example"

description "Use a Node built-in module from AgentScript and return JSON-safe data."

  


main func(input {

label: string

payload: json

}) {

run_id = Crypto.randomUUID()

digest = Crypto.hash("sha256", input.label, "hex")

  


return {

label: input.label,

payload: input.payload,

run_id: run_id,

digest: digest

}

}

}

这里没有 generate。这是刻意的:交互能力在调用模型之前也有价值。你可以先

做数据标准化、生成 ID、读取文件,或者调用一个 JSON-friendly 的库,然后在后续

agent 中决定哪些结果要通过 use 进入模型上下文。

3. 运行

bash 复制代码
agentscript tutorials/typescript-interop.as --quiet --input '{"label":"release-notes","payload":{"version":"0.1.19","kind":"patch"}}'

输出会包含原始 JSON payload,以及 Node 生成的值:

json 复制代码
{

"label": "release-notes",

"payload": {

"version": "0.1.19",

"kind": "patch"

},

"run_id": "generated-uuid",

"digest": "sha256-hex-digest"

}

4. 这对 TypeScript 意味着什么

AgentScript 不直接执行 TypeScript source file。它通过 Node module loader

调用 JavaScript 模块。实际使用时,可以这样理解:

  • node:crypto 这类 Node 内置模块在授权后可以直接导入。

  • npm 包需要先由宿主项目安装,再写入 agentscript.npm.json

  • TypeScript 写的库需要先编译或发布为 JavaScript,之后就能按 npm 包调用。

  • 函数参数和返回值必须是 JSON-safe:string、number、boolean、null、数组、

plain object。

如果某个包暴露的是 class、stream、buffer、callback 或 builder object,建议在

TypeScript 侧写一层很薄的 JSON-friendly wrapper,编译成 JavaScript 后再由

AgentScript 导入。

5. 调用 npm 包

对于已经安装的 npm 包,写法一样:

ts 复制代码
import tool Yaml from "npm:yaml"

  


main agent ParseYaml {

main func(input {

text: string

}) {

doc = Yaml.parse(input.text)

  


return {

document: doc

}

}

}

宿主项目需要安装 yaml 并授权:

json 复制代码
{

"allow": {

"node": ["crypto"],

"npm": {

"yaml": { "version": "^2.0" }

}

}

}

下一步

完整边界和异常情况见:../npm-tools.md。然后继续阅读 ReAct

教程,看 tool result 如何进入模型上下文。

相关推荐
Wanderer X1 小时前
【LLM】RAG mRAG
人工智能
eastyuxiao1 小时前
数字孪生教程(软件篇)官方学习路径
大数据·人工智能·学习·数字孪生
茉莉玫瑰花茶1 小时前
LangGraph 入门教程:构建 AI 工作流 [ 案例三 ]
前端·人工智能·python
我有医保我先冲1 小时前
【无标题】
java·大数据·人工智能
染指11101 小时前
2.AI大模型-链式思考TOC让AI实现思考-优秀提示词设计技巧
大数据·数据库·人工智能
Daydream.V1 小时前
从零搭建 AI Agent:LLM Agent+Function Calling+Dify 本地部署 + Coze 实战全攻略
人工智能·langchain·ollama·functioncalling·大模型部署
数据智研1 小时前
【数据分享】中国第三产业统计年鉴(1991-2025)(1993-1994、2001-2005末出版)
大数据·人工智能·信息可视化·数据分析
HyperAI超神经1 小时前
在线教程丨单卡即可爆改,面壁智能等开源MiniCPM-V-4.6,1.3B端侧模型支持图像理解/视频理解/OCR/多轮多模态对话
人工智能·ai·ocr
科技测评-阿博2 小时前
律师案源开发指南:精准获客方法,附实操模板
大数据·人工智能