@directive-run/ai 1.12.0 → 1.13.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/dist/anthropic.cjs +1 -1
- package/dist/anthropic.js +1 -1
- package/dist/anthropic.js.map +1 -1
- package/dist/chunk-3WO4MWJM.cjs +3 -0
- package/dist/chunk-3WO4MWJM.cjs.map +1 -0
- package/dist/chunk-ZFLHWJ56.js +3 -0
- package/dist/chunk-ZFLHWJ56.js.map +1 -0
- package/dist/gemini.cjs +1 -1
- package/dist/gemini.js +1 -1
- package/dist/gemini.js.map +1 -1
- package/dist/index.cjs +45 -45
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +207 -9
- package/dist/index.d.ts +207 -9
- package/dist/index.js +45 -45
- package/dist/index.js.map +1 -1
- package/dist/ollama.cjs +1 -1
- package/dist/ollama.js +2 -2
- package/dist/ollama.js.map +1 -1
- package/dist/openai.cjs +1 -1
- package/dist/openai.js +1 -1
- package/dist/openai.js.map +1 -1
- package/package.json +2 -2
- package/dist/chunk-W6MVJKWN.cjs +0 -3
- package/dist/chunk-W6MVJKWN.cjs.map +0 -1
- package/dist/chunk-W6WZBQER.js +0 -3
- package/dist/chunk-W6WZBQER.js.map +0 -1
package/dist/index.cjs
CHANGED
|
@@ -1,49 +1,49 @@
|
|
|
1
|
-
'use strict';var chunkXV2QSBBE_cjs=require('./chunk-XV2QSBBE.cjs'),
|
|
1
|
+
'use strict';var chunkXV2QSBBE_cjs=require('./chunk-XV2QSBBE.cjs'),chunk3WO4MWJM_cjs=require('./chunk-3WO4MWJM.cjs'),chunkX3VQ5F7D_cjs=require('./chunk-X3VQ5F7D.cjs'),internals=require('@directive-run/core/internals'),plugins=require('@directive-run/core/plugins'),ie=require('path'),core=require('@directive-run/core');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var ie__default=/*#__PURE__*/_interopDefault(ie);function vn(t){let{patterns:e=[/\b\d{3}-\d{2}-\d{4}\b/g,/\b\d{16}\b/g,/\b[A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,}\b/gi],redact:n=false,redactReplacement:o="[REDACTED]"}=t;return r=>{let s=r.input,a=false;for(let c of e)c.lastIndex=0,c.test(s)&&(a=true,n&&(c.lastIndex=0,s=s.replace(c,o)));return a&&!n?{passed:false,reason:"Input contains PII"}:{passed:true,transformed:n&&a?s:void 0}}}function Sn(t){let{checkFn:e,message:n="Content flagged by moderation"}=t;return async o=>{let r="output"in o?typeof o.output=="string"?o.output:JSON.stringify(o.output):o.input,s=await e(r);return {passed:!s,reason:s?n:void 0}}}function En(t){let{maxTokensPerMinute:e=1e5,maxRequestsPerMinute:n=60}=t,o=Math.max(n,1e3),r=[],s=[],a=6e4;function c(u,l){let p=0,d=u.length;for(;p<d;){let f=p+d>>>1;(u[f]??0)<l?p=f+1:d=f;}return p}let i=(u,l)=>{let p=Date.now(),d=p-a,f=c(r,d);f>0&&(r=r.slice(f));let y=c(s,d);y>0&&(s=s.slice(y));let h=l.facts[chunkX3VQ5F7D_cjs.c]?.tokenUsage??0,g=r.length,v=s.length;return g+h>e?{passed:false,reason:"Token rate limit exceeded"}:v>=n?{passed:false,reason:"Request rate limit exceeded"}:(s.length<o&&s.push(p),r.length<o&&r.push(p),{passed:true})};return i.reset=()=>{r=[],s=[];},i}function wn(t){let{allowlist:e,denylist:n,caseSensitive:o=false}=t,r=e?.map(a=>o?a:a.toLowerCase()),s=n?.map(a=>o?a:a.toLowerCase());return a=>{let c=o?a.toolCall.name:a.toolCall.name.toLowerCase();return r&&!r.includes(c)?{passed:false,reason:`Tool "${a.toolCall.name}" not in allowlist`}:s?.includes(c)?{passed:false,reason:`Tool "${a.toolCall.name}" is blocked`}:{passed:true}}}function Rn(t){let{validate:e,errorPrefix:n="Output schema validation failed"}=t;return o=>{let r=e(o.output);return typeof r=="boolean"?{passed:r,reason:r?void 0:n}:r.valid?{passed:true}:{passed:false,reason:r.errors?.length?`${n}: ${r.errors.join("; ")}`:n}}}function Cn(t){let{type:e,requiredFields:n=[],minLength:o,maxLength:r,minStringLength:s,maxStringLength:a}=t;return c=>{let i=c.output;switch(e){case "string":return typeof i!="string"?{passed:false,reason:`Expected string, got ${typeof i}`}:s!==void 0&&i.length<s?{passed:false,reason:`String too short: ${i.length} < ${s}`}:a!==void 0&&i.length>a?{passed:false,reason:`String too long: ${i.length} > ${a}`}:{passed:true};case "number":return typeof i!="number"||Number.isNaN(i)?{passed:false,reason:`Expected number, got ${typeof i}`}:{passed:true};case "boolean":return typeof i!="boolean"?{passed:false,reason:`Expected boolean, got ${typeof i}`}:{passed:true};case "object":if(typeof i!="object"||i===null||Array.isArray(i))return {passed:false,reason:`Expected object, got ${Array.isArray(i)?"array":typeof i}`};for(let u of n)if(!(u in i))return {passed:false,reason:`Missing required field: ${u}`};return {passed:true};case "array":return Array.isArray(i)?o!==void 0&&i.length<o?{passed:false,reason:`Array too short: ${i.length} < ${o}`}:r!==void 0&&i.length>r?{passed:false,reason:`Array too long: ${i.length} > ${r}`}:{passed:true}:{passed:false,reason:`Expected array, got ${typeof i}`};default:return {passed:false,reason:`Unknown type: ${e}`}}}}function An(t){let{maxCharacters:e,maxTokens:n,estimateTokens:o=r=>Math.ceil(r.length/4)}=t;return r=>{let s=internals.safeStringify(r.output);if(e!==void 0&&s.length>e)return {passed:false,reason:`Output too long: ${s.length} characters (max: ${e})`};if(n!==void 0){let a=o(s);if(a>n)return {passed:false,reason:`Output too long: ~${a} tokens (max: ${n})`}}return {passed:true}}}function xn(t){let{blockedPatterns:e,caseSensitive:n=false}=t;e.length===0&&console.warn("[Directive] createContentFilterGuardrail: blockedPatterns is empty \u2014 no content will be filtered");let o=e.map(r=>{if(r instanceof RegExp)return r;let s=r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");return new RegExp(s,n?"g":"gi")});return r=>{let s=internals.safeStringify(r.output);for(let a of o)if(a.lastIndex=0,a.test(s))return {passed:false,reason:`Output contains blocked content matching: ${a.source}`};return {passed:true}}}function Mn(t,...e){let n=t;for(let o of e)n=o(n);return n}function Y(t,e){let n=typeof t.content=="string"?t.content:JSON.stringify(t.content);return Math.ceil(n.length/4)}function he(t,e){return t.reduce((n,o)=>n+Y(o),0)}function ke(t={}){return (e,n={})=>{let o={...t,...n},r=o.maxMessages??100,s=o.preserveRecentCount??5;if(e.length<=r)return {keep:[...e],toSummarize:[],estimatedTokens:he(e)};let a=e.slice(-s),c=e.slice(0,-s),i=Math.max(0,r-s),u=c.slice(-i),l=c.slice(0,-i||void 0),p=[...u,...a];return {keep:p,toSummarize:l.length>0?l:[],estimatedTokens:he(p)}}}function Ie(t={}){return (e,n={})=>{let o={...t,...n},r=o.maxTokens??4e3,s=o.preserveRecentCount??5,a=o.countSystemMessages??true,c=e.slice(-s),i=e.slice(0,-s),u=c.reduce((f,y)=>!a&&y.role==="system"?f:f+Y(y),0),l=[],p=[],d=u;for(let f=i.length-1;f>=0;f--){let y=i[f],m=!a&&y.role==="system"?0:Y(y);if(d+m<=r)l.unshift(y),d+=m;else {p.push(...i.slice(0,f+1));break}}return {keep:[...l,...c],toSummarize:p,estimatedTokens:d}}}function Tn(t={}){let e=ke(t),n=Ie(t);return (o,r={})=>{let s={...t,...r},a=e(o,s),c=n(o,s);return a.keep.length<=c.keep.length?a:c}}function Pn(t){let{strategy:e,summarizer:n,strategyConfig:o={},autoManage:r=false,onMemoryManaged:s,onManageError:a,maxContextTokens:c}=t,i={messages:[],summaries:[],totalMessagesProcessed:0,estimatedTokens:0},u=false;async function l(){if(u)return {messagesBefore:i.messages.length,messagesAfter:i.messages.length,messagesSummarized:0,estimatedTokensBefore:i.estimatedTokens,estimatedTokensAfter:i.estimatedTokens};u=true;try{let d=i.messages.length,f=i.estimatedTokens,y=e(i.messages,o);if(y.toSummarize.length===0)return {messagesBefore:d,messagesAfter:d,messagesSummarized:0,estimatedTokensBefore:f,estimatedTokensAfter:y.estimatedTokens};let m;n&&y.toSummarize.length>0&&(m=await n(y.toSummarize),i.summaries.push({content:m,messagesCount:y.toSummarize.length,createdAt:Date.now()})),i.messages=y.keep,i.estimatedTokens=y.estimatedTokens;let S={messagesBefore:d,messagesAfter:i.messages.length,messagesSummarized:y.toSummarize.length,summary:m,estimatedTokensBefore:f,estimatedTokensAfter:y.estimatedTokens};return s?.(S),S}finally{u=false;}}function p(){if(u)return;e(i.messages,o).toSummarize.length>0&&l().catch(f=>{let y=f instanceof Error?f:new Error(String(f));a?a(y):console.error("[Directive Memory] Auto-manage error:",y);});}return {getState(){return {...i,messages:[...i.messages],summaries:i.summaries.map(d=>({...d}))}},addMessage(d){i.messages.push(d),i.totalMessagesProcessed++,i.estimatedTokens+=Y(d),r&&p();},addMessages(d){for(let f of d)i.messages.push(f),i.totalMessagesProcessed++,i.estimatedTokens+=Y(f);r&&p();},getContextMessages(){let d=[];if(i.summaries.length>0){let f=i.summaries.map(y=>y.content).join(`
|
|
2
2
|
|
|
3
3
|
---
|
|
4
4
|
|
|
5
5
|
`);d.push({role:"system",content:`[Previous conversation summary]
|
|
6
6
|
|
|
7
|
-
${
|
|
8
|
-
`);return
|
|
9
|
-
[truncated]`}}function
|
|
7
|
+
${f}`});}if(d.push(...i.messages),c){let f=he(d);f>c&&console.warn(`[Directive Memory] Context messages (${f} tokens) exceed maxContextTokens (${c}). Consider calling manage() or reducing message count.`);}return d},manage:l,isManaging(){return u},clear(){i={messages:[],summaries:[],totalMessagesProcessed:0,estimatedTokens:0};},export(){return {...i,messages:[...i.messages],summaries:i.summaries.map(d=>({...d}))}},import(d){i={...d,messages:[...d.messages],summaries:d.summaries.map(f=>({...f}))};}}}function kn(t=500){return async e=>{let n=e.filter(o=>o.role!=="system").map(o=>{let r=typeof o.content=="string"?o.content:JSON.stringify(o.content);return `${o.role}: ${r.slice(0,100)}${r.length>100?"...":""}`}).join(`
|
|
8
|
+
`);return n.length<=t?n:n.slice(0,t)+`
|
|
9
|
+
[truncated]`}}function In(){return async t=>{let e=[];for(let n of t)if(n.role==="user"){let r=(typeof n.content=="string"?n.content:JSON.stringify(n.content)).match(/[^.!?]*\?/g);r&&e.push(...r.map(s=>`Q: ${s.trim()}`));}return e.length===0?`[${t.length} messages processed - no key questions found]`:`Key topics discussed:
|
|
10
10
|
${e.join(`
|
|
11
|
-
`)}`}}function
|
|
11
|
+
`)}`}}function Dn(t,e={}){let{maxSummaryLength:n=500,preserveKeyFacts:o=true}=e;return async r=>{let s=r.filter(c=>c.role!=="system").map(c=>{let i=typeof c.content=="string"?c.content:JSON.stringify(c.content);return `${c.role.toUpperCase()}: ${i}`}).join(`
|
|
12
12
|
|
|
13
|
-
`),a=`Summarize the following conversation in ${
|
|
14
|
-
${
|
|
13
|
+
`),a=`Summarize the following conversation in ${n} characters or less.
|
|
14
|
+
${o?"Preserve key facts, decisions, and action items.":""}
|
|
15
15
|
Focus on information that would be useful context for continuing the conversation.
|
|
16
16
|
|
|
17
17
|
CONVERSATION:
|
|
18
|
-
${
|
|
18
|
+
${s}
|
|
19
19
|
|
|
20
|
-
SUMMARY:`;return t(a)}}function z(t){return t.replace(/[^a-zA-Z0-9]/g,"_")}function
|
|
21
|
-
`)}var
|
|
20
|
+
SUMMARY:`;return t(a)}}function z(t){return t.replace(/[^a-zA-Z0-9]/g,"_")}function De(t){return t.replace(/[\r\n]+/g," ").replace(/[[\](){}|<>"]/g,e=>`#${e.charCodeAt(0)};`)}var On={square:["[","]"],round:["(",")"],stadium:["([","])"],hexagon:["{{","}}"],circle:["((","))"]};function j(t,e,n,o){let r;n==="task"?r=o?.task??"hexagon":n==="agent"?r=o?.agent??"square":r=o?.virtual??"circle";let[s,a]=On[r];return `${t}${s}${De(e)}${a}`}function be(t){let e=new Map;for(let r of t)e.set(r,(e.get(r)??0)+1);let n=new Map,o=[];for(let r of t){let s=z(r);if(e.get(r)>1){let a=(n.get(r)??0)+1;n.set(r,a),o.push({id:`${s}_${a}`,label:`${r} #${a}`});}else o.push({id:s,label:r});}return o}function $n(t){let e=new Map,n=new Map;for(let s of Object.keys(t))e.has(s)||e.set(s,0),n.has(s)||n.set(s,[]);for(let[s,a]of Object.entries(t))for(let c of a.deps??[])n.get(c).push(s),e.set(s,(e.get(s)??0)+1);let o=[];for(let[s,a]of e)a===0&&o.push(s);o.sort();let r=[];for(;o.length>0;){let s=o.shift();r.push(s);let a=n.get(s)??[];a.sort();for(let c of a){let i=e.get(c)-1;if(e.set(c,i),i===0){let u=o.findIndex(l=>l>c);u===-1?o.push(c):o.splice(u,0,c);}}}return r}function Nn(t){let e=t;if(e.type==="parallel"&&typeof e.merge=="function"||e.type==="sequential"&&typeof e.transform=="function"||e.type==="supervisor"&&typeof e.extract=="function"||e.type==="dag"&&typeof e.merge=="function"||e.type==="reflect"&&typeof e.parseEvaluation=="function"||e.type==="race"&&typeof e.extract=="function"||e.type==="debate"&&typeof e.extract=="function"||e.type==="goal"&&(typeof e.when=="function"||typeof e.satisfaction=="function"||typeof e.extract=="function"))return false;if(e.type==="dag"&&e.nodes)for(let n of Object.values(e.nodes)){let o=n;if(typeof o.when=="function"||typeof o.transform=="function")return false}if(e.type==="goal"&&e.nodes)for(let n of Object.values(e.nodes)){let o=n;if(typeof o.buildInput=="function"||typeof o.extractOutput=="function")return false}return true}function _n(t,e){let n=[];return e&&n.push(`%%{init: {'theme': '${e}'}}%%`),n.push(`graph ${t}`),n.join(`
|
|
21
|
+
`)}var jn=new Set(["parallel","sequential","supervisor","dag","reflect","race","debate","goal"]);function Fn(t,e,n){let o=be(t.handlers),r=j("__input","Input","virtual",e),s=j("__merge","Merge","virtual",e),a=[];for(let c of o){let i=n?.has(c.label)?"task":"agent",u=j(c.id,c.label,i,e);a.push(` ${r} --> ${u}`),a.push(` ${u} --> ${s}`);}return a}function Gn(t,e,n){return t.handlers.length===0?[]:[` ${t.handlers.map(s=>({id:z(s),label:s})).map(s=>j(s.id,s.label,n?.has(s.label)?"task":"agent",e)).join(" --> ")}`]}function Ln(t,e){let n=z(t.supervisor),o=j(n,t.supervisor,"agent",e),r=[];for(let s of t.workers){let a=z(s),c=j(a,s,"agent",e);r.push(` ${o} -->|delegate| ${c}`),r.push(` ${c} -->|result| ${o}`);}return r}function Bn(t,e,n){let o=$n(t.nodes),r=[],s=new Set;for(let a of o){let c=t.nodes[a],i=z(a),u=c.handler,l=n?.has(c.handler)?"task":"agent";(!c.deps||c.deps.length===0)&&(s.has(i)||(r.push(` ${j(i,u,l,e)}`),s.add(i)));let p=[...c.deps??[]].sort();for(let d of p){let f=z(d),y=t.nodes[d],m=y.handler,S=n?.has(y.handler)?"task":"agent",h=j(f,m,S,e),g=j(i,u,l,e);r.push(` ${h} --> ${g}`),s.add(f),s.add(i);}}return r}function Un(t,e,n){let o=be(t.handlers),r=j("__input","Input","virtual",e),s=j("__output","Output","virtual",e),a=[];for(let c of o){let i=n?.has(c.label)?"task":"agent",u=j(c.id,c.label,i,e);a.push(` ${r} --> ${u}`),a.push(` ${u} -.-> ${s}`);}return a}function zn(t,e,n){let o=z(t.handler),r=z(t.evaluator),s=n?.has(t.handler)?"task":"agent",a=j(o,t.handler,s,e),c=j(r,t.evaluator,"agent",e),i=j("__output","Output","virtual",e);return [` ${a} --> ${c}`,` ${c} -->|feedback| ${a}`,` ${c} -->|pass| ${i}`]}function Hn(t,e,n){let o=Object.entries(t.nodes),r=[],s=new Map;for(let[u,l]of o)for(let p of l.produces)s.set(p,u);let a=new Set,c=new Set,i=[...o].sort(([u],[l])=>u.localeCompare(l));for(let[u,l]of i){let p=z(u),d=[...l.requires??[]].sort();if(d.length===0&&!a.has(p)){let f=n?.has(l.handler)?"task":"agent";r.push(` ${j(p,l.handler,f,e)}`),a.add(p);}for(let f of d){let y=s.get(f);if(y&&y!==u){let m=t.nodes[y];if(!m)continue;let S=`${y}->${u}`;if(!c.has(S)){let h=z(y),g=n?.has(m.handler)?"task":"agent",v=n?.has(l.handler)?"task":"agent",w=j(h,m.handler,g,e),M=j(p,l.handler,v,e);r.push(` ${w} -->|${De(f)}| ${M}`),a.add(h),a.add(p),c.add(S);}}}}for(let[u,l]of i){let p=z(u);if(!a.has(p)){let d=n?.has(l.handler)?"task":"agent";r.push(` ${j(p,l.handler,d,e)}`),a.add(p);}}return r}function qn(t,e,n){let o=be(t.handlers),r=z(t.evaluator),s=j(r,t.evaluator,"agent",e),a=j("__output","Output","virtual",e),c=[];for(let i of o){let u=n?.has(i.label)?"task":"agent",l=j(i.id,i.label,u,e);c.push(` ${l} --> ${s}`),c.push(` ${s} -->|next round| ${l}`);}return c.push(` ${s} --> ${a}`),c}function Vn(t,e){let n=e?.direction??"LR",o=e?.shapes,r=e?.taskIds,s=Nn(t)?t:chunkX3VQ5F7D_cjs.na(t);if(!jn.has(s.type))throw new Error(`[Directive] patternToMermaid: unknown pattern type "${s.type}"`);let a=_n(n,e?.theme),c=[];switch(s.type){case "parallel":c=Fn(s,o,r);break;case "sequential":c=Gn(s,o,r);break;case "supervisor":c=Ln(s,o);break;case "dag":c=Bn(s,o,r);break;case "race":c=Un(s,o,r);break;case "reflect":c=zn(s,o,r);break;case "debate":c=qn(s,o,r);break;case "goal":c=Hn(s,o,r);break}return a+`
|
|
22
22
|
`+c.join(`
|
|
23
23
|
`)+`
|
|
24
|
-
`}function Y(){return globalThis.crypto?.randomUUID?.()??`${Date.now().toString(36)}-${Math.random().toString(36).slice(2,11)}`}function zn(t={}){let{maxHistory:e=1e3,defaultTtlMs:r=36e5,maxPendingPerAgent:s=100,persistence:n,onDelivery:o,onDeliveryError:a}=t,c=new Map,i=[],u=new Map,l=new Map;function p(m,S){if(S.types&&!S.types.includes(m.type)||S.from&&!(Array.isArray(S.from)?S.from:[S.from]).includes(m.from))return false;if(S.topics){let h=m.topic;if(h&&!S.topics.includes(h))return false}return !(S.priority&&m.priority&&!S.priority.includes(m.priority)||S.custom&&!S.custom(m))}function d(m){return m.ttlMs?Date.now()-m.timestamp>m.ttlMs:false}function y(m){return m.to==="*"?Array.from(c.keys()):Array.isArray(m.to)?m.to:[m.to]}async function f(m){if(d(m))return;let S=y(m),h=[],g=[];for(let b of S){let R=c.get(b)??[];if(R.length===0){let x=l.get(b)??[];for(x.push(m);x.length>s;)x.shift();l.set(b,x);continue}for(let x of R)(!x.filter||p(m,x.filter))&&g.push(Promise.resolve(x.handler(m)).then(()=>{h.push(b);},M=>{a?.(m,M instanceof Error?M:new Error(String(M)));}));}g.length>0&&await Promise.allSettled(g),h.length>0&&o?.(m,h),n&&await n.save(m);}return {publish(m){let S={...m,id:Y(),timestamp:Date.now(),priority:m.priority??"normal",ttlMs:m.ttlMs??r};for(i.push(S),u.set(S.id,S);i.length>e;){let h=i.shift();h&&u.delete(h.id);}return f(S).catch(h=>{let g=h instanceof Error?h:new Error(String(h));a?a(S,g):console.error("[Directive MessageBus] Delivery error:",g);}),S.id},subscribe(m,S,h){let g=Y(),b={id:g,agentId:m,handler:S,filter:h,unsubscribe:()=>{let M=c.get(m)??[],P=M.findIndex(O=>O.id===g);P>=0&&M.splice(P,1);}},R=c.get(m)??[];R.push(b),c.set(m,R);let x=l.get(m)??[];l.delete(m);for(let M of x)if(!h||p(M,h)){let P=S(M);P instanceof Promise&&P.catch(O=>{let v=O instanceof Error?O:new Error(String(O));a?a(M,v):console.error("[Directive MessageBus] Pending delivery error:",v);});}return b},getHistory(m,S=100){let h=i.filter(g=>!d(g));return m&&(h=h.filter(g=>p(g,m))),h.slice(-S)},getMessage(m){let S=u.get(m);if(!(S&&d(S)))return S},getPending(m){return (l.get(m)??[]).filter(h=>!d(h))},clear(){i.length=0,u.clear(),l.clear();},destroy(){i.length=0,u.clear(),l.clear(),c.clear();}}}function qn(t){let{bus:e,agents:r={},defaultTimeout:s=3e4,onAgentOnline:n,onAgentOffline:o}=t,a=new Map,c=new Map;for(let[u,l]of Object.entries(r))a.set(u,{...l,id:u,status:"offline",lastSeen:Date.now()});function i(u){if(u.type!=="RESPONSE"&&u.type!=="DELEGATION_RESULT")return;let l=u.correlationId??u.replyTo;if(!l)return;let p=c.get(l);p&&(clearTimeout(p.timer),c.delete(l),p.resolve(u));}return {register(u,l){let p=!a.has(u)||a.get(u)?.status==="offline";a.set(u,{...l,id:u,status:"online",lastSeen:Date.now()}),p&&n?.(u);},unregister(u){let l=a.get(u);l&&(l.status="offline",o?.(u));},getAgent(u){return a.get(u)},getAgents(){return Array.from(a.values())},findByCapability(u){return Array.from(a.values()).filter(l=>l.capabilities.includes(u)&&l.status==="online")},send(u,l,p){let d=a.get(u);return d&&(d.lastSeen=Date.now(),d.status="online"),e.publish({...p,from:u,to:l,type:p.type??"CUSTOM"})},async request(u,l,p,d,y=s){return new Promise((f,m)=>{let S=Y(),h=e.subscribe(u,b=>{(b.correlationId===S||b.replyTo===S)&&(h.unsubscribe(),i(b));},{types:["RESPONSE"]}),g=setTimeout(()=>{h.unsubscribe(),c.delete(S),m(new Error(`[Directive Communication] Request timeout after ${y}ms`));},y);c.set(S,{resolve:f,reject:m,timer:g}),e.publish({type:"REQUEST",from:u,to:l,action:p,payload:d,timeout:y,correlationId:S});})},async delegate(u,l,p,d){return new Promise((y,f)=>{let m=Y(),S=e.subscribe(u,g=>{(g.correlationId===m||g.replyTo===m)&&(S.unsubscribe(),i(g));},{types:["DELEGATION_RESULT"]}),h=setTimeout(()=>{S.unsubscribe(),c.delete(m),f(new Error(`[Directive Communication] Delegation timeout after ${s}ms`));},s);c.set(m,{resolve:y,reject:f,timer:h}),e.publish({type:"DELEGATION",from:u,to:l,task:p,context:d,correlationId:m});})},async query(u,l,p,d){return new Promise((y,f)=>{let m=Y(),S=e.subscribe(u,g=>{(g.correlationId===m||g.replyTo===m)&&(S.unsubscribe(),i(g));},{types:["RESPONSE"]}),h=setTimeout(()=>{S.unsubscribe(),c.delete(m),f(new Error(`[Directive Communication] Query timeout after ${s}ms`));},s);c.set(m,{resolve:y,reject:f,timer:h}),e.publish({type:"QUERY",from:u,to:l,question:p,context:d,correlationId:m});})},broadcast(u,l){return e.publish({...l,from:u,to:"*",type:l.type??"INFORM"})},listen(u,l,p){let d=a.get(u);return d&&(d.status="online",d.lastSeen=Date.now(),n?.(u)),e.subscribe(u,l,p)},getBus(){return e},destroy(){for(let[,u]of c)clearTimeout(u.timer);c.clear(),a.clear();}}}function Hn(t,e){let r=new Map,s=t.listen(e,async n=>{if(n.type==="REQUEST"){let o=n,a=r.get(o.action),c;if(a)try{let i=await a(o.payload);c={type:"RESPONSE",success:i.success,result:i.result,error:i.error};}catch(i){c={type:"RESPONSE",success:false,error:i instanceof Error?i.message:String(i)};}else c={type:"RESPONSE",success:false,error:`Unknown action: ${o.action}`};t.send(e,n.from,{...c,correlationId:n.correlationId??n.id,replyTo:n.correlationId??n.id});}},{types:["REQUEST"]});return {onRequest(n,o){r.set(n,o);},offRequest(n){r.delete(n);},destroy(){s.unsubscribe(),r.clear();}}}function Vn(t,e){let r=null,s=t.listen(e,async n=>{if(n.type==="DELEGATION"&&r){let o=n,a=Date.now(),c;try{let i=await r(o.task,o.context);c={type:"DELEGATION_RESULT",success:i.success,result:i.result,error:i.error,metrics:i.metrics??{durationMs:Date.now()-a}};}catch(i){c={type:"DELEGATION_RESULT",success:false,error:i instanceof Error?i.message:String(i),metrics:{durationMs:Date.now()-a}};}t.send(e,n.from,{...c,correlationId:n.correlationId??n.id,replyTo:n.correlationId??n.id});}},{types:["DELEGATION"]});return {onDelegation(n){r=n;},offDelegation(){r=null;},destroy(){s.unsubscribe(),r=null;}}}function Jn(t,e){let r=new Map,s=t.listen(e,n=>{if(n.type==="UPDATE"){let o=n,a=r.get(o.topic)??[];for(let c of a)c(o.content);}},{types:["UPDATE"]});return {subscribe(n,o){let a=new Map;for(let c of n){let i=r.get(c)??[],u=l=>o(c,l);a.set(c,u),i.push(u),r.set(c,i);}return t.broadcast(e,{type:"SUBSCRIBE",topics:n}),()=>{for(let[c,i]of a){let u=r.get(c);if(u){let l=u.indexOf(i);l>=0&&u.splice(l,1),u.length===0&&r.delete(c);}}a.clear(),t.broadcast(e,{type:"UNSUBSCRIBE",topics:n});}},publish(n,o){t.broadcast(e,{type:"UPDATE",topic:n,content:o});},destroy(){s.unsubscribe(),r.clear();}}}var Kn=[{type:"ssn",pattern:/\b(\d{3}[-\s]?\d{2}[-\s]?\d{4})\b/g,validate:t=>{let e=t.replace(/[-\s]/g,"");return !(e.startsWith("000")||e.startsWith("666")||e.startsWith("9")||e.slice(3,5)==="00"||e.slice(5)==="0000")},confidence:.95},{type:"credit_card",pattern:/\b((?:\d{4}[-\s]?\d{4}[-\s]?\d{4}[-\s]?\d{4})|\d{13,19})\b/g,validate:t=>{let e=t.replace(/[-\s]/g,"");if(e.length<13||e.length>19)return false;let r=0,s=false;for(let n=e.length-1;n>=0;n--){let o=e[n];if(!o)continue;let a=Number.parseInt(o,10);s&&(a*=2,a>9&&(a-=9)),r+=a,s=!s;}return r%10===0},confidence:.95},{type:"email",pattern:/\b([A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,})\b/gi,confidence:.9},{type:"phone",pattern:/\b(\+?1?[-.\s]?\(?[0-9]{3}\)?[-.\s]?[0-9]{3}[-.\s]?[0-9]{4})\b/g,validate:t=>{let e=t.replace(/\D/g,"");return e.length>=10&&e.length<=11},confidence:.8},{type:"date_of_birth",pattern:/\b(born|dob|birth.?date|date.?of.?birth)[:.\s]+(\d{1,4}[-/]\d{1,2}[-/]\d{1,4})\b/gi,valueGroup:2,confidence:.85},{type:"ip_address",pattern:/\b(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})\b/g,validate:t=>{let r=t.split(".").map(o=>Number.parseInt(o,10));if(r.some(o=>Number.isNaN(o)||o<0||o>255))return false;let[s,n]=r;return !(s===10||s===172&&n>=16&&n<=31||s===192&&n===168||s===127||s===169&&n===254||t==="0.0.0.0"||t==="255.255.255.255")},confidence:.9},{type:"bank_account",pattern:/\b(account|acct)[\s#:]+(\d{8,17})\b/gi,valueGroup:2,confidence:.7},{type:"passport",pattern:/\b(passport)[\s#:]+([A-Z0-9]{6,9})\b/gi,valueGroup:2,confidence:.75},{type:"driver_license",pattern:/\b(driver'?s?\s*licen[cs]e|dl)[\s#:]+([A-Z0-9]{5,15})\b/gi,valueGroup:2,confidence:.7},{type:"medical_id",pattern:/\b(mrn|medical.?record|patient.?id)[\s#:]+([A-Z0-9-]{6,15})\b/gi,valueGroup:2,confidence:.7},{type:"national_id",pattern:/\b(national.?id|nin|identity.?number|identity.?card|id.?number)[\s#:]+([A-Z0-9-]{6,20})\b/gi,valueGroup:2,confidence:.85}];function Wn(t){let e=[],r="street|st|avenue|ave|road|rd|drive|dr|lane|ln|court|ct|way|boulevard|blvd|circle|cir|place|pl",s=new RegExp(`\\b(\\d{1,5}\\s+(?:\\w+\\s+){1,4}(?:${r})\\b[^\\n]{0,50}\\b[A-Z]{2}\\s+\\d{5}(?:-\\d{4})?)\\b`,"gi"),n;for(;(n=s.exec(t))!==null;)e.push({type:"address",value:n[0],position:{start:n.index,end:n.index+n[0].length},confidence:.7});return e}var Ie=["mr","mrs","ms","miss","dr","prof","sir","madam","name is","called","known as","signed by","from","dear","hi","hello","contact","recipient"];function Yn(t){let e=[],r=Ie.join("|"),s=new RegExp(`\\b(${r})[.,:]?\\s+([A-Z][a-z]{1,20}(?:\\s[A-Z][a-z]{1,20}){0,2})\\b`,"gi"),n;for(;(n=s.exec(t))!==null;){let o=n[2],a=n[1];o&&(o.split(/\s+/).length>=2||a&&Ie.some(c=>a.toLowerCase().includes(c)))&&e.push({type:"name",value:o,position:{start:n.index,end:n.index+n[0].length},confidence:.6,context:n[0]});}return e}var De=1e5;function Qn(t,e){let r=[],s=new RegExp(t.pattern.source,t.pattern.flags),n=t.valueGroup??1,o;for(;(o=s.exec(e))!==null;){let a=o[n]??o[0],c=o.index,i=o.index+o[0].length,u=e.slice(Math.max(0,c-20),i+20);t.validate&&!t.validate(a,u)||r.push({type:t.type,value:a,position:{start:c,end:i},confidence:t.confidence,context:u});}return r}var re={name:"regex",async detect(t,e){if(t.length>De)throw new Error(`[Directive] Input exceeds maximum length of ${De} characters for PII detection. Truncate input or process in chunks.`);let r=[],s=new Set(e);for(let n of Kn)s.has(n.type)&&r.push(...Qn(n,t));return s.has("address")&&r.push(...Wn(t)),s.has("name")&&r.push(...Yn(t)),r}},Xn=new Set(["ssn","credit_card","date_of_birth","medical_id","national_id","passport","driver_license","bank_account"]);function Zn(t,e){let{start:r,end:s}=t.position;return Number.isInteger(r)&&Number.isInteger(s)&&r>=0&&r<s&&s<=e}function er(t,e){switch(e){case "placeholder":return "[REDACTED]";case "typed":return Xn.has(t.type)?"[REDACTED]":`[${t.type.toUpperCase()}]`;case "masked":{if(t.type!=="credit_card")return "****";let r=t.value.replace(/\D/g,"");return `****${r.length>4?r.slice(-4):""}`}case "hashed":return `[HASH:${tr(t.value)}]`}}function Q(t,e,r="typed"){let n=[...e.filter(i=>Zn(i,t.length))].sort((i,u)=>{if(u.confidence!==i.confidence)return u.confidence-i.confidence;let l=i.position.end-i.position.start,p=u.position.end-u.position.start;return p!==l?p-l:i.position.start-u.position.start}),o=[];for(let i of n)o.some(l=>i.position.start<l.position.end&&l.position.start<i.position.end)||o.push(i);let a=o.sort((i,u)=>u.position.start-i.position.start),c=t;for(let i of a){let u=er(i,r);c=c.slice(0,i.position.start)+u+c.slice(i.position.end);}return c}function tr(t){let s=2166136261;for(let n=0;n<t.length;n++)s^=t.charCodeAt(n),s=Math.imul(s,16777619);return (s>>>0).toString(16).padStart(8,"0")}var Oe=["ssn","credit_card","email","phone","date_of_birth","bank_account"];function $e(t={}){let{types:e=Oe,detector:r="regex",redact:s=false,redactionStyle:n="typed",minConfidence:o=.7,onDetected:a,allowlist:c=[],minItemsToBlock:i=1,detectorTimeout:u=5e3}=t,l=r==="regex"?re:r,p=new Set(c.map(y=>y.toLowerCase().trim()));async function d(y,f){if(l===re)return l.detect(y,f);let m,S=l.detect(y,f),h=new Promise((g,b)=>{m=setTimeout(()=>b(new Error(`[Directive] PII detector '${l.name}' timed out after ${u}ms`)),u);});S.catch(()=>{}),h.catch(()=>{});try{return await Promise.race([S,h])}finally{clearTimeout(m);}}return async y=>{let m=(await d(y.input,e)).filter(S=>!(S.confidence<o||p.has(S.value.toLowerCase().trim())));if(m.length>0&&a?.(m),m.length>=i){if(s)return {passed:true,transformed:Q(y.input,m,n)};let S={};for(let g of m)S[g.type]=(S[g.type]||0)+1;return {passed:false,reason:`PII detected (${Object.entries(S).map(([g,b])=>`${g}: ${b}`).join(", ")})`}}return {passed:true}}}function nr(t={}){let e=$e(t);return async(r,s)=>{let n=typeof r.output=="string"?r.output:JSON.stringify(r.output);return e({input:n,agentName:r.agentName},s)}}async function se(t,e={}){let{types:r=Oe,detector:s="regex",minConfidence:n=.7,timeout:o=5e3}=e,a=s==="regex"?re:s,c;if(a===re)c=await a.detect(t,r);else {let l,p=a.detect(t,r),d=new Promise((y,f)=>{l=setTimeout(()=>f(new Error(`[Directive] PII detector '${a.name}' timed out after ${o}ms`)),o);});p.catch(()=>{}),d.catch(()=>{});try{c=await Promise.race([p,d]);}finally{clearTimeout(l);}}let i=c.filter(l=>l.confidence>=n),u={};for(let l of i)u[l.type]=(u[l.type]||0)+1;return {detected:i.length>0,items:i,typeCounts:u}}async function rr(t,e={}){let r=await se(t,e);return r.detected?{...r,redactedText:Q(t,r.items,e.style??"typed")}:{...r}}var sr=1e4,or=10080*60*1e3,ar=6e4,Ne="0".repeat(64);function ir(){return globalThis.crypto?.randomUUID?.()??`${Date.now().toString(36)}-${Math.random().toString(36).slice(2,11)}`}function cr(t){return new TextEncoder().encode(t)}function ur(t){return Array.from(t).map(e=>e.toString(16).padStart(2,"0")).join("")}async function _e(t){let e=cr(t),r=await globalThis.crypto.subtle.digest("SHA-256",e);return ur(new Uint8Array(r))}function je(t){let{id:e,timestamp:r,eventType:s,previousHash:n,payload:o,actorId:a,sessionId:c}=t;return JSON.stringify({id:e,timestamp:r,eventType:s,previousHash:n,payload:o,actorId:a,sessionId:c})}function lr(t){return JSON.parse(JSON.stringify(t))}async function dr(t,e){let r=lr(t);async function s(n){if(typeof n=="string"){let o=await se(n,{types:e.types,minConfidence:e.minConfidence??.7});if(o.detected){let a=e.allowlist?o.items.filter(c=>!e.allowlist.includes(c.value.toLowerCase())):o.items;if(a.length>0)return Q(n,a,e.redactionStyle)}return n}if(Array.isArray(n))return Promise.all(n.map(s));if(n&&typeof n=="object"){let o={};for(let[a,c]of Object.entries(n))o[a]=await s(c);return o}return n}for(let[n,o]of Object.entries(r))r[n]=await s(o);return r}function pr(t={}){let{maxEntries:e=sr,retentionMs:r=or,exportInterval:s=ar,exporter:n,piiMasking:o,signing:a,sessionId:c,actorId:i,events:u={}}=t,l=[],p=0,d=0,y=0,f=true,m;function S(){return l.length===0?Ne:l[l.length-1].hash}async function h(g,b,R){let x={id:ir(),timestamp:Date.now(),eventType:g,previousHash:S(),payload:b,actorId:i,sessionId:c};o?.enabled&&(x.maskedPayload=await dr(b,o));let M=je(x),P=await _e(M),O={...x,hash:P};for(a&&(O.signature=await a.signFn(P)),l.push(O);l.length>e;)l.shift(),d++,p>0&&p--;return u.onEntryAdded?.(O),O}return n&&s>0&&(m=setInterval(async()=>{try{let g=l.slice(p);g.length>0&&(await n(g),y+=g.length,p=l.length);}catch(g){u.onExportError?.(g instanceof Error?g:new Error(String(g)),l.slice(p));}},s)),{getEntries(g){let b=[...l];if(g){if(g.eventTypes?.length){let R=new Set(g.eventTypes);b=b.filter(x=>R.has(x.eventType));}g.actorId&&(b=b.filter(R=>R.actorId===g.actorId)),g.sessionId&&(b=b.filter(R=>R.sessionId===g.sessionId)),g.since!==void 0&&(b=b.filter(R=>R.timestamp>=g.since)),g.until!==void 0&&(b=b.filter(R=>R.timestamp<=g.until)),g.offset!==void 0&&(b=b.slice(g.offset)),g.limit!==void 0&&(b=b.slice(0,g.limit));}return b},async verifyChain(){if(l.length===0)return {valid:true,entriesVerified:0,verifiedAt:Date.now()};l[0].previousHash;for(let b=0;b<l.length;b++){let R=l[b],x=je({id:R.id,timestamp:R.timestamp,eventType:R.eventType,previousHash:R.previousHash,payload:R.payload,actorId:R.actorId,sessionId:R.sessionId}),M=await _e(x);if(R.hash!==M){f=false;let P={valid:false,entriesVerified:b,brokenAt:{index:b,entryId:R.id,expectedHash:M,actualHash:R.hash},verifiedAt:Date.now()};return u.onChainBroken?.(P),P}if(b>0){let P=l[b-1];if(R.previousHash!==P.hash){f=false;let O={valid:false,entriesVerified:b,brokenAt:{index:b,entryId:R.id,expectedHash:P.hash,actualHash:R.previousHash},verifiedAt:Date.now()};return u.onChainBroken?.(O),O}}if(a?.verifyFn&&R.signature&&!await a.verifyFn(R.hash,R.signature)){f=false;let O={valid:false,entriesVerified:b,brokenAt:{index:b,entryId:R.id,expectedHash:"signature-invalid",actualHash:R.signature},verifiedAt:Date.now()};return u.onChainBroken?.(O),O}}return f=true,{valid:true,entriesVerified:l.length,verifiedAt:Date.now()}},async export(g){let b=[...l];return g!==void 0&&(b=b.filter(R=>R.timestamp>=g)),n&&b.length>0&&(await n(b),y+=b.length),b},prune(){let g=Date.now()-r,b=l.length;for(;l.length>0&&l[0].timestamp<g;)l.shift(),p>0&&p--;let R=b-l.length;return d+=R,R},getStats(){let g={};for(let b of l)g[b.eventType]=(g[b.eventType]??0)+1;return {totalEntries:l.length,byEventType:g,oldestEntry:l[0]?.timestamp,newestEntry:l[l.length-1]?.timestamp,entriesPruned:d,entriesExported:y,chainIntegrity:f}},async destroy(){if(m&&(clearInterval(m),m=void 0),n)try{let g=l.slice(p);g.length>0&&(await n(g),y+=g.length);}catch(g){u.onExportError?.(g instanceof Error?g:new Error(String(g)),l.slice(p));}},addEntry(g,b){return h(g,b)},createPlugin(){return {name:"audit-trail",onFactSet:(g,b,R)=>{h("fact.set",{key:g,value:b,prev:R}).catch(console.error);},onFactsBatch:g=>{h("fact.batch",{changes:g.map(b=>({key:b.key,value:b.value,prev:b.prev}))}).catch(console.error);},onRequirementCreated:g=>{h("requirement.created",{id:g.id,type:g.requirement.type,payload:g.requirement}).catch(console.error);},onRequirementMet:(g,b)=>{h("requirement.met",{id:g.id,type:g.requirement.type,byResolver:b}).catch(console.error);},onResolverStart:(g,b)=>{h("resolver.start",{resolver:g,requirementId:b.id,requirementType:b.requirement.type}).catch(console.error);},onResolverComplete:(g,b,R)=>{h("resolver.complete",{resolver:g,requirementId:b.id,requirementType:b.requirement.type,duration:R}).catch(console.error);},onResolverError:(g,b,R)=>{h("resolver.error",{resolver:g,requirementId:b.id,requirementType:b.requirement.type,error:R instanceof Error?R.message:String(R)}).catch(console.error);},onError:g=>{h("error.occurred",{source:g.source,sourceId:g.sourceId,message:g.message,context:g.context}).catch(console.error);},onErrorRecovery:(g,b)=>{h("error.recovery",{source:g.source,message:g.message,strategy:b}).catch(console.error);}}}}}function gr(t){return {onAgentStart:(e,r)=>{t.addEntry("agent.run.start",{agentName:e,input:r});},onAgentComplete:(e,r,s,n)=>{t.addEntry("agent.run.complete",{agentName:e,output:r,tokens:s,cost:n});},onAgentError:(e,r)=>{t.addEntry("agent.run.error",{agentName:e,error:r.message,stack:r.stack});},onToolStart:(e,r,s)=>{t.addEntry("tool.call.start",{toolName:e,toolCallId:r,args:s});},onToolComplete:(e,r,s)=>{t.addEntry("tool.call.complete",{toolName:e,toolCallId:r,result:s});},onToolError:(e,r,s)=>{t.addEntry("tool.call.error",{toolName:e,toolCallId:r,error:s.message});},onApprovalRequested:(e,r,s)=>{t.addEntry("approval.requested",{toolName:e,toolCallId:r,args:s});},onApprovalGranted:(e,r)=>{t.addEntry("approval.granted",{toolName:e,toolCallId:r});},onApprovalDenied:(e,r,s)=>{t.addEntry("approval.denied",{toolName:e,toolCallId:r,reason:s});}}}var X=[{pattern:/ignore\s+(all\s+)?(previous|prior|above|earlier)\s+(instructions?|prompts?|rules?|guidelines?)/i,name:"ignore-previous",severity:"critical",category:"instruction_override"},{pattern:/disregard\s+(all\s+)?(previous|prior|above|earlier)\s+(instructions?|prompts?)/i,name:"disregard-previous",severity:"critical",category:"instruction_override"},{pattern:/forget\s+(all\s+)?(previous|prior|above|earlier)\s+(instructions?|prompts?)/i,name:"forget-previous",severity:"critical",category:"instruction_override"},{pattern:/override\s+(the\s+)?(system|base)\s+(prompt|instructions?)/i,name:"override-system",severity:"critical",category:"instruction_override"},{pattern:/\bDAN\s+(mode|jailbreak)\b/i,name:"dan-mode",severity:"critical",category:"jailbreak"},{pattern:/\bjailbreak(ed)?\s*(mode)?\b/i,name:"jailbreak-keyword",severity:"high",category:"jailbreak"},{pattern:/developer\s+mode\s+(enabled|activated|on)/i,name:"developer-mode",severity:"critical",category:"jailbreak"},{pattern:/pretend\s+(you\s+)?(are|can|have)\s+(no\s+)?(restrictions?|limits?|boundaries?|ethics)/i,name:"pretend-no-restrictions",severity:"high",category:"jailbreak"},{pattern:/you\s+(now\s+)?have\s+no\s+(ethical\s+)?(restrictions?|guidelines?|boundaries?)/i,name:"no-restrictions",severity:"high",category:"jailbreak"},{pattern:/you\s+are\s+now\s+(a|an)\s+\w+\s+(that|who)\s+(can|will|must)/i,name:"role-assignment",severity:"medium",category:"role_manipulation"},{pattern:/from\s+now\s+on,?\s+(you\s+)?(will|must|should)\s+(only\s+)?/i,name:"from-now-on",severity:"medium",category:"role_manipulation"},{pattern:/^(system|assistant|user):\s*/im,name:"fake-role-marker",severity:"high",category:"context_manipulation"},{pattern:/<\|?(system|endofprompt|im_start|im_end)\|?>/i,name:"special-token-injection",severity:"critical",category:"context_manipulation"},{pattern:/```(system|assistant|instructions?)\n/i,name:"markdown-code-injection",severity:"medium",category:"delimiter_injection"},{pattern:/<system>|<\/system>|<instructions?>|<\/instructions?>/i,name:"xml-tag-injection",severity:"high",category:"delimiter_injection"},{pattern:/fetch\s+(content\s+)?(from|at)\s+(the\s+)?url/i,name:"url-fetch-instruction",severity:"medium",category:"indirect_injection"},{pattern:/execute\s+(the\s+)?(code|script|command)\s+(from|in|at)/i,name:"execute-from-source",severity:"high",category:"indirect_injection"}],he=[...X,{pattern:/act\s+as\s+(if\s+)?(you\s+)?(were|are|can)/i,name:"act-as",severity:"low",category:"role_manipulation"},{pattern:/new\s+instructions?:/i,name:"new-instructions",severity:"medium",category:"instruction_override"},{pattern:/\[system\]|\[admin\]|\[developer\]/i,name:"bracket-role-marker",severity:"medium",category:"context_manipulation"},{pattern:/base64|rot13|decode\s+(this|the)/i,name:"encoding-reference",severity:"low",category:"encoding_evasion"},{pattern:/\u200b|\u200c|\u200d|\u2060|\ufeff/,name:"zero-width-chars",severity:"medium",category:"encoding_evasion"}],Ge=1e5;function ve(t,e=X){if(t.length>Ge)throw new Error(`[Directive] Input exceeds maximum length of ${Ge} characters for injection detection. Truncate input or process in chunks.`);let r=[];for(let{pattern:a,name:c,severity:i,category:u}of e){let p=new RegExp(a.source,a.flags).exec(t);p&&r.push({name:c,category:u,severity:i,match:p[0],position:p.index});}let s={low:10,medium:25,high:50,critical:100},n=r.reduce((a,c)=>a+s[c.severity],0),o=Math.min(100,n);return {detected:r.length>0,patterns:r,riskScore:o}}function Fe(t,e=X){let r=t.replace(/\u200b|\u200c|\u200d|\u2060|\ufeff/g,""),s=e.map(u=>`(${u.pattern.source})`);if(s.length===0)return r;let n=e.some(u=>u.pattern.flags.includes("g")),o=e.some(u=>u.pattern.flags.includes("i")),a=e.some(u=>u.pattern.flags.includes("m")),c=`${n?"g":""}${o?"i":""}${a?"m":""}`,i=new RegExp(s.join("|"),c||"gi");return r=r.replace(i,"[REDACTED]"),r}function Le(t={}){let{additionalPatterns:e=[],replacePatterns:r,strictMode:s=false,blockThreshold:n=50,sanitize:o=false,onBlocked:a,ignoreCategories:c=[]}=t,i;if(r?i=r:i=s?[...he]:[...X],i=[...i,...e],c.length>0){let u=new Set(c);i=i.filter(l=>!u.has(l.category));}return u=>{let l=ve(u.input,i);if(l.detected&&l.riskScore>=n){if(a?.(u.input,l),o)return {passed:true,transformed:Fe(u.input,i)};let p=l.patterns.sort((d,y)=>{let f={critical:0,high:1,medium:2,low:3};return f[d.severity]-f[y.severity]}).slice(0,3).map(d=>d.name).join(", ");return {passed:false,reason:`Prompt injection detected (risk: ${l.riskScore}%, patterns: ${p})`}}return {passed:true}}}function mr(t,e){return `[UNTRUSTED_CONTENT source="${e}"]
|
|
24
|
+
`}function Q(){return globalThis.crypto?.randomUUID?.()??`${Date.now().toString(36)}-${Math.random().toString(36).slice(2,11)}`}function Jn(t={}){let{maxHistory:e=1e3,defaultTtlMs:n=36e5,maxPendingPerAgent:o=100,persistence:r,onDelivery:s,onDeliveryError:a}=t,c=new Map,i=[],u=new Map,l=new Map;function p(m,S){if(S.types&&!S.types.includes(m.type)||S.from&&!(Array.isArray(S.from)?S.from:[S.from]).includes(m.from))return false;if(S.topics){let h=m.topic;if(h&&!S.topics.includes(h))return false}return !(S.priority&&m.priority&&!S.priority.includes(m.priority)||S.custom&&!S.custom(m))}function d(m){return m.ttlMs?Date.now()-m.timestamp>m.ttlMs:false}function f(m){return m.to==="*"?Array.from(c.keys()):Array.isArray(m.to)?m.to:[m.to]}async function y(m){if(d(m))return;let S=f(m),h=[],g=[];for(let v of S){let w=c.get(v)??[];if(w.length===0){let M=l.get(v)??[];for(M.push(m);M.length>o;)M.shift();l.set(v,M);continue}for(let M of w)(!M.filter||p(m,M.filter))&&g.push(Promise.resolve(M.handler(m)).then(()=>{h.push(v);},x=>{a?.(m,x instanceof Error?x:new Error(String(x)));}));}g.length>0&&await Promise.allSettled(g),h.length>0&&s?.(m,h),r&&await r.save(m);}return {publish(m){let S={...m,id:Q(),timestamp:Date.now(),priority:m.priority??"normal",ttlMs:m.ttlMs??n};for(i.push(S),u.set(S.id,S);i.length>e;){let h=i.shift();h&&u.delete(h.id);}return y(S).catch(h=>{let g=h instanceof Error?h:new Error(String(h));a?a(S,g):console.error("[Directive MessageBus] Delivery error:",g);}),S.id},subscribe(m,S,h){let g=Q(),v={id:g,agentId:m,handler:S,filter:h,unsubscribe:()=>{let x=c.get(m)??[],P=x.findIndex(O=>O.id===g);P>=0&&x.splice(P,1);}},w=c.get(m)??[];w.push(v),c.set(m,w);let M=l.get(m)??[];l.delete(m);for(let x of M)if(!h||p(x,h)){let P=S(x);P instanceof Promise&&P.catch(O=>{let b=O instanceof Error?O:new Error(String(O));a?a(x,b):console.error("[Directive MessageBus] Pending delivery error:",b);});}return v},getHistory(m,S=100){let h=i.filter(g=>!d(g));return m&&(h=h.filter(g=>p(g,m))),h.slice(-S)},getMessage(m){let S=u.get(m);if(!(S&&d(S)))return S},getPending(m){return (l.get(m)??[]).filter(h=>!d(h))},clear(){i.length=0,u.clear(),l.clear();},destroy(){i.length=0,u.clear(),l.clear(),c.clear();}}}function Kn(t){let{bus:e,agents:n={},defaultTimeout:o=3e4,onAgentOnline:r,onAgentOffline:s}=t,a=new Map,c=new Map;for(let[u,l]of Object.entries(n))a.set(u,{...l,id:u,status:"offline",lastSeen:Date.now()});function i(u){if(u.type!=="RESPONSE"&&u.type!=="DELEGATION_RESULT")return;let l=u.correlationId??u.replyTo;if(!l)return;let p=c.get(l);p&&(clearTimeout(p.timer),c.delete(l),p.resolve(u));}return {register(u,l){let p=!a.has(u)||a.get(u)?.status==="offline";a.set(u,{...l,id:u,status:"online",lastSeen:Date.now()}),p&&r?.(u);},unregister(u){let l=a.get(u);l&&(l.status="offline",s?.(u));},getAgent(u){return a.get(u)},getAgents(){return Array.from(a.values())},findByCapability(u){return Array.from(a.values()).filter(l=>l.capabilities.includes(u)&&l.status==="online")},send(u,l,p){let d=a.get(u);return d&&(d.lastSeen=Date.now(),d.status="online"),e.publish({...p,from:u,to:l,type:p.type??"CUSTOM"})},async request(u,l,p,d,f=o){return new Promise((y,m)=>{let S=Q(),h=e.subscribe(u,v=>{(v.correlationId===S||v.replyTo===S)&&(h.unsubscribe(),i(v));},{types:["RESPONSE"]}),g=setTimeout(()=>{h.unsubscribe(),c.delete(S),m(new Error(`[Directive Communication] Request timeout after ${f}ms`));},f);c.set(S,{resolve:y,reject:m,timer:g}),e.publish({type:"REQUEST",from:u,to:l,action:p,payload:d,timeout:f,correlationId:S});})},async delegate(u,l,p,d){return new Promise((f,y)=>{let m=Q(),S=e.subscribe(u,g=>{(g.correlationId===m||g.replyTo===m)&&(S.unsubscribe(),i(g));},{types:["DELEGATION_RESULT"]}),h=setTimeout(()=>{S.unsubscribe(),c.delete(m),y(new Error(`[Directive Communication] Delegation timeout after ${o}ms`));},o);c.set(m,{resolve:f,reject:y,timer:h}),e.publish({type:"DELEGATION",from:u,to:l,task:p,context:d,correlationId:m});})},async query(u,l,p,d){return new Promise((f,y)=>{let m=Q(),S=e.subscribe(u,g=>{(g.correlationId===m||g.replyTo===m)&&(S.unsubscribe(),i(g));},{types:["RESPONSE"]}),h=setTimeout(()=>{S.unsubscribe(),c.delete(m),y(new Error(`[Directive Communication] Query timeout after ${o}ms`));},o);c.set(m,{resolve:f,reject:y,timer:h}),e.publish({type:"QUERY",from:u,to:l,question:p,context:d,correlationId:m});})},broadcast(u,l){return e.publish({...l,from:u,to:"*",type:l.type??"INFORM"})},listen(u,l,p){let d=a.get(u);return d&&(d.status="online",d.lastSeen=Date.now(),r?.(u)),e.subscribe(u,l,p)},getBus(){return e},destroy(){for(let[,u]of c)clearTimeout(u.timer);c.clear(),a.clear();}}}function Wn(t,e){let n=new Map,o=t.listen(e,async r=>{if(r.type==="REQUEST"){let s=r,a=n.get(s.action),c;if(a)try{let i=await a(s.payload);c={type:"RESPONSE",success:i.success,result:i.result,error:i.error};}catch(i){c={type:"RESPONSE",success:false,error:i instanceof Error?i.message:String(i)};}else c={type:"RESPONSE",success:false,error:`Unknown action: ${s.action}`};t.send(e,r.from,{...c,correlationId:r.correlationId??r.id,replyTo:r.correlationId??r.id});}},{types:["REQUEST"]});return {onRequest(r,s){n.set(r,s);},offRequest(r){n.delete(r);},destroy(){o.unsubscribe(),n.clear();}}}function Yn(t,e){let n=null,o=t.listen(e,async r=>{if(r.type==="DELEGATION"&&n){let s=r,a=Date.now(),c;try{let i=await n(s.task,s.context);c={type:"DELEGATION_RESULT",success:i.success,result:i.result,error:i.error,metrics:i.metrics??{durationMs:Date.now()-a}};}catch(i){c={type:"DELEGATION_RESULT",success:false,error:i instanceof Error?i.message:String(i),metrics:{durationMs:Date.now()-a}};}t.send(e,r.from,{...c,correlationId:r.correlationId??r.id,replyTo:r.correlationId??r.id});}},{types:["DELEGATION"]});return {onDelegation(r){n=r;},offDelegation(){n=null;},destroy(){o.unsubscribe(),n=null;}}}function Qn(t,e){let n=new Map,o=t.listen(e,r=>{if(r.type==="UPDATE"){let s=r,a=n.get(s.topic)??[];for(let c of a)c(s.content);}},{types:["UPDATE"]});return {subscribe(r,s){let a=new Map;for(let c of r){let i=n.get(c)??[],u=l=>s(c,l);a.set(c,u),i.push(u),n.set(c,i);}return t.broadcast(e,{type:"SUBSCRIBE",topics:r}),()=>{for(let[c,i]of a){let u=n.get(c);if(u){let l=u.indexOf(i);l>=0&&u.splice(l,1),u.length===0&&n.delete(c);}}a.clear(),t.broadcast(e,{type:"UNSUBSCRIBE",topics:r});}},publish(r,s){t.broadcast(e,{type:"UPDATE",topic:r,content:s});},destroy(){o.unsubscribe(),n.clear();}}}var Xn=[{type:"ssn",pattern:/\b(\d{3}[-\s]?\d{2}[-\s]?\d{4})\b/g,validate:t=>{let e=t.replace(/[-\s]/g,"");return !(e.startsWith("000")||e.startsWith("666")||e.startsWith("9")||e.slice(3,5)==="00"||e.slice(5)==="0000")},confidence:.95},{type:"credit_card",pattern:/\b((?:\d{4}[-\s]?\d{4}[-\s]?\d{4}[-\s]?\d{4})|\d{13,19})\b/g,validate:t=>{let e=t.replace(/[-\s]/g,"");if(e.length<13||e.length>19)return false;let n=0,o=false;for(let r=e.length-1;r>=0;r--){let s=e[r];if(!s)continue;let a=Number.parseInt(s,10);o&&(a*=2,a>9&&(a-=9)),n+=a,o=!o;}return n%10===0},confidence:.95},{type:"email",pattern:/\b([A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,})\b/gi,confidence:.9},{type:"phone",pattern:/\b(\+?1?[-.\s]?\(?[0-9]{3}\)?[-.\s]?[0-9]{3}[-.\s]?[0-9]{4})\b/g,validate:t=>{let e=t.replace(/\D/g,"");return e.length>=10&&e.length<=11},confidence:.8},{type:"date_of_birth",pattern:/\b(born|dob|birth.?date|date.?of.?birth)[:.\s]+(\d{1,4}[-/]\d{1,2}[-/]\d{1,4})\b/gi,valueGroup:2,confidence:.85},{type:"ip_address",pattern:/\b(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})\b/g,validate:t=>{let n=t.split(".").map(s=>Number.parseInt(s,10));if(n.some(s=>Number.isNaN(s)||s<0||s>255))return false;let[o,r]=n;return !(o===10||o===172&&r>=16&&r<=31||o===192&&r===168||o===127||o===169&&r===254||t==="0.0.0.0"||t==="255.255.255.255")},confidence:.9},{type:"bank_account",pattern:/\b(account|acct)[\s#:]+(\d{8,17})\b/gi,valueGroup:2,confidence:.7},{type:"passport",pattern:/\b(passport)[\s#:]+([A-Z0-9]{6,9})\b/gi,valueGroup:2,confidence:.75},{type:"driver_license",pattern:/\b(driver'?s?\s*licen[cs]e|dl)[\s#:]+([A-Z0-9]{5,15})\b/gi,valueGroup:2,confidence:.7},{type:"medical_id",pattern:/\b(mrn|medical.?record|patient.?id)[\s#:]+([A-Z0-9-]{6,15})\b/gi,valueGroup:2,confidence:.7},{type:"national_id",pattern:/\b(national.?id|nin|identity.?number|identity.?card|id.?number)[\s#:]+([A-Z0-9-]{6,20})\b/gi,valueGroup:2,confidence:.85}];function Zn(t){let e=[],n="street|st|avenue|ave|road|rd|drive|dr|lane|ln|court|ct|way|boulevard|blvd|circle|cir|place|pl",o=new RegExp(`\\b(\\d{1,5}\\s+(?:\\w+\\s+){1,4}(?:${n})\\b[^\\n]{0,50}\\b[A-Z]{2}\\s+\\d{5}(?:-\\d{4})?)\\b`,"gi"),r;for(;(r=o.exec(t))!==null;)e.push({type:"address",value:r[0],position:{start:r.index,end:r.index+r[0].length},confidence:.7});return e}var Oe=["mr","mrs","ms","miss","dr","prof","sir","madam","name is","called","known as","signed by","from","dear","hi","hello","contact","recipient"];function er(t){let e=[],n=Oe.join("|"),o=new RegExp(`\\b(${n})[.,:]?\\s+([A-Z][a-z]{1,20}(?:\\s[A-Z][a-z]{1,20}){0,2})\\b`,"gi"),r;for(;(r=o.exec(t))!==null;){let s=r[2],a=r[1];s&&(s.split(/\s+/).length>=2||a&&Oe.some(c=>a.toLowerCase().includes(c)))&&e.push({type:"name",value:s,position:{start:r.index,end:r.index+r[0].length},confidence:.6,context:r[0]});}return e}var $e=1e5;function tr(t,e){let n=[],o=new RegExp(t.pattern.source,t.pattern.flags),r=t.valueGroup??1,s;for(;(s=o.exec(e))!==null;){let a=s[r]??s[0],c=s.index,i=s.index+s[0].length,u=e.slice(Math.max(0,c-20),i+20);t.validate&&!t.validate(a,u)||n.push({type:t.type,value:a,position:{start:c,end:i},confidence:t.confidence,context:u});}return n}var se={name:"regex",async detect(t,e){if(t.length>$e)throw new Error(`[Directive] Input exceeds maximum length of ${$e} characters for PII detection. Truncate input or process in chunks.`);let n=[],o=new Set(e);for(let r of Xn)o.has(r.type)&&n.push(...tr(r,t));return o.has("address")&&n.push(...Zn(t)),o.has("name")&&n.push(...er(t)),n}},nr=new Set(["ssn","credit_card","date_of_birth","medical_id","national_id","passport","driver_license","bank_account"]);function rr(t,e){let{start:n,end:o}=t.position;return Number.isInteger(n)&&Number.isInteger(o)&&n>=0&&n<o&&o<=e}function or(t,e){switch(e){case "placeholder":return "[REDACTED]";case "typed":return nr.has(t.type)?"[REDACTED]":`[${t.type.toUpperCase()}]`;case "masked":{if(t.type!=="credit_card")return "****";let n=t.value.replace(/\D/g,"");return `****${n.length>4?n.slice(-4):""}`}case "hashed":return `[HASH:${sr(t.value)}]`}}function X(t,e,n="typed"){let r=[...e.filter(i=>rr(i,t.length))].sort((i,u)=>{if(u.confidence!==i.confidence)return u.confidence-i.confidence;let l=i.position.end-i.position.start,p=u.position.end-u.position.start;return p!==l?p-l:i.position.start-u.position.start}),s=[];for(let i of r)s.some(l=>i.position.start<l.position.end&&l.position.start<i.position.end)||s.push(i);let a=s.sort((i,u)=>u.position.start-i.position.start),c=t;for(let i of a){let u=or(i,n);c=c.slice(0,i.position.start)+u+c.slice(i.position.end);}return c}function sr(t){let o=2166136261;for(let r=0;r<t.length;r++)o^=t.charCodeAt(r),o=Math.imul(o,16777619);return (o>>>0).toString(16).padStart(8,"0")}var Ne=["ssn","credit_card","email","phone","date_of_birth","bank_account"];function _e(t={}){let{types:e=Ne,detector:n="regex",redact:o=false,redactionStyle:r="typed",minConfidence:s=.7,onDetected:a,allowlist:c=[],minItemsToBlock:i=1,detectorTimeout:u=5e3}=t,l=n==="regex"?se:n,p=new Set(c.map(f=>f.toLowerCase().trim()));async function d(f,y){if(l===se)return l.detect(f,y);let m,S=l.detect(f,y),h=new Promise((g,v)=>{m=setTimeout(()=>v(new Error(`[Directive] PII detector '${l.name}' timed out after ${u}ms`)),u);});S.catch(()=>{}),h.catch(()=>{});try{return await Promise.race([S,h])}finally{clearTimeout(m);}}return async f=>{let m=(await d(f.input,e)).filter(S=>!(S.confidence<s||p.has(S.value.toLowerCase().trim())));if(m.length>0&&a?.(m),m.length>=i){if(o)return {passed:true,transformed:X(f.input,m,r)};let S={};for(let g of m)S[g.type]=(S[g.type]||0)+1;return {passed:false,reason:`PII detected (${Object.entries(S).map(([g,v])=>`${g}: ${v}`).join(", ")})`}}return {passed:true}}}function ar(t={}){let e=_e(t);return async(n,o)=>{let r=typeof n.output=="string"?n.output:JSON.stringify(n.output);return e({input:r,agentName:n.agentName},o)}}async function ae(t,e={}){let{types:n=Ne,detector:o="regex",minConfidence:r=.7,timeout:s=5e3}=e,a=o==="regex"?se:o,c;if(a===se)c=await a.detect(t,n);else {let l,p=a.detect(t,n),d=new Promise((f,y)=>{l=setTimeout(()=>y(new Error(`[Directive] PII detector '${a.name}' timed out after ${s}ms`)),s);});p.catch(()=>{}),d.catch(()=>{});try{c=await Promise.race([p,d]);}finally{clearTimeout(l);}}let i=c.filter(l=>l.confidence>=r),u={};for(let l of i)u[l.type]=(u[l.type]||0)+1;return {detected:i.length>0,items:i,typeCounts:u}}async function ir(t,e={}){let n=await ae(t,e);return n.detected?{...n,redactedText:X(t,n.items,e.style??"typed")}:{...n}}var cr=1e4,ur=10080*60*1e3,lr=6e4,je="0".repeat(64);function dr(){return globalThis.crypto?.randomUUID?.()??`${Date.now().toString(36)}-${Math.random().toString(36).slice(2,11)}`}function pr(t){return new TextEncoder().encode(t)}function gr(t){return Array.from(t).map(e=>e.toString(16).padStart(2,"0")).join("")}async function Fe(t){let e=pr(t),n=await globalThis.crypto.subtle.digest("SHA-256",e);return gr(new Uint8Array(n))}function Ge(t){let{id:e,timestamp:n,eventType:o,previousHash:r,payload:s,actorId:a,sessionId:c}=t;return JSON.stringify({id:e,timestamp:n,eventType:o,previousHash:r,payload:s,actorId:a,sessionId:c})}function mr(t){return JSON.parse(JSON.stringify(t))}async function fr(t,e){let n=mr(t);async function o(r){if(typeof r=="string"){let s=await ae(r,{types:e.types,minConfidence:e.minConfidence??.7});if(s.detected){let a=e.allowlist?s.items.filter(c=>!e.allowlist.includes(c.value.toLowerCase())):s.items;if(a.length>0)return X(r,a,e.redactionStyle)}return r}if(Array.isArray(r))return Promise.all(r.map(o));if(r&&typeof r=="object"){let s={};for(let[a,c]of Object.entries(r))s[a]=await o(c);return s}return r}for(let[r,s]of Object.entries(n))n[r]=await o(s);return n}function yr(t={}){let{maxEntries:e=cr,retentionMs:n=ur,exportInterval:o=lr,exporter:r,piiMasking:s,signing:a,sessionId:c,actorId:i,events:u={}}=t,l=[],p=0,d=0,f=0,y=true,m;function S(){return l.length===0?je:l[l.length-1].hash}async function h(g,v,w){let M={id:dr(),timestamp:Date.now(),eventType:g,previousHash:S(),payload:v,actorId:i,sessionId:c};s?.enabled&&(M.maskedPayload=await fr(v,s));let x=Ge(M),P=await Fe(x),O={...M,hash:P};for(a&&(O.signature=await a.signFn(P)),l.push(O);l.length>e;)l.shift(),d++,p>0&&p--;return u.onEntryAdded?.(O),O}return r&&o>0&&(m=setInterval(async()=>{try{let g=l.slice(p);g.length>0&&(await r(g),f+=g.length,p=l.length);}catch(g){u.onExportError?.(g instanceof Error?g:new Error(String(g)),l.slice(p));}},o)),{getEntries(g){let v=[...l];if(g){if(g.eventTypes?.length){let w=new Set(g.eventTypes);v=v.filter(M=>w.has(M.eventType));}g.actorId&&(v=v.filter(w=>w.actorId===g.actorId)),g.sessionId&&(v=v.filter(w=>w.sessionId===g.sessionId)),g.since!==void 0&&(v=v.filter(w=>w.timestamp>=g.since)),g.until!==void 0&&(v=v.filter(w=>w.timestamp<=g.until)),g.offset!==void 0&&(v=v.slice(g.offset)),g.limit!==void 0&&(v=v.slice(0,g.limit));}return v},async verifyChain(){if(l.length===0)return {valid:true,entriesVerified:0,verifiedAt:Date.now()};l[0].previousHash;for(let v=0;v<l.length;v++){let w=l[v],M=Ge({id:w.id,timestamp:w.timestamp,eventType:w.eventType,previousHash:w.previousHash,payload:w.payload,actorId:w.actorId,sessionId:w.sessionId}),x=await Fe(M);if(w.hash!==x){y=false;let P={valid:false,entriesVerified:v,brokenAt:{index:v,entryId:w.id,expectedHash:x,actualHash:w.hash},verifiedAt:Date.now()};return u.onChainBroken?.(P),P}if(v>0){let P=l[v-1];if(w.previousHash!==P.hash){y=false;let O={valid:false,entriesVerified:v,brokenAt:{index:v,entryId:w.id,expectedHash:P.hash,actualHash:w.previousHash},verifiedAt:Date.now()};return u.onChainBroken?.(O),O}}if(a?.verifyFn&&w.signature&&!await a.verifyFn(w.hash,w.signature)){y=false;let O={valid:false,entriesVerified:v,brokenAt:{index:v,entryId:w.id,expectedHash:"signature-invalid",actualHash:w.signature},verifiedAt:Date.now()};return u.onChainBroken?.(O),O}}return y=true,{valid:true,entriesVerified:l.length,verifiedAt:Date.now()}},async export(g){let v=[...l];return g!==void 0&&(v=v.filter(w=>w.timestamp>=g)),r&&v.length>0&&(await r(v),f+=v.length),v},prune(){let g=Date.now()-n,v=l.length;for(;l.length>0&&l[0].timestamp<g;)l.shift(),p>0&&p--;let w=v-l.length;return d+=w,w},getStats(){let g={};for(let v of l)g[v.eventType]=(g[v.eventType]??0)+1;return {totalEntries:l.length,byEventType:g,oldestEntry:l[0]?.timestamp,newestEntry:l[l.length-1]?.timestamp,entriesPruned:d,entriesExported:f,chainIntegrity:y}},async destroy(){if(m&&(clearInterval(m),m=void 0),r)try{let g=l.slice(p);g.length>0&&(await r(g),f+=g.length);}catch(g){u.onExportError?.(g instanceof Error?g:new Error(String(g)),l.slice(p));}},addEntry(g,v){return h(g,v)},createPlugin(){return {name:"audit-trail",onFactSet:(g,v,w)=>{h("fact.set",{key:g,value:v,prev:w}).catch(console.error);},onFactsBatch:g=>{h("fact.batch",{changes:g.map(v=>({key:v.key,value:v.value,prev:v.prev}))}).catch(console.error);},onRequirementCreated:g=>{h("requirement.created",{id:g.id,type:g.requirement.type,payload:g.requirement}).catch(console.error);},onRequirementMet:(g,v)=>{h("requirement.met",{id:g.id,type:g.requirement.type,byResolver:v}).catch(console.error);},onResolverStart:(g,v)=>{h("resolver.start",{resolver:g,requirementId:v.id,requirementType:v.requirement.type}).catch(console.error);},onResolverComplete:(g,v,w)=>{h("resolver.complete",{resolver:g,requirementId:v.id,requirementType:v.requirement.type,duration:w}).catch(console.error);},onResolverError:(g,v,w)=>{h("resolver.error",{resolver:g,requirementId:v.id,requirementType:v.requirement.type,error:w instanceof Error?w.message:String(w)}).catch(console.error);},onError:g=>{h("error.occurred",{source:g.source,sourceId:g.sourceId,message:g.message,context:g.context}).catch(console.error);},onErrorRecovery:(g,v)=>{h("error.recovery",{source:g.source,message:g.message,strategy:v}).catch(console.error);}}}}}function hr(t){return {onAgentStart:(e,n)=>{t.addEntry("agent.run.start",{agentName:e,input:n});},onAgentComplete:(e,n,o,r)=>{t.addEntry("agent.run.complete",{agentName:e,output:n,tokens:o,cost:r});},onAgentError:(e,n)=>{t.addEntry("agent.run.error",{agentName:e,error:n.message,stack:n.stack});},onToolStart:(e,n,o)=>{t.addEntry("tool.call.start",{toolName:e,toolCallId:n,args:o});},onToolComplete:(e,n,o)=>{t.addEntry("tool.call.complete",{toolName:e,toolCallId:n,result:o});},onToolError:(e,n,o)=>{t.addEntry("tool.call.error",{toolName:e,toolCallId:n,error:o.message});},onApprovalRequested:(e,n,o)=>{t.addEntry("approval.requested",{toolName:e,toolCallId:n,args:o});},onApprovalGranted:(e,n)=>{t.addEntry("approval.granted",{toolName:e,toolCallId:n});},onApprovalDenied:(e,n,o)=>{t.addEntry("approval.denied",{toolName:e,toolCallId:n,reason:o});}}}var Z=[{pattern:/ignore\s+(all\s+)?(previous|prior|above|earlier)\s+(instructions?|prompts?|rules?|guidelines?)/i,name:"ignore-previous",severity:"critical",category:"instruction_override"},{pattern:/disregard\s+(all\s+)?(previous|prior|above|earlier)\s+(instructions?|prompts?)/i,name:"disregard-previous",severity:"critical",category:"instruction_override"},{pattern:/forget\s+(all\s+)?(previous|prior|above|earlier)\s+(instructions?|prompts?)/i,name:"forget-previous",severity:"critical",category:"instruction_override"},{pattern:/override\s+(the\s+)?(system|base)\s+(prompt|instructions?)/i,name:"override-system",severity:"critical",category:"instruction_override"},{pattern:/\bDAN\s+(mode|jailbreak)\b/i,name:"dan-mode",severity:"critical",category:"jailbreak"},{pattern:/\bjailbreak(ed)?\s*(mode)?\b/i,name:"jailbreak-keyword",severity:"high",category:"jailbreak"},{pattern:/developer\s+mode\s+(enabled|activated|on)/i,name:"developer-mode",severity:"critical",category:"jailbreak"},{pattern:/pretend\s+(you\s+)?(are|can|have)\s+(no\s+)?(restrictions?|limits?|boundaries?|ethics)/i,name:"pretend-no-restrictions",severity:"high",category:"jailbreak"},{pattern:/you\s+(now\s+)?have\s+no\s+(ethical\s+)?(restrictions?|guidelines?|boundaries?)/i,name:"no-restrictions",severity:"high",category:"jailbreak"},{pattern:/you\s+are\s+now\s+(a|an)\s+\w+\s+(that|who)\s+(can|will|must)/i,name:"role-assignment",severity:"medium",category:"role_manipulation"},{pattern:/from\s+now\s+on,?\s+(you\s+)?(will|must|should)\s+(only\s+)?/i,name:"from-now-on",severity:"medium",category:"role_manipulation"},{pattern:/^(system|assistant|user):\s*/im,name:"fake-role-marker",severity:"high",category:"context_manipulation"},{pattern:/<\|?(system|endofprompt|im_start|im_end)\|?>/i,name:"special-token-injection",severity:"critical",category:"context_manipulation"},{pattern:/```(system|assistant|instructions?)\n/i,name:"markdown-code-injection",severity:"medium",category:"delimiter_injection"},{pattern:/<system>|<\/system>|<instructions?>|<\/instructions?>/i,name:"xml-tag-injection",severity:"high",category:"delimiter_injection"},{pattern:/fetch\s+(content\s+)?(from|at)\s+(the\s+)?url/i,name:"url-fetch-instruction",severity:"medium",category:"indirect_injection"},{pattern:/execute\s+(the\s+)?(code|script|command)\s+(from|in|at)/i,name:"execute-from-source",severity:"high",category:"indirect_injection"}],ve=[...Z,{pattern:/act\s+as\s+(if\s+)?(you\s+)?(were|are|can)/i,name:"act-as",severity:"low",category:"role_manipulation"},{pattern:/new\s+instructions?:/i,name:"new-instructions",severity:"medium",category:"instruction_override"},{pattern:/\[system\]|\[admin\]|\[developer\]/i,name:"bracket-role-marker",severity:"medium",category:"context_manipulation"},{pattern:/base64|rot13|decode\s+(this|the)/i,name:"encoding-reference",severity:"low",category:"encoding_evasion"},{pattern:/\u200b|\u200c|\u200d|\u2060|\ufeff/,name:"zero-width-chars",severity:"medium",category:"encoding_evasion"}],Le=1e5;function Se(t,e=Z){if(t.length>Le)throw new Error(`[Directive] Input exceeds maximum length of ${Le} characters for injection detection. Truncate input or process in chunks.`);let n=[];for(let{pattern:a,name:c,severity:i,category:u}of e){let p=new RegExp(a.source,a.flags).exec(t);p&&n.push({name:c,category:u,severity:i,match:p[0],position:p.index});}let o={low:10,medium:25,high:50,critical:100},r=n.reduce((a,c)=>a+o[c.severity],0),s=Math.min(100,r);return {detected:n.length>0,patterns:n,riskScore:s}}function Be(t,e=Z){let n=t.replace(/\u200b|\u200c|\u200d|\u2060|\ufeff/g,""),o=e.map(u=>`(${u.pattern.source})`);if(o.length===0)return n;let r=e.some(u=>u.pattern.flags.includes("g")),s=e.some(u=>u.pattern.flags.includes("i")),a=e.some(u=>u.pattern.flags.includes("m")),c=`${r?"g":""}${s?"i":""}${a?"m":""}`,i=new RegExp(o.join("|"),c||"gi");return n=n.replace(i,"[REDACTED]"),n}function Ue(t={}){let{additionalPatterns:e=[],replacePatterns:n,strictMode:o=false,blockThreshold:r=50,sanitize:s=false,onBlocked:a,ignoreCategories:c=[]}=t,i;if(n?i=n:i=o?[...ve]:[...Z],i=[...i,...e],c.length>0){let u=new Set(c);i=i.filter(l=>!u.has(l.category));}return u=>{let l=Se(u.input,i);if(l.detected&&l.riskScore>=r){if(a?.(u.input,l),s)return {passed:true,transformed:Be(u.input,i)};let p=l.patterns.sort((d,f)=>{let y={critical:0,high:1,medium:2,low:3};return y[d.severity]-y[f.severity]}).slice(0,3).map(d=>d.name).join(", ");return {passed:false,reason:`Prompt injection detected (risk: ${l.riskScore}%, patterns: ${p})`}}return {passed:true}}}function br(t,e){return `[UNTRUSTED_CONTENT source="${e}"]
|
|
25
25
|
${t}
|
|
26
|
-
[/UNTRUSTED_CONTENT]`}function
|
|
27
|
-
`)||i.includes('"')?`"${i.replace(/"/g,'""')}"`:i});
|
|
28
|
-
`)}function Sr(){let t=new Map,e=new Map,r=new Map;return {async getSubjectData(s,n){let o=[];for(let[a,c]of t){if(n&&!n.includes(a))continue;let i=c.get(s);i&&i.length>0&&o.push({category:a,records:[...i]});}return o},async deleteSubjectData(s,n){let o=0;for(let[a,c]of t){if(n&&!n.includes(a))continue;let i=c.get(s);i&&(o+=i.length,c.delete(s));}return o},async anonymizeSubjectData(s,n){let o=0;for(let[a,c]of t){if(n&&!n.includes(a))continue;let i=c.get(s);if(i)for(let u of i)u.data={...u.data,_anonymized:true,_anonymizedAt:Date.now()},o++;}return o},async getExpiredData(s,n){let o=[],a=t.get(s);if(a)for(let c of a.values())for(let i of c)i.createdAt<n&&o.push({id:i.id,createdAt:i.createdAt});return o},async deleteByIds(s){let n=new Set(s),o=0;for(let a of t.values())for(let[c,i]of a){let u=i.filter(l=>!n.has(l.id));u.length!==i.length&&(o+=i.length-u.length,u.length===0?a.delete(c):a.set(c,u));}return o},async storeConsent(s){e.set(`${s.subjectId}:${s.purpose}`,s);},async getConsent(s,n){return e.get(`${s}:${n}`)??null},async getConsentsBySubject(s){let n=[];for(let[o,a]of e)o.startsWith(`${s}:`)&&n.push(a);return n},async getConsentsByPurpose(s){let n=[];for(let[o,a]of e)o.endsWith(`:${s}`)&&n.push(a);return n},async storeDeletionCertificate(s){r.set(s.subjectId,s);}}}function Er(t){let{storage:e,retention:r,exportExpirationMs:s=864e5,events:n={}}=t,o={async grant(a,c,i={}){let u={subjectId:a,purpose:c,granted:true,grantedAt:Date.now(),expiresAt:i.expiresAt,source:i.source,version:i.version};return await e.storeConsent(u),n.onConsentChange?.(u),u},async revoke(a,c){let i=await e.getConsent(a,c);if(!i)return null;let u={...i,granted:false,revokedAt:Date.now()};return await e.storeConsent(u),n.onConsentChange?.(u),u},async check(a,c){let i=await e.getConsent(a,c);return !(!i||!i.granted||i.expiresAt&&i.expiresAt<Date.now())},async getForSubject(a){return e.getConsentsBySubject(a)},async getForPurpose(a){return e.getConsentsByPurpose(a)}};return {async exportData(a){try{let c=await e.getSubjectData(a.subjectId,a.categories),i=[],u=[];for(let{category:y,records:f}of c){u.push(y);for(let m of f)i.push({category:y,...m});}if(a.includeAudit&&e.getAuditEntries){let y=await e.getAuditEntries(a.subjectId);u.push("audit");for(let f of y)i.push({category:"audit",id:f.id,data:f.payload,createdAt:f.timestamp});}let l;a.format==="csv"?l=br(i.map(y=>({category:y.category,id:y.id,createdAt:new Date(y.createdAt).toISOString(),...y.data}))):l=JSON.stringify({subjectId:a.subjectId,exportedAt:new Date().toISOString(),recordCount:i.length,categories:u,records:i},null,2);let p=await Be(l),d={success:!0,subjectId:a.subjectId,format:a.format,data:l,categories:u,recordCount:i.length,checksum:p,exportedAt:Date.now(),expiresAt:Date.now()+s};return n.onExport?.(d),d}catch(c){return {success:false,subjectId:a.subjectId,format:a.format,data:"",categories:[],recordCount:0,checksum:"",exportedAt:Date.now(),error:c instanceof Error?c.message:String(c)}}},async deleteData(a){try{let c=0,i=[];a.anonymize?c=await e.anonymizeSubjectData(a.subjectId,a.categories):c=await e.deleteSubjectData(a.subjectId,a.categories),a.categories?i.push(...a.categories):a.scope==="all"&&i.push("all");let u=JSON.stringify({subjectId:a.subjectId,type:a.anonymize?"anonymization":"hard",scope:a.scope,categories:i,recordCount:c,deletedAt:Date.now(),reason:a.reason}),l={id:yr(),subjectId:a.subjectId,type:a.anonymize?"anonymization":"hard",scope:a.scope,categories:i,recordCount:c,deletedAt:Date.now(),reason:a.reason,hash:await Be(u)};await e.storeDeletionCertificate(l);let p={success:!0,subjectId:a.subjectId,scope:a.scope,anonymized:a.anonymize??!1,recordsAffected:c,categoriesAffected:i,certificate:l,deletedAt:Date.now()};return n.onDelete?.(p),p}catch(c){return {success:false,subjectId:a.subjectId,scope:a.scope,anonymized:a.anonymize??false,recordsAffected:0,categoriesAffected:[],certificate:{id:"error",subjectId:a.subjectId,type:"hard",scope:a.scope,categories:[],recordCount:0,deletedAt:Date.now(),hash:""},deletedAt:Date.now(),error:c instanceof Error?c.message:String(c)}}},consent:o,async enforceRetention(){if(!r)return 0;let a=0,c=Date.now(),i=new Set;if(r.categoryRetention)for(let u of Object.keys(r.categoryRetention))i.add(u);i.add("default");for(let u of i){let l=r.categoryRetention?.[u]??r.defaultRetentionMs,p=c-l,d=await e.getExpiredData(u,p);if(d.length>0){await r.onBeforeDelete?.({category:u,count:d.length});let y=await e.deleteByIds(d.map(f=>f.id));a+=y,r.onAfterDelete?.({category:u,count:y}),n.onRetentionEnforced?.(u,y);}}return a},createConsentGuardrail(a){return async c=>{let u=c.input.match(/user[_-]?id[:\s]*([a-zA-Z0-9-]+)/i)?.[1];return u?await o.check(u,a)?{passed:true}:{passed:false,reason:`No consent for '${a}' from subject ${u}`}:{passed:true}}},async getDeletionCertificate(a){return null}}}function J(t,e){if(t.length!==e.length)throw new Error(`Vector dimensions must match: ${t.length} vs ${e.length}`);let r=0,s=0,n=0;for(let o=0;o<t.length;o++){let a=t[o],c=e[o];r+=a*c,s+=a*a,n+=c*c;}return s=Math.sqrt(s),n=Math.sqrt(n),s===0||n===0?0:r/(s*n)}function Rr(t,e,r,s){let n=null;for(let o of e){if(s&&o.agentName&&o.agentName!==s)continue;let a=J(t,o.queryEmbedding);a>=r&&(!n||a>n.similarity)&&(n={entry:o,similarity:a});}return n}function Ue(){let t=new Map;function e(r){let s=t.get(r);return s||(s=new Map,t.set(r,s)),s}return {async getEntries(r){return Array.from(e(r).values())},async addEntry(r,s){e(r).set(s.id,s);},async updateEntry(r,s,n){let o=e(r),a=o.get(s);a&&o.set(s,{...a,...n});},async removeEntry(r,s){e(r).delete(s);},async clear(r){t.delete(r);}}}function wr(t){let{embedder:e,similarityThreshold:r=.9,maxCacheSize:s=1e3,ttlMs:n=36e5,namespace:o="default",storage:a=Ue(),onHit:c,onMiss:i,onError:u,perAgent:l=false}=t,p={totalEntries:0,totalHits:0,totalMisses:0,hitRate:0,avgSimilarityOnHit:0,oldestEntry:null,newestEntry:null},d=0;function y(m){if(p.totalEntries=m.length,p.hitRate=p.totalHits+p.totalMisses>0?p.totalHits/(p.totalHits+p.totalMisses):0,p.avgSimilarityOnHit=p.totalHits>0?d/p.totalHits:0,m.length>0){let S=m.map(h=>h.createdAt);p.oldestEntry=Math.min(...S),p.newestEntry=Math.max(...S);}else p.oldestEntry=null,p.newestEntry=null;}async function f(){let m=await a.getEntries(o),S=Date.now();for(let g of m)S-g.createdAt>n&&await a.removeEntry(o,g.id);let h=await a.getEntries(o);if(h.length>s){let b=h.sort((R,x)=>R.accessedAt-x.accessedAt).slice(0,h.length-s);for(let R of b)await a.removeEntry(o,R.id);}}return {async lookup(m,S){let h=Date.now();try{let g=await e(m),b=await a.getEntries(o),R=Rr(g,b,r,l?S:void 0);return R?(await a.updateEntry(o,R.entry.id,{accessedAt:Date.now(),accessCount:R.entry.accessCount+1}),p.totalHits++,d+=R.similarity,y(b),c?.(R.entry,R.similarity),{hit:!0,entry:R.entry,similarity:R.similarity,latencyMs:Date.now()-h}):(p.totalMisses++,y(b),i?.(m),{hit:!1,latencyMs:Date.now()-h})}catch(g){return p.totalMisses++,u?.(g instanceof Error?g:new Error(String(g))),{hit:false,latencyMs:Date.now()-h}}},async store(m,S,h,g={}){let b=await e(m),R={id:globalThis.crypto?.randomUUID?.()??`${Date.now()}-${Math.random().toString(36).slice(2,11)}`,query:m,queryEmbedding:b,response:S,metadata:g,createdAt:Date.now(),accessedAt:Date.now(),accessCount:0,agentName:l?h:void 0};await a.addEntry(o,R),await f();let x=await a.getEntries(o);y(x);},async invalidate(m){let S=await a.getEntries(o),h=0;for(let b of S)m(b)&&(await a.removeEntry(o,b.id),h++);let g=await a.getEntries(o);return y(g),h},async clear(){await a.clear(o),p={totalEntries:0,totalHits:0,totalMisses:0,hitRate:0,avgSimilarityOnHit:0,oldestEntry:null,newestEntry:null},d=0;},getStats(){return {...p}},async export(){return a.getEntries(o)},async import(m){for(let h of m)await a.addEntry(o,h);await f();let S=await a.getEntries(o);y(S);}}}function Cr(t){let{cache:e}=t;return async r=>{let s=await e.lookup(r.input,r.agentName);return s.hit&&s.entry?{passed:false,cacheHit:true,reason:`Cache hit (similarity: ${(s.similarity*100).toFixed(1)}%)`,cachedResponse:s.entry.response,similarity:s.similarity}:{passed:true,cacheHit:false}}}function Ar(t=128){return async e=>{let r=new Array(t).fill(0);for(let n=0;n<e.length;n++){let o=e.charCodeAt(n);r[n%t]+=o/256;}let s=Math.sqrt(r.reduce((n,o)=>n+o*o,0));if(s>0)for(let n=0;n<t;n++)r[n]/=s;return r}}function Mr(t){let{batchSize:e=20,embedBatch:r,maxWaitMs:s=50}=t;if(e<1||!Number.isFinite(e))throw new Error(`[Directive SemanticCache] batchSize must be >= 1, got ${e}`);let n=[],o=null,a=false;async function c(){if(n.length===0)return;let i=n;n=[],o&&(clearTimeout(o),o=null);try{let u=i.map(p=>p.text),l=await r(u);if(l.length!==i.length)throw new Error(`[Directive SemanticCache] embedBatch returned ${l.length} embeddings for ${i.length} texts. The embedBatch function must return exactly one embedding per input text.`);for(let p=0;p<i.length;p++)i[p].resolve(l[p]);}catch(u){let l=u instanceof Error?u:new Error(String(u));for(let p of i)p.reject(l);}}return {async embed(i){if(a)throw new Error("BatchedEmbedder has been destroyed");return new Promise((u,l)=>{n.push({text:i,resolve:u,reject:l}),n.length>=e?c():o||(o=setTimeout(c,s));})},async flush(){await c();},destroy(){a=true,o&&(clearTimeout(o),o=null);let i=n;n=[];let u=new Error("BatchedEmbedder destroyed");for(let l of i)l.reject(u);}}}function xr(){let t=new Map,e=null;function r(s){if(e===null)e=s.length;else if(s.length!==e)throw new Error(`[Directive ANNIndex] Dimension mismatch: expected ${e}, got ${s.length}`)}return {add(s,n){r(n),t.set(s,n);},remove(s){t.delete(s);},search(s,n,o=0){if(e!==null&&s.length!==e)throw new Error(`[Directive ANNIndex] Query dimension mismatch: expected ${e}, got ${s.length}`);let a=[];for(let[c,i]of t){let u=J(s,i);u>=o&&a.push({id:c,similarity:u});}return a.sort((c,i)=>i.similarity-c.similarity),a.slice(0,n)},rebuild(){},size(){return t.size},clear(){t.clear(),e=null;},needsRebuild(){return false}}}function ze(t,e){return 1-J(t,e)}function be(t,e){if(t.length===0)return null;let r=Math.floor(e()*t.length),s=t[r],n=t.filter((l,p)=>p!==r);if(n.length===0)return {id:s.id,embedding:s.embedding,mu:0,left:null,right:null};let o=n.map(l=>({item:l,distance:ze(s.embedding,l.embedding)}));o.sort((l,p)=>l.distance-p.distance);let a=Math.floor(o.length/2),c=o[a].distance,i=o.slice(0,a).map(l=>l.item),u=o.slice(a).map(l=>l.item);return {id:s.id,embedding:s.embedding,mu:c,left:be(i,e),right:be(u,e)}}function Z(t,e,r,s,n,o){if(!t)return;let a=ze(e,t.embedding),c=1-a;c>=s&&(n.push({id:t.id,similarity:c}),n.sort((i,u)=>u.similarity-i.similarity),n.length>r&&n.pop(),n.length===r&&(o.value=1-n[n.length-1].similarity)),a<t.mu?(Z(t.left,e,r,s,n,o),a+o.value>=t.mu&&Z(t.right,e,r,s,n,o)):(Z(t.right,e,r,s,n,o),a-o.value<=t.mu&&Z(t.left,e,r,s,n,o));}function Tr(t={}){let{random:e=Math.random}=t,r=new Map,s=null,n=false,o=null;function a(c){if(o===null)o=c.length;else if(c.length!==o)throw new Error(`[Directive ANNIndex] Dimension mismatch: expected ${o}, got ${c.length}`)}return {add(c,i){a(i),r.set(c,i),n=true;},remove(c){r.delete(c),n=true;},search(c,i,u=0){if(o!==null&&c.length!==o)throw new Error(`[Directive ANNIndex] Query dimension mismatch: expected ${o}, got ${c.length}`);if(n||!s){let d=[];for(let[y,f]of r){let m=J(c,f);m>=u&&d.push({id:y,similarity:m});}return d.sort((y,f)=>f.similarity-y.similarity),d.slice(0,i)}let l=[],p={value:Number.POSITIVE_INFINITY};return Z(s,c,i,u,l,p),l},rebuild(){let c=Array.from(r.entries()).map(([i,u])=>({id:i,embedding:u}));s=be(c,e),n=false;},size(){return r.size},clear(){r.clear(),s=null,n=false,o=null;},needsRebuild(){return n}}}function Se(t={}){let{bufferSize:e=100}=t;if(e<1||!Number.isFinite(e))throw new Error(`[Directive StreamChannel] bufferSize must be >= 1, got ${e}`);let r=[],s="open",n=null,o=null,a=null,c=false;function i(y){if(o){let f=o;o=null,f.resolve({value:y,done:false});}}function u(){if(o){let y=o;o=null,y.resolve({value:void 0,done:true});}}function l(y){if(o){let f=o;o=null,c=false,f.reject(y);}}function p(){if(a){let y=a;a=null,y();}}return {async send(y){if(s!=="open")throw new Error(`[Directive StreamChannel] Cannot send to ${s} channel${t.name?` "${t.name}"`:""}`);if(o){i(y);return}if(r.length>=e){if(await new Promise(f=>{a=f;}),s!=="open")throw new Error(`[Directive StreamChannel] Cannot send to ${s} channel${t.name?` "${t.name}"`:""}`);if(o){i(y);return}}r.push(y);},end(){s==="open"&&(s="closed",u());},error(y){s==="open"&&(s="error",n=y,l(y),p());},getState(){return s},bufferedCount(){return r.length},[Symbol.asyncIterator](){if(c)throw new Error("[Directive StreamChannel] Channel only supports a single consumer. Create a separate channel for each consumer.");return c=true,{next(){if(s==="error"&&n)return c=false,Promise.reject(n);if(r.length>0){let y=r.shift();return p(),Promise.resolve({value:y,done:false})}return s==="closed"?(c=false,Promise.resolve({value:void 0,done:true})):new Promise((y,f)=>{o={resolve:y,reject:f};})},return(){return s="closed",r.length=0,c=false,p(),Promise.resolve({value:void 0,done:true})}}}}}function Pr(t){let e=Se(t),r=Se(t);return {sideA:{send:s=>e.send(s),receive:r,close(){e.end(),r.end();}},sideB:{send:s=>r.send(s),receive:e,close(){e.end(),r.end();}}}}async function kr(t,e,r){try{for await(let s of t){let n=await r(s);await e.send(n);}e.end();}catch(s){e.error(s instanceof Error?s:new Error(String(s)));}}function Ir(...t){return {[Symbol.asyncIterator](){let r=[],s=0,n=null,o=null,a=false,c=false,i=[];function u(l){if(n){let p=n;return n=null,p(l),true}return false}for(let l of t){let p=l[Symbol.asyncIterator]();i.push(p),(async()=>{try{for(;!a;){let d=await p.next();if(d.done||a)break;u({value:d.value,done:!1})||(r.length<1e4?r.push(d.value):c||(c=!0,console.warn("[Directive mergeStreams] Buffer exceeded 10000 items. Values are being dropped. Ensure the consumer keeps up or use bounded StreamChannel sources.")));}}catch(d){a||(a=true,o=d instanceof Error?d:new Error(String(d)),u({value:void 0,done:true}));}s++,s>=t.length&&!a&&u({value:void 0,done:true});})();}return {next(){return o?Promise.reject(o):r.length>0?Promise.resolve({value:r.shift(),done:false}):s>=t.length?Promise.resolve({value:void 0,done:true}):new Promise(l=>{n=l;})},return(){a=true,r.length=0;for(let l of i)l.return?.({value:void 0,done:true});if(n){let l=n;n=null,l({value:void 0,done:true});}return Promise.resolve({value:void 0,done:true})}}}}}function Dr(t,e){let r=t.metadata.title??"",s=t.metadata.section??"",n=t.metadata.url??"";return `${r&&s&&n?`[${r} \u2014 ${s}](${n})`:r||t.id}
|
|
29
|
-
${t.content}`}function
|
|
26
|
+
[/UNTRUSTED_CONTENT]`}function vr(t){let{baseGuardrail:e=Ue({strictMode:true,blockThreshold:25}),additionalPatterns:n=[]}=t,o=/\[UNTRUSTED_CONTENT source="([^"]+)"\]([\s\S]*?)\[\/UNTRUSTED_CONTENT\]/g;return async(r,s)=>{let a=await e(r,s);if(!a.passed)return a;let c=r.input.matchAll(o);for(let i of c){let[,u,l]=i;if(!l)continue;let p=Se(l,[...ve,...n]);if(p.detected&&p.riskScore>=25)return {passed:false,reason:`Untrusted content from "${u}" contains potential injection (risk: ${p.riskScore}%)`}}return {passed:true}}}function Sr(){return globalThis.crypto?.randomUUID?.()??`${Date.now().toString(36)}-${Math.random().toString(36).slice(2,11)}`}function Er(t){return new TextEncoder().encode(t)}function wr(t){return Array.from(t).map(e=>e.toString(16).padStart(2,"0")).join("")}async function ze(t){let e=Er(t),n=await globalThis.crypto.subtle.digest("SHA-256",e);return wr(new Uint8Array(n))}function Rr(t){if(t.length===0)return "";let e=new Set;for(let r of t)for(let s of Object.keys(r))e.add(s);let n=Array.from(e),o=[n.join(",")];for(let r of t){let s=n.map(a=>{let c=r[a];if(c==null)return "";if(typeof c=="object")return JSON.stringify(c).replace(/"/g,'""');let i=String(c);return i.includes(",")||i.includes(`
|
|
27
|
+
`)||i.includes('"')?`"${i.replace(/"/g,'""')}"`:i});o.push(s.join(","));}return o.join(`
|
|
28
|
+
`)}function Cr(){let t=new Map,e=new Map,n=new Map;return {async getSubjectData(o,r){let s=[];for(let[a,c]of t){if(r&&!r.includes(a))continue;let i=c.get(o);i&&i.length>0&&s.push({category:a,records:[...i]});}return s},async deleteSubjectData(o,r){let s=0;for(let[a,c]of t){if(r&&!r.includes(a))continue;let i=c.get(o);i&&(s+=i.length,c.delete(o));}return s},async anonymizeSubjectData(o,r){let s=0;for(let[a,c]of t){if(r&&!r.includes(a))continue;let i=c.get(o);if(i)for(let u of i)u.data={...u.data,_anonymized:true,_anonymizedAt:Date.now()},s++;}return s},async getExpiredData(o,r){let s=[],a=t.get(o);if(a)for(let c of a.values())for(let i of c)i.createdAt<r&&s.push({id:i.id,createdAt:i.createdAt});return s},async deleteByIds(o){let r=new Set(o),s=0;for(let a of t.values())for(let[c,i]of a){let u=i.filter(l=>!r.has(l.id));u.length!==i.length&&(s+=i.length-u.length,u.length===0?a.delete(c):a.set(c,u));}return s},async storeConsent(o){e.set(`${o.subjectId}:${o.purpose}`,o);},async getConsent(o,r){return e.get(`${o}:${r}`)??null},async getConsentsBySubject(o){let r=[];for(let[s,a]of e)s.startsWith(`${o}:`)&&r.push(a);return r},async getConsentsByPurpose(o){let r=[];for(let[s,a]of e)s.endsWith(`:${o}`)&&r.push(a);return r},async storeDeletionCertificate(o){n.set(o.subjectId,o);}}}function Ar(t){let{storage:e,retention:n,exportExpirationMs:o=864e5,events:r={}}=t,s={async grant(a,c,i={}){let u={subjectId:a,purpose:c,granted:true,grantedAt:Date.now(),expiresAt:i.expiresAt,source:i.source,version:i.version};return await e.storeConsent(u),r.onConsentChange?.(u),u},async revoke(a,c){let i=await e.getConsent(a,c);if(!i)return null;let u={...i,granted:false,revokedAt:Date.now()};return await e.storeConsent(u),r.onConsentChange?.(u),u},async check(a,c){let i=await e.getConsent(a,c);return !(!i||!i.granted||i.expiresAt&&i.expiresAt<Date.now())},async getForSubject(a){return e.getConsentsBySubject(a)},async getForPurpose(a){return e.getConsentsByPurpose(a)}};return {async exportData(a){try{let c=await e.getSubjectData(a.subjectId,a.categories),i=[],u=[];for(let{category:f,records:y}of c){u.push(f);for(let m of y)i.push({category:f,...m});}if(a.includeAudit&&e.getAuditEntries){let f=await e.getAuditEntries(a.subjectId);u.push("audit");for(let y of f)i.push({category:"audit",id:y.id,data:y.payload,createdAt:y.timestamp});}let l;a.format==="csv"?l=Rr(i.map(f=>({category:f.category,id:f.id,createdAt:new Date(f.createdAt).toISOString(),...f.data}))):l=JSON.stringify({subjectId:a.subjectId,exportedAt:new Date().toISOString(),recordCount:i.length,categories:u,records:i},null,2);let p=await ze(l),d={success:!0,subjectId:a.subjectId,format:a.format,data:l,categories:u,recordCount:i.length,checksum:p,exportedAt:Date.now(),expiresAt:Date.now()+o};return r.onExport?.(d),d}catch(c){return {success:false,subjectId:a.subjectId,format:a.format,data:"",categories:[],recordCount:0,checksum:"",exportedAt:Date.now(),error:c instanceof Error?c.message:String(c)}}},async deleteData(a){try{let c=0,i=[];a.anonymize?c=await e.anonymizeSubjectData(a.subjectId,a.categories):c=await e.deleteSubjectData(a.subjectId,a.categories),a.categories?i.push(...a.categories):a.scope==="all"&&i.push("all");let u=JSON.stringify({subjectId:a.subjectId,type:a.anonymize?"anonymization":"hard",scope:a.scope,categories:i,recordCount:c,deletedAt:Date.now(),reason:a.reason}),l={id:Sr(),subjectId:a.subjectId,type:a.anonymize?"anonymization":"hard",scope:a.scope,categories:i,recordCount:c,deletedAt:Date.now(),reason:a.reason,hash:await ze(u)};await e.storeDeletionCertificate(l);let p={success:!0,subjectId:a.subjectId,scope:a.scope,anonymized:a.anonymize??!1,recordsAffected:c,categoriesAffected:i,certificate:l,deletedAt:Date.now()};return r.onDelete?.(p),p}catch(c){return {success:false,subjectId:a.subjectId,scope:a.scope,anonymized:a.anonymize??false,recordsAffected:0,categoriesAffected:[],certificate:{id:"error",subjectId:a.subjectId,type:"hard",scope:a.scope,categories:[],recordCount:0,deletedAt:Date.now(),hash:""},deletedAt:Date.now(),error:c instanceof Error?c.message:String(c)}}},consent:s,async enforceRetention(){if(!n)return 0;let a=0,c=Date.now(),i=new Set;if(n.categoryRetention)for(let u of Object.keys(n.categoryRetention))i.add(u);i.add("default");for(let u of i){let l=n.categoryRetention?.[u]??n.defaultRetentionMs,p=c-l,d=await e.getExpiredData(u,p);if(d.length>0){await n.onBeforeDelete?.({category:u,count:d.length});let f=await e.deleteByIds(d.map(y=>y.id));a+=f,n.onAfterDelete?.({category:u,count:f}),r.onRetentionEnforced?.(u,f);}}return a},createConsentGuardrail(a){return async c=>{let u=c.input.match(/user[_-]?id[:\s]*([a-zA-Z0-9-]+)/i)?.[1];return u?await s.check(u,a)?{passed:true}:{passed:false,reason:`No consent for '${a}' from subject ${u}`}:{passed:true}}},async getDeletionCertificate(a){return null}}}function J(t,e){if(t.length!==e.length)throw new Error(`Vector dimensions must match: ${t.length} vs ${e.length}`);let n=0,o=0,r=0;for(let s=0;s<t.length;s++){let a=t[s],c=e[s];n+=a*c,o+=a*a,r+=c*c;}return o=Math.sqrt(o),r=Math.sqrt(r),o===0||r===0?0:n/(o*r)}function xr(t,e,n,o){let r=null;for(let s of e){if(o&&s.agentName&&s.agentName!==o)continue;let a=J(t,s.queryEmbedding);a>=n&&(!r||a>r.similarity)&&(r={entry:s,similarity:a});}return r}function He(){let t=new Map;function e(n){let o=t.get(n);return o||(o=new Map,t.set(n,o)),o}return {async getEntries(n){return Array.from(e(n).values())},async addEntry(n,o){e(n).set(o.id,o);},async updateEntry(n,o,r){let s=e(n),a=s.get(o);a&&s.set(o,{...a,...r});},async removeEntry(n,o){e(n).delete(o);},async clear(n){t.delete(n);}}}function Mr(t){let{embedder:e,similarityThreshold:n=.9,maxCacheSize:o=1e3,ttlMs:r=36e5,namespace:s="default",storage:a=He(),onHit:c,onMiss:i,onError:u,perAgent:l=false}=t,p={totalEntries:0,totalHits:0,totalMisses:0,hitRate:0,avgSimilarityOnHit:0,oldestEntry:null,newestEntry:null},d=0;function f(m){if(p.totalEntries=m.length,p.hitRate=p.totalHits+p.totalMisses>0?p.totalHits/(p.totalHits+p.totalMisses):0,p.avgSimilarityOnHit=p.totalHits>0?d/p.totalHits:0,m.length>0){let S=m.map(h=>h.createdAt);p.oldestEntry=Math.min(...S),p.newestEntry=Math.max(...S);}else p.oldestEntry=null,p.newestEntry=null;}async function y(){let m=await a.getEntries(s),S=Date.now();for(let g of m)S-g.createdAt>r&&await a.removeEntry(s,g.id);let h=await a.getEntries(s);if(h.length>o){let v=h.sort((w,M)=>w.accessedAt-M.accessedAt).slice(0,h.length-o);for(let w of v)await a.removeEntry(s,w.id);}}return {async lookup(m,S){let h=Date.now();try{let g=await e(m),v=await a.getEntries(s),w=xr(g,v,n,l?S:void 0);return w?(await a.updateEntry(s,w.entry.id,{accessedAt:Date.now(),accessCount:w.entry.accessCount+1}),p.totalHits++,d+=w.similarity,f(v),c?.(w.entry,w.similarity),{hit:!0,entry:w.entry,similarity:w.similarity,latencyMs:Date.now()-h}):(p.totalMisses++,f(v),i?.(m),{hit:!1,latencyMs:Date.now()-h})}catch(g){return p.totalMisses++,u?.(g instanceof Error?g:new Error(String(g))),{hit:false,latencyMs:Date.now()-h}}},async store(m,S,h,g={}){let v=await e(m),w={id:globalThis.crypto?.randomUUID?.()??`${Date.now()}-${Math.random().toString(36).slice(2,11)}`,query:m,queryEmbedding:v,response:S,metadata:g,createdAt:Date.now(),accessedAt:Date.now(),accessCount:0,agentName:l?h:void 0};await a.addEntry(s,w),await y();let M=await a.getEntries(s);f(M);},async invalidate(m){let S=await a.getEntries(s),h=0;for(let v of S)m(v)&&(await a.removeEntry(s,v.id),h++);let g=await a.getEntries(s);return f(g),h},async clear(){await a.clear(s),p={totalEntries:0,totalHits:0,totalMisses:0,hitRate:0,avgSimilarityOnHit:0,oldestEntry:null,newestEntry:null},d=0;},getStats(){return {...p}},async export(){return a.getEntries(s)},async import(m){for(let h of m)await a.addEntry(s,h);await y();let S=await a.getEntries(s);f(S);}}}function Tr(t){let{cache:e}=t;return async n=>{let o=await e.lookup(n.input,n.agentName);return o.hit&&o.entry?{passed:false,cacheHit:true,reason:`Cache hit (similarity: ${(o.similarity*100).toFixed(1)}%)`,cachedResponse:o.entry.response,similarity:o.similarity}:{passed:true,cacheHit:false}}}function Pr(t=128){return async e=>{let n=new Array(t).fill(0);for(let r=0;r<e.length;r++){let s=e.charCodeAt(r);n[r%t]+=s/256;}let o=Math.sqrt(n.reduce((r,s)=>r+s*s,0));if(o>0)for(let r=0;r<t;r++)n[r]/=o;return n}}function kr(t){let{batchSize:e=20,embedBatch:n,maxWaitMs:o=50}=t;if(e<1||!Number.isFinite(e))throw new Error(`[Directive SemanticCache] batchSize must be >= 1, got ${e}`);let r=[],s=null,a=false;async function c(){if(r.length===0)return;let i=r;r=[],s&&(clearTimeout(s),s=null);try{let u=i.map(p=>p.text),l=await n(u);if(l.length!==i.length)throw new Error(`[Directive SemanticCache] embedBatch returned ${l.length} embeddings for ${i.length} texts. The embedBatch function must return exactly one embedding per input text.`);for(let p=0;p<i.length;p++)i[p].resolve(l[p]);}catch(u){let l=u instanceof Error?u:new Error(String(u));for(let p of i)p.reject(l);}}return {async embed(i){if(a)throw new Error("BatchedEmbedder has been destroyed");return new Promise((u,l)=>{r.push({text:i,resolve:u,reject:l}),r.length>=e?c():s||(s=setTimeout(c,o));})},async flush(){await c();},destroy(){a=true,s&&(clearTimeout(s),s=null);let i=r;r=[];let u=new Error("BatchedEmbedder destroyed");for(let l of i)l.reject(u);}}}function Ir(){let t=new Map,e=null;function n(o){if(e===null)e=o.length;else if(o.length!==e)throw new Error(`[Directive ANNIndex] Dimension mismatch: expected ${e}, got ${o.length}`)}return {add(o,r){n(r),t.set(o,r);},remove(o){t.delete(o);},search(o,r,s=0){if(e!==null&&o.length!==e)throw new Error(`[Directive ANNIndex] Query dimension mismatch: expected ${e}, got ${o.length}`);let a=[];for(let[c,i]of t){let u=J(o,i);u>=s&&a.push({id:c,similarity:u});}return a.sort((c,i)=>i.similarity-c.similarity),a.slice(0,r)},rebuild(){},size(){return t.size},clear(){t.clear(),e=null;},needsRebuild(){return false}}}function qe(t,e){return 1-J(t,e)}function Ee(t,e){if(t.length===0)return null;let n=Math.floor(e()*t.length),o=t[n],r=t.filter((l,p)=>p!==n);if(r.length===0)return {id:o.id,embedding:o.embedding,mu:0,left:null,right:null};let s=r.map(l=>({item:l,distance:qe(o.embedding,l.embedding)}));s.sort((l,p)=>l.distance-p.distance);let a=Math.floor(s.length/2),c=s[a].distance,i=s.slice(0,a).map(l=>l.item),u=s.slice(a).map(l=>l.item);return {id:o.id,embedding:o.embedding,mu:c,left:Ee(i,e),right:Ee(u,e)}}function ee(t,e,n,o,r,s){if(!t)return;let a=qe(e,t.embedding),c=1-a;c>=o&&(r.push({id:t.id,similarity:c}),r.sort((i,u)=>u.similarity-i.similarity),r.length>n&&r.pop(),r.length===n&&(s.value=1-r[r.length-1].similarity)),a<t.mu?(ee(t.left,e,n,o,r,s),a+s.value>=t.mu&&ee(t.right,e,n,o,r,s)):(ee(t.right,e,n,o,r,s),a-s.value<=t.mu&&ee(t.left,e,n,o,r,s));}function Dr(t={}){let{random:e=Math.random}=t,n=new Map,o=null,r=false,s=null;function a(c){if(s===null)s=c.length;else if(c.length!==s)throw new Error(`[Directive ANNIndex] Dimension mismatch: expected ${s}, got ${c.length}`)}return {add(c,i){a(i),n.set(c,i),r=true;},remove(c){n.delete(c),r=true;},search(c,i,u=0){if(s!==null&&c.length!==s)throw new Error(`[Directive ANNIndex] Query dimension mismatch: expected ${s}, got ${c.length}`);if(r||!o){let d=[];for(let[f,y]of n){let m=J(c,y);m>=u&&d.push({id:f,similarity:m});}return d.sort((f,y)=>y.similarity-f.similarity),d.slice(0,i)}let l=[],p={value:Number.POSITIVE_INFINITY};return ee(o,c,i,u,l,p),l},rebuild(){let c=Array.from(n.entries()).map(([i,u])=>({id:i,embedding:u}));o=Ee(c,e),r=false;},size(){return n.size},clear(){n.clear(),o=null,r=false,s=null;},needsRebuild(){return r}}}function we(t={}){let{bufferSize:e=100}=t;if(e<1||!Number.isFinite(e))throw new Error(`[Directive StreamChannel] bufferSize must be >= 1, got ${e}`);let n=[],o="open",r=null,s=null,a=null,c=false;function i(f){if(s){let y=s;s=null,y.resolve({value:f,done:false});}}function u(){if(s){let f=s;s=null,f.resolve({value:void 0,done:true});}}function l(f){if(s){let y=s;s=null,c=false,y.reject(f);}}function p(){if(a){let f=a;a=null,f();}}return {async send(f){if(o!=="open")throw new Error(`[Directive StreamChannel] Cannot send to ${o} channel${t.name?` "${t.name}"`:""}`);if(s){i(f);return}if(n.length>=e){if(await new Promise(y=>{a=y;}),o!=="open")throw new Error(`[Directive StreamChannel] Cannot send to ${o} channel${t.name?` "${t.name}"`:""}`);if(s){i(f);return}}n.push(f);},end(){o==="open"&&(o="closed",u());},error(f){o==="open"&&(o="error",r=f,l(f),p());},getState(){return o},bufferedCount(){return n.length},[Symbol.asyncIterator](){if(c)throw new Error("[Directive StreamChannel] Channel only supports a single consumer. Create a separate channel for each consumer.");return c=true,{next(){if(o==="error"&&r)return c=false,Promise.reject(r);if(n.length>0){let f=n.shift();return p(),Promise.resolve({value:f,done:false})}return o==="closed"?(c=false,Promise.resolve({value:void 0,done:true})):new Promise((f,y)=>{s={resolve:f,reject:y};})},return(){return o="closed",n.length=0,c=false,p(),Promise.resolve({value:void 0,done:true})}}}}}function Or(t){let e=we(t),n=we(t);return {sideA:{send:o=>e.send(o),receive:n,close(){e.end(),n.end();}},sideB:{send:o=>n.send(o),receive:e,close(){e.end(),n.end();}}}}async function $r(t,e,n){try{for await(let o of t){let r=await n(o);await e.send(r);}e.end();}catch(o){e.error(o instanceof Error?o:new Error(String(o)));}}function Nr(...t){return {[Symbol.asyncIterator](){let n=[],o=0,r=null,s=null,a=false,c=false,i=[];function u(l){if(r){let p=r;return r=null,p(l),true}return false}for(let l of t){let p=l[Symbol.asyncIterator]();i.push(p),(async()=>{try{for(;!a;){let d=await p.next();if(d.done||a)break;u({value:d.value,done:!1})||(n.length<1e4?n.push(d.value):c||(c=!0,console.warn("[Directive mergeStreams] Buffer exceeded 10000 items. Values are being dropped. Ensure the consumer keeps up or use bounded StreamChannel sources.")));}}catch(d){a||(a=true,s=d instanceof Error?d:new Error(String(d)),u({value:void 0,done:true}));}o++,o>=t.length&&!a&&u({value:void 0,done:true});})();}return {next(){return s?Promise.reject(s):n.length>0?Promise.resolve({value:n.shift(),done:false}):o>=t.length?Promise.resolve({value:void 0,done:true}):new Promise(l=>{r=l;})},return(){a=true,n.length=0;for(let l of i)l.return?.({value:void 0,done:true});if(r){let l=r;r=null,l({value:void 0,done:true});}return Promise.resolve({value:void 0,done:true})}}}}}function _r(t,e){let n=t.metadata.title??"",o=t.metadata.section??"",r=t.metadata.url??"";return `${n&&o&&r?`[${n} \u2014 ${o}](${r})`:n||t.id}
|
|
29
|
+
${t.content}`}function jr(t,e){return t.length===0?"":`Relevant documentation context:
|
|
30
30
|
|
|
31
31
|
${t.join(`
|
|
32
32
|
|
|
33
|
-
`)}`}function
|
|
33
|
+
`)}`}function Fr(t,e,n){return Math.max(e,Math.min(n,t))}function Gr(t){let{embedder:e,storage:n,topK:o=5,minSimilarity:r=.3,formatChunk:s=_r,formatContext:a=jr,onError:c}=t,i=Fr(r,0,1);typeof process<"u"&&process.env?.NODE_ENV==="development"&&r!==i&&console.warn(`[Directive] RAG: minSimilarity ${r} clamped to ${i} (valid range: 0-1)`);async function u(p,d){let f=Math.max(1,Math.floor(d??o));if(n.search)return n.search(await e(p),f,i);let y=await e(p),S=(await n.getChunks()).map(h=>({...h,similarity:J(y,h.embedding)}));return S.sort((h,g)=>g.similarity-h.similarity),S.filter(h=>h.similarity>=i).slice(0,f)}async function l(p,d={}){let{prefix:f,history:y,topK:m,filter:S}=d,h=[];try{h=await u(p,m);}catch(M){c?.(M instanceof Error?M:new Error(String(M)));}S&&(h=h.filter(M=>S(M)));let g=h.map(M=>s(M,M.similarity)),v=a(g,p),w=[];if(f&&w.push(f),v&&w.push(v),y&&y.length>0){let M=y.map(x=>`${x.role.charAt(0).toUpperCase()+x.role.slice(1)}: ${x.content}`).join(`
|
|
34
34
|
|
|
35
|
-
`);
|
|
36
|
-
${
|
|
35
|
+
`);w.push(`Previous conversation:
|
|
36
|
+
${M}`);}return w.push(p),w.join(`
|
|
37
37
|
|
|
38
38
|
---
|
|
39
39
|
|
|
40
|
-
`)}return {retrieve:u,enrich:l}}function
|
|
40
|
+
`)}return {retrieve:u,enrich:l}}function Lr(t,e){let n=ie__default.default.resolve(t);if(n.split(ie__default.default.sep).includes(".."))throw new Error(`[Directive] File path escapes allowed directory: ${t}`);if(e){let r=ie__default.default.resolve(e)+ie__default.default.sep;if(!n.startsWith(r)&&n!==r.slice(0,-1))throw new Error(`[Directive] File path escapes allowed directory: ${t}`)}return n}function Br(t){let{filePath:e,mapEntry:n,ttlMs:o=0,baseDir:r}=t,s=Lr(e,r),a=null,c=0;async function i(){if(a&&(o===0||Date.now()-c<o))return a;try{let l=await(await import('fs')).promises.readFile(s,"utf-8"),p=JSON.parse(l);return a=n?p.map(n):p,c=Date.now(),a}catch(u){return typeof process<"u"&&process.env?.NODE_ENV==="development"&&console.warn(`[Directive] JSONFileStore: failed to load ${s}:`,u),a=[],c=Date.now(),a}}return {async getChunks(){return i()},async size(){return (await i()).length},async reload(){a=null,c=0,await i();},destroy(){a=null,c=0;}}}var Ve="AI service temporarily unavailable. Please try again.";function Ur(t={}){let{maxResponseChars:e=Number.POSITIVE_INFINITY,truncationMessage:n=`
|
|
41
41
|
|
|
42
|
-
*[Response truncated]*`,heartbeatIntervalMs:
|
|
42
|
+
*[Response truncated]*`,heartbeatIntervalMs:o=0,errorMessages:r,headers:s}=t;if(e<0)throw new RangeError("maxResponseChars must be non-negative");if(o<0)throw new RangeError("heartbeatIntervalMs must be non-negative");function a(u){if(typeof r=="function")try{return r(u)}catch{return Ve}if(r&&typeof r=="object"){let l=u!=null&&typeof u=="object"&&"code"in u&&typeof u.code=="string"?u.code:void 0;if(l&&l in r)return r[l]}return Ve}function c(u,l,p,d){let f=new TextEncoder;function y(m){return f.encode(`data: ${JSON.stringify(m)}
|
|
43
43
|
|
|
44
|
-
`)}return new ReadableStream({async start(m){let S=null,h=null;try{
|
|
44
|
+
`)}return new ReadableStream({async start(m){let S=null,h=null;try{o>0&&(S=setInterval(()=>{try{m.enqueue(y({type:"heartbeat",timestamp:Date.now()}));}catch{}},o)),h=u.stream(l,p,{signal:d?.signal});let g=0,v=!1;for await(let w of h){if(g+=w.length,g>e){m.enqueue(y({type:"truncated",text:n})),m.enqueue(y({type:"done"})),v=!0,h.abort();break}m.enqueue(y({type:"text",text:w}));}try{await h.result;}catch{}v||m.enqueue(y({type:"done"}));}catch(g){let v=a(g);m.enqueue(y({type:"error",message:v}));}finally{S&&clearInterval(S),m.close();}}})}let i={"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive",...s};return {toResponse(u,l,p,d){let f=c(u,l,p,d);return new Response(f,{headers:i})},toStream(u,l,p,d){return c(u,l,p,d)}}}var ce=class extends Error{retryCount;lastError;constructor(e,n){super(`[Directive] All ${e} retries exhausted: ${n.message}`),this.name="RetryExhaustedError",this.retryCount=e,this.lastError=n,this.cause=n;}},zr=new Set([400,401,403,404,422]);function Re(t){let e=t;if(typeof e.status=="number"&&e.status>=100&&e.status<=599)return e.status;if(typeof e.statusCode=="number"&&e.statusCode>=100&&e.statusCode<=599)return e.statusCode;let o=(t.message.length>1e3?t.message.slice(0,1e3):t.message).match(/(?:failed|error|status|http)[:\s]+(\d{3})\b/i);if(!o)return null;let r=Number(o[1]);return r>=100&&r<=599?r:null}function Je(t){let e=t;if(typeof e.retryAfter=="number"&&e.retryAfter>0)return e.retryAfter*1e3;let o=(t.message.length>1e3?t.message.slice(0,1e3):t.message).match(/retry[- ]?after[:\s]+(\d+)/i);if(!o)return null;let r=Number(o[1]);return r>0?r*1e3:null}function Hr(t,e,n){let o=e*2**(t-1),r=Math.random()*e*.5,s=o+r;return Math.min(s,n)}function qr(t,e,n,o){if(Re(t)===429){let s=Je(t);if(s!==null)return Math.min(s,o)}return Hr(e,n,o)}function Vr(t){let e=Re(t);return e===null?true:!zr.has(e)}function Jr(t,e={}){let{maxRetries:n=3,baseDelayMs:o=1e3,maxDelayMs:r=3e4,isRetryable:s,onRetry:a}=e;if(!Number.isFinite(n)||n<0)throw new Error("[Directive] withRetry: maxRetries must be a non-negative finite number.");if(!Number.isFinite(o)||o<0)throw new Error("[Directive] withRetry: baseDelayMs must be a non-negative finite number.");if(!Number.isFinite(r)||r<0)throw new Error("[Directive] withRetry: maxDelayMs must be a non-negative finite number.");return async(c,i,u)=>{let l;for(let p=0;p<=n;p++)try{return await t(c,i,u)}catch(d){if(l=d instanceof Error?d:new Error(String(d)),p>=n)break;if(s)try{if(!s(l))break}catch{break}if(!Vr(l))break;let f=qr(l,p+1,o,r);try{a?.(p+1,l,f);}catch{}let y=u?.signal;if(y?.aborted)break;await new Promise((m,S)=>{let h=setTimeout(()=>{y?.removeEventListener("abort",g),m();},f);function g(){clearTimeout(h),S(y.reason??new Error("Aborted"));}y&&y.addEventListener("abort",g,{once:true});});}throw new ce(n,l)}}var ue=class extends Error{errors;constructor(e){let n=e.map((o,r)=>` [${r}] ${o.message}`).join(`
|
|
45
45
|
`);super(`[Directive] All ${e.length} providers failed:
|
|
46
|
-
${
|
|
46
|
+
${n}`),this.name="AllProvidersFailedError",this.errors=Object.freeze([...e]),e.length>0&&(this.cause=e[e.length-1]);}};function Kr(t,e={}){if(t.length===0)throw new Error("[Directive] withFallback requires at least one runner.");let{shouldFallback:n,onFallback:o}=e;return async(r,s,a)=>{let c=[];for(let i=0;i<t.length;i++)try{return await t[i](r,s,a)}catch(u){let l=u instanceof Error?u:new Error(String(u));if(c.push(l),i<t.length-1){if(n)try{if(!n(l))break}catch{break}try{o?.(i,i+1,l);}catch{}}}throw new ue(c)}}var te=class extends Error{estimated;remaining;window;constructor(e){super(`[Directive] Budget exceeded (${e.window}): estimated $${e.estimated.toFixed(4)}, remaining $${e.remaining.toFixed(4)}`),this.name="BudgetExceededError",this.estimated=e.estimated,this.remaining=e.remaining,this.window=e.window;}},le=class{entries=[];record(e){this.entries.push({timestamp:Date.now(),cost:e});}getCostInWindow(e){let n=Date.now()-e;this.prune(n);let o=0;for(let r of this.entries)r.timestamp>=n&&(o+=r.cost);return o}prune(e){let n=0;for(;n<this.entries.length&&this.entries[n].timestamp<e;)n++;n>0&&this.entries.splice(0,n);}clear(){this.entries=[];}},Ke={hour:3600*1e3,day:1440*60*1e3};function Wr(t,e){return Math.ceil(t.length/e)}function We(t,e){return t.inputTokens/1e6*e.inputPerMillion+t.outputTokens/1e6*e.outputPerMillion}function Ye(t,e,n=1){let o=Math.ceil(t*n);return t/1e6*e.inputPerMillion+o/1e6*e.outputPerMillion}function Yr(t,e){let{maxCostPerCall:n,budgets:o=[],pricing:r,charsPerToken:s=4,estimatedOutputMultiplier:a=1,onBudgetExceeded:c}=e;if(!Number.isFinite(s)||s<=0)throw new Error("[Directive] withBudget: charsPerToken must be a positive finite number.");if(n!=null&&(!Number.isFinite(n)||n<0))throw new Error("[Directive] withBudget: maxCostPerCall must be a non-negative finite number.");if(!Number.isFinite(a)||a<0)throw new Error("[Directive] withBudget: estimatedOutputMultiplier must be a non-negative finite number.");n!=null&&!r&&console.warn("[Directive] withBudget: maxCostPerCall has no effect without pricing. Provide a pricing config to enable per-call cost estimation.");for(let d of o)if(!Number.isFinite(d.maxCost)||d.maxCost<0)throw new Error(`[Directive] withBudget: budgets[${d.window}].maxCost must be a non-negative finite number.`);let i=new Map;for(let d of o)i.set(d.window,new le);let u=new le,l=async(d,f,y)=>{let m=Wr(f,s);if(n!=null&&r){let h=Ye(m,r,a);if(h>n){let g={estimated:h,remaining:n,window:"per-call"};try{c?.(g);}catch{}throw new te(g)}}for(let h of o){let g=Ke[h.window],w=i.get(h.window).getCostInWindow(g),M=h.maxCost-w,x=Ye(m,h.pricing,a);if(x>M){let P={estimated:x,remaining:Math.max(0,M),window:h.window};try{c?.(P);}catch{}throw new te(P)}}let S=await t(d,f,y);if(S.tokenUsage){for(let h of o){let g=i.get(h.window),v=We(S.tokenUsage,h.pricing);g.record(v);}if(r&&o.length===0){let h=We(S.tokenUsage,r);u.record(h);}}return S};function p(d){let f=i.get(d);if(!f)return 0;let y=Ke[d];return f.getCostInWindow(y)}return l.getSpent=p,l}function Qr(t,e){return {match:(n,o)=>o.length<=t,model:e}}function Xr(t,e){return {match:n=>n.name===t,model:e}}function Zr(t,e){return {match:(n,o)=>(t.lastIndex=0,t.test(o)),model:e}}function eo(t,e){let n=Array.isArray(e)?{rules:e}:e,{rules:o,onModelSelected:r}=n;return async(s,a,c)=>{let i=s.model;for(let l of o)try{if(l.match(s,a)){i=l.model;break}}catch{}try{r?.(s.model,i);}catch{}let u=i!==s.model?{...s,model:i}:s;return t(u,a,c)}}function oo(t){let e=5381;for(let n=0;n<t.length;n++)e=(e<<5)+e^t.charCodeAt(n);return (e>>>0).toString(16)}async function so(t){try{let e=globalThis.crypto?.subtle;if(e&&typeof e.digest=="function"){let n=new TextEncoder,o=await e.digest("SHA-256",n.encode(t)),r=new Uint8Array(o),s="";for(let a of r)s+=a.toString(16).padStart(2,"0");return s}}catch{}return oo(t)}var ne=class extends Error{constructor(n,o,r,s){super(n);this.attempts=o;this.errors=r;this.lastRawOutput=s;}name="PredicateFromIntentError"},ao=`You emit ONLY a JSON object describing a Directive FactPredicate \u2014 no prose, no markdown fences, no explanation.
|
|
47
47
|
|
|
48
48
|
A FactPredicate is a JSON tree of fact paths and operators:
|
|
49
49
|
- Object form (preferred): { "factName": { "$op": operand }, "otherFact": { "$op": operand } }
|
|
@@ -56,22 +56,22 @@ Operator set (CLOSED \u2014 only these are valid):
|
|
|
56
56
|
Combinators: $all, $any, $not
|
|
57
57
|
|
|
58
58
|
Each operator is only valid for certain kinds (see below). Emit ONLY operators valid for the fact's kind.
|
|
59
|
-
`;function
|
|
60
|
-
Facts in this schema (path \u2192 kind \u2192 allowed operators):`);for(let[
|
|
61
|
-
The user intent will be over the namespace "${e}". Use only facts at or below that path.`),
|
|
62
|
-
Respond with ONLY the JSON predicate object. No prose. No markdown fences. No "Here is...".`),
|
|
63
|
-
`)}function
|
|
64
|
-
Reason: ${
|
|
65
|
-
Validation errors (fix every one):`);for(let
|
|
66
|
-
Schema reminder:`);for(let[
|
|
67
|
-
Emit ONLY a corrected JSON FactPredicate object. No prose.`),
|
|
68
|
-
`)}function
|
|
69
|
-
|
|
70
|
-
${
|
|
71
|
-
|
|
72
|
-
Emit the predicate now.`:
|
|
73
|
-
`),
|
|
74
|
-
${n}`;return {name:o,description:a,input_schema:{type:"object",properties:{predicate:{type:"object"}},required:["predicate"]},schemaSummary:n}}function cs(t,e={}){let{maxBatchSize:r=20,maxWaitMs:s=5e3,concurrency:n=5}=e;if(!Number.isFinite(r)||r<1)throw new Error("[Directive] createBatchQueue: maxBatchSize must be a positive finite number (>= 1).");if(!Number.isFinite(s)||s<0)throw new Error("[Directive] createBatchQueue: maxWaitMs must be a non-negative finite number.");if(!Number.isFinite(n)||n<1)throw new Error("[Directive] createBatchQueue: concurrency must be a positive finite number (>= 1).");let o=[],a=null,c=false,i=null;function u(){a===null&&(a=setTimeout(()=>{a=null,d().catch(()=>{});},s));}function l(){a!==null&&(clearTimeout(a),a=null);}async function p(y){let f=0;async function m(){for(;f<y.length;){let h=f++,g=y[h];try{let b=await t(g.agent,g.input,g.options);g.resolve(b);}catch(b){g.reject(b instanceof Error?b:new Error(String(b)));}}}let S=Array.from({length:Math.min(n,y.length)},()=>m());await Promise.all(S);}async function d(){if(i&&await i,o.length===0)return;l();let y=o.splice(0);i=p(y).finally(()=>{i=null,o.length>0&&u();}),await i;}return {submit(y,f,m){return c?Promise.reject(new Error("[Directive] BatchQueue has been destroyed.")):new Promise((S,h)=>{o.push({agent:y,input:f,options:m,resolve:S,reject:h}),o.length>=r?(l(),d().catch(()=>{})):u();})},async flush(){await d();},get pending(){return o.length},async destroy(){c||(c=true,l(),o.length>0&&await d());}}}function Qe(){return {callCount:0,errorCount:0,totalCost:0,avgLatencyMs:0,lastErrorAt:null}}function us(t,e){return !t||!e?0:t.inputTokens/1e6*e.inputPerMillion+t.outputTokens/1e6*e.outputPerMillion}function ls(t){let{providers:e,defaultProvider:r,constraints:s=[],onProviderSelected:n,errorCooldownMs:o=3e4,preferCheapest:a=false}=t;if(!Number.isFinite(o)||o<0)throw new Error("[Directive] createConstraintRouter: errorCooldownMs must be a non-negative finite number.");let c=new Map;for(let f of e)c.set(f.name,f);if(!c.has(r))throw new Error(`[Directive] Default provider "${r}" not found in providers list.`);let i={totalCost:0,callCount:0,errorCount:0,lastProvider:null,avgLatencyMs:0,providers:Object.create(null)};for(let f of e)i.providers[f.name]=Qe();let u=0,l=[...s].sort((f,m)=>(m.priority??0)-(f.priority??0));function p(){let f=Date.now();for(let S of l)try{if(S.when(i)){let h=c.get(S.provider);if(h)return {provider:h,reason:"constraint"}}}catch{}let m=e.filter(S=>{let h=i.providers[S.name];return h?!(h.lastErrorAt&&f-h.lastErrorAt<o):true});if(a&&m.length>0){let S=[...m].sort((h,g)=>{let b=h.pricing?h.pricing.inputPerMillion+h.pricing.outputPerMillion:Number.POSITIVE_INFINITY,R=g.pricing?g.pricing.inputPerMillion+g.pricing.outputPerMillion:Number.POSITIVE_INFINITY;return b!==R?b-R:h.name===r?-1:g.name===r?1:0});if(S[0]!==c.get(r))return {provider:S[0],reason:"cheapest"}}return m.length>0&&!m.some(S=>S.name===r)?{provider:m[0],reason:"default"}:{provider:c.get(r),reason:"default"}}function d(f,m,S,h,g){let b=i.providers[f]??Qe();if(b.callCount++,i.callCount++,g)b.errorCount++,i.errorCount++,b.lastErrorAt=Date.now();else {let x=us(S,h);b.totalCost+=x,i.totalCost+=x;}u+=m,i.avgLatencyMs=u/i.callCount;let R=b.callCount>0?(b.avgLatencyMs*(b.callCount-1)+m)/b.callCount:m;b.avgLatencyMs=R,i.providers[f]=b,i.lastProvider=f;}let y=async(f,m,S)=>{let{provider:h,reason:g}=p();try{n?.(h.name,g);}catch{}let b=Date.now();try{let R=await h.runner(f,m,S),x=Date.now()-b;return d(h.name,x,R.tokenUsage,h.pricing),R}catch(R){let x=Date.now()-b,M=R instanceof Error?R:new Error(String(R));throw d(h.name,x,void 0,h.pricing,M),M}};return Object.defineProperty(y,"facts",{get:()=>{let f=Object.create(null);for(let m of Object.keys(i.providers))f[m]={...i.providers[m]};return {...i,providers:f}},enumerable:true}),y}function Xe(t){let{transport:e,timeline:r,healthMonitor:s,getSnapshot:n,getBreakpointState:o,onResumeBreakpoint:a,onCancelBreakpoint:c,getScratchpadState:i,getDerivedState:u,onForkFromSnapshot:l,batchSize:p=1,batchIntervalMs:d=50,healthPushIntervalMs:y=0,authenticate:f}=t,m=t.maxClients??50,S=`devtools_${crypto.randomUUID()}`,h=new Set,g=new Set,b=[],R=null,x=null;function M(w,_){try{w.send(JSON.stringify(_));}catch{h.delete(w);}}function P(w){let _=JSON.stringify(w),k=[...h];for(let L of k)try{L.send(_);}catch{h.delete(L);}}function O(){b.length!==0&&(b.length===1?P({type:"event",event:b[0]}):P({type:"event_batch",events:b}),b=[]);}let v=r.subscribe(w=>{if(h.size!==0){if(p<=1){P({type:"event",event:w});return}b.push(w),b.length>=p&&O();}});p>1&&d>0&&(R=setInterval(O,d)),y>0&&s&&(x=setInterval(()=>{h.size>0&&P({type:"health",metrics:s.getAllMetrics()});},y));function C(w,_){let k;try{k=JSON.parse(_);}catch{M(w,{type:"error",code:"INVALID_JSON",message:"Could not parse message"});return}if(!k||typeof k!="object"||typeof k.type!="string"){M(w,{type:"error",code:"INVALID_MESSAGE",message:"Missing type field"});return}let L=Date.now(),F=T.get(w)??0;if(L-F<D){M(w,{type:"error",code:"RATE_LIMITED",message:"Too many requests"});return}if(T.set(w,L),k.type==="authenticate"){if(!f){M(w,{type:"error",code:"UNKNOWN_COMMAND",message:"Authentication not configured on this server"});return}if(!g.has(w)){M(w,{type:"error",code:"ALREADY_AUTHENTICATED",message:"Already authenticated"});return}if(typeof k.token!="string"){M(w,{type:"error",code:"AUTH_FAILED",message:"Missing token"}),w.close(),g.delete(w);return}let N=f(k.token),U=V=>{V?(g.delete(w),h.add(w),M(w,{type:"welcome",version:1,sessionId:S,timestamp:Date.now()})):(M(w,{type:"error",code:"AUTH_FAILED",message:"Invalid token"}),g.delete(w),w.close());};N instanceof Promise?N.then(U).catch(()=>{M(w,{type:"error",code:"AUTH_FAILED",message:"Authentication error"}),g.delete(w),w.close();}):U(N);return}if(g.has(w)){M(w,{type:"error",code:"AUTH_REQUIRED",message:"Authentication required"});return}switch(k.type){case "ping":M(w,{type:"pong",timestamp:Date.now()});break;case "request_snapshot":n?M(w,{type:"snapshot",data:n()}):M(w,{type:"error",code:"NO_SNAPSHOT",message:"Snapshot provider not configured"});break;case "request_health":s?M(w,{type:"health",metrics:s.getAllMetrics()}):M(w,{type:"error",code:"NO_HEALTH",message:"Health monitor not configured"});break;case "request_events":{let N=r.getEvents(),U=k.since,V=U!=null?N.filter(de=>de.id>U):N;M(w,{type:"event_batch",events:V});break}case "request_breakpoints":o?M(w,{type:"breakpoints",state:o()}):M(w,{type:"error",code:"NO_BREAKPOINTS",message:"Breakpoint provider not configured"});break;case "resume_breakpoint":if(a&&typeof k.breakpointId=="string"){let N=k.modifications?{input:k.modifications.input,skip:k.modifications.skip}:void 0;a(k.breakpointId,N);}else M(w,{type:"error",code:"NO_BREAKPOINTS",message:"Breakpoint resume not configured"});break;case "cancel_breakpoint":if(c&&typeof k.breakpointId=="string"){let N=typeof k.reason=="string"?k.reason:void 0;c(k.breakpointId,N);}else M(w,{type:"error",code:"NO_BREAKPOINTS",message:"Breakpoint cancel not configured"});break;case "export_session":M(w,{type:"event_batch",events:r.getEvents()});break;case "import_session":{if(typeof k.data!="string")M(w,{type:"error",code:"INVALID_DATA",message:"Missing data field for import"});else if(k.data.length>10485760)M(w,{type:"error",code:"IMPORT_TOO_LARGE",message:`Import data exceeds ${10485760/1024/1024} MB limit`});else try{r.import(k.data),M(w,{type:"event_batch",events:r.getEvents()});}catch(U){let V=U instanceof Error?U.message:String(U);M(w,{type:"error",code:"IMPORT_FAILED",message:V});}break}case "request_scratchpad":i?M(w,{type:"scratchpad_state",data:i()}):M(w,{type:"error",code:"NO_SCRATCHPAD",message:"Scratchpad provider not configured"});break;case "request_derived":u?M(w,{type:"derived_state",data:u()}):M(w,{type:"error",code:"NO_DERIVED",message:"Derived state provider not configured"});break;case "fork_from_snapshot":{if(l&&typeof k.eventId=="number")try{let N=l(k.eventId);M(w,{type:"fork_complete",eventId:k.eventId,newEventCount:N.newEventCount});}catch(N){let U=N instanceof Error?N.message:String(N);M(w,{type:"error",code:"FORK_FAILED",message:U});}else M(w,{type:"error",code:"NO_FORK",message:"Fork provider not configured"});break}default:M(w,{type:"error",code:"UNKNOWN_COMMAND",message:`Unknown message type: ${String(k.type).slice(0,100)}`});}}let T=new Map,D=50;return e.onConnection((w,_,k)=>{if(h.size+g.size>=m){try{let L={type:"error",code:"MAX_CLIENTS",message:"Connection limit reached"};w.send(JSON.stringify(L));}catch{}w.close();return}f?g.add(w):(h.add(w),M(w,{type:"welcome",version:1,sessionId:S,timestamp:Date.now()})),_(L=>C(w,L)),k(()=>{h.delete(w),g.delete(w),T.delete(w);});}),{get clientCount(){return h.size},broadcast(w){P(w);},pushHealth(){s&&h.size>0&&P({type:"health",metrics:s.getAllMetrics()});},pushBreakpoints(){o&&h.size>0&&P({type:"breakpoints",state:o()});},pushScratchpadUpdate(w,_){h.size>0&&P({type:"scratchpad_update",key:w,value:_});},pushDerivedUpdate(w,_){h.size>0&&P({type:"derived_update",id:w,value:_});},pushTokenStream(w,_,k){h.size>0&&P({type:"token_stream",agentId:w,tokens:_,tokenCount:k});},pushStreamDone(w,_){h.size>0&&P({type:"stream_done",agentId:w,totalTokens:_});},close(){v(),R&&(clearInterval(R),R=null),x&&(clearInterval(x),x=null),O();for(let w of h)try{w.close();}catch{}for(let w of g)try{w.close();}catch{}h.clear(),g.clear(),T.clear(),e.close();}}}async function ds(t,e={}){if(!t.timeline)throw new Error("[Directive DevTools] Orchestrator must have debug: true to use DevTools");let r=await Ze({port:e.port??4040,host:e.host??"localhost"});return Xe({transport:r,timeline:t.timeline,healthMonitor:t.healthMonitor,healthPushIntervalMs:e.healthPushIntervalMs??5e3,batchSize:e.batchSize,authenticate:e.authenticate,getSnapshot:t.getAllAgentStates?()=>{let s=t.getAllAgentStates();return {timestamp:Date.now(),agents:s,eventCount:t.timeline.getEvents().length}}:void 0,getBreakpointState:t.getPendingBreakpoints?()=>({pending:t.getPendingBreakpoints(),resolved:[],cancelled:[]}):void 0,onResumeBreakpoint:t.resumeBreakpoint,onCancelBreakpoint:t.cancelBreakpoint,getScratchpadState:t.getScratchpadState,getDerivedState:t.getDerivedState,onForkFromSnapshot:t.timeline?.forkFrom?s=>(t.timeline.forkFrom(s),{newEventCount:t.timeline.getEvents().length}):void 0})}async function Ze(t={}){let e=t.port??4040,r=t.host??"localhost",{WebSocketServer:s}=await import('ws'),n=new s({port:e,host:r,maxPayload:t.maxPayloadBytes??1048576}),o=null;return n.on("connection",a=>{let c=null,i=null,u={send(l){a.readyState===a.OPEN&&a.send(l);},close(){a.close();}};a.on("message",l=>{c&&c(l.toString());}),a.on("close",()=>{i&&i();}),o?.(u,l=>{c=l;},l=>{i=l;});}),{onConnection(a){o=a;},close(){n.close();}}}function te(t){return Number.isFinite(t)?t:0}function we(t){let e=Object.keys(t),r=new Map;for(let[d,y]of Object.entries(t))for(let f of y.produces){if(r.has(f))throw new Error(`[Directive Goal] Fact key "${f}" is produced by both "${r.get(f)}" and "${d}". Each fact key must have exactly one producer.`);r.set(f,d);}let s=[],n=new Map,o=new Map;for(let d of e)n.set(d,0),o.set(d,[]);for(let[d,y]of Object.entries(t))for(let f of y.requires??[]){let m=r.get(f);m&&m!==d&&(s.push({from:m,to:d,factKey:f}),o.get(m).push(d),n.set(d,(n.get(d)??0)+1));}let a=[];for(let[d,y]of n)y===0&&a.push(d);let c=[],i=0;for(;i<a.length;){let d=a[i++];c.push(d);for(let y of o.get(d)??[]){let f=(n.get(y)??1)-1;n.set(y,f),f===0&&a.push(y);}}if(c.length!==e.length){let d=new Set(c),y=e.filter(f=>!d.has(f));throw new Error(`[Directive Goal] Circular dependency detected among agents: ${y.join(", ")}. Review their produces/requires declarations.`)}let u=c.filter(d=>(t[d].requires??[]).every(m=>!r.has(m)||r.get(m)===d)),l=new Set;for(let d of s)l.add(d.from);let p=e.filter(d=>!l.has(d));return {order:c,edges:s,roots:u,leaves:p,producers:r}}function ps(t){let e=we(t);return {order:[...e.order],edges:[...e.edges],roots:[...e.roots],leaves:[...e.leaves],producers:new Map(e.producers)}}function gs(t){let e=[],r=[];Object.keys(t).length===0&&e.push("No agents declared");for(let[n,o]of Object.entries(t))o.produces.length===0&&r.push(`Agent "${n}" has no produces \u2014 it will never contribute`);let s=new Set;for(let n of Object.values(t))for(let o of n.produces)s.add(o);for(let[n,o]of Object.entries(t))for(let a of o.requires??[])s.has(a)||r.push(`Agent "${n}" requires "${a}" which no agent produces \u2014 must be in initial facts`);try{we(t);}catch(n){e.push(n instanceof Error?n.message:String(n));}return {valid:e.length===0,errors:e,warnings:r}}function ms(t,e=[],r=50){let s=we(t),n=new Set;for(let l of Object.values(t))for(let p of l.produces)n.add(p);let o=[];for(let l of Object.values(t))for(let p of l.requires??[])n.has(p)||o.push(p);let a=new Set(e),c=new Set,i=[];for(let l=1;l<=r;l++){let p=s.order.filter(y=>c.has(y)?false:(t[y].requires??[]).every(S=>a.has(S)));if(p.length===0)break;let d=[];for(let y of p){c.add(y);for(let f of t[y].produces)a.has(f)||(d.push(f),a.add(f));}i.push({step:l,agents:p,availableFacts:[...a],producedFacts:d});}let u=Object.keys(t).filter(l=>!c.has(l));return {steps:i,unreachableAgents:u,externalDeps:[...new Set(o)],feasible:u.length===0}}function fs(t){let e=t.stepMetrics.map(u=>{let l=te(u.satisfaction),p=te(u.satisfactionDelta),d=u.nodesRun.join(", "),y=u.factsProduced.length>0?u.factsProduced.join(", "):"none",f=+te(l-p).toFixed(3),m=p>=0?`+${p.toFixed(3)}`:p.toFixed(3),S=`Step ${u.step}: Ran ${d}. Produced: ${y}. Satisfaction: ${f} \u2192 ${l.toFixed(3)} (${m}). ${u.tokensConsumed} tokens, ${u.durationMs}ms.`;return {step:u.step,agents:u.nodesRun,factsProduced:u.factsProduced,satisfaction:l,satisfactionDelta:p,durationMs:u.durationMs,tokensConsumed:u.tokensConsumed,description:S}}),r=t.relaxations.map(u=>{let l;switch(u.strategy){case "allow_rerun":l=`Step ${u.step}: Applied relaxation "${u.label}" \u2014 re-enabled completed nodes for another run.`;break;case "inject_facts":l=`Step ${u.step}: Applied relaxation "${u.label}" \u2014 injected fact values to unblock dependencies.`;break;case "accept_partial":l=`Step ${u.step}: Applied relaxation "${u.label}" \u2014 accepted current facts as partial result.`;break;case "alternative_nodes":l=`Step ${u.step}: Applied relaxation "${u.label}" \u2014 added alternative nodes to the graph.`;break;case "custom":l=`Step ${u.step}: Applied relaxation "${u.label}" \u2014 ran custom recovery logic.`;break;default:l=`Step ${u.step}: Applied relaxation "${u.label}" (${u.strategy}).`;}return {step:u.step,label:u.label,strategy:u.strategy,description:l}}),s=t.stepMetrics.length>0?te(t.stepMetrics[0].satisfaction-t.stepMetrics[0].satisfactionDelta).toFixed(3):"0",n=t.stepMetrics.length>0?te(t.stepMetrics[t.stepMetrics.length-1].satisfaction).toFixed(3):"0",o=t.achieved?"Goal achieved":"Goal not achieved",a=t.relaxations.length>0?` ${t.relaxations.length} relaxation(s) applied.`:"",c=t.error?` Error: ${t.error}`:"",i=`${o} in ${t.steps} step(s) (${t.totalTokens.toLocaleString()} tokens, ${t.durationMs}ms). Satisfaction: ${s} \u2192 ${n}.`+a+c;return {achieved:t.achieved,summary:i,steps:e,relaxations:r,totalTokens:t.totalTokens,durationMs:t.durationMs}}function ys(t,e=false){let r=false,s=[],n=[],o=e?(a,...c)=>console.debug(`[MCP Stub] ${a}`,...c):()=>{};return {async connect(){o(`Connecting to ${t.name} (${t.transport})`),r=true;},async disconnect(){r=false;},isConnected(){return r},getCapabilities(){return {tools:true,resources:true,prompts:true}},async listTools(){return s},async callTool(a,c){return o(`Calling tool ${a}`,c),{content:[{type:"text",text:`Stub result for ${a}`}]}},async listResources(){return n},async readResource(a){return o(`Reading resource ${a}`),{contents:[{uri:a,text:`Stub content for ${a}`}]}},async listPrompts(){return []},async getPrompt(a){return {messages:[{role:"user",content:{type:"text",text:`Stub prompt ${a}`}}]}}}}function hs(t,e,r){let s=Date.now(),n=t.get(e);return !n||s>n.resetTime?(t.set(e,{count:1,resetTime:s+6e4}),true):n.count>=r?false:(n.count++,true)}function vs(t){let{servers:e,toolConstraints:r={},resourceMappings:s=[],events:n={},autoConnect:o=false,autoReconnect:a=true,debug:c=false,allowDirectCalls:i=false}=t;!t.clientFactory&&(typeof process<"u"&&process.env?.NODE_ENV==="production"?console.warn(`[Directive MCP] WARNING: Using stub MCP client in production!
|
|
59
|
+
`;function H(t){let e=t.nullable?" (nullable)":"";switch(t.kind){case "literal":return `literal ${JSON.stringify(t.value)} (${t.primitive})${e}`;case "enum":return `enum ${JSON.stringify(t.values)} (${t.primitive})${e}`;case "array":return `array of ${H(t.element)}${e}`;case "tuple":return `tuple [${t.elements.map(H).join(", ")}]${e}`;case "object":return `object { ${Object.entries(t.shape).map(([n,o])=>`${n}: ${H(o)}`).join(", ")} }${e}`;case "record":return `record<string, ${H(t.value)}>${e}`;case "union":return `union (${t.members.map(H).join(" | ")})${e}`;case "branded":return `branded(${H(t.inner)})${e}`;default:return `${t.kind}${e}`}}function io(t,e){let n=[ao];n.push(`
|
|
60
|
+
Facts in this schema (path \u2192 kind \u2192 allowed operators):`);for(let[o,r]of t.entries()){if(e&&!o.startsWith(e))continue;let s=core.getOperatorsForKind(r);n.push(` ${o}: ${H(r)} \u2014 allowed: ${s.join(", ")}`);}return e&&n.push(`
|
|
61
|
+
The user intent will be over the namespace "${e}". Use only facts at or below that path.`),n.push(`
|
|
62
|
+
Respond with ONLY the JSON predicate object. No prose. No markdown fences. No "Here is...".`),n.join(`
|
|
63
|
+
`)}function co(t,e,n){let o=[];o.push("Your previous response was rejected. Original intent (still applies):"),o.push(` ${t}`);let r=null;if(typeof n=="string")o.push(`
|
|
64
|
+
Reason: ${n}`);else {o.push(`
|
|
65
|
+
Validation errors (fix every one):`),r=new Set;for(let s of n)o.push(` - path "${s.path}", op "${s.op}": ${s.reason}`),s.allowedOps&&s.allowedOps.length>0&&o.push(` \u2192 allowed operators for this fact: ${s.allowedOps.join(", ")}`),r.add(s.path);}if(o.push(`
|
|
66
|
+
Schema reminder:`),r&&r.size>0){let s=0;for(let c of r){let i=e.get(c);if(i){let u=core.getOperatorsForKind(i);o.push(` ${c}: ${H(i)} \u2014 allowed: ${u.join(", ")}`),s++;}else o.push(` ${c}: (not in schema \u2014 pick from the available facts below)`);}let a=e.size-s;a>0&&o.push(` \u2026and ${a} more fact(s) available \u2014 ask if you need the full list.`);}else for(let[s,a]of e.entries()){let c=core.getOperatorsForKind(a);o.push(` ${s}: ${H(a)} \u2014 allowed: ${c.join(", ")}`);}return o.push(`
|
|
67
|
+
Emit ONLY a corrected JSON FactPredicate object. No prose.`),o.join(`
|
|
68
|
+
`)}function uo(t,e,n){if(t.length>n.maxPredicateBytes)return {ok:false,reason:`Output exceeded maxPredicateBytes=${n.maxPredicateBytes} (got ${t.length}). Emit a smaller predicate.`};let o;try{o=chunkX3VQ5F7D_cjs.H(t);}catch(s){return {ok:false,reason:`Could not extract JSON from output: ${s instanceof Error?s.message:String(s)}`}}try{core.validatePredicate(o);}catch(s){return {ok:false,reason:`Structural validation failed: ${s instanceof Error?s.message:String(s)}`}}let r=core.validatePredicateAgainstSchema(o,e,{maxOperatorCount:n.maxOperatorCount,maxArrayOperandLength:n.maxArrayOperandLength});return r.ok?{ok:true,predicate:o}:{ok:false,reason:`Predicate has ${r.errors.length} schema-validation error(s).`,details:r.errors}}var lo=3,po=65536,go=256,mo=1e3;async function fo(t){let e=await Ce(t);if(e.predicate===null)throw new ne(`[Directive] predicateFromIntent: failed after ${e.attempts} attempt(s). Last error: ${e.errors[e.errors.length-1]?.reason??"unknown"}`,e.attempts,e.errors,e.lastRawOutput);return e.predicate}async function Ce(t){let{intent:e,schema:n,runner:o,agent:r,factPath:s,maxRetries:a=lo,maxPredicateBytes:c=po,maxOperatorCount:i=go,maxArrayOperandLength:u=mo,redact:l,signal:p}=t;if(typeof e!="string"||e.length===0)throw new Error("[Directive] predicateFromIntent: `intent` must be a non-empty string.");let d=l?l(e):e,f=core.getSchemaFieldKinds(n);if(f.size===0)throw new Error("[Directive] predicateFromIntent: schema has no introspectable facts. Pass a module schema or a bare facts record.");let y=io(f,s),m=r??{name:"predicate-emitter"},S={...m,instructions:`${m.instructions??""}
|
|
69
|
+
|
|
70
|
+
${y}`.trim()},h=[],g,v=0,w={maxPredicateBytes:c,maxOperatorCount:i,maxArrayOperandLength:u};for(;v<a+1;){if(p?.aborted)throw new Error("aborted");v++;let M=v===1?`Intent: ${d}
|
|
71
|
+
|
|
72
|
+
Emit the predicate now.`:co(d,f,h[h.length-1].details??h[h.length-1].reason),x;try{x=await o(S,M,{signal:p});}catch(b){if(p?.aborted)throw new Error("aborted");h.push({attempt:v,reason:`LLM runner threw: ${b instanceof Error?b.message:String(b)}`});continue}let P=typeof x.output=="string"?x.output:JSON.stringify(x.output);g=P;let O=uo(P,f,w);if(O.ok)return {predicate:O.predicate,attempts:v,errors:h,lastRawOutput:g};h.push({attempt:v,reason:O.reason,details:O.details});}return {predicate:null,attempts:v,errors:h,lastRawOutput:g}}function Xe(t,e){let n=core.getSchemaFieldKinds(t),o=[];for(let[r,s]of n.entries()){if(e&&!r.startsWith(e))continue;let a=core.getOperatorsForKind(s);o.push(`${r}: ${H(s)} \u2014 ops: ${a.join(", ")}`);}return o.join(`
|
|
73
|
+
`)}function Ze(t,e){return e??`Emit a Directive FactPredicate (JSON tree of facts and operators) matching the user's intent. Schema:
|
|
74
|
+
${t}`}function yo(t,e={}){let n=Xe(t,e.factPath),o=e.name??"emit_predicate",r=Ze(n,e.description);return {type:"function",function:{name:o,description:r,parameters:{type:"object",properties:{predicate:{type:"object"}},required:["predicate"]}},schemaSummary:n}}function et(t,e={}){let n=Xe(t,e.factPath),o=e.name??"emit_predicate",r=Ze(n,e.description);return {name:o,description:r,input_schema:{type:"object",properties:{predicate:{type:"object"}},required:["predicate"]},schemaSummary:n}}function ho(t,e={}){return et(t,e)}async function bo(t){let e=await Ce(t);if(e.predicate===null)throw new ne(`[Directive] predicateFromIntentWithProvenance: failed after ${e.attempts} attempt(s). Last error: ${e.errors[e.errors.length-1]?.reason??"unknown"}`,e.attempts,e.errors,e.lastRawOutput);let n=t.redact?t.redact(t.intent):t.intent,o=t.agent?.model??"unknown",r=core.predicateHash(e.predicate),s=await so(n),a=t.redactIntent?{model:o,intentHash:s,attemptCount:e.attempts,emittedAt:new Date().toISOString(),predicateHash:r}:{model:o,intent:n,intentHash:s,attemptCount:e.attempts,emittedAt:new Date().toISOString(),predicateHash:r};return {predicate:e.predicate,provenance:a}}function vo(t,e={}){let{maxBatchSize:n=20,maxWaitMs:o=5e3,concurrency:r=5}=e;if(!Number.isFinite(n)||n<1)throw new Error("[Directive] createBatchQueue: maxBatchSize must be a positive finite number (>= 1).");if(!Number.isFinite(o)||o<0)throw new Error("[Directive] createBatchQueue: maxWaitMs must be a non-negative finite number.");if(!Number.isFinite(r)||r<1)throw new Error("[Directive] createBatchQueue: concurrency must be a positive finite number (>= 1).");let s=[],a=null,c=false,i=null;function u(){a===null&&(a=setTimeout(()=>{a=null,d().catch(()=>{});},o));}function l(){a!==null&&(clearTimeout(a),a=null);}async function p(f){let y=0;async function m(){for(;y<f.length;){let h=y++,g=f[h];try{let v=await t(g.agent,g.input,g.options);g.resolve(v);}catch(v){g.reject(v instanceof Error?v:new Error(String(v)));}}}let S=Array.from({length:Math.min(r,f.length)},()=>m());await Promise.all(S);}async function d(){if(i&&await i,s.length===0)return;l();let f=s.splice(0);i=p(f).finally(()=>{i=null,s.length>0&&u();}),await i;}return {submit(f,y,m){return c?Promise.reject(new Error("[Directive] BatchQueue has been destroyed.")):new Promise((S,h)=>{s.push({agent:f,input:y,options:m,resolve:S,reject:h}),s.length>=n?(l(),d().catch(()=>{})):u();})},async flush(){await d();},get pending(){return s.length},async destroy(){c||(c=true,l(),s.length>0&&await d());}}}function tt(){return {callCount:0,errorCount:0,totalCost:0,avgLatencyMs:0,lastErrorAt:null}}function So(t,e){return !t||!e?0:t.inputTokens/1e6*e.inputPerMillion+t.outputTokens/1e6*e.outputPerMillion}function Eo(t){let{providers:e,defaultProvider:n,constraints:o=[],onProviderSelected:r,errorCooldownMs:s=3e4,preferCheapest:a=false}=t;if(!Number.isFinite(s)||s<0)throw new Error("[Directive] createConstraintRouter: errorCooldownMs must be a non-negative finite number.");let c=new Map;for(let y of e)c.set(y.name,y);if(!c.has(n))throw new Error(`[Directive] Default provider "${n}" not found in providers list.`);let i={totalCost:0,callCount:0,errorCount:0,lastProvider:null,avgLatencyMs:0,providers:Object.create(null)};for(let y of e)i.providers[y.name]=tt();let u=0,l=[...o].sort((y,m)=>(m.priority??0)-(y.priority??0));function p(){let y=Date.now();for(let S of l)try{if(S.when(i)){let h=c.get(S.provider);if(h)return {provider:h,reason:"constraint"}}}catch{}let m=e.filter(S=>{let h=i.providers[S.name];return h?!(h.lastErrorAt&&y-h.lastErrorAt<s):true});if(a&&m.length>0){let S=[...m].sort((h,g)=>{let v=h.pricing?h.pricing.inputPerMillion+h.pricing.outputPerMillion:Number.POSITIVE_INFINITY,w=g.pricing?g.pricing.inputPerMillion+g.pricing.outputPerMillion:Number.POSITIVE_INFINITY;return v!==w?v-w:h.name===n?-1:g.name===n?1:0});if(S[0]!==c.get(n))return {provider:S[0],reason:"cheapest"}}return m.length>0&&!m.some(S=>S.name===n)?{provider:m[0],reason:"default"}:{provider:c.get(n),reason:"default"}}function d(y,m,S,h,g){let v=i.providers[y]??tt();if(v.callCount++,i.callCount++,g)v.errorCount++,i.errorCount++,v.lastErrorAt=Date.now();else {let M=So(S,h);v.totalCost+=M,i.totalCost+=M;}u+=m,i.avgLatencyMs=u/i.callCount;let w=v.callCount>0?(v.avgLatencyMs*(v.callCount-1)+m)/v.callCount:m;v.avgLatencyMs=w,i.providers[y]=v,i.lastProvider=y;}let f=async(y,m,S)=>{let{provider:h,reason:g}=p();try{r?.(h.name,g);}catch{}let v=Date.now();try{let w=await h.runner(y,m,S),M=Date.now()-v;return d(h.name,M,w.tokenUsage,h.pricing),w}catch(w){let M=Date.now()-v,x=w instanceof Error?w:new Error(String(w));throw d(h.name,M,void 0,h.pricing,x),x}};return Object.defineProperty(f,"facts",{get:()=>{let y=Object.create(null);for(let m of Object.keys(i.providers))y[m]={...i.providers[m]};return {...i,providers:y}},enumerable:true}),f}function nt(t){let{transport:e,timeline:n,healthMonitor:o,getSnapshot:r,getBreakpointState:s,onResumeBreakpoint:a,onCancelBreakpoint:c,getScratchpadState:i,getDerivedState:u,onForkFromSnapshot:l,batchSize:p=1,batchIntervalMs:d=50,healthPushIntervalMs:f=0,authenticate:y}=t,m=t.maxClients??50,S=`devtools_${crypto.randomUUID()}`,h=new Set,g=new Set,v=[],w=null,M=null;function x(R,_){try{R.send(JSON.stringify(_));}catch{h.delete(R);}}function P(R){let _=JSON.stringify(R),k=[...h];for(let L of k)try{L.send(_);}catch{h.delete(L);}}function O(){v.length!==0&&(v.length===1?P({type:"event",event:v[0]}):P({type:"event_batch",events:v}),v=[]);}let b=n.subscribe(R=>{if(h.size!==0){if(p<=1){P({type:"event",event:R});return}v.push(R),v.length>=p&&O();}});p>1&&d>0&&(w=setInterval(O,d)),f>0&&o&&(M=setInterval(()=>{h.size>0&&P({type:"health",metrics:o.getAllMetrics()});},f));function C(R,_){let k;try{k=JSON.parse(_);}catch{x(R,{type:"error",code:"INVALID_JSON",message:"Could not parse message"});return}if(!k||typeof k!="object"||typeof k.type!="string"){x(R,{type:"error",code:"INVALID_MESSAGE",message:"Missing type field"});return}let L=Date.now(),G=T.get(R)??0;if(L-G<D){x(R,{type:"error",code:"RATE_LIMITED",message:"Too many requests"});return}if(T.set(R,L),k.type==="authenticate"){if(!y){x(R,{type:"error",code:"UNKNOWN_COMMAND",message:"Authentication not configured on this server"});return}if(!g.has(R)){x(R,{type:"error",code:"ALREADY_AUTHENTICATED",message:"Already authenticated"});return}if(typeof k.token!="string"){x(R,{type:"error",code:"AUTH_FAILED",message:"Missing token"}),R.close(),g.delete(R);return}let N=y(k.token),U=V=>{V?(g.delete(R),h.add(R),x(R,{type:"welcome",version:1,sessionId:S,timestamp:Date.now()})):(x(R,{type:"error",code:"AUTH_FAILED",message:"Invalid token"}),g.delete(R),R.close());};N instanceof Promise?N.then(U).catch(()=>{x(R,{type:"error",code:"AUTH_FAILED",message:"Authentication error"}),g.delete(R),R.close();}):U(N);return}if(g.has(R)){x(R,{type:"error",code:"AUTH_REQUIRED",message:"Authentication required"});return}switch(k.type){case "ping":x(R,{type:"pong",timestamp:Date.now()});break;case "request_snapshot":r?x(R,{type:"snapshot",data:r()}):x(R,{type:"error",code:"NO_SNAPSHOT",message:"Snapshot provider not configured"});break;case "request_health":o?x(R,{type:"health",metrics:o.getAllMetrics()}):x(R,{type:"error",code:"NO_HEALTH",message:"Health monitor not configured"});break;case "request_events":{let N=n.getEvents(),U=k.since,V=U!=null?N.filter(ge=>ge.id>U):N;x(R,{type:"event_batch",events:V});break}case "request_breakpoints":s?x(R,{type:"breakpoints",state:s()}):x(R,{type:"error",code:"NO_BREAKPOINTS",message:"Breakpoint provider not configured"});break;case "resume_breakpoint":if(a&&typeof k.breakpointId=="string"){let N=k.modifications?{input:k.modifications.input,skip:k.modifications.skip}:void 0;a(k.breakpointId,N);}else x(R,{type:"error",code:"NO_BREAKPOINTS",message:"Breakpoint resume not configured"});break;case "cancel_breakpoint":if(c&&typeof k.breakpointId=="string"){let N=typeof k.reason=="string"?k.reason:void 0;c(k.breakpointId,N);}else x(R,{type:"error",code:"NO_BREAKPOINTS",message:"Breakpoint cancel not configured"});break;case "export_session":x(R,{type:"event_batch",events:n.getEvents()});break;case "import_session":{if(typeof k.data!="string")x(R,{type:"error",code:"INVALID_DATA",message:"Missing data field for import"});else if(k.data.length>10485760)x(R,{type:"error",code:"IMPORT_TOO_LARGE",message:`Import data exceeds ${10485760/1024/1024} MB limit`});else try{n.import(k.data),x(R,{type:"event_batch",events:n.getEvents()});}catch(U){let V=U instanceof Error?U.message:String(U);x(R,{type:"error",code:"IMPORT_FAILED",message:V});}break}case "request_scratchpad":i?x(R,{type:"scratchpad_state",data:i()}):x(R,{type:"error",code:"NO_SCRATCHPAD",message:"Scratchpad provider not configured"});break;case "request_derived":u?x(R,{type:"derived_state",data:u()}):x(R,{type:"error",code:"NO_DERIVED",message:"Derived state provider not configured"});break;case "fork_from_snapshot":{if(l&&typeof k.eventId=="number")try{let N=l(k.eventId);x(R,{type:"fork_complete",eventId:k.eventId,newEventCount:N.newEventCount});}catch(N){let U=N instanceof Error?N.message:String(N);x(R,{type:"error",code:"FORK_FAILED",message:U});}else x(R,{type:"error",code:"NO_FORK",message:"Fork provider not configured"});break}default:x(R,{type:"error",code:"UNKNOWN_COMMAND",message:`Unknown message type: ${String(k.type).slice(0,100)}`});}}let T=new Map,D=50;return e.onConnection((R,_,k)=>{if(h.size+g.size>=m){try{let L={type:"error",code:"MAX_CLIENTS",message:"Connection limit reached"};R.send(JSON.stringify(L));}catch{}R.close();return}y?g.add(R):(h.add(R),x(R,{type:"welcome",version:1,sessionId:S,timestamp:Date.now()})),_(L=>C(R,L)),k(()=>{h.delete(R),g.delete(R),T.delete(R);});}),{get clientCount(){return h.size},broadcast(R){P(R);},pushHealth(){o&&h.size>0&&P({type:"health",metrics:o.getAllMetrics()});},pushBreakpoints(){s&&h.size>0&&P({type:"breakpoints",state:s()});},pushScratchpadUpdate(R,_){h.size>0&&P({type:"scratchpad_update",key:R,value:_});},pushDerivedUpdate(R,_){h.size>0&&P({type:"derived_update",id:R,value:_});},pushTokenStream(R,_,k){h.size>0&&P({type:"token_stream",agentId:R,tokens:_,tokenCount:k});},pushStreamDone(R,_){h.size>0&&P({type:"stream_done",agentId:R,totalTokens:_});},close(){b(),w&&(clearInterval(w),w=null),M&&(clearInterval(M),M=null),O();for(let R of h)try{R.close();}catch{}for(let R of g)try{R.close();}catch{}h.clear(),g.clear(),T.clear(),e.close();}}}async function wo(t,e={}){if(!t.timeline)throw new Error("[Directive DevTools] Orchestrator must have debug: true to use DevTools");let n=await rt({port:e.port??4040,host:e.host??"localhost"});return nt({transport:n,timeline:t.timeline,healthMonitor:t.healthMonitor,healthPushIntervalMs:e.healthPushIntervalMs??5e3,batchSize:e.batchSize,authenticate:e.authenticate,getSnapshot:t.getAllAgentStates?()=>{let o=t.getAllAgentStates();return {timestamp:Date.now(),agents:o,eventCount:t.timeline.getEvents().length}}:void 0,getBreakpointState:t.getPendingBreakpoints?()=>({pending:t.getPendingBreakpoints(),resolved:[],cancelled:[]}):void 0,onResumeBreakpoint:t.resumeBreakpoint,onCancelBreakpoint:t.cancelBreakpoint,getScratchpadState:t.getScratchpadState,getDerivedState:t.getDerivedState,onForkFromSnapshot:t.timeline?.forkFrom?o=>(t.timeline.forkFrom(o),{newEventCount:t.timeline.getEvents().length}):void 0})}async function rt(t={}){let e=t.port??4040,n=t.host??"localhost",{WebSocketServer:o}=await import('ws'),r=new o({port:e,host:n,maxPayload:t.maxPayloadBytes??1048576}),s=null;return r.on("connection",a=>{let c=null,i=null,u={send(l){a.readyState===a.OPEN&&a.send(l);},close(){a.close();}};a.on("message",l=>{c&&c(l.toString());}),a.on("close",()=>{i&&i();}),s?.(u,l=>{c=l;},l=>{i=l;});}),{onConnection(a){s=a;},close(){r.close();}}}function re(t){return Number.isFinite(t)?t:0}function Ae(t){let e=Object.keys(t),n=new Map;for(let[d,f]of Object.entries(t))for(let y of f.produces){if(n.has(y))throw new Error(`[Directive Goal] Fact key "${y}" is produced by both "${n.get(y)}" and "${d}". Each fact key must have exactly one producer.`);n.set(y,d);}let o=[],r=new Map,s=new Map;for(let d of e)r.set(d,0),s.set(d,[]);for(let[d,f]of Object.entries(t))for(let y of f.requires??[]){let m=n.get(y);m&&m!==d&&(o.push({from:m,to:d,factKey:y}),s.get(m).push(d),r.set(d,(r.get(d)??0)+1));}let a=[];for(let[d,f]of r)f===0&&a.push(d);let c=[],i=0;for(;i<a.length;){let d=a[i++];c.push(d);for(let f of s.get(d)??[]){let y=(r.get(f)??1)-1;r.set(f,y),y===0&&a.push(f);}}if(c.length!==e.length){let d=new Set(c),f=e.filter(y=>!d.has(y));throw new Error(`[Directive Goal] Circular dependency detected among agents: ${f.join(", ")}. Review their produces/requires declarations.`)}let u=c.filter(d=>(t[d].requires??[]).every(m=>!n.has(m)||n.get(m)===d)),l=new Set;for(let d of o)l.add(d.from);let p=e.filter(d=>!l.has(d));return {order:c,edges:o,roots:u,leaves:p,producers:n}}function Ro(t){let e=Ae(t);return {order:[...e.order],edges:[...e.edges],roots:[...e.roots],leaves:[...e.leaves],producers:new Map(e.producers)}}function Co(t){let e=[],n=[];Object.keys(t).length===0&&e.push("No agents declared");for(let[r,s]of Object.entries(t))s.produces.length===0&&n.push(`Agent "${r}" has no produces \u2014 it will never contribute`);let o=new Set;for(let r of Object.values(t))for(let s of r.produces)o.add(s);for(let[r,s]of Object.entries(t))for(let a of s.requires??[])o.has(a)||n.push(`Agent "${r}" requires "${a}" which no agent produces \u2014 must be in initial facts`);try{Ae(t);}catch(r){e.push(r instanceof Error?r.message:String(r));}return {valid:e.length===0,errors:e,warnings:n}}function Ao(t,e=[],n=50){let o=Ae(t),r=new Set;for(let l of Object.values(t))for(let p of l.produces)r.add(p);let s=[];for(let l of Object.values(t))for(let p of l.requires??[])r.has(p)||s.push(p);let a=new Set(e),c=new Set,i=[];for(let l=1;l<=n;l++){let p=o.order.filter(f=>c.has(f)?false:(t[f].requires??[]).every(S=>a.has(S)));if(p.length===0)break;let d=[];for(let f of p){c.add(f);for(let y of t[f].produces)a.has(y)||(d.push(y),a.add(y));}i.push({step:l,agents:p,availableFacts:[...a],producedFacts:d});}let u=Object.keys(t).filter(l=>!c.has(l));return {steps:i,unreachableAgents:u,externalDeps:[...new Set(s)],feasible:u.length===0}}function xo(t){let e=t.stepMetrics.map(u=>{let l=re(u.satisfaction),p=re(u.satisfactionDelta),d=u.nodesRun.join(", "),f=u.factsProduced.length>0?u.factsProduced.join(", "):"none",y=+re(l-p).toFixed(3),m=p>=0?`+${p.toFixed(3)}`:p.toFixed(3),S=`Step ${u.step}: Ran ${d}. Produced: ${f}. Satisfaction: ${y} \u2192 ${l.toFixed(3)} (${m}). ${u.tokensConsumed} tokens, ${u.durationMs}ms.`;return {step:u.step,agents:u.nodesRun,factsProduced:u.factsProduced,satisfaction:l,satisfactionDelta:p,durationMs:u.durationMs,tokensConsumed:u.tokensConsumed,description:S}}),n=t.relaxations.map(u=>{let l;switch(u.strategy){case "allow_rerun":l=`Step ${u.step}: Applied relaxation "${u.label}" \u2014 re-enabled completed nodes for another run.`;break;case "inject_facts":l=`Step ${u.step}: Applied relaxation "${u.label}" \u2014 injected fact values to unblock dependencies.`;break;case "accept_partial":l=`Step ${u.step}: Applied relaxation "${u.label}" \u2014 accepted current facts as partial result.`;break;case "alternative_nodes":l=`Step ${u.step}: Applied relaxation "${u.label}" \u2014 added alternative nodes to the graph.`;break;case "custom":l=`Step ${u.step}: Applied relaxation "${u.label}" \u2014 ran custom recovery logic.`;break;default:l=`Step ${u.step}: Applied relaxation "${u.label}" (${u.strategy}).`;}return {step:u.step,label:u.label,strategy:u.strategy,description:l}}),o=t.stepMetrics.length>0?re(t.stepMetrics[0].satisfaction-t.stepMetrics[0].satisfactionDelta).toFixed(3):"0",r=t.stepMetrics.length>0?re(t.stepMetrics[t.stepMetrics.length-1].satisfaction).toFixed(3):"0",s=t.achieved?"Goal achieved":"Goal not achieved",a=t.relaxations.length>0?` ${t.relaxations.length} relaxation(s) applied.`:"",c=t.error?` Error: ${t.error}`:"",i=`${s} in ${t.steps} step(s) (${t.totalTokens.toLocaleString()} tokens, ${t.durationMs}ms). Satisfaction: ${o} \u2192 ${r}.`+a+c;return {achieved:t.achieved,summary:i,steps:e,relaxations:n,totalTokens:t.totalTokens,durationMs:t.durationMs}}function Mo(t,e=false){let n=false,o=[],r=[],s=e?(a,...c)=>console.debug(`[MCP Stub] ${a}`,...c):()=>{};return {async connect(){s(`Connecting to ${t.name} (${t.transport})`),n=true;},async disconnect(){n=false;},isConnected(){return n},getCapabilities(){return {tools:true,resources:true,prompts:true}},async listTools(){return o},async callTool(a,c){return s(`Calling tool ${a}`,c),{content:[{type:"text",text:`Stub result for ${a}`}]}},async listResources(){return r},async readResource(a){return s(`Reading resource ${a}`),{contents:[{uri:a,text:`Stub content for ${a}`}]}},async listPrompts(){return []},async getPrompt(a){return {messages:[{role:"user",content:{type:"text",text:`Stub prompt ${a}`}}]}}}}function To(t,e,n){let o=Date.now(),r=t.get(e);return !r||o>r.resetTime?(t.set(e,{count:1,resetTime:o+6e4}),true):r.count>=n?false:(r.count++,true)}function Po(t){let{servers:e,toolConstraints:n={},resourceMappings:o=[],events:r={},autoConnect:s=false,autoReconnect:a=true,debug:c=false,allowDirectCalls:i=false}=t;!t.clientFactory&&(typeof process<"u"&&process.env?.NODE_ENV==="production"?console.warn(`[Directive MCP] WARNING: Using stub MCP client in production!
|
|
75
75
|
The stub client returns mock data and does not connect to real MCP servers.
|
|
76
76
|
Provide a real 'clientFactory' option to connect to actual MCP servers:
|
|
77
77
|
|
|
@@ -80,13 +80,13 @@ Provide a real 'clientFactory' option to connect to actual MCP servers:
|
|
|
80
80
|
const adapter = createMCPAdapter({
|
|
81
81
|
servers: [...],
|
|
82
82
|
clientFactory: (config) => new Client(config),
|
|
83
|
-
});`):c&&console.debug("[Directive MCP] Using stub client for development. Provide 'clientFactory' for production use."));let l=t.clientFactory??(v=>ys(v,c)),p=t.approvalTimeoutMs??3e5,d={servers:new Map,toolConstraints:new Map(Object.entries(r)),rateLimiters:new Map,pendingApprovals:new Map,approvedRequests:new Set,rejectedRequests:new Set},y=0,f=new Map,m=new Map;function S(v){return new Promise((C,T)=>{if(d.approvedRequests.has(v)){d.approvedRequests.delete(v),d.pendingApprovals.delete(v),n.onApprovalResolved?.(v,true),C();return}if(d.rejectedRequests.has(v)){d.rejectedRequests.delete(v),d.pendingApprovals.delete(v);let w=m.get(v);m.delete(v),n.onApprovalResolved?.(v,false),T(new Error(`[Directive MCP] Tool call request ${v} was rejected${w?`: ${w}`:""}`));return}let D=setTimeout(()=>{f.delete(v),d.pendingApprovals.delete(v),T(new Error(`[Directive MCP] Approval timeout: Request ${v} was not approved or rejected within ${p}ms. Call adapter.approve("${v}") or adapter.reject("${v}") to resolve.`));},p);f.set(v,{resolve:C,reject:T,timeoutId:D});})}function h(v,C,T){let D=f.get(v);D?(clearTimeout(D.timeoutId),f.delete(v),d.pendingApprovals.delete(v),n.onApprovalResolved?.(v,C),C?D.resolve():D.reject(new Error(`[Directive MCP] Tool call request ${v} was rejected${T?`: ${T}`:""}`))):(C?d.approvedRequests.add(v):(d.rejectedRequests.add(v),T&&m.set(v,T)),setTimeout(()=>{d.approvedRequests.delete(v),d.rejectedRequests.delete(v),m.delete(v),d.pendingApprovals.delete(v);},p));}let g=new Map;for(let v of e)d.servers.set(v.name,{config:v,client:null,tools:[],resources:[],status:"disconnected"}),g.set(v.name,{timer:null,attempts:0,maxAttempts:v.retry?.maxAttempts??10,baseDelay:v.retry?.backoffMs??5e3});function b(v){let C=/[;|&$`><]/;if(v.command&&C.test(v.command))throw new Error(`[Directive MCP] Stdio command for server '${v.name}' contains shell metacharacters: '${v.command}'. This may indicate a command injection vulnerability. Use 'args' for command arguments instead.`);if(v.args){for(let T of v.args)if(C.test(T))throw new Error(`[Directive MCP] Stdio argument for server '${v.name}' contains shell metacharacters: '${T}'. This may indicate a command injection vulnerability.`)}}async function R(v){let C=d.servers.get(v);if(!C)throw new Error(`Unknown MCP server: ${v}`);if(C.status!=="connected"){C.config.transport==="stdio"&&b(C.config),C.status="connecting";try{let T=l(C.config);await T.connect(),C.client=T,C.status="connected";let D=g.get(v);D&&(D.attempts=0,D.timer&&(clearTimeout(D.timer),D.timer=null)),T.getCapabilities().tools&&(C.tools=await T.listTools()),T.getCapabilities().resources&&(C.resources=await T.listResources()),C.lastSync=Date.now(),n.onConnect?.(v);}catch(T){if(C.status="error",C.error=T instanceof Error?T:new Error(String(T)),n.onError?.(v,C.error),a){let D=g.get(v);if(D&&D.attempts<D.maxAttempts){D.attempts++;let w=Math.min(D.baseDelay*2**(D.attempts-1)+Math.random()*1e3,6e4);D.timer=setTimeout(()=>{D.timer=null,R(v).catch(()=>{});},w);}else D&&console.error(`[Directive MCP] Max reconnect attempts (${D.maxAttempts}) reached for server '${v}'. Call adapter.connectServer("${v}") to retry manually.`);}throw C.error}}}async function x(v){let C=g.get(v);C?.timer&&(clearTimeout(C.timer),C.timer=null,C.attempts=0);let T=d.servers.get(v);if(!(!T||!T.client))try{await T.client.disconnect();}finally{T.status="disconnected",T.client=null,n.onDisconnect?.(v);}}async function M(v,C,T,D){let w=d.servers.get(v);if(!w)throw new Error(`[Directive MCP] Unknown server '${v}'. Available servers: ${Array.from(d.servers.keys()).join(", ")||"(none)"}`);if(!w.client)throw new Error(`[Directive MCP] Server '${v}' is not connected. Call 'adapter.connect()' or 'adapter.connectServer("${v}")' first.`);let _=`${v}.${C}`,k=d.toolConstraints.get(_);if(k){if(k.rateLimit){let F=d.rateLimiters.get(_);if(!hs(d.rateLimiters,_,k.rateLimit)){let N=F?.resetTime?new Date(F.resetTime).toISOString():"unknown";throw new Error(`[Directive MCP] Rate limit exceeded for '${_}': ${F?.count??0}/${k.rateLimit} requests per minute. Resets at ${N}.`)}}if(k.maxArgSize){let F=JSON.stringify(T).length;if(F>k.maxArgSize)throw new Error(`Arguments exceed max size (${F} > ${k.maxArgSize})`)}if(k.when&&!await k.when(D,T))throw new Error(`Constraint not satisfied for ${_}`);if(k.requireApproval){let F=`approval-${++y}-${Date.now()}`,N={id:F,server:v,tool:C,args:T,requestedAt:Date.now()};d.pendingApprovals.set(F,N),n.onApprovalRequest?.(N),await S(F);}}n.onToolCall?.(v,C,T);let L=await Promise.race([w.client.callTool(C,T),new Promise((F,N)=>setTimeout(()=>N(new Error(`Tool call timeout: ${_}`)),k?.timeout??3e4))]);return n.onToolResult?.(v,C,L),L}let P={name:"mcp-adapter",onInit:async()=>{o&&await Promise.all(Array.from(d.servers.keys()).map(v=>R(v).catch(C=>console.error(`Failed to connect to ${v}:`,C))));},onDestroy:async()=>{for(let v of g.values())v.timer&&(clearTimeout(v.timer),v.timer=null);for(let[,v]of f)clearTimeout(v.timeoutId),v.reject(new Error("[Directive MCP] Adapter destroyed while awaiting approval"));f.clear(),await Promise.all(Array.from(d.servers.keys()).map(v=>x(v).catch(C=>console.error(`Failed to disconnect from ${v}:`,C))));}};async function O(v){for(let C of s)for(let[T,D]of d.servers)if(D.client){for(let w of D.resources)if(typeof C.pattern=="string"?Ss(w.uri,C.pattern):C.pattern.test(w.uri))try{let k=await D.client.readResource(w.uri),L=k.contents[0]?.text??"",F=C.transform?C.transform(L):L;v[C.factKey]=F,n.onResourceUpdate?.(T,w.uri,k);}catch(k){console.error(`Failed to sync resource ${w.uri}:`,k);}}}return {plugin:P,async connect(){await Promise.all(Array.from(d.servers.keys()).map(R));},connectServer:R,async disconnect(){await Promise.all(Array.from(d.servers.keys()).map(x));},disconnectServer:x,getTools(){let v=new Map;for(let[C,T]of d.servers)v.set(C,T.tools);return v},getResources(){let v=new Map;for(let[C,T]of d.servers)v.set(C,T.resources);return v},async callTool(v,C,T,D){return M(v,C,T,D)},async callToolDirect(v,C,T){if(!i)throw new Error("[Directive] callToolDirect is disabled by default. Pass { allowDirectCalls: true } to enable unconstrained tool calls.");process.env.NODE_ENV!=="production"&&console.warn("[Directive] callToolDirect bypasses all constraints (rate limits, approvals, timeouts).");let D=d.servers.get(v);if(!D)throw new Error(`[Directive MCP] Unknown server '${v}'. Available servers: ${Array.from(d.servers.keys()).join(", ")||"(none)"}`);if(!D.client)throw new Error(`[Directive MCP] Server '${v}' is not connected. Call 'adapter.connect()' or 'adapter.connectServer("${v}")' first.`);n.onToolCall?.(v,C,T);let w=await D.client.callTool(C,T);return n.onToolResult?.(v,C,w),w},async readResource(v,C){let T=d.servers.get(v);if(!T)throw new Error(`[Directive MCP] Unknown server '${v}'. Available servers: ${Array.from(d.servers.keys()).join(", ")||"(none)"}`);if(!T.client)throw new Error(`[Directive MCP] Server '${v}' is not connected. Call 'adapter.connect()' or 'adapter.connectServer("${v}")' first.`);let D=await T.client.readResource(C);return n.onResourceUpdate?.(v,C,D),D},syncResources:O,getServerStatus(v){return d.servers.get(v)},getAllServerStatuses(){return new Map(d.servers)},approve(v){if(!d.pendingApprovals.get(v)&&!f.has(v))throw new Error(`[Directive MCP] No pending approval request with ID '${v}'. Pending requests: ${Array.from(d.pendingApprovals.keys()).join(", ")||"(none)"}`);h(v,true);},reject(v,C){if(!d.pendingApprovals.get(v)&&!f.has(v))throw new Error(`[Directive MCP] No pending approval request with ID '${v}'. Pending requests: ${Array.from(d.pendingApprovals.keys()).join(", ")||"(none)"}`);h(v,false,C);},getPendingApprovals(){return Array.from(d.pendingApprovals.values())},getRejectionReason(v){return m.get(v)}}}var ne=new Map,bs=200;function Ss(t,e){let r=ne.get(e);if(!r){let s=e.replace(/\*\*/g,"\0GLOBSTAR\0").replace(/\*/g,"\0STAR\0").replace(/\?/g,"\0QUESTION\0").replace(/[.+^${}()|[\]\\]/g,"\\$&").replace(/\0GLOBSTAR\0/g,".*").replace(/\0STAR\0/g,"[^/]*").replace(/\0QUESTION\0/g,".");if(r=new RegExp(`^${s}$`),ne.size>=bs){let n=ne.keys().next().value;n!==void 0&&ne.delete(n);}ne.set(e,r);}return r.test(t)}function Es(t){let e=[];for(let[r,s]of t)for(let n of s)e.push({type:"function",function:{name:`${r}.${n.name}`,description:n.description??`Tool: ${n.name}`,parameters:n.inputSchema}});return e}function Rs(t,e,r){return {type:"MCP_CALL_TOOL",server:t,tool:e,args:r}}function ws(t,e){return {type:"MCP_READ_RESOURCE",server:t,uri:e}}function Cs(t,e,r){return {type:"MCP_GET_PROMPT",server:t,prompt:e,args:r}}function As(t,e){return {type:"MCP_SYNC_RESOURCES",server:t,pattern:e}}var Ce=class{constructor(e){this.max=e;if(e<1)throw new Error(`[Directive Evals] concurrency must be >= 1, got ${e}`)}queue=[];active=0;async acquire(e){if(this.active<this.max){this.active++;return}return new Promise((r,s)=>{let n={resolve:r,reject:s};this.queue.push(n),e&&e.addEventListener("abort",()=>{let o=this.queue.indexOf(n);o!==-1&&(this.queue.splice(o,1),s(new Error("Semaphore acquire aborted")));},{once:true});})}release(){if(this.active<=0)return;this.active--;let e=this.queue.shift();e&&(this.active++,e.resolve());}};function Ms(t,e){return typeof e=="function"?{name:t,fn:e,threshold:.5,weight:1}:{...e,name:t,threshold:e.threshold??.5,weight:e.weight??1}}function xs(t,e){let r=0,s=0;for(let[n,o]of Object.entries(t)){let c=e[n]?.weight??1,i=Number.isFinite(o.score)?o.score:0;r+=i*c,s+=c;}return s===0?0:r/s}function Ts(t,e){let r=0,s=0;for(let[n,o]of Object.entries(t)){let c=e[n]?.weight??1,i=Number.isFinite(o)?o:0;r+=i*c,s+=c;}return s===0?0:r/s}var et={pii:[/\b\d{3}-\d{2}-\d{4}\b/,/\b(?:4\d{3}|5[1-5]\d{2}|6011)\d{12}\b/,/\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,}\b/],violence:[/\b(kill|murder|attack|bomb|weapon|shoot|stab)\b/i],self_harm:[/\b(suicide|self[- ]harm|cut myself)\b/i],illegal:[/\b(hack into|break into|steal|counterfeit)\b/i]};function Ps(t){return {name:"cost",fn:e=>{let r=Date.now(),s=e.result.totalTokens,n=s/t.maxTokensPerRun,o;return n<=.5?o=1:n>=2?o=0:o=1-(n-.5)/1.5,{score:o,passed:s<=t.maxTokensPerRun,reason:`${s} tokens (budget: ${t.maxTokensPerRun})`,durationMs:Date.now()-r}},threshold:.5,weight:1}}function ks(t){return {name:"latency",fn:e=>{let r=Date.now(),s=e.runDurationMs,n=s/t.maxMs,o;return n<=.5?o=1:n>=2?o=0:o=1-(n-.5)/1.5,{score:o,passed:s<=t.maxMs,reason:`${Math.round(s)}ms (max: ${t.maxMs}ms)`,durationMs:Date.now()-r}},threshold:.5,weight:1}}function Is(t){if(t.minLength!==void 0&&t.maxLength!==void 0&&t.minLength>t.maxLength)throw new Error("[Directive Evals] evalOutputLength: minLength must be <= maxLength");return {name:"outputLength",fn:e=>{let r=Date.now(),n=String(e.result.output).length,o=t.minLength??0,a=t.maxLength??Number.POSITIVE_INFINITY,c=n>=o&&n<=a,i;return c?i=1:n<o?i=o>0?Math.max(0,n/o):0:i=a>0&&a!==Number.POSITIVE_INFINITY?Math.max(0,1-(n-a)/a):0,{score:i,passed:c,reason:`${n} chars (range: ${o}-${a===Number.POSITIVE_INFINITY?"\u221E":a})`,durationMs:Date.now()-r}},threshold:.5,weight:1}}function Ds(t={}){let e;if(t.blockedPatterns)e=t.blockedPatterns;else if(t.categories&&t.categories.length>0){e=[];for(let r of t.categories){let s=et[r];s&&e.push(...s);}}else {e=[];for(let r of Object.values(et))e.push(...r);}return {name:"safety",fn:r=>{let s=Date.now(),n=String(r.result.output),o=[];for(let c of e)c.test(n)&&o.push(c.source);return {score:o.length===0?1:0,passed:o.length===0,reason:o.length===0?"No unsafe patterns detected":`Matched patterns: ${o.join(", ")}`,durationMs:Date.now()-s}},threshold:1,weight:2}}function Os(t){return {name:"structure",fn:e=>{let r=Date.now(),s=e.result.output;if(t.type==="json")try{let o=typeof s=="string"?JSON.parse(s):s;if(!o||typeof o!="object"||Array.isArray(o))return {score:0,passed:!1,reason:"Output is not a valid JSON object",durationMs:Date.now()-r};if(t.requiredKeys&&o&&typeof o=="object"){let a=t.requiredKeys.filter(c=>!Object.hasOwn(o,c));if(a.length>0)return {score:1-a.length/t.requiredKeys.length,passed:!1,reason:`Missing keys: ${a.join(", ")}`,durationMs:Date.now()-r}}return {score:1,passed:!0,reason:"Valid JSON with all required keys",durationMs:Date.now()-r}}catch{return {score:0,passed:false,reason:"Output is not valid JSON",durationMs:Date.now()-r}}let n=String(s);return {score:n.length>0?1:0,passed:n.length>0,reason:n.length>0?"Non-empty output":"Empty output",durationMs:Date.now()-r}},threshold:.5,weight:1}}function $s(t){let e=t.promptTemplate??`You are evaluating an AI agent's output. Score it from 0.0 to 1.0.
|
|
83
|
+
});`):c&&console.debug("[Directive MCP] Using stub client for development. Provide 'clientFactory' for production use."));let l=t.clientFactory??(b=>Mo(b,c)),p=t.approvalTimeoutMs??3e5,d={servers:new Map,toolConstraints:new Map(Object.entries(n)),rateLimiters:new Map,pendingApprovals:new Map,approvedRequests:new Set,rejectedRequests:new Set},f=0,y=new Map,m=new Map;function S(b){return new Promise((C,T)=>{if(d.approvedRequests.has(b)){d.approvedRequests.delete(b),d.pendingApprovals.delete(b),r.onApprovalResolved?.(b,true),C();return}if(d.rejectedRequests.has(b)){d.rejectedRequests.delete(b),d.pendingApprovals.delete(b);let R=m.get(b);m.delete(b),r.onApprovalResolved?.(b,false),T(new Error(`[Directive MCP] Tool call request ${b} was rejected${R?`: ${R}`:""}`));return}let D=setTimeout(()=>{y.delete(b),d.pendingApprovals.delete(b),T(new Error(`[Directive MCP] Approval timeout: Request ${b} was not approved or rejected within ${p}ms. Call adapter.approve("${b}") or adapter.reject("${b}") to resolve.`));},p);y.set(b,{resolve:C,reject:T,timeoutId:D});})}function h(b,C,T){let D=y.get(b);D?(clearTimeout(D.timeoutId),y.delete(b),d.pendingApprovals.delete(b),r.onApprovalResolved?.(b,C),C?D.resolve():D.reject(new Error(`[Directive MCP] Tool call request ${b} was rejected${T?`: ${T}`:""}`))):(C?d.approvedRequests.add(b):(d.rejectedRequests.add(b),T&&m.set(b,T)),setTimeout(()=>{d.approvedRequests.delete(b),d.rejectedRequests.delete(b),m.delete(b),d.pendingApprovals.delete(b);},p));}let g=new Map;for(let b of e)d.servers.set(b.name,{config:b,client:null,tools:[],resources:[],status:"disconnected"}),g.set(b.name,{timer:null,attempts:0,maxAttempts:b.retry?.maxAttempts??10,baseDelay:b.retry?.backoffMs??5e3});function v(b){let C=/[;|&$`><]/;if(b.command&&C.test(b.command))throw new Error(`[Directive MCP] Stdio command for server '${b.name}' contains shell metacharacters: '${b.command}'. This may indicate a command injection vulnerability. Use 'args' for command arguments instead.`);if(b.args){for(let T of b.args)if(C.test(T))throw new Error(`[Directive MCP] Stdio argument for server '${b.name}' contains shell metacharacters: '${T}'. This may indicate a command injection vulnerability.`)}}async function w(b){let C=d.servers.get(b);if(!C)throw new Error(`Unknown MCP server: ${b}`);if(C.status!=="connected"){C.config.transport==="stdio"&&v(C.config),C.status="connecting";try{let T=l(C.config);await T.connect(),C.client=T,C.status="connected";let D=g.get(b);D&&(D.attempts=0,D.timer&&(clearTimeout(D.timer),D.timer=null)),T.getCapabilities().tools&&(C.tools=await T.listTools()),T.getCapabilities().resources&&(C.resources=await T.listResources()),C.lastSync=Date.now(),r.onConnect?.(b);}catch(T){if(C.status="error",C.error=T instanceof Error?T:new Error(String(T)),r.onError?.(b,C.error),a){let D=g.get(b);if(D&&D.attempts<D.maxAttempts){D.attempts++;let R=Math.min(D.baseDelay*2**(D.attempts-1)+Math.random()*1e3,6e4);D.timer=setTimeout(()=>{D.timer=null,w(b).catch(()=>{});},R);}else D&&console.error(`[Directive MCP] Max reconnect attempts (${D.maxAttempts}) reached for server '${b}'. Call adapter.connectServer("${b}") to retry manually.`);}throw C.error}}}async function M(b){let C=g.get(b);C?.timer&&(clearTimeout(C.timer),C.timer=null,C.attempts=0);let T=d.servers.get(b);if(!(!T||!T.client))try{await T.client.disconnect();}finally{T.status="disconnected",T.client=null,r.onDisconnect?.(b);}}async function x(b,C,T,D){let R=d.servers.get(b);if(!R)throw new Error(`[Directive MCP] Unknown server '${b}'. Available servers: ${Array.from(d.servers.keys()).join(", ")||"(none)"}`);if(!R.client)throw new Error(`[Directive MCP] Server '${b}' is not connected. Call 'adapter.connect()' or 'adapter.connectServer("${b}")' first.`);let _=`${b}.${C}`,k=d.toolConstraints.get(_);if(k){if(k.rateLimit){let G=d.rateLimiters.get(_);if(!To(d.rateLimiters,_,k.rateLimit)){let N=G?.resetTime?new Date(G.resetTime).toISOString():"unknown";throw new Error(`[Directive MCP] Rate limit exceeded for '${_}': ${G?.count??0}/${k.rateLimit} requests per minute. Resets at ${N}.`)}}if(k.maxArgSize){let G=JSON.stringify(T).length;if(G>k.maxArgSize)throw new Error(`Arguments exceed max size (${G} > ${k.maxArgSize})`)}if(k.when&&!await k.when(D,T))throw new Error(`Constraint not satisfied for ${_}`);if(k.requireApproval){let G=`approval-${++f}-${Date.now()}`,N={id:G,server:b,tool:C,args:T,requestedAt:Date.now()};d.pendingApprovals.set(G,N),r.onApprovalRequest?.(N),await S(G);}}r.onToolCall?.(b,C,T);let L=await Promise.race([R.client.callTool(C,T),new Promise((G,N)=>setTimeout(()=>N(new Error(`Tool call timeout: ${_}`)),k?.timeout??3e4))]);return r.onToolResult?.(b,C,L),L}let P={name:"mcp-adapter",onInit:async()=>{s&&await Promise.all(Array.from(d.servers.keys()).map(b=>w(b).catch(C=>console.error(`Failed to connect to ${b}:`,C))));},onDestroy:async()=>{for(let b of g.values())b.timer&&(clearTimeout(b.timer),b.timer=null);for(let[,b]of y)clearTimeout(b.timeoutId),b.reject(new Error("[Directive MCP] Adapter destroyed while awaiting approval"));y.clear(),await Promise.all(Array.from(d.servers.keys()).map(b=>M(b).catch(C=>console.error(`Failed to disconnect from ${b}:`,C))));}};async function O(b){for(let C of o)for(let[T,D]of d.servers)if(D.client){for(let R of D.resources)if(typeof C.pattern=="string"?Io(R.uri,C.pattern):C.pattern.test(R.uri))try{let k=await D.client.readResource(R.uri),L=k.contents[0]?.text??"",G=C.transform?C.transform(L):L;b[C.factKey]=G,r.onResourceUpdate?.(T,R.uri,k);}catch(k){console.error(`Failed to sync resource ${R.uri}:`,k);}}}return {plugin:P,async connect(){await Promise.all(Array.from(d.servers.keys()).map(w));},connectServer:w,async disconnect(){await Promise.all(Array.from(d.servers.keys()).map(M));},disconnectServer:M,getTools(){let b=new Map;for(let[C,T]of d.servers)b.set(C,T.tools);return b},getResources(){let b=new Map;for(let[C,T]of d.servers)b.set(C,T.resources);return b},async callTool(b,C,T,D){return x(b,C,T,D)},async callToolDirect(b,C,T){if(!i)throw new Error("[Directive] callToolDirect is disabled by default. Pass { allowDirectCalls: true } to enable unconstrained tool calls.");process.env.NODE_ENV!=="production"&&console.warn("[Directive] callToolDirect bypasses all constraints (rate limits, approvals, timeouts).");let D=d.servers.get(b);if(!D)throw new Error(`[Directive MCP] Unknown server '${b}'. Available servers: ${Array.from(d.servers.keys()).join(", ")||"(none)"}`);if(!D.client)throw new Error(`[Directive MCP] Server '${b}' is not connected. Call 'adapter.connect()' or 'adapter.connectServer("${b}")' first.`);r.onToolCall?.(b,C,T);let R=await D.client.callTool(C,T);return r.onToolResult?.(b,C,R),R},async readResource(b,C){let T=d.servers.get(b);if(!T)throw new Error(`[Directive MCP] Unknown server '${b}'. Available servers: ${Array.from(d.servers.keys()).join(", ")||"(none)"}`);if(!T.client)throw new Error(`[Directive MCP] Server '${b}' is not connected. Call 'adapter.connect()' or 'adapter.connectServer("${b}")' first.`);let D=await T.client.readResource(C);return r.onResourceUpdate?.(b,C,D),D},syncResources:O,getServerStatus(b){return d.servers.get(b)},getAllServerStatuses(){return new Map(d.servers)},approve(b){if(!d.pendingApprovals.get(b)&&!y.has(b))throw new Error(`[Directive MCP] No pending approval request with ID '${b}'. Pending requests: ${Array.from(d.pendingApprovals.keys()).join(", ")||"(none)"}`);h(b,true);},reject(b,C){if(!d.pendingApprovals.get(b)&&!y.has(b))throw new Error(`[Directive MCP] No pending approval request with ID '${b}'. Pending requests: ${Array.from(d.pendingApprovals.keys()).join(", ")||"(none)"}`);h(b,false,C);},getPendingApprovals(){return Array.from(d.pendingApprovals.values())},getRejectionReason(b){return m.get(b)}}}var oe=new Map,ko=200;function Io(t,e){let n=oe.get(e);if(!n){let o=e.replace(/\*\*/g,"\0GLOBSTAR\0").replace(/\*/g,"\0STAR\0").replace(/\?/g,"\0QUESTION\0").replace(/[.+^${}()|[\]\\]/g,"\\$&").replace(/\0GLOBSTAR\0/g,".*").replace(/\0STAR\0/g,"[^/]*").replace(/\0QUESTION\0/g,".");if(n=new RegExp(`^${o}$`),oe.size>=ko){let r=oe.keys().next().value;r!==void 0&&oe.delete(r);}oe.set(e,n);}return n.test(t)}function Do(t){let e=[];for(let[n,o]of t)for(let r of o)e.push({type:"function",function:{name:`${n}.${r.name}`,description:r.description??`Tool: ${r.name}`,parameters:r.inputSchema}});return e}function Oo(t,e,n){return {type:"MCP_CALL_TOOL",server:t,tool:e,args:n}}function $o(t,e){return {type:"MCP_READ_RESOURCE",server:t,uri:e}}function No(t,e,n){return {type:"MCP_GET_PROMPT",server:t,prompt:e,args:n}}function _o(t,e){return {type:"MCP_SYNC_RESOURCES",server:t,pattern:e}}var xe=class{constructor(e){this.max=e;if(e<1)throw new Error(`[Directive Evals] concurrency must be >= 1, got ${e}`)}queue=[];active=0;async acquire(e){if(this.active<this.max){this.active++;return}return new Promise((n,o)=>{let r={resolve:n,reject:o};this.queue.push(r),e&&e.addEventListener("abort",()=>{let s=this.queue.indexOf(r);s!==-1&&(this.queue.splice(s,1),o(new Error("Semaphore acquire aborted")));},{once:true});})}release(){if(this.active<=0)return;this.active--;let e=this.queue.shift();e&&(this.active++,e.resolve());}};function jo(t,e){return typeof e=="function"?{name:t,fn:e,threshold:.5,weight:1}:{...e,name:t,threshold:e.threshold??.5,weight:e.weight??1}}function Fo(t,e){let n=0,o=0;for(let[r,s]of Object.entries(t)){let c=e[r]?.weight??1,i=Number.isFinite(s.score)?s.score:0;n+=i*c,o+=c;}return o===0?0:n/o}function Go(t,e){let n=0,o=0;for(let[r,s]of Object.entries(t)){let c=e[r]?.weight??1,i=Number.isFinite(s)?s:0;n+=i*c,o+=c;}return o===0?0:n/o}var ot={pii:[/\b\d{3}-\d{2}-\d{4}\b/,/\b(?:4\d{3}|5[1-5]\d{2}|6011)\d{12}\b/,/\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,}\b/],violence:[/\b(kill|murder|attack|bomb|weapon|shoot|stab)\b/i],self_harm:[/\b(suicide|self[- ]harm|cut myself)\b/i],illegal:[/\b(hack into|break into|steal|counterfeit)\b/i]};function Lo(t){return {name:"cost",fn:e=>{let n=Date.now(),o=e.result.totalTokens,r=o/t.maxTokensPerRun,s;return r<=.5?s=1:r>=2?s=0:s=1-(r-.5)/1.5,{score:s,passed:o<=t.maxTokensPerRun,reason:`${o} tokens (budget: ${t.maxTokensPerRun})`,durationMs:Date.now()-n}},threshold:.5,weight:1}}function Bo(t){return {name:"latency",fn:e=>{let n=Date.now(),o=e.runDurationMs,r=o/t.maxMs,s;return r<=.5?s=1:r>=2?s=0:s=1-(r-.5)/1.5,{score:s,passed:o<=t.maxMs,reason:`${Math.round(o)}ms (max: ${t.maxMs}ms)`,durationMs:Date.now()-n}},threshold:.5,weight:1}}function Uo(t){if(t.minLength!==void 0&&t.maxLength!==void 0&&t.minLength>t.maxLength)throw new Error("[Directive Evals] evalOutputLength: minLength must be <= maxLength");return {name:"outputLength",fn:e=>{let n=Date.now(),r=String(e.result.output).length,s=t.minLength??0,a=t.maxLength??Number.POSITIVE_INFINITY,c=r>=s&&r<=a,i;return c?i=1:r<s?i=s>0?Math.max(0,r/s):0:i=a>0&&a!==Number.POSITIVE_INFINITY?Math.max(0,1-(r-a)/a):0,{score:i,passed:c,reason:`${r} chars (range: ${s}-${a===Number.POSITIVE_INFINITY?"\u221E":a})`,durationMs:Date.now()-n}},threshold:.5,weight:1}}function zo(t={}){let e;if(t.blockedPatterns)e=t.blockedPatterns;else if(t.categories&&t.categories.length>0){e=[];for(let n of t.categories){let o=ot[n];o&&e.push(...o);}}else {e=[];for(let n of Object.values(ot))e.push(...n);}return {name:"safety",fn:n=>{let o=Date.now(),r=String(n.result.output),s=[];for(let c of e)c.test(r)&&s.push(c.source);return {score:s.length===0?1:0,passed:s.length===0,reason:s.length===0?"No unsafe patterns detected":`Matched patterns: ${s.join(", ")}`,durationMs:Date.now()-o}},threshold:1,weight:2}}function Ho(t){return {name:"structure",fn:e=>{let n=Date.now(),o=e.result.output;if(t.type==="json")try{let s=typeof o=="string"?JSON.parse(o):o;if(!s||typeof s!="object"||Array.isArray(s))return {score:0,passed:!1,reason:"Output is not a valid JSON object",durationMs:Date.now()-n};if(t.requiredKeys&&s&&typeof s=="object"){let a=t.requiredKeys.filter(c=>!Object.hasOwn(s,c));if(a.length>0)return {score:1-a.length/t.requiredKeys.length,passed:!1,reason:`Missing keys: ${a.join(", ")}`,durationMs:Date.now()-n}}return {score:1,passed:!0,reason:"Valid JSON with all required keys",durationMs:Date.now()-n}}catch{return {score:0,passed:false,reason:"Output is not valid JSON",durationMs:Date.now()-n}}let r=String(o);return {score:r.length>0?1:0,passed:r.length>0,reason:r.length>0?"Non-empty output":"Empty output",durationMs:Date.now()-n}},threshold:.5,weight:1}}function qo(t){let e=t.promptTemplate??`You are evaluating an AI agent's output. Score it from 0.0 to 1.0.
|
|
84
84
|
|
|
85
85
|
Input: {{input}}
|
|
86
86
|
Expected: {{expected}}
|
|
87
87
|
Actual Output: {{output}}
|
|
88
88
|
|
|
89
|
-
Respond with ONLY a JSON object: {"score": <number>, "reason": "<brief explanation>"}`;return {name:"judge",fn:async
|
|
89
|
+
Respond with ONLY a JSON object: {"score": <number>, "reason": "<brief explanation>"}`;return {name:"judge",fn:async n=>{let o=Date.now(),r=e.replaceAll("{{input}}",n.testCase.input).replaceAll("{{expected}}",n.testCase.expected??"N/A").replaceAll("{{output}}",String(n.result.output)),s=t.timeoutMs??3e4,a=new AbortController,c=setTimeout(()=>a.abort(),s),i=t.signal?chunk3WO4MWJM_cjs.e([t.signal,a.signal]):a.signal;try{let l=(await t.runner(t.judge,r,{signal:i})).output;if(typeof l!="string")return {score:0,passed:!1,reason:"Judge returned non-string output",durationMs:Date.now()-o};let p=JSON.parse(l),d=Math.max(0,Math.min(1,p.score));return {score:d,passed:d>=.5,reason:p.reason??`Judge score: ${d}`,durationMs:Date.now()-o}}catch(u){return {score:0,passed:false,reason:`Judge error: ${u instanceof Error?u.message:String(u)}`,durationMs:Date.now()-o}}finally{clearTimeout(c);}},threshold:.5,weight:1.5}}function Vo(t={}){let e=t.mode??"contains",n=t.caseInsensitive??true;return {name:"match",fn:o=>{let r=Date.now(),s=o.testCase.expected;if(!s)return {score:1,passed:true,reason:"No expected output to match",durationMs:Date.now()-r};let a=String(o.result.output),c=n?a.toLowerCase():a,i=n?s.toLowerCase():s,u=false;if(e==="exact")u=c===i;else if(e==="contains")u=c.includes(i);else if(e==="regex"){if(s.length>500)return {score:0,passed:false,reason:`Regex pattern too long (${s.length} chars, max 500)`,durationMs:Date.now()-r};if(/([+*}])\)([+*{])/.test(s)||/([+*}])\]([+*{])/.test(s))return {score:0,passed:false,reason:"Pattern contains dangerous nested quantifiers",durationMs:Date.now()-r};try{u=new RegExp(s,n?"i":"").test(a);}catch{return {score:0,passed:false,reason:`Invalid regex pattern: ${s}`,durationMs:Date.now()-r}}}return {score:u?1:0,passed:u,reason:u?`Output ${e} match`:`Output does not ${e} match expected`,durationMs:Date.now()-r}},threshold:1,weight:1}}var Jo=`You are evaluating an AI agent's output for faithfulness to the provided context.
|
|
90
90
|
|
|
91
91
|
Faithfulness measures whether all claims in the output are supported by the context.
|
|
92
92
|
Score 1.0 if every claim is grounded in the context.
|
|
@@ -95,7 +95,7 @@ Score 0.0 if the output contains fabricated information not in the context.
|
|
|
95
95
|
Context: {{context}}
|
|
96
96
|
Agent Output: {{output}}
|
|
97
97
|
|
|
98
|
-
Respond with ONLY a JSON object: {"score": <number 0.0-1.0>, "reason": "<brief explanation>"}`;function
|
|
98
|
+
Respond with ONLY a JSON object: {"score": <number 0.0-1.0>, "reason": "<brief explanation>"}`;function Ko(t){return {name:"faithfulness",fn:async e=>{let n=Date.now(),o=e.testCase.context??e.testCase.expected;if(!o)return {score:1,passed:true,reason:"No context provided for faithfulness check",durationMs:Date.now()-n};let r=Jo.replaceAll("{{context}}",o).replaceAll("{{output}}",String(e.result.output)),s=t.timeoutMs??3e4,a=new AbortController,c=setTimeout(()=>a.abort(),s),i=t.signal?chunk3WO4MWJM_cjs.e([t.signal,a.signal]):a.signal;try{let l=(await t.runner(t.judge,r,{signal:i})).output;if(typeof l!="string")return {score:0,passed:!1,reason:"Judge returned non-string output",durationMs:Date.now()-n};let p=JSON.parse(l),d=Math.max(0,Math.min(1,p.score));return {score:d,passed:d>=.7,reason:p.reason??`Faithfulness score: ${d}`,durationMs:Date.now()-n}}catch(u){return {score:0,passed:false,reason:`Faithfulness eval error: ${u instanceof Error?u.message:String(u)}`,durationMs:Date.now()-n}}finally{clearTimeout(c);}},threshold:.7,weight:1.5}}var Wo=`You are evaluating an AI agent's output for relevance to the user's question.
|
|
99
99
|
|
|
100
100
|
Relevance measures whether the output directly addresses the question asked.
|
|
101
101
|
Score 1.0 if the output fully and directly answers the question.
|
|
@@ -104,7 +104,7 @@ Score 0.0 if the output is completely off-topic or irrelevant.
|
|
|
104
104
|
User Question: {{input}}
|
|
105
105
|
Agent Output: {{output}}
|
|
106
106
|
|
|
107
|
-
Respond with ONLY a JSON object: {"score": <number 0.0-1.0>, "reason": "<brief explanation>"}`;function
|
|
107
|
+
Respond with ONLY a JSON object: {"score": <number 0.0-1.0>, "reason": "<brief explanation>"}`;function Yo(t){return {name:"relevance",fn:async e=>{let n=Date.now(),o=Wo.replaceAll("{{input}}",e.testCase.input).replaceAll("{{output}}",String(e.result.output)),r=t.timeoutMs??3e4,s=new AbortController,a=setTimeout(()=>s.abort(),r),c=t.signal?chunk3WO4MWJM_cjs.e([t.signal,s.signal]):s.signal;try{let u=(await t.runner(t.judge,o,{signal:c})).output;if(typeof u!="string")return {score:0,passed:!1,reason:"Judge returned non-string output",durationMs:Date.now()-n};let l=JSON.parse(u),p=Math.max(0,Math.min(1,l.score));return {score:p,passed:p>=.7,reason:l.reason??`Relevance score: ${p}`,durationMs:Date.now()-n}}catch(i){return {score:0,passed:false,reason:`Relevance eval error: ${i instanceof Error?i.message:String(i)}`,durationMs:Date.now()-n}}finally{clearTimeout(a);}},threshold:.7,weight:1.5}}var Qo=`You are evaluating an AI agent's output for coherence and logical consistency.
|
|
108
108
|
|
|
109
109
|
Coherence measures whether the output is well-structured, logically consistent,
|
|
110
110
|
and flows naturally. Check for contradictions, non-sequiturs, and clarity.
|
|
@@ -113,7 +113,7 @@ Score 0.0 if the output is incoherent, contradictory, or disorganized.
|
|
|
113
113
|
|
|
114
114
|
Agent Output: {{output}}
|
|
115
115
|
|
|
116
|
-
Respond with ONLY a JSON object: {"score": <number 0.0-1.0>, "reason": "<brief explanation>"}`;function
|
|
117
|
-
${
|
|
118
|
-
`)}`)}var B={UNSET:0,OK:1,ERROR:2},le=class{constructor(e,r,s,n,o,a){this.name=e;this.spanId=r;this.traceId=s;this.parentSpanId=n;this.onEnd=a;if(this.startTime=Date.now(),o)for(let[c,i]of Object.entries(o))this.attributes[c]=i;}attributes=Object.create(null);spanEvents=[];status={code:B.UNSET};startTime;endTime=0;setAttribute(e,r){this.attributes[e]=r;}addEvent(e,r){this.spanEvents.push({name:e,attributes:r,timestamp:Date.now()});}setStatus(e){this.status=e;}end(){this.endTime=Date.now(),this.onEnd?.(this);}toSpanData(){return {name:this.name,traceId:this.traceId,spanId:this.spanId,parentSpanId:this.parentSpanId,attributes:{...this.attributes},events:[...this.spanEvents],status:{...this.status},startTime:this.startTime,endTime:this.endTime,durationMs:this.endTime-this.startTime}}},Ae=class{spans=[];startSpan(e,r){let s=r?.spanId??`fallback-${crypto.randomUUID()}`,n=r?.traceId??`fallback-${crypto.randomUUID()}`,o=r?.parentSpanId;return new le(e,s,n,o,r?.attributes,a=>{this.spans.push(a.toSpanData());})}clear(){this.spans.length=0;}};function qs(t){let e=t.spanPrefix??"directive.ai",r=t.instrumentEvents,s=t.spanTtlMs??3e5,n=!t.tracer,o=n?new Ae:null,a=t.tracer??o,c=0;function i(){return `${Date.now().toString(36)}-${(c++).toString(36)}`}function u(){return `${Date.now().toString(36)}-${crypto.randomUUID().slice(0,8)}`}let l=new Map,p=0,d=new Map,y=[],f=null,m=false;function S(E){return r?r.has(E):true}function h(E,A){return `${E}:${A}:${p++}`}function g(E,A){let I=`${E}:${A}`,$=d.get(I);if($){for(let G=$.length-1;G>=0;G--){let H=l.get($[G]);if(H)return {key:$[G],entry:H}}d.delete(I);}return null}function b(E,A,I,$){let G=`${E}:${A}`;$.indexKey=G,l.set(I,$);let H=d.get(G);H?H.push(I):d.set(G,[I]);}function R(E){let A=l.get(E);l.delete(E);let I=A?.indexKey;if(I){let $=d.get(I);if($){let G=$.indexOf(E);G!==-1&&$.splice(G,1),$.length===0&&d.delete(I);}}}function x(){let E=Date.now();if(l.size<1e4){for(let[I,$]of l)E-$.startTime>s&&(v($,"directive.stale",true),T($,{code:B.ERROR,message:"Span TTL exceeded \u2014 cleaned up"}),P($),R(I),true);return void 0}for(let[A,I]of l)E-I.startTime>s&&(v(I,"directive.stale",true),T(I,{code:B.ERROR,message:"Span TTL exceeded \u2014 cleaned up"}),P(I),R(A));}function M(E,A,I){let $=i(),G=I?.traceId??u(),H=I?.spanId,K;n?K=a.startSpan(E,{attributes:A,spanId:$,traceId:G,parentSpanId:H}):K=a.startSpan(E,{attributes:A});let pe={span:K,spanId:$,traceId:G,startTime:Date.now()};return n||(pe.shadow={span:K,name:E,spanId:$,traceId:G,parentSpanId:H,attributes:{...A},events:[],status:{code:B.UNSET},startTime:pe.startTime}),{span:K,entry:pe}}function P(E){E.span.end(),t.onSpanEnd&&t.onSpanEnd(O(E));}function O(E){if(E.span instanceof le)return E.span.toSpanData();if(E.shadow){let I=Date.now();return {name:E.shadow.name,traceId:E.shadow.traceId,spanId:E.shadow.spanId,parentSpanId:E.shadow.parentSpanId,attributes:{...E.shadow.attributes},events:[...E.shadow.events],status:{...E.shadow.status},startTime:E.shadow.startTime,endTime:I,durationMs:I-E.shadow.startTime}}let A=Date.now();return {name:"unknown",traceId:E.traceId,spanId:E.spanId,attributes:{},events:[],status:{code:B.UNSET},startTime:E.startTime,endTime:A,durationMs:A-E.startTime}}function v(E,A,I){E.span.setAttribute(A,I),E.shadow&&(E.shadow.attributes[A]=I);}function C(E,A,I){E.span.addEvent(A,I),E.shadow&&E.shadow.events.push({name:A,attributes:I,timestamp:Date.now()});}function T(E,A){E.span.setStatus(A),E.shadow&&(E.shadow.status={...A});}function D(E){if(S(E.type))switch(x(),E.type){case "agent_start":w(E);break;case "agent_complete":_(E);break;case "agent_error":k(E);break;case "guardrail_check":L(E);break;case "constraint_evaluate":F(E);break;case "resolver_start":N(E);break;case "resolver_complete":U(E);break;case "resolver_error":V(E);break;case "pattern_start":de(E);break;case "pattern_complete":tt(E);break;default:if(E.agentId){let A=g("agent",E.agentId);A&&C(A.entry,E.type,{"event.id":E.id,"event.timestamp":E.timestamp});}}}function w(E){let A=y.length>0?y[y.length-1]:null,{entry:I}=M(`${e}.agent.run`,{"directive.service":t.serviceName,"directive.agent.name":E.agentId,"directive.agent.input_length":E.inputLength,"gen_ai.operation.name":"agent.run","gen_ai.agent.name":E.agentId},A),$=h("agent",E.agentId);b("agent",E.agentId,$,I);}function _(E){let A=g("agent",E.agentId);A&&(v(A.entry,"directive.agent.output_length",E.outputLength),v(A.entry,"directive.agent.total_tokens",E.totalTokens),v(A.entry,"directive.agent.duration_ms",E.durationMs),v(A.entry,"gen_ai.usage.total_tokens",E.totalTokens),T(A.entry,{code:B.OK}),P(A.entry),R(A.key));}function k(E){let A=g("agent",E.agentId);A&&(v(A.entry,"directive.agent.duration_ms",E.durationMs),v(A.entry,"directive.agent.error",E.errorMessage),v(A.entry,"gen_ai.error.message",E.errorMessage),T(A.entry,{code:B.ERROR,message:E.errorMessage}),P(A.entry),R(A.key));}function L(E){let A=E.agentId?g("agent",E.agentId)?.entry??null:null,{entry:I}=M(`${e}.guardrail.check`,{"directive.service":t.serviceName,"directive.guardrail.name":E.guardrailName,"directive.guardrail.type":E.guardrailType,"directive.guardrail.passed":E.passed,"directive.guardrail.duration_ms":E.durationMs,"gen_ai.guardrail.name":E.guardrailName,"gen_ai.guardrail.type":E.guardrailType,"gen_ai.guardrail.passed":E.passed},A);E.reason&&v(I,"directive.guardrail.reason",E.reason),T(I,{code:E.passed?B.OK:B.ERROR,message:E.passed?void 0:E.reason}),P(I);}function F(E){if(E.agentId){let I=g("agent",E.agentId);if(I){C(I.entry,"constraint_evaluate",{"directive.constraint.id":E.constraintId,"directive.constraint.fired":E.fired});return}}let{entry:A}=M(`${e}.constraint.evaluate`,{"directive.service":t.serviceName,"directive.constraint.id":E.constraintId,"directive.constraint.fired":E.fired},null);T(A,{code:B.OK}),P(A);}function N(E){let I=(E.agentId?g("agent",E.agentId)?.entry??null:null)??(y.length>0?y[y.length-1]:null),{entry:$}=M(`${e}.resolver.execute`,{"directive.service":t.serviceName,"directive.resolver.id":E.resolverId,"directive.resolver.requirement_type":E.requirementType},I),G=h("resolver",E.resolverId);b("resolver",E.resolverId,G,$);}function U(E){let A=g("resolver",E.resolverId);A&&(v(A.entry,"directive.resolver.duration_ms",E.durationMs),T(A.entry,{code:B.OK}),P(A.entry),R(A.key));}function V(E){let A=g("resolver",E.resolverId);A&&(v(A.entry,"directive.resolver.duration_ms",E.durationMs),v(A.entry,"directive.resolver.error",E.errorMessage),T(A.entry,{code:B.ERROR,message:E.errorMessage}),P(A.entry),R(A.key));}function de(E){let A=y.length>0?y[y.length-1]:null,{entry:I}=M(`${e}.pattern.${E.patternType}`,{"directive.service":t.serviceName,"directive.pattern.id":E.patternId,"directive.pattern.type":E.patternType},A),$=h("pattern",E.patternId);b("pattern",E.patternId,$,I),y.length<100&&y.push(I);}function tt(E){let A=g("pattern",E.patternId);if(A){v(A.entry,"directive.pattern.duration_ms",E.durationMs),E.error?(v(A.entry,"directive.pattern.error",E.error),T(A.entry,{code:B.ERROR,message:E.error})):T(A.entry,{code:B.OK}),P(A.entry),R(A.key);let I=y.indexOf(A.entry);I!==-1&&y.splice(I,1);}}return {attach(E){if(f&&f!==E)throw new Error("[Directive OTEL] Plugin already attached to a different timeline. Create a new plugin instance.");f=E;let A=E.subscribe(D),I=setInterval(x,Math.min(s,6e4));return ()=>{A(),clearInterval(I),f=null;for(let[$,G]of l)v(G,"directive.detached",true),T(G,{code:B.ERROR,message:"Plugin detached while span was active"}),P(G);l.clear(),d.clear(),y.length=0;}},getSpans(){return o?[...o.spans]:(m||(m=true,typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.warn("[Directive OTEL] getSpans() returns [] when using an external tracer. Use the onSpanEnd callback to collect span data instead.")),[])},clearSpans(){o?.clear();},getTracer(){return a},getActiveSpanCount(){return l.size}}}Object.defineProperty(exports,"createAgentOrchestrator",{enumerable:true,get:function(){return chunkXV2QSBBE_cjs.a}});Object.defineProperty(exports,"createRunner",{enumerable:true,get:function(){return chunkW6MVJKWN_cjs.e}});Object.defineProperty(exports,"estimateCost",{enumerable:true,get:function(){return chunkW6MVJKWN_cjs.c}});Object.defineProperty(exports,"hasPendingApprovals",{enumerable:true,get:function(){return chunkW6MVJKWN_cjs.b}});Object.defineProperty(exports,"isAgentRunning",{enumerable:true,get:function(){return chunkW6MVJKWN_cjs.a}});Object.defineProperty(exports,"validateBaseURL",{enumerable:true,get:function(){return chunkW6MVJKWN_cjs.d}});Object.defineProperty(exports,"GuardrailError",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.a}});Object.defineProperty(exports,"InMemoryCheckpointStore",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.G}});Object.defineProperty(exports,"MAX_BREAKPOINT_HISTORY",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.A}});Object.defineProperty(exports,"ReflectionExhaustedError",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.W}});Object.defineProperty(exports,"Semaphore",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.Z}});Object.defineProperty(exports,"StructuredOutputError",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.J}});Object.defineProperty(exports,"adaptOutputGuardrail",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.P}});Object.defineProperty(exports,"aggregateTokens",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ua}});Object.defineProperty(exports,"allReadyStrategy",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ka}});Object.defineProperty(exports,"capabilityRoute",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.xa}});Object.defineProperty(exports,"collectOutputs",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ta}});Object.defineProperty(exports,"collectTokens",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.Q}});Object.defineProperty(exports,"combineStreamingGuardrails",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.O}});Object.defineProperty(exports,"composePatterns",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.va}});Object.defineProperty(exports,"concatResults",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ra}});Object.defineProperty(exports,"costEfficientStrategy",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ma}});Object.defineProperty(exports,"createBreakpointId",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.B}});Object.defineProperty(exports,"createCheckpointId",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.E}});Object.defineProperty(exports,"createDebugTimeline",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.i}});Object.defineProperty(exports,"createDebugTimelinePlugin",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.j}});Object.defineProperty(exports,"createHealthMonitor",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.V}});Object.defineProperty(exports,"createInitialBreakpointState",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.D}});Object.defineProperty(exports,"createLengthStreamingGuardrail",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.M}});Object.defineProperty(exports,"createMultiAgentOrchestrator",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.Da}});Object.defineProperty(exports,"createPatternStreamingGuardrail",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.N}});Object.defineProperty(exports,"createStreamingRunner",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.K}});Object.defineProperty(exports,"createToxicityStreamingGuardrail",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.L}});Object.defineProperty(exports,"dag",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ga}});Object.defineProperty(exports,"debate",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.za}});Object.defineProperty(exports,"derivedConstraint",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.Ba}});Object.defineProperty(exports,"diffCheckpoints",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.aa}});Object.defineProperty(exports,"extractJsonFromOutput",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.H}});Object.defineProperty(exports,"filterStream",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.S}});Object.defineProperty(exports,"findAgentsByCapability",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.wa}});Object.defineProperty(exports,"forkFromCheckpoint",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ba}});Object.defineProperty(exports,"formatSystemMeta",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.g}});Object.defineProperty(exports,"getCheckpointProgress",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.$}});Object.defineProperty(exports,"getPatternStep",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs._}});Object.defineProperty(exports,"goal",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ja}});Object.defineProperty(exports,"highestImpactStrategy",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.la}});Object.defineProperty(exports,"isGuardrailError",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.b}});Object.defineProperty(exports,"mapStream",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.T}});Object.defineProperty(exports,"matchBreakpoint",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.C}});Object.defineProperty(exports,"mergeTaggedStreams",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.U}});Object.defineProperty(exports,"parallel",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.da}});Object.defineProperty(exports,"patternFromJSON",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.oa}});Object.defineProperty(exports,"patternToJSON",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.na}});Object.defineProperty(exports,"pickBestResult",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.sa}});Object.defineProperty(exports,"race",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ia}});Object.defineProperty(exports,"reflect",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ha}});Object.defineProperty(exports,"runAgentRequirement",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.qa}});Object.defineProperty(exports,"runDebate",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.Aa}});Object.defineProperty(exports,"selectAgent",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.pa}});Object.defineProperty(exports,"sequential",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ea}});Object.defineProperty(exports,"spawnOnCondition",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ya}});Object.defineProperty(exports,"spawnPool",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.Ca}});Object.defineProperty(exports,"supervisor",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.fa}});Object.defineProperty(exports,"tapStream",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.R}});Object.defineProperty(exports,"toAIContext",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.h}});Object.defineProperty(exports,"validateCheckpoint",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.F}});Object.defineProperty(exports,"withReflection",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.X}});Object.defineProperty(exports,"withStructuredOutput",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.I}});Object.defineProperty(exports,"CircuitBreakerOpenError",{enumerable:true,get:function(){return plugins.CircuitBreakerOpenError}});Object.defineProperty(exports,"createCircuitBreaker",{enumerable:true,get:function(){return plugins.createCircuitBreaker}});Object.defineProperty(exports,"createOTLPExporter",{enumerable:true,get:function(){return plugins.createOTLPExporter}});exports.AllProvidersFailedError=ie;exports.BudgetExceededError=ee;exports.DEFAULT_INJECTION_PATTERNS=X;exports.OtelStatusCode=B;exports.PredicateFromIntentError=ue;exports.RetryExhaustedError=ae;exports.STRICT_INJECTION_PATTERNS=he;exports.byAgentName=Kr;exports.byInputLength=Jr;exports.byPattern=Wr;exports.connectDevTools=ds;exports.convertToolsForLLM=Es;exports.createAgentAuditHandlers=gr;exports.createAgentMemory=An;exports.createAgentNetwork=qn;exports.createAuditTrail=pr;exports.createBatchQueue=cs;exports.createBatchedEmbedder=Mr;exports.createBidirectionalStream=Pr;exports.createBruteForceIndex=xr;exports.createCompliance=Er;exports.createConstraintRouter=ls;exports.createContentFilterGuardrail=Rn;exports.createDelegator=Vn;exports.createDevToolsServer=Xe;exports.createEnhancedPIIGuardrail=$e;exports.createEvalSuite=Us;exports.createHybridStrategy=Cn;exports.createInMemoryComplianceStorage=Sr;exports.createInMemoryStorage=Ue;exports.createJSONFileStore=jr;exports.createKeyPointsSummarizer=xn;exports.createLLMSummarizer=Tn;exports.createLengthGuardrail=En;exports.createMCPAdapter=vs;exports.createMessageBus=zn;exports.createModerationGuardrail=yn;exports.createOtelPlugin=qs;exports.createOutputPIIGuardrail=nr;exports.createOutputSchemaGuardrail=bn;exports.createOutputTypeGuardrail=Sn;exports.createPIIGuardrail=fn;exports.createPromptInjectionGuardrail=Le;exports.createPubSub=Jn;exports.createRAGEnricher=Nr;exports.createRateLimitGuardrail=hn;exports.createResponder=Hn;exports.createSSETransport=Gr;exports.createSemanticCache=wr;exports.createSemanticCacheGuardrail=Cr;exports.createSlidingWindowStrategy=Te;exports.createStreamChannel=Se;exports.createTestEmbedder=Ar;exports.createTokenBasedStrategy=Pe;exports.createToolGuardrail=vn;exports.createTruncationSummarizer=Mn;exports.createUntrustedContentGuardrail=fr;exports.createVPTreeIndex=Tr;exports.createWsTransport=Ze;exports.detectAndRedactPII=rr;exports.detectPII=se;exports.detectPromptInjection=ve;exports.evalAssert=zs;exports.evalCoherence=Bs;exports.evalCost=Ps;exports.evalFaithfulness=js;exports.evalJudge=$s;exports.evalLatency=ks;exports.evalMatch=Ns;exports.evalOutputLength=Is;exports.evalRelevance=Fs;exports.evalSafety=Ds;exports.evalStructure=Os;exports.explainGoal=fs;exports.getDependencyGraph=ps;exports.markUntrustedContent=mr;exports.mcpCallTool=Rs;exports.mcpGetPrompt=Cs;exports.mcpReadResource=ws;exports.mcpSyncResources=As;exports.mergeStreams=Ir;exports.parseHttpStatus=Ee;exports.parseRetryAfter=He;exports.patternToMermaid=Un;exports.pipe=wn;exports.pipeThrough=kr;exports.planGoal=ms;exports.predicateFromIntent=as;exports.predicateFromIntentRaw=Ye;exports.predicateToolSpec=is;exports.redactPII=Q;exports.sanitizeInjection=Fe;exports.validateGoal=gs;exports.withBudget=Vr;exports.withFallback=qr;exports.withModelSelection=Yr;exports.withRetry=zr;//# sourceMappingURL=index.cjs.map
|
|
116
|
+
Respond with ONLY a JSON object: {"score": <number 0.0-1.0>, "reason": "<brief explanation>"}`;function Xo(t){return {name:"coherence",fn:async e=>{let n=Date.now(),o=Qo.replaceAll("{{output}}",String(e.result.output)),r=t.timeoutMs??3e4,s=new AbortController,a=setTimeout(()=>s.abort(),r),c=t.signal?chunk3WO4MWJM_cjs.e([t.signal,s.signal]):s.signal;try{let u=(await t.runner(t.judge,o,{signal:c})).output;if(typeof u!="string")return {score:0,passed:!1,reason:"Judge returned non-string output",durationMs:Date.now()-n};let l=JSON.parse(u),p=Math.max(0,Math.min(1,l.score));return {score:p,passed:p>=.7,reason:l.reason??`Coherence score: ${p}`,durationMs:Date.now()-n}}catch(i){return {score:0,passed:false,reason:`Coherence eval error: ${i instanceof Error?i.message:String(i)}`,durationMs:Date.now()-n}}finally{clearTimeout(a);}},threshold:.7,weight:1}}function Zo(t){let{agents:e,runner:n,dataset:o,runOptions:r,concurrency:s=5,timeline:a,onCaseComplete:c,onAgentComplete:i,signal:u}=t;if(o.length===0)throw new Error("[Directive Evals] Dataset must contain at least one test case");let l=new xe(s),p={};for(let[y,m]of Object.entries(t.criteria))p[y]=jo(y,m);async function d(y,m){try{await l.acquire(u);}catch{let S={};for(let h of Object.keys(p))S[h]={score:0,passed:false,reason:"Evaluation aborted",durationMs:0};return {testCase:m,agentName:y.name,runResult:{output:"",messages:[],toolCalls:[],totalTokens:0},scores:S,overallScore:0,allPassed:false,runDurationMs:0}}try{let S=Date.now(),h;try{h=await n(y,m.input,{...r,signal:u});}catch(O){let b={output:"",messages:[],toolCalls:[],totalTokens:0},C={};for(let T of Object.keys(p))C[T]={score:0,passed:!1,reason:`Agent error: ${O instanceof Error?`${O.name}: ${O.message}`:String(O)}`,durationMs:0};return {testCase:m,agentName:y.name,runResult:b,scores:C,overallScore:0,allPassed:!1,runDurationMs:Date.now()-S}}let g=Date.now()-S,v={agent:y,testCase:m,result:h,runDurationMs:g},w={};for(let[O,b]of Object.entries(p))try{let C=await b.fn(v);w[O]={...C,passed:C.score>=(b.threshold??.5)};}catch(C){w[O]={score:0,passed:!1,reason:`Criterion error: ${C instanceof Error?`${C.name}: ${C.message}`:String(C)}`,durationMs:0};}let M=Fo(w,p),x=Object.values(w).every(O=>O.passed),P={testCase:m,agentName:y.name,runResult:h,scores:w,overallScore:M,allPassed:x,runDurationMs:g};return a&&a.record({type:"agent_complete",timestamp:Date.now(),agentId:`eval:${y.name}`,outputLength:String(h.output).length,totalTokens:h.totalTokens,durationMs:g,snapshotId:null}),c?.(P),P}finally{l.release();}}function f(y,m){let S={},h={},g=0,v=0,w=0;for(let b of Object.keys(p))S[b]=0,h[b]=0;for(let b of m){g+=b.runResult.totalTokens,v+=b.runDurationMs,b.allPassed&&w++;for(let[C,T]of Object.entries(b.scores))S[C]=(S[C]??0)+T.score,T.passed&&(h[C]=(h[C]??0)+1);}let M=m.length,x={},P={};for(let b of Object.keys(p))x[b]=M>0?(S[b]??0)/M:0,P[b]=M>0?(h[b]??0)/M:0;let O=M>0?Go(x,p):0;return {agentName:y,criterionAverages:x,criterionPassRates:P,overallScore:O,passRate:M>0?w/M:0,totalTokens:g,avgLatencyMs:M>0?v/M:0,totalCases:M,passedCases:w}}return {getAgents:()=>[...e],getCriteria:()=>Object.keys(p),getDataset:()=>[...o],async run(){let y=Date.now(),m=[],S={},h=e.map(async w=>{if(u?.aborted)return;let M=await Promise.all(o.map(x=>d(w,x)));return {agent:w,agentResults:M}}),g=await Promise.all(h);for(let w of g){if(!w)continue;m.push(...w.agentResults);let M=f(w.agent.name,w.agentResults);S[w.agent.name]=M,i?.(M);}let v=Date.now();return {summary:S,details:m,durationMs:v-y,totalTokens:m.reduce((w,M)=>w+M.runResult.totalTokens,0),startedAt:y,completedAt:v}},async runAgent(y){let m=e.find(g=>g.name===y);if(!m)throw new Error(`[Directive Evals] Unknown agent: "${y}"`);let S=await Promise.all(o.map(g=>d(m,g))),h=f(m.name,S);return i?.(h),h}}}function es(t,e){let n=[];for(let[o,r]of Object.entries(t.summary))if(e.minScore!==void 0&&r.overallScore<e.minScore&&n.push(`Agent "${o}" score ${r.overallScore.toFixed(3)} < minimum ${e.minScore}`),e.minPassRate!==void 0&&r.passRate<e.minPassRate&&n.push(`Agent "${o}" pass rate ${r.passRate.toFixed(3)} < minimum ${e.minPassRate}`),e.failOn)for(let s of e.failOn){let a=r.criterionPassRates[s];a!==void 0&&a<1&&n.push(`Agent "${o}" criterion "${s}" pass rate ${a.toFixed(3)} < 1.0 (failOn)`);}if(n.length>0)throw new Error(`[Directive Evals] Assertion failed:
|
|
117
|
+
${n.join(`
|
|
118
|
+
`)}`)}var B={UNSET:0,OK:1,ERROR:2},pe=class{constructor(e,n,o,r,s,a){this.name=e;this.spanId=n;this.traceId=o;this.parentSpanId=r;this.onEnd=a;if(this.startTime=Date.now(),s)for(let[c,i]of Object.entries(s))this.attributes[c]=i;}attributes=Object.create(null);spanEvents=[];status={code:B.UNSET};startTime;endTime=0;setAttribute(e,n){this.attributes[e]=n;}addEvent(e,n){this.spanEvents.push({name:e,attributes:n,timestamp:Date.now()});}setStatus(e){this.status=e;}end(){this.endTime=Date.now(),this.onEnd?.(this);}toSpanData(){return {name:this.name,traceId:this.traceId,spanId:this.spanId,parentSpanId:this.parentSpanId,attributes:{...this.attributes},events:[...this.spanEvents],status:{...this.status},startTime:this.startTime,endTime:this.endTime,durationMs:this.endTime-this.startTime}}},Me=class{spans=[];startSpan(e,n){let o=n?.spanId??`fallback-${crypto.randomUUID()}`,r=n?.traceId??`fallback-${crypto.randomUUID()}`,s=n?.parentSpanId;return new pe(e,o,r,s,n?.attributes,a=>{this.spans.push(a.toSpanData());})}clear(){this.spans.length=0;}};function ts(t){let e=t.spanPrefix??"directive.ai",n=t.instrumentEvents,o=t.spanTtlMs??3e5,r=!t.tracer,s=r?new Me:null,a=t.tracer??s,c=0;function i(){return `${Date.now().toString(36)}-${(c++).toString(36)}`}function u(){return `${Date.now().toString(36)}-${crypto.randomUUID().slice(0,8)}`}let l=new Map,p=0,d=new Map,f=[],y=null,m=false;function S(E){return n?n.has(E):true}function h(E,A){return `${E}:${A}:${p++}`}function g(E,A){let I=`${E}:${A}`,$=d.get(I);if($){for(let F=$.length-1;F>=0;F--){let q=l.get($[F]);if(q)return {key:$[F],entry:q}}d.delete(I);}return null}function v(E,A,I,$){let F=`${E}:${A}`;$.indexKey=F,l.set(I,$);let q=d.get(F);q?q.push(I):d.set(F,[I]);}function w(E){let A=l.get(E);l.delete(E);let I=A?.indexKey;if(I){let $=d.get(I);if($){let F=$.indexOf(E);F!==-1&&$.splice(F,1),$.length===0&&d.delete(I);}}}function M(){let E=Date.now();if(l.size<1e4){for(let[I,$]of l)E-$.startTime>o&&(b($,"directive.stale",true),T($,{code:B.ERROR,message:"Span TTL exceeded \u2014 cleaned up"}),P($),w(I),true);return void 0}for(let[A,I]of l)E-I.startTime>o&&(b(I,"directive.stale",true),T(I,{code:B.ERROR,message:"Span TTL exceeded \u2014 cleaned up"}),P(I),w(A));}function x(E,A,I){let $=i(),F=I?.traceId??u(),q=I?.spanId,K;r?K=a.startSpan(E,{attributes:A,spanId:$,traceId:F,parentSpanId:q}):K=a.startSpan(E,{attributes:A});let me={span:K,spanId:$,traceId:F,startTime:Date.now()};return r||(me.shadow={span:K,name:E,spanId:$,traceId:F,parentSpanId:q,attributes:{...A},events:[],status:{code:B.UNSET},startTime:me.startTime}),{span:K,entry:me}}function P(E){E.span.end(),t.onSpanEnd&&t.onSpanEnd(O(E));}function O(E){if(E.span instanceof pe)return E.span.toSpanData();if(E.shadow){let I=Date.now();return {name:E.shadow.name,traceId:E.shadow.traceId,spanId:E.shadow.spanId,parentSpanId:E.shadow.parentSpanId,attributes:{...E.shadow.attributes},events:[...E.shadow.events],status:{...E.shadow.status},startTime:E.shadow.startTime,endTime:I,durationMs:I-E.shadow.startTime}}let A=Date.now();return {name:"unknown",traceId:E.traceId,spanId:E.spanId,attributes:{},events:[],status:{code:B.UNSET},startTime:E.startTime,endTime:A,durationMs:A-E.startTime}}function b(E,A,I){E.span.setAttribute(A,I),E.shadow&&(E.shadow.attributes[A]=I);}function C(E,A,I){E.span.addEvent(A,I),E.shadow&&E.shadow.events.push({name:A,attributes:I,timestamp:Date.now()});}function T(E,A){E.span.setStatus(A),E.shadow&&(E.shadow.status={...A});}function D(E){if(S(E.type))switch(M(),E.type){case "agent_start":R(E);break;case "agent_complete":_(E);break;case "agent_error":k(E);break;case "guardrail_check":L(E);break;case "constraint_evaluate":G(E);break;case "resolver_start":N(E);break;case "resolver_complete":U(E);break;case "resolver_error":V(E);break;case "pattern_start":ge(E);break;case "pattern_complete":st(E);break;default:if(E.agentId){let A=g("agent",E.agentId);A&&C(A.entry,E.type,{"event.id":E.id,"event.timestamp":E.timestamp});}}}function R(E){let A=f.length>0?f[f.length-1]:null,{entry:I}=x(`${e}.agent.run`,{"directive.service":t.serviceName,"directive.agent.name":E.agentId,"directive.agent.input_length":E.inputLength,"gen_ai.operation.name":"agent.run","gen_ai.agent.name":E.agentId},A),$=h("agent",E.agentId);v("agent",E.agentId,$,I);}function _(E){let A=g("agent",E.agentId);A&&(b(A.entry,"directive.agent.output_length",E.outputLength),b(A.entry,"directive.agent.total_tokens",E.totalTokens),b(A.entry,"directive.agent.duration_ms",E.durationMs),b(A.entry,"gen_ai.usage.total_tokens",E.totalTokens),T(A.entry,{code:B.OK}),P(A.entry),w(A.key));}function k(E){let A=g("agent",E.agentId);A&&(b(A.entry,"directive.agent.duration_ms",E.durationMs),b(A.entry,"directive.agent.error",E.errorMessage),b(A.entry,"gen_ai.error.message",E.errorMessage),T(A.entry,{code:B.ERROR,message:E.errorMessage}),P(A.entry),w(A.key));}function L(E){let A=E.agentId?g("agent",E.agentId)?.entry??null:null,{entry:I}=x(`${e}.guardrail.check`,{"directive.service":t.serviceName,"directive.guardrail.name":E.guardrailName,"directive.guardrail.type":E.guardrailType,"directive.guardrail.passed":E.passed,"directive.guardrail.duration_ms":E.durationMs,"gen_ai.guardrail.name":E.guardrailName,"gen_ai.guardrail.type":E.guardrailType,"gen_ai.guardrail.passed":E.passed},A);E.reason&&b(I,"directive.guardrail.reason",E.reason),T(I,{code:E.passed?B.OK:B.ERROR,message:E.passed?void 0:E.reason}),P(I);}function G(E){if(E.agentId){let I=g("agent",E.agentId);if(I){C(I.entry,"constraint_evaluate",{"directive.constraint.id":E.constraintId,"directive.constraint.fired":E.fired});return}}let{entry:A}=x(`${e}.constraint.evaluate`,{"directive.service":t.serviceName,"directive.constraint.id":E.constraintId,"directive.constraint.fired":E.fired},null);T(A,{code:B.OK}),P(A);}function N(E){let I=(E.agentId?g("agent",E.agentId)?.entry??null:null)??(f.length>0?f[f.length-1]:null),{entry:$}=x(`${e}.resolver.execute`,{"directive.service":t.serviceName,"directive.resolver.id":E.resolverId,"directive.resolver.requirement_type":E.requirementType},I),F=h("resolver",E.resolverId);v("resolver",E.resolverId,F,$);}function U(E){let A=g("resolver",E.resolverId);A&&(b(A.entry,"directive.resolver.duration_ms",E.durationMs),T(A.entry,{code:B.OK}),P(A.entry),w(A.key));}function V(E){let A=g("resolver",E.resolverId);A&&(b(A.entry,"directive.resolver.duration_ms",E.durationMs),b(A.entry,"directive.resolver.error",E.errorMessage),T(A.entry,{code:B.ERROR,message:E.errorMessage}),P(A.entry),w(A.key));}function ge(E){let A=f.length>0?f[f.length-1]:null,{entry:I}=x(`${e}.pattern.${E.patternType}`,{"directive.service":t.serviceName,"directive.pattern.id":E.patternId,"directive.pattern.type":E.patternType},A),$=h("pattern",E.patternId);v("pattern",E.patternId,$,I),f.length<100&&f.push(I);}function st(E){let A=g("pattern",E.patternId);if(A){b(A.entry,"directive.pattern.duration_ms",E.durationMs),E.error?(b(A.entry,"directive.pattern.error",E.error),T(A.entry,{code:B.ERROR,message:E.error})):T(A.entry,{code:B.OK}),P(A.entry),w(A.key);let I=f.indexOf(A.entry);I!==-1&&f.splice(I,1);}}return {attach(E){if(y&&y!==E)throw new Error("[Directive OTEL] Plugin already attached to a different timeline. Create a new plugin instance.");y=E;let A=E.subscribe(D),I=setInterval(M,Math.min(o,6e4));return ()=>{A(),clearInterval(I),y=null;for(let[$,F]of l)b(F,"directive.detached",true),T(F,{code:B.ERROR,message:"Plugin detached while span was active"}),P(F);l.clear(),d.clear(),f.length=0;}},getSpans(){return s?[...s.spans]:(m||(m=true,typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.warn("[Directive OTEL] getSpans() returns [] when using an external tracer. Use the onSpanEnd callback to collect span data instead.")),[])},clearSpans(){s?.clear();},getTracer(){return a},getActiveSpanCount(){return l.size}}}Object.defineProperty(exports,"createAgentOrchestrator",{enumerable:true,get:function(){return chunkXV2QSBBE_cjs.a}});Object.defineProperty(exports,"createRunner",{enumerable:true,get:function(){return chunk3WO4MWJM_cjs.f}});Object.defineProperty(exports,"estimateCost",{enumerable:true,get:function(){return chunk3WO4MWJM_cjs.c}});Object.defineProperty(exports,"hasPendingApprovals",{enumerable:true,get:function(){return chunk3WO4MWJM_cjs.b}});Object.defineProperty(exports,"isAgentRunning",{enumerable:true,get:function(){return chunk3WO4MWJM_cjs.a}});Object.defineProperty(exports,"validateBaseURL",{enumerable:true,get:function(){return chunk3WO4MWJM_cjs.d}});Object.defineProperty(exports,"GuardrailError",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.a}});Object.defineProperty(exports,"InMemoryCheckpointStore",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.G}});Object.defineProperty(exports,"MAX_BREAKPOINT_HISTORY",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.A}});Object.defineProperty(exports,"ReflectionExhaustedError",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.W}});Object.defineProperty(exports,"Semaphore",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.Z}});Object.defineProperty(exports,"StructuredOutputError",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.J}});Object.defineProperty(exports,"adaptOutputGuardrail",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.P}});Object.defineProperty(exports,"aggregateTokens",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ua}});Object.defineProperty(exports,"allReadyStrategy",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ka}});Object.defineProperty(exports,"capabilityRoute",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.xa}});Object.defineProperty(exports,"collectOutputs",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ta}});Object.defineProperty(exports,"collectTokens",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.Q}});Object.defineProperty(exports,"combineStreamingGuardrails",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.O}});Object.defineProperty(exports,"composePatterns",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.va}});Object.defineProperty(exports,"concatResults",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ra}});Object.defineProperty(exports,"costEfficientStrategy",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ma}});Object.defineProperty(exports,"createBreakpointId",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.B}});Object.defineProperty(exports,"createCheckpointId",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.E}});Object.defineProperty(exports,"createDebugTimeline",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.i}});Object.defineProperty(exports,"createDebugTimelinePlugin",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.j}});Object.defineProperty(exports,"createHealthMonitor",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.V}});Object.defineProperty(exports,"createInitialBreakpointState",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.D}});Object.defineProperty(exports,"createLengthStreamingGuardrail",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.M}});Object.defineProperty(exports,"createMultiAgentOrchestrator",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.Da}});Object.defineProperty(exports,"createPatternStreamingGuardrail",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.N}});Object.defineProperty(exports,"createStreamingRunner",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.K}});Object.defineProperty(exports,"createToxicityStreamingGuardrail",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.L}});Object.defineProperty(exports,"dag",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ga}});Object.defineProperty(exports,"debate",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.za}});Object.defineProperty(exports,"derivedConstraint",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.Ba}});Object.defineProperty(exports,"diffCheckpoints",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.aa}});Object.defineProperty(exports,"extractJsonFromOutput",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.H}});Object.defineProperty(exports,"filterStream",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.S}});Object.defineProperty(exports,"findAgentsByCapability",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.wa}});Object.defineProperty(exports,"forkFromCheckpoint",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ba}});Object.defineProperty(exports,"formatSystemMeta",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.g}});Object.defineProperty(exports,"getCheckpointProgress",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.$}});Object.defineProperty(exports,"getPatternStep",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs._}});Object.defineProperty(exports,"goal",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ja}});Object.defineProperty(exports,"highestImpactStrategy",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.la}});Object.defineProperty(exports,"isGuardrailError",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.b}});Object.defineProperty(exports,"mapStream",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.T}});Object.defineProperty(exports,"matchBreakpoint",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.C}});Object.defineProperty(exports,"mergeTaggedStreams",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.U}});Object.defineProperty(exports,"parallel",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.da}});Object.defineProperty(exports,"patternFromJSON",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.oa}});Object.defineProperty(exports,"patternToJSON",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.na}});Object.defineProperty(exports,"pickBestResult",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.sa}});Object.defineProperty(exports,"race",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ia}});Object.defineProperty(exports,"reflect",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ha}});Object.defineProperty(exports,"runAgentRequirement",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.qa}});Object.defineProperty(exports,"runDebate",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.Aa}});Object.defineProperty(exports,"selectAgent",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.pa}});Object.defineProperty(exports,"sequential",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ea}});Object.defineProperty(exports,"spawnOnCondition",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.ya}});Object.defineProperty(exports,"spawnPool",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.Ca}});Object.defineProperty(exports,"supervisor",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.fa}});Object.defineProperty(exports,"tapStream",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.R}});Object.defineProperty(exports,"toAIContext",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.h}});Object.defineProperty(exports,"validateCheckpoint",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.F}});Object.defineProperty(exports,"withReflection",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.X}});Object.defineProperty(exports,"withStructuredOutput",{enumerable:true,get:function(){return chunkX3VQ5F7D_cjs.I}});Object.defineProperty(exports,"CircuitBreakerOpenError",{enumerable:true,get:function(){return plugins.CircuitBreakerOpenError}});Object.defineProperty(exports,"createCircuitBreaker",{enumerable:true,get:function(){return plugins.createCircuitBreaker}});Object.defineProperty(exports,"createOTLPExporter",{enumerable:true,get:function(){return plugins.createOTLPExporter}});exports.AllProvidersFailedError=ue;exports.BudgetExceededError=te;exports.DEFAULT_INJECTION_PATTERNS=Z;exports.OtelStatusCode=B;exports.PredicateFromIntentError=ne;exports.RetryExhaustedError=ce;exports.STRICT_INJECTION_PATTERNS=ve;exports.byAgentName=Xr;exports.byInputLength=Qr;exports.byPattern=Zr;exports.connectDevTools=wo;exports.convertToolsForLLM=Do;exports.createAgentAuditHandlers=hr;exports.createAgentMemory=Pn;exports.createAgentNetwork=Kn;exports.createAuditTrail=yr;exports.createBatchQueue=vo;exports.createBatchedEmbedder=kr;exports.createBidirectionalStream=Or;exports.createBruteForceIndex=Ir;exports.createCompliance=Ar;exports.createConstraintRouter=Eo;exports.createContentFilterGuardrail=xn;exports.createDelegator=Yn;exports.createDevToolsServer=nt;exports.createEnhancedPIIGuardrail=_e;exports.createEvalSuite=Zo;exports.createHybridStrategy=Tn;exports.createInMemoryComplianceStorage=Cr;exports.createInMemoryStorage=He;exports.createJSONFileStore=Br;exports.createKeyPointsSummarizer=In;exports.createLLMSummarizer=Dn;exports.createLengthGuardrail=An;exports.createMCPAdapter=Po;exports.createMessageBus=Jn;exports.createModerationGuardrail=Sn;exports.createOtelPlugin=ts;exports.createOutputPIIGuardrail=ar;exports.createOutputSchemaGuardrail=Rn;exports.createOutputTypeGuardrail=Cn;exports.createPIIGuardrail=vn;exports.createPromptInjectionGuardrail=Ue;exports.createPubSub=Qn;exports.createRAGEnricher=Gr;exports.createRateLimitGuardrail=En;exports.createResponder=Wn;exports.createSSETransport=Ur;exports.createSemanticCache=Mr;exports.createSemanticCacheGuardrail=Tr;exports.createSlidingWindowStrategy=ke;exports.createStreamChannel=we;exports.createTestEmbedder=Pr;exports.createTokenBasedStrategy=Ie;exports.createToolGuardrail=wn;exports.createTruncationSummarizer=kn;exports.createUntrustedContentGuardrail=vr;exports.createVPTreeIndex=Dr;exports.createWsTransport=rt;exports.detectAndRedactPII=ir;exports.detectPII=ae;exports.detectPromptInjection=Se;exports.evalAssert=es;exports.evalCoherence=Xo;exports.evalCost=Lo;exports.evalFaithfulness=Ko;exports.evalJudge=qo;exports.evalLatency=Bo;exports.evalMatch=Vo;exports.evalOutputLength=Uo;exports.evalRelevance=Yo;exports.evalSafety=zo;exports.evalStructure=Ho;exports.explainGoal=xo;exports.getDependencyGraph=Ro;exports.markUntrustedContent=br;exports.mcpCallTool=Oo;exports.mcpGetPrompt=No;exports.mcpReadResource=$o;exports.mcpSyncResources=_o;exports.mergeStreams=Nr;exports.parseHttpStatus=Re;exports.parseRetryAfter=Je;exports.patternToMermaid=Vn;exports.pipe=Mn;exports.pipeThrough=$r;exports.planGoal=Ao;exports.predicateFromIntent=fo;exports.predicateFromIntentRaw=Ce;exports.predicateFromIntentWithProvenance=bo;exports.predicateToolSpec=ho;exports.predicateToolSpecAnthropic=et;exports.predicateToolSpecOpenAI=yo;exports.redactPII=X;exports.sanitizeInjection=Be;exports.validateGoal=Co;exports.withBudget=Yr;exports.withFallback=Kr;exports.withModelSelection=eo;exports.withRetry=Jr;//# sourceMappingURL=index.cjs.map
|
|
119
119
|
//# sourceMappingURL=index.cjs.map
|