opc-agent 1.1.0 → 1.1.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 (142) hide show
  1. package/CHANGELOG.md +51 -51
  2. package/CONTRIBUTING.md +75 -75
  3. package/README.md +341 -101
  4. package/README.zh-CN.md +382 -55
  5. package/dist/channels/web.js +256 -256
  6. package/dist/cli.js +1 -32
  7. package/dist/deploy/hermes.js +22 -22
  8. package/dist/deploy/openclaw.js +31 -31
  9. package/dist/i18n/index.js +60 -9
  10. package/dist/templates/code-reviewer.js +5 -5
  11. package/dist/templates/customer-service.js +2 -2
  12. package/dist/templates/data-analyst.js +5 -5
  13. package/dist/templates/knowledge-base.js +2 -2
  14. package/dist/templates/sales-assistant.js +4 -4
  15. package/dist/templates/teacher.js +6 -6
  16. package/docs/.vitepress/config.ts +103 -92
  17. package/docs/api/cli.md +48 -48
  18. package/docs/api/oad-schema.md +64 -64
  19. package/docs/api/sdk.md +80 -80
  20. package/docs/guide/concepts.md +51 -51
  21. package/docs/guide/configuration.md +79 -79
  22. package/docs/guide/deployment.md +42 -42
  23. package/docs/guide/getting-started.md +44 -44
  24. package/docs/guide/templates.md +28 -28
  25. package/docs/guide/testing.md +84 -84
  26. package/docs/index.md +27 -27
  27. package/docs/zh/api/cli.md +54 -0
  28. package/docs/zh/api/oad-schema.md +87 -3
  29. package/docs/zh/api/sdk.md +102 -0
  30. package/docs/zh/guide/concepts.md +104 -28
  31. package/docs/zh/guide/configuration.md +135 -39
  32. package/docs/zh/guide/deployment.md +81 -3
  33. package/docs/zh/guide/getting-started.md +82 -58
  34. package/docs/zh/guide/templates.md +84 -22
  35. package/docs/zh/guide/testing.md +88 -18
  36. package/docs/zh/index.md +27 -27
  37. package/examples/customer-service-demo/README.md +90 -90
  38. package/examples/customer-service-demo/oad.yaml +107 -107
  39. package/package.json +1 -1
  40. package/src/analytics/index.ts +66 -66
  41. package/src/channels/discord.ts +192 -192
  42. package/src/channels/email.ts +177 -177
  43. package/src/channels/feishu.ts +236 -236
  44. package/src/channels/index.ts +15 -15
  45. package/src/channels/slack.ts +160 -160
  46. package/src/channels/telegram.ts +90 -90
  47. package/src/channels/voice.ts +106 -106
  48. package/src/channels/web.ts +596 -596
  49. package/src/channels/webhook.ts +199 -199
  50. package/src/channels/websocket.ts +87 -87
  51. package/src/channels/wechat.ts +149 -149
  52. package/src/cli.ts +1 -35
  53. package/src/core/a2a.ts +143 -143
  54. package/src/core/agent.ts +152 -152
  55. package/src/core/analytics-engine.ts +186 -186
  56. package/src/core/auth.ts +57 -57
  57. package/src/core/cache.ts +141 -141
  58. package/src/core/compose.ts +77 -77
  59. package/src/core/config.ts +14 -14
  60. package/src/core/errors.ts +148 -148
  61. package/src/core/hitl.ts +138 -138
  62. package/src/core/knowledge.ts +210 -210
  63. package/src/core/logger.ts +57 -57
  64. package/src/core/orchestrator.ts +215 -215
  65. package/src/core/performance.ts +187 -187
  66. package/src/core/rate-limiter.ts +128 -128
  67. package/src/core/room.ts +109 -109
  68. package/src/core/runtime.ts +152 -152
  69. package/src/core/sandbox.ts +101 -101
  70. package/src/core/security.ts +171 -171
  71. package/src/core/types.ts +68 -68
  72. package/src/core/versioning.ts +106 -106
  73. package/src/core/watch.ts +178 -178
  74. package/src/core/workflow.ts +235 -235
  75. package/src/deploy/hermes.ts +156 -156
  76. package/src/deploy/openclaw.ts +200 -200
  77. package/src/dtv/data.ts +29 -29
  78. package/src/dtv/trust.ts +43 -43
  79. package/src/dtv/value.ts +47 -47
  80. package/src/i18n/index.ts +216 -165
  81. package/src/index.ts +110 -110
  82. package/src/marketplace/index.ts +223 -223
  83. package/src/memory/deepbrain.ts +108 -108
  84. package/src/memory/index.ts +34 -34
  85. package/src/plugins/index.ts +208 -208
  86. package/src/providers/index.ts +183 -183
  87. package/src/schema/oad.ts +155 -155
  88. package/src/skills/base.ts +16 -16
  89. package/src/skills/document.ts +100 -100
  90. package/src/skills/http.ts +35 -35
  91. package/src/skills/index.ts +27 -27
  92. package/src/skills/scheduler.ts +80 -80
  93. package/src/skills/webhook-trigger.ts +59 -59
  94. package/src/templates/code-reviewer.ts +34 -34
  95. package/src/templates/customer-service.ts +80 -80
  96. package/src/templates/data-analyst.ts +70 -70
  97. package/src/templates/executive-assistant.ts +71 -71
  98. package/src/templates/financial-advisor.ts +60 -60
  99. package/src/templates/knowledge-base.ts +31 -31
  100. package/src/templates/legal-assistant.ts +71 -71
  101. package/src/templates/sales-assistant.ts +79 -79
  102. package/src/templates/teacher.ts +79 -79
  103. package/src/testing/index.ts +181 -181
  104. package/src/tools/calculator.ts +73 -73
  105. package/src/tools/datetime.ts +149 -149
  106. package/src/tools/json-transform.ts +187 -187
  107. package/src/tools/mcp.ts +76 -76
  108. package/src/tools/text-analysis.ts +116 -116
  109. package/templates/Dockerfile +15 -15
  110. package/templates/code-reviewer/README.md +27 -27
  111. package/templates/code-reviewer/oad.yaml +41 -41
  112. package/templates/customer-service/README.md +22 -22
  113. package/templates/customer-service/oad.yaml +36 -36
  114. package/templates/docker-compose.yml +21 -21
  115. package/templates/knowledge-base/README.md +28 -28
  116. package/templates/knowledge-base/oad.yaml +38 -38
  117. package/templates/sales-assistant/README.md +26 -26
  118. package/templates/sales-assistant/oad.yaml +43 -43
  119. package/tests/a2a.test.ts +66 -66
  120. package/tests/agent.test.ts +72 -72
  121. package/tests/analytics.test.ts +50 -50
  122. package/tests/channel.test.ts +39 -39
  123. package/tests/e2e.test.ts +134 -134
  124. package/tests/errors.test.ts +83 -83
  125. package/tests/hitl.test.ts +71 -71
  126. package/tests/i18n.test.ts +41 -41
  127. package/tests/mcp.test.ts +54 -54
  128. package/tests/oad.test.ts +68 -68
  129. package/tests/performance.test.ts +115 -115
  130. package/tests/plugin.test.ts +74 -74
  131. package/tests/room.test.ts +106 -106
  132. package/tests/runtime.test.ts +42 -42
  133. package/tests/sandbox.test.ts +46 -46
  134. package/tests/security.test.ts +60 -60
  135. package/tests/templates.test.ts +77 -77
  136. package/tests/v070.test.ts +76 -76
  137. package/tests/versioning.test.ts +75 -75
  138. package/tests/voice.test.ts +61 -61
  139. package/tests/webhook.test.ts +29 -29
  140. package/tests/workflow.test.ts +143 -143
  141. package/tsconfig.json +19 -19
  142. package/vitest.config.ts +9 -9
