@symbolica/agentica 0.2.11-rc
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 +77 -0
- package/README.md +50 -0
- package/bun/agentica.plugin.ts +40 -0
- package/default-configs/agentica-hello-world.ts +12 -0
- package/default-configs/esbuild.config.ts +30 -0
- package/default-configs/next.config.ts +9 -0
- package/default-configs/rollup.config.ts +57 -0
- package/default-configs/vite.config.ts +6 -0
- package/default-configs/webpack.config.ts +5 -0
- package/dist/bin/agentica-setup.d.ts +3 -0
- package/dist/bin/agentica-setup.d.ts.map +1 -0
- package/dist/bin/agentica-setup.js +1407 -0
- package/dist/bin/agentica-setup.js.map +1 -0
- package/dist/src/agentica/agent.d.ts +68 -0
- package/dist/src/agentica/agent.d.ts.map +1 -0
- package/dist/src/agentica/agent.js +171 -0
- package/dist/src/agentica/agent.js.map +1 -0
- package/dist/src/agentica/agentic.d.ts +35 -0
- package/dist/src/agentica/agentic.d.ts.map +1 -0
- package/dist/src/agentica/agentic.js +86 -0
- package/dist/src/agentica/agentic.js.map +1 -0
- package/dist/src/agentica/common.d.ts +89 -0
- package/dist/src/agentica/common.d.ts.map +1 -0
- package/dist/src/agentica/common.js +229 -0
- package/dist/src/agentica/common.js.map +1 -0
- package/dist/src/agentica/index.d.ts +3 -0
- package/dist/src/agentica/index.d.ts.map +1 -0
- package/dist/src/agentica/index.js +3 -0
- package/dist/src/agentica/index.js.map +1 -0
- package/dist/src/agentica/template.d.ts +19 -0
- package/dist/src/agentica/template.d.ts.map +1 -0
- package/dist/src/agentica/template.js +44 -0
- package/dist/src/agentica/template.js.map +1 -0
- package/dist/src/agentica-client/agentica-client.d.ts +14 -0
- package/dist/src/agentica-client/agentica-client.d.ts.map +1 -0
- package/dist/src/agentica-client/agentica-client.js +109 -0
- package/dist/src/agentica-client/agentica-client.js.map +1 -0
- package/dist/src/agentica-client/global-csm.d.ts +6 -0
- package/dist/src/agentica-client/global-csm.d.ts.map +1 -0
- package/dist/src/agentica-client/global-csm.js +33 -0
- package/dist/src/agentica-client/global-csm.js.map +1 -0
- package/dist/src/agentica-client/index.d.ts +3 -0
- package/dist/src/agentica-client/index.d.ts.map +1 -0
- package/dist/src/agentica-client/index.js +3 -0
- package/dist/src/agentica-client/index.js.map +1 -0
- package/dist/src/agentica-client/utils.d.ts +2 -0
- package/dist/src/agentica-client/utils.d.ts.map +1 -0
- package/dist/src/agentica-client/utils.js +4 -0
- package/dist/src/agentica-client/utils.js.map +1 -0
- package/dist/src/agentica-unplugin.d.ts +21 -0
- package/dist/src/agentica-unplugin.d.ts.map +1 -0
- package/dist/src/agentica-unplugin.js +136 -0
- package/dist/src/agentica-unplugin.js.map +1 -0
- package/dist/src/bundlers/bun.d.ts +7 -0
- package/dist/src/bundlers/bun.d.ts.map +1 -0
- package/dist/src/bundlers/bun.js +55 -0
- package/dist/src/bundlers/bun.js.map +1 -0
- package/dist/src/bundlers/esbuild.d.ts +3 -0
- package/dist/src/bundlers/esbuild.d.ts.map +1 -0
- package/dist/src/bundlers/esbuild.js +3 -0
- package/dist/src/bundlers/esbuild.js.map +1 -0
- package/dist/src/bundlers/rollup.d.ts +3 -0
- package/dist/src/bundlers/rollup.d.ts.map +1 -0
- package/dist/src/bundlers/rollup.js +3 -0
- package/dist/src/bundlers/rollup.js.map +1 -0
- package/dist/src/bundlers/utils.d.ts +5 -0
- package/dist/src/bundlers/utils.d.ts.map +1 -0
- package/dist/src/bundlers/utils.js +37 -0
- package/dist/src/bundlers/utils.js.map +1 -0
- package/dist/src/bundlers/vite.d.ts +3 -0
- package/dist/src/bundlers/vite.d.ts.map +1 -0
- package/dist/src/bundlers/vite.js +3 -0
- package/dist/src/bundlers/vite.js.map +1 -0
- package/dist/src/bundlers/webpack.d.ts +3 -0
- package/dist/src/bundlers/webpack.d.ts.map +1 -0
- package/dist/src/bundlers/webpack.js +3 -0
- package/dist/src/bundlers/webpack.js.map +1 -0
- package/dist/src/client-session-manager/at-exit.d.ts +6 -0
- package/dist/src/client-session-manager/at-exit.d.ts.map +1 -0
- package/dist/src/client-session-manager/at-exit.js +120 -0
- package/dist/src/client-session-manager/at-exit.js.map +1 -0
- package/dist/src/client-session-manager/client-session-manager.d.ts +73 -0
- package/dist/src/client-session-manager/client-session-manager.d.ts.map +1 -0
- package/dist/src/client-session-manager/client-session-manager.js +859 -0
- package/dist/src/client-session-manager/client-session-manager.js.map +1 -0
- package/dist/src/client-session-manager/message-utils.d.ts +7 -0
- package/dist/src/client-session-manager/message-utils.d.ts.map +1 -0
- package/dist/src/client-session-manager/message-utils.js +58 -0
- package/dist/src/client-session-manager/message-utils.js.map +1 -0
- package/dist/src/client-session-manager/queue.d.ts +10 -0
- package/dist/src/client-session-manager/queue.d.ts.map +1 -0
- package/dist/src/client-session-manager/queue.js +41 -0
- package/dist/src/client-session-manager/queue.js.map +1 -0
- package/dist/src/client-session-manager/types.d.ts +23 -0
- package/dist/src/client-session-manager/types.d.ts.map +1 -0
- package/dist/src/client-session-manager/types.js +2 -0
- package/dist/src/client-session-manager/types.js.map +1 -0
- package/dist/src/coming-soon.d.ts +45 -0
- package/dist/src/coming-soon.d.ts.map +1 -0
- package/dist/src/coming-soon.js +206 -0
- package/dist/src/coming-soon.js.map +1 -0
- package/dist/src/common.d.ts +3 -0
- package/dist/src/common.d.ts.map +1 -0
- package/dist/src/common.js +14 -0
- package/dist/src/common.js.map +1 -0
- package/dist/src/errors/base.d.ts +16 -0
- package/dist/src/errors/base.d.ts.map +1 -0
- package/dist/src/errors/base.js +45 -0
- package/dist/src/errors/base.js.map +1 -0
- package/dist/src/errors/bugs.d.ts +5 -0
- package/dist/src/errors/bugs.d.ts.map +1 -0
- package/dist/src/errors/bugs.js +15 -0
- package/dist/src/errors/bugs.js.map +1 -0
- package/dist/src/errors/connection.d.ts +17 -0
- package/dist/src/errors/connection.d.ts.map +1 -0
- package/dist/src/errors/connection.js +27 -0
- package/dist/src/errors/connection.js.map +1 -0
- package/dist/src/errors/generation.d.ts +53 -0
- package/dist/src/errors/generation.d.ts.map +1 -0
- package/dist/src/errors/generation.js +73 -0
- package/dist/src/errors/generation.js.map +1 -0
- package/dist/src/errors/index.d.ts +9 -0
- package/dist/src/errors/index.d.ts.map +1 -0
- package/dist/src/errors/index.js +62 -0
- package/dist/src/errors/index.js.map +1 -0
- package/dist/src/errors/invocation.d.ts +8 -0
- package/dist/src/errors/invocation.d.ts.map +1 -0
- package/dist/src/errors/invocation.js +8 -0
- package/dist/src/errors/invocation.js.map +1 -0
- package/dist/src/index.d.ts +8 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +33 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/logging/composite-logger.d.ts +20 -0
- package/dist/src/logging/composite-logger.d.ts.map +1 -0
- package/dist/src/logging/composite-logger.js +107 -0
- package/dist/src/logging/composite-logger.js.map +1 -0
- package/dist/src/logging/config.d.ts +17 -0
- package/dist/src/logging/config.d.ts.map +1 -0
- package/dist/src/logging/config.js +88 -0
- package/dist/src/logging/config.js.map +1 -0
- package/dist/src/logging/index.d.ts +11 -0
- package/dist/src/logging/index.d.ts.map +1 -0
- package/dist/src/logging/index.js +24 -0
- package/dist/src/logging/index.js.map +1 -0
- package/dist/src/logging/logger.d.ts +30 -0
- package/dist/src/logging/logger.d.ts.map +1 -0
- package/dist/src/logging/logger.js +156 -0
- package/dist/src/logging/logger.js.map +1 -0
- package/dist/src/logging/otel-logger.d.ts +24 -0
- package/dist/src/logging/otel-logger.d.ts.map +1 -0
- package/dist/src/logging/otel-logger.js +114 -0
- package/dist/src/logging/otel-logger.js.map +1 -0
- package/dist/src/logging/span.d.ts +23 -0
- package/dist/src/logging/span.d.ts.map +1 -0
- package/dist/src/logging/span.js +42 -0
- package/dist/src/logging/span.js.map +1 -0
- package/dist/src/logging/types.d.ts +32 -0
- package/dist/src/logging/types.d.ts.map +1 -0
- package/dist/src/logging/types.js +2 -0
- package/dist/src/logging/types.js.map +1 -0
- package/dist/src/nextjs-wrapper.d.ts +6 -0
- package/dist/src/nextjs-wrapper.d.ts.map +1 -0
- package/dist/src/nextjs-wrapper.js +18 -0
- package/dist/src/nextjs-wrapper.js.map +1 -0
- package/dist/src/otel-config.d.ts +18 -0
- package/dist/src/otel-config.d.ts.map +1 -0
- package/dist/src/otel-config.js +116 -0
- package/dist/src/otel-config.js.map +1 -0
- package/dist/src/otel-logging.d.ts +13 -0
- package/dist/src/otel-logging.d.ts.map +1 -0
- package/dist/src/otel-logging.js +63 -0
- package/dist/src/otel-logging.js.map +1 -0
- package/dist/src/transformer/codegen/context-gen.d.ts +31 -0
- package/dist/src/transformer/codegen/context-gen.d.ts.map +1 -0
- package/dist/src/transformer/codegen/context-gen.js +292 -0
- package/dist/src/transformer/codegen/context-gen.js.map +1 -0
- package/dist/src/transformer/processor/class-targets.d.ts +11 -0
- package/dist/src/transformer/processor/class-targets.d.ts.map +1 -0
- package/dist/src/transformer/processor/class-targets.js +35 -0
- package/dist/src/transformer/processor/class-targets.js.map +1 -0
- package/dist/src/transformer/processor/function-targets.d.ts +11 -0
- package/dist/src/transformer/processor/function-targets.d.ts.map +1 -0
- package/dist/src/transformer/processor/function-targets.js +9 -0
- package/dist/src/transformer/processor/function-targets.js.map +1 -0
- package/dist/src/transformer/processor/object-targets.d.ts +11 -0
- package/dist/src/transformer/processor/object-targets.d.ts.map +1 -0
- package/dist/src/transformer/processor/object-targets.js +9 -0
- package/dist/src/transformer/processor/object-targets.js.map +1 -0
- package/dist/src/transformer/processor/processor-utils.d.ts +55 -0
- package/dist/src/transformer/processor/processor-utils.d.ts.map +1 -0
- package/dist/src/transformer/processor/processor-utils.js +491 -0
- package/dist/src/transformer/processor/processor-utils.js.map +1 -0
- package/dist/src/transformer/processor/processor.d.ts +22 -0
- package/dist/src/transformer/processor/processor.d.ts.map +1 -0
- package/dist/src/transformer/processor/processor.js +187 -0
- package/dist/src/transformer/processor/processor.js.map +1 -0
- package/dist/src/transformer/transformer-config.d.ts +9 -0
- package/dist/src/transformer/transformer-config.d.ts.map +1 -0
- package/dist/src/transformer/transformer-config.js +13 -0
- package/dist/src/transformer/transformer-config.js.map +1 -0
- package/dist/src/transformer/transformer-utils.d.ts +29 -0
- package/dist/src/transformer/transformer-utils.d.ts.map +1 -0
- package/dist/src/transformer/transformer-utils.js +349 -0
- package/dist/src/transformer/transformer-utils.js.map +1 -0
- package/dist/src/transformer/transformer.d.ts +4 -0
- package/dist/src/transformer/transformer.d.ts.map +1 -0
- package/dist/src/transformer/transformer.js +96 -0
- package/dist/src/transformer/transformer.js.map +1 -0
- package/dist/src/transformer/traverser/class-traversal.d.ts +9 -0
- package/dist/src/transformer/traverser/class-traversal.d.ts.map +1 -0
- package/dist/src/transformer/traverser/class-traversal.js +292 -0
- package/dist/src/transformer/traverser/class-traversal.js.map +1 -0
- package/dist/src/transformer/traverser/function-traversal.d.ts +7 -0
- package/dist/src/transformer/traverser/function-traversal.d.ts.map +1 -0
- package/dist/src/transformer/traverser/function-traversal.js +29 -0
- package/dist/src/transformer/traverser/function-traversal.js.map +1 -0
- package/dist/src/transformer/traverser/system-traversal.d.ts +9 -0
- package/dist/src/transformer/traverser/system-traversal.d.ts.map +1 -0
- package/dist/src/transformer/traverser/system-traversal.js +309 -0
- package/dist/src/transformer/traverser/system-traversal.js.map +1 -0
- package/dist/src/transformer/traverser/traversal-utils.d.ts +16 -0
- package/dist/src/transformer/traverser/traversal-utils.d.ts.map +1 -0
- package/dist/src/transformer/traverser/traversal-utils.js +132 -0
- package/dist/src/transformer/traverser/traversal-utils.js.map +1 -0
- package/dist/src/transformer/traverser/traverser.d.ts +44 -0
- package/dist/src/transformer/traverser/traverser.d.ts.map +1 -0
- package/dist/src/transformer/traverser/traverser.js +369 -0
- package/dist/src/transformer/traverser/traverser.js.map +1 -0
- package/dist/src/version.d.ts +2 -0
- package/dist/src/version.d.ts.map +1 -0
- package/dist/src/version.js +2 -0
- package/dist/src/version.js.map +1 -0
- package/dist/src/warpc/frame-context/annotation-ctx.d.ts +15 -0
- package/dist/src/warpc/frame-context/annotation-ctx.d.ts.map +1 -0
- package/dist/src/warpc/frame-context/annotation-ctx.js +33 -0
- package/dist/src/warpc/frame-context/annotation-ctx.js.map +1 -0
- package/dist/src/warpc/frame-context/frame-ctx.d.ts +27 -0
- package/dist/src/warpc/frame-context/frame-ctx.d.ts.map +1 -0
- package/dist/src/warpc/frame-context/frame-ctx.js +49 -0
- package/dist/src/warpc/frame-context/frame-ctx.js.map +1 -0
- package/dist/src/warpc/frame-context/message-conversion/decoder.d.ts +24 -0
- package/dist/src/warpc/frame-context/message-conversion/decoder.d.ts.map +1 -0
- package/dist/src/warpc/frame-context/message-conversion/decoder.js +197 -0
- package/dist/src/warpc/frame-context/message-conversion/decoder.js.map +1 -0
- package/dist/src/warpc/frame-context/message-conversion/encoder.d.ts +21 -0
- package/dist/src/warpc/frame-context/message-conversion/encoder.d.ts.map +1 -0
- package/dist/src/warpc/frame-context/message-conversion/encoder.js +225 -0
- package/dist/src/warpc/frame-context/message-conversion/encoder.js.map +1 -0
- package/dist/src/warpc/frame-context/resource-ctx.d.ts +45 -0
- package/dist/src/warpc/frame-context/resource-ctx.d.ts.map +1 -0
- package/dist/src/warpc/frame-context/resource-ctx.js +112 -0
- package/dist/src/warpc/frame-context/resource-ctx.js.map +1 -0
- package/dist/src/warpc/frame-context/synthetic-resources/factory.d.ts +22 -0
- package/dist/src/warpc/frame-context/synthetic-resources/factory.d.ts.map +1 -0
- package/dist/src/warpc/frame-context/synthetic-resources/factory.js +174 -0
- package/dist/src/warpc/frame-context/synthetic-resources/factory.js.map +1 -0
- package/dist/src/warpc/frame-context/synthetic-resources/index.d.ts +1 -0
- package/dist/src/warpc/frame-context/synthetic-resources/index.d.ts.map +1 -0
- package/dist/src/warpc/frame-context/synthetic-resources/index.js +2 -0
- package/dist/src/warpc/frame-context/synthetic-resources/index.js.map +1 -0
- package/dist/src/warpc/frame-context/system-ctx.d.ts +18 -0
- package/dist/src/warpc/frame-context/system-ctx.d.ts.map +1 -0
- package/dist/src/warpc/frame-context/system-ctx.js +132 -0
- package/dist/src/warpc/frame-context/system-ctx.js.map +1 -0
- package/dist/src/warpc/frame-context/uid-gen.d.ts +10 -0
- package/dist/src/warpc/frame-context/uid-gen.d.ts.map +1 -0
- package/dist/src/warpc/frame-context/uid-gen.js +20 -0
- package/dist/src/warpc/frame-context/uid-gen.js.map +1 -0
- package/dist/src/warpc/frame-context/virtual-resources/default.d.ts +16 -0
- package/dist/src/warpc/frame-context/virtual-resources/default.d.ts.map +1 -0
- package/dist/src/warpc/frame-context/virtual-resources/default.js +193 -0
- package/dist/src/warpc/frame-context/virtual-resources/default.js.map +1 -0
- package/dist/src/warpc/frame-context/virtual-resources/dispatcher.d.ts +17 -0
- package/dist/src/warpc/frame-context/virtual-resources/dispatcher.d.ts.map +1 -0
- package/dist/src/warpc/frame-context/virtual-resources/dispatcher.js +257 -0
- package/dist/src/warpc/frame-context/virtual-resources/dispatcher.js.map +1 -0
- package/dist/src/warpc/frame-context/virtual-resources/virtualizer.d.ts +29 -0
- package/dist/src/warpc/frame-context/virtual-resources/virtualizer.d.ts.map +1 -0
- package/dist/src/warpc/frame-context/virtual-resources/virtualizer.js +16 -0
- package/dist/src/warpc/frame-context/virtual-resources/virtualizer.js.map +1 -0
- package/dist/src/warpc/frame.d.ts +45 -0
- package/dist/src/warpc/frame.d.ts.map +1 -0
- package/dist/src/warpc/frame.js +390 -0
- package/dist/src/warpc/frame.js.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/annotations/annotation-msg.d.ts +64 -0
- package/dist/src/warpc/msg-protocol/concept/annotations/annotation-msg.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/annotations/annotation-msg.js +138 -0
- package/dist/src/warpc/msg-protocol/concept/annotations/annotation-msg.js.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/concept.d.ts +33 -0
- package/dist/src/warpc/msg-protocol/concept/concept.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/concept.js +47 -0
- package/dist/src/warpc/msg-protocol/concept/concept.js.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/exception/exception-msg.d.ts +42 -0
- package/dist/src/warpc/msg-protocol/concept/exception/exception-msg.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/exception/exception-msg.js +86 -0
- package/dist/src/warpc/msg-protocol/concept/exception/exception-msg.js.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/rehydrate.d.ts +2 -0
- package/dist/src/warpc/msg-protocol/concept/rehydrate.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/rehydrate.js +56 -0
- package/dist/src/warpc/msg-protocol/concept/rehydrate.js.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/resource/class-msg.d.ts +86 -0
- package/dist/src/warpc/msg-protocol/concept/resource/class-msg.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/resource/class-msg.js +158 -0
- package/dist/src/warpc/msg-protocol/concept/resource/class-msg.js.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/resource/function-msg.d.ts +30 -0
- package/dist/src/warpc/msg-protocol/concept/resource/function-msg.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/resource/function-msg.js +48 -0
- package/dist/src/warpc/msg-protocol/concept/resource/function-msg.js.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/resource/object-msg.d.ts +19 -0
- package/dist/src/warpc/msg-protocol/concept/resource/object-msg.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/resource/object-msg.js +23 -0
- package/dist/src/warpc/msg-protocol/concept/resource/object-msg.js.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/resource/resource-msg.d.ts +27 -0
- package/dist/src/warpc/msg-protocol/concept/resource/resource-msg.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/resource/resource-msg.js +32 -0
- package/dist/src/warpc/msg-protocol/concept/resource/resource-msg.js.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/resource/system-msg.d.ts +48 -0
- package/dist/src/warpc/msg-protocol/concept/resource/system-msg.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/resource/system-msg.js +301 -0
- package/dist/src/warpc/msg-protocol/concept/resource/system-msg.js.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/value/atom.d.ts +33 -0
- package/dist/src/warpc/msg-protocol/concept/value/atom.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/value/atom.js +74 -0
- package/dist/src/warpc/msg-protocol/concept/value/atom.js.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/value/container.d.ts +59 -0
- package/dist/src/warpc/msg-protocol/concept/value/container.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/value/container.js +189 -0
- package/dist/src/warpc/msg-protocol/concept/value/container.js.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/value/symbol.d.ts +20 -0
- package/dist/src/warpc/msg-protocol/concept/value/symbol.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/value/symbol.js +61 -0
- package/dist/src/warpc/msg-protocol/concept/value/symbol.js.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/value/value-msg.d.ts +8 -0
- package/dist/src/warpc/msg-protocol/concept/value/value-msg.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/concept/value/value-msg.js +12 -0
- package/dist/src/warpc/msg-protocol/concept/value/value-msg.js.map +1 -0
- package/dist/src/warpc/msg-protocol/kinds.d.ts +118 -0
- package/dist/src/warpc/msg-protocol/kinds.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/kinds.js +131 -0
- package/dist/src/warpc/msg-protocol/kinds.js.map +1 -0
- package/dist/src/warpc/msg-protocol/rpc/event-msg.d.ts +12 -0
- package/dist/src/warpc/msg-protocol/rpc/event-msg.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/rpc/event-msg.js +19 -0
- package/dist/src/warpc/msg-protocol/rpc/event-msg.js.map +1 -0
- package/dist/src/warpc/msg-protocol/rpc/request-msg.d.ts +90 -0
- package/dist/src/warpc/msg-protocol/rpc/request-msg.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/rpc/request-msg.js +75 -0
- package/dist/src/warpc/msg-protocol/rpc/request-msg.js.map +1 -0
- package/dist/src/warpc/msg-protocol/rpc/response-msg.d.ts +29 -0
- package/dist/src/warpc/msg-protocol/rpc/response-msg.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/rpc/response-msg.js +37 -0
- package/dist/src/warpc/msg-protocol/rpc/response-msg.js.map +1 -0
- package/dist/src/warpc/msg-protocol/rpc/rpc-msg.d.ts +8 -0
- package/dist/src/warpc/msg-protocol/rpc/rpc-msg.d.ts.map +1 -0
- package/dist/src/warpc/msg-protocol/rpc/rpc-msg.js +13 -0
- package/dist/src/warpc/msg-protocol/rpc/rpc-msg.js.map +1 -0
- package/dist/src/warpc/rpc-channel/handler.d.ts +23 -0
- package/dist/src/warpc/rpc-channel/handler.d.ts.map +1 -0
- package/dist/src/warpc/rpc-channel/handler.js +163 -0
- package/dist/src/warpc/rpc-channel/handler.js.map +1 -0
- package/dist/src/warpc/rpc-channel/mux.d.ts +25 -0
- package/dist/src/warpc/rpc-channel/mux.d.ts.map +1 -0
- package/dist/src/warpc/rpc-channel/mux.js +95 -0
- package/dist/src/warpc/rpc-channel/mux.js.map +1 -0
- package/dist/src/warpc/rpc-channel/responder.d.ts +18 -0
- package/dist/src/warpc/rpc-channel/responder.d.ts.map +1 -0
- package/dist/src/warpc/rpc-channel/responder.js +423 -0
- package/dist/src/warpc/rpc-channel/responder.js.map +1 -0
- package/dist/src/warpc/rpc-channel/socket.d.ts +25 -0
- package/dist/src/warpc/rpc-channel/socket.d.ts.map +1 -0
- package/dist/src/warpc/rpc-channel/socket.js +58 -0
- package/dist/src/warpc/rpc-channel/socket.js.map +1 -0
- package/dist/src/warpc/rpc-channel/utils.d.ts +6 -0
- package/dist/src/warpc/rpc-channel/utils.d.ts.map +1 -0
- package/dist/src/warpc/rpc-channel/utils.js +15 -0
- package/dist/src/warpc/rpc-channel/utils.js.map +1 -0
- package/dist/src/warpc/runtime.d.ts +36 -0
- package/dist/src/warpc/runtime.d.ts.map +1 -0
- package/dist/src/warpc/runtime.js +153 -0
- package/dist/src/warpc/runtime.js.map +1 -0
- package/dist-transformer/agentica/agent.d.ts +81 -0
- package/dist-transformer/agentica/agent.d.ts.map +1 -0
- package/dist-transformer/agentica/agent.js +185 -0
- package/dist-transformer/agentica/agentic.d.ts +36 -0
- package/dist-transformer/agentica/agentic.d.ts.map +1 -0
- package/dist-transformer/agentica/agentic.js +100 -0
- package/dist-transformer/agentica/common.d.ts +137 -0
- package/dist-transformer/agentica/common.d.ts.map +1 -0
- package/dist-transformer/agentica/common.js +276 -0
- package/dist-transformer/agentica/template.d.ts +19 -0
- package/dist-transformer/agentica/template.d.ts.map +1 -0
- package/dist-transformer/agentica/template.js +47 -0
- package/dist-transformer/agentica-client/agentica-client.d.ts +32 -0
- package/dist-transformer/agentica-client/agentica-client.d.ts.map +1 -0
- package/dist-transformer/agentica-client/agentica-client.js +129 -0
- package/dist-transformer/agentica-client/global-csm.d.ts +20 -0
- package/dist-transformer/agentica-client/global-csm.d.ts.map +1 -0
- package/dist-transformer/agentica-client/global-csm.js +46 -0
- package/dist-transformer/agentica-client/index.d.ts +3 -0
- package/dist-transformer/agentica-client/index.d.ts.map +1 -0
- package/dist-transformer/agentica-client/index.js +2 -0
- package/dist-transformer/agentica-client/utils.d.ts +5 -0
- package/dist-transformer/agentica-client/utils.d.ts.map +1 -0
- package/dist-transformer/agentica-client/utils.js +6 -0
- package/dist-transformer/bundlers/utils.d.ts +18 -0
- package/dist-transformer/bundlers/utils.d.ts.map +1 -0
- package/dist-transformer/bundlers/utils.js +49 -0
- package/dist-transformer/client-session-manager/at-exit.d.ts +19 -0
- package/dist-transformer/client-session-manager/at-exit.d.ts.map +1 -0
- package/dist-transformer/client-session-manager/at-exit.js +140 -0
- package/dist-transformer/client-session-manager/client-session-manager.d.ts +148 -0
- package/dist-transformer/client-session-manager/client-session-manager.d.ts.map +1 -0
- package/dist-transformer/client-session-manager/client-session-manager.js +966 -0
- package/dist-transformer/client-session-manager/message-utils.d.ts +19 -0
- package/dist-transformer/client-session-manager/message-utils.d.ts.map +1 -0
- package/dist-transformer/client-session-manager/message-utils.js +69 -0
- package/dist-transformer/client-session-manager/queue.d.ts +13 -0
- package/dist-transformer/client-session-manager/queue.d.ts.map +1 -0
- package/dist-transformer/client-session-manager/queue.js +45 -0
- package/dist-transformer/client-session-manager/types.d.ts +23 -0
- package/dist-transformer/client-session-manager/types.d.ts.map +1 -0
- package/dist-transformer/client-session-manager/types.js +1 -0
- package/dist-transformer/coming-soon.d.ts +45 -0
- package/dist-transformer/coming-soon.d.ts.map +1 -0
- package/dist-transformer/coming-soon.js +210 -0
- package/dist-transformer/common.d.ts +3 -0
- package/dist-transformer/common.d.ts.map +1 -0
- package/dist-transformer/common.js +13 -0
- package/dist-transformer/errors/base.d.ts +20 -0
- package/dist-transformer/errors/base.d.ts.map +1 -0
- package/dist-transformer/errors/base.js +43 -0
- package/dist-transformer/errors/bugs.d.ts +7 -0
- package/dist-transformer/errors/bugs.d.ts.map +1 -0
- package/dist-transformer/errors/bugs.js +16 -0
- package/dist-transformer/errors/connection.d.ts +22 -0
- package/dist-transformer/errors/connection.d.ts.map +1 -0
- package/dist-transformer/errors/connection.js +31 -0
- package/dist-transformer/errors/generation.d.ts +75 -0
- package/dist-transformer/errors/generation.d.ts.map +1 -0
- package/dist-transformer/errors/generation.js +98 -0
- package/dist-transformer/errors/index.d.ts +9 -0
- package/dist-transformer/errors/index.d.ts.map +1 -0
- package/dist-transformer/errors/index.js +64 -0
- package/dist-transformer/errors/invocation.d.ts +8 -0
- package/dist-transformer/errors/invocation.d.ts.map +1 -0
- package/dist-transformer/errors/invocation.js +7 -0
- package/dist-transformer/index.d.ts +8 -0
- package/dist-transformer/index.d.ts.map +1 -0
- package/dist-transformer/index.js +40 -0
- package/dist-transformer/logging/composite-logger.d.ts +28 -0
- package/dist-transformer/logging/composite-logger.d.ts.map +1 -0
- package/dist-transformer/logging/composite-logger.js +118 -0
- package/dist-transformer/logging/config.d.ts +17 -0
- package/dist-transformer/logging/config.d.ts.map +1 -0
- package/dist-transformer/logging/config.js +86 -0
- package/dist-transformer/logging/index.d.ts +19 -0
- package/dist-transformer/logging/index.d.ts.map +1 -0
- package/dist-transformer/logging/index.js +32 -0
- package/dist-transformer/logging/logger.d.ts +30 -0
- package/dist-transformer/logging/logger.d.ts.map +1 -0
- package/dist-transformer/logging/logger.js +153 -0
- package/dist-transformer/logging/otel-logger.d.ts +33 -0
- package/dist-transformer/logging/otel-logger.d.ts.map +1 -0
- package/dist-transformer/logging/otel-logger.js +121 -0
- package/dist-transformer/logging/span.d.ts +23 -0
- package/dist-transformer/logging/span.d.ts.map +1 -0
- package/dist-transformer/logging/span.js +40 -0
- package/dist-transformer/logging/types.d.ts +32 -0
- package/dist-transformer/logging/types.d.ts.map +1 -0
- package/dist-transformer/logging/types.js +1 -0
- package/dist-transformer/otel-config.d.ts +61 -0
- package/dist-transformer/otel-config.d.ts.map +1 -0
- package/dist-transformer/otel-config.js +175 -0
- package/dist-transformer/otel-logging.d.ts +49 -0
- package/dist-transformer/otel-logging.d.ts.map +1 -0
- package/dist-transformer/otel-logging.js +99 -0
- package/dist-transformer/transformer/codegen/context-gen.d.ts +47 -0
- package/dist-transformer/transformer/codegen/context-gen.d.ts.map +1 -0
- package/dist-transformer/transformer/codegen/context-gen.js +354 -0
- package/dist-transformer/transformer/processor/class-targets.d.ts +11 -0
- package/dist-transformer/transformer/processor/class-targets.d.ts.map +1 -0
- package/dist-transformer/transformer/processor/class-targets.js +37 -0
- package/dist-transformer/transformer/processor/function-targets.d.ts +11 -0
- package/dist-transformer/transformer/processor/function-targets.d.ts.map +1 -0
- package/dist-transformer/transformer/processor/function-targets.js +8 -0
- package/dist-transformer/transformer/processor/object-targets.d.ts +11 -0
- package/dist-transformer/transformer/processor/object-targets.d.ts.map +1 -0
- package/dist-transformer/transformer/processor/object-targets.js +8 -0
- package/dist-transformer/transformer/processor/processor-utils.d.ts +67 -0
- package/dist-transformer/transformer/processor/processor-utils.d.ts.map +1 -0
- package/dist-transformer/transformer/processor/processor-utils.js +533 -0
- package/dist-transformer/transformer/processor/processor.d.ts +22 -0
- package/dist-transformer/transformer/processor/processor.d.ts.map +1 -0
- package/dist-transformer/transformer/processor/processor.js +202 -0
- package/dist-transformer/transformer/transformer-config.d.ts +9 -0
- package/dist-transformer/transformer/transformer-config.d.ts.map +1 -0
- package/dist-transformer/transformer/transformer-config.js +12 -0
- package/dist-transformer/transformer/transformer-utils.d.ts +29 -0
- package/dist-transformer/transformer/transformer-utils.d.ts.map +1 -0
- package/dist-transformer/transformer/transformer-utils.js +364 -0
- package/dist-transformer/transformer/transformer.d.ts +8 -0
- package/dist-transformer/transformer/transformer.d.ts.map +1 -0
- package/dist-transformer/transformer/transformer.js +104 -0
- package/dist-transformer/transformer/traverser/class-traversal.d.ts +9 -0
- package/dist-transformer/transformer/traverser/class-traversal.d.ts.map +1 -0
- package/dist-transformer/transformer/traverser/class-traversal.js +336 -0
- package/dist-transformer/transformer/traverser/function-traversal.d.ts +7 -0
- package/dist-transformer/transformer/traverser/function-traversal.d.ts.map +1 -0
- package/dist-transformer/transformer/traverser/function-traversal.js +28 -0
- package/dist-transformer/transformer/traverser/system-traversal.d.ts +13 -0
- package/dist-transformer/transformer/traverser/system-traversal.d.ts.map +1 -0
- package/dist-transformer/transformer/traverser/system-traversal.js +350 -0
- package/dist-transformer/transformer/traverser/traversal-utils.d.ts +16 -0
- package/dist-transformer/transformer/traverser/traversal-utils.d.ts.map +1 -0
- package/dist-transformer/transformer/traverser/traversal-utils.js +132 -0
- package/dist-transformer/transformer/traverser/traverser.d.ts +44 -0
- package/dist-transformer/transformer/traverser/traverser.d.ts.map +1 -0
- package/dist-transformer/transformer/traverser/traverser.js +414 -0
- package/dist-transformer/version.d.ts +2 -0
- package/dist-transformer/version.d.ts.map +1 -0
- package/dist-transformer/version.js +3 -0
- package/dist-transformer/warpc/frame-context/annotation-ctx.d.ts +15 -0
- package/dist-transformer/warpc/frame-context/annotation-ctx.d.ts.map +1 -0
- package/dist-transformer/warpc/frame-context/annotation-ctx.js +30 -0
- package/dist-transformer/warpc/frame-context/frame-ctx.d.ts +27 -0
- package/dist-transformer/warpc/frame-context/frame-ctx.d.ts.map +1 -0
- package/dist-transformer/warpc/frame-context/frame-ctx.js +42 -0
- package/dist-transformer/warpc/frame-context/message-conversion/decoder.d.ts +24 -0
- package/dist-transformer/warpc/frame-context/message-conversion/decoder.d.ts.map +1 -0
- package/dist-transformer/warpc/frame-context/message-conversion/decoder.js +204 -0
- package/dist-transformer/warpc/frame-context/message-conversion/encoder.d.ts +22 -0
- package/dist-transformer/warpc/frame-context/message-conversion/encoder.d.ts.map +1 -0
- package/dist-transformer/warpc/frame-context/message-conversion/encoder.js +246 -0
- package/dist-transformer/warpc/frame-context/resource-ctx.d.ts +45 -0
- package/dist-transformer/warpc/frame-context/resource-ctx.d.ts.map +1 -0
- package/dist-transformer/warpc/frame-context/resource-ctx.js +103 -0
- package/dist-transformer/warpc/frame-context/synthetic-resources/factory.d.ts +31 -0
- package/dist-transformer/warpc/frame-context/synthetic-resources/factory.d.ts.map +1 -0
- package/dist-transformer/warpc/frame-context/synthetic-resources/factory.js +196 -0
- package/dist-transformer/warpc/frame-context/system-ctx.d.ts +18 -0
- package/dist-transformer/warpc/frame-context/system-ctx.d.ts.map +1 -0
- package/dist-transformer/warpc/frame-context/system-ctx.js +135 -0
- package/dist-transformer/warpc/frame-context/uid-gen.d.ts +14 -0
- package/dist-transformer/warpc/frame-context/uid-gen.d.ts.map +1 -0
- package/dist-transformer/warpc/frame-context/uid-gen.js +22 -0
- package/dist-transformer/warpc/frame-context/virtual-resources/default.d.ts +16 -0
- package/dist-transformer/warpc/frame-context/virtual-resources/default.d.ts.map +1 -0
- package/dist-transformer/warpc/frame-context/virtual-resources/default.js +196 -0
- package/dist-transformer/warpc/frame-context/virtual-resources/dispatcher.d.ts +17 -0
- package/dist-transformer/warpc/frame-context/virtual-resources/dispatcher.d.ts.map +1 -0
- package/dist-transformer/warpc/frame-context/virtual-resources/dispatcher.js +255 -0
- package/dist-transformer/warpc/frame-context/virtual-resources/virtualizer.d.ts +32 -0
- package/dist-transformer/warpc/frame-context/virtual-resources/virtualizer.d.ts.map +1 -0
- package/dist-transformer/warpc/frame-context/virtual-resources/virtualizer.js +15 -0
- package/dist-transformer/warpc/frame.d.ts +45 -0
- package/dist-transformer/warpc/frame.d.ts.map +1 -0
- package/dist-transformer/warpc/frame.js +417 -0
- package/dist-transformer/warpc/msg-protocol/concept/annotations/annotation-msg.d.ts +68 -0
- package/dist-transformer/warpc/msg-protocol/concept/annotations/annotation-msg.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/concept/annotations/annotation-msg.js +135 -0
- package/dist-transformer/warpc/msg-protocol/concept/concept.d.ts +33 -0
- package/dist-transformer/warpc/msg-protocol/concept/concept.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/concept/concept.js +44 -0
- package/dist-transformer/warpc/msg-protocol/concept/exception/exception-msg.d.ts +42 -0
- package/dist-transformer/warpc/msg-protocol/concept/exception/exception-msg.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/concept/exception/exception-msg.js +74 -0
- package/dist-transformer/warpc/msg-protocol/concept/rehydrate.d.ts +2 -0
- package/dist-transformer/warpc/msg-protocol/concept/rehydrate.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/concept/rehydrate.js +61 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/class-msg.d.ts +86 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/class-msg.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/class-msg.js +157 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/function-msg.d.ts +30 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/function-msg.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/function-msg.js +48 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/object-msg.d.ts +25 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/object-msg.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/object-msg.js +24 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/resource-msg.d.ts +37 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/resource-msg.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/resource-msg.js +32 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/system-msg.d.ts +48 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/system-msg.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/concept/resource/system-msg.js +306 -0
- package/dist-transformer/warpc/msg-protocol/concept/value/atom.d.ts +33 -0
- package/dist-transformer/warpc/msg-protocol/concept/value/atom.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/concept/value/atom.js +69 -0
- package/dist-transformer/warpc/msg-protocol/concept/value/container.d.ts +59 -0
- package/dist-transformer/warpc/msg-protocol/concept/value/container.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/concept/value/container.js +185 -0
- package/dist-transformer/warpc/msg-protocol/concept/value/symbol.d.ts +20 -0
- package/dist-transformer/warpc/msg-protocol/concept/value/symbol.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/concept/value/symbol.js +57 -0
- package/dist-transformer/warpc/msg-protocol/concept/value/value-msg.d.ts +8 -0
- package/dist-transformer/warpc/msg-protocol/concept/value/value-msg.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/concept/value/value-msg.js +10 -0
- package/dist-transformer/warpc/msg-protocol/kinds.d.ts +118 -0
- package/dist-transformer/warpc/msg-protocol/kinds.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/kinds.js +141 -0
- package/dist-transformer/warpc/msg-protocol/rpc/event-msg.d.ts +12 -0
- package/dist-transformer/warpc/msg-protocol/rpc/event-msg.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/rpc/event-msg.js +15 -0
- package/dist-transformer/warpc/msg-protocol/rpc/request-msg.d.ts +90 -0
- package/dist-transformer/warpc/msg-protocol/rpc/request-msg.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/rpc/request-msg.js +64 -0
- package/dist-transformer/warpc/msg-protocol/rpc/response-msg.d.ts +29 -0
- package/dist-transformer/warpc/msg-protocol/rpc/response-msg.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/rpc/response-msg.js +32 -0
- package/dist-transformer/warpc/msg-protocol/rpc/rpc-msg.d.ts +8 -0
- package/dist-transformer/warpc/msg-protocol/rpc/rpc-msg.d.ts.map +1 -0
- package/dist-transformer/warpc/msg-protocol/rpc/rpc-msg.js +9 -0
- package/dist-transformer/warpc/rpc-channel/handler.d.ts +23 -0
- package/dist-transformer/warpc/rpc-channel/handler.d.ts.map +1 -0
- package/dist-transformer/warpc/rpc-channel/handler.js +163 -0
- package/dist-transformer/warpc/rpc-channel/mux.d.ts +25 -0
- package/dist-transformer/warpc/rpc-channel/mux.d.ts.map +1 -0
- package/dist-transformer/warpc/rpc-channel/mux.js +93 -0
- package/dist-transformer/warpc/rpc-channel/responder.d.ts +27 -0
- package/dist-transformer/warpc/rpc-channel/responder.d.ts.map +1 -0
- package/dist-transformer/warpc/rpc-channel/responder.js +463 -0
- package/dist-transformer/warpc/rpc-channel/socket.d.ts +25 -0
- package/dist-transformer/warpc/rpc-channel/socket.d.ts.map +1 -0
- package/dist-transformer/warpc/rpc-channel/socket.js +70 -0
- package/dist-transformer/warpc/rpc-channel/utils.d.ts +6 -0
- package/dist-transformer/warpc/rpc-channel/utils.d.ts.map +1 -0
- package/dist-transformer/warpc/rpc-channel/utils.js +14 -0
- package/dist-transformer/warpc/runtime.d.ts +36 -0
- package/dist-transformer/warpc/runtime.d.ts.map +1 -0
- package/dist-transformer/warpc/runtime.js +159 -0
- package/package.json +126 -0
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { createLogger } from "../../logging/index.js";
|
|
2
|
+
import { bytesToStr, strToBytes } from './utils.js';
|
|
3
|
+
export class VirtualSocketForHandle {
|
|
4
|
+
readyState = 1;
|
|
5
|
+
onmessage = null;
|
|
6
|
+
onclose = null;
|
|
7
|
+
#running = true;
|
|
8
|
+
handle;
|
|
9
|
+
#logger;
|
|
10
|
+
constructor(handle, parentLogger) {
|
|
11
|
+
this.handle = handle;
|
|
12
|
+
this.#logger = parentLogger?.withScope('socket:virtual') ?? createLogger('socket:virtual');
|
|
13
|
+
}
|
|
14
|
+
send(data) {
|
|
15
|
+
try {
|
|
16
|
+
const bytes = strToBytes(data);
|
|
17
|
+
void this.handle.send_message(bytes);
|
|
18
|
+
this.#logger.debug(`Sent message (${bytes.length} bytes)`);
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
this.#logger.error('Failed to send message', error);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
close() {
|
|
25
|
+
this.#running = false;
|
|
26
|
+
this.#logger.debug('Socket closed');
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
startReceiving() {
|
|
30
|
+
this.#startRecvLoop();
|
|
31
|
+
}
|
|
32
|
+
async #startRecvLoop() {
|
|
33
|
+
this.#logger.debug('Starting receive loop');
|
|
34
|
+
while (this.#running) {
|
|
35
|
+
try {
|
|
36
|
+
const bytes = await this.handle.recv_message();
|
|
37
|
+
this.#logger.debug(`Received ${bytes.length} bytes`);
|
|
38
|
+
const decoded = bytesToStr(bytes);
|
|
39
|
+
if (this.onmessage) {
|
|
40
|
+
this.onmessage?.({ data: decoded });
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
this.#logger.warn('Received bytes before onmessage is set');
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
catch (error) {
|
|
47
|
+
if (error instanceof Error && error.message === 'Queue closed') {
|
|
48
|
+
this.#logger.debug('Receive loop ended (queue closed)');
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
this.#logger.debug('Receive loop ended because of an error', error);
|
|
52
|
+
}
|
|
53
|
+
break;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=socket.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"socket.js","sourceRoot":"","sources":["../../../../src/warpc/rpc-channel/socket.ts"],"names":[],"mappings":"AACA,OAAO,EAAqB,YAAY,EAAE,4BAAuB;AAEjE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAYjD,MAAM,OAAO,sBAAsB;IAC/B,UAAU,GAAG,CAAC,CAAC;IACf,SAAS,GAA4C,IAAI,CAAC;IAC1D,OAAO,GAAwB,IAAI,CAAC;IACpC,QAAQ,GAAG,IAAI,CAAC;IAChB,MAAM,CAAI;IACV,OAAO,CAAe;IAEtB,YAAY,MAAS,EAAE,YAA2B;QAC9C,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,YAAY,EAAE,SAAS,CAAC,gBAAgB,CAAC,IAAI,YAAY,CAAC,gBAAgB,CAAC,CAAC;IAC/F,CAAC;IAED,IAAI,CAAC,IAAY;QACb,IAAI,CAAC;YACD,MAAM,KAAK,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC;YAC/B,KAAK,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YACrC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,iBAAiB,KAAK,CAAC,MAAM,SAAS,CAAC,CAAC;QAC/D,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACb,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,KAAc,CAAC,CAAC;QACjE,CAAC;IACL,CAAC;IAED,KAAK;QACD,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;QACpC,OAAO;IACX,CAAC;IAED,cAAc;QACV,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;IAED,KAAK,CAAC,cAAc;QAChB,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAC;QAC5C,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,CAAC;gBACD,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;gBAC/C,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,YAAY,KAAK,CAAC,MAAM,QAAQ,CAAC,CAAC;gBACrD,MAAM,OAAO,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC;gBAClC,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;oBACjB,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;gBACxC,CAAC;qBAAM,CAAC;oBACJ,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,wCAAwC,CAAC,CAAC;gBAChE,CAAC;YACL,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACb,IAAI,KAAK,YAAY,KAAK,IAAI,KAAK,CAAC,OAAO,KAAK,cAAc,EAAE,CAAC;oBAC7D,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,mCAAmC,CAAC,CAAC;gBAC5D,CAAC;qBAAM,CAAC;oBACJ,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,wCAAwC,EAAE,KAAc,CAAC,CAAC;gBACjF,CAAC;gBACD,MAAM;YACV,CAAC;QACL,CAAC;IACL,CAAC;CACJ"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Msg } from '@warpc/msg-protocol/kinds';
|
|
2
|
+
export declare function msgToBytes(msg: Msg): Uint8Array;
|
|
3
|
+
export declare function strToBytes(data: string): Uint8Array;
|
|
4
|
+
export declare function bytesToMsg(bytes: Uint8Array): Msg;
|
|
5
|
+
export declare function bytesToStr(bytes: Uint8Array): string;
|
|
6
|
+
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/warpc/rpc-channel/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,2BAA2B,CAAC;AAEhD,wBAAgB,UAAU,CAAC,GAAG,EAAE,GAAG,GAAG,UAAU,CAG/C;AAED,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,UAAU,CAEnD;AAED,wBAAgB,UAAU,CAAC,KAAK,EAAE,UAAU,GAAG,GAAG,CAGjD;AAED,wBAAgB,UAAU,CAAC,KAAK,EAAE,UAAU,GAAG,MAAM,CAEpD"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export function msgToBytes(msg) {
|
|
2
|
+
const data = JSON.stringify(msg);
|
|
3
|
+
return strToBytes(data);
|
|
4
|
+
}
|
|
5
|
+
export function strToBytes(data) {
|
|
6
|
+
return new TextEncoder().encode(data);
|
|
7
|
+
}
|
|
8
|
+
export function bytesToMsg(bytes) {
|
|
9
|
+
const decoded = bytesToStr(bytes);
|
|
10
|
+
return JSON.parse(decoded);
|
|
11
|
+
}
|
|
12
|
+
export function bytesToStr(bytes) {
|
|
13
|
+
return new TextDecoder().decode(bytes);
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/warpc/rpc-channel/utils.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,UAAU,CAAC,GAAQ;IAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IACjC,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC;AAC5B,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,IAAY;IACnC,OAAO,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;AAC1C,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,KAAiB;IACxC,MAAM,OAAO,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC;IAClC,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;AAC/B,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,KAAiB;IACxC,OAAO,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;AAC3C,CAAC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { type ScopedLogger } from '@logging/index';
|
|
2
|
+
import { Frame, FrameTree } from './frame.js';
|
|
3
|
+
import { UIDGenerator } from './frame-context/uid-gen.js';
|
|
4
|
+
import { DefMsg } from './msg-protocol/concept/concept.js';
|
|
5
|
+
import { FrameID, World } from './msg-protocol/kinds.js';
|
|
6
|
+
import { ResponseMsg } from './msg-protocol/rpc/response-msg.js';
|
|
7
|
+
import { FrameMuxSocket } from './rpc-channel/mux.js';
|
|
8
|
+
export declare class FrameRuntime {
|
|
9
|
+
world: World;
|
|
10
|
+
remoteFrameCounter: FrameID;
|
|
11
|
+
localFrameTree: FrameTree;
|
|
12
|
+
remoteParents: Map<FrameID, FrameID>;
|
|
13
|
+
remoteChildren: Map<FrameID, Set<FrameID>>;
|
|
14
|
+
socket?: FrameMuxSocket;
|
|
15
|
+
uidGenerator: UIDGenerator;
|
|
16
|
+
logger: ScopedLogger;
|
|
17
|
+
uid: string | undefined;
|
|
18
|
+
iid: string | undefined;
|
|
19
|
+
createdAt: number;
|
|
20
|
+
private sentDefsByRemote;
|
|
21
|
+
constructor(world?: World, parentLogger?: ScopedLogger);
|
|
22
|
+
setUid(uid: string | undefined): void;
|
|
23
|
+
setIid(iid: string | undefined): void;
|
|
24
|
+
get elapsedTimeInSeconds(): number;
|
|
25
|
+
get rootFrame(): Frame;
|
|
26
|
+
get otherWorld(): World;
|
|
27
|
+
incrementRemoteFrameCounter(): FrameID;
|
|
28
|
+
newRemoteFrameForLocalRequest(localFrameID: FrameID): number;
|
|
29
|
+
newLocalFrameForRemoteRequest(localParentID: FrameID, requestedLocalID: FrameID, requestingRemoteID: FrameID): Frame;
|
|
30
|
+
returnFromRemoteFrame(localID: FrameID, remoteID: FrameID): void;
|
|
31
|
+
returnContextFromLocalFrame(localID: FrameID, response: ResponseMsg): DefMsg[];
|
|
32
|
+
private getOrInitSentSet;
|
|
33
|
+
filterUnsentLocalDefs(remoteFID: FrameID, defs: DefMsg[]): DefMsg[];
|
|
34
|
+
markDefsSent(remoteFID: FrameID, defs: DefMsg[]): void;
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=runtime.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime.d.ts","sourceRoot":"","sources":["../../../src/warpc/runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,YAAY,EAAgB,MAAM,gBAAgB,CAAC;AAEjE,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAc,MAAM,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,OAAO,EAAW,KAAK,EAAmB,MAAM,sBAAsB,CAAC;AAChF,OAAO,EAAkB,WAAW,EAAE,MAAM,iCAAiC,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAInD,qBAAa,YAAY;IACd,KAAK,EAAE,KAAK,CAAC;IACb,kBAAkB,EAAE,OAAO,CAAC;IAC5B,cAAc,EAAE,SAAS,CAAC;IAC1B,aAAa,EAAE,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,CAAa;IACjD,cAAc,EAAE,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,CAAa;IACvD,MAAM,CAAC,EAAE,cAAc,CAAC;IACxB,YAAY,EAAE,YAAY,CAAC;IAC3B,MAAM,EAAE,YAAY,CAAC;IACrB,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC;IACxB,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC;IACxB,SAAS,EAAE,MAAM,CAAC;IAGzB,OAAO,CAAC,gBAAgB,CAAwC;gBAEpD,KAAK,GAAE,KAAoB,EAAE,YAAY,CAAC,EAAE,YAAY;IAapE,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS;IAI9B,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS;IAI9B,IAAI,oBAAoB,IAAI,MAAM,CAEjC;IAED,IAAI,SAAS,IAAI,KAAK,CAErB;IAED,IAAI,UAAU,IAAI,KAAK,CAEtB;IAED,2BAA2B,IAAI,OAAO;IAStC,6BAA6B,CAAC,YAAY,EAAE,OAAO,GAAG,MAAM;IAa5D,6BAA6B,CACzB,aAAa,EAAE,OAAO,EACtB,gBAAgB,EAAE,OAAO,EACzB,kBAAkB,EAAE,OAAO,GAC5B,KAAK;IAqBR,qBAAqB,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,GAAG,IAAI;IAYhE,2BAA2B,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,WAAW,GAAG,MAAM,EAAE;IAoD9E,OAAO,CAAC,gBAAgB;IASxB,qBAAqB,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE;IAanE,YAAY,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI;CAMzD"}
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import { createLogger } from "../logging/index.js";
|
|
2
|
+
import { Frame, FrameTree } from './frame.js';
|
|
3
|
+
import { UIDGenerator } from './frame-context/uid-gen.js';
|
|
4
|
+
import { RPCKind, World, defnUidToString } from './msg-protocol/kinds.js';
|
|
5
|
+
const ROOT_FRAME_ID = 0;
|
|
6
|
+
export class FrameRuntime {
|
|
7
|
+
world;
|
|
8
|
+
remoteFrameCounter;
|
|
9
|
+
localFrameTree;
|
|
10
|
+
remoteParents = new Map();
|
|
11
|
+
remoteChildren = new Map();
|
|
12
|
+
socket;
|
|
13
|
+
uidGenerator;
|
|
14
|
+
logger;
|
|
15
|
+
uid;
|
|
16
|
+
iid;
|
|
17
|
+
createdAt;
|
|
18
|
+
sentDefsByRemote = new Map();
|
|
19
|
+
constructor(world = World.Client, parentLogger) {
|
|
20
|
+
this.world = world;
|
|
21
|
+
this.logger = parentLogger?.withScope(`runtime`) ?? createLogger(`runtime`);
|
|
22
|
+
this.remoteFrameCounter = ROOT_FRAME_ID;
|
|
23
|
+
this.remoteParents.set(ROOT_FRAME_ID, ROOT_FRAME_ID);
|
|
24
|
+
this.remoteChildren.set(ROOT_FRAME_ID, new Set());
|
|
25
|
+
this.uidGenerator = new UIDGenerator(this.world);
|
|
26
|
+
this.localFrameTree = new FrameTree();
|
|
27
|
+
this.localFrameTree.push(undefined, new Frame(this, ROOT_FRAME_ID));
|
|
28
|
+
this.logger.debug(`Initialized runtime with root frame ${ROOT_FRAME_ID}`);
|
|
29
|
+
this.createdAt = Date.now();
|
|
30
|
+
}
|
|
31
|
+
setUid(uid) {
|
|
32
|
+
this.uid = uid;
|
|
33
|
+
}
|
|
34
|
+
setIid(iid) {
|
|
35
|
+
this.iid = iid;
|
|
36
|
+
}
|
|
37
|
+
get elapsedTimeInSeconds() {
|
|
38
|
+
return (Date.now() - this.createdAt) / 1000;
|
|
39
|
+
}
|
|
40
|
+
get rootFrame() {
|
|
41
|
+
return this.localFrameTree.frames.get(ROOT_FRAME_ID);
|
|
42
|
+
}
|
|
43
|
+
get otherWorld() {
|
|
44
|
+
return this.world === World.Client ? World.Server : World.Client;
|
|
45
|
+
}
|
|
46
|
+
incrementRemoteFrameCounter() {
|
|
47
|
+
return ++this.remoteFrameCounter;
|
|
48
|
+
}
|
|
49
|
+
newRemoteFrameForLocalRequest(localFrameID) {
|
|
50
|
+
const remoteFrameId = this.incrementRemoteFrameCounter();
|
|
51
|
+
let remoteRequests = this.remoteChildren.get(localFrameID);
|
|
52
|
+
if (!remoteRequests) {
|
|
53
|
+
remoteRequests = new Set();
|
|
54
|
+
this.remoteChildren.set(localFrameID, remoteRequests);
|
|
55
|
+
}
|
|
56
|
+
remoteRequests.add(remoteFrameId);
|
|
57
|
+
this.logger.debug(`New remote frame ${remoteFrameId} for local ${localFrameID}`);
|
|
58
|
+
return remoteFrameId;
|
|
59
|
+
}
|
|
60
|
+
newLocalFrameForRemoteRequest(localParentID, requestedLocalID, requestingRemoteID) {
|
|
61
|
+
const localParentFrame = this.localFrameTree.frames.get(localParentID);
|
|
62
|
+
if (!localParentFrame) {
|
|
63
|
+
this.logger.error(`Unknown parent frame ${localParentID}`);
|
|
64
|
+
throw new Error('Unknown parent frame');
|
|
65
|
+
}
|
|
66
|
+
this.remoteParents.set(requestedLocalID, requestingRemoteID);
|
|
67
|
+
this.remoteChildren.set(requestedLocalID, new Set([]));
|
|
68
|
+
const newFrame = new Frame(this, requestedLocalID, localParentFrame);
|
|
69
|
+
this.localFrameTree.push(localParentID, newFrame);
|
|
70
|
+
this.logger.debug(`New local frame ${requestedLocalID} (parent=${localParentID}, remote=${requestingRemoteID})`);
|
|
71
|
+
return newFrame;
|
|
72
|
+
}
|
|
73
|
+
returnFromRemoteFrame(localID, remoteID) {
|
|
74
|
+
const children = this.remoteChildren.get(localID);
|
|
75
|
+
if (!children || !children.has(remoteID)) {
|
|
76
|
+
this.logger.error(`Trying to return from unknown remote frame ${remoteID}`);
|
|
77
|
+
throw new Error('Trying to return from unknown remote frame');
|
|
78
|
+
}
|
|
79
|
+
children.delete(remoteID);
|
|
80
|
+
this.logger.debug(`Returned from remote frame ${remoteID} (local=${localID})`);
|
|
81
|
+
}
|
|
82
|
+
returnContextFromLocalFrame(localID, response) {
|
|
83
|
+
const span = this.logger.startSpan(`returnFromLocalFrame-${localID}`);
|
|
84
|
+
try {
|
|
85
|
+
const localFrame = this.localFrameTree.frames.get(localID);
|
|
86
|
+
if (!localFrame) {
|
|
87
|
+
this.logger.error(`Trying to return from unknown local frame ${localID}`);
|
|
88
|
+
throw new Error('Trying to return from unknown local frame');
|
|
89
|
+
}
|
|
90
|
+
const outstanding = this.remoteChildren.get(localID);
|
|
91
|
+
if (outstanding && outstanding.size > 1) {
|
|
92
|
+
this.logger.error(`Returning from local frame ${localID} with ${outstanding.size} outstanding remote frames`);
|
|
93
|
+
throw new Error('Returning from local frame with outstanding remote frames');
|
|
94
|
+
}
|
|
95
|
+
const new_defs = [];
|
|
96
|
+
switch (response.kind) {
|
|
97
|
+
case RPCKind.Response.Ok:
|
|
98
|
+
this.logger.debug(`Frame ${localID} returned OK`);
|
|
99
|
+
break;
|
|
100
|
+
case RPCKind.Response.Err: {
|
|
101
|
+
this.logger.warn(`Frame ${localID} returned an error with the following payload:`, response.payload.error);
|
|
102
|
+
break;
|
|
103
|
+
}
|
|
104
|
+
case RPCKind.Response.Res: {
|
|
105
|
+
const result = response.payload.result;
|
|
106
|
+
localFrame.parentFrame?.passContextFromOtherFrame(localFrame, result, new_defs);
|
|
107
|
+
this.logger.debug(`Frame ${localID} returned result with ${new_defs.length} new defs`);
|
|
108
|
+
span.setAttribute('new_defs_count', new_defs.length);
|
|
109
|
+
break;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
this.localFrameTree.pop(localID);
|
|
113
|
+
this.remoteParents.delete(localID);
|
|
114
|
+
this.remoteChildren.delete(localID);
|
|
115
|
+
return new_defs;
|
|
116
|
+
}
|
|
117
|
+
catch (error) {
|
|
118
|
+
span.recordException(error);
|
|
119
|
+
throw error;
|
|
120
|
+
}
|
|
121
|
+
finally {
|
|
122
|
+
span.end();
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
getOrInitSentSet(remoteFID) {
|
|
126
|
+
let set = this.sentDefsByRemote.get(remoteFID);
|
|
127
|
+
if (!set) {
|
|
128
|
+
set = new Set();
|
|
129
|
+
this.sentDefsByRemote.set(remoteFID, set);
|
|
130
|
+
}
|
|
131
|
+
return set;
|
|
132
|
+
}
|
|
133
|
+
filterUnsentLocalDefs(remoteFID, defs) {
|
|
134
|
+
const sent = this.getOrInitSentSet(remoteFID);
|
|
135
|
+
const filtered = [];
|
|
136
|
+
for (const def of defs) {
|
|
137
|
+
if (def.uid.world !== this.world)
|
|
138
|
+
continue;
|
|
139
|
+
const key = defnUidToString(def.uid);
|
|
140
|
+
if (sent.has(key))
|
|
141
|
+
continue;
|
|
142
|
+
filtered.push(def);
|
|
143
|
+
}
|
|
144
|
+
return filtered;
|
|
145
|
+
}
|
|
146
|
+
markDefsSent(remoteFID, defs) {
|
|
147
|
+
const sent = this.getOrInitSentSet(remoteFID);
|
|
148
|
+
for (const def of defs) {
|
|
149
|
+
sent.add(defnUidToString(def.uid));
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
//# sourceMappingURL=runtime.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime.js","sourceRoot":"","sources":["../../../src/warpc/runtime.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { CompiledConceptContext } from '../transformer/processor/processor-utils.js';
|
|
2
|
+
import { Chunk, MaxTokens, ModelStrings, ToolModeStrings, Usage } from './common.js';
|
|
3
|
+
import { type Template } from './template.js';
|
|
4
|
+
import { Agentica } from '../agentica-client/index.js';
|
|
5
|
+
export { Usage } from './common.js';
|
|
6
|
+
export type AgentSpawnCtx = {
|
|
7
|
+
siteId: string;
|
|
8
|
+
concepts?: CompiledConceptContext;
|
|
9
|
+
};
|
|
10
|
+
export type AgentSpawnConfig = {
|
|
11
|
+
model?: ModelStrings;
|
|
12
|
+
premise?: string;
|
|
13
|
+
system?: string | Template;
|
|
14
|
+
listener?: (iid: string, chunk: Chunk) => void;
|
|
15
|
+
mode?: ToolModeStrings;
|
|
16
|
+
maxTokens?: number | MaxTokens;
|
|
17
|
+
client?: Agentica;
|
|
18
|
+
};
|
|
19
|
+
export declare function spawn(config: AgentSpawnConfig & {
|
|
20
|
+
system: string | Template;
|
|
21
|
+
premise?: never;
|
|
22
|
+
}, scope?: object): Promise<Agent>;
|
|
23
|
+
export declare function spawn(config: AgentSpawnConfig & {
|
|
24
|
+
system?: never;
|
|
25
|
+
premise: string;
|
|
26
|
+
}, scope?: object): Promise<Agent>;
|
|
27
|
+
export declare function spawn(config: AgentSpawnConfig & {
|
|
28
|
+
system?: never;
|
|
29
|
+
premise?: never;
|
|
30
|
+
}, scope?: object): Promise<Agent>;
|
|
31
|
+
export declare function spawnTransformation(ctx: AgentSpawnCtx, config: AgentSpawnConfig): Promise<Agent>;
|
|
32
|
+
export type AgentCallCtx = {
|
|
33
|
+
concepts: CompiledConceptContext;
|
|
34
|
+
siteId: string;
|
|
35
|
+
siteOutputType: string;
|
|
36
|
+
docString: string;
|
|
37
|
+
};
|
|
38
|
+
export type AgentCallConfig = {
|
|
39
|
+
listener?: (iid: string, chunk: Chunk) => void;
|
|
40
|
+
parentCallId?: string;
|
|
41
|
+
};
|
|
42
|
+
export declare class Agent implements AsyncDisposable {
|
|
43
|
+
private uid;
|
|
44
|
+
private iid;
|
|
45
|
+
private onCallComplete;
|
|
46
|
+
private ctx;
|
|
47
|
+
private config;
|
|
48
|
+
private runtime?;
|
|
49
|
+
private sessionManager?;
|
|
50
|
+
private mode;
|
|
51
|
+
private logger;
|
|
52
|
+
private lastIid;
|
|
53
|
+
private lastTotal;
|
|
54
|
+
private usages;
|
|
55
|
+
constructor(ctx: AgentSpawnCtx, config: AgentSpawnConfig);
|
|
56
|
+
initialize(): Promise<void>;
|
|
57
|
+
call<T>(userPrompt: string | Template, scope?: object, config?: AgentCallConfig): Promise<T>;
|
|
58
|
+
callPro<T>(userPromptParts: TemplateStringsArray, ...scope: any[]): (config?: AgentCallConfig) => Promise<T>;
|
|
59
|
+
setOnCallComplete(onCallComplete: (iid: string | undefined) => void): void;
|
|
60
|
+
getUid(): string;
|
|
61
|
+
getCurrentCallIid(): string | undefined;
|
|
62
|
+
/**
|
|
63
|
+
* Get the usage for the last invocation.
|
|
64
|
+
* @throws Error if no invocation has been made yet or usage not found
|
|
65
|
+
*/
|
|
66
|
+
lastUsage(): Usage;
|
|
67
|
+
/**
|
|
68
|
+
* Get the total usage across all invocations.
|
|
69
|
+
*/
|
|
70
|
+
totalUsage(): Usage;
|
|
71
|
+
/**
|
|
72
|
+
* Manually close the agent and clean up resources
|
|
73
|
+
*/
|
|
74
|
+
close(): Promise<void>;
|
|
75
|
+
/**
|
|
76
|
+
* AsyncDisposable implementation for "await using" syntax
|
|
77
|
+
*/
|
|
78
|
+
[Symbol.asyncDispose](): Promise<void>;
|
|
79
|
+
callTransformation<T>(ctx: AgentCallCtx, prompt: string | Template, config?: AgentCallConfig): Promise<T>;
|
|
80
|
+
}
|
|
81
|
+
//# sourceMappingURL=agent.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent.d.ts","sourceRoot":"","sources":["../../src/agentica/agent.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
import { createLogger } from '../logging/index.js';
|
|
2
|
+
import { MaxTokens, Usage, createAgentEnvironment, invokeAgent, serveRequestsUntilResult, startEchoStream, } from './common.js';
|
|
3
|
+
import { maybePromptTemplate } from './template.js';
|
|
4
|
+
import { throwNoJsonMode } from '../coming-soon.js';
|
|
5
|
+
// Re-export Usage for convenience
|
|
6
|
+
export { Usage } from './common.js';
|
|
7
|
+
let AGENT_COUNTER = 0;
|
|
8
|
+
export async function spawn(config, scope) {
|
|
9
|
+
void config;
|
|
10
|
+
void scope;
|
|
11
|
+
throw new Error('Run the transformation before calling spawn');
|
|
12
|
+
}
|
|
13
|
+
export async function spawnTransformation(ctx, config) {
|
|
14
|
+
const agent = new Agent(ctx, config);
|
|
15
|
+
await agent.initialize();
|
|
16
|
+
return agent;
|
|
17
|
+
}
|
|
18
|
+
export class Agent {
|
|
19
|
+
constructor(ctx, config) {
|
|
20
|
+
this.usages = new Map();
|
|
21
|
+
this.ctx = ctx;
|
|
22
|
+
this.config = config;
|
|
23
|
+
this.mode = config.mode ?? 'code';
|
|
24
|
+
if (this.mode === 'json') {
|
|
25
|
+
throwNoJsonMode();
|
|
26
|
+
}
|
|
27
|
+
this.uid = ''; // set using initialize
|
|
28
|
+
this.iid = undefined; // no call yet
|
|
29
|
+
this.onCallComplete = () => { }; // no-op
|
|
30
|
+
this.logger = createLogger(`agent:${AGENT_COUNTER}`);
|
|
31
|
+
AGENT_COUNTER++;
|
|
32
|
+
}
|
|
33
|
+
async initialize() {
|
|
34
|
+
const initConfig = {
|
|
35
|
+
persist: true,
|
|
36
|
+
streaming: !!this.config.listener,
|
|
37
|
+
model: this.config.model,
|
|
38
|
+
system: maybePromptTemplate(this.config.system),
|
|
39
|
+
premise: this.config.premise,
|
|
40
|
+
siteId: this.ctx.siteId,
|
|
41
|
+
mode: this.mode,
|
|
42
|
+
maxTokens: MaxTokens.fromMaxTokens(this.config.maxTokens),
|
|
43
|
+
concepts: this.ctx.concepts,
|
|
44
|
+
client: this.config.client,
|
|
45
|
+
};
|
|
46
|
+
const { uid, runtime, sessionManager } = await createAgentEnvironment(initConfig, this.logger);
|
|
47
|
+
this.uid = uid;
|
|
48
|
+
this.runtime = runtime;
|
|
49
|
+
this.sessionManager = sessionManager;
|
|
50
|
+
this.logger.debug(`Agent initialized: ${this.uid}`);
|
|
51
|
+
}
|
|
52
|
+
// my_result = myAgent.call("Return the sum of obj1 and obj2", {obj1, obj2})
|
|
53
|
+
// my_result = myAgent.call("Return the sum of obj1 and obj2", {obj1, obj2}, { echo: (iid, chunk) => {...} })
|
|
54
|
+
async call(userPrompt, scope, config) {
|
|
55
|
+
void userPrompt;
|
|
56
|
+
void scope;
|
|
57
|
+
void config;
|
|
58
|
+
throw new Error('Run the transformation before calling call');
|
|
59
|
+
}
|
|
60
|
+
// my_result = myAgent.callPro`Return the sum of ${obj1} and ${obj2}`()
|
|
61
|
+
// my_result = myAgent.callPro`Return the sum of ${obj1} and ${obj2}`(config)
|
|
62
|
+
callPro(userPromptParts, ...scope) {
|
|
63
|
+
void userPromptParts;
|
|
64
|
+
void scope;
|
|
65
|
+
throw new Error('Run the transformation before calling callPro');
|
|
66
|
+
}
|
|
67
|
+
setOnCallComplete(onCallComplete) {
|
|
68
|
+
this.onCallComplete = onCallComplete;
|
|
69
|
+
}
|
|
70
|
+
getUid() {
|
|
71
|
+
return this.uid;
|
|
72
|
+
}
|
|
73
|
+
getCurrentCallIid() {
|
|
74
|
+
return this.iid;
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Get the usage for the last invocation.
|
|
78
|
+
* @throws Error if no invocation has been made yet or usage not found
|
|
79
|
+
*/
|
|
80
|
+
lastUsage() {
|
|
81
|
+
if (!this.lastIid) {
|
|
82
|
+
throw new Error('No invocation has been made yet');
|
|
83
|
+
}
|
|
84
|
+
const usage = this.usages.get(this.lastIid);
|
|
85
|
+
if (!usage) {
|
|
86
|
+
throw new Error(`Usage not found for invocation ${this.lastIid}`);
|
|
87
|
+
}
|
|
88
|
+
return usage;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Get the total usage across all invocations.
|
|
92
|
+
*/
|
|
93
|
+
totalUsage() {
|
|
94
|
+
let total = Usage.zero();
|
|
95
|
+
for (const usage of this.usages.values()) {
|
|
96
|
+
total = total.add(usage);
|
|
97
|
+
}
|
|
98
|
+
return total;
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Manually close the agent and clean up resources
|
|
102
|
+
*/
|
|
103
|
+
async close() {
|
|
104
|
+
if (!this.uid || !this.sessionManager) {
|
|
105
|
+
this.logger.debug('Agent not initialized, nothing to close');
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
this.logger.debug(`Manually closing agent ${this.uid.slice(0, 8)}`);
|
|
109
|
+
// Close local resources
|
|
110
|
+
await this.sessionManager.closeAgent(this.uid);
|
|
111
|
+
// Clear references to help GC
|
|
112
|
+
this.runtime = undefined;
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* AsyncDisposable implementation for "await using" syntax
|
|
116
|
+
*/
|
|
117
|
+
async [Symbol.asyncDispose]() {
|
|
118
|
+
await this.close();
|
|
119
|
+
}
|
|
120
|
+
async callTransformation(ctx, prompt, config) {
|
|
121
|
+
const span = this.logger.startSpan('agentCallTransformation');
|
|
122
|
+
try {
|
|
123
|
+
// Check initialized
|
|
124
|
+
if (!this.uid || !this.runtime || !this.sessionManager) {
|
|
125
|
+
throw new Error('Agent not initialized. Call initialize first!');
|
|
126
|
+
}
|
|
127
|
+
// Invoke agent with call-time concepts (spawn concepts already sent during initialization)
|
|
128
|
+
const invokeConfig = {
|
|
129
|
+
uid: this.uid,
|
|
130
|
+
concepts: ctx.concepts,
|
|
131
|
+
siteId: ctx.siteId,
|
|
132
|
+
siteOutputType: ctx.siteOutputType,
|
|
133
|
+
prompt: maybePromptTemplate(prompt),
|
|
134
|
+
streaming: !!config?.listener || !!this.config.listener,
|
|
135
|
+
parentCallId: config?.parentCallId,
|
|
136
|
+
};
|
|
137
|
+
const { handle } = await invokeAgent(invokeConfig, this.mode, this.logger, this.sessionManager, this.runtime);
|
|
138
|
+
this.iid = handle.iid;
|
|
139
|
+
let cancelStream;
|
|
140
|
+
// If echo callback is provided, iterate over stream and call the callback
|
|
141
|
+
if (config?.listener || this.config.listener) {
|
|
142
|
+
cancelStream = new AbortController();
|
|
143
|
+
const echoCallback = config?.listener || this.config.listener; // Prioritize per-site config
|
|
144
|
+
// Start streaming in parallel with serving response
|
|
145
|
+
startEchoStream(this.sessionManager, cancelStream.signal, this.uid, handle.iid, echoCallback, this.logger);
|
|
146
|
+
}
|
|
147
|
+
// Serve response
|
|
148
|
+
const serveConfig = {
|
|
149
|
+
runtime: this.runtime,
|
|
150
|
+
handle,
|
|
151
|
+
siteOutputType: ctx.siteOutputType,
|
|
152
|
+
};
|
|
153
|
+
const result = (await Promise.race([
|
|
154
|
+
serveRequestsUntilResult(serveConfig, this.logger),
|
|
155
|
+
handle.exception,
|
|
156
|
+
]));
|
|
157
|
+
if (cancelStream) {
|
|
158
|
+
cancelStream.abort(); // Cancel the streaming loop after result is returned
|
|
159
|
+
}
|
|
160
|
+
return result;
|
|
161
|
+
}
|
|
162
|
+
catch (error) {
|
|
163
|
+
span.recordException(error);
|
|
164
|
+
throw error;
|
|
165
|
+
}
|
|
166
|
+
finally {
|
|
167
|
+
// Fetch usage for this invocation
|
|
168
|
+
if (this.iid && this.sessionManager) {
|
|
169
|
+
try {
|
|
170
|
+
const { usage, newTotal } = await this.sessionManager.fetchUsage(this.uid, this.iid, this.lastTotal);
|
|
171
|
+
this.usages.set(this.iid, usage);
|
|
172
|
+
this.lastIid = this.iid;
|
|
173
|
+
this.lastTotal = newTotal;
|
|
174
|
+
}
|
|
175
|
+
catch (e) {
|
|
176
|
+
this.logger.warn('Failed to fetch usage', e);
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
this.onCallComplete(this.iid);
|
|
180
|
+
this.iid = undefined;
|
|
181
|
+
this.runtime?.setIid(undefined);
|
|
182
|
+
span.end();
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { CompiledConceptContext } from '../transformer/processor/processor-utils.js';
|
|
2
|
+
import { Chunk, MaxTokens, ModelStrings, ToolModeStrings, Usage } from './common.js';
|
|
3
|
+
import { type Template } from './template.js';
|
|
4
|
+
export { Usage } from './common.js';
|
|
5
|
+
export type AgenticContext = {
|
|
6
|
+
concepts: CompiledConceptContext;
|
|
7
|
+
siteId: string;
|
|
8
|
+
siteOutputType: string;
|
|
9
|
+
docString: string;
|
|
10
|
+
};
|
|
11
|
+
export type AgenticConfig = {
|
|
12
|
+
model?: ModelStrings;
|
|
13
|
+
premise?: string;
|
|
14
|
+
system?: string | Template;
|
|
15
|
+
listener?: (iid: string, chunk: Chunk) => void;
|
|
16
|
+
/** Callback to receive usage statistics after the agentic function completes */
|
|
17
|
+
onUsage?: (usage: Usage) => void;
|
|
18
|
+
mode?: ToolModeStrings;
|
|
19
|
+
maxTokens?: MaxTokens | number;
|
|
20
|
+
parentCallId?: string;
|
|
21
|
+
};
|
|
22
|
+
export declare function agentic<T>(userPrompt: string, scope?: object, config?: AgenticConfig & {
|
|
23
|
+
system: string | Template;
|
|
24
|
+
premise?: never;
|
|
25
|
+
}): Promise<T>;
|
|
26
|
+
export declare function agentic<T>(userPrompt: string, scope?: object, config?: AgenticConfig & {
|
|
27
|
+
system?: never;
|
|
28
|
+
premise: string;
|
|
29
|
+
}): Promise<T>;
|
|
30
|
+
export declare function agentic<T>(userPrompt: string, scope?: object, config?: AgenticConfig & {
|
|
31
|
+
system?: never;
|
|
32
|
+
premise?: never;
|
|
33
|
+
}): Promise<T>;
|
|
34
|
+
export declare function agenticPro<T>(userPromptParts: TemplateStringsArray, ...scope: any[]): (config?: AgenticConfig) => Promise<T>;
|
|
35
|
+
export declare function agenticTransformation<T = any>(ctx: AgenticContext, prompt: string, config?: AgenticConfig): Promise<T>;
|
|
36
|
+
//# sourceMappingURL=agentic.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agentic.d.ts","sourceRoot":"","sources":["../../src/agentica/agentic.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,sBAAsB,EAAE,MAAM,wCAAwC,CAAC;AAEhF,OAAO,EAGH,KAAK,EACL,SAAS,EACT,YAAY,EAEZ,eAAe,EACf,KAAK,EAKR,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,KAAK,QAAQ,EAAuB,MAAM,YAAY,CAAC;AAKhE,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AAEjC,MAAM,MAAM,cAAc,GAAG;IACzB,QAAQ,EAAE,sBAAsB,CAAC;IACjC,MAAM,EAAE,MAAM,CAAC;IACf,cAAc,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IACxB,KAAK,CAAC,EAAE,YAAY,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC;IAC3B,QAAQ,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IAC/C,gFAAgF;IAChF,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IACjC,IAAI,CAAC,EAAE,eAAe,CAAC;IACvB,SAAS,CAAC,EAAE,SAAS,GAAG,MAAM,CAAC;IAC/B,YAAY,CAAC,EAAE,MAAM,CAAC;CACzB,CAAC;AAGF,wBAAsB,OAAO,CAAC,CAAC,EAC3B,UAAU,EAAE,MAAM,EAClB,KAAK,CAAC,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,aAAa,GAAG;IAAE,MAAM,EAAE,MAAM,GAAG,QAAQ,CAAC;IAAC,OAAO,CAAC,EAAE,KAAK,CAAA;CAAE,GACxE,OAAO,CAAC,CAAC,CAAC,CAAC;AAEd,wBAAsB,OAAO,CAAC,CAAC,EAC3B,UAAU,EAAE,MAAM,EAClB,KAAK,CAAC,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,aAAa,GAAG;IAAE,MAAM,CAAC,EAAE,KAAK,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,GAC7D,OAAO,CAAC,CAAC,CAAC,CAAC;AAEd,wBAAsB,OAAO,CAAC,CAAC,EAC3B,UAAU,EAAE,MAAM,EAClB,KAAK,CAAC,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,aAAa,GAAG;IAAE,MAAM,CAAC,EAAE,KAAK,CAAC;IAAC,OAAO,CAAC,EAAE,KAAK,CAAA;CAAE,GAC7D,OAAO,CAAC,CAAC,CAAC,CAAC;AAQd,wBAAgB,UAAU,CAAC,CAAC,EACxB,eAAe,EAAE,oBAAoB,EACrC,GAAG,KAAK,EAAE,GAAG,EAAE,GAChB,CAAC,MAAM,CAAC,EAAE,aAAa,KAAK,OAAO,CAAC,CAAC,CAAC,CAIxC;AAED,wBAAsB,qBAAqB,CAAC,CAAC,GAAG,GAAG,EAC/C,GAAG,EAAE,cAAc,EACnB,MAAM,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,aAAa,GACvB,OAAO,CAAC,CAAC,CAAC,CAwFZ"}
|