@agentica/core 0.43.3 → 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.
- package/LICENSE +21 -21
- package/README.md +218 -218
- package/lib/constants/AgenticaSystemPrompt.js +1 -1
- package/lib/constants/AgenticaSystemPrompt.js.map +1 -1
- package/lib/context/AgenticaOperation.d.ts +3 -2
- package/lib/context/internal/AgenticaOperationComposer.js.map +1 -1
- package/lib/context/internal/AgenticaTokenUsageAggregator.js.map +1 -1
- package/lib/context/internal/__IChatInitialApplication.d.ts +1 -1
- package/lib/errors/AgenticaJsonParseError.d.ts +5 -8
- package/lib/errors/AgenticaJsonParseError.js +11 -6
- package/lib/errors/AgenticaJsonParseError.js.map +1 -1
- package/lib/errors/AgenticaValidationError.d.ts +1 -1
- package/lib/events/AgenticaExecuteEvent.d.ts +1 -1
- package/lib/events/AgenticaJsonParseErrorEvent.d.ts +2 -2
- package/lib/factory/events.d.ts +2 -3
- package/lib/factory/events.js +1 -2
- package/lib/factory/events.js.map +1 -1
- package/lib/functional/assertHttpController.d.ts +2 -3
- package/lib/functional/assertHttpController.js +3939 -2656
- package/lib/functional/assertHttpController.js.map +1 -1
- package/lib/functional/assertHttpLlmApplication.d.ts +3 -3
- package/lib/functional/assertHttpLlmApplication.js +3939 -2656
- package/lib/functional/assertHttpLlmApplication.js.map +1 -1
- package/lib/functional/assertMcpController.d.ts +2 -2
- package/lib/functional/assertMcpController.js +202 -629
- package/lib/functional/assertMcpController.js.map +1 -1
- package/lib/functional/createMcpLlmApplication.d.ts +6 -0
- package/lib/functional/createMcpLlmApplication.js +56 -0
- package/lib/functional/createMcpLlmApplication.js.map +1 -0
- package/lib/functional/validateHttpController.d.ts +3 -3
- package/lib/functional/validateHttpController.js +3367 -2268
- package/lib/functional/validateHttpController.js.map +1 -1
- package/lib/functional/validateHttpLlmApplication.d.ts +3 -4
- package/lib/functional/validateHttpLlmApplication.js +3367 -2268
- package/lib/functional/validateHttpLlmApplication.js.map +1 -1
- package/lib/functional/validateMcpController.d.ts +2 -2
- package/lib/functional/validateMcpController.js +388 -1161
- package/lib/functional/validateMcpController.js.map +1 -1
- package/lib/histories/AgenticaExecuteHistory.d.ts +1 -1
- package/lib/index.mjs +21256 -18946
- package/lib/index.mjs.map +1 -1
- package/lib/orchestrate/call.js +43 -56
- package/lib/orchestrate/call.js.map +1 -1
- package/lib/orchestrate/cancel.js +9 -66
- package/lib/orchestrate/cancel.js.map +1 -1
- package/lib/orchestrate/initialize.js +4 -947
- package/lib/orchestrate/initialize.js.map +1 -1
- package/lib/orchestrate/select.js +11 -68
- package/lib/orchestrate/select.js.map +1 -1
- package/lib/structures/IAgenticaController.d.ts +143 -151
- package/lib/structures/IMcpTool.d.ts +52 -0
- package/lib/structures/IMcpTool.js +3 -0
- package/lib/structures/IMcpTool.js.map +1 -0
- package/lib/utils/ChatGptCompletionMessageUtil.js +16 -5
- package/lib/utils/ChatGptCompletionMessageUtil.js.map +1 -1
- package/lib/utils/ChatGptCompletionMessageUtil.spec.js +0 -5
- package/lib/utils/ChatGptCompletionMessageUtil.spec.js.map +1 -1
- package/package.json +7 -9
- package/prompts/cancel.md +5 -5
- package/prompts/common.md +3 -3
- package/prompts/describe.md +7 -7
- package/prompts/execute.md +122 -122
- package/prompts/initialize.md +3 -3
- package/prompts/json_parse_error.md +35 -33
- package/prompts/select.md +7 -7
- package/prompts/validate.md +123 -123
- package/prompts/validate_repeated.md +31 -31
- package/src/Agentica.ts +367 -367
- package/src/MicroAgentica.ts +357 -357
- package/src/constants/AgenticaConstant.ts +4 -4
- package/src/constants/AgenticaDefaultPrompt.ts +44 -44
- package/src/constants/AgenticaSystemPrompt.ts +1 -1
- package/src/constants/index.ts +2 -2
- package/src/context/AgenticaContext.ts +136 -136
- package/src/context/AgenticaContextRequestResult.ts +14 -14
- package/src/context/AgenticaOperation.ts +73 -72
- package/src/context/AgenticaOperationCollection.ts +49 -49
- package/src/context/AgenticaOperationSelection.ts +9 -9
- package/src/context/AgenticaTokenUsage.ts +186 -186
- package/src/context/MicroAgenticaContext.ts +99 -99
- package/src/context/index.ts +5 -5
- package/src/context/internal/AgenticaOperationComposer.ts +177 -177
- package/src/context/internal/AgenticaTokenUsageAggregator.ts +66 -66
- package/src/context/internal/__IChatCancelFunctionsApplication.ts +23 -23
- package/src/context/internal/__IChatFunctionReference.ts +21 -21
- package/src/context/internal/__IChatInitialApplication.ts +15 -15
- package/src/context/internal/__IChatSelectFunctionsApplication.ts +24 -24
- package/src/context/internal/isAgenticaContext.ts +11 -11
- package/src/errors/AgenticaJsonParseError.ts +52 -47
- package/src/errors/AgenticaValidationError.ts +49 -49
- package/src/errors/index.ts +2 -2
- package/src/events/AgenticaAssistantMessageEvent.ts +12 -12
- package/src/events/AgenticaCallEvent.ts +27 -27
- package/src/events/AgenticaCancelEvent.ts +9 -9
- package/src/events/AgenticaDescribeEvent.ts +14 -14
- package/src/events/AgenticaEvent.ts +59 -59
- package/src/events/AgenticaEvent.type.ts +19 -19
- package/src/events/AgenticaEventBase.ts +18 -18
- package/src/events/AgenticaEventSource.ts +6 -6
- package/src/events/AgenticaExecuteEvent.ts +45 -45
- package/src/events/AgenticaInitializeEvent.ts +7 -7
- package/src/events/AgenticaJsonParseErrorEvent.ts +16 -15
- package/src/events/AgenticaRequestEvent.ts +27 -27
- package/src/events/AgenticaResponseEvent.ts +32 -32
- package/src/events/AgenticaSelectEvent.ts +11 -11
- package/src/events/AgenticaUserMessageEvent.ts +12 -12
- package/src/events/AgenticaValidateEvent.ts +32 -32
- package/src/events/MicroAgenticaEvent.ts +45 -45
- package/src/events/index.ts +15 -15
- package/src/factory/events.ts +357 -359
- package/src/factory/histories.ts +348 -348
- package/src/factory/index.ts +3 -3
- package/src/factory/operations.ts +16 -16
- package/src/functional/assertHttpController.ts +106 -104
- package/src/functional/assertHttpLlmApplication.ts +52 -57
- package/src/functional/assertMcpController.ts +47 -44
- package/src/functional/createMcpLlmApplication.ts +72 -0
- package/src/functional/index.ts +7 -7
- package/src/functional/validateHttpController.ts +113 -110
- package/src/functional/validateHttpLlmApplication.ts +65 -70
- package/src/functional/validateMcpController.ts +53 -50
- package/src/histories/AgenticaAssistantMessageHistory.ts +10 -10
- package/src/histories/AgenticaCancelHistory.ts +8 -8
- package/src/histories/AgenticaDescribeHistory.ts +18 -18
- package/src/histories/AgenticaExecuteHistory.ts +64 -64
- package/src/histories/AgenticaHistory.ts +28 -28
- package/src/histories/AgenticaHistoryBase.ts +35 -35
- package/src/histories/AgenticaSelectHistory.ts +8 -8
- package/src/histories/AgenticaSystemMessageHistory.ts +10 -10
- package/src/histories/AgenticaUserMessageHistory.ts +11 -11
- package/src/histories/MicroAgenticaHistory.ts +19 -19
- package/src/histories/contents/AgenticaUserMessageAudioContent.ts +21 -21
- package/src/histories/contents/AgenticaUserMessageContent.ts +19 -19
- package/src/histories/contents/AgenticaUserMessageContentBase.ts +6 -6
- package/src/histories/contents/AgenticaUserMessageFileContent.ts +25 -25
- package/src/histories/contents/AgenticaUserMessageImageContent.ts +33 -33
- package/src/histories/contents/AgenticaUserMessageTextContent.ts +15 -15
- package/src/histories/contents/index.ts +5 -5
- package/src/histories/index.ts +10 -10
- package/src/index.ts +15 -15
- package/src/json/IAgenticaEventJson.ts +265 -265
- package/src/json/IAgenticaEventJson.type.ts +19 -19
- package/src/json/IAgenticaHistoryJson.ts +165 -165
- package/src/json/IAgenticaHistoryJson.type.ts +19 -19
- package/src/json/IAgenticaOperationJson.ts +36 -36
- package/src/json/IAgenticaOperationSelectionJson.ts +26 -26
- package/src/json/IAgenticaTokenUsageJson.ts +107 -107
- package/src/json/IMicroAgenticaEventJson.ts +22 -22
- package/src/json/IMicroAgenticaHistoryJson.ts +25 -25
- package/src/json/index.ts +7 -7
- package/src/orchestrate/call.ts +542 -558
- package/src/orchestrate/cancel.ts +265 -269
- package/src/orchestrate/describe.ts +66 -66
- package/src/orchestrate/execute.ts +61 -61
- package/src/orchestrate/index.ts +6 -6
- package/src/orchestrate/initialize.ts +102 -102
- package/src/orchestrate/internal/cancelFunctionFromContext.ts +33 -33
- package/src/orchestrate/internal/selectFunctionFromContext.ts +34 -34
- package/src/orchestrate/select.ts +320 -322
- package/src/structures/IAgenticaConfig.ts +83 -83
- package/src/structures/IAgenticaConfigBase.ts +87 -87
- package/src/structures/IAgenticaController.ts +143 -151
- package/src/structures/IAgenticaExecutor.ts +167 -167
- package/src/structures/IAgenticaProps.ts +78 -78
- package/src/structures/IAgenticaSystemPrompt.ts +236 -236
- package/src/structures/IAgenticaVendor.ts +54 -54
- package/src/structures/IMcpTool.ts +60 -0
- package/src/structures/IMicroAgenticaConfig.ts +56 -56
- package/src/structures/IMicroAgenticaExecutor.ts +67 -67
- package/src/structures/IMicroAgenticaProps.ts +77 -77
- package/src/structures/IMicroAgenticaSystemPrompt.ts +169 -169
- package/src/structures/index.ts +10 -10
- package/src/transformers/transformHistory.ts +172 -172
- package/src/utils/AssistantMessageEmptyError.ts +20 -20
- package/src/utils/AsyncQueue.spec.ts +355 -355
- package/src/utils/AsyncQueue.ts +95 -95
- package/src/utils/ByteArrayUtil.ts +5 -5
- package/src/utils/ChatGptCompletionMessageUtil.spec.ts +314 -320
- package/src/utils/ChatGptCompletionMessageUtil.ts +210 -195
- package/src/utils/ChatGptCompletionStreamingUtil.spec.ts +909 -909
- package/src/utils/ChatGptCompletionStreamingUtil.ts +91 -91
- package/src/utils/ChatGptTokenUsageAggregator.spec.ts +226 -226
- package/src/utils/ChatGptTokenUsageAggregator.ts +57 -57
- package/src/utils/MPSC.spec.ts +276 -276
- package/src/utils/MPSC.ts +42 -42
- package/src/utils/Singleton.spec.ts +138 -138
- package/src/utils/Singleton.ts +42 -42
- package/src/utils/StreamUtil.spec.ts +512 -512
- package/src/utils/StreamUtil.ts +87 -87
- package/src/utils/__map_take.spec.ts +140 -140
- package/src/utils/__map_take.ts +13 -13
- package/src/utils/__retry.spec.ts +198 -198
- package/src/utils/__retry.ts +18 -18
- package/src/utils/assertExecuteFailure.ts +16 -16
- package/src/utils/index.ts +4 -4
- package/src/utils/request.ts +140 -140
- package/src/utils/types.ts +50 -50
- package/lib/context/internal/AgenticaOperationComposer.spec.d.ts +0 -1
- package/lib/context/internal/AgenticaOperationComposer.spec.js +0 -353
- package/lib/context/internal/AgenticaOperationComposer.spec.js.map +0 -1
- package/lib/utils/JsonUtil.d.ts +0 -8
- package/lib/utils/JsonUtil.js +0 -349
- package/lib/utils/JsonUtil.js.map +0 -1
- package/src/context/internal/AgenticaOperationComposer.spec.ts +0 -401
- 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
|
+
}
|
package/src/context/index.ts
CHANGED
|
@@ -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
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
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
|
+
};
|