@portel/photon 1.34.0 → 1.34.2
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/README.md +20 -6
- package/dist/auto-ui/beam/routes/api-browse.d.ts.map +1 -1
- package/dist/auto-ui/beam/routes/api-browse.js +92 -15
- package/dist/auto-ui/beam/routes/api-browse.js.map +1 -1
- package/dist/auto-ui/beam/routes/api-config.d.ts.map +1 -1
- package/dist/auto-ui/beam/routes/api-config.js +16 -7
- package/dist/auto-ui/beam/routes/api-config.js.map +1 -1
- package/dist/auto-ui/beam/routes/api-marketplace.js +4 -4
- package/dist/auto-ui/beam/routes/api-marketplace.js.map +1 -1
- package/dist/auto-ui/beam.d.ts.map +1 -1
- package/dist/auto-ui/beam.js +21 -2
- package/dist/auto-ui/beam.js.map +1 -1
- package/dist/auto-ui/streamable-http-transport.d.ts.map +1 -1
- package/dist/auto-ui/streamable-http-transport.js +56 -2
- package/dist/auto-ui/streamable-http-transport.js.map +1 -1
- package/dist/beam.bundle.js +47 -0
- package/dist/beam.bundle.js.map +2 -2
- package/dist/daemon/server.js +57 -13
- package/dist/daemon/server.js.map +1 -1
- package/dist/daemon/session-manager.d.ts +2 -1
- package/dist/daemon/session-manager.d.ts.map +1 -1
- package/dist/daemon/session-manager.js +33 -2
- package/dist/daemon/session-manager.js.map +1 -1
- package/dist/serv/auth/http-adapter.d.ts.map +1 -1
- package/dist/serv/auth/http-adapter.js +7 -2
- package/dist/serv/auth/http-adapter.js.map +1 -1
- package/dist/server.d.ts.map +1 -1
- package/dist/server.js +15 -2
- package/dist/server.js.map +1 -1
- package/package.json +4 -3
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"streamable-http-transport.d.ts","sourceRoot":"","sources":["../../src/auto-ui/streamable-http-transport.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AAuBjF,OAAO,KAAK,EACV,cAAc,EAMd,aAAa,EACb,cAAc,EACd,eAAe,EAChB,MAAM,YAAY,CAAC;AAuJpB,UAAU,UAAU;IAClB,EAAE,EAAE,MAAM,CAAC;IACX,WAAW,EAAE,OAAO,CAAC;IACrB,SAAS,EAAE,IAAI,CAAC;IAChB,YAAY,EAAE,IAAI,CAAC;IACnB,WAAW,CAAC,EAAE,cAAc,CAAC;IAC7B,WAAW,CAAC,EAAE,IAAI,CAAC;IACnB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,UAAU,CAAC,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IAC/C,kBAAkB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC7C,aAAa,CAAC,EAAE,aAAa,CAAC;IAC9B,sDAAsD;IACtD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB;;;;;OAKG;IACH,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,MAAM,eAAe,GAAG,mBAAmB,GAAG,WAAW,CAAC;AAEhE,MAAM,WAAW,aAAa;IAC5B,eAAe,EAAE,MAAM,CAAC;IACxB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,IAAI,EAAE,eAAe,CAAC;IACtB,YAAY,EAAE;QACZ,KAAK,EAAE,OAAO,CAAC;QACf,OAAO,EAAE,OAAO,CAAC;QACjB,SAAS,EAAE,OAAO,CAAC;QACnB,QAAQ,EAAE,OAAO,CAAC;QAClB,OAAO,EAAE,OAAO,CAAC;QACjB,KAAK,EAAE,MAAM,GAAG,aAAa,GAAG,WAAW,CAAC;QAC5C,aAAa,EAAE,OAAO,CAAC;KACxB,CAAC;IACF,MAAM,EAAE;QACN,qBAAqB,EAAE,OAAO,CAAC;QAC/B,wBAAwB,EAAE,OAAO,CAAC;QAClC,oCAAoC,EAAE,OAAO,CAAC;KAC/C,CAAC;CACH;AAED,MAAM,WAAW,oBAAoB;IACnC,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC5B,eAAe,EAAE,MAAM,CAAC;IACxB,SAAS,EAAE,iBAAiB,CAAC;IAC7B,MAAM,EAAE,aAAa,CAAC;IACtB,MAAM,CAAC,EAAE,UAAU,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,wBAAwB,CAAC,EAAE,MAAM,CAAC;IAClC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,gBAAgB,EACZ,eAAe,GACf,mBAAmB,GACnB,QAAQ,GACR,oBAAoB,GACpB,gBAAgB,GAChB,mBAAmB,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAiHD,iBAAS,oBAAoB,CAC3B,OAAO,EAAE,cAAc,GAAG,SAAS,EACnC,OAAO,EAAE,UAAU,EACnB,OAAO,EAAE,mBAAmB,GAC3B,aAAa,CAgFf;AAED,iBAAS,2BAA2B,CAAC,KAAK,EAAE;IAC1C,OAAO,EAAE,cAAc,CAAC;IACxB,OAAO,EAAE,UAAU,CAAC;IACpB,OAAO,EAAE,mBAAmB,CAAC;IAC7B,MAAM,CAAC,EAAE,UAAU,CAAC;CACrB,GAAG,oBAAoB,CA4CvB;AAED,eAAO,MAAM,kCAAkC;;;CAG9C,CAAC;
|
|
1
|
+
{"version":3,"file":"streamable-http-transport.d.ts","sourceRoot":"","sources":["../../src/auto-ui/streamable-http-transport.ts"],"names":[],"mappings":"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"}
|
|
@@ -23,7 +23,7 @@ import { join, dirname, extname, resolve, normalize } from 'path';
|
|
|
23
23
|
import { homedir } from 'os';
|
|
24
24
|
import { PHOTON_VERSION } from '../version.js';
|
|
25
25
|
import { formatToolError } from '../shared/error-handler.js';
|
|
26
|
-
import { SimpleRateLimiter } from '../shared/security.js';
|
|
26
|
+
import { SimpleRateLimiter, getCorsOrigin } from '../shared/security.js';
|
|
27
27
|
// Default rate limit: 600 requests/min per source IP. Beam app UI opens several
|
|
28
28
|
// MCP sessions and can legitimately burst while navigating between photons.
|
|
29
29
|
// Override via
|
|
@@ -365,6 +365,51 @@ function splitNamespacedToolName(name) {
|
|
|
365
365
|
const sessions = new Map();
|
|
366
366
|
const MAX_SSE_SESSIONS_PER_CLIENT = Math.max(4, Number.parseInt(process.env.PHOTON_MAX_SSE_SESSIONS_PER_CLIENT || '12', 10) || 12);
|
|
367
367
|
const pendingElicitations = new Map();
|
|
368
|
+
const SECRET_PREVIEW_KEY_RE = /pass(word)?|secret|token|api[-_]?key|credential|cookie|authorization|bearer|private[-_]?key/i;
|
|
369
|
+
const MAX_PREVIEW_DEPTH = 4;
|
|
370
|
+
const MAX_PREVIEW_ARRAY_ITEMS = 12;
|
|
371
|
+
const MAX_PREVIEW_OBJECT_KEYS = 40;
|
|
372
|
+
const MAX_PREVIEW_STRING_LENGTH = 500;
|
|
373
|
+
function buildSafeToolArgumentPreview(value, depth = 0) {
|
|
374
|
+
if (depth >= MAX_PREVIEW_DEPTH)
|
|
375
|
+
return '[truncated: depth]';
|
|
376
|
+
if (value == null)
|
|
377
|
+
return value;
|
|
378
|
+
if (typeof value === 'string') {
|
|
379
|
+
if (value.length <= MAX_PREVIEW_STRING_LENGTH)
|
|
380
|
+
return value;
|
|
381
|
+
return `${value.slice(0, MAX_PREVIEW_STRING_LENGTH)}... [truncated ${value.length - MAX_PREVIEW_STRING_LENGTH} chars]`;
|
|
382
|
+
}
|
|
383
|
+
if (typeof value === 'number' || typeof value === 'boolean')
|
|
384
|
+
return value;
|
|
385
|
+
if (typeof value === 'bigint')
|
|
386
|
+
return value.toString();
|
|
387
|
+
if (value instanceof Date)
|
|
388
|
+
return value.toISOString();
|
|
389
|
+
if (Array.isArray(value)) {
|
|
390
|
+
const items = value
|
|
391
|
+
.slice(0, MAX_PREVIEW_ARRAY_ITEMS)
|
|
392
|
+
.map((item) => buildSafeToolArgumentPreview(item, depth + 1));
|
|
393
|
+
if (value.length > MAX_PREVIEW_ARRAY_ITEMS) {
|
|
394
|
+
items.push(`[truncated ${value.length - MAX_PREVIEW_ARRAY_ITEMS} items]`);
|
|
395
|
+
}
|
|
396
|
+
return items;
|
|
397
|
+
}
|
|
398
|
+
if (typeof value === 'object') {
|
|
399
|
+
const out = {};
|
|
400
|
+
const entries = Object.entries(value);
|
|
401
|
+
for (const [key, child] of entries.slice(0, MAX_PREVIEW_OBJECT_KEYS)) {
|
|
402
|
+
out[key] = SECRET_PREVIEW_KEY_RE.test(key)
|
|
403
|
+
? '[redacted]'
|
|
404
|
+
: buildSafeToolArgumentPreview(child, depth + 1);
|
|
405
|
+
}
|
|
406
|
+
if (entries.length > MAX_PREVIEW_OBJECT_KEYS) {
|
|
407
|
+
out.__truncated__ = `${entries.length - MAX_PREVIEW_OBJECT_KEYS} keys`;
|
|
408
|
+
}
|
|
409
|
+
return out;
|
|
410
|
+
}
|
|
411
|
+
return `[${typeof value}]`;
|
|
412
|
+
}
|
|
368
413
|
const pendingServerRequests = new Map();
|
|
369
414
|
let nextServerRequestId = 1;
|
|
370
415
|
/**
|
|
@@ -2013,6 +2058,13 @@ const handlers = {
|
|
|
2013
2058
|
methodName,
|
|
2014
2059
|
methodTitle: methodInfo.title || methodInfo.name,
|
|
2015
2060
|
risk: 'destructive',
|
|
2061
|
+
_meta: {
|
|
2062
|
+
toolCall: {
|
|
2063
|
+
photon: photonName,
|
|
2064
|
+
method: methodName,
|
|
2065
|
+
argumentPreview: buildSafeToolArgumentPreview(args || {}),
|
|
2066
|
+
},
|
|
2067
|
+
},
|
|
2016
2068
|
}, { photonName: serverName, methodName });
|
|
2017
2069
|
if (elicitResult.action !== 'accept' || elicitResult.content === false) {
|
|
2018
2070
|
return {
|
|
@@ -4331,7 +4383,9 @@ export async function handleStreamableHTTP(req, res, options) {
|
|
|
4331
4383
|
return false;
|
|
4332
4384
|
}
|
|
4333
4385
|
// CORS headers
|
|
4334
|
-
|
|
4386
|
+
const corsOrigin = getCorsOrigin(req);
|
|
4387
|
+
if (corsOrigin)
|
|
4388
|
+
res.setHeader('Access-Control-Allow-Origin', corsOrigin);
|
|
4335
4389
|
res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS');
|
|
4336
4390
|
res.setHeader('Access-Control-Allow-Headers', [
|
|
4337
4391
|
'Content-Type',
|