opc-agent 1.4.0 → 1.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (192) hide show
  1. package/CHANGELOG.md +69 -23
  2. package/CONTRIBUTING.md +60 -21
  3. package/README.md +358 -235
  4. package/README.zh-CN.md +415 -415
  5. package/dist/channels/slack.js +10 -93
  6. package/dist/channels/web.d.ts +0 -10
  7. package/dist/channels/web.js +2 -33
  8. package/dist/cli.js +60 -255
  9. package/dist/core/dashboard.d.ts +35 -0
  10. package/dist/core/dashboard.js +157 -0
  11. package/dist/core/fast-mode.d.ts +27 -0
  12. package/dist/core/fast-mode.js +59 -0
  13. package/dist/core/priority.d.ts +52 -0
  14. package/dist/core/priority.js +102 -0
  15. package/dist/core/runtime.d.ts +0 -4
  16. package/dist/core/runtime.js +0 -27
  17. package/dist/deploy/hermes.js +22 -22
  18. package/dist/deploy/openclaw.js +40 -31
  19. package/dist/index.d.ts +14 -3
  20. package/dist/index.js +20 -6
  21. package/dist/memory/cloud-storage.d.ts +40 -0
  22. package/dist/memory/cloud-storage.js +211 -0
  23. package/dist/providers/index.d.ts +1 -1
  24. package/dist/providers/index.js +1 -7
  25. package/dist/schema/oad.d.ts +2 -1
  26. package/dist/templates/code-reviewer.d.ts +8 -0
  27. package/dist/templates/code-reviewer.js +9 -5
  28. package/dist/templates/customer-service.d.ts +8 -0
  29. package/dist/templates/customer-service.js +6 -2
  30. package/dist/templates/data-analyst.d.ts +8 -0
  31. package/dist/templates/data-analyst.js +9 -5
  32. package/dist/templates/knowledge-base.d.ts +8 -0
  33. package/dist/templates/knowledge-base.js +6 -2
  34. package/dist/templates/sales-assistant.d.ts +8 -0
  35. package/dist/templates/sales-assistant.js +8 -4
  36. package/dist/templates/teacher.d.ts +8 -0
  37. package/dist/templates/teacher.js +10 -6
  38. package/docs/.vitepress/config.ts +103 -103
  39. package/docs/api/cli.md +48 -48
  40. package/docs/api/oad-schema.md +64 -64
  41. package/docs/api/sdk.md +80 -80
  42. package/docs/guide/concepts.md +51 -51
  43. package/docs/guide/configuration.md +79 -79
  44. package/docs/guide/deployment.md +42 -42
  45. package/docs/guide/getting-started.md +44 -44
  46. package/docs/guide/templates.md +28 -28
  47. package/docs/guide/testing.md +84 -84
  48. package/docs/index.md +27 -27
  49. package/docs/zh/api/cli.md +54 -54
  50. package/docs/zh/api/oad-schema.md +87 -87
  51. package/docs/zh/api/sdk.md +102 -102
  52. package/docs/zh/guide/concepts.md +104 -104
  53. package/docs/zh/guide/configuration.md +135 -135
  54. package/docs/zh/guide/deployment.md +81 -81
  55. package/docs/zh/guide/getting-started.md +82 -82
  56. package/docs/zh/guide/templates.md +84 -84
  57. package/docs/zh/guide/testing.md +88 -88
  58. package/docs/zh/index.md +27 -27
  59. package/examples/customer-service-demo/README.md +90 -90
  60. package/examples/customer-service-demo/oad.yaml +107 -107
  61. package/package.json +1 -1
  62. package/src/analytics/index.ts +66 -66
  63. package/src/channels/discord.ts +192 -192
  64. package/src/channels/email.ts +177 -177
  65. package/src/channels/feishu.ts +236 -236
  66. package/src/channels/index.ts +15 -15
  67. package/src/channels/slack.ts +160 -217
  68. package/src/channels/telegram.ts +90 -90
  69. package/src/channels/voice.ts +106 -106
  70. package/src/channels/web.ts +2 -38
  71. package/src/channels/webhook.ts +199 -199
  72. package/src/channels/websocket.ts +87 -87
  73. package/src/channels/wechat.ts +149 -149
  74. package/src/cli.ts +58 -282
  75. package/src/core/a2a.ts +143 -143
  76. package/src/core/agent.ts +152 -152
  77. package/src/core/analytics-engine.ts +186 -186
  78. package/src/core/auth.ts +57 -57
  79. package/src/core/cache.ts +141 -141
  80. package/src/core/compose.ts +77 -77
  81. package/src/core/config.ts +14 -14
  82. package/src/core/dashboard.ts +219 -0
  83. package/src/core/errors.ts +148 -148
  84. package/src/core/fast-mode.ts +75 -0
  85. package/src/core/hitl.ts +138 -138
  86. package/src/core/logger.ts +57 -57
  87. package/src/core/orchestrator.ts +215 -215
  88. package/src/core/performance.ts +187 -187
  89. package/src/core/priority.ts +140 -0
  90. package/src/core/rate-limiter.ts +128 -128
  91. package/src/core/room.ts +109 -109
  92. package/src/core/runtime.ts +152 -183
  93. package/src/core/sandbox.ts +101 -101
  94. package/src/core/security.ts +171 -171
  95. package/src/core/types.ts +68 -68
  96. package/src/core/versioning.ts +106 -106
  97. package/src/core/watch.ts +178 -178
  98. package/src/core/workflow.ts +235 -235
  99. package/src/deploy/hermes.ts +156 -156
  100. package/src/deploy/openclaw.ts +200 -190
  101. package/src/dtv/data.ts +29 -0
  102. package/src/dtv/trust.ts +43 -0
  103. package/src/dtv/value.ts +47 -0
  104. package/src/i18n/index.ts +216 -216
  105. package/src/index.ts +16 -3
  106. package/src/marketplace/index.ts +223 -0
  107. package/src/memory/cloud-storage.ts +217 -0
  108. package/src/memory/deepbrain.ts +108 -108
  109. package/src/memory/index.ts +34 -34
  110. package/src/plugins/index.ts +208 -208
  111. package/src/providers/index.ts +1 -9
  112. package/src/schema/oad.ts +155 -154
  113. package/src/skills/base.ts +16 -16
  114. package/src/skills/document.ts +100 -100
  115. package/src/skills/http.ts +35 -35
  116. package/src/skills/index.ts +27 -27
  117. package/src/skills/scheduler.ts +80 -80
  118. package/src/skills/webhook-trigger.ts +59 -59
  119. package/src/templates/code-reviewer.ts +34 -30
  120. package/src/templates/customer-service.ts +80 -76
  121. package/src/templates/data-analyst.ts +70 -66
  122. package/src/templates/executive-assistant.ts +71 -71
  123. package/src/templates/financial-advisor.ts +60 -60
  124. package/src/templates/knowledge-base.ts +31 -27
  125. package/src/templates/legal-assistant.ts +71 -71
  126. package/src/templates/sales-assistant.ts +79 -75
  127. package/src/templates/teacher.ts +79 -75
  128. package/src/testing/index.ts +181 -181
  129. package/src/tools/calculator.ts +73 -73
  130. package/src/tools/datetime.ts +149 -149
  131. package/src/tools/json-transform.ts +187 -187
  132. package/src/tools/mcp.ts +76 -76
  133. package/src/tools/text-analysis.ts +116 -116
  134. package/templates/Dockerfile +15 -15
  135. package/templates/code-reviewer/README.md +27 -27
  136. package/templates/code-reviewer/oad.yaml +41 -41
  137. package/templates/customer-service/README.md +22 -22
  138. package/templates/customer-service/oad.yaml +36 -36
  139. package/templates/docker-compose.yml +21 -21
  140. package/templates/ecommerce-assistant/README.md +45 -45
  141. package/templates/ecommerce-assistant/oad.yaml +47 -47
  142. package/templates/knowledge-base/README.md +28 -28
  143. package/templates/knowledge-base/oad.yaml +38 -38
  144. package/templates/sales-assistant/README.md +26 -26
  145. package/templates/sales-assistant/oad.yaml +43 -43
  146. package/templates/tech-support/README.md +43 -43
  147. package/templates/tech-support/oad.yaml +45 -45
  148. package/tests/a2a.test.ts +66 -66
  149. package/tests/agent.test.ts +72 -72
  150. package/tests/analytics.test.ts +50 -50
  151. package/tests/channel.test.ts +39 -39
  152. package/tests/e2e.test.ts +134 -134
  153. package/tests/errors.test.ts +83 -83
  154. package/tests/hitl.test.ts +71 -71
  155. package/tests/i18n.test.ts +41 -41
  156. package/tests/mcp.test.ts +54 -54
  157. package/tests/oad.test.ts +68 -68
  158. package/tests/performance.test.ts +115 -115
  159. package/tests/plugin.test.ts +74 -74
  160. package/tests/room.test.ts +106 -106
  161. package/tests/runtime.test.ts +42 -42
  162. package/tests/sandbox.test.ts +46 -46
  163. package/tests/security.test.ts +60 -60
  164. package/tests/templates.test.ts +77 -77
  165. package/tests/v070.test.ts +76 -76
  166. package/tests/versioning.test.ts +75 -75
  167. package/tests/voice.test.ts +61 -61
  168. package/tests/webhook.test.ts +29 -29
  169. package/tests/workflow.test.ts +143 -143
  170. package/tsconfig.json +19 -19
  171. package/vitest.config.ts +9 -9
  172. package/.github/ISSUE_TEMPLATE/bug_report.md +0 -20
  173. package/.github/ISSUE_TEMPLATE/feature_request.md +0 -14
  174. package/.github/PULL_REQUEST_TEMPLATE.md +0 -13
  175. package/.github/workflows/ci.yml +0 -24
  176. package/dist/traces/index.d.ts +0 -49
  177. package/dist/traces/index.js +0 -102
  178. package/examples/README.md +0 -22
  179. package/examples/basic-agent.ts +0 -90
  180. package/examples/brain-integration.ts +0 -71
  181. package/examples/multi-channel.ts +0 -74
  182. package/src/traces/index.ts +0 -132
  183. package/test-agent/Dockerfile +0 -9
  184. package/test-agent/README.md +0 -50
  185. package/test-agent/agent.yaml +0 -23
  186. package/test-agent/docker-compose.yml +0 -11
  187. package/test-agent/oad.yaml +0 -31
  188. package/test-agent/package-lock.json +0 -1492
  189. package/test-agent/package.json +0 -18
  190. package/test-agent/src/index.ts +0 -24
  191. package/test-agent/src/skills/echo.ts +0 -15
  192. package/test-agent/tsconfig.json +0 -25