@@ -1,34 +1,34 @@
1
- export const CODE_REVIEWER_SYSTEM_PROMPT = `You are an expert code reviewer. When given code:
2
- 1. Check for bugs, security issues, and performance problems
3
- 2. Suggest improvements for readability and maintainability
4
- 3. Follow language-specific best practices
5
- 4. Be constructive and explain your reasoning
6
- Rate severity: 🔴 Critical | 🟡 Warning | 🔵 Info`;
7
-
8
- export function createCodeReviewerConfig() {
9
- return {
10
- apiVersion: 'opc/v1' as const,
11
- kind: 'Agent' as const,
12
- metadata: {
13
- name: 'code-reviewer',
14
- version: '1.0.0',
15
- description: 'AI code reviewer that reviews code and suggests improvements',
16
- author: 'OPC Agent',
17
- license: 'Apache-2.0',
18
- },
19
- spec: {
20
- provider: { default: 'deepseek', allowed: ['openai', 'deepseek', 'qwen'] },
21
- model: 'deepseek-chat',
22
- systemPrompt: CODE_REVIEWER_SYSTEM_PROMPT,
23
- skills: [
24
- { name: 'code-analysis', description: 'Analyze code for bugs' },
25
- ],
26
- channels: [{ type: 'web' as const, port: 3000 }],
27
- memory: { shortTerm: true, longTerm: false },
28
- dtv: {
29
- trust: { level: 'sandbox' as const },
30
- value: { metrics: ['reviews_completed', 'issues_found'] },
31
- },
32
- },
33
- };
34
- }
1
+ export const CODE_REVIEWER_SYSTEM_PROMPT = `You are an expert code reviewer. When given code:
2
+ 1. Check for bugs, security issues, and performance problems
3
+ 2. Suggest improvements for readability and maintainability
4
+ 3. Follow language-specific best practices
5
+ 4. Be constructive and explain your reasoning
6
+ Rate severity: 🔴 Critical | 🟡 Warning | 🔵 Info`;
7
+
8
+ export function createCodeReviewerConfig() {
9
+ return {
10
+ apiVersion: 'opc/v1' as const,
11
+ kind: 'Agent' as const,
12
+ metadata: {
13
+ name: 'code-reviewer',
14
+ version: '1.0.0',
15
+ description: 'AI code reviewer that reviews code and suggests improvements',
16
+ author: 'OPC Agent',
17
+ license: 'Apache-2.0',
18
+ },
19
+ spec: {
20
+ provider: { default: 'deepseek', allowed: ['openai', 'deepseek', 'qwen'] },
21
+ model: 'deepseek-chat',
22
+ systemPrompt: CODE_REVIEWER_SYSTEM_PROMPT,
23
+ skills: [
24
+ { name: 'code-analysis', description: 'Analyze code for bugs' },
25
+ ],
26
+ channels: [{ type: 'web' as const, port: 3000 }],
27
+ memory: { shortTerm: true, longTerm: false },
28
+ dtv: {
29
+ trust: { level: 'sandbox' as const },
30
+ value: { metrics: ['reviews_completed', 'issues_found'] },
31
+ },
32
+ },
33
+ };
34
+ }
@@ -1,80 +1,80 @@
1
- import { BaseSkill } from '../skills/base';
2
- import type { AgentContext, Message, SkillResult } from '../core/types';
3
-
4
- const DEFAULT_FAQ: Record<string, string> = {
5
- 'hours': 'Our business hours are Monday-Friday, 9am-6pm.',
6
- 'return': 'You can return items within 30 days of purchase.',
7
- 'shipping': 'Standard shipping takes 3-5 business days.',
8
- 'contact': 'You can reach us at support@example.com.',
9
- };
10
-
11
- export class FAQSkill extends BaseSkill {
12
- name = 'faq-lookup';
13
- description = 'Look up FAQ answers';
14
- private faq: Record<string, string>;
15
-
16
- constructor(faq?: Record<string, string>) {
17
- super();
18
- this.faq = faq ?? DEFAULT_FAQ;
19
- }
20
-
21
- async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
22
- const lower = message.content.toLowerCase();
23
- for (const [key, answer] of Object.entries(this.faq)) {
24
- if (lower.includes(key)) {
25
- return this.match(answer, 0.9);
26
- }
27
- }
28
- return this.noMatch();
29
- }
30
- }
31
-
32
- export class HandoffSkill extends BaseSkill {
33
- name = 'human-handoff';
34
- description = 'Hand off to a human agent when confidence is low';
35
- private keywords = ['speak to human', 'talk to agent', 'real person', 'human agent'];
36
-
37
- async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
38
- const lower = message.content.toLowerCase();
39
- if (this.keywords.some((kw) => lower.includes(kw))) {
40
- return this.match(
41
- 'I understand you\'d like to speak with a human agent. Let me connect you now. Please hold.',
42
- 1.0
43
- );
44
- }
45
- return this.noMatch();
46
- }
47
- }
48
-
49
- export const CUSTOMER_SERVICE_SYSTEM_PROMPT = `You are a friendly and professional customer service agent.
50
- You help customers with their questions about products, orders, shipping, and returns.
51
- Be concise, helpful, and empathetic. If you're unsure, offer to connect them with a human agent.`;
52
-
53
- export function createCustomerServiceConfig() {
54
- return {
55
- apiVersion: 'opc/v1' as const,
56
- kind: 'Agent' as const,
57
- metadata: {
58
- name: 'customer-service',
59
- version: '1.0.0',
60
- description: 'Customer service agent with FAQ and human handoff',
61
- author: 'OPC Agent',
62
- license: 'Apache-2.0',
63
- },
64
- spec: {
65
- provider: { default: 'deepseek', allowed: ['openai', 'deepseek', 'qwen'] },
66
- model: 'deepseek-chat',
67
- systemPrompt: CUSTOMER_SERVICE_SYSTEM_PROMPT,
68
- skills: [
69
- { name: 'faq-lookup', description: 'Look up FAQ answers' },
70
- { name: 'human-handoff', description: 'Hand off to human agent' },
71
- ],
72
- channels: [{ type: 'web' as const, port: 3000 }],
73
- memory: { shortTerm: true, longTerm: false },
74
- dtv: {
75
- trust: { level: 'sandbox' as const },
76
- value: { metrics: ['response_time', 'satisfaction_score'] },
77
- },
78
- },
79
- };
80
- }
1
+ import { BaseSkill } from '../skills/base';
2
+ import type { AgentContext, Message, SkillResult } from '../core/types';
3
+
4
+ const DEFAULT_FAQ: Record<string, string> = {
5
+ 'hours': 'Our business hours are Monday-Friday, 9am-6pm.',
6
+ 'return': 'You can return items within 30 days of purchase.',
7
+ 'shipping': 'Standard shipping takes 3-5 business days.',
8
+ 'contact': 'You can reach us at support@example.com.',
9
+ };
10
+
11
+ export class FAQSkill extends BaseSkill {
12
+ name = 'faq-lookup';
13
+ description = 'Look up FAQ answers';
14
+ private faq: Record<string, string>;
15
+
16
+ constructor(faq?: Record<string, string>) {
17
+ super();
18
+ this.faq = faq ?? DEFAULT_FAQ;
19
+ }
20
+
21
+ async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
22
+ const lower = message.content.toLowerCase();
23
+ for (const [key, answer] of Object.entries(this.faq)) {
24
+ if (lower.includes(key)) {
25
+ return this.match(answer, 0.9);
26
+ }
27
+ }
28
+ return this.noMatch();
29
+ }
30
+ }
31
+
32
+ export class HandoffSkill extends BaseSkill {
33
+ name = 'human-handoff';
34
+ description = 'Hand off to a human agent when confidence is low';
35
+ private keywords = ['speak to human', 'talk to agent', 'real person', 'human agent'];
36
+
37
+ async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
38
+ const lower = message.content.toLowerCase();
39
+ if (this.keywords.some((kw) => lower.includes(kw))) {
40
+ return this.match(
41
+ 'I understand you\'d like to speak with a human agent. Let me connect you now. Please hold.',
42
+ 1.0
43
+ );
44
+ }
45
+ return this.noMatch();
46
+ }
47
+ }
48
+
49
+ export const CUSTOMER_SERVICE_SYSTEM_PROMPT = `You are a friendly and professional customer service agent.
50
+ You help customers with their questions about products, orders, shipping, and returns.
51
+ Be concise, helpful, and empathetic. If you're unsure, offer to connect them with a human agent.`;
52
+
53
+ export function createCustomerServiceConfig() {
54
+ return {
55
+ apiVersion: 'opc/v1' as const,
56
+ kind: 'Agent' as const,
57
+ metadata: {
58
+ name: 'customer-service',
59
+ version: '1.0.0',
60
+ description: 'Customer service agent with FAQ and human handoff',
61
+ author: 'OPC Agent',
62
+ license: 'Apache-2.0',
63
+ },
64
+ spec: {
65
+ provider: { default: 'deepseek', allowed: ['openai', 'deepseek', 'qwen'] },
66
+ model: 'deepseek-chat',
67
+ systemPrompt: CUSTOMER_SERVICE_SYSTEM_PROMPT,
68
+ skills: [
69
+ { name: 'faq-lookup', description: 'Look up FAQ answers' },
70
+ { name: 'human-handoff', description: 'Hand off to human agent' },
71
+ ],
72
+ channels: [{ type: 'web' as const, port: 3000 }],
73
+ memory: { shortTerm: true, longTerm: false },
74
+ dtv: {
75
+ trust: { level: 'sandbox' as const },
76
+ value: { metrics: ['response_time', 'satisfaction_score'] },
77
+ },
78
+ },
79
+ };
80
+ }
@@ -1,70 +1,70 @@
1
- import { BaseSkill } from '../skills/base';
2
- import type { AgentContext, Message, SkillResult } from '../core/types';
3
-
4
- export class DataQuerySkill extends BaseSkill {
5
- name = 'data-query';
6
- description = 'Help users query and analyze data';
7
-
8
- async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
9
- const lower = message.content.toLowerCase();
10
- if (lower.includes('average') || lower.includes('mean') || lower.includes('sum') || lower.includes('count')) {
11
- return this.match('I can help with that calculation. Could you share the dataset or describe the data source?', 0.8);
12
- }
13
- if (lower.includes('chart') || lower.includes('graph') || lower.includes('visualize') || lower.includes('plot')) {
14
- return this.match('I can help create visualizations. What type of chart would you like? (bar, line, pie, scatter)', 0.85);
15
- }
16
- if (lower.includes('csv') || lower.includes('excel') || lower.includes('spreadsheet')) {
17
- return this.match('I can analyze CSV/Excel data. Please share the file or paste the data.', 0.8);
18
- }
19
- return this.noMatch();
20
- }
21
- }
22
-
23
- export class InsightSkill extends BaseSkill {
24
- name = 'insight-generator';
25
- description = 'Generate insights from data patterns';
26
-
27
- async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
28
- const lower = message.content.toLowerCase();
29
- if (lower.includes('trend') || lower.includes('pattern') || lower.includes('insight') || lower.includes('anomaly')) {
30
- return this.match('I\'ll analyze the data for trends and anomalies. Please provide the dataset or describe what you\'re looking for.', 0.8);
31
- }
32
- return this.noMatch();
33
- }
34
- }
35
-
36
- export const DATA_ANALYST_SYSTEM_PROMPT = `You are a professional data analyst assistant. Your goals:
37
- 1. Help users query, transform, and analyze data
38
- 2. Create clear visualizations and summaries
39
- 3. Identify trends, patterns, and anomalies
40
- 4. Explain findings in plain language
41
- Be precise with numbers, always cite your data source, and suggest next steps for deeper analysis.`;
42
-
43
- export function createDataAnalystConfig() {
44
- return {
45
- apiVersion: 'opc/v1' as const,
46
- kind: 'Agent' as const,
47
- metadata: {
48
- name: 'data-analyst',
49
- version: '1.0.0',
50
- description: 'AI data analyst with data querying, visualization, and insight generation',
51
- author: 'OPC Agent',
52
- license: 'Apache-2.0',
53
- },
54
- spec: {
55
- provider: { default: 'openai', allowed: ['openai', 'deepseek', 'qwen'] },
56
- model: 'gpt-4o-mini',
57
- systemPrompt: DATA_ANALYST_SYSTEM_PROMPT,
58
- skills: [
59
- { name: 'data-query', description: 'Query and transform data' },
60
- { name: 'insight-generator', description: 'Generate data insights' },
61
- ],
62
- channels: [{ type: 'web' as const, port: 3000 }],
63
- memory: { shortTerm: true, longTerm: true },
64
- dtv: {
65
- trust: { level: 'sandbox' as const },
66
- value: { metrics: ['queries_processed', 'insights_generated'] },
67
- },
68
- },
69
- };
70
- }
1
+ import { BaseSkill } from '../skills/base';
2
+ import type { AgentContext, Message, SkillResult } from '../core/types';
3
+
4
+ export class DataQuerySkill extends BaseSkill {
5
+ name = 'data-query';
6
+ description = 'Help users query and analyze data';
7
+
8
+ async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
9
+ const lower = message.content.toLowerCase();
10
+ if (lower.includes('average') || lower.includes('mean') || lower.includes('sum') || lower.includes('count')) {
11
+ return this.match('I can help with that calculation. Could you share the dataset or describe the data source?', 0.8);
12
+ }
13
+ if (lower.includes('chart') || lower.includes('graph') || lower.includes('visualize') || lower.includes('plot')) {
14
+ return this.match('I can help create visualizations. What type of chart would you like? (bar, line, pie, scatter)', 0.85);
15
+ }
16
+ if (lower.includes('csv') || lower.includes('excel') || lower.includes('spreadsheet')) {
17
+ return this.match('I can analyze CSV/Excel data. Please share the file or paste the data.', 0.8);
18
+ }
19
+ return this.noMatch();
20
+ }
21
+ }
22
+
23
+ export class InsightSkill extends BaseSkill {
24
+ name = 'insight-generator';
25
+ description = 'Generate insights from data patterns';
26
+
27
+ async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
28
+ const lower = message.content.toLowerCase();
29
+ if (lower.includes('trend') || lower.includes('pattern') || lower.includes('insight') || lower.includes('anomaly')) {
30
+ return this.match('I\'ll analyze the data for trends and anomalies. Please provide the dataset or describe what you\'re looking for.', 0.8);
31
+ }
32
+ return this.noMatch();
33
+ }
34
+ }
35
+
36
+ export const DATA_ANALYST_SYSTEM_PROMPT = `You are a professional data analyst assistant. Your goals:
37
+ 1. Help users query, transform, and analyze data
38
+ 2. Create clear visualizations and summaries
39
+ 3. Identify trends, patterns, and anomalies
40
+ 4. Explain findings in plain language
41
+ Be precise with numbers, always cite your data source, and suggest next steps for deeper analysis.`;
42
+
43
+ export function createDataAnalystConfig() {
44
+ return {
45
+ apiVersion: 'opc/v1' as const,
46
+ kind: 'Agent' as const,
47
+ metadata: {
48
+ name: 'data-analyst',
49
+ version: '1.0.0',
50
+ description: 'AI data analyst with data querying, visualization, and insight generation',
51
+ author: 'OPC Agent',
52
+ license: 'Apache-2.0',
53
+ },
54
+ spec: {
55
+ provider: { default: 'openai', allowed: ['openai', 'deepseek', 'qwen'] },
56
+ model: 'gpt-4o-mini',
57
+ systemPrompt: DATA_ANALYST_SYSTEM_PROMPT,
58
+ skills: [
59
+ { name: 'data-query', description: 'Query and transform data' },
60
+ { name: 'insight-generator', description: 'Generate data insights' },
61
+ ],
62
+ channels: [{ type: 'web' as const, port: 3000 }],
63
+ memory: { shortTerm: true, longTerm: true },
64
+ dtv: {
65
+ trust: { level: 'sandbox' as const },
66
+ value: { metrics: ['queries_processed', 'insights_generated'] },
67
+ },
68
+ },
69
+ };
70
+ }
@@ -1,71 +1,71 @@
1
- import { BaseSkill } from '../skills/base';
2
- import type { AgentContext, Message, SkillResult } from '../core/types';
3
- import type { OADDocument } from '../schema/oad';
4
-
5
- export class CalendarSkill extends BaseSkill {
6
- name = 'calendar-management';
7
- description = 'Manage calendar and scheduling';
8
-
9
- async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
10
- const lower = message.content.toLowerCase();
11
- if (lower.includes('schedule') || lower.includes('meeting') || lower.includes('calendar')) {
12
- return this.match('I can help manage your calendar. I can schedule meetings, check availability, send invites, and set reminders. What would you like to do?', 0.8);
13
- }
14
- if (lower.includes('remind') || lower.includes('reminder')) {
15
- return this.match('I\'ll set a reminder for you. Please provide the date, time, and what you\'d like to be reminded about.', 0.75);
16
- }
17
- return this.noMatch();
18
- }
19
- }
20
-
21
- export class EmailDraftSkill extends BaseSkill {
22
- name = 'email-drafting';
23
- description = 'Draft professional emails';
24
-
25
- async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
26
- const lower = message.content.toLowerCase();
27
- if (lower.includes('email') || lower.includes('draft') || lower.includes('write')) {
28
- return this.match('I can draft emails for you. Please provide: the recipient, subject, key points to cover, and desired tone (formal/casual/friendly).', 0.8);
29
- }
30
- return this.noMatch();
31
- }
32
- }
33
-
34
- export class MeetingPrepSkill extends BaseSkill {
35
- name = 'meeting-prep';
36
- description = 'Prepare for meetings with agendas and notes';
37
-
38
- async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
39
- const lower = message.content.toLowerCase();
40
- if (lower.includes('agenda') || lower.includes('prep') || lower.includes('prepare')) {
41
- return this.match('I can prepare meeting materials including: agenda creation, attendee briefings, talking points, action item tracking, and follow-up summaries.', 0.8);
42
- }
43
- return this.noMatch();
44
- }
45
- }
46
-
47
- export function createExecutiveAssistantConfig(): OADDocument {
48
- return {
49
- apiVersion: 'opc/v1',
50
- kind: 'Agent',
51
- metadata: {
52
- name: 'executive-assistant',
53
- version: '1.0.0',
54
- description: 'AI Executive Assistant - calendar management, email drafting, meeting prep',
55
- author: 'OPC',
56
- license: 'Apache-2.0',
57
- },
58
- spec: {
59
- model: 'deepseek-chat',
60
- systemPrompt: 'You are an executive assistant AI. Help users manage their calendar, draft emails, and prepare for meetings. Be professional, concise, and proactive.',
61
- skills: [
62
- { name: 'calendar-management', description: 'Manage calendar and scheduling' },
63
- { name: 'email-drafting', description: 'Draft professional emails' },
64
- { name: 'meeting-prep', description: 'Prepare meeting materials' },
65
- ],
66
- channels: [{ type: 'web', port: 3000 }],
67
- memory: { shortTerm: true, longTerm: false },
68
- streaming: false,
69
- },
70
- };
71
- }
1
+ import { BaseSkill } from '../skills/base';
2
+ import type { AgentContext, Message, SkillResult } from '../core/types';
3
+ import type { OADDocument } from '../schema/oad';
4
+
5
+ export class CalendarSkill extends BaseSkill {
6
+ name = 'calendar-management';
7
+ description = 'Manage calendar and scheduling';
8
+
9
+ async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
10
+ const lower = message.content.toLowerCase();
11
+ if (lower.includes('schedule') || lower.includes('meeting') || lower.includes('calendar')) {
12
+ return this.match('I can help manage your calendar. I can schedule meetings, check availability, send invites, and set reminders. What would you like to do?', 0.8);
13
+ }
14
+ if (lower.includes('remind') || lower.includes('reminder')) {
15
+ return this.match('I\'ll set a reminder for you. Please provide the date, time, and what you\'d like to be reminded about.', 0.75);
16
+ }
17
+ return this.noMatch();
18
+ }
19
+ }
20
+
21
+ export class EmailDraftSkill extends BaseSkill {
22
+ name = 'email-drafting';
23
+ description = 'Draft professional emails';
24
+
25
+ async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
26
+ const lower = message.content.toLowerCase();
27
+ if (lower.includes('email') || lower.includes('draft') || lower.includes('write')) {
28
+ return this.match('I can draft emails for you. Please provide: the recipient, subject, key points to cover, and desired tone (formal/casual/friendly).', 0.8);
29
+ }
30
+ return this.noMatch();
31
+ }
32
+ }
33
+
34
+ export class MeetingPrepSkill extends BaseSkill {
35
+ name = 'meeting-prep';
36
+ description = 'Prepare for meetings with agendas and notes';
37
+
38
+ async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
39
+ const lower = message.content.toLowerCase();
40
+ if (lower.includes('agenda') || lower.includes('prep') || lower.includes('prepare')) {
41
+ return this.match('I can prepare meeting materials including: agenda creation, attendee briefings, talking points, action item tracking, and follow-up summaries.', 0.8);
42
+ }
43
+ return this.noMatch();
44
+ }
45
+ }
46
+
47
+ export function createExecutiveAssistantConfig(): OADDocument {
48
+ return {
49
+ apiVersion: 'opc/v1',
50
+ kind: 'Agent',
51
+ metadata: {
52
+ name: 'executive-assistant',
53
+ version: '1.0.0',
54
+ description: 'AI Executive Assistant - calendar management, email drafting, meeting prep',
55
+ author: 'OPC',
56
+ license: 'Apache-2.0',
57
+ },
58
+ spec: {
59
+ model: 'deepseek-chat',
60
+ systemPrompt: 'You are an executive assistant AI. Help users manage their calendar, draft emails, and prepare for meetings. Be professional, concise, and proactive.',
61
+ skills: [
62
+ { name: 'calendar-management', description: 'Manage calendar and scheduling' },
63
+ { name: 'email-drafting', description: 'Draft professional emails' },
64
+ { name: 'meeting-prep', description: 'Prepare meeting materials' },
65
+ ],
66
+ channels: [{ type: 'web', port: 3000 }],
67
+ memory: { shortTerm: true, longTerm: false },
68
+ streaming: false,
69
+ },
70
+ };
71
+ }
@@ -1,60 +1,60 @@
1
- import { BaseSkill } from '../skills/base';
2
- import type { AgentContext, Message, SkillResult } from '../core/types';
3
- import type { OADDocument } from '../schema/oad';
4
-
5
- export class BudgetAnalysisSkill extends BaseSkill {
6
- name = 'budget-analysis';
7
- description = 'Analyze budgets and expenses';
8
-
9
- async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
10
- const lower = message.content.toLowerCase();
11
- if (lower.includes('budget') || lower.includes('expense') || lower.includes('cost')) {
12
- return this.match('I can help analyze your budget. Please share your income and expense categories, and I\'ll provide insights on spending patterns and savings opportunities.', 0.8);
13
- }
14
- if (lower.includes('save') || lower.includes('saving')) {
15
- return this.match('Common savings strategies: 50/30/20 rule (needs/wants/savings), automate transfers, review subscriptions, negotiate bills, and track daily spending.', 0.75);
16
- }
17
- return this.noMatch();
18
- }
19
- }
20
-
21
- export class FinancialPlanningSkill extends BaseSkill {
22
- name = 'financial-planning';
23
- description = 'Help with financial planning and advice';
24
-
25
- async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
26
- const lower = message.content.toLowerCase();
27
- if (lower.includes('invest') || lower.includes('portfolio')) {
28
- return this.match('For investment planning, consider: risk tolerance, time horizon, diversification, asset allocation, and regular rebalancing. This is general guidance — consult a certified financial advisor for personalized advice.', 0.8);
29
- }
30
- if (lower.includes('retire') || lower.includes('pension')) {
31
- return this.match('Retirement planning essentials: estimate target savings (25x annual expenses), maximize employer matching, consider tax-advantaged accounts, and start early for compound growth.', 0.8);
32
- }
33
- return this.noMatch();
34
- }
35
- }
36
-
37
- export function createFinancialAdvisorConfig(): OADDocument {
38
- return {
39
- apiVersion: 'opc/v1',
40
- kind: 'Agent',
41
- metadata: {
42
- name: 'financial-advisor',
43
- version: '1.0.0',
44
- description: 'AI Financial Advisor - budget analysis, expense tracking, financial planning',
45
- author: 'OPC',
46
- license: 'Apache-2.0',
47
- },
48
- spec: {
49
- model: 'deepseek-chat',
50
- systemPrompt: 'You are a financial advisor AI. Help users with budget analysis, expense tracking, and financial planning. Always recommend consulting a certified financial advisor for binding decisions.',
51
- skills: [
52
- { name: 'budget-analysis', description: 'Analyze budgets and expenses' },
53
- { name: 'financial-planning', description: 'Financial planning advice' },
54
- ],
55
- channels: [{ type: 'web', port: 3000 }],
56
- memory: { shortTerm: true, longTerm: false },
57
- streaming: false,
58
- },
59
- };
60
- }
1
+ import { BaseSkill } from '../skills/base';
2
+ import type { AgentContext, Message, SkillResult } from '../core/types';
3
+ import type { OADDocument } from '../schema/oad';
4
+
5
+ export class BudgetAnalysisSkill extends BaseSkill {
6
+ name = 'budget-analysis';
7
+ description = 'Analyze budgets and expenses';
8
+
9
+ async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
10
+ const lower = message.content.toLowerCase();
11
+ if (lower.includes('budget') || lower.includes('expense') || lower.includes('cost')) {
12
+ return this.match('I can help analyze your budget. Please share your income and expense categories, and I\'ll provide insights on spending patterns and savings opportunities.', 0.8);
13
+ }
14
+ if (lower.includes('save') || lower.includes('saving')) {
15
+ return this.match('Common savings strategies: 50/30/20 rule (needs/wants/savings), automate transfers, review subscriptions, negotiate bills, and track daily spending.', 0.75);
16
+ }
17
+ return this.noMatch();
18
+ }
19
+ }
20
+
21
+ export class FinancialPlanningSkill extends BaseSkill {
22
+ name = 'financial-planning';
23
+ description = 'Help with financial planning and advice';
24
+
25
+ async execute(_context: AgentContext, message: Message): Promise<SkillResult> {
26
+ const lower = message.content.toLowerCase();
27
+ if (lower.includes('invest') || lower.includes('portfolio')) {
28
+ return this.match('For investment planning, consider: risk tolerance, time horizon, diversification, asset allocation, and regular rebalancing. This is general guidance — consult a certified financial advisor for personalized advice.', 0.8);
29
+ }
30
+ if (lower.includes('retire') || lower.includes('pension')) {
31
+ return this.match('Retirement planning essentials: estimate target savings (25x annual expenses), maximize employer matching, consider tax-advantaged accounts, and start early for compound growth.', 0.8);
32
+ }
33
+ return this.noMatch();
34
+ }
35
+ }
36
+
37
+ export function createFinancialAdvisorConfig(): OADDocument {
38
+ return {
39
+ apiVersion: 'opc/v1',
40
+ kind: 'Agent',
41
+ metadata: {
42
+ name: 'financial-advisor',
43
+ version: '1.0.0',
44
+ description: 'AI Financial Advisor - budget analysis, expense tracking, financial planning',
45
+ author: 'OPC',
46
+ license: 'Apache-2.0',
47
+ },
48
+ spec: {
49
+ model: 'deepseek-chat',
50
+ systemPrompt: 'You are a financial advisor AI. Help users with budget analysis, expense tracking, and financial planning. Always recommend consulting a certified financial advisor for binding decisions.',
51
+ skills: [
52
+ { name: 'budget-analysis', description: 'Analyze budgets and expenses' },
53
+ { name: 'financial-planning', description: 'Financial planning advice' },
54
+ ],
55
+ channels: [{ type: 'web', port: 3000 }],
56
+ memory: { shortTerm: true, longTerm: false },
57
+ streaming: false,
58
+ },
59
+ };
60
+ }