@agentuity/runtime 2.0.11 → 3.0.0-alpha.1
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/dist/index.d.ts +37 -65
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +59 -61
- package/dist/index.js.map +1 -1
- package/package.json +9 -38
- package/src/index.ts +58 -259
- package/AGENTS.md +0 -116
- package/dist/_config.d.ts +0 -100
- package/dist/_config.d.ts.map +0 -1
- package/dist/_config.js +0 -147
- package/dist/_config.js.map +0 -1
- package/dist/_context.d.ts +0 -80
- package/dist/_context.d.ts.map +0 -1
- package/dist/_context.js +0 -160
- package/dist/_context.js.map +0 -1
- package/dist/_events.d.ts +0 -64
- package/dist/_events.d.ts.map +0 -1
- package/dist/_events.js +0 -92
- package/dist/_events.js.map +0 -1
- package/dist/_globals.d.ts +0 -58
- package/dist/_globals.d.ts.map +0 -1
- package/dist/_globals.js +0 -71
- package/dist/_globals.js.map +0 -1
- package/dist/_idle.d.ts +0 -7
- package/dist/_idle.d.ts.map +0 -1
- package/dist/_idle.js +0 -10
- package/dist/_idle.js.map +0 -1
- package/dist/_metadata.d.ts +0 -117
- package/dist/_metadata.d.ts.map +0 -1
- package/dist/_metadata.js +0 -268
- package/dist/_metadata.js.map +0 -1
- package/dist/_process-protection.d.ts +0 -27
- package/dist/_process-protection.d.ts.map +0 -1
- package/dist/_process-protection.js +0 -56
- package/dist/_process-protection.js.map +0 -1
- package/dist/_server.d.ts +0 -50
- package/dist/_server.d.ts.map +0 -1
- package/dist/_server.js +0 -89
- package/dist/_server.js.map +0 -1
- package/dist/_services.d.ts +0 -25
- package/dist/_services.d.ts.map +0 -1
- package/dist/_services.js +0 -286
- package/dist/_services.js.map +0 -1
- package/dist/_standalone.d.ts +0 -212
- package/dist/_standalone.d.ts.map +0 -1
- package/dist/_standalone.js +0 -556
- package/dist/_standalone.js.map +0 -1
- package/dist/_tokens.d.ts +0 -12
- package/dist/_tokens.d.ts.map +0 -1
- package/dist/_tokens.js +0 -97
- package/dist/_tokens.js.map +0 -1
- package/dist/_util.d.ts +0 -16
- package/dist/_util.d.ts.map +0 -1
- package/dist/_util.js +0 -54
- package/dist/_util.js.map +0 -1
- package/dist/_validation.d.ts +0 -89
- package/dist/_validation.d.ts.map +0 -1
- package/dist/_validation.js +0 -29
- package/dist/_validation.js.map +0 -1
- package/dist/_waituntil.d.ts +0 -32
- package/dist/_waituntil.d.ts.map +0 -1
- package/dist/_waituntil.js +0 -156
- package/dist/_waituntil.js.map +0 -1
- package/dist/agent.d.ts +0 -1262
- package/dist/agent.d.ts.map +0 -1
- package/dist/agent.js +0 -981
- package/dist/agent.js.map +0 -1
- package/dist/app.d.ts +0 -514
- package/dist/app.d.ts.map +0 -1
- package/dist/app.js +0 -228
- package/dist/app.js.map +0 -1
- package/dist/bootstrap.d.ts +0 -44
- package/dist/bootstrap.d.ts.map +0 -1
- package/dist/bootstrap.js +0 -259
- package/dist/bootstrap.js.map +0 -1
- package/dist/bun-s3-patch.d.ts +0 -37
- package/dist/bun-s3-patch.d.ts.map +0 -1
- package/dist/bun-s3-patch.js +0 -142
- package/dist/bun-s3-patch.js.map +0 -1
- package/dist/cors.d.ts +0 -42
- package/dist/cors.d.ts.map +0 -1
- package/dist/cors.js +0 -117
- package/dist/cors.js.map +0 -1
- package/dist/dev-patches/aisdk.d.ts +0 -17
- package/dist/dev-patches/aisdk.d.ts.map +0 -1
- package/dist/dev-patches/aisdk.js +0 -160
- package/dist/dev-patches/aisdk.js.map +0 -1
- package/dist/dev-patches/gateway.d.ts +0 -16
- package/dist/dev-patches/gateway.d.ts.map +0 -1
- package/dist/dev-patches/gateway.js +0 -54
- package/dist/dev-patches/gateway.js.map +0 -1
- package/dist/dev-patches/index.d.ts +0 -21
- package/dist/dev-patches/index.d.ts.map +0 -1
- package/dist/dev-patches/index.js +0 -33
- package/dist/dev-patches/index.js.map +0 -1
- package/dist/dev-patches/otel-llm.d.ts +0 -12
- package/dist/dev-patches/otel-llm.d.ts.map +0 -1
- package/dist/dev-patches/otel-llm.js +0 -352
- package/dist/dev-patches/otel-llm.js.map +0 -1
- package/dist/devmode.d.ts +0 -3
- package/dist/devmode.d.ts.map +0 -1
- package/dist/devmode.js +0 -167
- package/dist/devmode.js.map +0 -1
- package/dist/eval.d.ts +0 -91
- package/dist/eval.d.ts.map +0 -1
- package/dist/eval.js +0 -16
- package/dist/eval.js.map +0 -1
- package/dist/handlers/_route-meta.d.ts +0 -22
- package/dist/handlers/_route-meta.d.ts.map +0 -1
- package/dist/handlers/_route-meta.js +0 -25
- package/dist/handlers/_route-meta.js.map +0 -1
- package/dist/handlers/cron.d.ts +0 -73
- package/dist/handlers/cron.d.ts.map +0 -1
- package/dist/handlers/cron.js +0 -43
- package/dist/handlers/cron.js.map +0 -1
- package/dist/handlers/index.d.ts +0 -6
- package/dist/handlers/index.d.ts.map +0 -1
- package/dist/handlers/index.js +0 -6
- package/dist/handlers/index.js.map +0 -1
- package/dist/handlers/sse.d.ts +0 -163
- package/dist/handlers/sse.d.ts.map +0 -1
- package/dist/handlers/sse.js +0 -175
- package/dist/handlers/sse.js.map +0 -1
- package/dist/handlers/stream.d.ts +0 -52
- package/dist/handlers/stream.d.ts.map +0 -1
- package/dist/handlers/stream.js +0 -108
- package/dist/handlers/stream.js.map +0 -1
- package/dist/handlers/webrtc.d.ts +0 -49
- package/dist/handlers/webrtc.d.ts.map +0 -1
- package/dist/handlers/webrtc.js +0 -109
- package/dist/handlers/webrtc.js.map +0 -1
- package/dist/handlers/websocket.d.ts +0 -88
- package/dist/handlers/websocket.d.ts.map +0 -1
- package/dist/handlers/websocket.js +0 -161
- package/dist/handlers/websocket.js.map +0 -1
- package/dist/logger/console.d.ts +0 -70
- package/dist/logger/console.d.ts.map +0 -1
- package/dist/logger/console.js +0 -278
- package/dist/logger/console.js.map +0 -1
- package/dist/logger/index.d.ts +0 -3
- package/dist/logger/index.d.ts.map +0 -1
- package/dist/logger/index.js +0 -3
- package/dist/logger/index.js.map +0 -1
- package/dist/logger/internal.d.ts +0 -79
- package/dist/logger/internal.d.ts.map +0 -1
- package/dist/logger/internal.js +0 -133
- package/dist/logger/internal.js.map +0 -1
- package/dist/logger/logger.d.ts +0 -41
- package/dist/logger/logger.d.ts.map +0 -1
- package/dist/logger/logger.js +0 -2
- package/dist/logger/logger.js.map +0 -1
- package/dist/logger/user.d.ts +0 -8
- package/dist/logger/user.d.ts.map +0 -1
- package/dist/logger/user.js +0 -7
- package/dist/logger/user.js.map +0 -1
- package/dist/logger/util.d.ts +0 -11
- package/dist/logger/util.d.ts.map +0 -1
- package/dist/logger/util.js +0 -77
- package/dist/logger/util.js.map +0 -1
- package/dist/middleware.d.ts +0 -105
- package/dist/middleware.d.ts.map +0 -1
- package/dist/middleware.js +0 -763
- package/dist/middleware.js.map +0 -1
- package/dist/otel/config.d.ts +0 -19
- package/dist/otel/config.d.ts.map +0 -1
- package/dist/otel/config.js +0 -26
- package/dist/otel/config.js.map +0 -1
- package/dist/otel/console.d.ts +0 -33
- package/dist/otel/console.d.ts.map +0 -1
- package/dist/otel/console.js +0 -86
- package/dist/otel/console.js.map +0 -1
- package/dist/otel/exporters/index.d.ts +0 -4
- package/dist/otel/exporters/index.d.ts.map +0 -1
- package/dist/otel/exporters/index.js +0 -4
- package/dist/otel/exporters/index.js.map +0 -1
- package/dist/otel/exporters/jsonl-log-exporter.d.ts +0 -36
- package/dist/otel/exporters/jsonl-log-exporter.d.ts.map +0 -1
- package/dist/otel/exporters/jsonl-log-exporter.js +0 -103
- package/dist/otel/exporters/jsonl-log-exporter.js.map +0 -1
- package/dist/otel/exporters/jsonl-metric-exporter.d.ts +0 -40
- package/dist/otel/exporters/jsonl-metric-exporter.d.ts.map +0 -1
- package/dist/otel/exporters/jsonl-metric-exporter.js +0 -104
- package/dist/otel/exporters/jsonl-metric-exporter.js.map +0 -1
- package/dist/otel/exporters/jsonl-trace-exporter.d.ts +0 -36
- package/dist/otel/exporters/jsonl-trace-exporter.d.ts.map +0 -1
- package/dist/otel/exporters/jsonl-trace-exporter.js +0 -111
- package/dist/otel/exporters/jsonl-trace-exporter.js.map +0 -1
- package/dist/otel/fetch.d.ts +0 -12
- package/dist/otel/fetch.d.ts.map +0 -1
- package/dist/otel/fetch.js +0 -82
- package/dist/otel/fetch.js.map +0 -1
- package/dist/otel/http.d.ts +0 -16
- package/dist/otel/http.d.ts.map +0 -1
- package/dist/otel/http.js +0 -44
- package/dist/otel/http.js.map +0 -1
- package/dist/otel/logger.d.ts +0 -37
- package/dist/otel/logger.d.ts.map +0 -1
- package/dist/otel/logger.js +0 -265
- package/dist/otel/logger.js.map +0 -1
- package/dist/otel/otel.d.ts +0 -68
- package/dist/otel/otel.d.ts.map +0 -1
- package/dist/otel/otel.js +0 -245
- package/dist/otel/otel.js.map +0 -1
- package/dist/otel/tracestate.d.ts +0 -44
- package/dist/otel/tracestate.d.ts.map +0 -1
- package/dist/otel/tracestate.js +0 -84
- package/dist/otel/tracestate.js.map +0 -1
- package/dist/router.d.ts +0 -66
- package/dist/router.d.ts.map +0 -1
- package/dist/router.js +0 -44
- package/dist/router.js.map +0 -1
- package/dist/services/evalrun/composite.d.ts +0 -21
- package/dist/services/evalrun/composite.d.ts.map +0 -1
- package/dist/services/evalrun/composite.js +0 -26
- package/dist/services/evalrun/composite.js.map +0 -1
- package/dist/services/evalrun/http.d.ts +0 -24
- package/dist/services/evalrun/http.d.ts.map +0 -1
- package/dist/services/evalrun/http.js +0 -115
- package/dist/services/evalrun/http.js.map +0 -1
- package/dist/services/evalrun/index.d.ts +0 -5
- package/dist/services/evalrun/index.d.ts.map +0 -1
- package/dist/services/evalrun/index.js +0 -5
- package/dist/services/evalrun/index.js.map +0 -1
- package/dist/services/evalrun/json.d.ts +0 -21
- package/dist/services/evalrun/json.d.ts.map +0 -1
- package/dist/services/evalrun/json.js +0 -38
- package/dist/services/evalrun/json.js.map +0 -1
- package/dist/services/evalrun/local.d.ts +0 -19
- package/dist/services/evalrun/local.d.ts.map +0 -1
- package/dist/services/evalrun/local.js +0 -22
- package/dist/services/evalrun/local.js.map +0 -1
- package/dist/services/local/_db.d.ts +0 -4
- package/dist/services/local/_db.d.ts.map +0 -1
- package/dist/services/local/_db.js +0 -281
- package/dist/services/local/_db.js.map +0 -1
- package/dist/services/local/_router.d.ts +0 -3
- package/dist/services/local/_router.d.ts.map +0 -1
- package/dist/services/local/_router.js +0 -28
- package/dist/services/local/_router.js.map +0 -1
- package/dist/services/local/_util.d.ts +0 -18
- package/dist/services/local/_util.d.ts.map +0 -1
- package/dist/services/local/_util.js +0 -44
- package/dist/services/local/_util.js.map +0 -1
- package/dist/services/local/email.d.ts +0 -24
- package/dist/services/local/email.d.ts.map +0 -1
- package/dist/services/local/email.js +0 -58
- package/dist/services/local/email.js.map +0 -1
- package/dist/services/local/index.d.ts +0 -10
- package/dist/services/local/index.d.ts.map +0 -1
- package/dist/services/local/index.js +0 -10
- package/dist/services/local/index.js.map +0 -1
- package/dist/services/local/keyvalue.d.ts +0 -17
- package/dist/services/local/keyvalue.d.ts.map +0 -1
- package/dist/services/local/keyvalue.js +0 -133
- package/dist/services/local/keyvalue.js.map +0 -1
- package/dist/services/local/queue.d.ts +0 -10
- package/dist/services/local/queue.d.ts.map +0 -1
- package/dist/services/local/queue.js +0 -96
- package/dist/services/local/queue.js.map +0 -1
- package/dist/services/local/stream.d.ts +0 -12
- package/dist/services/local/stream.d.ts.map +0 -1
- package/dist/services/local/stream.js +0 -266
- package/dist/services/local/stream.js.map +0 -1
- package/dist/services/local/task.d.ts +0 -55
- package/dist/services/local/task.d.ts.map +0 -1
- package/dist/services/local/task.js +0 -1248
- package/dist/services/local/task.js.map +0 -1
- package/dist/services/local/vector.d.ts +0 -17
- package/dist/services/local/vector.d.ts.map +0 -1
- package/dist/services/local/vector.js +0 -303
- package/dist/services/local/vector.js.map +0 -1
- package/dist/services/sandbox/http.d.ts +0 -23
- package/dist/services/sandbox/http.d.ts.map +0 -1
- package/dist/services/sandbox/http.js +0 -327
- package/dist/services/sandbox/http.js.map +0 -1
- package/dist/services/sandbox/index.d.ts +0 -2
- package/dist/services/sandbox/index.d.ts.map +0 -1
- package/dist/services/sandbox/index.js +0 -2
- package/dist/services/sandbox/index.js.map +0 -1
- package/dist/services/session/composite.d.ts +0 -21
- package/dist/services/session/composite.d.ts.map +0 -1
- package/dist/services/session/composite.js +0 -26
- package/dist/services/session/composite.js.map +0 -1
- package/dist/services/session/http.d.ts +0 -34
- package/dist/services/session/http.d.ts.map +0 -1
- package/dist/services/session/http.js +0 -124
- package/dist/services/session/http.js.map +0 -1
- package/dist/services/session/index.d.ts +0 -5
- package/dist/services/session/index.d.ts.map +0 -1
- package/dist/services/session/index.js +0 -5
- package/dist/services/session/index.js.map +0 -1
- package/dist/services/session/json.d.ts +0 -22
- package/dist/services/session/json.d.ts.map +0 -1
- package/dist/services/session/json.js +0 -35
- package/dist/services/session/json.js.map +0 -1
- package/dist/services/session/local.d.ts +0 -19
- package/dist/services/session/local.d.ts.map +0 -1
- package/dist/services/session/local.js +0 -23
- package/dist/services/session/local.js.map +0 -1
- package/dist/services/thread/local.d.ts +0 -20
- package/dist/services/thread/local.d.ts.map +0 -1
- package/dist/services/thread/local.js +0 -158
- package/dist/services/thread/local.js.map +0 -1
- package/dist/session.d.ts +0 -734
- package/dist/session.d.ts.map +0 -1
- package/dist/session.js +0 -1140
- package/dist/session.js.map +0 -1
- package/dist/signature.d.ts +0 -22
- package/dist/signature.d.ts.map +0 -1
- package/dist/signature.js +0 -63
- package/dist/signature.js.map +0 -1
- package/dist/validator.d.ts +0 -142
- package/dist/validator.d.ts.map +0 -1
- package/dist/validator.js +0 -149
- package/dist/validator.js.map +0 -1
- package/dist/version-check.d.ts +0 -20
- package/dist/version-check.d.ts.map +0 -1
- package/dist/version-check.js +0 -157
- package/dist/version-check.js.map +0 -1
- package/dist/web.d.ts +0 -8
- package/dist/web.d.ts.map +0 -1
- package/dist/web.js +0 -67
- package/dist/web.js.map +0 -1
- package/dist/webrtc-signaling.d.ts +0 -80
- package/dist/webrtc-signaling.d.ts.map +0 -1
- package/dist/webrtc-signaling.js +0 -237
- package/dist/webrtc-signaling.js.map +0 -1
- package/dist/workbench.d.ts +0 -17
- package/dist/workbench.d.ts.map +0 -1
- package/dist/workbench.js +0 -605
- package/dist/workbench.js.map +0 -1
- package/src/_config.ts +0 -163
- package/src/_context.ts +0 -240
- package/src/_events.ts +0 -142
- package/src/_globals.ts +0 -92
- package/src/_idle.ts +0 -10
- package/src/_metadata.ts +0 -407
- package/src/_process-protection.ts +0 -71
- package/src/_server.ts +0 -109
- package/src/_services.ts +0 -379
- package/src/_standalone.ts +0 -710
- package/src/_tokens.ts +0 -114
- package/src/_util.ts +0 -62
- package/src/_validation.ts +0 -119
- package/src/_waituntil.ts +0 -188
- package/src/agent.ts +0 -2739
- package/src/app.ts +0 -769
- package/src/bootstrap.ts +0 -321
- package/src/bun-s3-patch.ts +0 -224
- package/src/cors.ts +0 -137
- package/src/dev-patches/aisdk.ts +0 -169
- package/src/dev-patches/gateway.ts +0 -68
- package/src/dev-patches/index.ts +0 -37
- package/src/dev-patches/otel-llm.ts +0 -405
- package/src/devmode.ts +0 -171
- package/src/eval.ts +0 -109
- package/src/globals.d.ts +0 -28
- package/src/handlers/_route-meta.ts +0 -33
- package/src/handlers/cron.ts +0 -141
- package/src/handlers/index.ts +0 -18
- package/src/handlers/sse.ts +0 -358
- package/src/handlers/stream.ts +0 -121
- package/src/handlers/webrtc.ts +0 -125
- package/src/handlers/websocket.ts +0 -203
- package/src/logger/console.ts +0 -323
- package/src/logger/index.ts +0 -2
- package/src/logger/internal.ts +0 -165
- package/src/logger/logger.ts +0 -44
- package/src/logger/user.ts +0 -15
- package/src/logger/util.ts +0 -80
- package/src/middleware.ts +0 -1095
- package/src/otel/config.ts +0 -47
- package/src/otel/console.ts +0 -91
- package/src/otel/exporters/README.md +0 -217
- package/src/otel/exporters/index.ts +0 -3
- package/src/otel/exporters/jsonl-log-exporter.ts +0 -113
- package/src/otel/exporters/jsonl-metric-exporter.ts +0 -120
- package/src/otel/exporters/jsonl-trace-exporter.ts +0 -121
- package/src/otel/fetch.ts +0 -105
- package/src/otel/http.ts +0 -53
- package/src/otel/logger.ts +0 -293
- package/src/otel/otel.ts +0 -354
- package/src/otel/tracestate.ts +0 -108
- package/src/router.ts +0 -75
- package/src/services/evalrun/composite.ts +0 -34
- package/src/services/evalrun/http.ts +0 -167
- package/src/services/evalrun/index.ts +0 -4
- package/src/services/evalrun/json.ts +0 -46
- package/src/services/evalrun/local.ts +0 -28
- package/src/services/local/README.md +0 -1576
- package/src/services/local/_db.ts +0 -353
- package/src/services/local/_router.ts +0 -40
- package/src/services/local/_util.ts +0 -55
- package/src/services/local/email.ts +0 -91
- package/src/services/local/index.ts +0 -9
- package/src/services/local/keyvalue.ts +0 -174
- package/src/services/local/queue.ts +0 -145
- package/src/services/local/stream.ts +0 -358
- package/src/services/local/task.ts +0 -1711
- package/src/services/local/vector.ts +0 -438
- package/src/services/sandbox/http.ts +0 -522
- package/src/services/sandbox/index.ts +0 -1
- package/src/services/session/composite.ts +0 -33
- package/src/services/session/http.ts +0 -167
- package/src/services/session/index.ts +0 -4
- package/src/services/session/json.ts +0 -42
- package/src/services/session/local.ts +0 -33
- package/src/services/thread/local.ts +0 -199
- package/src/session.ts +0 -1960
- package/src/signature.ts +0 -82
- package/src/validator.ts +0 -283
- package/src/version-check.ts +0 -184
- package/src/web.ts +0 -76
- package/src/webrtc-signaling.ts +0 -288
- package/src/workbench.ts +0 -725
package/src/_tokens.ts
DELETED
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
import type { Context, AttributeValue } from '@opentelemetry/api';
|
|
2
|
-
import type { Span } from '@opentelemetry/sdk-trace-base';
|
|
3
|
-
import type { SpanProcessor } from '@opentelemetry/sdk-trace-base';
|
|
4
|
-
import { inAgentContext, inHTTPContext, getHTTPContext } from './_context';
|
|
5
|
-
import {
|
|
6
|
-
ATTR_GEN_AI_SYSTEM,
|
|
7
|
-
ATTR_GEN_AI_RESPONSE_MODEL,
|
|
8
|
-
ATTR_GEN_AI_USAGE_INPUT_TOKENS,
|
|
9
|
-
ATTR_GEN_AI_USAGE_OUTPUT_TOKENS,
|
|
10
|
-
} from '@opentelemetry/semantic-conventions/incubating';
|
|
11
|
-
|
|
12
|
-
export const TOKENS_HEADER = 'x-agentuity-tokens';
|
|
13
|
-
export const DURATION_HEADER = 'x-agentuity-duration';
|
|
14
|
-
|
|
15
|
-
// AI SDK span names: ai.generateText, ai.streamText, ai.generateObject, ai.streamObject, ai.embed, ai.embedMany
|
|
16
|
-
const AI_SDK_SPAN_PREFIX = 'ai.';
|
|
17
|
-
const AI_SDK_MODEL_NAME = 'ai.model.id';
|
|
18
|
-
const AI_SDK_USAGE_PROMPT_TOKENS = 'ai.usage.promptTokens';
|
|
19
|
-
const AI_SDK_USAGE_COMPLETION_TOKENS = 'ai.usage.completionTokens';
|
|
20
|
-
|
|
21
|
-
const parseTokenHeader = (val: string | undefined): Map<string, number> => {
|
|
22
|
-
const kv = new Map<string, number>();
|
|
23
|
-
if (val) {
|
|
24
|
-
// format is: [model]:[count] [model:count]
|
|
25
|
-
const tok = val.split(' ');
|
|
26
|
-
for (const entry of tok) {
|
|
27
|
-
const [name, count] = entry.split(':');
|
|
28
|
-
if (name) {
|
|
29
|
-
kv.set(name, parseInt(count ?? '0', 10) ?? 0);
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
return kv;
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
const serializeTokenHeader = (kv: Map<string, number>): string => {
|
|
37
|
-
const lines: string[] = [];
|
|
38
|
-
for (const [k, v] of kv) {
|
|
39
|
-
lines.push(`${k}:${v}`);
|
|
40
|
-
}
|
|
41
|
-
return lines.join(' ');
|
|
42
|
-
};
|
|
43
|
-
|
|
44
|
-
const getTokenValue = (val: AttributeValue | undefined): number => {
|
|
45
|
-
if (val) {
|
|
46
|
-
const v = val.valueOf();
|
|
47
|
-
switch (typeof v) {
|
|
48
|
-
case 'number':
|
|
49
|
-
return v;
|
|
50
|
-
case 'string':
|
|
51
|
-
return parseInt(v, 10);
|
|
52
|
-
default:
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
return 0;
|
|
56
|
-
};
|
|
57
|
-
|
|
58
|
-
export class TokenSpanProcessor implements SpanProcessor {
|
|
59
|
-
onStart(_span: Span, _context: Context) {
|
|
60
|
-
return;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
onEnd(span: Span) {
|
|
64
|
-
if (inAgentContext() && inHTTPContext()) {
|
|
65
|
-
const ctx = getHTTPContext();
|
|
66
|
-
const tokenLine = ctx.res.headers.get(TOKENS_HEADER) ?? undefined;
|
|
67
|
-
const tokens = parseTokenHeader(tokenLine);
|
|
68
|
-
let mutated = false;
|
|
69
|
-
// AI SDK uses ai.* span names but doesn't use the semantic attribute names
|
|
70
|
-
if (span.name.startsWith(AI_SDK_SPAN_PREFIX) && AI_SDK_MODEL_NAME in span.attributes) {
|
|
71
|
-
const model = span.attributes[AI_SDK_MODEL_NAME]!.toString();
|
|
72
|
-
let totalTokens = tokens.get(model) ?? 0;
|
|
73
|
-
if (AI_SDK_USAGE_PROMPT_TOKENS in span.attributes) {
|
|
74
|
-
totalTokens += getTokenValue(span.attributes[AI_SDK_USAGE_PROMPT_TOKENS]);
|
|
75
|
-
}
|
|
76
|
-
if (AI_SDK_USAGE_COMPLETION_TOKENS in span.attributes) {
|
|
77
|
-
totalTokens += getTokenValue(span.attributes[AI_SDK_USAGE_COMPLETION_TOKENS]);
|
|
78
|
-
}
|
|
79
|
-
if (totalTokens > 0) {
|
|
80
|
-
tokens.set(model, totalTokens);
|
|
81
|
-
mutated = true;
|
|
82
|
-
}
|
|
83
|
-
} else if (
|
|
84
|
-
ATTR_GEN_AI_SYSTEM in span.attributes &&
|
|
85
|
-
ATTR_GEN_AI_RESPONSE_MODEL in span.attributes
|
|
86
|
-
) {
|
|
87
|
-
// OpenTelemetry GenAI semantic conventions (used by build-time LLM instrumentation)
|
|
88
|
-
const model = span.attributes[ATTR_GEN_AI_RESPONSE_MODEL]!.toString();
|
|
89
|
-
let totalTokens = tokens.get(model) ?? 0;
|
|
90
|
-
if (ATTR_GEN_AI_USAGE_INPUT_TOKENS in span.attributes) {
|
|
91
|
-
totalTokens += getTokenValue(span.attributes[ATTR_GEN_AI_USAGE_INPUT_TOKENS]);
|
|
92
|
-
}
|
|
93
|
-
if (ATTR_GEN_AI_USAGE_OUTPUT_TOKENS in span.attributes) {
|
|
94
|
-
totalTokens += getTokenValue(span.attributes[ATTR_GEN_AI_USAGE_OUTPUT_TOKENS]);
|
|
95
|
-
}
|
|
96
|
-
if (totalTokens > 0) {
|
|
97
|
-
tokens.set(model, totalTokens);
|
|
98
|
-
mutated = true;
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
if (mutated) {
|
|
102
|
-
ctx.header(TOKENS_HEADER, serializeTokenHeader(tokens));
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
forceFlush() {
|
|
108
|
-
return Promise.resolve();
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
shutdown() {
|
|
112
|
-
return Promise.resolve();
|
|
113
|
-
}
|
|
114
|
-
}
|
package/src/_util.ts
DELETED
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
import type { Context } from 'hono';
|
|
2
|
-
|
|
3
|
-
export function returnResponse(ctx: Context, result: unknown) {
|
|
4
|
-
if (result instanceof ReadableStream) return ctx.body(result);
|
|
5
|
-
if (result instanceof Response) return result;
|
|
6
|
-
if (typeof result === 'string') return ctx.text(result);
|
|
7
|
-
if (typeof result === 'number' || typeof result === 'boolean') return ctx.text(String(result));
|
|
8
|
-
return ctx.json(result);
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
/**
|
|
12
|
-
* SHA256 hash of the given values
|
|
13
|
-
*
|
|
14
|
-
* @param val one or more strings to hash
|
|
15
|
-
* @returns hash string in hex format
|
|
16
|
-
*/
|
|
17
|
-
export function hash(...val: string[]): string {
|
|
18
|
-
const hasher = new Bun.CryptoHasher('sha256');
|
|
19
|
-
val.map((val) => hasher.update(val));
|
|
20
|
-
return hasher.digest().toHex();
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* Safely stringify an object to JSON, handling circular references
|
|
25
|
-
* @param obj - The object to stringify
|
|
26
|
-
* @returns JSON string representation
|
|
27
|
-
*/
|
|
28
|
-
export function safeStringify(obj: unknown): string {
|
|
29
|
-
const stack: unknown[] = [];
|
|
30
|
-
|
|
31
|
-
function replacer(_key: string, value: unknown): unknown {
|
|
32
|
-
if (typeof value === 'bigint') {
|
|
33
|
-
return value.toString();
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
if (typeof value === 'object' && value !== null) {
|
|
37
|
-
// Check if this object is already in our ancestor chain
|
|
38
|
-
if (stack.includes(value)) {
|
|
39
|
-
return '[Circular]';
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
// Add to stack before processing
|
|
43
|
-
stack.push(value);
|
|
44
|
-
|
|
45
|
-
// Process the object
|
|
46
|
-
const result = Array.isArray(value) ? [] : {};
|
|
47
|
-
|
|
48
|
-
for (const [k, v] of Object.entries(value)) {
|
|
49
|
-
(result as Record<string, unknown>)[k] = replacer(k, v);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
// Remove from stack after processing
|
|
53
|
-
stack.pop();
|
|
54
|
-
|
|
55
|
-
return result;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
return value;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
return JSON.stringify(replacer('', obj));
|
|
62
|
-
}
|
package/src/_validation.ts
DELETED
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
2
|
-
import type { StandardSchemaV1, InferInput, InferOutput } from '@agentuity/core';
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Schema definition for routes that can have input (POST, PUT, PATCH, DELETE).
|
|
6
|
-
* Both input and output are optional, but output is recommended.
|
|
7
|
-
*
|
|
8
|
-
* @template TInput - Input schema (StandardSchemaV1 or undefined)
|
|
9
|
-
* @template TOutput - Output schema (StandardSchemaV1 or undefined)
|
|
10
|
-
*
|
|
11
|
-
* @example
|
|
12
|
-
* ```typescript
|
|
13
|
-
* const schema: RouteSchema<z.ZodObject<{name: z.ZodString}>, z.ZodString> = {
|
|
14
|
-
* input: z.object({ name: z.string() }),
|
|
15
|
-
* output: z.string()
|
|
16
|
-
* };
|
|
17
|
-
* ```
|
|
18
|
-
*/
|
|
19
|
-
export type RouteSchema<
|
|
20
|
-
TInput extends StandardSchemaV1 | undefined = StandardSchemaV1 | undefined,
|
|
21
|
-
TOutput extends StandardSchemaV1 | undefined = StandardSchemaV1 | undefined,
|
|
22
|
-
> = {
|
|
23
|
-
input?: TInput;
|
|
24
|
-
output?: TOutput;
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
/**
|
|
28
|
-
* Schema definition for GET routes.
|
|
29
|
-
* Input is not allowed (enforced as never), only output validation is supported.
|
|
30
|
-
*
|
|
31
|
-
* @template TOutput - Output schema (StandardSchemaV1 or undefined)
|
|
32
|
-
*
|
|
33
|
-
* @example
|
|
34
|
-
* ```typescript
|
|
35
|
-
* const schema: GetRouteSchema<z.ZodString> = {
|
|
36
|
-
* output: z.string()
|
|
37
|
-
* };
|
|
38
|
-
* ```
|
|
39
|
-
*/
|
|
40
|
-
export type GetRouteSchema<
|
|
41
|
-
TOutput extends StandardSchemaV1 | undefined = StandardSchemaV1 | undefined,
|
|
42
|
-
> = {
|
|
43
|
-
input?: never;
|
|
44
|
-
output?: TOutput;
|
|
45
|
-
};
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* Infer the input type from a StandardSchema.
|
|
49
|
-
* Returns the input type of the schema (before validation/transformation).
|
|
50
|
-
*
|
|
51
|
-
* @template T - Schema type
|
|
52
|
-
*/
|
|
53
|
-
export type InferSchemaInput<T> = T extends StandardSchemaV1 ? InferInput<T> : undefined;
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* Infer the output type from a StandardSchema.
|
|
57
|
-
* Returns the output type of the schema (after validation/transformation).
|
|
58
|
-
*
|
|
59
|
-
* @template T - Schema type
|
|
60
|
-
*/
|
|
61
|
-
export type InferSchemaOutput<T> = T extends StandardSchemaV1 ? InferOutput<T> : undefined;
|
|
62
|
-
|
|
63
|
-
/**
|
|
64
|
-
* Extract input schema from RouteSchema or GetRouteSchema.
|
|
65
|
-
*
|
|
66
|
-
* @template T - RouteSchema or GetRouteSchema type
|
|
67
|
-
*/
|
|
68
|
-
export type ExtractInputSchema<T> =
|
|
69
|
-
T extends RouteSchema<infer I, any> ? I : T extends GetRouteSchema<any> ? never : never;
|
|
70
|
-
|
|
71
|
-
/**
|
|
72
|
-
* Extract output schema from RouteSchema or GetRouteSchema.
|
|
73
|
-
*
|
|
74
|
-
* @template T - RouteSchema or GetRouteSchema type
|
|
75
|
-
*/
|
|
76
|
-
export type ExtractOutputSchema<T> =
|
|
77
|
-
T extends RouteSchema<any, infer O> ? O : T extends GetRouteSchema<infer O> ? O : never;
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* Validation result from StandardSchema validation.
|
|
81
|
-
*/
|
|
82
|
-
export type ValidationResult<T> =
|
|
83
|
-
| { success: true; data: T }
|
|
84
|
-
| { success: false; issues: StandardSchemaV1.Issue[] };
|
|
85
|
-
|
|
86
|
-
/**
|
|
87
|
-
* Validates a value against a StandardSchema.
|
|
88
|
-
*
|
|
89
|
-
* @param schema - The StandardSchema to validate against
|
|
90
|
-
* @param value - The value to validate
|
|
91
|
-
* @returns ValidationResult with success/failure and data/issues
|
|
92
|
-
*/
|
|
93
|
-
export async function validateSchema<T>(
|
|
94
|
-
schema: StandardSchemaV1,
|
|
95
|
-
value: unknown
|
|
96
|
-
): Promise<ValidationResult<T>> {
|
|
97
|
-
const result = await schema['~standard'].validate(value);
|
|
98
|
-
|
|
99
|
-
if ('issues' in result && result.issues) {
|
|
100
|
-
return { success: false, issues: Array.from(result.issues) };
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
return { success: true, data: result.value as T };
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
/**
|
|
107
|
-
* Format validation issues into a readable error message.
|
|
108
|
-
*
|
|
109
|
-
* @param issues - Array of validation issues
|
|
110
|
-
* @returns Formatted error message
|
|
111
|
-
*/
|
|
112
|
-
export function formatValidationIssues(issues: StandardSchemaV1.Issue[]): string {
|
|
113
|
-
return issues
|
|
114
|
-
.map((issue) => {
|
|
115
|
-
const path = issue.path?.map((p) => (typeof p === 'object' ? p.key : p)).join('.') || '';
|
|
116
|
-
return path ? `${path}: ${issue.message}` : issue.message;
|
|
117
|
-
})
|
|
118
|
-
.join(', ');
|
|
119
|
-
}
|
package/src/_waituntil.ts
DELETED
|
@@ -1,188 +0,0 @@
|
|
|
1
|
-
import { context, SpanStatusCode, type Tracer, trace } from '@opentelemetry/api';
|
|
2
|
-
import type { Logger } from './logger';
|
|
3
|
-
import { internal } from './logger/internal';
|
|
4
|
-
import { StructuredError } from '@agentuity/core';
|
|
5
|
-
|
|
6
|
-
let running = 0;
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* returns true if wait until is pending
|
|
10
|
-
* @returns boolean
|
|
11
|
-
*/
|
|
12
|
-
export function hasWaitUntilPending(): boolean {
|
|
13
|
-
internal.debug('hasWaitUntilPending called: %d', running);
|
|
14
|
-
return running > 0;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
const WaitUntilInvalidStateError = StructuredError(
|
|
18
|
-
'WaitUntilInvalidStateError',
|
|
19
|
-
'waitUntil cannot be called after waitUntilAll has been called'
|
|
20
|
-
);
|
|
21
|
-
|
|
22
|
-
const WaitUntilAllInvalidStateError = StructuredError(
|
|
23
|
-
'WaitUntilAllInvalidStateError',
|
|
24
|
-
'waitUntilAll can only be called once per instance'
|
|
25
|
-
);
|
|
26
|
-
|
|
27
|
-
export default class WaitUntilHandler {
|
|
28
|
-
private promises: Promise<void>[];
|
|
29
|
-
private tracer: Tracer;
|
|
30
|
-
private started: number | undefined;
|
|
31
|
-
private hasCalledWaitUntilAll = false;
|
|
32
|
-
|
|
33
|
-
public constructor(tracer: Tracer) {
|
|
34
|
-
this.tracer = tracer;
|
|
35
|
-
this.promises = [];
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
public waitUntil(
|
|
39
|
-
promise: Promise<void> | (() => void | Promise<void>),
|
|
40
|
-
options?: { noSpan?: boolean }
|
|
41
|
-
): void {
|
|
42
|
-
if (this.hasCalledWaitUntilAll) {
|
|
43
|
-
throw new WaitUntilInvalidStateError();
|
|
44
|
-
}
|
|
45
|
-
running++;
|
|
46
|
-
internal.debug('wait until called, running: %d', running);
|
|
47
|
-
const currentContext = context.active();
|
|
48
|
-
const skipSpan = options?.noSpan === true;
|
|
49
|
-
|
|
50
|
-
// Start execution immediately, don't defer it
|
|
51
|
-
const executingPromise = (async () => {
|
|
52
|
-
if (this.started === undefined) {
|
|
53
|
-
this.started = Date.now(); /// this first execution marks the start time
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
try {
|
|
57
|
-
if (skipSpan) {
|
|
58
|
-
// Execute without creating a span (used for coordination tasks)
|
|
59
|
-
// Still propagate context so downstream async operations inherit the original context
|
|
60
|
-
try {
|
|
61
|
-
internal.debug('starting waituntil (no span)');
|
|
62
|
-
await context.with(currentContext, async () => {
|
|
63
|
-
const resolvedPromise = typeof promise === 'function' ? promise() : promise;
|
|
64
|
-
return await Promise.resolve(resolvedPromise);
|
|
65
|
-
});
|
|
66
|
-
internal.debug('completed waituntil (no span)');
|
|
67
|
-
} catch (ex: unknown) {
|
|
68
|
-
// Log the error but don't re-throw - background tasks should never crash the server
|
|
69
|
-
internal.error('Background task error: %s', ex);
|
|
70
|
-
}
|
|
71
|
-
} else {
|
|
72
|
-
// Execute with a span (default behavior)
|
|
73
|
-
const span = this.tracer.startSpan('waitUntil', {}, currentContext);
|
|
74
|
-
const spanContext = trace.setSpan(currentContext, span);
|
|
75
|
-
try {
|
|
76
|
-
internal.debug('starting waituntil');
|
|
77
|
-
await context.with(spanContext, async () => {
|
|
78
|
-
const resolvedPromise = typeof promise === 'function' ? promise() : promise;
|
|
79
|
-
return await Promise.resolve(resolvedPromise);
|
|
80
|
-
});
|
|
81
|
-
internal.debug('completed waituntil');
|
|
82
|
-
span.setStatus({ code: SpanStatusCode.OK });
|
|
83
|
-
} catch (ex: unknown) {
|
|
84
|
-
span.recordException(ex as Error);
|
|
85
|
-
span.setStatus({ code: SpanStatusCode.ERROR });
|
|
86
|
-
// Log the error but don't re-throw - background tasks should never crash the server
|
|
87
|
-
internal.error('Background task error: %s', ex);
|
|
88
|
-
} finally {
|
|
89
|
-
span.end();
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
} finally {
|
|
93
|
-
// Decrement running counter when promise completes (success or failure)
|
|
94
|
-
running--;
|
|
95
|
-
internal.debug('waituntil completed, running: %d', running);
|
|
96
|
-
}
|
|
97
|
-
})();
|
|
98
|
-
|
|
99
|
-
// Store the executing promise for cleanup tracking
|
|
100
|
-
this.promises.push(executingPromise);
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
public hasPending(): boolean {
|
|
104
|
-
return this.promises.length > 0;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
/**
|
|
108
|
-
* Returns a snapshot of currently pending promises.
|
|
109
|
-
* This allows waiting for specific promises without including promises added later.
|
|
110
|
-
* Useful to avoid deadlock when the caller will add their own promise via waitUntil.
|
|
111
|
-
*/
|
|
112
|
-
public getPendingSnapshot(): Promise<void>[] {
|
|
113
|
-
return [...this.promises];
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
/**
|
|
117
|
-
* Wait for a specific set of promises to complete.
|
|
118
|
-
* Unlike waitUntilAll, this doesn't mark the handler as "all called" and
|
|
119
|
-
* allows additional waitUntil calls afterward.
|
|
120
|
-
*/
|
|
121
|
-
public async waitForPromises(
|
|
122
|
-
promises: Promise<void>[],
|
|
123
|
-
logger: Logger,
|
|
124
|
-
sessionId: string
|
|
125
|
-
): Promise<void> {
|
|
126
|
-
if (promises.length === 0) {
|
|
127
|
-
internal.debug('No promises to wait for in snapshot');
|
|
128
|
-
return;
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
internal.debug(
|
|
132
|
-
`⏳ Waiting for ${promises.length} snapshot promises to complete (session: ${sessionId})...`
|
|
133
|
-
);
|
|
134
|
-
try {
|
|
135
|
-
const results = await Promise.allSettled(promises);
|
|
136
|
-
|
|
137
|
-
// Log any failures
|
|
138
|
-
const failures = results.filter((r) => r.status === 'rejected');
|
|
139
|
-
if (failures.length > 0) {
|
|
140
|
-
logger.error('%d background task(s) failed during execution', failures.length);
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
internal.debug('✅ Snapshot promises completed (session: %s)', sessionId);
|
|
144
|
-
} catch (ex) {
|
|
145
|
-
logger.error('error waiting for snapshot promises', ex);
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
public async waitUntilAll(logger: Logger, sessionId: string): Promise<void> {
|
|
150
|
-
internal.debug(`🔍 waitUntilAll() called for session ${sessionId} (count: %d)`, running);
|
|
151
|
-
|
|
152
|
-
if (this.hasCalledWaitUntilAll) {
|
|
153
|
-
throw new WaitUntilAllInvalidStateError();
|
|
154
|
-
}
|
|
155
|
-
this.hasCalledWaitUntilAll = true;
|
|
156
|
-
|
|
157
|
-
if (this.promises.length === 0) {
|
|
158
|
-
internal.debug('No promises to wait for, executing evals directly');
|
|
159
|
-
// await this.executeEvalsForSession(logger, sessionId);
|
|
160
|
-
return;
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
internal.debug(`⏳ Waiting for ${this.promises.length} promises to complete...`);
|
|
164
|
-
try {
|
|
165
|
-
// Promises are already executing, just wait for them to complete
|
|
166
|
-
// Use allSettled so one failing promise doesn't stop others
|
|
167
|
-
const results = await Promise.allSettled(this.promises);
|
|
168
|
-
const duration = Date.now() - (this.started as number);
|
|
169
|
-
|
|
170
|
-
// Log any failures
|
|
171
|
-
const failures = results.filter((r) => r.status === 'rejected');
|
|
172
|
-
if (failures.length > 0) {
|
|
173
|
-
logger.error('%d background task(s) failed during execution', failures.length);
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
internal.debug(
|
|
177
|
-
'✅ All promises completed, marking session completed (duration %dms)',
|
|
178
|
-
duration
|
|
179
|
-
);
|
|
180
|
-
} catch (ex) {
|
|
181
|
-
logger.error('error sending session completed', ex);
|
|
182
|
-
} finally {
|
|
183
|
-
// Note: running counter is decremented by each promise when it completes,
|
|
184
|
-
// so we don't decrement here. Just clear the array.
|
|
185
|
-
this.promises.length = 0;
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
}
|