@@ -1,103 +1,103 @@
1
- import { defineConfig } from 'vitepress';
2
-
3
- export default defineConfig({
4
- title: 'OPC Agent',
5
- description: 'Open Agent Framework - Build, test, and run AI Agents for business workstations',
6
-
7
- locales: {
8
- root: {
9
- label: 'English',
10
- lang: 'en',
11
- themeConfig: {
12
- nav: [
13
- { text: 'Guide', link: '/guide/getting-started' },
14
- { text: 'API', link: '/api/oad-schema' },
15
- { text: 'GitHub', link: 'https://github.com/Deepleaper/opc-agent' },
16
- ],
17
- sidebar: {
18
- '/guide/': [
19
- {
20
- text: 'Introduction',
21
- items: [
22
- { text: 'Getting Started', link: '/guide/getting-started' },
23
- { text: 'Core Concepts', link: '/guide/concepts' },
24
- ],
25
- },
26
- {
27
- text: 'Usage',
28
- items: [
29
- { text: 'Templates', link: '/guide/templates' },
30
- { text: 'Configuration', link: '/guide/configuration' },
31
- { text: 'Testing', link: '/guide/testing' },
32
- { text: 'Deployment', link: '/guide/deployment' },
33
- ],
34
- },
35
- ],
36
- '/api/': [
37
- {
38
- text: 'Reference',
39
- items: [
40
- { text: 'OAD Schema', link: '/api/oad-schema' },
41
- { text: 'CLI Commands', link: '/api/cli' },
42
- { text: 'SDK', link: '/api/sdk' },
43
- ],
44
- },
45
- ],
46
- },
47
- },
48
- },
49
- zh: {
50
- label: '中文',
51
- lang: 'zh-CN',
52
- description: '开放智能体框架 — 构建、测试、运行企业级 AI 智能体',
53
- themeConfig: {
54
- nav: [
55
- { text: '指南', link: '/zh/guide/getting-started' },
56
- { text: 'API', link: '/zh/api/oad-schema' },
57
- { text: 'GitHub', link: 'https://github.com/Deepleaper/opc-agent' },
58
- ],
59
- sidebar: {
60
- '/zh/guide/': [
61
- {
62
- text: '入门',
63
- items: [
64
- { text: '快速开始', link: '/zh/guide/getting-started' },
65
- { text: '核心概念', link: '/zh/guide/concepts' },
66
- ],
67
- },
68
- {
69
- text: '使用',
70
- items: [
71
- { text: '模板', link: '/zh/guide/templates' },
72
- { text: '配置', link: '/zh/guide/configuration' },
73
- { text: '测试', link: '/zh/guide/testing' },
74
- { text: '部署', link: '/zh/guide/deployment' },
75
- ],
76
- },
77
- ],
78
- '/zh/api/': [
79
- {
80
- text: '参考',
81
- items: [
82
- { text: 'OAD Schema', link: '/zh/api/oad-schema' },
83
- { text: 'CLI 命令', link: '/zh/api/cli' },
84
- { text: 'SDK', link: '/zh/api/sdk' },
85
- ],
86
- },
87
- ],
88
- },
89
- },
90
- },
91
- },
92
-
93
- themeConfig: {
94
- logo: '/logo.svg',
95
- socialLinks: [
96
- { icon: 'github', link: 'https://github.com/Deepleaper/opc-agent' },
97
- ],
98
- footer: {
99
- message: 'Released under the Apache-2.0 License.',
100
- copyright: 'Copyright © 2025 Deepleaper 跃盟科技',
101
- },
102
- },
103
- });
1
+ import { defineConfig } from 'vitepress';
2
+
3
+ export default defineConfig({
4
+ title: 'OPC Agent',
5
+ description: 'Open Agent Framework - Build, test, and run AI Agents for business workstations',
6
+
7
+ locales: {
8
+ root: {
9
+ label: 'English',
10
+ lang: 'en',
11
+ themeConfig: {
12
+ nav: [
13
+ { text: 'Guide', link: '/guide/getting-started' },
14
+ { text: 'API', link: '/api/oad-schema' },
15
+ { text: 'GitHub', link: 'https://github.com/Deepleaper/opc-agent' },
16
+ ],
17
+ sidebar: {
18
+ '/guide/': [
19
+ {
20
+ text: 'Introduction',
21
+ items: [
22
+ { text: 'Getting Started', link: '/guide/getting-started' },
23
+ { text: 'Core Concepts', link: '/guide/concepts' },
24
+ ],
25
+ },
26
+ {
27
+ text: 'Usage',
28
+ items: [
29
+ { text: 'Templates', link: '/guide/templates' },
30
+ { text: 'Configuration', link: '/guide/configuration' },
31
+ { text: 'Testing', link: '/guide/testing' },
32
+ { text: 'Deployment', link: '/guide/deployment' },
33
+ ],
34
+ },
35
+ ],
36
+ '/api/': [
37
+ {
38
+ text: 'Reference',
39
+ items: [
40
+ { text: 'OAD Schema', link: '/api/oad-schema' },
41
+ { text: 'CLI Commands', link: '/api/cli' },
42
+ { text: 'SDK', link: '/api/sdk' },
43
+ ],
44
+ },
45
+ ],
46
+ },
47
+ },
48
+ },
49
+ zh: {
50
+ label: '中文',
51
+ lang: 'zh-CN',
52
+ description: '开放智能体框架 — 构建、测试、运行企业级 AI 智能体',
53
+ themeConfig: {
54
+ nav: [
55
+ { text: '指南', link: '/zh/guide/getting-started' },
56
+ { text: 'API', link: '/zh/api/oad-schema' },
57
+ { text: 'GitHub', link: 'https://github.com/Deepleaper/opc-agent' },
58
+ ],
59
+ sidebar: {
60
+ '/zh/guide/': [
61
+ {
62
+ text: '入门',
63
+ items: [
64
+ { text: '快速开始', link: '/zh/guide/getting-started' },
65
+ { text: '核心概念', link: '/zh/guide/concepts' },
66
+ ],
67
+ },
68
+ {
69
+ text: '使用',
70
+ items: [
71
+ { text: '模板', link: '/zh/guide/templates' },
72
+ { text: '配置', link: '/zh/guide/configuration' },
73
+ { text: '测试', link: '/zh/guide/testing' },
74
+ { text: '部署', link: '/zh/guide/deployment' },
75
+ ],
76
+ },
77
+ ],
78
+ '/zh/api/': [
79
+ {
80
+ text: '参考',
81
+ items: [
82
+ { text: 'OAD Schema', link: '/zh/api/oad-schema' },
83
+ { text: 'CLI 命令', link: '/zh/api/cli' },
84
+ { text: 'SDK', link: '/zh/api/sdk' },
85
+ ],
86
+ },
87
+ ],
88
+ },
89
+ },
90
+ },
91
+ },
92
+
93
+ themeConfig: {
94
+ logo: '/logo.svg',
95
+ socialLinks: [
96
+ { icon: 'github', link: 'https://github.com/Deepleaper/opc-agent' },
97
+ ],
98
+ footer: {
99
+ message: 'Released under the Apache-2.0 License.',
100
+ copyright: 'Copyright © 2025 Deepleaper 跃盟科技',
101
+ },
102
+ },
103
+ });
package/docs/api/cli.md CHANGED
@@ -1,48 +1,48 @@
1
- # CLI Commands
2
-
3
- ## Reference
4
-
5
- | Command | Description |
6
- |---------|-------------|
7
- | `opc init [name]` | Initialize a new agent project |
8
- | `opc run` | Start agent with web server |
9
- | `opc chat` | Interactive CLI chat |
10
- | `opc test` | Run agent tests |
11
- | `opc analytics` | Show usage analytics |
12
- | `opc info` | Show agent info from OAD |
13
- | `opc build` | Validate OAD |
14
- | `opc dev` | Hot-reload development mode |
15
- | `opc create <name>` | Create agent from template |
16
- | `opc deploy` | Deploy to OpenClaw or Hermes |
17
- | `opc publish` | Package for distribution |
18
- | `opc install <source>` | Install agent from package |
19
- | `opc search <query>` | Search OPC Registry |
20
- | `opc stats` | Show runtime stats |
21
- | `opc kb add <file>` | Add file to knowledge base |
22
- | `opc kb search <query>` | Search knowledge base |
23
- | `opc tool list` | List MCP tools |
24
- | `opc workflow run <name>` | Run a workflow |
25
- | `opc version-mgmt list` | List saved versions |
26
-
27
- ## Common Options
28
-
29
- - `-f, --file <file>` — OAD file path (default: `oad.yaml`)
30
- - `-t, --template <name>` — Template name
31
- - `-p, --port <port>` — Port override
32
- - `--json` — JSON output (for test/analytics)
33
-
34
- ## Examples
35
-
36
- ```bash
37
- # Create a new project
38
- opc init my-bot -t teacher
39
-
40
- # Run tests
41
- opc test --json
42
-
43
- # View analytics
44
- opc analytics
45
-
46
- # Deploy
47
- opc deploy --target openclaw --install
48
- ```
1
+ # CLI Commands
2
+
3
+ ## Reference
4
+
5
+ | Command | Description |
6
+ |---------|-------------|
7
+ | `opc init [name]` | Initialize a new agent project |
8
+ | `opc run` | Start agent with web server |
9
+ | `opc chat` | Interactive CLI chat |
10
+ | `opc test` | Run agent tests |
11
+ | `opc analytics` | Show usage analytics |
12
+ | `opc info` | Show agent info from OAD |
13
+ | `opc build` | Validate OAD |
14
+ | `opc dev` | Hot-reload development mode |
15
+ | `opc create <name>` | Create agent from template |
16
+ | `opc deploy` | Deploy to OpenClaw or Hermes |
17
+ | `opc publish` | Package for distribution |
18
+ | `opc install <source>` | Install agent from package |
19
+ | `opc search <query>` | Search OPC Registry |
20
+ | `opc stats` | Show runtime stats |
21
+ | `opc kb add <file>` | Add file to knowledge base |
22
+ | `opc kb search <query>` | Search knowledge base |
23
+ | `opc tool list` | List MCP tools |
24
+ | `opc workflow run <name>` | Run a workflow |
25
+ | `opc version-mgmt list` | List saved versions |
26
+
27
+ ## Common Options
28
+
29
+ - `-f, --file <file>` — OAD file path (default: `oad.yaml`)
30
+ - `-t, --template <name>` — Template name
31
+ - `-p, --port <port>` — Port override
32
+ - `--json` — JSON output (for test/analytics)
33
+
34
+ ## Examples
35
+
36
+ ```bash
37
+ # Create a new project
38
+ opc init my-bot -t teacher
39
+
40
+ # Run tests
41
+ opc test --json
42
+
43
+ # View analytics
44
+ opc analytics
45
+
46
+ # Deploy
47
+ opc deploy --target openclaw --install
48
+ ```
@@ -1,64 +1,64 @@
1
- # OAD Schema v1 Specification
2
-
3
- **OAD** (Open Agent Definition) is a declarative YAML/JSON format for defining AI agents.
4
-
5
- ## Full Schema
6
-
7
- ```yaml
8
- apiVersion: opc/v1 # Required. Must be "opc/v1"
9
- kind: Agent # Required. Must be "Agent"
10
-
11
- metadata:
12
- name: string # Required. Agent identifier
13
- version: string # Semver. Default: "1.0.0"
14
- description: string # Optional. Human-readable description
15
- author: string # Optional. Author name
16
- license: string # Default: "Apache-2.0"
17
- marketplace: # Optional. Marketplace settings
18
- certified: boolean # Default: false
19
- category: string # e.g., "customer-service"
20
-
21
- spec:
22
- provider: # LLM provider configuration
23
- default: string # Default provider. Default: "deepseek"
24
- allowed: string[] # Allowed providers. Default: ["openai", "deepseek", "qwen"]
25
- model: string # Model name. Default: "deepseek-chat"
26
- systemPrompt: string # System prompt for the agent
27
-
28
- skills: # List of skills
29
- - name: string # Skill identifier
30
- description: string # What the skill does
31
- config: object # Optional skill-specific config
32
-
33
- channels: # Communication channels
34
- - type: web|websocket|cli
35
- port: number # Port for web channels
36
- config: object # Optional channel config
37
-
38
- memory:
39
- shortTerm: boolean # Enable conversation memory. Default: true
40
- longTerm: boolean # Enable persistent memory. Default: false
41
- provider: string # Memory backend (optional)
42
-
43
- dtv:
44
- trust:
45
- level: sandbox|verified|certified|listed # Default: "sandbox"
46
- value:
47
- metrics: string[] # Metrics to track. Default: []
48
- ```
49
-
50
- ## Validation
51
-
52
- OAD files are validated using Zod schemas. Use the CLI to validate:
53
-
54
- ```bash
55
- opc build -f oad.yaml
56
- ```
57
-
58
- Or programmatically:
59
-
60
- ```typescript
61
- import { validateOAD } from 'opc-agent';
62
-
63
- const config = validateOAD(yamlData);
64
- ```
1
+ # OAD Schema v1 Specification
2
+
3
+ **OAD** (Open Agent Definition) is a declarative YAML/JSON format for defining AI agents.
4
+
5
+ ## Full Schema
6
+
7
+ ```yaml
8
+ apiVersion: opc/v1 # Required. Must be "opc/v1"
9
+ kind: Agent # Required. Must be "Agent"
10
+
11
+ metadata:
12
+ name: string # Required. Agent identifier
13
+ version: string # Semver. Default: "1.0.0"
14
+ description: string # Optional. Human-readable description
15
+ author: string # Optional. Author name
16
+ license: string # Default: "Apache-2.0"
17
+ marketplace: # Optional. Marketplace settings
18
+ certified: boolean # Default: false
19
+ category: string # e.g., "customer-service"
20
+
21
+ spec:
22
+ provider: # LLM provider configuration
23
+ default: string # Default provider. Default: "deepseek"
24
+ allowed: string[] # Allowed providers. Default: ["openai", "deepseek", "qwen"]
25
+ model: string # Model name. Default: "deepseek-chat"
26
+ systemPrompt: string # System prompt for the agent
27
+
28
+ skills: # List of skills
29
+ - name: string # Skill identifier
30
+ description: string # What the skill does
31
+ config: object # Optional skill-specific config
32
+
33
+ channels: # Communication channels
34
+ - type: web|websocket|cli
35
+ port: number # Port for web channels
36
+ config: object # Optional channel config
37
+
38
+ memory:
39
+ shortTerm: boolean # Enable conversation memory. Default: true
40
+ longTerm: boolean # Enable persistent memory. Default: false
41
+ provider: string # Memory backend (optional)
42
+
43
+ dtv:
44
+ trust:
45
+ level: sandbox|verified|certified|listed # Default: "sandbox"
46
+ value:
47
+ metrics: string[] # Metrics to track. Default: []
48
+ ```
49
+
50
+ ## Validation
51
+
52
+ OAD files are validated using Zod schemas. Use the CLI to validate:
53
+
54
+ ```bash
55
+ opc build -f oad.yaml
56
+ ```
57
+
58
+ Or programmatically:
59
+
60
+ ```typescript
61
+ import { validateOAD } from 'opc-agent';
62
+
63
+ const config = validateOAD(yamlData);
64
+ ```
package/docs/api/sdk.md CHANGED
@@ -1,80 +1,80 @@
1
- # SDK Reference
2
-
3
- ## Core Classes
4
-
5
- ### AgentRuntime
6
-
7
- ```typescript
8
- import { AgentRuntime } from 'opc-agent';
9
-
10
- const runtime = new AgentRuntime();
11
- await runtime.loadConfig('oad.yaml');
12
- const agent = await runtime.initialize();
13
- await runtime.start();
14
- ```
15
-
16
- ### AnalyticsEngine
17
-
18
- ```typescript
19
- import { AnalyticsEngine } from 'opc-agent';
20
-
21
- const engine = new AnalyticsEngine('.');
22
- engine.trackMessage('user-1', 250, 100, 50);
23
- engine.trackToolUse('search', true, 120);
24
- const stats = engine.getStats();
25
- ```
26
-
27
- ### RateLimiter
28
-
29
- ```typescript
30
- import { RateLimiter } from 'opc-agent';
31
-
32
- const limiter = new RateLimiter({
33
- userLimit: { maxRequests: 60, windowMs: 60000 },
34
- providerLimit: { maxRequests: 100, windowMs: 60000 },
35
- });
36
-
37
- await limiter.acquire('user-1', 'openai');
38
- ```
39
-
40
- ### LLMCache
41
-
42
- ```typescript
43
- import { LLMCache } from 'opc-agent';
44
-
45
- const cache = new LLMCache({ ttlMs: 3600000 });
46
- const key = LLMCache.makeKey(messages, systemPrompt);
47
- const cached = cache.get(key);
48
- if (!cached) {
49
- const response = await callLLM(messages);
50
- cache.set(key, response);
51
- }
52
- ```
53
-
54
- ### Testing
55
-
56
- ```typescript
57
- import { runTests, formatReport } from 'opc-agent';
58
-
59
- const report = await runTests('oad.yaml');
60
- console.log(formatReport(report));
61
- ```
62
-
63
- ## Templates
64
-
65
- 13 built-in templates:
66
-
67
- | Template | Description |
68
- |----------|-------------|
69
- | `customer-service` | FAQ + human handoff |
70
- | `sales-assistant` | Product Q&A + lead capture |
71
- | `knowledge-base` | RAG with DeepBrain |
72
- | `code-reviewer` | Bug detection + style checks |
73
- | `hr-recruiter` | Resume screening + interviews |
74
- | `project-manager` | Task tracking + meeting notes |
75
- | `content-writer` | Blog + social media + SEO |
76
- | `legal-assistant` | Contract review + compliance |
77
- | `financial-advisor` | Budget + expense tracking |
78
- | `executive-assistant` | Calendar + email + meetings |
79
- | `data-analyst` | Data querying + visualization |
80
- | `teacher` | Lesson plans + quizzes |
1
+ # SDK Reference
2
+
3
+ ## Core Classes
4
+
5
+ ### AgentRuntime
6
+
7
+ ```typescript
8
+ import { AgentRuntime } from 'opc-agent';
9
+
10
+ const runtime = new AgentRuntime();
11
+ await runtime.loadConfig('oad.yaml');
12
+ const agent = await runtime.initialize();
13
+ await runtime.start();
14
+ ```
15
+
16
+ ### AnalyticsEngine
17
+
18
+ ```typescript
19
+ import { AnalyticsEngine } from 'opc-agent';
20
+
21
+ const engine = new AnalyticsEngine('.');
22
+ engine.trackMessage('user-1', 250, 100, 50);
23
+ engine.trackToolUse('search', true, 120);
24
+ const stats = engine.getStats();
25
+ ```
26
+
27
+ ### RateLimiter
28
+
29
+ ```typescript
30
+ import { RateLimiter } from 'opc-agent';
31
+
32
+ const limiter = new RateLimiter({
33
+ userLimit: { maxRequests: 60, windowMs: 60000 },
34
+ providerLimit: { maxRequests: 100, windowMs: 60000 },
35
+ });
36
+
37
+ await limiter.acquire('user-1', 'openai');
38
+ ```
39
+
40
+ ### LLMCache
41
+
42
+ ```typescript
43
+ import { LLMCache } from 'opc-agent';
44
+
45
+ const cache = new LLMCache({ ttlMs: 3600000 });
46
+ const key = LLMCache.makeKey(messages, systemPrompt);
47
+ const cached = cache.get(key);
48
+ if (!cached) {
49
+ const response = await callLLM(messages);
50
+ cache.set(key, response);
51
+ }
52
+ ```
53
+
54
+ ### Testing
55
+
56
+ ```typescript
57
+ import { runTests, formatReport } from 'opc-agent';
58
+
59
+ const report = await runTests('oad.yaml');
60
+ console.log(formatReport(report));
61
+ ```
62
+
63
+ ## Templates
64
+
65
+ 13 built-in templates:
66
+
67
+ | Template | Description |
68
+ |----------|-------------|
69
+ | `customer-service` | FAQ + human handoff |
70
+ | `sales-assistant` | Product Q&A + lead capture |
71
+ | `knowledge-base` | RAG with DeepBrain |
72
+ | `code-reviewer` | Bug detection + style checks |
73
+ | `hr-recruiter` | Resume screening + interviews |
74
+ | `project-manager` | Task tracking + meeting notes |
75
+ | `content-writer` | Blog + social media + SEO |
76
+ | `legal-assistant` | Contract review + compliance |
77
+ | `financial-advisor` | Budget + expense tracking |
78
+ | `executive-assistant` | Calendar + email + meetings |
79
+ | `data-analyst` | Data querying + visualization |
80
+ | `teacher` | Lesson plans + quizzes |