UNPKG

@agentica/rpc

Version:

Agentic AI Library specialized in LLM Function Calling

80 lines (79 loc) 2.57 kB
import type { IAgenticaController, MicroAgentica } from "@agentica/core"; import type { ILlmSchema } from "@samchon/openapi"; import type { IAgenticaRpcService } from "./IAgenticaRpcService"; import type { IMicroAgenticaRpcListener } from "./IMicroAgenticaRpcListener"; /** * RPC service for the {@link MicroAgentica}. * * `MicroAgenticaRpcService` is class defining an AI agent service * provided from the server to clients through the RPC (Remote Procedure Call) * paradigm in the websocket protocol. * * Client connecting to the `MicroAgenticaRpcService` providing websocket server * will call the {@link conversate} function remotely through its basic * interface type {@link IAgenticaRpcService} with the RPC paradigm. * * Also, the client provides the {@link IMicroAgenticaRpcListener} type to the * server, so that `MicroAgenticaRpcService` will remotely call the * {@link IMicroAgenticaRpcListener listener}'s functions internally. * * You can open the WebSocket server of the AI agent like below: * * ```typescript * import { * IMicroAgenticaRpcListener, * IAgenticaRpcService, * Agentica, * MicroAgenticaRpcService, * } from "@agentica/core"; * import { WebSocketServer } from "tgrid"; * * const server: WebSocketServer< * null, * IAgenticaRpcService, * IMicroAgenticaRpcListener * > = new WebSocketServer(); * await server.open(3001, async (acceptor) => { * await acceptor.accept( * new MicroAgenticaRpcService({ * agent: new MicroAgentica({ ... }), * listener: acceptor.getDriver(), * }), * ); * }); * ``` * * @author Samchon */ export declare class MicroAgenticaRpcService<Model extends ILlmSchema.Model> implements IAgenticaRpcService<Model> { private readonly props; /** * Initializer Constructor. * * @param props Properties to construct the RPC service */ constructor(props: MicroAgenticaRpcService.IProps<Model>); /** * @inheritDoc */ conversate(content: string | Parameters<typeof MicroAgentica.prototype.conversate>[0]): Promise<void>; /** * @inheritDoc */ getControllers(): Promise<IAgenticaController<Model>[]>; } export declare namespace MicroAgenticaRpcService { /** * Properties to construct the RPC service. */ interface IProps<Model extends ILlmSchema.Model> { /** * AI agent to be controlled. */ agent: MicroAgentica<Model>; /** * Listener to be notified. */ listener: IMicroAgenticaRpcListener; } }