opc-agent 1.3.1 → 1.3.2

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 (160) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/CONTRIBUTING.md +75 -75
  3. package/README.md +358 -235
  4. package/README.zh-CN.md +415 -415
  5. package/dist/cli.js +34 -118
  6. package/dist/core/dashboard.d.ts +35 -0
  7. package/dist/core/dashboard.js +157 -0
  8. package/dist/core/priority.d.ts +52 -0
  9. package/dist/core/priority.js +102 -0
  10. package/dist/deploy/hermes.js +22 -22
  11. package/dist/deploy/openclaw.js +40 -31
  12. package/dist/index.d.ts +10 -3
  13. package/dist/index.js +15 -6
  14. package/dist/schema/oad.d.ts +2 -1
  15. package/dist/templates/code-reviewer.d.ts +8 -0
  16. package/dist/templates/code-reviewer.js +9 -5
  17. package/dist/templates/customer-service.d.ts +8 -0
  18. package/dist/templates/customer-service.js +6 -2
  19. package/dist/templates/data-analyst.d.ts +8 -0
  20. package/dist/templates/data-analyst.js +9 -5
  21. package/dist/templates/knowledge-base.d.ts +8 -0
  22. package/dist/templates/knowledge-base.js +6 -2
  23. package/dist/templates/sales-assistant.d.ts +8 -0
  24. package/dist/templates/sales-assistant.js +8 -4
  25. package/dist/templates/teacher.d.ts +8 -0
  26. package/dist/templates/teacher.js +10 -6
  27. package/docs/.vitepress/config.ts +103 -103
  28. package/docs/api/cli.md +48 -48
  29. package/docs/api/oad-schema.md +64 -64
  30. package/docs/api/sdk.md +80 -80
  31. package/docs/guide/concepts.md +51 -51
  32. package/docs/guide/configuration.md +79 -79
  33. package/docs/guide/deployment.md +42 -42
  34. package/docs/guide/getting-started.md +44 -44
  35. package/docs/guide/templates.md +28 -28
  36. package/docs/guide/testing.md +84 -84
  37. package/docs/index.md +27 -27
  38. package/docs/zh/api/cli.md +54 -54
  39. package/docs/zh/api/oad-schema.md +87 -87
  40. package/docs/zh/api/sdk.md +102 -102
  41. package/docs/zh/guide/concepts.md +104 -104
  42. package/docs/zh/guide/configuration.md +135 -135
  43. package/docs/zh/guide/deployment.md +81 -81
  44. package/docs/zh/guide/getting-started.md +82 -82
  45. package/docs/zh/guide/templates.md +84 -84
  46. package/docs/zh/guide/testing.md +88 -88
  47. package/docs/zh/index.md +27 -27
  48. package/examples/customer-service-demo/README.md +90 -90
  49. package/examples/customer-service-demo/oad.yaml +107 -107
  50. package/package.json +1 -1
  51. package/src/analytics/index.ts +66 -66
  52. package/src/channels/discord.ts +192 -192
  53. package/src/channels/email.ts +177 -177
  54. package/src/channels/feishu.ts +236 -236
  55. package/src/channels/index.ts +15 -15
  56. package/src/channels/slack.ts +160 -160
  57. package/src/channels/telegram.ts +90 -90
  58. package/src/channels/voice.ts +106 -106
  59. package/src/channels/webhook.ts +199 -199
  60. package/src/channels/websocket.ts +87 -87
  61. package/src/channels/wechat.ts +149 -149
  62. package/src/cli.ts +32 -124
  63. package/src/core/a2a.ts +143 -143
  64. package/src/core/agent.ts +152 -152
  65. package/src/core/analytics-engine.ts +186 -186
  66. package/src/core/auth.ts +57 -57
  67. package/src/core/cache.ts +141 -141
  68. package/src/core/compose.ts +77 -77
  69. package/src/core/config.ts +14 -14
  70. package/src/core/dashboard.ts +219 -0
  71. package/src/core/errors.ts +148 -148
  72. package/src/core/hitl.ts +138 -138
  73. package/src/core/logger.ts +57 -57
  74. package/src/core/orchestrator.ts +215 -215
  75. package/src/core/performance.ts +187 -187
  76. package/src/core/priority.ts +140 -0
  77. package/src/core/rate-limiter.ts +128 -128
  78. package/src/core/room.ts +109 -109
  79. package/src/core/runtime.ts +152 -152
  80. package/src/core/sandbox.ts +101 -101
  81. package/src/core/security.ts +171 -171
  82. package/src/core/types.ts +68 -68
  83. package/src/core/versioning.ts +106 -106
  84. package/src/core/watch.ts +178 -178
  85. package/src/core/workflow.ts +235 -235
  86. package/src/deploy/hermes.ts +156 -156
  87. package/src/deploy/openclaw.ts +200 -190
  88. package/src/dtv/data.ts +29 -0
  89. package/src/dtv/trust.ts +43 -0
  90. package/src/dtv/value.ts +47 -0
  91. package/src/i18n/index.ts +216 -216
  92. package/src/index.ts +10 -3
  93. package/src/marketplace/index.ts +223 -0
  94. package/src/memory/deepbrain.ts +108 -108
  95. package/src/memory/index.ts +34 -34
  96. package/src/plugins/index.ts +208 -208
  97. package/src/schema/oad.ts +155 -154
  98. package/src/skills/base.ts +16 -16
  99. package/src/skills/document.ts +100 -100
  100. package/src/skills/http.ts +35 -35
  101. package/src/skills/index.ts +27 -27
  102. package/src/skills/scheduler.ts +80 -80
  103. package/src/skills/webhook-trigger.ts +59 -59
  104. package/src/templates/code-reviewer.ts +34 -30
  105. package/src/templates/customer-service.ts +80 -76
  106. package/src/templates/data-analyst.ts +70 -66
  107. package/src/templates/executive-assistant.ts +71 -71
  108. package/src/templates/financial-advisor.ts +60 -60
  109. package/src/templates/knowledge-base.ts +31 -27
  110. package/src/templates/legal-assistant.ts +71 -71
  111. package/src/templates/sales-assistant.ts +79 -75
  112. package/src/templates/teacher.ts +79 -75
  113. package/src/testing/index.ts +181 -181
  114. package/src/tools/calculator.ts +73 -73
  115. package/src/tools/datetime.ts +149 -149
  116. package/src/tools/json-transform.ts +187 -187
  117. package/src/tools/mcp.ts +76 -76
  118. package/src/tools/text-analysis.ts +116 -116
  119. package/templates/Dockerfile +15 -15
  120. package/templates/code-reviewer/README.md +27 -27
  121. package/templates/code-reviewer/oad.yaml +41 -41
  122. package/templates/customer-service/README.md +22 -22
  123. package/templates/customer-service/oad.yaml +36 -36
  124. package/templates/docker-compose.yml +21 -21
  125. package/templates/ecommerce-assistant/README.md +45 -45
  126. package/templates/ecommerce-assistant/oad.yaml +47 -47
  127. package/templates/knowledge-base/README.md +28 -28
  128. package/templates/knowledge-base/oad.yaml +38 -38
  129. package/templates/sales-assistant/README.md +26 -26
  130. package/templates/sales-assistant/oad.yaml +43 -43
  131. package/templates/tech-support/README.md +43 -43
  132. package/templates/tech-support/oad.yaml +45 -45
  133. package/tests/a2a.test.ts +66 -66
  134. package/tests/agent.test.ts +72 -72
  135. package/tests/analytics.test.ts +50 -50
  136. package/tests/channel.test.ts +39 -39
  137. package/tests/e2e.test.ts +134 -134
  138. package/tests/errors.test.ts +83 -83
  139. package/tests/hitl.test.ts +71 -71
  140. package/tests/i18n.test.ts +41 -41
  141. package/tests/mcp.test.ts +54 -54
  142. package/tests/oad.test.ts +68 -68
  143. package/tests/performance.test.ts +115 -115
  144. package/tests/plugin.test.ts +74 -74
  145. package/tests/room.test.ts +106 -106
  146. package/tests/runtime.test.ts +42 -42
  147. package/tests/sandbox.test.ts +46 -46
  148. package/tests/security.test.ts +60 -60
  149. package/tests/templates.test.ts +77 -77
  150. package/tests/v070.test.ts +76 -76
  151. package/tests/versioning.test.ts +75 -75
  152. package/tests/voice.test.ts +61 -61
  153. package/tests/webhook.test.ts +29 -29
  154. package/tests/workflow.test.ts +143 -143
  155. package/tsconfig.json +19 -19
  156. package/vitest.config.ts +9 -9
  157. package/.github/workflows/ci.yml +0 -24
  158. package/dist/traces/index.d.ts +0 -49
  159. package/dist/traces/index.js +0 -102
  160. package/src/traces/index.ts +0 -132
