@agentica/core 0.44.0-dev.20260313 → 0.44.0

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 (150) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +218 -218
  3. package/lib/context/internal/__IChatInitialApplication.d.ts +1 -2
  4. package/lib/errors/AgenticaJsonParseError.js +6 -6
  5. package/lib/index.mjs +47 -1
  6. package/lib/index.mjs.map +1 -1
  7. package/lib/orchestrate/call.js +16 -16
  8. package/lib/orchestrate/initialize.js +43 -1
  9. package/lib/orchestrate/initialize.js.map +1 -1
  10. package/lib/structures/IAgenticaController.d.ts +143 -143
  11. package/lib/utils/ChatGptCompletionMessageUtil.js +6 -6
  12. package/package.json +6 -6
  13. package/prompts/cancel.md +5 -5
  14. package/prompts/common.md +3 -3
  15. package/prompts/describe.md +7 -7
  16. package/prompts/execute.md +122 -122
  17. package/prompts/initialize.md +3 -3
  18. package/prompts/json_parse_error.md +35 -35
  19. package/prompts/select.md +7 -7
  20. package/prompts/validate.md +123 -123
  21. package/prompts/validate_repeated.md +31 -31
  22. package/src/Agentica.ts +367 -367
  23. package/src/MicroAgentica.ts +357 -357
  24. package/src/constants/AgenticaConstant.ts +4 -4
  25. package/src/constants/AgenticaDefaultPrompt.ts +44 -44
  26. package/src/constants/index.ts +2 -2
  27. package/src/context/AgenticaContext.ts +136 -136
  28. package/src/context/AgenticaContextRequestResult.ts +14 -14
  29. package/src/context/AgenticaOperation.ts +73 -73
  30. package/src/context/AgenticaOperationCollection.ts +49 -49
  31. package/src/context/AgenticaOperationSelection.ts +9 -9
  32. package/src/context/AgenticaTokenUsage.ts +186 -186
  33. package/src/context/MicroAgenticaContext.ts +99 -99
  34. package/src/context/index.ts +5 -5
  35. package/src/context/internal/AgenticaOperationComposer.ts +177 -177
  36. package/src/context/internal/AgenticaTokenUsageAggregator.ts +66 -66
  37. package/src/context/internal/__IChatCancelFunctionsApplication.ts +23 -23
  38. package/src/context/internal/__IChatFunctionReference.ts +21 -21
  39. package/src/context/internal/__IChatInitialApplication.ts +13 -15
  40. package/src/context/internal/__IChatSelectFunctionsApplication.ts +24 -24
  41. package/src/context/internal/isAgenticaContext.ts +11 -11
  42. package/src/errors/AgenticaJsonParseError.ts +52 -52
  43. package/src/errors/AgenticaValidationError.ts +49 -49
  44. package/src/errors/index.ts +2 -2
  45. package/src/events/AgenticaAssistantMessageEvent.ts +12 -12
  46. package/src/events/AgenticaCallEvent.ts +27 -27
  47. package/src/events/AgenticaCancelEvent.ts +9 -9
  48. package/src/events/AgenticaDescribeEvent.ts +14 -14
  49. package/src/events/AgenticaEvent.ts +59 -59
  50. package/src/events/AgenticaEvent.type.ts +19 -19
  51. package/src/events/AgenticaEventBase.ts +18 -18
  52. package/src/events/AgenticaEventSource.ts +6 -6
  53. package/src/events/AgenticaExecuteEvent.ts +45 -45
  54. package/src/events/AgenticaInitializeEvent.ts +7 -7
  55. package/src/events/AgenticaJsonParseErrorEvent.ts +16 -16
  56. package/src/events/AgenticaRequestEvent.ts +27 -27
  57. package/src/events/AgenticaResponseEvent.ts +32 -32
  58. package/src/events/AgenticaSelectEvent.ts +11 -11
  59. package/src/events/AgenticaUserMessageEvent.ts +12 -12
  60. package/src/events/AgenticaValidateEvent.ts +32 -32
  61. package/src/events/MicroAgenticaEvent.ts +45 -45
  62. package/src/events/index.ts +15 -15
  63. package/src/factory/events.ts +357 -357
  64. package/src/factory/histories.ts +348 -348
  65. package/src/factory/index.ts +3 -3
  66. package/src/factory/operations.ts +16 -16
  67. package/src/functional/assertHttpController.ts +106 -106
  68. package/src/functional/assertHttpLlmApplication.ts +52 -52
  69. package/src/functional/assertMcpController.ts +47 -47
  70. package/src/functional/createMcpLlmApplication.ts +72 -72
  71. package/src/functional/index.ts +7 -7
  72. package/src/functional/validateHttpController.ts +113 -113
  73. package/src/functional/validateHttpLlmApplication.ts +65 -65
  74. package/src/functional/validateMcpController.ts +53 -53
  75. package/src/histories/AgenticaAssistantMessageHistory.ts +10 -10
  76. package/src/histories/AgenticaCancelHistory.ts +8 -8
  77. package/src/histories/AgenticaDescribeHistory.ts +18 -18
  78. package/src/histories/AgenticaExecuteHistory.ts +64 -64
  79. package/src/histories/AgenticaHistory.ts +28 -28
  80. package/src/histories/AgenticaHistoryBase.ts +35 -35
  81. package/src/histories/AgenticaSelectHistory.ts +8 -8
  82. package/src/histories/AgenticaSystemMessageHistory.ts +10 -10
  83. package/src/histories/AgenticaUserMessageHistory.ts +11 -11
  84. package/src/histories/MicroAgenticaHistory.ts +19 -19
  85. package/src/histories/contents/AgenticaUserMessageAudioContent.ts +21 -21
  86. package/src/histories/contents/AgenticaUserMessageContent.ts +19 -19
  87. package/src/histories/contents/AgenticaUserMessageContentBase.ts +6 -6
  88. package/src/histories/contents/AgenticaUserMessageFileContent.ts +25 -25
  89. package/src/histories/contents/AgenticaUserMessageImageContent.ts +33 -33
  90. package/src/histories/contents/AgenticaUserMessageTextContent.ts +15 -15
  91. package/src/histories/contents/index.ts +5 -5
  92. package/src/histories/index.ts +10 -10
  93. package/src/index.ts +15 -15
  94. package/src/json/IAgenticaEventJson.ts +265 -265
  95. package/src/json/IAgenticaEventJson.type.ts +19 -19
  96. package/src/json/IAgenticaHistoryJson.ts +165 -165
  97. package/src/json/IAgenticaHistoryJson.type.ts +19 -19
  98. package/src/json/IAgenticaOperationJson.ts +36 -36
  99. package/src/json/IAgenticaOperationSelectionJson.ts +26 -26
  100. package/src/json/IAgenticaTokenUsageJson.ts +107 -107
  101. package/src/json/IMicroAgenticaEventJson.ts +22 -22
  102. package/src/json/IMicroAgenticaHistoryJson.ts +25 -25
  103. package/src/json/index.ts +7 -7
  104. package/src/orchestrate/call.ts +542 -542
  105. package/src/orchestrate/cancel.ts +265 -265
  106. package/src/orchestrate/describe.ts +66 -66
  107. package/src/orchestrate/execute.ts +61 -61
  108. package/src/orchestrate/index.ts +6 -6
  109. package/src/orchestrate/initialize.ts +102 -102
  110. package/src/orchestrate/internal/cancelFunctionFromContext.ts +33 -33
  111. package/src/orchestrate/internal/selectFunctionFromContext.ts +34 -34
  112. package/src/orchestrate/select.ts +320 -320
  113. package/src/structures/IAgenticaConfig.ts +83 -83
  114. package/src/structures/IAgenticaConfigBase.ts +87 -87
  115. package/src/structures/IAgenticaController.ts +143 -143
  116. package/src/structures/IAgenticaExecutor.ts +167 -167
  117. package/src/structures/IAgenticaProps.ts +78 -78
  118. package/src/structures/IAgenticaSystemPrompt.ts +236 -236
  119. package/src/structures/IAgenticaVendor.ts +54 -54
  120. package/src/structures/IMcpTool.ts +60 -60
  121. package/src/structures/IMicroAgenticaConfig.ts +56 -56
  122. package/src/structures/IMicroAgenticaExecutor.ts +67 -67
  123. package/src/structures/IMicroAgenticaProps.ts +77 -77
  124. package/src/structures/IMicroAgenticaSystemPrompt.ts +169 -169
  125. package/src/structures/index.ts +10 -10
  126. package/src/transformers/transformHistory.ts +172 -172
  127. package/src/utils/AssistantMessageEmptyError.ts +20 -20
  128. package/src/utils/AsyncQueue.spec.ts +355 -355
  129. package/src/utils/AsyncQueue.ts +95 -95
  130. package/src/utils/ByteArrayUtil.ts +5 -5
  131. package/src/utils/ChatGptCompletionMessageUtil.spec.ts +314 -314
  132. package/src/utils/ChatGptCompletionMessageUtil.ts +210 -210
  133. package/src/utils/ChatGptCompletionStreamingUtil.spec.ts +909 -909
  134. package/src/utils/ChatGptCompletionStreamingUtil.ts +91 -91
  135. package/src/utils/ChatGptTokenUsageAggregator.spec.ts +226 -226
  136. package/src/utils/ChatGptTokenUsageAggregator.ts +57 -57
  137. package/src/utils/MPSC.spec.ts +276 -276
  138. package/src/utils/MPSC.ts +42 -42
  139. package/src/utils/Singleton.spec.ts +138 -138
  140. package/src/utils/Singleton.ts +42 -42
  141. package/src/utils/StreamUtil.spec.ts +512 -512
  142. package/src/utils/StreamUtil.ts +87 -87
  143. package/src/utils/__map_take.spec.ts +140 -140
  144. package/src/utils/__map_take.ts +13 -13
  145. package/src/utils/__retry.spec.ts +198 -198
  146. package/src/utils/__retry.ts +18 -18
  147. package/src/utils/assertExecuteFailure.ts +16 -16
  148. package/src/utils/index.ts +4 -4
  149. package/src/utils/request.ts +140 -140
  150. package/src/utils/types.ts +50 -50
