@agentica/core 0.43.2 → 0.44.0-dev.20260313

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 (205) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +218 -218
  3. package/lib/constants/AgenticaSystemPrompt.js +1 -1
  4. package/lib/constants/AgenticaSystemPrompt.js.map +1 -1
  5. package/lib/context/AgenticaOperation.d.ts +3 -2
  6. package/lib/context/internal/AgenticaOperationComposer.js.map +1 -1
  7. package/lib/context/internal/AgenticaTokenUsageAggregator.js.map +1 -1
  8. package/lib/context/internal/__IChatInitialApplication.d.ts +1 -1
  9. package/lib/errors/AgenticaJsonParseError.d.ts +5 -8
  10. package/lib/errors/AgenticaJsonParseError.js +11 -6
  11. package/lib/errors/AgenticaJsonParseError.js.map +1 -1
  12. package/lib/errors/AgenticaValidationError.d.ts +1 -1
  13. package/lib/events/AgenticaExecuteEvent.d.ts +1 -1
  14. package/lib/events/AgenticaJsonParseErrorEvent.d.ts +2 -2
  15. package/lib/factory/events.d.ts +2 -3
  16. package/lib/factory/events.js +1 -2
  17. package/lib/factory/events.js.map +1 -1
  18. package/lib/functional/assertHttpController.d.ts +2 -3
  19. package/lib/functional/assertHttpController.js +3939 -2656
  20. package/lib/functional/assertHttpController.js.map +1 -1
  21. package/lib/functional/assertHttpLlmApplication.d.ts +3 -3
  22. package/lib/functional/assertHttpLlmApplication.js +3939 -2656
  23. package/lib/functional/assertHttpLlmApplication.js.map +1 -1
  24. package/lib/functional/assertMcpController.d.ts +2 -2
  25. package/lib/functional/assertMcpController.js +202 -629
  26. package/lib/functional/assertMcpController.js.map +1 -1
  27. package/lib/functional/createMcpLlmApplication.d.ts +6 -0
  28. package/lib/functional/createMcpLlmApplication.js +56 -0
  29. package/lib/functional/createMcpLlmApplication.js.map +1 -0
  30. package/lib/functional/validateHttpController.d.ts +3 -3
  31. package/lib/functional/validateHttpController.js +3367 -2268
  32. package/lib/functional/validateHttpController.js.map +1 -1
  33. package/lib/functional/validateHttpLlmApplication.d.ts +3 -4
  34. package/lib/functional/validateHttpLlmApplication.js +3367 -2268
  35. package/lib/functional/validateHttpLlmApplication.js.map +1 -1
  36. package/lib/functional/validateMcpController.d.ts +2 -2
  37. package/lib/functional/validateMcpController.js +388 -1161
  38. package/lib/functional/validateMcpController.js.map +1 -1
  39. package/lib/histories/AgenticaExecuteHistory.d.ts +1 -1
  40. package/lib/index.mjs +21256 -18948
  41. package/lib/index.mjs.map +1 -1
  42. package/lib/orchestrate/call.js +43 -56
  43. package/lib/orchestrate/call.js.map +1 -1
  44. package/lib/orchestrate/cancel.js +9 -66
  45. package/lib/orchestrate/cancel.js.map +1 -1
  46. package/lib/orchestrate/initialize.js +4 -947
  47. package/lib/orchestrate/initialize.js.map +1 -1
  48. package/lib/orchestrate/select.js +11 -68
  49. package/lib/orchestrate/select.js.map +1 -1
  50. package/lib/structures/IAgenticaController.d.ts +143 -151
  51. package/lib/structures/IMcpTool.d.ts +52 -0
  52. package/lib/structures/IMcpTool.js +3 -0
  53. package/lib/structures/IMcpTool.js.map +1 -0
  54. package/lib/utils/ChatGptCompletionMessageUtil.js +16 -5
  55. package/lib/utils/ChatGptCompletionMessageUtil.js.map +1 -1
  56. package/lib/utils/ChatGptCompletionMessageUtil.spec.js +0 -5
  57. package/lib/utils/ChatGptCompletionMessageUtil.spec.js.map +1 -1
  58. package/package.json +7 -9
  59. package/prompts/cancel.md +5 -5
  60. package/prompts/common.md +3 -3
  61. package/prompts/describe.md +7 -7
  62. package/prompts/execute.md +122 -122
  63. package/prompts/initialize.md +3 -3
  64. package/prompts/json_parse_error.md +35 -33
  65. package/prompts/select.md +7 -7
  66. package/prompts/validate.md +123 -123
  67. package/prompts/validate_repeated.md +31 -31
  68. package/src/Agentica.ts +367 -367
  69. package/src/MicroAgentica.ts +357 -357
  70. package/src/constants/AgenticaConstant.ts +4 -4
  71. package/src/constants/AgenticaDefaultPrompt.ts +44 -44
  72. package/src/constants/AgenticaSystemPrompt.ts +1 -1
  73. package/src/constants/index.ts +2 -2
  74. package/src/context/AgenticaContext.ts +136 -136
  75. package/src/context/AgenticaContextRequestResult.ts +14 -14
  76. package/src/context/AgenticaOperation.ts +73 -72
  77. package/src/context/AgenticaOperationCollection.ts +49 -49
  78. package/src/context/AgenticaOperationSelection.ts +9 -9
  79. package/src/context/AgenticaTokenUsage.ts +186 -186
  80. package/src/context/MicroAgenticaContext.ts +99 -99
  81. package/src/context/index.ts +5 -5
  82. package/src/context/internal/AgenticaOperationComposer.ts +177 -177
  83. package/src/context/internal/AgenticaTokenUsageAggregator.ts +66 -66
  84. package/src/context/internal/__IChatCancelFunctionsApplication.ts +23 -23
  85. package/src/context/internal/__IChatFunctionReference.ts +21 -21
  86. package/src/context/internal/__IChatInitialApplication.ts +15 -15
  87. package/src/context/internal/__IChatSelectFunctionsApplication.ts +24 -24
  88. package/src/context/internal/isAgenticaContext.ts +11 -11
  89. package/src/errors/AgenticaJsonParseError.ts +52 -47
  90. package/src/errors/AgenticaValidationError.ts +49 -49
  91. package/src/errors/index.ts +2 -2
  92. package/src/events/AgenticaAssistantMessageEvent.ts +12 -12
  93. package/src/events/AgenticaCallEvent.ts +27 -27
  94. package/src/events/AgenticaCancelEvent.ts +9 -9
  95. package/src/events/AgenticaDescribeEvent.ts +14 -14
  96. package/src/events/AgenticaEvent.ts +59 -59
  97. package/src/events/AgenticaEvent.type.ts +19 -19
  98. package/src/events/AgenticaEventBase.ts +18 -18
  99. package/src/events/AgenticaEventSource.ts +6 -6
  100. package/src/events/AgenticaExecuteEvent.ts +45 -45
  101. package/src/events/AgenticaInitializeEvent.ts +7 -7
  102. package/src/events/AgenticaJsonParseErrorEvent.ts +16 -15
  103. package/src/events/AgenticaRequestEvent.ts +27 -27
  104. package/src/events/AgenticaResponseEvent.ts +32 -32
  105. package/src/events/AgenticaSelectEvent.ts +11 -11
  106. package/src/events/AgenticaUserMessageEvent.ts +12 -12
  107. package/src/events/AgenticaValidateEvent.ts +32 -32
  108. package/src/events/MicroAgenticaEvent.ts +45 -45
  109. package/src/events/index.ts +15 -15
  110. package/src/factory/events.ts +357 -359
  111. package/src/factory/histories.ts +348 -348
  112. package/src/factory/index.ts +3 -3
  113. package/src/factory/operations.ts +16 -16
  114. package/src/functional/assertHttpController.ts +106 -104
  115. package/src/functional/assertHttpLlmApplication.ts +52 -57
  116. package/src/functional/assertMcpController.ts +47 -44
  117. package/src/functional/createMcpLlmApplication.ts +72 -0
  118. package/src/functional/index.ts +7 -7
  119. package/src/functional/validateHttpController.ts +113 -110
  120. package/src/functional/validateHttpLlmApplication.ts +65 -70
  121. package/src/functional/validateMcpController.ts +53 -50
  122. package/src/histories/AgenticaAssistantMessageHistory.ts +10 -10
  123. package/src/histories/AgenticaCancelHistory.ts +8 -8
  124. package/src/histories/AgenticaDescribeHistory.ts +18 -18
  125. package/src/histories/AgenticaExecuteHistory.ts +64 -64
  126. package/src/histories/AgenticaHistory.ts +28 -28
  127. package/src/histories/AgenticaHistoryBase.ts +35 -35
  128. package/src/histories/AgenticaSelectHistory.ts +8 -8
  129. package/src/histories/AgenticaSystemMessageHistory.ts +10 -10
  130. package/src/histories/AgenticaUserMessageHistory.ts +11 -11
  131. package/src/histories/MicroAgenticaHistory.ts +19 -19
  132. package/src/histories/contents/AgenticaUserMessageAudioContent.ts +21 -21
  133. package/src/histories/contents/AgenticaUserMessageContent.ts +19 -19
  134. package/src/histories/contents/AgenticaUserMessageContentBase.ts +6 -6
  135. package/src/histories/contents/AgenticaUserMessageFileContent.ts +25 -25
  136. package/src/histories/contents/AgenticaUserMessageImageContent.ts +33 -33
  137. package/src/histories/contents/AgenticaUserMessageTextContent.ts +15 -15
  138. package/src/histories/contents/index.ts +5 -5
  139. package/src/histories/index.ts +10 -10
  140. package/src/index.ts +15 -15
  141. package/src/json/IAgenticaEventJson.ts +265 -265
  142. package/src/json/IAgenticaEventJson.type.ts +19 -19
  143. package/src/json/IAgenticaHistoryJson.ts +165 -165
  144. package/src/json/IAgenticaHistoryJson.type.ts +19 -19
  145. package/src/json/IAgenticaOperationJson.ts +36 -36
  146. package/src/json/IAgenticaOperationSelectionJson.ts +26 -26
  147. package/src/json/IAgenticaTokenUsageJson.ts +107 -107
  148. package/src/json/IMicroAgenticaEventJson.ts +22 -22
  149. package/src/json/IMicroAgenticaHistoryJson.ts +25 -25
  150. package/src/json/index.ts +7 -7
  151. package/src/orchestrate/call.ts +542 -558
  152. package/src/orchestrate/cancel.ts +265 -269
  153. package/src/orchestrate/describe.ts +66 -66
  154. package/src/orchestrate/execute.ts +61 -61
  155. package/src/orchestrate/index.ts +6 -6
  156. package/src/orchestrate/initialize.ts +102 -102
  157. package/src/orchestrate/internal/cancelFunctionFromContext.ts +33 -33
  158. package/src/orchestrate/internal/selectFunctionFromContext.ts +34 -34
  159. package/src/orchestrate/select.ts +320 -322
  160. package/src/structures/IAgenticaConfig.ts +83 -83
  161. package/src/structures/IAgenticaConfigBase.ts +87 -87
  162. package/src/structures/IAgenticaController.ts +143 -151
  163. package/src/structures/IAgenticaExecutor.ts +167 -167
  164. package/src/structures/IAgenticaProps.ts +78 -78
  165. package/src/structures/IAgenticaSystemPrompt.ts +236 -236
  166. package/src/structures/IAgenticaVendor.ts +54 -54
  167. package/src/structures/IMcpTool.ts +60 -0
  168. package/src/structures/IMicroAgenticaConfig.ts +56 -56
  169. package/src/structures/IMicroAgenticaExecutor.ts +67 -67
  170. package/src/structures/IMicroAgenticaProps.ts +77 -77
  171. package/src/structures/IMicroAgenticaSystemPrompt.ts +169 -169
  172. package/src/structures/index.ts +10 -10
  173. package/src/transformers/transformHistory.ts +172 -172
  174. package/src/utils/AssistantMessageEmptyError.ts +20 -20
  175. package/src/utils/AsyncQueue.spec.ts +355 -355
  176. package/src/utils/AsyncQueue.ts +95 -95
  177. package/src/utils/ByteArrayUtil.ts +5 -5
  178. package/src/utils/ChatGptCompletionMessageUtil.spec.ts +314 -320
  179. package/src/utils/ChatGptCompletionMessageUtil.ts +210 -195
  180. package/src/utils/ChatGptCompletionStreamingUtil.spec.ts +909 -909
  181. package/src/utils/ChatGptCompletionStreamingUtil.ts +91 -91
  182. package/src/utils/ChatGptTokenUsageAggregator.spec.ts +226 -226
  183. package/src/utils/ChatGptTokenUsageAggregator.ts +57 -57
  184. package/src/utils/MPSC.spec.ts +276 -276
  185. package/src/utils/MPSC.ts +42 -42
  186. package/src/utils/Singleton.spec.ts +138 -138
  187. package/src/utils/Singleton.ts +42 -42
  188. package/src/utils/StreamUtil.spec.ts +512 -512
  189. package/src/utils/StreamUtil.ts +87 -87
  190. package/src/utils/__map_take.spec.ts +140 -140
  191. package/src/utils/__map_take.ts +13 -13
  192. package/src/utils/__retry.spec.ts +198 -198
  193. package/src/utils/__retry.ts +18 -18
  194. package/src/utils/assertExecuteFailure.ts +16 -16
  195. package/src/utils/index.ts +4 -4
  196. package/src/utils/request.ts +140 -140
  197. package/src/utils/types.ts +50 -50
  198. package/lib/context/internal/AgenticaOperationComposer.spec.d.ts +0 -1
  199. package/lib/context/internal/AgenticaOperationComposer.spec.js +0 -353
  200. package/lib/context/internal/AgenticaOperationComposer.spec.js.map +0 -1
  201. package/lib/utils/JsonUtil.d.ts +0 -8
  202. package/lib/utils/JsonUtil.js +0 -350
  203. package/lib/utils/JsonUtil.js.map +0 -1
  204. package/src/context/internal/AgenticaOperationComposer.spec.ts +0 -401
  205. package/src/utils/JsonUtil.ts +0 -462
