@circuitwall/jarela 0.14.0 → 1.0.0
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/.next/standalone/.next/BUILD_ID +1 -1
- package/.next/standalone/.next/app-path-routes-manifest.json +1 -1
- package/.next/standalone/.next/build-manifest.json +2 -2
- package/.next/standalone/.next/prerender-manifest.json +3 -3
- package/.next/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/_global-error.html +1 -1
- package/.next/standalone/.next/server/app/_global-error.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/_not-found.html +2 -2
- package/.next/standalone/.next/server/app/_not-found.rsc +2 -2
- package/.next/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/api/v1/agents/[id]/route.js +6 -1
- package/.next/standalone/.next/server/app/api/v1/agents/[id]/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/agents/route.js +6 -1
- package/.next/standalone/.next/server/app/api/v1/agents/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/bridges/[id]/route.js +9 -1
- package/.next/standalone/.next/server/app/api/v1/bridges/[id]/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/bridges/route.js +9 -1
- package/.next/standalone/.next/server/app/api/v1/bridges/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/builtin-tools/route.js +36 -29
- package/.next/standalone/.next/server/app/api/v1/builtin-tools/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/events/route.js +7 -1
- package/.next/standalone/.next/server/app/api/v1/events/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/extensions/route.js +3 -3
- package/.next/standalone/.next/server/app/api/v1/extensions/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/extensions/tools/[name]/secrets/route.js +4 -4
- package/.next/standalone/.next/server/app/api/v1/extensions/tools/[name]/secrets/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/health/route.js +7 -1
- package/.next/standalone/.next/server/app/api/v1/health/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/mcp-servers/[name]/route.js +9 -1
- package/.next/standalone/.next/server/app/api/v1/mcp-servers/[name]/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/mcp-servers/route.js +9 -1
- package/.next/standalone/.next/server/app/api/v1/mcp-servers/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/models/route.js +6 -1
- package/.next/standalone/.next/server/app/api/v1/models/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/page-capture/route.js +7 -1
- package/.next/standalone/.next/server/app/api/v1/page-capture/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/pending-actions/[id]/approve/route.js +14 -7
- package/.next/standalone/.next/server/app/api/v1/pending-actions/[id]/approve/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/providers/[provider]/models/route.js +28 -0
- package/.next/standalone/.next/server/app/api/v1/providers/[provider]/models/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/providers/route.js +7 -1
- package/.next/standalone/.next/server/app/api/v1/providers/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/threads/[thread_id]/route.js +16 -2
- package/.next/standalone/.next/server/app/api/v1/threads/[thread_id]/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/threads/[thread_id]/run/route.js +8 -1
- package/.next/standalone/.next/server/app/api/v1/threads/[thread_id]/run/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/threads/route.js +6 -1
- package/.next/standalone/.next/server/app/api/v1/threads/route.js.map +1 -1
- package/.next/standalone/.next/server/app/api/v1/tools/route.js +10 -3
- package/.next/standalone/.next/server/app/api/v1/tools/route.js.map +1 -1
- package/.next/standalone/.next/server/app/index.html +2 -2
- package/.next/standalone/.next/server/app/index.rsc +3 -3
- package/.next/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/index.segments/_full.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/index.segments/_index.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/index.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/page.js +56 -0
- package/.next/standalone/.next/server/app/page.js.map +1 -1
- package/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/setup/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/setup.html +1 -1
- package/.next/standalone/.next/server/app/setup.rsc +2 -2
- package/.next/standalone/.next/server/app/setup.segments/_full.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/setup.segments/_head.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/setup.segments/_index.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/setup.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/setup.segments/setup/__PAGE__.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/setup.segments/setup.segment.rsc +1 -1
- package/.next/standalone/.next/server/app-paths-manifest.json +1 -1
- package/.next/standalone/.next/server/chunks/1683.js +2 -2
- package/.next/standalone/.next/server/chunks/2082.js +122 -13
- package/.next/standalone/.next/server/chunks/2082.js.map +1 -1
- package/.next/standalone/.next/server/chunks/210.js +3 -3
- package/.next/standalone/.next/server/chunks/210.js.map +1 -1
- package/.next/standalone/.next/server/chunks/239.js +1902 -1487
- package/.next/standalone/.next/server/chunks/239.js.map +1 -1
- package/.next/standalone/.next/server/chunks/2447.js +9 -1
- package/.next/standalone/.next/server/chunks/2447.js.map +1 -1
- package/.next/standalone/.next/server/chunks/423.js +125 -16
- package/.next/standalone/.next/server/chunks/423.js.map +1 -1
- package/.next/standalone/.next/server/chunks/4631.js +36 -29
- package/.next/standalone/.next/server/chunks/4631.js.map +1 -1
- package/.next/standalone/.next/server/chunks/5937.js +3 -2
- package/.next/standalone/.next/server/chunks/5937.js.map +1 -1
- package/.next/standalone/.next/server/chunks/{947.js → 8866.js} +11321 -10883
- package/.next/standalone/.next/server/chunks/8866.js.map +1 -0
- package/.next/standalone/.next/server/chunks/9032.js +3 -3
- package/.next/standalone/.next/server/chunks/9032.js.map +1 -1
- package/.next/standalone/.next/server/middleware-build-manifest.js +2 -2
- package/.next/standalone/.next/server/middleware.js +122 -13
- package/.next/standalone/.next/server/pages/404.html +2 -2
- package/.next/standalone/.next/server/pages/500.html +1 -1
- package/.next/standalone/.next/server/proxy.js.map +1 -1
- package/.next/standalone/.next/server/server-reference-manifest.json +1 -1
- package/.next/standalone/.next/static/chunks/app/{page-473b39ec30c7f569.js → page-a7cae65f235e2942.js} +57 -1
- package/.next/standalone/.next/static/chunks/app/page-a7cae65f235e2942.js.map +1 -0
- package/.next/standalone/.next/static/css/{6f8b1a84bcbcd467.css → e57bdbbbb5a05779.css} +2 -2
- package/.next/standalone/.next/static/css/e57bdbbbb5a05779.css.map +1 -0
- package/.next/standalone/package.json +9 -1
- package/CHANGELOG.md +90 -0
- package/README.md +30 -2
- package/api/types.ts +8 -0
- package/app/api/v1/agents/[id]/route.ts +7 -0
- package/app/api/v1/agents/route.ts +7 -0
- package/app/api/v1/events/route.ts +8 -0
- package/app/api/v1/extensions/route.ts +2 -2
- package/app/api/v1/extensions/tools/[name]/secrets/route.ts +3 -3
- package/app/api/v1/health/route.ts +8 -0
- package/app/api/v1/models/route.ts +7 -0
- package/app/api/v1/page-capture/route.ts +8 -0
- package/app/api/v1/providers/route.ts +8 -0
- package/app/api/v1/threads/[thread_id]/route.ts +8 -0
- package/app/api/v1/threads/[thread_id]/run/route.ts +9 -0
- package/app/api/v1/threads/route.ts +7 -0
- package/app/api/v1/tools/route.ts +9 -0
- package/components/chat/ContextUsageBar.tsx +44 -0
- package/lib/agents/llm.ts +25 -2
- package/lib/agents/run-thread.ts +13 -1
- package/lib/agents/stream-collector.ts +9 -1
- package/lib/api/serializers.test.ts +15 -0
- package/lib/api/serializers.ts +8 -0
- package/lib/db/migrations.ts +15 -0
- package/lib/health/runner.test.ts +24 -2
- package/lib/mcp/registry.ts +14 -6
- package/lib/providers/anthropic.test.ts +95 -0
- package/lib/providers/anthropic.ts +106 -10
- package/lib/providers/jarela-chat-model.ts +9 -1
- package/lib/providers/known-context-windows.ts +21 -0
- package/lib/providers/types.ts +21 -1
- package/lib/stores/message-usage.test.ts +34 -0
- package/lib/stores/message-usage.ts +15 -3
- package/lib/stores/pricing.test.ts +52 -0
- package/lib/stores/pricing.ts +26 -1
- package/lib/tools/builtins.ts +4 -0
- package/lib/tools/extension-surfaces.test.ts +79 -0
- package/lib/tools/extension-surfaces.ts +153 -0
- package/lib/tools/index.ts +27 -8
- package/lib/tools/list-tools.test.ts +76 -0
- package/lib/tools/list-tools.ts +84 -0
- package/lib/tools/mcp-servers-info.test.ts +73 -0
- package/lib/tools/mcp-servers-info.ts +71 -0
- package/lib/tools/providers-info.test.ts +73 -0
- package/lib/tools/providers-info.ts +106 -0
- package/lib/tools/registry.ts +36 -25
- package/lib/tools/types.ts +13 -0
- package/package.json +9 -1
- package/.next/standalone/.next/server/chunks/947.js.map +0 -1
- package/.next/standalone/.next/static/chunks/app/page-473b39ec30c7f569.js.map +0 -1
- package/.next/standalone/.next/static/css/6f8b1a84bcbcd467.css.map +0 -1
- /package/.next/standalone/.next/static/{T0p2VVPsJPj44rwbmjaFb → d_vhp-lJqfdjRFpnLVIqZ}/_buildManifest.js +0 -0
- /package/.next/standalone/.next/static/{T0p2VVPsJPj44rwbmjaFb → d_vhp-lJqfdjRFpnLVIqZ}/_ssgManifest.js +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"node":{},"edge":{},"encryptionKey":"
|
|
1
|
+
{"node":{},"edge":{},"encryptionKey":"ubPhx7uFx+LHNqC9dnHYxShQQMb39nMQGziRbWhUdww="}
|
|
@@ -2177,6 +2177,14 @@ function fmtTokens(n) {
|
|
|
2177
2177
|
const warmUsed = usage.warm_tokens;
|
|
2178
2178
|
const factsUsed = usage.facts_tokens;
|
|
2179
2179
|
const overheadUsed = usage.overhead_tokens;
|
|
2180
|
+
// Anthropic prompt-cache breakdown (ADR-0062). Disjoint from
|
|
2181
|
+
// hot/warm/facts/overhead: those tiers count fresh input, while these
|
|
2182
|
+
// count tokens served from / written to the prompt cache. Surface them
|
|
2183
|
+
// in the tooltip and expanded panel so the user can see when caching
|
|
2184
|
+
// is firing for this turn.
|
|
2185
|
+
const cacheRead = usage.cache_read_input_tokens ?? 0;
|
|
2186
|
+
const cacheCreation = usage.cache_creation_input_tokens ?? 0;
|
|
2187
|
+
const cacheActive = cacheRead > 0 || cacheCreation > 0;
|
|
2180
2188
|
// Overhead's "budget" is whatever it actually consumed — there's no slider
|
|
2181
2189
|
// for it. Shown as a fixed-size segment so it doesn't visually compete
|
|
2182
2190
|
// with the tunable tiers.
|
|
@@ -2196,6 +2204,11 @@ function fmtTokens(n) {
|
|
|
2196
2204
|
`Context window: ${cap.toLocaleString()} tokens (the model's full capacity)`,
|
|
2197
2205
|
`This turn's prompt used ${(hotUsed + warmUsed + factsUsed + overheadUsed).toLocaleString()} tokens`,
|
|
2198
2206
|
`Reply generated: ${usage.output_tokens.toLocaleString()} tokens`,
|
|
2207
|
+
...cacheActive ? [
|
|
2208
|
+
"",
|
|
2209
|
+
`Prompt cache: ${cacheRead.toLocaleString()} read · ${cacheCreation.toLocaleString()} written`,
|
|
2210
|
+
"(cache reads bill at 0.1× input, writes at 1.25×)"
|
|
2211
|
+
] : [],
|
|
2199
2212
|
"",
|
|
2200
2213
|
"Each coloured slot's width = budget for that tier; filled portion = actually used.",
|
|
2201
2214
|
"Red = tier overflowed its budget. Grey tail = headroom reserved for the reply.",
|
|
@@ -2247,6 +2260,30 @@ function fmtTokens(n) {
|
|
|
2247
2260
|
]
|
|
2248
2261
|
})
|
|
2249
2262
|
}),
|
|
2263
|
+
cacheActive && !showDetails && /*#__PURE__*/ (0,jsx_runtime.jsxs)("div", {
|
|
2264
|
+
className: "mt-0.5 px-2 text-[10px] text-violet-500/80",
|
|
2265
|
+
title: [
|
|
2266
|
+
"Prompt cache (ADR-0062). Reads bill at 0.1× input, writes at 1.25×.",
|
|
2267
|
+
cacheRead > 0 ? `${cacheRead.toLocaleString()} tokens served from cache.` : "",
|
|
2268
|
+
cacheCreation > 0 ? `${cacheCreation.toLocaleString()} tokens written to cache.` : ""
|
|
2269
|
+
].filter(Boolean).join("\n"),
|
|
2270
|
+
children: [
|
|
2271
|
+
cacheRead > 0 && /*#__PURE__*/ (0,jsx_runtime.jsxs)(jsx_runtime.Fragment, {
|
|
2272
|
+
children: [
|
|
2273
|
+
"cache hit \xb7 ",
|
|
2274
|
+
fmtTokens(cacheRead),
|
|
2275
|
+
" read"
|
|
2276
|
+
]
|
|
2277
|
+
}),
|
|
2278
|
+
cacheRead > 0 && cacheCreation > 0 && " · ",
|
|
2279
|
+
cacheCreation > 0 && /*#__PURE__*/ (0,jsx_runtime.jsxs)(jsx_runtime.Fragment, {
|
|
2280
|
+
children: [
|
|
2281
|
+
"cache write \xb7 ",
|
|
2282
|
+
fmtTokens(cacheCreation)
|
|
2283
|
+
]
|
|
2284
|
+
})
|
|
2285
|
+
]
|
|
2286
|
+
}),
|
|
2250
2287
|
showDetails && /*#__PURE__*/ (0,jsx_runtime.jsxs)("div", {
|
|
2251
2288
|
className: "mt-1 px-2 pb-1 grid grid-cols-2 gap-x-3 gap-y-0.5 text-[10px] text-fg-faint",
|
|
2252
2289
|
children: [
|
|
@@ -2278,6 +2315,25 @@ function fmtTokens(n) {
|
|
|
2278
2315
|
budget: overheadUsed,
|
|
2279
2316
|
hint: "System prompt + per-message scaffolding"
|
|
2280
2317
|
}),
|
|
2318
|
+
cacheActive && /*#__PURE__*/ (0,jsx_runtime.jsxs)("span", {
|
|
2319
|
+
className: "col-span-2 text-violet-500",
|
|
2320
|
+
title: [
|
|
2321
|
+
"Prompt cache (ADR-0062). Disjoint from the tiers above.",
|
|
2322
|
+
`Read ${cacheRead.toLocaleString()} tokens — billed at 0.1× input rate.`,
|
|
2323
|
+
`Wrote ${cacheCreation.toLocaleString()} tokens — billed at 1.25× input rate.`,
|
|
2324
|
+
"Reads pay off on subsequent turns; writes are an investment."
|
|
2325
|
+
].join("\n"),
|
|
2326
|
+
children: [
|
|
2327
|
+
/*#__PURE__*/ (0,jsx_runtime.jsx)("span", {
|
|
2328
|
+
className: "text-violet-500",
|
|
2329
|
+
children: "Cache"
|
|
2330
|
+
}),
|
|
2331
|
+
" ",
|
|
2332
|
+
"read ",
|
|
2333
|
+
fmtTokens(cacheRead),
|
|
2334
|
+
cacheCreation > 0 ? ` · created ${fmtTokens(cacheCreation)}` : ""
|
|
2335
|
+
]
|
|
2336
|
+
}),
|
|
2281
2337
|
/*#__PURE__*/ (0,jsx_runtime.jsxs)("span", {
|
|
2282
2338
|
className: "col-span-2 mt-0.5 border-t border-border pt-0.5",
|
|
2283
2339
|
title: `Output: tokens the model generated in its reply.\nWindow: total context capacity of this model.`,
|
|
@@ -23376,4 +23432,4 @@ Promise.resolve(/* import() eager */).then(__webpack_require__.bind(__webpack_re
|
|
|
23376
23432
|
/******/ _N_E = __webpack_exports__;
|
|
23377
23433
|
/******/ }
|
|
23378
23434
|
]);
|
|
23379
|
-
//# sourceMappingURL=page-
|
|
23435
|
+
//# sourceMappingURL=page-a7cae65f235e2942.js.map
|