@@ -1,265 +1,265 @@
1
- import type OpenAI from "openai";
2
- import type { ILlmFunction, IValidation } from "typia";
3
-
4
- import typia from "typia";
5
-
6
- import type { AgenticaContext } from "../context/AgenticaContext";
7
- import type { AgenticaOperation } from "../context/AgenticaOperation";
8
- import type { AgenticaOperationSelection } from "../context/AgenticaOperationSelection";
9
- import type { __IChatCancelFunctionsApplication } from "../context/internal/__IChatCancelFunctionsApplication";
10
- import type { __IChatFunctionReference } from "../context/internal/__IChatFunctionReference";
11
- import type { AgenticaCancelEvent } from "../events/AgenticaCancelEvent";
12
- import type { AgenticaEvent } from "../events/AgenticaEvent";
13
-
14
- import { AgenticaConstant } from "../constants/AgenticaConstant";
15
- import { AgenticaDefaultPrompt } from "../constants/AgenticaDefaultPrompt";
16
- import { AgenticaSystemPrompt } from "../constants/AgenticaSystemPrompt";
17
- import { decodeHistory, decodeUserMessageContent } from "../factory/histories";
18
- import { ChatGptCompletionMessageUtil } from "../utils/ChatGptCompletionMessageUtil";
19
- import { StreamUtil } from "../utils/StreamUtil";
20
-
21
- import { cancelFunctionFromContext } from "./internal/cancelFunctionFromContext";
22
-
23
- const FUNCTION: ILlmFunction = typia.llm.application<
24
- __IChatCancelFunctionsApplication
25
- >().functions[0]!;
26
-
27
- interface IFailure {
28
- id: string;
29
- name: string;
30
- validation: IValidation.IFailure;
31
- }
32
-
33
- export async function cancel(
34
- ctx: AgenticaContext,
35
- ): Promise<void> {
36
- if (ctx.operations.divided === undefined) {
37
- return step(ctx, ctx.operations.array, 0);
38
- }
39
-
40
- const stacks: AgenticaOperationSelection[][]
41
- = ctx.operations.divided.map(() => []);
42
- const events: AgenticaEvent[] = [];
43
- await Promise.all(
44
- ctx.operations.divided.map(async (operations, i) =>
45
- step(
46
- {
47
- ...ctx,
48
- stack: stacks[i]!,
49
- dispatch: async (e) => {
50
- events.push(e);
51
- },
52
- },
53
- operations,
54
- 0,
55
- ),
56
- ),
57
- );
58
-
59
- // ELITICISM
60
- if (
61
- (ctx.config?.eliticism ?? AgenticaConstant.ELITICISM) === true
62
- && stacks.some(s => s.length !== 0)
63
- ) {
64
- return step(
65
- ctx,
66
- stacks
67
- .flat()
68
- .map(
69
- s =>
70
- ctx.operations.group
71
- .get(s.operation.controller.name)!
72
- .get(s.operation.function.name)!,
73
- ),
74
- 0,
75
- );
76
- }
77
- else {
78
- const cancelled: AgenticaCancelEvent[]
79
- = events.filter(e => e.type === "cancel");
80
- (cancelled.length !== 0 ? cancelled : events)
81
- .forEach((e) => {
82
- void ctx.dispatch(e).catch(() => {});
83
- });
84
- }
85
- }
86
-
87
- async function step(
88
- ctx: AgenticaContext,
89
- operations: AgenticaOperation[],
90
- retry: number,
91
- failures?: IFailure[],
92
- ): Promise<void> {
93
- // ----
94
- // EXECUTE CHATGPT API
95
- // ----
96
- const result = await ctx.request("cancel", {
97
- messages: [
98
- // CANDIDATE FUNCTIONS
99
- {
100
- role: "assistant",
101
- tool_calls: [
102
- {
103
- type: "function",
104
- id: "getApiFunctions",
105
- function: {
106
- name: "getApiFunctions",
107
- arguments: JSON.stringify({}),
108
- },
109
- },
110
- ],
111
- },
112
- {
113
- role: "tool",
114
- tool_call_id: "getApiFunctions",
115
- content: JSON.stringify(
116
- operations.map(op => ({
117
- name: op.name,
118
- description: op.function.description,
119
- ...(op.protocol === "http"
120
- ? {
121
- method: op.function.method,
122
- path: op.function.path,
123
- tags: op.function.tags,
124
- }
125
- : {}),
126
- })),
127
- ),
128
- },
129
- // PREVIOUS HISTORIES
130
- ...ctx.histories.map(decodeHistory).flat(),
131
- // USER INPUT
132
- {
133
- role: "user",
134
- content: ctx.prompt.contents.map(decodeUserMessageContent),
135
- },
136
- // SYSTEM PROMPT
137
- {
138
- role: "system",
139
- content:
140
- ctx.config?.systemPrompt?.cancel?.(ctx.histories)
141
- ?? AgenticaSystemPrompt.CANCEL,
142
- },
143
- // TYPE CORRECTIONS
144
- ...emendMessages(failures ?? []),
145
- {
146
- role: "system",
147
- content: AgenticaDefaultPrompt.write(ctx.config),
148
- },
149
- ],
150
- // STACK FUNCTIONS
151
- tools: [{
152
- type: "function",
153
- function: {
154
- name: FUNCTION.name,
155
- description: FUNCTION.description,
156
- /**
157
- * @TODO fix it
158
- * The property and value have a type mismatch, but it works.
159
- */
160
- parameters: FUNCTION.parameters as Record<string, any>,
161
- },
162
- } satisfies OpenAI.ChatCompletionTool],
163
- tool_choice: retry === 0
164
- ? "auto"
165
- : "required",
166
- // parallel_tool_calls: true,
167
- });
168
-
169
- const completion = await (async () => {
170
- if (result.type === "none-stream") {
171
- return result.value;
172
- }
173
- return ChatGptCompletionMessageUtil.merge(await StreamUtil.readAll(result.value));
174
- })();
175
-
176
- // ----
177
- // VALIDATION
178
- // ----
179
- if (retry++ < (ctx.config?.retry ?? AgenticaConstant.RETRY)) {
180
- const failures: IFailure[] = [];
181
- for (const choice of (completion.choices ?? [])) {
182
- for (const tc of choice.message.tool_calls ?? []) {
183
- if (tc.type !== "function" || tc.function.name !== "cancelFunctions") {
184
- continue;
185
- }
186
-
187
- const input: object = FUNCTION.parse(tc.function.arguments) as object;
188
- const validation: IValidation<__IChatFunctionReference.IProps>
189
- = FUNCTION.validate(input) as IValidation<__IChatFunctionReference.IProps>;
190
- if (validation.success === false) {
191
- failures.push({
192
- id: tc.id,
193
- name: tc.function.name,
194
- validation,
195
- });
196
- }
197
- }
198
- }
199
- if (failures.length > 0) {
200
- return step(ctx, operations, retry, failures);
201
- }
202
- }
203
-
204
- // ----
205
- // PROCESS COMPLETION
206
- // ----
207
- for (const choice of (completion.choices ?? [])) {
208
- // TOOL CALLING HANDLER
209
- if (choice.message.tool_calls != null) {
210
- for (const tc of choice.message.tool_calls) {
211
- if (tc.type !== "function") {
212
- continue;
213
- }
214
- else if (tc.function.name !== "cancelFunctions") {
215
- continue;
216
- }
217
-
218
- const input: __IChatFunctionReference.IProps | null
219
- = typia.json.isParse<
220
- __IChatFunctionReference.IProps
221
- >(tc.function.arguments);
222
- if (input === null) {
223
- continue;
224
- }
225
-
226
- for (const reference of input.functions) {
227
- cancelFunctionFromContext(ctx, reference);
228
- }
229
- }
230
- }
231
- }
232
- }
233
-
234
- function emendMessages(failures: IFailure[]): OpenAI.ChatCompletionMessageParam[] {
235
- return failures
236
- .map(f => [
237
- {
238
- role: "assistant",
239
- tool_calls: [
240
- {
241
- type: "function",
242
- id: f.id,
243
- function: {
244
- name: f.name,
245
- arguments: JSON.stringify(f.validation.data),
246
- },
247
- },
248
- ],
249
- } satisfies OpenAI.ChatCompletionAssistantMessageParam,
250
- {
251
- role: "tool",
252
- content: JSON.stringify(f.validation.errors),
253
- tool_call_id: f.id,
254
- } satisfies OpenAI.ChatCompletionToolMessageParam,
255
- {
256
- role: "system",
257
- content: [
258
- "You A.I. assistant has composed wrong typed arguments.",
259
- "",
260
- "Correct it at the next function calling.",
261
- ].join("\n"),
262
- } satisfies OpenAI.ChatCompletionSystemMessageParam,
263
- ])
264
- .flat();
265
- }
1
+ import type OpenAI from "openai";
2
+ import type { ILlmFunction, IValidation } from "typia";
3
+
4
+ import typia from "typia";
5
+
6
+ import type { AgenticaContext } from "../context/AgenticaContext";
7
+ import type { AgenticaOperation } from "../context/AgenticaOperation";
8
+ import type { AgenticaOperationSelection } from "../context/AgenticaOperationSelection";
9
+ import type { __IChatCancelFunctionsApplication } from "../context/internal/__IChatCancelFunctionsApplication";
10
+ import type { __IChatFunctionReference } from "../context/internal/__IChatFunctionReference";
11
+ import type { AgenticaCancelEvent } from "../events/AgenticaCancelEvent";
12
+ import type { AgenticaEvent } from "../events/AgenticaEvent";
13
+
14
+ import { AgenticaConstant } from "../constants/AgenticaConstant";
15
+ import { AgenticaDefaultPrompt } from "../constants/AgenticaDefaultPrompt";
16
+ import { AgenticaSystemPrompt } from "../constants/AgenticaSystemPrompt";
17
+ import { decodeHistory, decodeUserMessageContent } from "../factory/histories";
18
+ import { ChatGptCompletionMessageUtil } from "../utils/ChatGptCompletionMessageUtil";
19
+ import { StreamUtil } from "../utils/StreamUtil";
20
+
21
+ import { cancelFunctionFromContext } from "./internal/cancelFunctionFromContext";
22
+
23
+ const FUNCTION: ILlmFunction = typia.llm.application<
24
+ __IChatCancelFunctionsApplication
25
+ >().functions[0]!;
26
+
27
+ interface IFailure {
28
+ id: string;
29
+ name: string;
30
+ validation: IValidation.IFailure;
31
+ }
32
+
33
+ export async function cancel(
34
+ ctx: AgenticaContext,
35
+ ): Promise<void> {
36
+ if (ctx.operations.divided === undefined) {
37
+ return step(ctx, ctx.operations.array, 0);
38
+ }
39
+
40
+ const stacks: AgenticaOperationSelection[][]
41
+ = ctx.operations.divided.map(() => []);
42
+ const events: AgenticaEvent[] = [];
43
+ await Promise.all(
44
+ ctx.operations.divided.map(async (operations, i) =>
45
+ step(
46
+ {
47
+ ...ctx,
48
+ stack: stacks[i]!,
49
+ dispatch: async (e) => {
50
+ events.push(e);
51
+ },
52
+ },
53
+ operations,
54
+ 0,
55
+ ),
56
+ ),
57
+ );
58
+
59
+ // ELITICISM
60
+ if (
61
+ (ctx.config?.eliticism ?? AgenticaConstant.ELITICISM) === true
62
+ && stacks.some(s => s.length !== 0)
63
+ ) {
64
+ return step(
65
+ ctx,
66
+ stacks
67
+ .flat()
68
+ .map(
69
+ s =>
70
+ ctx.operations.group
71
+ .get(s.operation.controller.name)!
72
+ .get(s.operation.function.name)!,
73
+ ),
74
+ 0,
75
+ );
76
+ }
77
+ else {
78
+ const cancelled: AgenticaCancelEvent[]
79
+ = events.filter(e => e.type === "cancel");
80
+ (cancelled.length !== 0 ? cancelled : events)
81
+ .forEach((e) => {
82
+ void ctx.dispatch(e).catch(() => {});
83
+ });
84
+ }
85
+ }
86
+
87
+ async function step(
88
+ ctx: AgenticaContext,
89
+ operations: AgenticaOperation[],
90
+ retry: number,
91
+ failures?: IFailure[],
92
+ ): Promise<void> {
93
+ // ----
94
+ // EXECUTE CHATGPT API
95
+ // ----
96
+ const result = await ctx.request("cancel", {
97
+ messages: [
98
+ // CANDIDATE FUNCTIONS
99
+ {
100
+ role: "assistant",
101
+ tool_calls: [
102
+ {
103
+ type: "function",
104
+ id: "getApiFunctions",
105
+ function: {
106
+ name: "getApiFunctions",
107
+ arguments: JSON.stringify({}),
108
+ },
109
+ },
110
+ ],
111
+ },
112
+ {
113
+ role: "tool",
114
+ tool_call_id: "getApiFunctions",
115
+ content: JSON.stringify(
116
+ operations.map(op => ({
117
+ name: op.name,
118
+ description: op.function.description,
119
+ ...(op.protocol === "http"
120
+ ? {
121
+ method: op.function.method,
122
+ path: op.function.path,
123
+ tags: op.function.tags,
124
+ }
125
+ : {}),
126
+ })),
127
+ ),
128
+ },
129
+ // PREVIOUS HISTORIES
130
+ ...ctx.histories.map(decodeHistory).flat(),
131
+ // USER INPUT
132
+ {
133
+ role: "user",
134
+ content: ctx.prompt.contents.map(decodeUserMessageContent),
135
+ },
136
+ // SYSTEM PROMPT
137
+ {
138
+ role: "system",
139
+ content:
140
+ ctx.config?.systemPrompt?.cancel?.(ctx.histories)
141
+ ?? AgenticaSystemPrompt.CANCEL,
142
+ },
143
+ // TYPE CORRECTIONS
144
+ ...emendMessages(failures ?? []),
145
+ {
146
+ role: "system",
147
+ content: AgenticaDefaultPrompt.write(ctx.config),
148
+ },
149
+ ],
150
+ // STACK FUNCTIONS
151
+ tools: [{
152
+ type: "function",
153
+ function: {
154
+ name: FUNCTION.name,
155
+ description: FUNCTION.description,
156
+ /**
157
+ * @TODO fix it
158
+ * The property and value have a type mismatch, but it works.
159
+ */
160
+ parameters: FUNCTION.parameters as Record<string, any>,
161
+ },
162
+ } satisfies OpenAI.ChatCompletionTool],
163
+ tool_choice: retry === 0
164
+ ? "auto"
165
+ : "required",
166
+ // parallel_tool_calls: true,
167
+ });
168
+
169
+ const completion = await (async () => {
170
+ if (result.type === "none-stream") {
171
+ return result.value;
172
+ }
173
+ return ChatGptCompletionMessageUtil.merge(await StreamUtil.readAll(result.value));
174
+ })();
175
+
176
+ // ----
177
+ // VALIDATION
178
+ // ----
179
+ if (retry++ < (ctx.config?.retry ?? AgenticaConstant.RETRY)) {
180
+ const failures: IFailure[] = [];
181
+ for (const choice of (completion.choices ?? [])) {
182
+ for (const tc of choice.message.tool_calls ?? []) {
183
+ if (tc.type !== "function" || tc.function.name !== "cancelFunctions") {
184
+ continue;
185
+ }
186
+
187
+ const input: object = FUNCTION.parse(tc.function.arguments) as object;
188
+ const validation: IValidation<__IChatFunctionReference.IProps>
189
+ = FUNCTION.validate(input) as IValidation<__IChatFunctionReference.IProps>;
190
+ if (validation.success === false) {
191
+ failures.push({
192
+ id: tc.id,
193
+ name: tc.function.name,
194
+ validation,
195
+ });
196
+ }
197
+ }
198
+ }
199
+ if (failures.length > 0) {
200
+ return step(ctx, operations, retry, failures);
201
+ }
202
+ }
203
+
204
+ // ----
205
+ // PROCESS COMPLETION
206
+ // ----
207
+ for (const choice of (completion.choices ?? [])) {
208
+ // TOOL CALLING HANDLER
209
+ if (choice.message.tool_calls != null) {
210
+ for (const tc of choice.message.tool_calls) {
211
+ if (tc.type !== "function") {
212
+ continue;
213
+ }
214
+ else if (tc.function.name !== "cancelFunctions") {
215
+ continue;
216
+ }
217
+
218
+ const input: __IChatFunctionReference.IProps | null
219
+ = typia.json.isParse<
220
+ __IChatFunctionReference.IProps
221
+ >(tc.function.arguments);
222
+ if (input === null) {
223
+ continue;
224
+ }
225
+
226
+ for (const reference of input.functions) {
227
+ cancelFunctionFromContext(ctx, reference);
228
+ }
229
+ }
230
+ }
231
+ }
232
+ }
233
+
234
+ function emendMessages(failures: IFailure[]): OpenAI.ChatCompletionMessageParam[] {
235
+ return failures
236
+ .map(f => [
237
+ {
238
+ role: "assistant",
239
+ tool_calls: [
240
+ {
241
+ type: "function",
242
+ id: f.id,
243
+ function: {
244
+ name: f.name,
245
+ arguments: JSON.stringify(f.validation.data),
246
+ },
247
+ },
248
+ ],
249
+ } satisfies OpenAI.ChatCompletionAssistantMessageParam,
250
+ {
251
+ role: "tool",
252
+ content: JSON.stringify(f.validation.errors),
253
+ tool_call_id: f.id,
254
+ } satisfies OpenAI.ChatCompletionToolMessageParam,
255
+ {
256
+ role: "system",
257
+ content: [
258
+ "You A.I. assistant has composed wrong typed arguments.",
259
+ "",
260
+ "Correct it at the next function calling.",
261
+ ].join("\n"),
262
+ } satisfies OpenAI.ChatCompletionSystemMessageParam,
263
+ ])
264
+ .flat();
265
+ }
@@ -1,66 +1,66 @@
1
- import type OpenAI from "openai";
2
-
3
- import type { AgenticaContext } from "../context/AgenticaContext";
4
- import type { MicroAgenticaContext } from "../context/MicroAgenticaContext";
5
- import type { AgenticaDescribeEvent } from "../events";
6
- import type { AgenticaExecuteHistory } from "../histories/AgenticaExecuteHistory";
7
-
8
- import { AgenticaDefaultPrompt } from "../constants/AgenticaDefaultPrompt";
9
- import { AgenticaSystemPrompt } from "../constants/AgenticaSystemPrompt";
10
- import { createDescribeEvent } from "../factory/events";
11
- import { decodeHistory } from "../factory/histories";
12
- import { reduceStreamingWithDispatch } from "../utils/ChatGptCompletionStreamingUtil";
13
- import { toAsyncGenerator } from "../utils/StreamUtil";
14
-
15
- export async function describe(
16
- ctx: AgenticaContext | MicroAgenticaContext,
17
- histories: AgenticaExecuteHistory[],
18
- ): Promise<void> {
19
- if (histories.length === 0) {
20
- return;
21
- }
22
-
23
- const result = await ctx.request("describe", {
24
- messages: [
25
- // FUNCTION CALLING HISTORIES
26
- ...histories.map(decodeHistory).flat(),
27
- // SYSTEM PROMPT
28
- {
29
- role: "system",
30
- content:
31
- ctx.config?.systemPrompt?.describe?.(histories)
32
- ?? AgenticaSystemPrompt.DESCRIBE,
33
- },
34
- // COMMON SYSTEM PROMPT
35
- {
36
- role: "system",
37
- content: AgenticaDefaultPrompt.write(ctx.config),
38
- } satisfies OpenAI.ChatCompletionSystemMessageParam,
39
- ],
40
- });
41
-
42
- if (result.type === "none-stream") {
43
- const message = result.value.choices?.[0]?.message.content ?? "";
44
- const event: AgenticaDescribeEvent = createDescribeEvent({
45
- executes: histories,
46
- stream: toAsyncGenerator(message),
47
- done: () => true,
48
- get: () => message,
49
- join: async () => message,
50
- });
51
- void ctx.dispatch(event).catch(() => {});
52
- return;
53
- }
54
-
55
- await reduceStreamingWithDispatch(result.value, (props) => {
56
- const event: AgenticaDescribeEvent = createDescribeEvent({
57
- executes: histories,
58
- ...props,
59
- });
60
- void ctx.dispatch(event).catch(() => {});
61
- }, ctx.abortSignal);
62
- }
63
-
64
- export const ChatGptDescribeFunctionAgent = {
65
- execute: describe,
66
- };
1
+ import type OpenAI from "openai";
2
+
3
+ import type { AgenticaContext } from "../context/AgenticaContext";
4
+ import type { MicroAgenticaContext } from "../context/MicroAgenticaContext";
5
+ import type { AgenticaDescribeEvent } from "../events";
6
+ import type { AgenticaExecuteHistory } from "../histories/AgenticaExecuteHistory";
7
+
8
+ import { AgenticaDefaultPrompt } from "../constants/AgenticaDefaultPrompt";
9
+ import { AgenticaSystemPrompt } from "../constants/AgenticaSystemPrompt";
10
+ import { createDescribeEvent } from "../factory/events";
11
+ import { decodeHistory } from "../factory/histories";
12
+ import { reduceStreamingWithDispatch } from "../utils/ChatGptCompletionStreamingUtil";
13
+ import { toAsyncGenerator } from "../utils/StreamUtil";
14
+
15
+ export async function describe(
16
+ ctx: AgenticaContext | MicroAgenticaContext,
17
+ histories: AgenticaExecuteHistory[],
18
+ ): Promise<void> {
19
+ if (histories.length === 0) {
20
+ return;
21
+ }
22
+
23
+ const result = await ctx.request("describe", {
24
+ messages: [
25
+ // FUNCTION CALLING HISTORIES
26
+ ...histories.map(decodeHistory).flat(),
27
+ // SYSTEM PROMPT
28
+ {
29
+ role: "system",
30
+ content:
31
+ ctx.config?.systemPrompt?.describe?.(histories)
32
+ ?? AgenticaSystemPrompt.DESCRIBE,
33
+ },
34
+ // COMMON SYSTEM PROMPT
35
+ {
36
+ role: "system",
37
+ content: AgenticaDefaultPrompt.write(ctx.config),
38
+ } satisfies OpenAI.ChatCompletionSystemMessageParam,
39
+ ],
40
+ });
41
+
42
+ if (result.type === "none-stream") {
43
+ const message = result.value.choices?.[0]?.message.content ?? "";
44
+ const event: AgenticaDescribeEvent = createDescribeEvent({
45
+ executes: histories,
46
+ stream: toAsyncGenerator(message),
47
+ done: () => true,
48
+ get: () => message,
49
+ join: async () => message,
50
+ });
51
+ void ctx.dispatch(event).catch(() => {});
52
+ return;
53
+ }
54
+
55
+ await reduceStreamingWithDispatch(result.value, (props) => {
56
+ const event: AgenticaDescribeEvent = createDescribeEvent({
57
+ executes: histories,
58
+ ...props,
59
+ });
60
+ void ctx.dispatch(event).catch(() => {});
61
+ }, ctx.abortSignal);
62
+ }
63
+
64
+ export const ChatGptDescribeFunctionAgent = {
65
+ execute: describe,
66
+ };