@@ -1,66 +1,66 @@
1
- import type { CompletionUsage } from "openai/resources";
2
-
3
- import type { IAgenticaTokenUsageJson } from "../../json/IAgenticaTokenUsageJson";
4
- import type { AgenticaTokenUsage } from "../AgenticaTokenUsage";
5
-
6
- export function aggregate(props: {
7
- kind: Exclude<keyof IAgenticaTokenUsageJson, "aggregate">;
8
- completionUsage: CompletionUsage;
9
- usage: AgenticaTokenUsage;
10
- }): void {
11
- // ----
12
- // COMPONENT
13
- // ----
14
- const component: AgenticaTokenUsage.IComponent = props.usage[props.kind];
15
-
16
- // TOTAL
17
- component.total += props.completionUsage.total_tokens;
18
-
19
- // PROMPT
20
- component.input.total += props.completionUsage.prompt_tokens;
21
- component.input.total
22
- += props.completionUsage.prompt_tokens_details?.audio_tokens ?? 0;
23
- component.input.cached
24
- += props.completionUsage.prompt_tokens_details?.cached_tokens ?? 0;
25
-
26
- // COMPLETION
27
- component.output.total += props.completionUsage.completion_tokens;
28
- component.output.accepted_prediction
29
- += props.completionUsage.completion_tokens_details
30
- ?.accepted_prediction_tokens ?? 0;
31
- component.output.reasoning
32
- += props.completionUsage.completion_tokens_details?.reasoning_tokens ?? 0;
33
- component.output.rejected_prediction
34
- += props.completionUsage.completion_tokens_details
35
- ?.rejected_prediction_tokens ?? 0;
36
-
37
- // ----
38
- // RE-AGGREGATE
39
- // ----
40
- const sum = (getter: (comp: AgenticaTokenUsage.IComponent) => number) =>
41
- (
42
- Object.entries(props.usage) as [
43
- keyof AgenticaTokenUsage,
44
- AgenticaTokenUsage.IComponent,
45
- ][]
46
- )
47
- .filter(([key]) => key !== "aggregate")
48
- .map(([, comp]) => getter(comp))
49
- .reduce((a, b) => a + b, 0);
50
- const aggregate: AgenticaTokenUsage.IComponent = props.usage.aggregate;
51
- aggregate.total = sum(comp => comp.total);
52
- aggregate.input.total = sum(comp => comp.input.total);
53
- aggregate.input.cached = sum(comp => comp.input.cached);
54
- aggregate.output.total = sum(comp => comp.output.total);
55
- aggregate.output.reasoning = sum(comp => comp.output.reasoning);
56
- aggregate.output.accepted_prediction = sum(
57
- comp => comp.output.accepted_prediction,
58
- );
59
- aggregate.output.rejected_prediction = sum(
60
- comp => comp.output.rejected_prediction,
61
- );
62
- }
63
-
64
- export const AgenticaTokenUsageAggregator = {
65
- aggregate,
66
- };
1
+ import type { CompletionUsage } from "openai/resources";
2
+
3
+ import type { IAgenticaTokenUsageJson } from "../../json/IAgenticaTokenUsageJson";
4
+ import type { AgenticaTokenUsage } from "../AgenticaTokenUsage";
5
+
6
+ export function aggregate(props: {
7
+ kind: Exclude<keyof IAgenticaTokenUsageJson, "aggregate">;
8
+ completionUsage: CompletionUsage;
9
+ usage: AgenticaTokenUsage;
10
+ }): void {
11
+ // ----
12
+ // COMPONENT
13
+ // ----
14
+ const component: AgenticaTokenUsage.IComponent = props.usage[props.kind];
15
+
16
+ // TOTAL
17
+ component.total += props.completionUsage.total_tokens;
18
+
19
+ // PROMPT
20
+ component.input.total += props.completionUsage.prompt_tokens;
21
+ component.input.total
22
+ += props.completionUsage.prompt_tokens_details?.audio_tokens ?? 0;
23
+ component.input.cached
24
+ += props.completionUsage.prompt_tokens_details?.cached_tokens ?? 0;
25
+
26
+ // COMPLETION
27
+ component.output.total += props.completionUsage.completion_tokens;
28
+ component.output.accepted_prediction
29
+ += props.completionUsage.completion_tokens_details
30
+ ?.accepted_prediction_tokens ?? 0;
31
+ component.output.reasoning
32
+ += props.completionUsage.completion_tokens_details?.reasoning_tokens ?? 0;
33
+ component.output.rejected_prediction
34
+ += props.completionUsage.completion_tokens_details
35
+ ?.rejected_prediction_tokens ?? 0;
36
+
37
+ // ----
38
+ // RE-AGGREGATE
39
+ // ----
40
+ const sum = (getter: (comp: AgenticaTokenUsage.IComponent) => number) =>
41
+ (
42
+ Object.entries(props.usage) as [
43
+ keyof AgenticaTokenUsage,
44
+ AgenticaTokenUsage.IComponent,
45
+ ][]
46
+ )
47
+ .filter(([key]) => key !== "aggregate")
48
+ .map(([, comp]) => getter(comp))
49
+ .reduce((a, b) => a + b, 0);
50
+ const aggregate: AgenticaTokenUsage.IComponent = props.usage.aggregate;
51
+ aggregate.total = sum(comp => comp.total);
52
+ aggregate.input.total = sum(comp => comp.input.total);
53
+ aggregate.input.cached = sum(comp => comp.input.cached);
54
+ aggregate.output.total = sum(comp => comp.output.total);
55
+ aggregate.output.reasoning = sum(comp => comp.output.reasoning);
56
+ aggregate.output.accepted_prediction = sum(
57
+ comp => comp.output.accepted_prediction,
58
+ );
59
+ aggregate.output.rejected_prediction = sum(
60
+ comp => comp.output.rejected_prediction,
61
+ );
62
+ }
63
+
64
+ export const AgenticaTokenUsageAggregator = {
65
+ aggregate,
66
+ };
@@ -1,23 +1,23 @@
1
- import type { __IChatFunctionReference } from "./__IChatFunctionReference";
2
-
3
- export interface __IChatCancelFunctionsApplication {
4
- /**
5
- * Cancel a function from the candidate list to call.
6
- *
7
- * If you A.I. agent has understood that the user wants to cancel
8
- * some candidate functions to call from the conversation, please cancel
9
- * them through this function.
10
- *
11
- * Also, when you A.I. find a function that has been selected by the candidate
12
- * pooling, cancel the function by calling this function. For reference, the
13
- * candidate pooling means that user wants only one function to call, but you A.I.
14
- * agent selects multiple candidate functions because the A.I. agent can't specify
15
- * only one thing due to lack of specificity or homogeneity of candidate functions.
16
- *
17
- * Additionally, if you A.I. agent wants to cancel same function multiply, you can
18
- * do it by assigning the same function name multiply in the `functions` property.
19
- *
20
- * @param props Properties of the function
21
- */
22
- cancelFunctions: (props: __IChatFunctionReference.IProps) => Promise<void>;
23
- }
1
+ import type { __IChatFunctionReference } from "./__IChatFunctionReference";
2
+
3
+ export interface __IChatCancelFunctionsApplication {
4
+ /**
5
+ * Cancel a function from the candidate list to call.
6
+ *
7
+ * If you A.I. agent has understood that the user wants to cancel
8
+ * some candidate functions to call from the conversation, please cancel
9
+ * them through this function.
10
+ *
11
+ * Also, when you A.I. find a function that has been selected by the candidate
12
+ * pooling, cancel the function by calling this function. For reference, the
13
+ * candidate pooling means that user wants only one function to call, but you A.I.
14
+ * agent selects multiple candidate functions because the A.I. agent can't specify
15
+ * only one thing due to lack of specificity or homogeneity of candidate functions.
16
+ *
17
+ * Additionally, if you A.I. agent wants to cancel same function multiply, you can
18
+ * do it by assigning the same function name multiply in the `functions` property.
19
+ *
20
+ * @param props Properties of the function
21
+ */
22
+ cancelFunctions: (props: __IChatFunctionReference.IProps) => Promise<void>;
23
+ }
@@ -1,21 +1,21 @@
1
- export interface __IChatFunctionReference {
2
- /**
3
- * The reason of the function selection.
4
- *
5
- * Just write the reason why you've determined to select this function.
6
- */
7
- reason: string;
8
-
9
- /**
10
- * Name of the target function to call.
11
- */
12
- name: string;
13
- }
14
- export namespace __IChatFunctionReference {
15
- export interface IProps {
16
- /**
17
- * List of target functions.
18
- */
19
- functions: __IChatFunctionReference[];
20
- }
21
- }
1
+ export interface __IChatFunctionReference {
2
+ /**
3
+ * The reason of the function selection.
4
+ *
5
+ * Just write the reason why you've determined to select this function.
6
+ */
7
+ reason: string;
8
+
9
+ /**
10
+ * Name of the target function to call.
11
+ */
12
+ name: string;
13
+ }
14
+ export namespace __IChatFunctionReference {
15
+ export interface IProps {
16
+ /**
17
+ * List of target functions.
18
+ */
19
+ functions: __IChatFunctionReference[];
20
+ }
21
+ }
@@ -1,15 +1,15 @@
1
- import type { IHttpLlmFunction } from "@samchon/openapi";
2
-
3
- export interface __IChatInitialApplication {
4
- /**
5
- * Get list of API functions.
6
- *
7
- * If user seems like to request some function calling except this one,
8
- * call this `getApiFunctions()` to get the list of candidate API functions
9
- * provided from this application.
10
- *
11
- * Also, user just wants to list up every remote API functions that can be
12
- * called from the backend server, utilize this function too.
13
- */
14
- getApiFunctions: (props: object) => Promise<Array<IHttpLlmFunction>>;
15
- }
1
+ import type { IHttpLlmFunction } from "@typia/interface";
2
+
3
+ export interface __IChatInitialApplication {
4
+ /**
5
+ * Get list of API functions.
6
+ *
7
+ * If user seems like to request some function calling except this one,
8
+ * call this `getApiFunctions()` to get the list of candidate API functions
9
+ * provided from this application.
10
+ *
11
+ * Also, user just wants to list up every remote API functions that can be
12
+ * called from the backend server, utilize this function too.
13
+ */
14
+ getApiFunctions: (props: object) => Promise<Array<IHttpLlmFunction>>;
15
+ }
@@ -1,24 +1,24 @@
1
- import type { __IChatFunctionReference } from "./__IChatFunctionReference";
2
-
3
- export interface __IChatSelectFunctionsApplication {
4
- /**
5
- * Select proper API functions to call.
6
- *
7
- * If you A.I. agent has found some proper API functions to call
8
- * from the conversation with user, please select the API functions
9
- * just by calling this function.
10
- *
11
- * When user wants to call a same function multiply, you A.I. agent must
12
- * list up it multiply in the `functions` property. Otherwise the user has
13
- * requested to call many different functions, you A.I. agent have to assign
14
- * them all into the `functions` property.
15
- *
16
- * Also, if you A.I. agent can't specify a specific function to call due to lack
17
- * of specificity or homogeneity of candidate functions, just assign all of them
18
- * by in the` functions` property` too. Instead, when you A.I. agent can specify
19
- * a specific function to call, the others would be eliminated.
20
- *
21
- * @param props Properties of the function
22
- */
23
- selectFunctions: (props: __IChatFunctionReference.IProps) => Promise<void>;
24
- }
1
+ import type { __IChatFunctionReference } from "./__IChatFunctionReference";
2
+
3
+ export interface __IChatSelectFunctionsApplication {
4
+ /**
5
+ * Select proper API functions to call.
6
+ *
7
+ * If you A.I. agent has found some proper API functions to call
8
+ * from the conversation with user, please select the API functions
9
+ * just by calling this function.
10
+ *
11
+ * When user wants to call a same function multiply, you A.I. agent must
12
+ * list up it multiply in the `functions` property. Otherwise the user has
13
+ * requested to call many different functions, you A.I. agent have to assign
14
+ * them all into the `functions` property.
15
+ *
16
+ * Also, if you A.I. agent can't specify a specific function to call due to lack
17
+ * of specificity or homogeneity of candidate functions, just assign all of them
18
+ * by in the` functions` property` too. Instead, when you A.I. agent can specify
19
+ * a specific function to call, the others would be eliminated.
20
+ *
21
+ * @param props Properties of the function
22
+ */
23
+ selectFunctions: (props: __IChatFunctionReference.IProps) => Promise<void>;
24
+ }
@@ -1,11 +1,11 @@
1
- import type { AgenticaContext } from "../AgenticaContext";
2
- import type { MicroAgenticaContext } from "../MicroAgenticaContext";
3
-
4
- /**
5
- * @internal
6
- */
7
- export function isAgenticaContext(
8
- ctx: AgenticaContext | MicroAgenticaContext,
9
- ): ctx is AgenticaContext {
10
- return typeof (ctx as AgenticaContext).initialize === "function";
11
- }
1
+ import type { AgenticaContext } from "../AgenticaContext";
2
+ import type { MicroAgenticaContext } from "../MicroAgenticaContext";
3
+
4
+ /**
5
+ * @internal
6
+ */
7
+ export function isAgenticaContext(
8
+ ctx: AgenticaContext | MicroAgenticaContext,
9
+ ): ctx is AgenticaContext {
10
+ return typeof (ctx as AgenticaContext).initialize === "function";
11
+ }
@@ -1,47 +1,52 @@
1
- import { AgenticaConstant } from "../constants/AgenticaConstant";
2
-
3
- export class AgenticaJsonParseError extends Error {
4
- public readonly arguments: string;
5
- public readonly reason: string;
6
-
7
- public constructor(props: AgenticaJsonParseError.IProps) {
8
- super(`Invalid JSON format. The parsing failed after ${AgenticaConstant.RETRY} retries.`);
9
-
10
- const proto = new.target.prototype;
11
-
12
- // eslint-disable-next-line
13
- if (Object.setPrototypeOf) {
14
- Object.setPrototypeOf(this, proto);
15
- }
16
- else {
17
- // eslint-disable-next-line
18
- (this as any).__proto__ = proto;
19
- }
20
-
21
- this.arguments = props.arguments;
22
- this.reason = props.reason;
23
- }
24
-
25
- public get name(): "AgenticaJsonParseError" {
26
- return "AgenticaJsonParseError";
27
- }
28
-
29
- public toJSON(): AgenticaJsonParseError.IJson {
30
- return {
31
- name: "AgenticaJsonParseError",
32
- message: this.message,
33
- arguments: this.arguments,
34
- reason: this.reason,
35
- };
36
- }
37
- }
38
- export namespace AgenticaJsonParseError {
39
- export interface IProps {
40
- arguments: string;
41
- reason: string;
42
- }
43
- export interface IJson extends IProps {
44
- name: "AgenticaJsonParseError";
45
- message: string;
46
- }
47
- }
1
+ import type { IJsonParseResult } from "typia";
2
+
3
+ import { dedent } from "@typia/utils";
4
+
5
+ import { AgenticaConstant } from "../constants/AgenticaConstant";
6
+
7
+ export class AgenticaJsonParseError extends Error {
8
+ public readonly failure: IJsonParseResult.IFailure;
9
+
10
+ public constructor(failure: IJsonParseResult.IFailure) {
11
+ super(
12
+ dedent`
13
+ Invalid JSON format. The parsing failed after ${AgenticaConstant.RETRY} retries.
14
+
15
+ \`\`\`json
16
+ ${JSON.stringify(failure, null, 2)}
17
+ \`\`\`
18
+ `,
19
+ );
20
+
21
+ const proto = new.target.prototype;
22
+
23
+ // eslint-disable-next-line
24
+ if (Object.setPrototypeOf) {
25
+ Object.setPrototypeOf(this, proto);
26
+ }
27
+ else {
28
+ // eslint-disable-next-line
29
+ (this as any).__proto__ = proto;
30
+ }
31
+ this.failure = failure;
32
+ }
33
+
34
+ public get name(): "AgenticaJsonParseError" {
35
+ return "AgenticaJsonParseError";
36
+ }
37
+
38
+ public toJSON(): AgenticaJsonParseError.IJson {
39
+ return {
40
+ name: "AgenticaJsonParseError",
41
+ failure: this.failure,
42
+ message: this.message,
43
+ };
44
+ }
45
+ }
46
+ export namespace AgenticaJsonParseError {
47
+ export interface IJson {
48
+ name: "AgenticaJsonParseError";
49
+ failure: IJsonParseResult.IFailure;
50
+ message: string;
51
+ }
52
+ }
@@ -1,49 +1,49 @@
1
- import type { IValidation } from "@samchon/openapi";
2
-
3
- import { AgenticaConstant } from "../constants/AgenticaConstant";
4
-
5
- export class AgenticaValidationError extends Error {
6
- public readonly arguments: unknown;
7
- public readonly errors: IValidation.IError[];
8
-
9
- public constructor(props: AgenticaValidationError.IProps) {
10
- super(`Invalid arguments. The validation failed after ${AgenticaConstant.RETRY} retries.`);
11
-
12
- const proto = new.target.prototype;
13
-
14
- // eslint-disable-next-line
15
- if (Object.setPrototypeOf) {
16
- Object.setPrototypeOf(this, proto);
17
- }
18
- else {
19
- // eslint-disable-next-line
20
- (this as any).__proto__ = proto;
21
- }
22
-
23
- this.arguments = props.arguments;
24
- this.errors = props.errors;
25
- }
26
-
27
- public get name(): "AgenticaValidationError" {
28
- return "AgenticaValidationError";
29
- }
30
-
31
- public toJSON(): AgenticaValidationError.IJson {
32
- return {
33
- name: "AgenticaValidationError",
34
- message: this.message,
35
- arguments: this.arguments,
36
- errors: this.errors,
37
- };
38
- }
39
- }
40
- export namespace AgenticaValidationError {
41
- export interface IProps {
42
- arguments: unknown;
43
- errors: IValidation.IError[];
44
- }
45
- export interface IJson extends IProps {
46
- name: "AgenticaValidationError";
47
- message: string;
48
- }
49
- }
1
+ import type { IValidation } from "typia";
2
+
3
+ import { AgenticaConstant } from "../constants/AgenticaConstant";
4
+
5
+ export class AgenticaValidationError extends Error {
6
+ public readonly arguments: unknown;
7
+ public readonly errors: IValidation.IError[];
8
+
9
+ public constructor(props: AgenticaValidationError.IProps) {
10
+ super(`Invalid arguments. The validation failed after ${AgenticaConstant.RETRY} retries.`);
11
+
12
+ const proto = new.target.prototype;
13
+
14
+ // eslint-disable-next-line
15
+ if (Object.setPrototypeOf) {
16
+ Object.setPrototypeOf(this, proto);
17
+ }
18
+ else {
19
+ // eslint-disable-next-line
20
+ (this as any).__proto__ = proto;
21
+ }
22
+
23
+ this.arguments = props.arguments;
24
+ this.errors = props.errors;
25
+ }
26
+
27
+ public get name(): "AgenticaValidationError" {
28
+ return "AgenticaValidationError";
29
+ }
30
+
31
+ public toJSON(): AgenticaValidationError.IJson {
32
+ return {
33
+ name: "AgenticaValidationError",
34
+ message: this.message,
35
+ arguments: this.arguments,
36
+ errors: this.errors,
37
+ };
38
+ }
39
+ }
40
+ export namespace AgenticaValidationError {
41
+ export interface IProps {
42
+ arguments: unknown;
43
+ errors: IValidation.IError[];
44
+ }
45
+ export interface IJson extends IProps {
46
+ name: "AgenticaValidationError";
47
+ message: string;
48
+ }
49
+ }
@@ -1,2 +1,2 @@
1
- export * from "./AgenticaJsonParseError";
2
- export * from "./AgenticaValidationError";
1
+ export * from "./AgenticaJsonParseError";
2
+ export * from "./AgenticaValidationError";
@@ -1,12 +1,12 @@
1
- import type { AgenticaAssistantMessageHistory } from "../histories/AgenticaAssistantMessageHistory";
2
- import type { IAgenticaEventJson } from "../json/IAgenticaEventJson";
3
-
4
- import type { AgenticaEventBase } from "./AgenticaEventBase";
5
-
6
- export interface AgenticaAssistantMessageEvent
7
- extends AgenticaEventBase<"assistantMessage"> {
8
- stream: AsyncGenerator<string, undefined, undefined>;
9
- join: () => Promise<string>;
10
- toJSON: () => IAgenticaEventJson.IAssistantMessage;
11
- toHistory: () => AgenticaAssistantMessageHistory;
12
- }
1
+ import type { AgenticaAssistantMessageHistory } from "../histories/AgenticaAssistantMessageHistory";
2
+ import type { IAgenticaEventJson } from "../json/IAgenticaEventJson";
3
+
4
+ import type { AgenticaEventBase } from "./AgenticaEventBase";
5
+
6
+ export interface AgenticaAssistantMessageEvent
7
+ extends AgenticaEventBase<"assistantMessage"> {
8
+ stream: AsyncGenerator<string, undefined, undefined>;
9
+ join: () => Promise<string>;
10
+ toJSON: () => IAgenticaEventJson.IAssistantMessage;
11
+ toHistory: () => AgenticaAssistantMessageHistory;
12
+ }
@@ -1,27 +1,27 @@
1
- import type { AgenticaOperation } from "../context/AgenticaOperation";
2
- import type { IAgenticaEventJson } from "../json/IAgenticaEventJson";
3
-
4
- import type { AgenticaEventBase } from "./AgenticaEventBase";
5
-
6
- /**
7
- * Event of a function calling.
8
- *
9
- * @author Samchon
10
- */
11
- export interface AgenticaCallEvent extends AgenticaEventBase<"call"> {
12
- /**
13
- * Target operation to call.
14
- */
15
- operation: AgenticaOperation;
16
-
17
- /**
18
- * Arguments of the function calling.
19
- *
20
- * If you modify this {@link arguments} property, it actually modifies
21
- * the backend server's request. Therefore, be careful when you're
22
- * trying to modify this property.
23
- */
24
- arguments: Record<string, any>;
25
-
26
- toJSON: () => IAgenticaEventJson.ICall;
27
- }
1
+ import type { AgenticaOperation } from "../context/AgenticaOperation";
2
+ import type { IAgenticaEventJson } from "../json/IAgenticaEventJson";
3
+
4
+ import type { AgenticaEventBase } from "./AgenticaEventBase";
5
+
6
+ /**
7
+ * Event of a function calling.
8
+ *
9
+ * @author Samchon
10
+ */
11
+ export interface AgenticaCallEvent extends AgenticaEventBase<"call"> {
12
+ /**
13
+ * Target operation to call.
14
+ */
15
+ operation: AgenticaOperation;
16
+
17
+ /**
18
+ * Arguments of the function calling.
19
+ *
20
+ * If you modify this {@link arguments} property, it actually modifies
21
+ * the backend server's request. Therefore, be careful when you're
22
+ * trying to modify this property.
23
+ */
24
+ arguments: Record<string, any>;
25
+
26
+ toJSON: () => IAgenticaEventJson.ICall;
27
+ }
@@ -1,9 +1,9 @@
1
- import type { AgenticaOperationSelection } from "../context/AgenticaOperationSelection";
2
- import type { IAgenticaEventJson } from "../json/IAgenticaEventJson";
3
-
4
- import type { AgenticaEventBase } from "./AgenticaEventBase";
5
-
6
- export interface AgenticaCancelEvent extends AgenticaEventBase<"cancel"> {
7
- selection: AgenticaOperationSelection;
8
- toJSON: () => IAgenticaEventJson.ICancel;
9
- }
1
+ import type { AgenticaOperationSelection } from "../context/AgenticaOperationSelection";
2
+ import type { IAgenticaEventJson } from "../json/IAgenticaEventJson";
3
+
4
+ import type { AgenticaEventBase } from "./AgenticaEventBase";
5
+
6
+ export interface AgenticaCancelEvent extends AgenticaEventBase<"cancel"> {
7
+ selection: AgenticaOperationSelection;
8
+ toJSON: () => IAgenticaEventJson.ICancel;
9
+ }