@agentica/core 0.43.3 → 0.44.0-dev.20260313-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 (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 -18946
  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 -349
  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 -460
@@ -1,99 +1,99 @@
1
- import type OpenAI from "openai";
2
-
3
- import type { MicroAgenticaEvent } from "../events/MicroAgenticaEvent";
4
- import type { AgenticaUserMessageHistory } from "../histories/AgenticaUserMessageHistory";
5
- import type { MicroAgenticaHistory } from "../histories/MicroAgenticaHistory";
6
- import type { IMicroAgenticaConfig } from "../structures/IMicroAgenticaConfig";
7
-
8
- import type { AgenticaContextRequestResult } from "./AgenticaContextRequestResult";
9
- import type { AgenticaOperationCollection } from "./AgenticaOperationCollection";
10
-
11
- /**
12
- * Context of the Micro Agentic AI agent.
13
- *
14
- * `MicroAgenticaContext` is a structure defining the context of the
15
- * internal agents composing the {@link MicroAgentica}.
16
- *
17
- * It contains every information that is required to interact with
18
- * the AI vendor like OpenAI. It contains every operations for LLM
19
- * function calling, and configuration used for the agent construction.
20
- * And it contains the prompt histories, and facade controller
21
- * functions for interacting with the {@link MicroAgentica} like
22
- * {@link dispatch}.
23
- *
24
- * In such reasons, if you're planning to customize some internal
25
- * agents, or add new agents with new process routine, you have to
26
- * understand this context structure. Otherwise you don't have any
27
- * plan to customize the internal agents, this context information is
28
- * not important for you.
29
- *
30
- * @author Samchon
31
- */
32
- export interface MicroAgenticaContext {
33
- // ----
34
- // APPLICATION
35
- // ----
36
- /**
37
- * Collection of operations.
38
- *
39
- * Collection of operations from every controllers, and their
40
- * groups composed by the divide and conquer rule for the
41
- * efficient operation selection if configured.
42
- */
43
- operations: AgenticaOperationCollection;
44
-
45
- /**
46
- * Configuration of the agent.
47
- *
48
- * Configuration of the agent, that is used when constructing the
49
- * {@link Agentica} instance.
50
- *
51
- * @todo Write detaily after supporting the agent customization feature
52
- */
53
- config: IMicroAgenticaConfig | undefined;
54
-
55
- // ----
56
- // STATES
57
- // ----
58
- /**
59
- * Prompt histories.
60
- */
61
- histories: MicroAgenticaHistory[];
62
-
63
- /**
64
- * Text prompt of the user.
65
- *
66
- * Text conversation written the by user through the
67
- * {@link Agentica.conversate} function.
68
- */
69
- prompt: AgenticaUserMessageHistory;
70
-
71
- /**
72
- * Abort signal.
73
- */
74
- abortSignal?: AbortSignal;
75
- // ----
76
- // HANDLERS
77
- // ----
78
- /**
79
- * Dispatch event.
80
- *
81
- * Dispatch event so that the agent can be handle the event
82
- * through the {@link MicroAgentica.on} function.
83
- *
84
- * @param event Event to deliver
85
- */
86
- dispatch: (event: MicroAgenticaEvent) => Promise<void>;
87
-
88
- /**
89
- * Request to the OpenAI server.
90
- *
91
- * @param source The source agent of the agent
92
- * @param body The request body to the OpenAI server
93
- * @returns Response from the OpenAI server
94
- */
95
- request: (
96
- source: MicroAgenticaEvent.Source,
97
- body: Omit<OpenAI.ChatCompletionCreateParamsStreaming, "model" | "stream">,
98
- ) => Promise<AgenticaContextRequestResult>;
99
- }
1
+ import type OpenAI from "openai";
2
+
3
+ import type { MicroAgenticaEvent } from "../events/MicroAgenticaEvent";
4
+ import type { AgenticaUserMessageHistory } from "../histories/AgenticaUserMessageHistory";
5
+ import type { MicroAgenticaHistory } from "../histories/MicroAgenticaHistory";
6
+ import type { IMicroAgenticaConfig } from "../structures/IMicroAgenticaConfig";
7
+
8
+ import type { AgenticaContextRequestResult } from "./AgenticaContextRequestResult";
9
+ import type { AgenticaOperationCollection } from "./AgenticaOperationCollection";
10
+
11
+ /**
12
+ * Context of the Micro Agentic AI agent.
13
+ *
14
+ * `MicroAgenticaContext` is a structure defining the context of the
15
+ * internal agents composing the {@link MicroAgentica}.
16
+ *
17
+ * It contains every information that is required to interact with
18
+ * the AI vendor like OpenAI. It contains every operations for LLM
19
+ * function calling, and configuration used for the agent construction.
20
+ * And it contains the prompt histories, and facade controller
21
+ * functions for interacting with the {@link MicroAgentica} like
22
+ * {@link dispatch}.
23
+ *
24
+ * In such reasons, if you're planning to customize some internal
25
+ * agents, or add new agents with new process routine, you have to
26
+ * understand this context structure. Otherwise you don't have any
27
+ * plan to customize the internal agents, this context information is
28
+ * not important for you.
29
+ *
30
+ * @author Samchon
31
+ */
32
+ export interface MicroAgenticaContext {
33
+ // ----
34
+ // APPLICATION
35
+ // ----
36
+ /**
37
+ * Collection of operations.
38
+ *
39
+ * Collection of operations from every controllers, and their
40
+ * groups composed by the divide and conquer rule for the
41
+ * efficient operation selection if configured.
42
+ */
43
+ operations: AgenticaOperationCollection;
44
+
45
+ /**
46
+ * Configuration of the agent.
47
+ *
48
+ * Configuration of the agent, that is used when constructing the
49
+ * {@link Agentica} instance.
50
+ *
51
+ * @todo Write detaily after supporting the agent customization feature
52
+ */
53
+ config: IMicroAgenticaConfig | undefined;
54
+
55
+ // ----
56
+ // STATES
57
+ // ----
58
+ /**
59
+ * Prompt histories.
60
+ */
61
+ histories: MicroAgenticaHistory[];
62
+
63
+ /**
64
+ * Text prompt of the user.
65
+ *
66
+ * Text conversation written the by user through the
67
+ * {@link Agentica.conversate} function.
68
+ */
69
+ prompt: AgenticaUserMessageHistory;
70
+
71
+ /**
72
+ * Abort signal.
73
+ */
74
+ abortSignal?: AbortSignal;
75
+ // ----
76
+ // HANDLERS
77
+ // ----
78
+ /**
79
+ * Dispatch event.
80
+ *
81
+ * Dispatch event so that the agent can be handle the event
82
+ * through the {@link MicroAgentica.on} function.
83
+ *
84
+ * @param event Event to deliver
85
+ */
86
+ dispatch: (event: MicroAgenticaEvent) => Promise<void>;
87
+
88
+ /**
89
+ * Request to the OpenAI server.
90
+ *
91
+ * @param source The source agent of the agent
92
+ * @param body The request body to the OpenAI server
93
+ * @returns Response from the OpenAI server
94
+ */
95
+ request: (
96
+ source: MicroAgenticaEvent.Source,
97
+ body: Omit<OpenAI.ChatCompletionCreateParamsStreaming, "model" | "stream">,
98
+ ) => Promise<AgenticaContextRequestResult>;
99
+ }
@@ -1,5 +1,5 @@
1
- export * from "./AgenticaContext";
2
- export * from "./AgenticaOperation";
3
- export * from "./AgenticaOperationCollection";
4
- export * from "./AgenticaOperationSelection";
5
- export * from "./AgenticaTokenUsage";
1
+ export * from "./AgenticaContext";
2
+ export * from "./AgenticaOperation";
3
+ export * from "./AgenticaOperationCollection";
4
+ export * from "./AgenticaOperationSelection";
5
+ export * from "./AgenticaTokenUsage";
@@ -1,177 +1,177 @@
1
- import type { IAgenticaConfig } from "../../structures/IAgenticaConfig";
2
- import type { IAgenticaController } from "../../structures/IAgenticaController";
3
- import type { IMicroAgenticaConfig } from "../../structures/IMicroAgenticaConfig";
4
- import type { AgenticaOperation } from "../AgenticaOperation";
5
- import type { AgenticaOperationCollection } from "../AgenticaOperationCollection";
6
-
7
- import { __map_take } from "../../utils/__map_take";
8
-
9
- /**
10
- * Compose the agentica operation collection.
11
- *
12
- * Compose the {@link AgenticaOperationCollection} from the given
13
- * controllers and config.
14
- *
15
- * @internal
16
- */
17
- export function compose(props: {
18
- controllers: IAgenticaController[];
19
- config?: IAgenticaConfig | IMicroAgenticaConfig | undefined;
20
- }): AgenticaOperationCollection {
21
- const unique: boolean = (props.controllers.length === 1 || (() => {
22
- const names = props.controllers.map(
23
-
24
- controllers => controllers.application.functions.map((func: { name: string }) => func.name),
25
- ).flat();
26
- return new Set(names).size === names.length;
27
- })());
28
-
29
- const array: AgenticaOperation[] = getOperations({
30
- controllers: props.controllers,
31
- naming: (func: string, controllerIndex: number) => unique ? func : `_${controllerIndex}_${func}`,
32
- });
33
- const capacity: number | undefined = (props.config as IAgenticaConfig)?.capacity;
34
- const divided: AgenticaOperation[][] | undefined
35
- = capacity !== undefined && array.length > capacity
36
- ? divide({
37
- array,
38
- capacity,
39
- })
40
- : undefined;
41
-
42
- const flat: Map<string, AgenticaOperation> = new Map();
43
- const group: Map<string, Map<string, AgenticaOperation>> = new Map();
44
- for (const item of array) {
45
- flat.set(item.name, item);
46
- __map_take(group, item.controller.name, () => new Map()).set(
47
- item.name,
48
- item,
49
- );
50
- }
51
- return {
52
- array,
53
- divided,
54
- flat,
55
- group,
56
- };
57
- }
58
-
59
- /**
60
- * @internal
61
- */
62
- export function getOperations(props: {
63
- controllers: IAgenticaController[];
64
- naming: (func: string, controllerIndex: number) => string;
65
- }): AgenticaOperation[] {
66
- return props.controllers.flatMap((controller, idx) => {
67
- switch (controller.protocol) {
68
- case "http":{
69
- return toHttpOperations({ controller, index: idx, naming: props.naming }); }
70
- case "class":{
71
- return toClassOperations({ controller, index: idx, naming: props.naming }); }
72
- case "mcp": {
73
- return toMcpOperations({ controller, index: idx, naming: props.naming });
74
- }
75
- default:
76
- controller satisfies never;
77
- throw new Error(`Unsupported protocol: ${(controller as { protocol: string }).protocol}`);
78
- }
79
- });
80
- }
81
-
82
- /**
83
- * @internal
84
- */
85
- export function toHttpOperations(props: {
86
- controller: IAgenticaController.IHttp;
87
- index: number;
88
- naming: (func: string, controllerIndex: number) => string;
89
- }): AgenticaOperation[] {
90
- return props.controller.application.functions.map(func => ({
91
- protocol: "http",
92
- controller: props.controller,
93
- function: func,
94
- name: props.naming(func.name, props.index),
95
- toJSON: () => ({
96
- protocol: "http",
97
- controller: props.controller.name,
98
- function: func.name,
99
- name: props.naming(func.name, props.index),
100
- }),
101
- }));
102
- }
103
-
104
- /**
105
- * @internal
106
- */
107
- export function toClassOperations(props: {
108
- controller: IAgenticaController.IClass;
109
- index: number;
110
- naming: (func: string, controllerIndex: number) => string;
111
- }): AgenticaOperation[] {
112
- return props.controller.application.functions.map(func => ({
113
- protocol: "class",
114
- controller: props.controller,
115
- function: func,
116
- name: props.naming(func.name, props.index),
117
- toJSON: () => ({
118
- protocol: "class",
119
- controller: props.controller.name,
120
- function: func.name,
121
- name: props.naming(func.name, props.index),
122
- }),
123
- }));
124
- }
125
-
126
- /**
127
- * @internal
128
- */
129
- export function toMcpOperations(props: {
130
- controller: IAgenticaController.IMcp;
131
- index: number;
132
- naming: (func: string, controllerIndex: number) => string;
133
- }): AgenticaOperation[] {
134
- return props.controller.application.functions.map(func => ({
135
- protocol: "mcp",
136
- controller: props.controller,
137
-
138
- function: func,
139
-
140
- name: props.naming(func.name, props.index),
141
- toJSON: () => ({
142
- protocol: "mcp",
143
- controller: props.controller.name,
144
-
145
- function: func.name,
146
-
147
- name: props.naming(func.name, props.index),
148
- }),
149
- }));
150
- }
151
-
152
- /**
153
- * @internal
154
- */
155
- export function divide<T>(props: {
156
- array: T[];
157
- capacity: number;
158
- }): T[][] {
159
- if (props.capacity <= 0) {
160
- throw new Error("Capacity must be a positive integer");
161
- }
162
- if (Number.isNaN(props.capacity)) {
163
- throw new TypeError("Capacity must be a positive integer");
164
- }
165
- if (props.capacity === Infinity) {
166
- throw new Error("Capacity must be a positive integer");
167
- }
168
-
169
- const size: number = Math.ceil(props.array.length / props.capacity);
170
- const capacity: number = Math.ceil(props.array.length / size);
171
- const replica: T[] = props.array.slice();
172
- return Array.from({ length: size }, () => replica.splice(0, capacity));
173
- }
174
-
175
- export const AgenticaOperationComposer = {
176
- compose,
177
- };
1
+ import type { IAgenticaConfig } from "../../structures/IAgenticaConfig";
2
+ import type { IAgenticaController } from "../../structures/IAgenticaController";
3
+ import type { IMicroAgenticaConfig } from "../../structures/IMicroAgenticaConfig";
4
+ import type { AgenticaOperation } from "../AgenticaOperation";
5
+ import type { AgenticaOperationCollection } from "../AgenticaOperationCollection";
6
+
7
+ import { __map_take } from "../../utils/__map_take";
8
+
9
+ /**
10
+ * Compose the agentica operation collection.
11
+ *
12
+ * Compose the {@link AgenticaOperationCollection} from the given
13
+ * controllers and config.
14
+ *
15
+ * @internal
16
+ */
17
+ export function compose(props: {
18
+ controllers: IAgenticaController[];
19
+ config?: IAgenticaConfig | IMicroAgenticaConfig | undefined;
20
+ }): AgenticaOperationCollection {
21
+ const unique: boolean = (props.controllers.length === 1 || (() => {
22
+ const names = props.controllers.map(
23
+
24
+ controllers => controllers.application.functions.map((func: { name: string }) => func.name),
25
+ ).flat();
26
+ return new Set(names).size === names.length;
27
+ })());
28
+
29
+ const array: AgenticaOperation[] = getOperations({
30
+ controllers: props.controllers,
31
+ naming: (func: string, controllerIndex: number) => unique ? func : `_${controllerIndex}_${func}`,
32
+ });
33
+ const capacity: number | undefined = (props.config as IAgenticaConfig)?.capacity;
34
+ const divided: AgenticaOperation[][] | undefined
35
+ = capacity !== undefined && array.length > capacity
36
+ ? divide({
37
+ array,
38
+ capacity,
39
+ })
40
+ : undefined;
41
+
42
+ const flat: Map<string, AgenticaOperation> = new Map();
43
+ const group: Map<string, Map<string, AgenticaOperation>> = new Map();
44
+ for (const item of array) {
45
+ flat.set(item.name, item);
46
+ __map_take(group, item.controller.name, () => new Map()).set(
47
+ item.name,
48
+ item,
49
+ );
50
+ }
51
+ return {
52
+ array,
53
+ divided,
54
+ flat,
55
+ group,
56
+ };
57
+ }
58
+
59
+ /**
60
+ * @internal
61
+ */
62
+ export function getOperations(props: {
63
+ controllers: IAgenticaController[];
64
+ naming: (func: string, controllerIndex: number) => string;
65
+ }): AgenticaOperation[] {
66
+ return props.controllers.flatMap((controller, idx) => {
67
+ switch (controller.protocol) {
68
+ case "http":{
69
+ return toHttpOperations({ controller, index: idx, naming: props.naming }); }
70
+ case "class":{
71
+ return toClassOperations({ controller, index: idx, naming: props.naming }); }
72
+ case "mcp": {
73
+ return toMcpOperations({ controller, index: idx, naming: props.naming });
74
+ }
75
+ default:
76
+ controller satisfies never;
77
+ throw new Error(`Unsupported protocol: ${(controller as { protocol: string }).protocol}`);
78
+ }
79
+ });
80
+ }
81
+
82
+ /**
83
+ * @internal
84
+ */
85
+ export function toHttpOperations(props: {
86
+ controller: IAgenticaController.IHttp;
87
+ index: number;
88
+ naming: (func: string, controllerIndex: number) => string;
89
+ }): AgenticaOperation[] {
90
+ return props.controller.application.functions.map(func => ({
91
+ protocol: "http",
92
+ controller: props.controller,
93
+ function: func,
94
+ name: props.naming(func.name, props.index),
95
+ toJSON: () => ({
96
+ protocol: "http",
97
+ controller: props.controller.name,
98
+ function: func.name,
99
+ name: props.naming(func.name, props.index),
100
+ }),
101
+ }));
102
+ }
103
+
104
+ /**
105
+ * @internal
106
+ */
107
+ export function toClassOperations(props: {
108
+ controller: IAgenticaController.IClass;
109
+ index: number;
110
+ naming: (func: string, controllerIndex: number) => string;
111
+ }): AgenticaOperation[] {
112
+ return props.controller.application.functions.map(func => ({
113
+ protocol: "class",
114
+ controller: props.controller,
115
+ function: func,
116
+ name: props.naming(func.name, props.index),
117
+ toJSON: () => ({
118
+ protocol: "class",
119
+ controller: props.controller.name,
120
+ function: func.name,
121
+ name: props.naming(func.name, props.index),
122
+ }),
123
+ }));
124
+ }
125
+
126
+ /**
127
+ * @internal
128
+ */
129
+ export function toMcpOperations(props: {
130
+ controller: IAgenticaController.IMcp;
131
+ index: number;
132
+ naming: (func: string, controllerIndex: number) => string;
133
+ }): AgenticaOperation[] {
134
+ return props.controller.application.functions.map(func => ({
135
+ protocol: "mcp",
136
+ controller: props.controller,
137
+
138
+ function: func,
139
+
140
+ name: props.naming(func.name, props.index),
141
+ toJSON: () => ({
142
+ protocol: "mcp",
143
+ controller: props.controller.name,
144
+
145
+ function: func.name,
146
+
147
+ name: props.naming(func.name, props.index),
148
+ }),
149
+ }));
150
+ }
151
+
152
+ /**
153
+ * @internal
154
+ */
155
+ export function divide<T>(props: {
156
+ array: T[];
157
+ capacity: number;
158
+ }): T[][] {
159
+ if (props.capacity <= 0) {
160
+ throw new Error("Capacity must be a positive integer");
161
+ }
162
+ if (Number.isNaN(props.capacity)) {
163
+ throw new TypeError("Capacity must be a positive integer");
164
+ }
165
+ if (props.capacity === Infinity) {
166
+ throw new Error("Capacity must be a positive integer");
167
+ }
168
+
169
+ const size: number = Math.ceil(props.array.length / props.capacity);
170
+ const capacity: number = Math.ceil(props.array.length / size);
171
+ const replica: T[] = props.array.slice();
172
+ return Array.from({ length: size }, () => replica.splice(0, capacity));
173
+ }
174
+
175
+ export const AgenticaOperationComposer = {
176
+ compose,
177
+ };