@@ -1,156 +1,156 @@
1
- /**
2
- * Hermes Agent Adapter - Convert OAD → Hermes Agent config
3
- */
4
- import * as fs from 'fs';
5
- import * as path from 'path';
6
- import type { OADDocument } from '../schema/oad';
7
-
8
- export interface HermesDeployOptions {
9
- oad: OADDocument;
10
- outputDir: string;
11
- }
12
-
13
- export interface HermesDeployResult {
14
- outputDir: string;
15
- files: string[];
16
- }
17
-
18
- interface HermesCharacter {
19
- name: string;
20
- description: string;
21
- personality: string;
22
- system: string;
23
- bio: string[];
24
- lore: string[];
25
- messageExamples: Array<Array<{ user: string; content: { text: string } }>>;
26
- postExamples: string[];
27
- topics: string[];
28
- adjectives: string[];
29
- style: {
30
- all: string[];
31
- chat: string[];
32
- post: string[];
33
- };
34
- plugins: string[];
35
- settings: {
36
- model: string;
37
- voice: { model: string };
38
- secrets: Record<string, string>;
39
- };
40
- }
41
-
42
- function oadToHermesCharacter(oad: OADDocument): HermesCharacter {
43
- const m = oad.metadata;
44
- const s = oad.spec;
45
- const prompt = s.systemPrompt ?? 'You are a helpful AI agent.';
46
-
47
- // Extract personality traits from system prompt
48
- const lines = prompt.split('\n').filter(l => l.trim());
49
- const bio = lines.slice(0, 3).map(l => l.replace(/^[-*#]\s*/, '').trim());
50
-
51
- return {
52
- name: m.name,
53
- description: m.description ?? `${m.name} - AI Agent`,
54
- personality: prompt.slice(0, 500),
55
- system: prompt,
56
- bio: bio.length > 0 ? bio : [`${m.name} is an AI agent built with OPC Agent framework.`],
57
- lore: [`Created with OPC Agent v${m.version}`, `Licensed under ${m.license}`],
58
- messageExamples: [
59
- [
60
- { user: '{{user1}}', content: { text: 'Hello!' } },
61
- { user: m.name, content: { text: 'Hi there! How can I help you today?' } },
62
- ],
63
- ],
64
- postExamples: [],
65
- topics: s.skills.map(sk => sk.name),
66
- adjectives: ['helpful', 'knowledgeable', 'professional'],
67
- style: {
68
- all: ['Be helpful and professional', 'Use clear language'],
69
- chat: ['Respond conversationally', 'Be concise but thorough'],
70
- post: ['Share useful insights', 'Be informative'],
71
- },
72
- plugins: s.skills.map(sk => sk.name),
73
- settings: {
74
- model: s.model,
75
- voice: { model: 'en_US-neutral' },
76
- secrets: {},
77
- },
78
- };
79
- }
80
-
81
- function generateHermesSettings(oad: OADDocument): Record<string, any> {
82
- return {
83
- name: oad.metadata.name,
84
- version: oad.metadata.version,
85
- runtime: {
86
- provider: oad.spec.provider?.default ?? 'openai',
87
- model: oad.spec.model,
88
- temperature: 0.7,
89
- maxTokens: 2048,
90
- },
91
- channels: oad.spec.channels.map(ch => ({
92
- type: ch.type,
93
- enabled: true,
94
- config: ch.config ?? {},
95
- })),
96
- memory: {
97
- enabled: !!oad.spec.memory,
98
- provider: typeof oad.spec.memory?.longTerm === 'object'
99
- ? oad.spec.memory.longTerm.provider
100
- : 'in-memory',
101
- },
102
- };
103
- }
104
-
105
- export function deployToHermes(options: HermesDeployOptions): HermesDeployResult {
106
- const { oad, outputDir } = options;
107
- const files: string[] = [];
108
-
109
- fs.mkdirSync(outputDir, { recursive: true });
110
-
111
- // character.json
112
- const character = oadToHermesCharacter(oad);
113
- const charPath = path.join(outputDir, 'character.json');
114
- fs.writeFileSync(charPath, JSON.stringify(character, null, 2), 'utf-8');
115
- files.push('character.json');
116
-
117
- // settings.json
118
- const settings = generateHermesSettings(oad);
119
- const settingsPath = path.join(outputDir, 'settings.json');
120
- fs.writeFileSync(settingsPath, JSON.stringify(settings, null, 2), 'utf-8');
121
- files.push('settings.json');
122
-
123
- // .env template
124
- const envContent = `# Hermes Agent Environment
125
- HERMES_CHARACTER=${oad.metadata.name}
126
- HERMES_MODEL=${oad.spec.model}
127
- HERMES_PROVIDER=${oad.spec.provider?.default ?? 'openai'}
128
- # Add your API keys below:
129
- # OPENAI_API_KEY=
130
- # DEEPSEEK_API_KEY=
131
- `;
132
- fs.writeFileSync(path.join(outputDir, '.env.hermes'), envContent, 'utf-8');
133
- files.push('.env.hermes');
134
-
135
- // README
136
- const readme = `# ${oad.metadata.name} - Hermes Agent
137
-
138
- Converted from OAD format using \`opc deploy --target hermes\`.
139
-
140
- ## Usage
141
-
142
- 1. Copy \`character.json\` to your Hermes agents directory
143
- 2. Configure \`.env.hermes\` with your API keys
144
- 3. Start Hermes with this character
145
-
146
- ## Files
147
-
148
- - \`character.json\` - Agent character definition
149
- - \`settings.json\` - Runtime settings
150
- - \`.env.hermes\` - Environment template
151
- `;
152
- fs.writeFileSync(path.join(outputDir, 'README.md'), readme, 'utf-8');
153
- files.push('README.md');
154
-
155
- return { outputDir, files };
156
- }
1
+ /**
2
+ * Hermes Agent Adapter - Convert OAD → Hermes Agent config
3
+ */
4
+ import * as fs from 'fs';
5
+ import * as path from 'path';
6
+ import type { OADDocument } from '../schema/oad';
7
+
8
+ export interface HermesDeployOptions {
9
+ oad: OADDocument;
10
+ outputDir: string;
11
+ }
12
+
13
+ export interface HermesDeployResult {
14
+ outputDir: string;
15
+ files: string[];
16
+ }
17
+
18
+ interface HermesCharacter {
19
+ name: string;
20
+ description: string;
21
+ personality: string;
22
+ system: string;
23
+ bio: string[];
24
+ lore: string[];
25
+ messageExamples: Array<Array<{ user: string; content: { text: string } }>>;
26
+ postExamples: string[];
27
+ topics: string[];
28
+ adjectives: string[];
29
+ style: {
30
+ all: string[];
31
+ chat: string[];
32
+ post: string[];
33
+ };
34
+ plugins: string[];
35
+ settings: {
36
+ model: string;
37
+ voice: { model: string };
38
+ secrets: Record<string, string>;
39
+ };
40
+ }
41
+
42
+ function oadToHermesCharacter(oad: OADDocument): HermesCharacter {
43
+ const m = oad.metadata;
44
+ const s = oad.spec;
45
+ const prompt = s.systemPrompt ?? 'You are a helpful AI agent.';
46
+
47
+ // Extract personality traits from system prompt
48
+ const lines = prompt.split('\n').filter(l => l.trim());
49
+ const bio = lines.slice(0, 3).map(l => l.replace(/^[-*#]\s*/, '').trim());
50
+
51
+ return {
52
+ name: m.name,
53
+ description: m.description ?? `${m.name} - AI Agent`,
54
+ personality: prompt.slice(0, 500),
55
+ system: prompt,
56
+ bio: bio.length > 0 ? bio : [`${m.name} is an AI agent built with OPC Agent framework.`],
57
+ lore: [`Created with OPC Agent v${m.version}`, `Licensed under ${m.license}`],
58
+ messageExamples: [
59
+ [
60
+ { user: '{{user1}}', content: { text: 'Hello!' } },
61
+ { user: m.name, content: { text: 'Hi there! How can I help you today?' } },
62
+ ],
63
+ ],
64
+ postExamples: [],
65
+ topics: s.skills.map(sk => sk.name),
66
+ adjectives: ['helpful', 'knowledgeable', 'professional'],
67
+ style: {
68
+ all: ['Be helpful and professional', 'Use clear language'],
69
+ chat: ['Respond conversationally', 'Be concise but thorough'],
70
+ post: ['Share useful insights', 'Be informative'],
71
+ },
72
+ plugins: s.skills.map(sk => sk.name),
73
+ settings: {
74
+ model: s.model,
75
+ voice: { model: 'en_US-neutral' },
76
+ secrets: {},
77
+ },
78
+ };
79
+ }
80
+
81
+ function generateHermesSettings(oad: OADDocument): Record<string, any> {
82
+ return {
83
+ name: oad.metadata.name,
84
+ version: oad.metadata.version,
85
+ runtime: {
86
+ provider: oad.spec.provider?.default ?? 'openai',
87
+ model: oad.spec.model,
88
+ temperature: 0.7,
89
+ maxTokens: 2048,
90
+ },
91
+ channels: oad.spec.channels.map(ch => ({
92
+ type: ch.type,
93
+ enabled: true,
94
+ config: ch.config ?? {},
95
+ })),
96
+ memory: {
97
+ enabled: !!oad.spec.memory,
98
+ provider: typeof oad.spec.memory?.longTerm === 'object'
99
+ ? oad.spec.memory.longTerm.provider
100
+ : 'in-memory',
101
+ },
102
+ };
103
+ }
104
+
105
+ export function deployToHermes(options: HermesDeployOptions): HermesDeployResult {
106
+ const { oad, outputDir } = options;
107
+ const files: string[] = [];
108
+
109
+ fs.mkdirSync(outputDir, { recursive: true });
110
+
111
+ // character.json
112
+ const character = oadToHermesCharacter(oad);
113
+ const charPath = path.join(outputDir, 'character.json');
114
+ fs.writeFileSync(charPath, JSON.stringify(character, null, 2), 'utf-8');
115
+ files.push('character.json');
116
+
117
+ // settings.json
118
+ const settings = generateHermesSettings(oad);
119
+ const settingsPath = path.join(outputDir, 'settings.json');
120
+ fs.writeFileSync(settingsPath, JSON.stringify(settings, null, 2), 'utf-8');
121
+ files.push('settings.json');
122
+
123
+ // .env template
124
+ const envContent = `# Hermes Agent Environment
125
+ HERMES_CHARACTER=${oad.metadata.name}
126
+ HERMES_MODEL=${oad.spec.model}
127
+ HERMES_PROVIDER=${oad.spec.provider?.default ?? 'openai'}
128
+ # Add your API keys below:
129
+ # OPENAI_API_KEY=
130
+ # DEEPSEEK_API_KEY=
131
+ `;
132
+ fs.writeFileSync(path.join(outputDir, '.env.hermes'), envContent, 'utf-8');
133
+ files.push('.env.hermes');
134
+
135
+ // README
136
+ const readme = `# ${oad.metadata.name} - Hermes Agent
137
+
138
+ Converted from OAD format using \`opc deploy --target hermes\`.
139
+
140
+ ## Usage
141
+
142
+ 1. Copy \`character.json\` to your Hermes agents directory
143
+ 2. Configure \`.env.hermes\` with your API keys
144
+ 3. Start Hermes with this character
145
+
146
+ ## Files
147
+
148
+ - \`character.json\` - Agent character definition
149
+ - \`settings.json\` - Runtime settings
150
+ - \`.env.hermes\` - Environment template
151
+ `;
152
+ fs.writeFileSync(path.join(outputDir, 'README.md'), readme, 'utf-8');
153
+ files.push('README.md');
154
+
155
+ return { outputDir, files };
156
+ }