@elizaos/core 1.5.8-alpha.7 → 1.5.8-alpha.8

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.
@@ -580,7 +580,7 @@ Message: ${Array.isArray(j.detail)?j.detail.join(`
580
580
 
581
581
  ${$.stack}`:"");if(typeof $==="string")return $;return`${$}`}_addChildRun($,q){$.child_runs.push(q)}_addRunToRunMap($){let{dottedOrder:q,microsecondPrecisionDatestring:K}=yz(new Date($.start_time).getTime(),$.id,$.execution_order),_={...$},Y=this.getRunById(_.parent_run_id);if(_.parent_run_id!==void 0){if(Y){if(this._addChildRun(Y,_),Y.child_execution_order=Math.max(Y.child_execution_order,_.child_execution_order),_.trace_id=Y.trace_id,Y.dotted_order!==void 0)_.dotted_order=[Y.dotted_order,q].join("."),_._serialized_start_time=K}}else _.trace_id=_.id,_.dotted_order=q,_._serialized_start_time=K;if(this.usesRunTreeMap){let j=Bz(_,Y);if(j!==void 0)this.runTreeMap.set(_.id,j)}else this.runMap.set(_.id,_);return _}async _endTrace($){let q=$.parent_run_id!==void 0&&this.getRunById($.parent_run_id);if(q)q.child_execution_order=Math.max(q.child_execution_order,$.child_execution_order);else await this.persistRun($);if(await this.onRunUpdate?.($),this.usesRunTreeMap)this.runTreeMap.delete($.id);else this.runMap.delete($.id)}_getExecutionOrder($){let q=$!==void 0&&this.getRunById($);if(!q)return 1;return q.child_execution_order+1}_createRunForLLMStart($,q,K,_,Y,j,P,O){let W=this._getExecutionOrder(_),X=Date.now(),A=P?{...Y,metadata:P}:Y,Z={id:K,name:O??$.id[$.id.length-1],parent_run_id:_,start_time:X,serialized:$,events:[{name:"start",time:new Date(X).toISOString()}],inputs:{prompts:q},execution_order:W,child_runs:[],child_execution_order:W,run_type:"llm",extra:A??{},tags:j||[]};return this._addRunToRunMap(Z)}async handleLLMStart($,q,K,_,Y,j,P,O){let W=this.getRunById(K)??this._createRunForLLMStart($,q,K,_,Y,j,P,O);return await this.onRunCreate?.(W),await this.onLLMStart?.(W),W}_createRunForChatModelStart($,q,K,_,Y,j,P,O){let W=this._getExecutionOrder(_),X=Date.now(),A=P?{...Y,metadata:P}:Y,Z={id:K,name:O??$.id[$.id.length-1],parent_run_id:_,start_time:X,serialized:$,events:[{name:"start",time:new Date(X).toISOString()}],inputs:{messages:q},execution_order:W,child_runs:[],child_execution_order:W,run_type:"llm",extra:A??{},tags:j||[]};return this._addRunToRunMap(Z)}async handleChatModelStart($,q,K,_,Y,j,P,O){let W=this.getRunById(K)??this._createRunForChatModelStart($,q,K,_,Y,j,P,O);return await this.onRunCreate?.(W),await this.onLLMStart?.(W),W}async handleLLMEnd($,q,K,_,Y){let j=this.getRunById(q);if(!j||j?.run_type!=="llm")throw new Error("No LLM run to end.");return j.end_time=Date.now(),j.outputs=$,j.events.push({name:"end",time:new Date(j.end_time).toISOString()}),j.extra={...j.extra,...Y},await this.onLLMEnd?.(j),await this._endTrace(j),j}async handleLLMError($,q,K,_,Y){let j=this.getRunById(q);if(!j||j?.run_type!=="llm")throw new Error("No LLM run to end.");return j.end_time=Date.now(),j.error=this.stringifyError($),j.events.push({name:"error",time:new Date(j.end_time).toISOString()}),j.extra={...j.extra,...Y},await this.onLLMError?.(j),await this._endTrace(j),j}_createRunForChainStart($,q,K,_,Y,j,P,O){let W=this._getExecutionOrder(_),X=Date.now(),A={id:K,name:O??$.id[$.id.length-1],parent_run_id:_,start_time:X,serialized:$,events:[{name:"start",time:new Date(X).toISOString()}],inputs:q,execution_order:W,child_execution_order:W,run_type:P??"chain",child_runs:[],extra:j?{metadata:j}:{},tags:Y||[]};return this._addRunToRunMap(A)}async handleChainStart($,q,K,_,Y,j,P,O){let W=this.getRunById(K)??this._createRunForChainStart($,q,K,_,Y,j,P,O);return await this.onRunCreate?.(W),await this.onChainStart?.(W),W}async handleChainEnd($,q,K,_,Y){let j=this.getRunById(q);if(!j)throw new Error("No chain run to end.");if(j.end_time=Date.now(),j.outputs=cz($,"output"),j.events.push({name:"end",time:new Date(j.end_time).toISOString()}),Y?.inputs!==void 0)j.inputs=cz(Y.inputs,"input");return await this.onChainEnd?.(j),await this._endTrace(j),j}async handleChainError($,q,K,_,Y){let j=this.getRunById(q);if(!j)throw new Error("No chain run to end.");if(j.end_time=Date.now(),j.error=this.stringifyError($),j.events.push({name:"error",time:new Date(j.end_time).toISOString()}),Y?.inputs!==void 0)j.inputs=cz(Y.inputs,"input");return await this.onChainError?.(j),await this._endTrace(j),j}_createRunForToolStart($,q,K,_,Y,j,P){let O=this._getExecutionOrder(_),W=Date.now(),X={id:K,name:P??$.id[$.id.length-1],parent_run_id:_,start_time:W,serialized:$,events:[{name:"start",time:new Date(W).toISOString()}],inputs:{input:q},execution_order:O,child_execution_order:O,run_type:"tool",child_runs:[],extra:j?{metadata:j}:{},tags:Y||[]};return this._addRunToRunMap(X)}async handleToolStart($,q,K,_,Y,j,P){let O=this.getRunById(K)??this._createRunForToolStart($,q,K,_,Y,j,P);return await this.onRunCreate?.(O),await this.onToolStart?.(O),O}async handleToolEnd($,q){let K=this.getRunById(q);if(!K||K?.run_type!=="tool")throw new Error("No tool run to end");return K.end_time=Date.now(),K.outputs={output:$},K.events.push({name:"end",time:new Date(K.end_time).toISOString()}),await this.onToolEnd?.(K),await this._endTrace(K),K}async handleToolError($,q){let K=this.getRunById(q);if(!K||K?.run_type!=="tool")throw new Error("No tool run to end");return K.end_time=Date.now(),K.error=this.stringifyError($),K.events.push({name:"error",time:new Date(K.end_time).toISOString()}),await this.onToolError?.(K),await this._endTrace(K),K}async handleAgentAction($,q){let K=this.getRunById(q);if(!K||K?.run_type!=="chain")return;let _=K;_.actions=_.actions||[],_.actions.push($),_.events.push({name:"agent_action",time:new Date().toISOString(),kwargs:{action:$}}),await this.onAgentAction?.(K)}async handleAgentEnd($,q){let K=this.getRunById(q);if(!K||K?.run_type!=="chain")return;K.events.push({name:"agent_end",time:new Date().toISOString(),kwargs:{action:$}}),await this.onAgentEnd?.(K)}_createRunForRetrieverStart($,q,K,_,Y,j,P){let O=this._getExecutionOrder(_),W=Date.now(),X={id:K,name:P??$.id[$.id.length-1],parent_run_id:_,start_time:W,serialized:$,events:[{name:"start",time:new Date(W).toISOString()}],inputs:{query:q},execution_order:O,child_execution_order:O,run_type:"retriever",child_runs:[],extra:j?{metadata:j}:{},tags:Y||[]};return this._addRunToRunMap(X)}async handleRetrieverStart($,q,K,_,Y,j,P){let O=this.getRunById(K)??this._createRunForRetrieverStart($,q,K,_,Y,j,P);return await this.onRunCreate?.(O),await this.onRetrieverStart?.(O),O}async handleRetrieverEnd($,q){let K=this.getRunById(q);if(!K||K?.run_type!=="retriever")throw new Error("No retriever run to end");return K.end_time=Date.now(),K.outputs={documents:$},K.events.push({name:"end",time:new Date(K.end_time).toISOString()}),await this.onRetrieverEnd?.(K),await this._endTrace(K),K}async handleRetrieverError($,q){let K=this.getRunById(q);if(!K||K?.run_type!=="retriever")throw new Error("No retriever run to end");return K.end_time=Date.now(),K.error=this.stringifyError($),K.events.push({name:"error",time:new Date(K.end_time).toISOString()}),await this.onRetrieverError?.(K),await this._endTrace(K),K}async handleText($,q){let K=this.getRunById(q);if(!K||K?.run_type!=="chain")return;K.events.push({name:"text",time:new Date().toISOString(),kwargs:{text:$}}),await this.onText?.(K)}async handleLLMNewToken($,q,K,_,Y,j){let P=this.getRunById(K);if(!P||P?.run_type!=="llm")throw new Error('Invalid "runId" provided to "handleLLMNewToken" callback.');return P.events.push({name:"new_token",time:new Date().toISOString(),kwargs:{token:$,idx:q,chunk:j?.chunk}}),await this.onLLMNewToken?.(P,$,{chunk:j?.chunk}),P}}var dz=HK(B0(),1);function n6($,q){return`${$.open}${q}${$.close}`}function nK($,q){try{return JSON.stringify($,null,2)}catch(K){return q}}function d0($){if(typeof $==="string")return $.trim();if($===null||$===void 0)return $;return nK($,$.toString())}function V_($){if(!$.end_time)return"";let q=$.end_time-$.start_time;if(q<1000)return`${q}ms`;return`${(q/1000).toFixed(2)}s`}var{color:GK}=dz.default;class F3 extends C4{constructor(){super(...arguments);Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"console_callback_handler"})}persistRun($){return Promise.resolve()}getParents($){let q=[],K=$;while(K.parent_run_id){let _=this.runMap.get(K.parent_run_id);if(_)q.push(_),K=_;else break}return q}getBreadcrumbs($){let K=[...this.getParents($).reverse(),$].map((_,Y,j)=>{let P=`${_.execution_order}:${_.run_type}:${_.name}`;return Y===j.length-1?n6(dz.default.bold,P):P}).join(" > ");return n6(GK.grey,K)}onChainStart($){let q=this.getBreadcrumbs($);console.log(`${n6(GK.green,"[chain/start]")} [${q}] Entering Chain run with input: ${nK($.inputs,"[inputs]")}`)}onChainEnd($){let q=this.getBreadcrumbs($);console.log(`${n6(GK.cyan,"[chain/end]")} [${q}] [${V_($)}] Exiting Chain run with output: ${nK($.outputs,"[outputs]")}`)}onChainError($){let q=this.getBreadcrumbs($);console.log(`${n6(GK.red,"[chain/error]")} [${q}] [${V_($)}] Chain run errored with error: ${nK($.error,"[error]")}`)}onLLMStart($){let q=this.getBreadcrumbs($),K="prompts"in $.inputs?{prompts:$.inputs.prompts.map((_)=>_.trim())}:$.inputs;console.log(`${n6(GK.green,"[llm/start]")} [${q}] Entering LLM run with input: ${nK(K,"[inputs]")}`)}onLLMEnd($){let q=this.getBreadcrumbs($);console.log(`${n6(GK.cyan,"[llm/end]")} [${q}] [${V_($)}] Exiting LLM run with output: ${nK($.outputs,"[response]")}`)}onLLMError($){let q=this.getBreadcrumbs($);console.log(`${n6(GK.red,"[llm/error]")} [${q}] [${V_($)}] LLM run errored with error: ${nK($.error,"[error]")}`)}onToolStart($){let q=this.getBreadcrumbs($);console.log(`${n6(GK.green,"[tool/start]")} [${q}] Entering Tool run with input: "${d0($.inputs.input)}"`)}onToolEnd($){let q=this.getBreadcrumbs($);console.log(`${n6(GK.cyan,"[tool/end]")} [${q}] [${V_($)}] Exiting Tool run with output: "${d0($.outputs?.output)}"`)}onToolError($){let q=this.getBreadcrumbs($);console.log(`${n6(GK.red,"[tool/error]")} [${q}] [${V_($)}] Tool run errored with error: ${nK($.error,"[error]")}`)}onRetrieverStart($){let q=this.getBreadcrumbs($);console.log(`${n6(GK.green,"[retriever/start]")} [${q}] Entering Retriever run with input: ${nK($.inputs,"[inputs]")}`)}onRetrieverEnd($){let q=this.getBreadcrumbs($);console.log(`${n6(GK.cyan,"[retriever/end]")} [${q}] [${V_($)}] Exiting Retriever run with output: ${nK($.outputs,"[outputs]")}`)}onRetrieverError($){let q=this.getBreadcrumbs($);console.log(`${n6(GK.red,"[retriever/error]")} [${q}] [${V_($)}] Retriever run errored with error: ${nK($.error,"[error]")}`)}onAgentAction($){let q=$,K=this.getBreadcrumbs($);console.log(`${n6(GK.blue,"[agent/action]")} [${K}] Agent selected action: ${nK(q.actions[q.actions.length-1],"[action]")}`)}}function lz($){return!!($&&typeof $==="object"&&("type"in $)&&$.type==="tool_call")}class Uz extends Error{constructor($,q){super($);Object.defineProperty(this,"output",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.output=q}}function l0($){if(typeof $==="undefined")return null;try{return JSON.parse($)}catch(j){}let q="",K=[],_=!1,Y=!1;for(let j of $){if(_)if(j==='"'&&!Y)_=!1;else if(j===`
582
582
  `&&!Y)j="\\n";else if(j==="\\")Y=!Y;else Y=!1;else if(j==='"')_=!0,Y=!1;else if(j==="{")K.push("}");else if(j==="[")K.push("]");else if(j==="}"||j==="]")if(K&&K[K.length-1]===j)K.pop();else return null;q+=j}if(_)q+='"';for(let j=K.length-1;j>=0;j-=1)q+=K[j];try{return JSON.parse(q)}catch(j){return null}}function Fz($){return typeof $==="object"&&$!==null&&"type"in $&&typeof $.type==="string"&&"source_type"in $&&($.source_type==="url"||$.source_type==="base64"||$.source_type==="text"||$.source_type==="id")}function A9($,q){if(typeof $==="string"){if($==="")return q;if(typeof q==="string")return $+q;else if(Array.isArray(q)&&q.some((K)=>Fz(K)))return[{type:"text",source_type:"text",text:$},...q];else return[{type:"text",text:$},...q]}else if(Array.isArray(q))return Q3($,q)??[...$,...q];else if(q==="")return $;else if(Array.isArray($)&&$.some((K)=>Fz(K)))return[...$,{type:"file",source_type:"text",text:q}];else return[...$,{type:"text",text:q}]}function Fd($,q){function K(_,Y){if(typeof _!=="object"||_===null||_===void 0)return _;if(Y>=q){if(Array.isArray(_))return"[Array]";return"[Object]"}if(Array.isArray(_))return _.map((P)=>K(P,Y+1));let j={};for(let P of Object.keys(_))j[P]=K(_[P],Y+1);return j}return JSON.stringify(K($,0),null,2)}class M_ extends b7{get lc_aliases(){return{additional_kwargs:"additional_kwargs",response_metadata:"response_metadata"}}get text(){if(typeof this.content==="string")return this.content;if(!Array.isArray(this.content))return"";return this.content.map(($)=>{if(typeof $==="string")return $;if($.type==="text")return $.text;return""}).join("")}getType(){return this._getType()}constructor($,q){if(typeof $==="string")$={content:$,additional_kwargs:q,response_metadata:{}};if(!$.additional_kwargs)$.additional_kwargs={};if(!$.response_metadata)$.response_metadata={};super($);Object.defineProperty(this,"lc_namespace",{enumerable:!0,configurable:!0,writable:!0,value:["langchain_core","messages"]}),Object.defineProperty(this,"lc_serializable",{enumerable:!0,configurable:!0,writable:!0,value:!0}),Object.defineProperty(this,"content",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"additional_kwargs",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"response_metadata",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"id",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.name=$.name,this.content=$.content,this.additional_kwargs=$.additional_kwargs,this.response_metadata=$.response_metadata,this.id=$.id}toDict(){return{type:this._getType(),data:this.toJSON().kwargs}}static lc_name(){return"BaseMessage"}get _printableFields(){return{id:this.id,content:this.content,name:this.name,additional_kwargs:this.additional_kwargs,response_metadata:this.response_metadata}}_updateId($){this.id=$,this.lc_kwargs.id=$}get[Symbol.toStringTag](){return this.constructor.lc_name()}[Symbol.for("nodejs.util.inspect.custom")]($){if($===null)return this;let q=Fd(this._printableFields,Math.max(4,$));return`${this.constructor.lc_name()} ${q}`}}function e4($,q){let K={...$};for(let[_,Y]of Object.entries(q))if(K[_]==null)K[_]=Y;else if(Y==null)continue;else if(typeof K[_]!==typeof Y||Array.isArray(K[_])!==Array.isArray(Y))throw new Error(`field[${_}] already exists in the message chunk, but with a different type.`);else if(typeof K[_]==="string"){if(_==="type")continue;K[_]+=Y}else if(typeof K[_]==="object"&&!Array.isArray(K[_]))K[_]=e4(K[_],Y);else if(Array.isArray(K[_]))K[_]=Q3(K[_],Y);else if(K[_]===Y)continue;else console.warn(`field[${_}] already exists in this message chunk and value has unsupported type.`);return K}function Q3($,q){if($===void 0&&q===void 0)return;else if($===void 0||q===void 0)return $||q;else{let K=[...$];for(let _ of q)if(typeof _==="object"&&"index"in _&&typeof _.index==="number"){let Y=K.findIndex((j)=>j.index===_.index);if(Y!==-1)K[Y]=e4(K[Y],_);else K.push(_)}else if(typeof _==="object"&&"text"in _&&_.text==="")continue;else K.push(_);return K}}class N_ extends M_{}class f9 extends N_{constructor($){let q;if(typeof $==="string")q={content:$,tool_calls:[],invalid_tool_calls:[],tool_call_chunks:[]};else if($.tool_call_chunks===void 0)q={...$,tool_calls:$.tool_calls??[],invalid_tool_calls:[],tool_call_chunks:[],usage_metadata:$.usage_metadata!==void 0?$.usage_metadata:void 0};else{let K=$.tool_call_chunks.reduce((j,P)=>{let O=P.id||`fallback-${P.index||0}`;return j[O]=j[O]??[],j[O].push(P),j},{}),_=[],Y=[];for(let[j,P]of Object.entries(K)){let O={},W=P[0]?.name??"",X=P.map((T)=>T.args||"").join(""),A=X.length?X:"{}",Z=P[0]?.id||j;try{if(O=l0(A),O===null||typeof O!=="object"||Array.isArray(O))throw new Error("Malformed tool call chunk args.");_.push({name:W,args:O,id:Z,type:"tool_call"})}catch(T){Y.push({name:W,args:A,id:Z,error:"Malformed args.",type:"invalid_tool_call"})}}q={...$,tool_calls:_,invalid_tool_calls:Y,usage_metadata:$.usage_metadata!==void 0?$.usage_metadata:void 0}}super(q);Object.defineProperty(this,"tool_calls",{enumerable:!0,configurable:!0,writable:!0,value:[]}),Object.defineProperty(this,"invalid_tool_calls",{enumerable:!0,configurable:!0,writable:!0,value:[]}),Object.defineProperty(this,"tool_call_chunks",{enumerable:!0,configurable:!0,writable:!0,value:[]}),Object.defineProperty(this,"usage_metadata",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.tool_call_chunks=q.tool_call_chunks??this.tool_call_chunks,this.tool_calls=q.tool_calls??this.tool_calls,this.invalid_tool_calls=q.invalid_tool_calls??this.invalid_tool_calls,this.usage_metadata=q.usage_metadata}get lc_aliases(){return{...super.lc_aliases,tool_calls:"tool_calls",invalid_tool_calls:"invalid_tool_calls",tool_call_chunks:"tool_call_chunks"}}static lc_name(){return"AIMessageChunk"}_getType(){return"ai"}get _printableFields(){return{...super._printableFields,tool_calls:this.tool_calls,tool_call_chunks:this.tool_call_chunks,invalid_tool_calls:this.invalid_tool_calls,usage_metadata:this.usage_metadata}}concat($){let q={content:A9(this.content,$.content),additional_kwargs:e4(this.additional_kwargs,$.additional_kwargs),response_metadata:e4(this.response_metadata,$.response_metadata),tool_call_chunks:[],id:this.id??$.id};if(this.tool_call_chunks!==void 0||$.tool_call_chunks!==void 0){let K=Q3(this.tool_call_chunks,$.tool_call_chunks);if(K!==void 0&&K.length>0)q.tool_call_chunks=K}if(this.usage_metadata!==void 0||$.usage_metadata!==void 0){let K={...(this.usage_metadata?.input_token_details?.audio!==void 0||$.usage_metadata?.input_token_details?.audio!==void 0)&&{audio:(this.usage_metadata?.input_token_details?.audio??0)+($.usage_metadata?.input_token_details?.audio??0)},...(this.usage_metadata?.input_token_details?.cache_read!==void 0||$.usage_metadata?.input_token_details?.cache_read!==void 0)&&{cache_read:(this.usage_metadata?.input_token_details?.cache_read??0)+($.usage_metadata?.input_token_details?.cache_read??0)},...(this.usage_metadata?.input_token_details?.cache_creation!==void 0||$.usage_metadata?.input_token_details?.cache_creation!==void 0)&&{cache_creation:(this.usage_metadata?.input_token_details?.cache_creation??0)+($.usage_metadata?.input_token_details?.cache_creation??0)}},_={...(this.usage_metadata?.output_token_details?.audio!==void 0||$.usage_metadata?.output_token_details?.audio!==void 0)&&{audio:(this.usage_metadata?.output_token_details?.audio??0)+($.usage_metadata?.output_token_details?.audio??0)},...(this.usage_metadata?.output_token_details?.reasoning!==void 0||$.usage_metadata?.output_token_details?.reasoning!==void 0)&&{reasoning:(this.usage_metadata?.output_token_details?.reasoning??0)+($.usage_metadata?.output_token_details?.reasoning??0)}},Y=this.usage_metadata??{input_tokens:0,output_tokens:0,total_tokens:0},j=$.usage_metadata??{input_tokens:0,output_tokens:0,total_tokens:0},P={input_tokens:Y.input_tokens+j.input_tokens,output_tokens:Y.output_tokens+j.output_tokens,total_tokens:Y.total_tokens+j.total_tokens,...Object.keys(K).length>0&&{input_token_details:K},...Object.keys(_).length>0&&{output_token_details:_}};q.usage_metadata=P}return new f9(q)}}function U0($,q="Human",K="AI"){let _=[];for(let Y of $){let j;if(Y._getType()==="human")j=q;else if(Y._getType()==="ai")j=K;else if(Y._getType()==="system")j="System";else if(Y._getType()==="function")j="Function";else if(Y._getType()==="tool")j="Tool";else if(Y._getType()==="generic")j=Y.role;else throw new Error(`Got unsupported message type: ${Y._getType()}`);let P=Y.name?`${Y.name}, `:"",O=typeof Y.content==="string"?Y.content:JSON.stringify(Y.content,null,2);_.push(`${j}: ${P}${O}`)}return _.join(`
583
- `)}var Qz,oz=()=>{if(Qz===void 0){let $=s4("LANGCHAIN_CALLBACKS_BACKGROUND")==="false"?{blockOnRootRunFinalization:!0}:{};Qz=new v_($)}return Qz};class o1 extends C4{constructor($={}){super($);Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"langchain_tracer"}),Object.defineProperty(this,"projectName",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"exampleId",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"client",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"replicas",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"usesRunTreeMap",{enumerable:!0,configurable:!0,writable:!0,value:!0});let{exampleId:q,projectName:K,client:_,replicas:Y}=$;this.projectName=K??j2(),this.replicas=Y,this.exampleId=q,this.client=_??oz();let j=o1.getTraceableRunTree();if(j)this.updateFromRunTree(j)}async persistRun($){}async onRunCreate($){await this.getRunTreeWithTracingConfig($.id)?.postRun()}async onRunUpdate($){await this.getRunTreeWithTracingConfig($.id)?.patchRun()}getRun($){return this.runTreeMap.get($)}updateFromRunTree($){this.runTreeMap.set($.id,$);let q=$,K=new Set;while(q.parent_run){if(K.has(q.id))break;if(K.add(q.id),!q.parent_run)break;q=q.parent_run}K.clear();let _=[q];while(_.length>0){let Y=_.shift();if(!Y||K.has(Y.id))continue;if(K.add(Y.id),this.runTreeMap.set(Y.id,Y),Y.child_runs)_.push(...Y.child_runs)}this.client=$.client??this.client,this.replicas=$.replicas??this.replicas,this.projectName=$.project_name??this.projectName,this.exampleId=$.reference_example_id??this.exampleId}getRunTreeWithTracingConfig($){let q=this.runTreeMap.get($);if(!q)return;return new q6({...q,client:this.client,project_name:this.projectName,replicas:this.replicas,reference_example_id:this.exampleId,tracingEnabled:!0})}static getTraceableRunTree(){try{return Pk(!0)}catch{return}}}var o3=HK(M3(),1);var F0=Symbol.for("ls:tracing_async_local_storage"),k9=Symbol.for("lc:context_variables"),Q0=($)=>{globalThis[F0]=$},C_=()=>{return globalThis[F0]};var T2;function Qd(){return new("default"in o3.default?o3.default.default:o3.default)({autoStart:!0,concurrency:1})}function od(){if(typeof T2==="undefined")T2=Qd();return T2}async function I8($,q){if(q===!0){let K=C_();if(K!==void 0)await K.run(void 0,async()=>$());else await $()}else T2=od(),T2.add(async()=>{let K=C_();if(K!==void 0)await K.run(void 0,async()=>$());else await $()})}var o0=($)=>{if($!==void 0)return $;return!!["LANGSMITH_TRACING_V2","LANGCHAIN_TRACING_V2","LANGSMITH_TRACING","LANGCHAIN_TRACING"].find((K)=>s4(K)==="true")};function iz($){let q=C_();if(q===void 0)return;return q.getStore()?.[k9]?.[$]}var id=Symbol("lc:configure_hooks"),i0=()=>iz(id)||[];class r0{setHandler($){return this.setHandlers([$])}}class f2{constructor($,q,K,_,Y,j,P,O){Object.defineProperty(this,"runId",{enumerable:!0,configurable:!0,writable:!0,value:$}),Object.defineProperty(this,"handlers",{enumerable:!0,configurable:!0,writable:!0,value:q}),Object.defineProperty(this,"inheritableHandlers",{enumerable:!0,configurable:!0,writable:!0,value:K}),Object.defineProperty(this,"tags",{enumerable:!0,configurable:!0,writable:!0,value:_}),Object.defineProperty(this,"inheritableTags",{enumerable:!0,configurable:!0,writable:!0,value:Y}),Object.defineProperty(this,"metadata",{enumerable:!0,configurable:!0,writable:!0,value:j}),Object.defineProperty(this,"inheritableMetadata",{enumerable:!0,configurable:!0,writable:!0,value:P}),Object.defineProperty(this,"_parentRunId",{enumerable:!0,configurable:!0,writable:!0,value:O})}get parentRunId(){return this._parentRunId}async handleText($){await Promise.all(this.handlers.map((q)=>I8(async()=>{try{await q.handleText?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleText: ${K}`),q.raiseError)throw K}},q.awaitHandlers)))}async handleCustomEvent($,q,K,_,Y){await Promise.all(this.handlers.map((j)=>I8(async()=>{try{await j.handleCustomEvent?.($,q,this.runId,this.tags,this.metadata)}catch(P){if((j.raiseError?console.error:console.warn)(`Error in handler ${j.constructor.name}, handleCustomEvent: ${P}`),j.raiseError)throw P}},j.awaitHandlers)))}}class n0 extends f2{getChild($){let q=new bK(this.runId);if(q.setHandlers(this.inheritableHandlers),q.addTags(this.inheritableTags),q.addMetadata(this.inheritableMetadata),$)q.addTags([$],!1);return q}async handleRetrieverEnd($){await Promise.all(this.handlers.map((q)=>I8(async()=>{if(!q.ignoreRetriever)try{await q.handleRetrieverEnd?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleRetriever`),q.raiseError)throw K}},q.awaitHandlers)))}async handleRetrieverError($){await Promise.all(this.handlers.map((q)=>I8(async()=>{if(!q.ignoreRetriever)try{await q.handleRetrieverError?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleRetrieverError: ${K}`),q.raiseError)throw $}},q.awaitHandlers)))}}class rz extends f2{async handleLLMNewToken($,q,K,_,Y,j){await Promise.all(this.handlers.map((P)=>I8(async()=>{if(!P.ignoreLLM)try{await P.handleLLMNewToken?.($,q??{prompt:0,completion:0},this.runId,this._parentRunId,this.tags,j)}catch(O){if((P.raiseError?console.error:console.warn)(`Error in handler ${P.constructor.name}, handleLLMNewToken: ${O}`),P.raiseError)throw O}},P.awaitHandlers)))}async handleLLMError($,q,K,_,Y){await Promise.all(this.handlers.map((j)=>I8(async()=>{if(!j.ignoreLLM)try{await j.handleLLMError?.($,this.runId,this._parentRunId,this.tags,Y)}catch(P){if((j.raiseError?console.error:console.warn)(`Error in handler ${j.constructor.name}, handleLLMError: ${P}`),j.raiseError)throw P}},j.awaitHandlers)))}async handleLLMEnd($,q,K,_,Y){await Promise.all(this.handlers.map((j)=>I8(async()=>{if(!j.ignoreLLM)try{await j.handleLLMEnd?.($,this.runId,this._parentRunId,this.tags,Y)}catch(P){if((j.raiseError?console.error:console.warn)(`Error in handler ${j.constructor.name}, handleLLMEnd: ${P}`),j.raiseError)throw P}},j.awaitHandlers)))}}class a0 extends f2{getChild($){let q=new bK(this.runId);if(q.setHandlers(this.inheritableHandlers),q.addTags(this.inheritableTags),q.addMetadata(this.inheritableMetadata),$)q.addTags([$],!1);return q}async handleChainError($,q,K,_,Y){await Promise.all(this.handlers.map((j)=>I8(async()=>{if(!j.ignoreChain)try{await j.handleChainError?.($,this.runId,this._parentRunId,this.tags,Y)}catch(P){if((j.raiseError?console.error:console.warn)(`Error in handler ${j.constructor.name}, handleChainError: ${P}`),j.raiseError)throw P}},j.awaitHandlers)))}async handleChainEnd($,q,K,_,Y){await Promise.all(this.handlers.map((j)=>I8(async()=>{if(!j.ignoreChain)try{await j.handleChainEnd?.($,this.runId,this._parentRunId,this.tags,Y)}catch(P){if((j.raiseError?console.error:console.warn)(`Error in handler ${j.constructor.name}, handleChainEnd: ${P}`),j.raiseError)throw P}},j.awaitHandlers)))}async handleAgentAction($){await Promise.all(this.handlers.map((q)=>I8(async()=>{if(!q.ignoreAgent)try{await q.handleAgentAction?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleAgentAction: ${K}`),q.raiseError)throw K}},q.awaitHandlers)))}async handleAgentEnd($){await Promise.all(this.handlers.map((q)=>I8(async()=>{if(!q.ignoreAgent)try{await q.handleAgentEnd?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleAgentEnd: ${K}`),q.raiseError)throw K}},q.awaitHandlers)))}}class t0 extends f2{getChild($){let q=new bK(this.runId);if(q.setHandlers(this.inheritableHandlers),q.addTags(this.inheritableTags),q.addMetadata(this.inheritableMetadata),$)q.addTags([$],!1);return q}async handleToolError($){await Promise.all(this.handlers.map((q)=>I8(async()=>{if(!q.ignoreAgent)try{await q.handleToolError?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleToolError: ${K}`),q.raiseError)throw K}},q.awaitHandlers)))}async handleToolEnd($){await Promise.all(this.handlers.map((q)=>I8(async()=>{if(!q.ignoreAgent)try{await q.handleToolEnd?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleToolEnd: ${K}`),q.raiseError)throw K}},q.awaitHandlers)))}}class bK extends r0{constructor($,q){super();Object.defineProperty(this,"handlers",{enumerable:!0,configurable:!0,writable:!0,value:[]}),Object.defineProperty(this,"inheritableHandlers",{enumerable:!0,configurable:!0,writable:!0,value:[]}),Object.defineProperty(this,"tags",{enumerable:!0,configurable:!0,writable:!0,value:[]}),Object.defineProperty(this,"inheritableTags",{enumerable:!0,configurable:!0,writable:!0,value:[]}),Object.defineProperty(this,"metadata",{enumerable:!0,configurable:!0,writable:!0,value:{}}),Object.defineProperty(this,"inheritableMetadata",{enumerable:!0,configurable:!0,writable:!0,value:{}}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"callback_manager"}),Object.defineProperty(this,"_parentRunId",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.handlers=q?.handlers??this.handlers,this.inheritableHandlers=q?.inheritableHandlers??this.inheritableHandlers,this.tags=q?.tags??this.tags,this.inheritableTags=q?.inheritableTags??this.inheritableTags,this.metadata=q?.metadata??this.metadata,this.inheritableMetadata=q?.inheritableMetadata??this.inheritableMetadata,this._parentRunId=$}getParentRunId(){return this._parentRunId}async handleLLMStart($,q,K=void 0,_=void 0,Y=void 0,j=void 0,P=void 0,O=void 0){return Promise.all(q.map(async(W,X)=>{let A=X===0&&K?K:XK();return await Promise.all(this.handlers.map((Z)=>{if(Z.ignoreLLM)return;if(Q1(Z))Z._createRunForLLMStart($,[W],A,this._parentRunId,Y,this.tags,this.metadata,O);return I8(async()=>{try{await Z.handleLLMStart?.($,[W],A,this._parentRunId,Y,this.tags,this.metadata,O)}catch(T){if((Z.raiseError?console.error:console.warn)(`Error in handler ${Z.constructor.name}, handleLLMStart: ${T}`),Z.raiseError)throw T}},Z.awaitHandlers)})),new rz(A,this.handlers,this.inheritableHandlers,this.tags,this.inheritableTags,this.metadata,this.inheritableMetadata,this._parentRunId)}))}async handleChatModelStart($,q,K=void 0,_=void 0,Y=void 0,j=void 0,P=void 0,O=void 0){return Promise.all(q.map(async(W,X)=>{let A=X===0&&K?K:XK();return await Promise.all(this.handlers.map((Z)=>{if(Z.ignoreLLM)return;if(Q1(Z))Z._createRunForChatModelStart($,[W],A,this._parentRunId,Y,this.tags,this.metadata,O);return I8(async()=>{try{if(Z.handleChatModelStart)await Z.handleChatModelStart?.($,[W],A,this._parentRunId,Y,this.tags,this.metadata,O);else if(Z.handleLLMStart){let T=U0(W);await Z.handleLLMStart?.($,[T],A,this._parentRunId,Y,this.tags,this.metadata,O)}}catch(T){if((Z.raiseError?console.error:console.warn)(`Error in handler ${Z.constructor.name}, handleLLMStart: ${T}`),Z.raiseError)throw T}},Z.awaitHandlers)})),new rz(A,this.handlers,this.inheritableHandlers,this.tags,this.inheritableTags,this.metadata,this.inheritableMetadata,this._parentRunId)}))}async handleChainStart($,q,K=XK(),_=void 0,Y=void 0,j=void 0,P=void 0){return await Promise.all(this.handlers.map((O)=>{if(O.ignoreChain)return;if(Q1(O))O._createRunForChainStart($,q,K,this._parentRunId,this.tags,this.metadata,_,P);return I8(async()=>{try{await O.handleChainStart?.($,q,K,this._parentRunId,this.tags,this.metadata,_,P)}catch(W){if((O.raiseError?console.error:console.warn)(`Error in handler ${O.constructor.name}, handleChainStart: ${W}`),O.raiseError)throw W}},O.awaitHandlers)})),new a0(K,this.handlers,this.inheritableHandlers,this.tags,this.inheritableTags,this.metadata,this.inheritableMetadata,this._parentRunId)}async handleToolStart($,q,K=XK(),_=void 0,Y=void 0,j=void 0,P=void 0){return await Promise.all(this.handlers.map((O)=>{if(O.ignoreAgent)return;if(Q1(O))O._createRunForToolStart($,q,K,this._parentRunId,this.tags,this.metadata,P);return I8(async()=>{try{await O.handleToolStart?.($,q,K,this._parentRunId,this.tags,this.metadata,P)}catch(W){if((O.raiseError?console.error:console.warn)(`Error in handler ${O.constructor.name}, handleToolStart: ${W}`),O.raiseError)throw W}},O.awaitHandlers)})),new t0(K,this.handlers,this.inheritableHandlers,this.tags,this.inheritableTags,this.metadata,this.inheritableMetadata,this._parentRunId)}async handleRetrieverStart($,q,K=XK(),_=void 0,Y=void 0,j=void 0,P=void 0){return await Promise.all(this.handlers.map((O)=>{if(O.ignoreRetriever)return;if(Q1(O))O._createRunForRetrieverStart($,q,K,this._parentRunId,this.tags,this.metadata,P);return I8(async()=>{try{await O.handleRetrieverStart?.($,q,K,this._parentRunId,this.tags,this.metadata,P)}catch(W){if((O.raiseError?console.error:console.warn)(`Error in handler ${O.constructor.name}, handleRetrieverStart: ${W}`),O.raiseError)throw W}},O.awaitHandlers)})),new n0(K,this.handlers,this.inheritableHandlers,this.tags,this.inheritableTags,this.metadata,this.inheritableMetadata,this._parentRunId)}async handleCustomEvent($,q,K,_,Y){await Promise.all(this.handlers.map((j)=>I8(async()=>{if(!j.ignoreCustomEvent)try{await j.handleCustomEvent?.($,q,K,this.tags,this.metadata)}catch(P){if((j.raiseError?console.error:console.warn)(`Error in handler ${j.constructor.name}, handleCustomEvent: ${P}`),j.raiseError)throw P}},j.awaitHandlers)))}addHandler($,q=!0){if(this.handlers.push($),q)this.inheritableHandlers.push($)}removeHandler($){this.handlers=this.handlers.filter((q)=>q!==$),this.inheritableHandlers=this.inheritableHandlers.filter((q)=>q!==$)}setHandlers($,q=!0){this.handlers=[],this.inheritableHandlers=[];for(let K of $)this.addHandler(K,q)}addTags($,q=!0){if(this.removeTags($),this.tags.push(...$),q)this.inheritableTags.push(...$)}removeTags($){this.tags=this.tags.filter((q)=>!$.includes(q)),this.inheritableTags=this.inheritableTags.filter((q)=>!$.includes(q))}addMetadata($,q=!0){if(this.metadata={...this.metadata,...$},q)this.inheritableMetadata={...this.inheritableMetadata,...$}}removeMetadata($){for(let q of Object.keys($))delete this.metadata[q],delete this.inheritableMetadata[q]}copy($=[],q=!0){let K=new bK(this._parentRunId);for(let _ of this.handlers){let Y=this.inheritableHandlers.includes(_);K.addHandler(_,Y)}for(let _ of this.tags){let Y=this.inheritableTags.includes(_);K.addTags([_],Y)}for(let _ of Object.keys(this.metadata)){let Y=Object.keys(this.inheritableMetadata).includes(_);K.addMetadata({[_]:this.metadata[_]},Y)}for(let _ of $){if(K.handlers.filter((Y)=>Y.name==="console_callback_handler").some((Y)=>Y.name===_.name))continue;K.addHandler(_,q)}return K}static fromHandlers($){class q extends T9{constructor(){super();Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:XK()}),Object.assign(this,$)}}let K=new this;return K.addHandler(new q),K}static configure($,q,K,_,Y,j,P){return this._configureSync($,q,K,_,Y,j,P)}static _configureSync($,q,K,_,Y,j,P){let O;if($||q){if(Array.isArray($)||!$)O=new bK,O.setHandlers($?.map(A2)??[],!0);else O=$;O=O.copy(Array.isArray(q)?q.map(A2):q?.handlers,!1)}let W=s4("LANGCHAIN_VERBOSE")==="true"||P?.verbose,X=o1.getTraceableRunTree()?.tracingEnabled||o0(),A=X||(s4("LANGCHAIN_TRACING")??!1);if(W||A){if(!O)O=new bK;if(W&&!O.handlers.some((Z)=>Z.name===F3.prototype.name)){let Z=new F3;O.addHandler(Z,!0)}if(A&&!O.handlers.some((Z)=>Z.name==="langchain_tracer")){if(X){let Z=new o1;O.addHandler(Z,!0),O._parentRunId=o1.getTraceableRunTree()?.id??O._parentRunId}}}for(let{contextVar:Z,inheritable:T=!0,handlerClass:V,envVar:S}of i0()){let R=S&&s4(S)==="true"&&V,E,D=Z!==void 0?iz(Z):void 0;if(D&&u0(D))E=D;else if(R)E=new V({});if(E!==void 0){if(!O)O=new bK;if(!O.handlers.some((h)=>h.name===E.name))O.addHandler(E,T)}}if(K||_){if(O)O.addTags(K??[]),O.addTags(_??[],!1)}if(Y||j){if(O)O.addMetadata(Y??{}),O.addMetadata(j??{},!1)}return O}}function A2($){if("name"in $)return $;return T9.fromMethods($)}class nz{getStore(){return}run($,q){return q()}enterWith($){return}}var rd=new nz,s0=Symbol.for("lc:child_config");class e0{getInstance(){return C_()??rd}getRunnableConfig(){return this.getInstance().getStore()?.extra?.[s0]}runWithConfig($,q,K){let _=bK._configureSync($?.callbacks,void 0,$?.tags,void 0,$?.metadata),Y=this.getInstance(),j=Y.getStore(),P=_?.getParentRunId(),O=_?.handlers?.find((X)=>X?.name==="langchain_tracer"),W;if(O&&P)W=O.getRunTreeWithTracingConfig(P);else if(!K)W=new q6({name:"<runnable_lambda>",tracingEnabled:!1});if(W)W.extra={...W.extra,[s0]:$};if(j!==void 0&&j[k9]!==void 0){if(W===void 0)W={};W[k9]=j[k9]}return Y.run(W,q)}initializeGlobalInstance($){if(C_()===void 0)Q0($)}}var xK=new e0;var i3=25;async function aK($){return bK._configureSync($?.callbacks,void 0,$?.tags,void 0,$?.metadata)}function az(...$){let q={};for(let K of $.filter((_)=>!!_))for(let _ of Object.keys(K))if(_==="metadata")q[_]={...q[_],...K[_]};else if(_==="tags"){let Y=q[_]??[];q[_]=[...new Set(Y.concat(K[_]??[]))]}else if(_==="configurable")q[_]={...q[_],...K[_]};else if(_==="timeout"){if(q.timeout===void 0)q.timeout=K.timeout;else if(K.timeout!==void 0)q.timeout=Math.min(q.timeout,K.timeout)}else if(_==="signal"){if(q.signal===void 0)q.signal=K.signal;else if(K.signal!==void 0)if("any"in AbortSignal)q.signal=AbortSignal.any([q.signal,K.signal]);else q.signal=K.signal}else if(_==="callbacks"){let Y=q.callbacks,j=K.callbacks;if(Array.isArray(j))if(!Y)q.callbacks=j;else if(Array.isArray(Y))q.callbacks=Y.concat(j);else{let P=Y.copy();for(let O of j)P.addHandler(A2(O),!0);q.callbacks=P}else if(j)if(!Y)q.callbacks=j;else if(Array.isArray(Y)){let P=j.copy();for(let O of Y)P.addHandler(A2(O),!0);q.callbacks=P}else q.callbacks=new bK(j._parentRunId,{handlers:Y.handlers.concat(j.handlers),inheritableHandlers:Y.inheritableHandlers.concat(j.inheritableHandlers),tags:Array.from(new Set(Y.tags.concat(j.tags))),inheritableTags:Array.from(new Set(Y.inheritableTags.concat(j.inheritableTags))),metadata:{...Y.metadata,...j.metadata}})}else{let Y=_;q[Y]=K[Y]??q[Y]}return q}var nd=new Set(["string","number","boolean"]);function eq($){let q=xK.getRunnableConfig(),K={tags:[],metadata:{},recursionLimit:25,runId:void 0};if(q){let{runId:_,runName:Y,...j}=q;K=Object.entries(j).reduce((P,[O,W])=>{if(W!==void 0)P[O]=W;return P},K)}if($)K=Object.entries($).reduce((_,[Y,j])=>{if(j!==void 0)_[Y]=j;return _},K);if(K?.configurable){for(let _ of Object.keys(K.configurable))if(nd.has(typeof K.configurable[_])&&!K.metadata?.[_]){if(!K.metadata)K.metadata={};K.metadata[_]=K.configurable[_]}}if(K.timeout!==void 0){if(K.timeout<=0)throw new Error("Timeout must be a positive number");let _=AbortSignal.timeout(K.timeout);if(K.signal!==void 0){if("any"in AbortSignal)K.signal=AbortSignal.any([K.signal,_])}else K.signal=_;delete K.timeout}return K}function k6($={},{callbacks:q,maxConcurrency:K,recursionLimit:_,runName:Y,configurable:j,runId:P}={}){let O=eq($);if(q!==void 0)delete O.runName,O.callbacks=q;if(_!==void 0)O.recursionLimit=_;if(K!==void 0)O.maxConcurrency=K;if(Y!==void 0)O.runName=Y;if(j!==void 0)O.configurable={...O.configurable,...j};if(P!==void 0)delete O.runId;return O}function x7($){return $?{configurable:$.configurable,recursionLimit:$.recursionLimit,callbacks:$.callbacks,tags:$.tags,metadata:$.metadata,maxConcurrency:$.maxConcurrency,timeout:$.timeout,signal:$.signal}:void 0}async function $7($,q){if(q===void 0)return $;let K;return Promise.race([$.catch((_)=>{if(!q?.aborted)throw _;else return}),new Promise((_,Y)=>{if(K=()=>{Y(new Error("Aborted"))},q.addEventListener("abort",K),q.aborted)Y(new Error("Aborted"))})]).finally(()=>q.removeEventListener("abort",K))}class v6 extends ReadableStream{constructor(){super(...arguments);Object.defineProperty(this,"reader",{enumerable:!0,configurable:!0,writable:!0,value:void 0})}ensureReader(){if(!this.reader)this.reader=this.getReader()}async next(){this.ensureReader();try{let $=await this.reader.read();if($.done)return this.reader.releaseLock(),{done:!0,value:void 0};else return{done:!1,value:$.value}}catch($){throw this.reader.releaseLock(),$}}async return(){if(this.ensureReader(),this.locked){let $=this.reader.cancel();this.reader.releaseLock(),await $}return{done:!0,value:void 0}}async throw($){if(this.ensureReader(),this.locked){let q=this.reader.cancel();this.reader.releaseLock(),await q}throw $}[Symbol.asyncIterator](){return this}async[Symbol.asyncDispose](){await this.return()}static fromReadableStream($){let q=$.getReader();return new v6({start(K){return _();function _(){return q.read().then(({done:Y,value:j})=>{if(Y){K.close();return}return K.enqueue(j),_()})}},cancel(){q.releaseLock()}})}static fromAsyncGenerator($){return new v6({async pull(q){let{value:K,done:_}=await $.next();if(_)q.close();q.enqueue(K)},async cancel(q){await $.return(q)}})}}function tz($,q=2){let K=Array.from({length:q},()=>[]);return K.map(async function*_(Y){while(!0)if(Y.length===0){let j=await $.next();for(let P of K)P.push(j)}else if(Y[0].done)return;else yield Y.shift().value})}function sz($,q){if(Array.isArray($)&&Array.isArray(q))return $.concat(q);else if(typeof $==="string"&&typeof q==="string")return $+q;else if(typeof $==="number"&&typeof q==="number")return $+q;else if("concat"in $&&typeof $.concat==="function")return $.concat(q);else if(typeof $==="object"&&typeof q==="object"){let K={...$};for(let[_,Y]of Object.entries(q))if(_ in K&&!Array.isArray(K[_]))K[_]=sz(K[_],Y);else K[_]=Y;return K}else throw new Error(`Cannot concat ${typeof $} and ${typeof q}`)}class S_{constructor($){Object.defineProperty(this,"generator",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"setup",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"config",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"signal",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"firstResult",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"firstResultUsed",{enumerable:!0,configurable:!0,writable:!0,value:!1}),this.generator=$.generator,this.config=$.config,this.signal=$.signal??this.config?.signal,this.setup=new Promise((q,K)=>{xK.runWithConfig(x7($.config),async()=>{if(this.firstResult=$.generator.next(),$.startSetup)this.firstResult.then($.startSetup).then(q,K);else this.firstResult.then((_)=>q(void 0),K)},!0)})}async next(...$){if(this.signal?.throwIfAborted(),!this.firstResultUsed)return this.firstResultUsed=!0,this.firstResult;return xK.runWithConfig(x7(this.config),this.signal?async()=>{return $7(this.generator.next(...$),this.signal)}:async()=>{return this.generator.next(...$)},!0)}async return($){return this.generator.return($)}async throw($){return this.generator.throw($)}[Symbol.asyncIterator](){return this}async[Symbol.asyncDispose](){await this.return()}}async function $M($,q,K,_,...Y){let j=new S_({generator:q,startSetup:K,signal:_}),P=await j.setup;return{output:$(j,P,...Y),setup:P}}class q7{constructor($){Object.defineProperty(this,"ops",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.ops=$.ops??[]}concat($){let q=this.ops.concat($.ops),K=Z9({},q);return new i1({ops:q,state:K[K.length-1].newDocument})}}class i1 extends q7{constructor($){super($);Object.defineProperty(this,"state",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.state=$.state}concat($){let q=this.ops.concat($.ops),K=Z9(this.state,$.ops);return new i1({ops:q,state:K[K.length-1].newDocument})}static fromRunLogPatch($){let q=Z9({},$.ops);return new i1({ops:$.ops,state:q[q.length-1].newDocument})}}var _M=($)=>$.name==="log_stream_tracer";async function qM($,q){if(q==="original")throw new Error("Do not assign inputs with original schema drop the key for now. When inputs are added to streamLog they should be added with standardized schema for streaming events.");let{inputs:K}=$;if(["retriever","llm","prompt"].includes($.run_type))return K;if(Object.keys(K).length===1&&K?.input==="")return;return K.input}async function KM($,q){let{outputs:K}=$;if(q==="original")return K;if(["retriever","llm","prompt"].includes($.run_type))return K;if(K!==void 0&&Object.keys(K).length===1&&K?.output!==void 0)return K.output;return K}function ad($){return $!==void 0&&$.message!==void 0}class r3 extends C4{constructor($){super({_awaitHandler:!0,...$});Object.defineProperty(this,"autoClose",{enumerable:!0,configurable:!0,writable:!0,value:!0}),Object.defineProperty(this,"includeNames",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"includeTypes",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"includeTags",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeNames",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeTypes",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeTags",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"_schemaFormat",{enumerable:!0,configurable:!0,writable:!0,value:"original"}),Object.defineProperty(this,"rootId",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"keyMapByRunId",{enumerable:!0,configurable:!0,writable:!0,value:{}}),Object.defineProperty(this,"counterMapByRunName",{enumerable:!0,configurable:!0,writable:!0,value:{}}),Object.defineProperty(this,"transformStream",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"writer",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"receiveStream",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"log_stream_tracer"}),Object.defineProperty(this,"lc_prefer_streaming",{enumerable:!0,configurable:!0,writable:!0,value:!0}),this.autoClose=$?.autoClose??!0,this.includeNames=$?.includeNames,this.includeTypes=$?.includeTypes,this.includeTags=$?.includeTags,this.excludeNames=$?.excludeNames,this.excludeTypes=$?.excludeTypes,this.excludeTags=$?.excludeTags,this._schemaFormat=$?._schemaFormat??this._schemaFormat,this.transformStream=new TransformStream,this.writer=this.transformStream.writable.getWriter(),this.receiveStream=v6.fromReadableStream(this.transformStream.readable)}[Symbol.asyncIterator](){return this.receiveStream}async persistRun($){}_includeRun($){if($.id===this.rootId)return!1;let q=$.tags??[],K=this.includeNames===void 0&&this.includeTags===void 0&&this.includeTypes===void 0;if(this.includeNames!==void 0)K=K||this.includeNames.includes($.name);if(this.includeTypes!==void 0)K=K||this.includeTypes.includes($.run_type);if(this.includeTags!==void 0)K=K||q.find((_)=>this.includeTags?.includes(_))!==void 0;if(this.excludeNames!==void 0)K=K&&!this.excludeNames.includes($.name);if(this.excludeTypes!==void 0)K=K&&!this.excludeTypes.includes($.run_type);if(this.excludeTags!==void 0)K=K&&q.every((_)=>!this.excludeTags?.includes(_));return K}async*tapOutputIterable($,q){for await(let K of q){if($!==this.rootId){let _=this.keyMapByRunId[$];if(_)await this.writer.write(new q7({ops:[{op:"add",path:`/logs/${_}/streamed_output/-`,value:K}]}))}yield K}}async onRunCreate($){if(this.rootId===void 0)this.rootId=$.id,await this.writer.write(new q7({ops:[{op:"replace",path:"",value:{id:$.id,name:$.name,type:$.run_type,streamed_output:[],final_output:void 0,logs:{}}}]}));if(!this._includeRun($))return;if(this.counterMapByRunName[$.name]===void 0)this.counterMapByRunName[$.name]=0;this.counterMapByRunName[$.name]+=1;let q=this.counterMapByRunName[$.name];this.keyMapByRunId[$.id]=q===1?$.name:`${$.name}:${q}`;let K={id:$.id,name:$.name,type:$.run_type,tags:$.tags??[],metadata:$.extra?.metadata??{},start_time:new Date($.start_time).toISOString(),streamed_output:[],streamed_output_str:[],final_output:void 0,end_time:void 0};if(this._schemaFormat==="streaming_events")K.inputs=await qM($,this._schemaFormat);await this.writer.write(new q7({ops:[{op:"add",path:`/logs/${this.keyMapByRunId[$.id]}`,value:K}]}))}async onRunUpdate($){try{let q=this.keyMapByRunId[$.id];if(q===void 0)return;let K=[];if(this._schemaFormat==="streaming_events")K.push({op:"replace",path:`/logs/${q}/inputs`,value:await qM($,this._schemaFormat)});if(K.push({op:"add",path:`/logs/${q}/final_output`,value:await KM($,this._schemaFormat)}),$.end_time!==void 0)K.push({op:"add",path:`/logs/${q}/end_time`,value:new Date($.end_time).toISOString()});let _=new q7({ops:K});await this.writer.write(_)}finally{if($.id===this.rootId){let q=new q7({ops:[{op:"replace",path:"/final_output",value:await KM($,this._schemaFormat)}]});if(await this.writer.write(q),this.autoClose)await this.writer.close()}}}async onLLMNewToken($,q,K){let _=this.keyMapByRunId[$.id];if(_===void 0)return;let Y=$.inputs.messages!==void 0,j;if(Y)if(ad(K?.chunk))j=K?.chunk;else j=new f9({id:`run-${$.id}`,content:q});else j=q;let P=new q7({ops:[{op:"add",path:`/logs/${_}/streamed_output_str/-`,value:q},{op:"add",path:`/logs/${_}/streamed_output/-`,value:j}]});await this.writer.write(P)}}class k2{constructor($){Object.defineProperty(this,"text",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"generationInfo",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.text=$.text,this.generationInfo=$.generationInfo}concat($){return new k2({text:this.text+$.text,generationInfo:{...this.generationInfo,...$.generationInfo}})}}function n3({name:$,serialized:q}){if($!==void 0)return $;if(q?.name!==void 0)return q.name;else if(q?.id!==void 0&&Array.isArray(q?.id))return q.id[q.id.length-1];return"Unnamed"}var YM=($)=>$.name==="event_stream_tracer";class ez extends C4{constructor($){super({_awaitHandler:!0,...$});Object.defineProperty(this,"autoClose",{enumerable:!0,configurable:!0,writable:!0,value:!0}),Object.defineProperty(this,"includeNames",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"includeTypes",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"includeTags",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeNames",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeTypes",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeTags",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"runInfoMap",{enumerable:!0,configurable:!0,writable:!0,value:new Map}),Object.defineProperty(this,"tappedPromises",{enumerable:!0,configurable:!0,writable:!0,value:new Map}),Object.defineProperty(this,"transformStream",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"writer",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"receiveStream",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"event_stream_tracer"}),Object.defineProperty(this,"lc_prefer_streaming",{enumerable:!0,configurable:!0,writable:!0,value:!0}),this.autoClose=$?.autoClose??!0,this.includeNames=$?.includeNames,this.includeTypes=$?.includeTypes,this.includeTags=$?.includeTags,this.excludeNames=$?.excludeNames,this.excludeTypes=$?.excludeTypes,this.excludeTags=$?.excludeTags,this.transformStream=new TransformStream,this.writer=this.transformStream.writable.getWriter(),this.receiveStream=v6.fromReadableStream(this.transformStream.readable)}[Symbol.asyncIterator](){return this.receiveStream}async persistRun($){}_includeRun($){let q=$.tags??[],K=this.includeNames===void 0&&this.includeTags===void 0&&this.includeTypes===void 0;if(this.includeNames!==void 0)K=K||this.includeNames.includes($.name);if(this.includeTypes!==void 0)K=K||this.includeTypes.includes($.runType);if(this.includeTags!==void 0)K=K||q.find((_)=>this.includeTags?.includes(_))!==void 0;if(this.excludeNames!==void 0)K=K&&!this.excludeNames.includes($.name);if(this.excludeTypes!==void 0)K=K&&!this.excludeTypes.includes($.runType);if(this.excludeTags!==void 0)K=K&&q.every((_)=>!this.excludeTags?.includes(_));return K}async*tapOutputIterable($,q){let K=await q.next();if(K.done)return;let _=this.runInfoMap.get($);if(_===void 0){yield K.value;return}function Y(P,O){if(P==="llm"&&typeof O==="string")return new k2({text:O});return O}let j=this.tappedPromises.get($);if(j===void 0){let P;j=new Promise((O)=>{P=O}),this.tappedPromises.set($,j);try{let O={event:`on_${_.runType}_stream`,run_id:$,name:_.name,tags:_.tags,metadata:_.metadata,data:{}};await this.send({...O,data:{chunk:Y(_.runType,K.value)}},_),yield K.value;for await(let W of q){if(_.runType!=="tool"&&_.runType!=="retriever")await this.send({...O,data:{chunk:Y(_.runType,W)}},_);yield W}}finally{P()}}else{yield K.value;for await(let P of q)yield P}}async send($,q){if(this._includeRun(q))await this.writer.write($)}async sendEndEvent($,q){let K=this.tappedPromises.get($.run_id);if(K!==void 0)K.then(()=>{this.send($,q)});else await this.send($,q)}async onLLMStart($){let q=n3($),K=$.inputs.messages!==void 0?"chat_model":"llm",_={tags:$.tags??[],metadata:$.extra?.metadata??{},name:q,runType:K,inputs:$.inputs};this.runInfoMap.set($.id,_);let Y=`on_${K}_start`;await this.send({event:Y,data:{input:$.inputs},name:q,tags:$.tags??[],run_id:$.id,metadata:$.extra?.metadata??{}},_)}async onLLMNewToken($,q,K){let _=this.runInfoMap.get($.id),Y,j;if(_===void 0)throw new Error(`onLLMNewToken: Run ID ${$.id} not found in run map.`);if(this.runInfoMap.size===1)return;if(_.runType==="chat_model")if(j="on_chat_model_stream",K?.chunk===void 0)Y=new f9({content:q,id:`run-${$.id}`});else Y=K.chunk.message;else if(_.runType==="llm")if(j="on_llm_stream",K?.chunk===void 0)Y=new k2({text:q});else Y=K.chunk;else throw new Error(`Unexpected run type ${_.runType}`);await this.send({event:j,data:{chunk:Y},run_id:$.id,name:_.name,tags:_.tags,metadata:_.metadata},_)}async onLLMEnd($){let q=this.runInfoMap.get($.id);this.runInfoMap.delete($.id);let K;if(q===void 0)throw new Error(`onLLMEnd: Run ID ${$.id} not found in run map.`);let _=$.outputs?.generations,Y;if(q.runType==="chat_model"){for(let j of _??[]){if(Y!==void 0)break;Y=j[0]?.message}K="on_chat_model_end"}else if(q.runType==="llm")Y={generations:_?.map((j)=>{return j.map((P)=>{return{text:P.text,generationInfo:P.generationInfo}})}),llmOutput:$.outputs?.llmOutput??{}},K="on_llm_end";else throw new Error(`onLLMEnd: Unexpected run type: ${q.runType}`);await this.sendEndEvent({event:K,data:{output:Y,input:q.inputs},run_id:$.id,name:q.name,tags:q.tags,metadata:q.metadata},q)}async onChainStart($){let q=n3($),K=$.run_type??"chain",_={tags:$.tags??[],metadata:$.extra?.metadata??{},name:q,runType:$.run_type},Y={};if($.inputs.input===""&&Object.keys($.inputs).length===1)Y={},_.inputs={};else if($.inputs.input!==void 0)Y.input=$.inputs.input,_.inputs=$.inputs.input;else Y.input=$.inputs,_.inputs=$.inputs;this.runInfoMap.set($.id,_),await this.send({event:`on_${K}_start`,data:Y,name:q,tags:$.tags??[],run_id:$.id,metadata:$.extra?.metadata??{}},_)}async onChainEnd($){let q=this.runInfoMap.get($.id);if(this.runInfoMap.delete($.id),q===void 0)throw new Error(`onChainEnd: Run ID ${$.id} not found in run map.`);let K=`on_${$.run_type}_end`,_=$.inputs??q.inputs??{},j={output:$.outputs?.output??$.outputs,input:_};if(_.input&&Object.keys(_).length===1)j.input=_.input,q.inputs=_.input;await this.sendEndEvent({event:K,data:j,run_id:$.id,name:q.name,tags:q.tags,metadata:q.metadata??{}},q)}async onToolStart($){let q=n3($),K={tags:$.tags??[],metadata:$.extra?.metadata??{},name:q,runType:"tool",inputs:$.inputs??{}};this.runInfoMap.set($.id,K),await this.send({event:"on_tool_start",data:{input:$.inputs??{}},name:q,run_id:$.id,tags:$.tags??[],metadata:$.extra?.metadata??{}},K)}async onToolEnd($){let q=this.runInfoMap.get($.id);if(this.runInfoMap.delete($.id),q===void 0)throw new Error(`onToolEnd: Run ID ${$.id} not found in run map.`);if(q.inputs===void 0)throw new Error(`onToolEnd: Run ID ${$.id} is a tool call, and is expected to have traced inputs.`);let K=$.outputs?.output===void 0?$.outputs:$.outputs.output;await this.sendEndEvent({event:"on_tool_end",data:{output:K,input:q.inputs},run_id:$.id,name:q.name,tags:q.tags,metadata:q.metadata},q)}async onRetrieverStart($){let q=n3($),K="retriever",_={tags:$.tags??[],metadata:$.extra?.metadata??{},name:q,runType:"retriever",inputs:{query:$.inputs.query}};this.runInfoMap.set($.id,_),await this.send({event:"on_retriever_start",data:{input:{query:$.inputs.query}},name:q,tags:$.tags??[],run_id:$.id,metadata:$.extra?.metadata??{}},_)}async onRetrieverEnd($){let q=this.runInfoMap.get($.id);if(this.runInfoMap.delete($.id),q===void 0)throw new Error(`onRetrieverEnd: Run ID ${$.id} not found in run map.`);await this.sendEndEvent({event:"on_retriever_end",data:{output:$.outputs?.documents??$.outputs,input:q.inputs},run_id:$.id,name:q.name,tags:q.tags,metadata:q.metadata},q)}async handleCustomEvent($,q,K){let _=this.runInfoMap.get(K);if(_===void 0)throw new Error(`handleCustomEvent: Run ID ${K} not found in run map.`);await this.send({event:"on_custom_event",run_id:K,name:$,tags:_.tags,metadata:_.metadata,data:q},_)}async finish(){let $=[...this.tappedPromises.values()];Promise.all($).finally(()=>{this.writer.close()})}}var PM=HK(Y3(),1),a3=HK(M3(),1),td=[400,401,402,403,404,405,406,407,409],sd=($)=>{if($.message.startsWith("Cancel")||$.message.startsWith("AbortError")||$.name==="AbortError")throw $;if($?.code==="ECONNABORTED")throw $;let q=$?.response?.status??$?.status;if(q&&td.includes(+q))throw $;if($?.error?.code==="insufficient_quota"){let K=new Error($?.message);throw K.name="InsufficientQuotaError",K}};class t3{constructor($){Object.defineProperty(this,"maxConcurrency",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"maxRetries",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"onFailedAttempt",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"queue",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.maxConcurrency=$.maxConcurrency??1/0,this.maxRetries=$.maxRetries??6,this.onFailedAttempt=$.onFailedAttempt??sd;let q="default"in a3.default?a3.default.default:a3.default;this.queue=new q({concurrency:this.maxConcurrency})}call($,...q){return this.queue.add(()=>PM.default(()=>$(...q).catch((K)=>{if(K instanceof Error)throw K;else throw new Error(K)}),{onFailedAttempt:this.onFailedAttempt,retries:this.maxRetries,randomize:!0}),{throwOnTimeout:!0})}callWithOptions($,q,...K){if($.signal)return Promise.race([this.call(q,...K),new Promise((_,Y)=>{$.signal?.addEventListener("abort",()=>{Y(new Error("AbortError"))})})]);return this.call(q,...K)}fetch(...$){return this.call(()=>fetch(...$).then((q)=>q.ok?q:Promise.reject(q)))}}class s3 extends C4{constructor({config:$,onStart:q,onEnd:K,onError:_}){super({_awaitHandler:!0});Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"RootListenersTracer"}),Object.defineProperty(this,"rootId",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"config",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"argOnStart",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"argOnEnd",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"argOnError",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.config=$,this.argOnStart=q,this.argOnEnd=K,this.argOnError=_}persistRun($){return Promise.resolve()}async onRunCreate($){if(this.rootId)return;if(this.rootId=$.id,this.argOnStart)await this.argOnStart($,this.config)}async onRunUpdate($){if($.id!==this.rootId)return;if(!$.error){if(this.argOnEnd)await this.argOnEnd($,this.config)}else if(this.argOnError)await this.argOnError($,this.config)}}function v2($){return $?$.lc_runnable:!1}class $X{constructor($){Object.defineProperty(this,"includeNames",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"includeTypes",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"includeTags",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeNames",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeTypes",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeTags",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.includeNames=$.includeNames,this.includeTypes=$.includeTypes,this.includeTags=$.includeTags,this.excludeNames=$.excludeNames,this.excludeTypes=$.excludeTypes,this.excludeTags=$.excludeTags}includeEvent($,q){let K=this.includeNames===void 0&&this.includeTypes===void 0&&this.includeTags===void 0,_=$.tags??[];if(this.includeNames!==void 0)K=K||this.includeNames.includes($.name);if(this.includeTypes!==void 0)K=K||this.includeTypes.includes(q);if(this.includeTags!==void 0)K=K||_.some((Y)=>this.includeTags?.includes(Y));if(this.excludeNames!==void 0)K=K&&!this.excludeNames.includes($.name);if(this.excludeTypes!==void 0)K=K&&!this.excludeTypes.includes(q);if(this.excludeTags!==void 0)K=K&&_.every((Y)=>!this.excludeTags?.includes(Y));return K}}function qX($){return $.replace(/[^a-zA-Z-_0-9]/g,"_")}var ed=["*","_","`"];function $l($){let q="";for(let[K,_]of Object.entries($))q+=` classDef ${K} ${_};
583
+ `)}var Qz,oz=()=>{if(Qz===void 0){let $=s4("LANGCHAIN_CALLBACKS_BACKGROUND")==="false"?{blockOnRootRunFinalization:!0}:{};Qz=new v_($)}return Qz};class o1 extends C4{constructor($={}){super($);Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"langchain_tracer"}),Object.defineProperty(this,"projectName",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"exampleId",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"client",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"replicas",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"usesRunTreeMap",{enumerable:!0,configurable:!0,writable:!0,value:!0});let{exampleId:q,projectName:K,client:_,replicas:Y}=$;this.projectName=K??j2(),this.replicas=Y,this.exampleId=q,this.client=_??oz();let j=o1.getTraceableRunTree();if(j)this.updateFromRunTree(j)}async persistRun($){}async onRunCreate($){await this.getRunTreeWithTracingConfig($.id)?.postRun()}async onRunUpdate($){await this.getRunTreeWithTracingConfig($.id)?.patchRun()}getRun($){return this.runTreeMap.get($)}updateFromRunTree($){this.runTreeMap.set($.id,$);let q=$,K=new Set;while(q.parent_run){if(K.has(q.id))break;if(K.add(q.id),!q.parent_run)break;q=q.parent_run}K.clear();let _=[q];while(_.length>0){let Y=_.shift();if(!Y||K.has(Y.id))continue;if(K.add(Y.id),this.runTreeMap.set(Y.id,Y),Y.child_runs)_.push(...Y.child_runs)}this.client=$.client??this.client,this.replicas=$.replicas??this.replicas,this.projectName=$.project_name??this.projectName,this.exampleId=$.reference_example_id??this.exampleId}getRunTreeWithTracingConfig($){let q=this.runTreeMap.get($);if(!q)return;return new q6({...q,client:this.client,project_name:this.projectName,replicas:this.replicas,reference_example_id:this.exampleId,tracingEnabled:!0})}static getTraceableRunTree(){try{return Pk(!0)}catch{return}}}var o3=HK(M3(),1);var F0=Symbol.for("ls:tracing_async_local_storage"),k9=Symbol.for("lc:context_variables"),Q0=($)=>{globalThis[F0]=$},C_=()=>{return globalThis[F0]};var T2;function Qd(){return new("default"in o3.default?o3.default.default:o3.default)({autoStart:!0,concurrency:1})}function od(){if(typeof T2==="undefined")T2=Qd();return T2}async function I8($,q){if(q===!0){let K=C_();if(K!==void 0)await K.run(void 0,async()=>$());else await $()}else T2=od(),T2.add(async()=>{let K=C_();if(K!==void 0)await K.run(void 0,async()=>$());else await $()})}var o0=($)=>{if($!==void 0)return $;return!!["LANGSMITH_TRACING_V2","LANGCHAIN_TRACING_V2","LANGSMITH_TRACING","LANGCHAIN_TRACING"].find((K)=>s4(K)==="true")};function iz($){let q=C_();if(q===void 0)return;return q.getStore()?.[k9]?.[$]}var id=Symbol("lc:configure_hooks"),i0=()=>iz(id)||[];class r0{setHandler($){return this.setHandlers([$])}}class f2{constructor($,q,K,_,Y,j,P,O){Object.defineProperty(this,"runId",{enumerable:!0,configurable:!0,writable:!0,value:$}),Object.defineProperty(this,"handlers",{enumerable:!0,configurable:!0,writable:!0,value:q}),Object.defineProperty(this,"inheritableHandlers",{enumerable:!0,configurable:!0,writable:!0,value:K}),Object.defineProperty(this,"tags",{enumerable:!0,configurable:!0,writable:!0,value:_}),Object.defineProperty(this,"inheritableTags",{enumerable:!0,configurable:!0,writable:!0,value:Y}),Object.defineProperty(this,"metadata",{enumerable:!0,configurable:!0,writable:!0,value:j}),Object.defineProperty(this,"inheritableMetadata",{enumerable:!0,configurable:!0,writable:!0,value:P}),Object.defineProperty(this,"_parentRunId",{enumerable:!0,configurable:!0,writable:!0,value:O})}get parentRunId(){return this._parentRunId}async handleText($){await Promise.all(this.handlers.map((q)=>I8(async()=>{try{await q.handleText?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleText: ${K}`),q.raiseError)throw K}},q.awaitHandlers)))}async handleCustomEvent($,q,K,_,Y){await Promise.all(this.handlers.map((j)=>I8(async()=>{try{await j.handleCustomEvent?.($,q,this.runId,this.tags,this.metadata)}catch(P){if((j.raiseError?console.error:console.warn)(`Error in handler ${j.constructor.name}, handleCustomEvent: ${P}`),j.raiseError)throw P}},j.awaitHandlers)))}}class n0 extends f2{getChild($){let q=new bK(this.runId);if(q.setHandlers(this.inheritableHandlers),q.addTags(this.inheritableTags),q.addMetadata(this.inheritableMetadata),$)q.addTags([$],!1);return q}async handleRetrieverEnd($){await Promise.all(this.handlers.map((q)=>I8(async()=>{if(!q.ignoreRetriever)try{await q.handleRetrieverEnd?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleRetriever`),q.raiseError)throw K}},q.awaitHandlers)))}async handleRetrieverError($){await Promise.all(this.handlers.map((q)=>I8(async()=>{if(!q.ignoreRetriever)try{await q.handleRetrieverError?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleRetrieverError: ${K}`),q.raiseError)throw $}},q.awaitHandlers)))}}class rz extends f2{async handleLLMNewToken($,q,K,_,Y,j){await Promise.all(this.handlers.map((P)=>I8(async()=>{if(!P.ignoreLLM)try{await P.handleLLMNewToken?.($,q??{prompt:0,completion:0},this.runId,this._parentRunId,this.tags,j)}catch(O){if((P.raiseError?console.error:console.warn)(`Error in handler ${P.constructor.name}, handleLLMNewToken: ${O}`),P.raiseError)throw O}},P.awaitHandlers)))}async handleLLMError($,q,K,_,Y){await Promise.all(this.handlers.map((j)=>I8(async()=>{if(!j.ignoreLLM)try{await j.handleLLMError?.($,this.runId,this._parentRunId,this.tags,Y)}catch(P){if((j.raiseError?console.error:console.warn)(`Error in handler ${j.constructor.name}, handleLLMError: ${P}`),j.raiseError)throw P}},j.awaitHandlers)))}async handleLLMEnd($,q,K,_,Y){await Promise.all(this.handlers.map((j)=>I8(async()=>{if(!j.ignoreLLM)try{await j.handleLLMEnd?.($,this.runId,this._parentRunId,this.tags,Y)}catch(P){if((j.raiseError?console.error:console.warn)(`Error in handler ${j.constructor.name}, handleLLMEnd: ${P}`),j.raiseError)throw P}},j.awaitHandlers)))}}class a0 extends f2{getChild($){let q=new bK(this.runId);if(q.setHandlers(this.inheritableHandlers),q.addTags(this.inheritableTags),q.addMetadata(this.inheritableMetadata),$)q.addTags([$],!1);return q}async handleChainError($,q,K,_,Y){await Promise.all(this.handlers.map((j)=>I8(async()=>{if(!j.ignoreChain)try{await j.handleChainError?.($,this.runId,this._parentRunId,this.tags,Y)}catch(P){if((j.raiseError?console.error:console.warn)(`Error in handler ${j.constructor.name}, handleChainError: ${P}`),j.raiseError)throw P}},j.awaitHandlers)))}async handleChainEnd($,q,K,_,Y){await Promise.all(this.handlers.map((j)=>I8(async()=>{if(!j.ignoreChain)try{await j.handleChainEnd?.($,this.runId,this._parentRunId,this.tags,Y)}catch(P){if((j.raiseError?console.error:console.warn)(`Error in handler ${j.constructor.name}, handleChainEnd: ${P}`),j.raiseError)throw P}},j.awaitHandlers)))}async handleAgentAction($){await Promise.all(this.handlers.map((q)=>I8(async()=>{if(!q.ignoreAgent)try{await q.handleAgentAction?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleAgentAction: ${K}`),q.raiseError)throw K}},q.awaitHandlers)))}async handleAgentEnd($){await Promise.all(this.handlers.map((q)=>I8(async()=>{if(!q.ignoreAgent)try{await q.handleAgentEnd?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleAgentEnd: ${K}`),q.raiseError)throw K}},q.awaitHandlers)))}}class t0 extends f2{getChild($){let q=new bK(this.runId);if(q.setHandlers(this.inheritableHandlers),q.addTags(this.inheritableTags),q.addMetadata(this.inheritableMetadata),$)q.addTags([$],!1);return q}async handleToolError($){await Promise.all(this.handlers.map((q)=>I8(async()=>{if(!q.ignoreAgent)try{await q.handleToolError?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleToolError: ${K}`),q.raiseError)throw K}},q.awaitHandlers)))}async handleToolEnd($){await Promise.all(this.handlers.map((q)=>I8(async()=>{if(!q.ignoreAgent)try{await q.handleToolEnd?.($,this.runId,this._parentRunId,this.tags)}catch(K){if((q.raiseError?console.error:console.warn)(`Error in handler ${q.constructor.name}, handleToolEnd: ${K}`),q.raiseError)throw K}},q.awaitHandlers)))}}class bK extends r0{constructor($,q){super();Object.defineProperty(this,"handlers",{enumerable:!0,configurable:!0,writable:!0,value:[]}),Object.defineProperty(this,"inheritableHandlers",{enumerable:!0,configurable:!0,writable:!0,value:[]}),Object.defineProperty(this,"tags",{enumerable:!0,configurable:!0,writable:!0,value:[]}),Object.defineProperty(this,"inheritableTags",{enumerable:!0,configurable:!0,writable:!0,value:[]}),Object.defineProperty(this,"metadata",{enumerable:!0,configurable:!0,writable:!0,value:{}}),Object.defineProperty(this,"inheritableMetadata",{enumerable:!0,configurable:!0,writable:!0,value:{}}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"callback_manager"}),Object.defineProperty(this,"_parentRunId",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.handlers=q?.handlers??this.handlers,this.inheritableHandlers=q?.inheritableHandlers??this.inheritableHandlers,this.tags=q?.tags??this.tags,this.inheritableTags=q?.inheritableTags??this.inheritableTags,this.metadata=q?.metadata??this.metadata,this.inheritableMetadata=q?.inheritableMetadata??this.inheritableMetadata,this._parentRunId=$}getParentRunId(){return this._parentRunId}async handleLLMStart($,q,K=void 0,_=void 0,Y=void 0,j=void 0,P=void 0,O=void 0){return Promise.all(q.map(async(W,X)=>{let A=X===0&&K?K:XK();return await Promise.all(this.handlers.map((Z)=>{if(Z.ignoreLLM)return;if(Q1(Z))Z._createRunForLLMStart($,[W],A,this._parentRunId,Y,this.tags,this.metadata,O);return I8(async()=>{try{await Z.handleLLMStart?.($,[W],A,this._parentRunId,Y,this.tags,this.metadata,O)}catch(T){if((Z.raiseError?console.error:console.warn)(`Error in handler ${Z.constructor.name}, handleLLMStart: ${T}`),Z.raiseError)throw T}},Z.awaitHandlers)})),new rz(A,this.handlers,this.inheritableHandlers,this.tags,this.inheritableTags,this.metadata,this.inheritableMetadata,this._parentRunId)}))}async handleChatModelStart($,q,K=void 0,_=void 0,Y=void 0,j=void 0,P=void 0,O=void 0){return Promise.all(q.map(async(W,X)=>{let A=X===0&&K?K:XK();return await Promise.all(this.handlers.map((Z)=>{if(Z.ignoreLLM)return;if(Q1(Z))Z._createRunForChatModelStart($,[W],A,this._parentRunId,Y,this.tags,this.metadata,O);return I8(async()=>{try{if(Z.handleChatModelStart)await Z.handleChatModelStart?.($,[W],A,this._parentRunId,Y,this.tags,this.metadata,O);else if(Z.handleLLMStart){let T=U0(W);await Z.handleLLMStart?.($,[T],A,this._parentRunId,Y,this.tags,this.metadata,O)}}catch(T){if((Z.raiseError?console.error:console.warn)(`Error in handler ${Z.constructor.name}, handleLLMStart: ${T}`),Z.raiseError)throw T}},Z.awaitHandlers)})),new rz(A,this.handlers,this.inheritableHandlers,this.tags,this.inheritableTags,this.metadata,this.inheritableMetadata,this._parentRunId)}))}async handleChainStart($,q,K=XK(),_=void 0,Y=void 0,j=void 0,P=void 0){return await Promise.all(this.handlers.map((O)=>{if(O.ignoreChain)return;if(Q1(O))O._createRunForChainStart($,q,K,this._parentRunId,this.tags,this.metadata,_,P);return I8(async()=>{try{await O.handleChainStart?.($,q,K,this._parentRunId,this.tags,this.metadata,_,P)}catch(W){if((O.raiseError?console.error:console.warn)(`Error in handler ${O.constructor.name}, handleChainStart: ${W}`),O.raiseError)throw W}},O.awaitHandlers)})),new a0(K,this.handlers,this.inheritableHandlers,this.tags,this.inheritableTags,this.metadata,this.inheritableMetadata,this._parentRunId)}async handleToolStart($,q,K=XK(),_=void 0,Y=void 0,j=void 0,P=void 0){return await Promise.all(this.handlers.map((O)=>{if(O.ignoreAgent)return;if(Q1(O))O._createRunForToolStart($,q,K,this._parentRunId,this.tags,this.metadata,P);return I8(async()=>{try{await O.handleToolStart?.($,q,K,this._parentRunId,this.tags,this.metadata,P)}catch(W){if((O.raiseError?console.error:console.warn)(`Error in handler ${O.constructor.name}, handleToolStart: ${W}`),O.raiseError)throw W}},O.awaitHandlers)})),new t0(K,this.handlers,this.inheritableHandlers,this.tags,this.inheritableTags,this.metadata,this.inheritableMetadata,this._parentRunId)}async handleRetrieverStart($,q,K=XK(),_=void 0,Y=void 0,j=void 0,P=void 0){return await Promise.all(this.handlers.map((O)=>{if(O.ignoreRetriever)return;if(Q1(O))O._createRunForRetrieverStart($,q,K,this._parentRunId,this.tags,this.metadata,P);return I8(async()=>{try{await O.handleRetrieverStart?.($,q,K,this._parentRunId,this.tags,this.metadata,P)}catch(W){if((O.raiseError?console.error:console.warn)(`Error in handler ${O.constructor.name}, handleRetrieverStart: ${W}`),O.raiseError)throw W}},O.awaitHandlers)})),new n0(K,this.handlers,this.inheritableHandlers,this.tags,this.inheritableTags,this.metadata,this.inheritableMetadata,this._parentRunId)}async handleCustomEvent($,q,K,_,Y){await Promise.all(this.handlers.map((j)=>I8(async()=>{if(!j.ignoreCustomEvent)try{await j.handleCustomEvent?.($,q,K,this.tags,this.metadata)}catch(P){if((j.raiseError?console.error:console.warn)(`Error in handler ${j.constructor.name}, handleCustomEvent: ${P}`),j.raiseError)throw P}},j.awaitHandlers)))}addHandler($,q=!0){if(this.handlers.push($),q)this.inheritableHandlers.push($)}removeHandler($){this.handlers=this.handlers.filter((q)=>q!==$),this.inheritableHandlers=this.inheritableHandlers.filter((q)=>q!==$)}setHandlers($,q=!0){this.handlers=[],this.inheritableHandlers=[];for(let K of $)this.addHandler(K,q)}addTags($,q=!0){if(this.removeTags($),this.tags.push(...$),q)this.inheritableTags.push(...$)}removeTags($){this.tags=this.tags.filter((q)=>!$.includes(q)),this.inheritableTags=this.inheritableTags.filter((q)=>!$.includes(q))}addMetadata($,q=!0){if(this.metadata={...this.metadata,...$},q)this.inheritableMetadata={...this.inheritableMetadata,...$}}removeMetadata($){for(let q of Object.keys($))delete this.metadata[q],delete this.inheritableMetadata[q]}copy($=[],q=!0){let K=new bK(this._parentRunId);for(let _ of this.handlers){let Y=this.inheritableHandlers.includes(_);K.addHandler(_,Y)}for(let _ of this.tags){let Y=this.inheritableTags.includes(_);K.addTags([_],Y)}for(let _ of Object.keys(this.metadata)){let Y=Object.keys(this.inheritableMetadata).includes(_);K.addMetadata({[_]:this.metadata[_]},Y)}for(let _ of $){if(K.handlers.filter((Y)=>Y.name==="console_callback_handler").some((Y)=>Y.name===_.name))continue;K.addHandler(_,q)}return K}static fromHandlers($){class q extends T9{constructor(){super();Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:XK()}),Object.assign(this,$)}}let K=new this;return K.addHandler(new q),K}static configure($,q,K,_,Y,j,P){return this._configureSync($,q,K,_,Y,j,P)}static _configureSync($,q,K,_,Y,j,P){let O;if($||q){if(Array.isArray($)||!$)O=new bK,O.setHandlers($?.map(A2)??[],!0);else O=$;O=O.copy(Array.isArray(q)?q.map(A2):q?.handlers,!1)}let W=s4("LANGCHAIN_VERBOSE")==="true"||P?.verbose,X=o1.getTraceableRunTree()?.tracingEnabled||o0(),A=X||(s4("LANGCHAIN_TRACING")??!1);if(W||A){if(!O)O=new bK;if(W&&!O.handlers.some((Z)=>Z.name===F3.prototype.name)){let Z=new F3;O.addHandler(Z,!0)}if(A&&!O.handlers.some((Z)=>Z.name==="langchain_tracer")){if(X){let Z=new o1;O.addHandler(Z,!0)}}if(X)O._parentRunId=o1.getTraceableRunTree()?.id??O._parentRunId}for(let{contextVar:Z,inheritable:T=!0,handlerClass:V,envVar:S}of i0()){let R=S&&s4(S)==="true"&&V,E,D=Z!==void 0?iz(Z):void 0;if(D&&u0(D))E=D;else if(R)E=new V({});if(E!==void 0){if(!O)O=new bK;if(!O.handlers.some((h)=>h.name===E.name))O.addHandler(E,T)}}if(K||_){if(O)O.addTags(K??[]),O.addTags(_??[],!1)}if(Y||j){if(O)O.addMetadata(Y??{}),O.addMetadata(j??{},!1)}return O}}function A2($){if("name"in $)return $;return T9.fromMethods($)}class nz{getStore(){return}run($,q){return q()}enterWith($){return}}var rd=new nz,s0=Symbol.for("lc:child_config");class e0{getInstance(){return C_()??rd}getRunnableConfig(){return this.getInstance().getStore()?.extra?.[s0]}runWithConfig($,q,K){let _=bK._configureSync($?.callbacks,void 0,$?.tags,void 0,$?.metadata),Y=this.getInstance(),j=Y.getStore(),P=_?.getParentRunId(),O=_?.handlers?.find((X)=>X?.name==="langchain_tracer"),W;if(O&&P)W=O.getRunTreeWithTracingConfig(P);else if(!K)W=new q6({name:"<runnable_lambda>",tracingEnabled:!1});if(W)W.extra={...W.extra,[s0]:$};if(j!==void 0&&j[k9]!==void 0){if(W===void 0)W={};W[k9]=j[k9]}return Y.run(W,q)}initializeGlobalInstance($){if(C_()===void 0)Q0($)}}var xK=new e0;var i3=25;async function aK($){return bK._configureSync($?.callbacks,void 0,$?.tags,void 0,$?.metadata)}function az(...$){let q={};for(let K of $.filter((_)=>!!_))for(let _ of Object.keys(K))if(_==="metadata")q[_]={...q[_],...K[_]};else if(_==="tags"){let Y=q[_]??[];q[_]=[...new Set(Y.concat(K[_]??[]))]}else if(_==="configurable")q[_]={...q[_],...K[_]};else if(_==="timeout"){if(q.timeout===void 0)q.timeout=K.timeout;else if(K.timeout!==void 0)q.timeout=Math.min(q.timeout,K.timeout)}else if(_==="signal"){if(q.signal===void 0)q.signal=K.signal;else if(K.signal!==void 0)if("any"in AbortSignal)q.signal=AbortSignal.any([q.signal,K.signal]);else q.signal=K.signal}else if(_==="callbacks"){let Y=q.callbacks,j=K.callbacks;if(Array.isArray(j))if(!Y)q.callbacks=j;else if(Array.isArray(Y))q.callbacks=Y.concat(j);else{let P=Y.copy();for(let O of j)P.addHandler(A2(O),!0);q.callbacks=P}else if(j)if(!Y)q.callbacks=j;else if(Array.isArray(Y)){let P=j.copy();for(let O of Y)P.addHandler(A2(O),!0);q.callbacks=P}else q.callbacks=new bK(j._parentRunId,{handlers:Y.handlers.concat(j.handlers),inheritableHandlers:Y.inheritableHandlers.concat(j.inheritableHandlers),tags:Array.from(new Set(Y.tags.concat(j.tags))),inheritableTags:Array.from(new Set(Y.inheritableTags.concat(j.inheritableTags))),metadata:{...Y.metadata,...j.metadata}})}else{let Y=_;q[Y]=K[Y]??q[Y]}return q}var nd=new Set(["string","number","boolean"]);function eq($){let q=xK.getRunnableConfig(),K={tags:[],metadata:{},recursionLimit:25,runId:void 0};if(q){let{runId:_,runName:Y,...j}=q;K=Object.entries(j).reduce((P,[O,W])=>{if(W!==void 0)P[O]=W;return P},K)}if($)K=Object.entries($).reduce((_,[Y,j])=>{if(j!==void 0)_[Y]=j;return _},K);if(K?.configurable){for(let _ of Object.keys(K.configurable))if(nd.has(typeof K.configurable[_])&&!K.metadata?.[_]){if(!K.metadata)K.metadata={};K.metadata[_]=K.configurable[_]}}if(K.timeout!==void 0){if(K.timeout<=0)throw new Error("Timeout must be a positive number");let _=AbortSignal.timeout(K.timeout);if(K.signal!==void 0){if("any"in AbortSignal)K.signal=AbortSignal.any([K.signal,_])}else K.signal=_;delete K.timeout}return K}function k6($={},{callbacks:q,maxConcurrency:K,recursionLimit:_,runName:Y,configurable:j,runId:P}={}){let O=eq($);if(q!==void 0)delete O.runName,O.callbacks=q;if(_!==void 0)O.recursionLimit=_;if(K!==void 0)O.maxConcurrency=K;if(Y!==void 0)O.runName=Y;if(j!==void 0)O.configurable={...O.configurable,...j};if(P!==void 0)delete O.runId;return O}function x7($){return $?{configurable:$.configurable,recursionLimit:$.recursionLimit,callbacks:$.callbacks,tags:$.tags,metadata:$.metadata,maxConcurrency:$.maxConcurrency,timeout:$.timeout,signal:$.signal}:void 0}async function $7($,q){if(q===void 0)return $;let K;return Promise.race([$.catch((_)=>{if(!q?.aborted)throw _;else return}),new Promise((_,Y)=>{if(K=()=>{Y(new Error("Aborted"))},q.addEventListener("abort",K),q.aborted)Y(new Error("Aborted"))})]).finally(()=>q.removeEventListener("abort",K))}class v6 extends ReadableStream{constructor(){super(...arguments);Object.defineProperty(this,"reader",{enumerable:!0,configurable:!0,writable:!0,value:void 0})}ensureReader(){if(!this.reader)this.reader=this.getReader()}async next(){this.ensureReader();try{let $=await this.reader.read();if($.done)return this.reader.releaseLock(),{done:!0,value:void 0};else return{done:!1,value:$.value}}catch($){throw this.reader.releaseLock(),$}}async return(){if(this.ensureReader(),this.locked){let $=this.reader.cancel();this.reader.releaseLock(),await $}return{done:!0,value:void 0}}async throw($){if(this.ensureReader(),this.locked){let q=this.reader.cancel();this.reader.releaseLock(),await q}throw $}[Symbol.asyncIterator](){return this}async[Symbol.asyncDispose](){await this.return()}static fromReadableStream($){let q=$.getReader();return new v6({start(K){return _();function _(){return q.read().then(({done:Y,value:j})=>{if(Y){K.close();return}return K.enqueue(j),_()})}},cancel(){q.releaseLock()}})}static fromAsyncGenerator($){return new v6({async pull(q){let{value:K,done:_}=await $.next();if(_)q.close();q.enqueue(K)},async cancel(q){await $.return(q)}})}}function tz($,q=2){let K=Array.from({length:q},()=>[]);return K.map(async function*_(Y){while(!0)if(Y.length===0){let j=await $.next();for(let P of K)P.push(j)}else if(Y[0].done)return;else yield Y.shift().value})}function sz($,q){if(Array.isArray($)&&Array.isArray(q))return $.concat(q);else if(typeof $==="string"&&typeof q==="string")return $+q;else if(typeof $==="number"&&typeof q==="number")return $+q;else if("concat"in $&&typeof $.concat==="function")return $.concat(q);else if(typeof $==="object"&&typeof q==="object"){let K={...$};for(let[_,Y]of Object.entries(q))if(_ in K&&!Array.isArray(K[_]))K[_]=sz(K[_],Y);else K[_]=Y;return K}else throw new Error(`Cannot concat ${typeof $} and ${typeof q}`)}class S_{constructor($){Object.defineProperty(this,"generator",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"setup",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"config",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"signal",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"firstResult",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"firstResultUsed",{enumerable:!0,configurable:!0,writable:!0,value:!1}),this.generator=$.generator,this.config=$.config,this.signal=$.signal??this.config?.signal,this.setup=new Promise((q,K)=>{xK.runWithConfig(x7($.config),async()=>{if(this.firstResult=$.generator.next(),$.startSetup)this.firstResult.then($.startSetup).then(q,K);else this.firstResult.then((_)=>q(void 0),K)},!0)})}async next(...$){if(this.signal?.throwIfAborted(),!this.firstResultUsed)return this.firstResultUsed=!0,this.firstResult;return xK.runWithConfig(x7(this.config),this.signal?async()=>{return $7(this.generator.next(...$),this.signal)}:async()=>{return this.generator.next(...$)},!0)}async return($){return this.generator.return($)}async throw($){return this.generator.throw($)}[Symbol.asyncIterator](){return this}async[Symbol.asyncDispose](){await this.return()}}async function $M($,q,K,_,...Y){let j=new S_({generator:q,startSetup:K,signal:_}),P=await j.setup;return{output:$(j,P,...Y),setup:P}}class q7{constructor($){Object.defineProperty(this,"ops",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.ops=$.ops??[]}concat($){let q=this.ops.concat($.ops),K=Z9({},q);return new i1({ops:q,state:K[K.length-1].newDocument})}}class i1 extends q7{constructor($){super($);Object.defineProperty(this,"state",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.state=$.state}concat($){let q=this.ops.concat($.ops),K=Z9(this.state,$.ops);return new i1({ops:q,state:K[K.length-1].newDocument})}static fromRunLogPatch($){let q=Z9({},$.ops);return new i1({ops:$.ops,state:q[q.length-1].newDocument})}}var _M=($)=>$.name==="log_stream_tracer";async function qM($,q){if(q==="original")throw new Error("Do not assign inputs with original schema drop the key for now. When inputs are added to streamLog they should be added with standardized schema for streaming events.");let{inputs:K}=$;if(["retriever","llm","prompt"].includes($.run_type))return K;if(Object.keys(K).length===1&&K?.input==="")return;return K.input}async function KM($,q){let{outputs:K}=$;if(q==="original")return K;if(["retriever","llm","prompt"].includes($.run_type))return K;if(K!==void 0&&Object.keys(K).length===1&&K?.output!==void 0)return K.output;return K}function ad($){return $!==void 0&&$.message!==void 0}class r3 extends C4{constructor($){super({_awaitHandler:!0,...$});Object.defineProperty(this,"autoClose",{enumerable:!0,configurable:!0,writable:!0,value:!0}),Object.defineProperty(this,"includeNames",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"includeTypes",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"includeTags",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeNames",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeTypes",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeTags",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"_schemaFormat",{enumerable:!0,configurable:!0,writable:!0,value:"original"}),Object.defineProperty(this,"rootId",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"keyMapByRunId",{enumerable:!0,configurable:!0,writable:!0,value:{}}),Object.defineProperty(this,"counterMapByRunName",{enumerable:!0,configurable:!0,writable:!0,value:{}}),Object.defineProperty(this,"transformStream",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"writer",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"receiveStream",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"log_stream_tracer"}),Object.defineProperty(this,"lc_prefer_streaming",{enumerable:!0,configurable:!0,writable:!0,value:!0}),this.autoClose=$?.autoClose??!0,this.includeNames=$?.includeNames,this.includeTypes=$?.includeTypes,this.includeTags=$?.includeTags,this.excludeNames=$?.excludeNames,this.excludeTypes=$?.excludeTypes,this.excludeTags=$?.excludeTags,this._schemaFormat=$?._schemaFormat??this._schemaFormat,this.transformStream=new TransformStream,this.writer=this.transformStream.writable.getWriter(),this.receiveStream=v6.fromReadableStream(this.transformStream.readable)}[Symbol.asyncIterator](){return this.receiveStream}async persistRun($){}_includeRun($){if($.id===this.rootId)return!1;let q=$.tags??[],K=this.includeNames===void 0&&this.includeTags===void 0&&this.includeTypes===void 0;if(this.includeNames!==void 0)K=K||this.includeNames.includes($.name);if(this.includeTypes!==void 0)K=K||this.includeTypes.includes($.run_type);if(this.includeTags!==void 0)K=K||q.find((_)=>this.includeTags?.includes(_))!==void 0;if(this.excludeNames!==void 0)K=K&&!this.excludeNames.includes($.name);if(this.excludeTypes!==void 0)K=K&&!this.excludeTypes.includes($.run_type);if(this.excludeTags!==void 0)K=K&&q.every((_)=>!this.excludeTags?.includes(_));return K}async*tapOutputIterable($,q){for await(let K of q){if($!==this.rootId){let _=this.keyMapByRunId[$];if(_)await this.writer.write(new q7({ops:[{op:"add",path:`/logs/${_}/streamed_output/-`,value:K}]}))}yield K}}async onRunCreate($){if(this.rootId===void 0)this.rootId=$.id,await this.writer.write(new q7({ops:[{op:"replace",path:"",value:{id:$.id,name:$.name,type:$.run_type,streamed_output:[],final_output:void 0,logs:{}}}]}));if(!this._includeRun($))return;if(this.counterMapByRunName[$.name]===void 0)this.counterMapByRunName[$.name]=0;this.counterMapByRunName[$.name]+=1;let q=this.counterMapByRunName[$.name];this.keyMapByRunId[$.id]=q===1?$.name:`${$.name}:${q}`;let K={id:$.id,name:$.name,type:$.run_type,tags:$.tags??[],metadata:$.extra?.metadata??{},start_time:new Date($.start_time).toISOString(),streamed_output:[],streamed_output_str:[],final_output:void 0,end_time:void 0};if(this._schemaFormat==="streaming_events")K.inputs=await qM($,this._schemaFormat);await this.writer.write(new q7({ops:[{op:"add",path:`/logs/${this.keyMapByRunId[$.id]}`,value:K}]}))}async onRunUpdate($){try{let q=this.keyMapByRunId[$.id];if(q===void 0)return;let K=[];if(this._schemaFormat==="streaming_events")K.push({op:"replace",path:`/logs/${q}/inputs`,value:await qM($,this._schemaFormat)});if(K.push({op:"add",path:`/logs/${q}/final_output`,value:await KM($,this._schemaFormat)}),$.end_time!==void 0)K.push({op:"add",path:`/logs/${q}/end_time`,value:new Date($.end_time).toISOString()});let _=new q7({ops:K});await this.writer.write(_)}finally{if($.id===this.rootId){let q=new q7({ops:[{op:"replace",path:"/final_output",value:await KM($,this._schemaFormat)}]});if(await this.writer.write(q),this.autoClose)await this.writer.close()}}}async onLLMNewToken($,q,K){let _=this.keyMapByRunId[$.id];if(_===void 0)return;let Y=$.inputs.messages!==void 0,j;if(Y)if(ad(K?.chunk))j=K?.chunk;else j=new f9({id:`run-${$.id}`,content:q});else j=q;let P=new q7({ops:[{op:"add",path:`/logs/${_}/streamed_output_str/-`,value:q},{op:"add",path:`/logs/${_}/streamed_output/-`,value:j}]});await this.writer.write(P)}}class k2{constructor($){Object.defineProperty(this,"text",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"generationInfo",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.text=$.text,this.generationInfo=$.generationInfo}concat($){return new k2({text:this.text+$.text,generationInfo:{...this.generationInfo,...$.generationInfo}})}}function n3({name:$,serialized:q}){if($!==void 0)return $;if(q?.name!==void 0)return q.name;else if(q?.id!==void 0&&Array.isArray(q?.id))return q.id[q.id.length-1];return"Unnamed"}var YM=($)=>$.name==="event_stream_tracer";class ez extends C4{constructor($){super({_awaitHandler:!0,...$});Object.defineProperty(this,"autoClose",{enumerable:!0,configurable:!0,writable:!0,value:!0}),Object.defineProperty(this,"includeNames",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"includeTypes",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"includeTags",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeNames",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeTypes",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeTags",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"runInfoMap",{enumerable:!0,configurable:!0,writable:!0,value:new Map}),Object.defineProperty(this,"tappedPromises",{enumerable:!0,configurable:!0,writable:!0,value:new Map}),Object.defineProperty(this,"transformStream",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"writer",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"receiveStream",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"event_stream_tracer"}),Object.defineProperty(this,"lc_prefer_streaming",{enumerable:!0,configurable:!0,writable:!0,value:!0}),this.autoClose=$?.autoClose??!0,this.includeNames=$?.includeNames,this.includeTypes=$?.includeTypes,this.includeTags=$?.includeTags,this.excludeNames=$?.excludeNames,this.excludeTypes=$?.excludeTypes,this.excludeTags=$?.excludeTags,this.transformStream=new TransformStream,this.writer=this.transformStream.writable.getWriter(),this.receiveStream=v6.fromReadableStream(this.transformStream.readable)}[Symbol.asyncIterator](){return this.receiveStream}async persistRun($){}_includeRun($){let q=$.tags??[],K=this.includeNames===void 0&&this.includeTags===void 0&&this.includeTypes===void 0;if(this.includeNames!==void 0)K=K||this.includeNames.includes($.name);if(this.includeTypes!==void 0)K=K||this.includeTypes.includes($.runType);if(this.includeTags!==void 0)K=K||q.find((_)=>this.includeTags?.includes(_))!==void 0;if(this.excludeNames!==void 0)K=K&&!this.excludeNames.includes($.name);if(this.excludeTypes!==void 0)K=K&&!this.excludeTypes.includes($.runType);if(this.excludeTags!==void 0)K=K&&q.every((_)=>!this.excludeTags?.includes(_));return K}async*tapOutputIterable($,q){let K=await q.next();if(K.done)return;let _=this.runInfoMap.get($);if(_===void 0){yield K.value;return}function Y(P,O){if(P==="llm"&&typeof O==="string")return new k2({text:O});return O}let j=this.tappedPromises.get($);if(j===void 0){let P;j=new Promise((O)=>{P=O}),this.tappedPromises.set($,j);try{let O={event:`on_${_.runType}_stream`,run_id:$,name:_.name,tags:_.tags,metadata:_.metadata,data:{}};await this.send({...O,data:{chunk:Y(_.runType,K.value)}},_),yield K.value;for await(let W of q){if(_.runType!=="tool"&&_.runType!=="retriever")await this.send({...O,data:{chunk:Y(_.runType,W)}},_);yield W}}finally{P()}}else{yield K.value;for await(let P of q)yield P}}async send($,q){if(this._includeRun(q))await this.writer.write($)}async sendEndEvent($,q){let K=this.tappedPromises.get($.run_id);if(K!==void 0)K.then(()=>{this.send($,q)});else await this.send($,q)}async onLLMStart($){let q=n3($),K=$.inputs.messages!==void 0?"chat_model":"llm",_={tags:$.tags??[],metadata:$.extra?.metadata??{},name:q,runType:K,inputs:$.inputs};this.runInfoMap.set($.id,_);let Y=`on_${K}_start`;await this.send({event:Y,data:{input:$.inputs},name:q,tags:$.tags??[],run_id:$.id,metadata:$.extra?.metadata??{}},_)}async onLLMNewToken($,q,K){let _=this.runInfoMap.get($.id),Y,j;if(_===void 0)throw new Error(`onLLMNewToken: Run ID ${$.id} not found in run map.`);if(this.runInfoMap.size===1)return;if(_.runType==="chat_model")if(j="on_chat_model_stream",K?.chunk===void 0)Y=new f9({content:q,id:`run-${$.id}`});else Y=K.chunk.message;else if(_.runType==="llm")if(j="on_llm_stream",K?.chunk===void 0)Y=new k2({text:q});else Y=K.chunk;else throw new Error(`Unexpected run type ${_.runType}`);await this.send({event:j,data:{chunk:Y},run_id:$.id,name:_.name,tags:_.tags,metadata:_.metadata},_)}async onLLMEnd($){let q=this.runInfoMap.get($.id);this.runInfoMap.delete($.id);let K;if(q===void 0)throw new Error(`onLLMEnd: Run ID ${$.id} not found in run map.`);let _=$.outputs?.generations,Y;if(q.runType==="chat_model"){for(let j of _??[]){if(Y!==void 0)break;Y=j[0]?.message}K="on_chat_model_end"}else if(q.runType==="llm")Y={generations:_?.map((j)=>{return j.map((P)=>{return{text:P.text,generationInfo:P.generationInfo}})}),llmOutput:$.outputs?.llmOutput??{}},K="on_llm_end";else throw new Error(`onLLMEnd: Unexpected run type: ${q.runType}`);await this.sendEndEvent({event:K,data:{output:Y,input:q.inputs},run_id:$.id,name:q.name,tags:q.tags,metadata:q.metadata},q)}async onChainStart($){let q=n3($),K=$.run_type??"chain",_={tags:$.tags??[],metadata:$.extra?.metadata??{},name:q,runType:$.run_type},Y={};if($.inputs.input===""&&Object.keys($.inputs).length===1)Y={},_.inputs={};else if($.inputs.input!==void 0)Y.input=$.inputs.input,_.inputs=$.inputs.input;else Y.input=$.inputs,_.inputs=$.inputs;this.runInfoMap.set($.id,_),await this.send({event:`on_${K}_start`,data:Y,name:q,tags:$.tags??[],run_id:$.id,metadata:$.extra?.metadata??{}},_)}async onChainEnd($){let q=this.runInfoMap.get($.id);if(this.runInfoMap.delete($.id),q===void 0)throw new Error(`onChainEnd: Run ID ${$.id} not found in run map.`);let K=`on_${$.run_type}_end`,_=$.inputs??q.inputs??{},j={output:$.outputs?.output??$.outputs,input:_};if(_.input&&Object.keys(_).length===1)j.input=_.input,q.inputs=_.input;await this.sendEndEvent({event:K,data:j,run_id:$.id,name:q.name,tags:q.tags,metadata:q.metadata??{}},q)}async onToolStart($){let q=n3($),K={tags:$.tags??[],metadata:$.extra?.metadata??{},name:q,runType:"tool",inputs:$.inputs??{}};this.runInfoMap.set($.id,K),await this.send({event:"on_tool_start",data:{input:$.inputs??{}},name:q,run_id:$.id,tags:$.tags??[],metadata:$.extra?.metadata??{}},K)}async onToolEnd($){let q=this.runInfoMap.get($.id);if(this.runInfoMap.delete($.id),q===void 0)throw new Error(`onToolEnd: Run ID ${$.id} not found in run map.`);if(q.inputs===void 0)throw new Error(`onToolEnd: Run ID ${$.id} is a tool call, and is expected to have traced inputs.`);let K=$.outputs?.output===void 0?$.outputs:$.outputs.output;await this.sendEndEvent({event:"on_tool_end",data:{output:K,input:q.inputs},run_id:$.id,name:q.name,tags:q.tags,metadata:q.metadata},q)}async onRetrieverStart($){let q=n3($),K="retriever",_={tags:$.tags??[],metadata:$.extra?.metadata??{},name:q,runType:"retriever",inputs:{query:$.inputs.query}};this.runInfoMap.set($.id,_),await this.send({event:"on_retriever_start",data:{input:{query:$.inputs.query}},name:q,tags:$.tags??[],run_id:$.id,metadata:$.extra?.metadata??{}},_)}async onRetrieverEnd($){let q=this.runInfoMap.get($.id);if(this.runInfoMap.delete($.id),q===void 0)throw new Error(`onRetrieverEnd: Run ID ${$.id} not found in run map.`);await this.sendEndEvent({event:"on_retriever_end",data:{output:$.outputs?.documents??$.outputs,input:q.inputs},run_id:$.id,name:q.name,tags:q.tags,metadata:q.metadata},q)}async handleCustomEvent($,q,K){let _=this.runInfoMap.get(K);if(_===void 0)throw new Error(`handleCustomEvent: Run ID ${K} not found in run map.`);await this.send({event:"on_custom_event",run_id:K,name:$,tags:_.tags,metadata:_.metadata,data:q},_)}async finish(){let $=[...this.tappedPromises.values()];Promise.all($).finally(()=>{this.writer.close()})}}var PM=HK(Y3(),1),a3=HK(M3(),1),td=[400,401,402,403,404,405,406,407,409],sd=($)=>{if($.message.startsWith("Cancel")||$.message.startsWith("AbortError")||$.name==="AbortError")throw $;if($?.code==="ECONNABORTED")throw $;let q=$?.response?.status??$?.status;if(q&&td.includes(+q))throw $;if($?.error?.code==="insufficient_quota"){let K=new Error($?.message);throw K.name="InsufficientQuotaError",K}};class t3{constructor($){Object.defineProperty(this,"maxConcurrency",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"maxRetries",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"onFailedAttempt",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"queue",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.maxConcurrency=$.maxConcurrency??1/0,this.maxRetries=$.maxRetries??6,this.onFailedAttempt=$.onFailedAttempt??sd;let q="default"in a3.default?a3.default.default:a3.default;this.queue=new q({concurrency:this.maxConcurrency})}call($,...q){return this.queue.add(()=>PM.default(()=>$(...q).catch((K)=>{if(K instanceof Error)throw K;else throw new Error(K)}),{onFailedAttempt:this.onFailedAttempt,retries:this.maxRetries,randomize:!0}),{throwOnTimeout:!0})}callWithOptions($,q,...K){if($.signal)return Promise.race([this.call(q,...K),new Promise((_,Y)=>{$.signal?.addEventListener("abort",()=>{Y(new Error("AbortError"))})})]);return this.call(q,...K)}fetch(...$){return this.call(()=>fetch(...$).then((q)=>q.ok?q:Promise.reject(q)))}}class s3 extends C4{constructor({config:$,onStart:q,onEnd:K,onError:_}){super({_awaitHandler:!0});Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"RootListenersTracer"}),Object.defineProperty(this,"rootId",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"config",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"argOnStart",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"argOnEnd",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"argOnError",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.config=$,this.argOnStart=q,this.argOnEnd=K,this.argOnError=_}persistRun($){return Promise.resolve()}async onRunCreate($){if(this.rootId)return;if(this.rootId=$.id,this.argOnStart)await this.argOnStart($,this.config)}async onRunUpdate($){if($.id!==this.rootId)return;if(!$.error){if(this.argOnEnd)await this.argOnEnd($,this.config)}else if(this.argOnError)await this.argOnError($,this.config)}}function v2($){return $?$.lc_runnable:!1}class $X{constructor($){Object.defineProperty(this,"includeNames",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"includeTypes",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"includeTags",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeNames",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeTypes",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"excludeTags",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.includeNames=$.includeNames,this.includeTypes=$.includeTypes,this.includeTags=$.includeTags,this.excludeNames=$.excludeNames,this.excludeTypes=$.excludeTypes,this.excludeTags=$.excludeTags}includeEvent($,q){let K=this.includeNames===void 0&&this.includeTypes===void 0&&this.includeTags===void 0,_=$.tags??[];if(this.includeNames!==void 0)K=K||this.includeNames.includes($.name);if(this.includeTypes!==void 0)K=K||this.includeTypes.includes(q);if(this.includeTags!==void 0)K=K||_.some((Y)=>this.includeTags?.includes(Y));if(this.excludeNames!==void 0)K=K&&!this.excludeNames.includes($.name);if(this.excludeTypes!==void 0)K=K&&!this.excludeTypes.includes(q);if(this.excludeTags!==void 0)K=K&&_.every((Y)=>!this.excludeTags?.includes(Y));return K}}function qX($){return $.replace(/[^a-zA-Z-_0-9]/g,"_")}var ed=["*","_","`"];function $l($){let q="";for(let[K,_]of Object.entries($))q+=` classDef ${K} ${_};
584
584
  `;return q}function jM($,q,K){let{firstNode:_,lastNode:Y,nodeColors:j,withStyles:P=!0,curveStyle:O="linear",wrapLabelNWords:W=9}=K??{},X=P?`%%{init: {'flowchart': {'curve': '${O}'}}}%%
585
585
  graph TD;
586
586
  `:`graph TD;
@@ -1099,5 +1099,5 @@ Data: ${JSON.stringify(K.metadata)}
1099
1099
  `}`}).join(`
1100
1100
  `)}var hf=!1,sj=null;async function mg(){if(h8("SENTRY_LOGGING")==="false")return null;let $=h8("SENTRY_DSN")||"https://c20e2d51b66c14a783b0689d536f7e5c@o4509349865259008.ingest.us.sentry.io/4509352524120064";if(hf&&sj)return sj;try{let q=await Promise.resolve().then(() => (XA(),zA)),K=()=>q.init({dsn:$,environment:h8("SENTRY_ENVIRONMENT")||h8("NODE_ENV","development"),tracesSampleRate:u9("SENTRY_TRACES_SAMPLE_RATE",1)??1,sendDefaultPii:JP("SENTRY_SEND_DEFAULT_PII",!1)});if(typeof q.onLoad==="function")q.onLoad(K);else K();return hf=!0,sj=q,sj}catch{return hf=!0,sj=null,null}}var qu$={async captureException($){let q=await mg();try{q?.captureException?.($)}catch{}},async flush($){let q=await mg();try{if(q?.flush)return await q.flush($)}catch{}return!0}};var _u$=!0,Yu$=!1,Pu$={check:async()=>({status:"not-applicable",environment:"browser"}),isHealthy:()=>!0};export{B_$ as validateUuid,Jy as validateCharacter,Gg$ as updateWorldSettings,gg as unsaltWorldSettings,cY$ as unsaltSettingValue,Oy$ as truncateToCompleteSentence,Hy$ as trimTokens,ZY$ as toString,Ig as toHex,Bj as stringToUuid,Wy$ as splitChunks,kY$ as slice,Dy$ as shouldRespondTemplate,XT$ as setEnv,Pu$ as serverHealth,BY$ as saltWorldSettings,pY$ as saltSettingValue,FA as safeReplacer,rx$ as recentLogs,MY$ as randomBytes,Xy$ as prewarmUuidCache,hy$ as postCreationTemplate,_y as parseKeyValueXml,Jy$ as parseJSONObjectFromText,zy$ as parseBooleanFromText,Ay$ as parseAndValidateCharacter,sx as normalizeJsonString,yy$ as multiStepSummaryTemplate,xy$ as multiStepDecisionTemplate,Iy$ as messageHandlerTemplate,c8 as logger,fy$ as isValidCharacter,Yu$ as isNode,aY$ as isMessageMetadata,nY$ as isFragmentMetadata,$2$ as isFragmentMemory,rY$ as isDocumentMetadata,eY$ as isDocumentMemory,tY$ as isDescriptionMetadata,sY$ as isCustomMetadata,GY$ as isBuffer,_u$ as isBrowser,Ag$ as initializeOnboarding,ZT$ as initBrowserEnvironment,by$ as imageDescriptionTemplate,wT$ as hasEnv,Tg$ as getWorldSettings,cy$ as getUserServerRole,O2$ as getTypedService,N1 as getSalt,u9 as getNumberEnv,z2$ as getModelSpecificSettingKey,q2$ as getMemoryText,Zy$ as getLocalServerUrl,D5 as getEnvironment,h8 as getEnv,tg$ as getEntityDetails,wy$ as getContentTypeFromMimeType,JP as getBooleanEnv,wY$ as fromString,XY$ as fromHex,AY$ as fromBytes,Ky as formatTimestamp,Py$ as formatPosts,jy$ as formatMessages,sg$ as formatEntities,Sy$ as formatActions,Cy$ as formatActionNames,By$ as findWorldsForOwner,ag$ as findEntityByName,vY$ as equals,fg$ as encryptedCharacter,yg as encryptStringValue,bg as encryptObjectValues,ix$ as elizaLogger,BJ as detectEnvironment,Mg$ as defineService,kg$ as decryptedCharacter,mH as decryptStringValue,mH as decryptSecret,xg as decryptObjectValues,ox$ as customLevels,GT$ as currentRuntime,M1 as createUniqueUuid,uY$ as createSettingFromConfig,W2$ as createServiceError,dY$ as createService,iY$ as createMessageMemory,cj as createLogger,j2$ as createActionResult,fY$ as concat,_y$ as composePromptFromState,$y as composePrompt,Ny$ as composeActionExamples,Zg$ as clearSaltCache,s_$ as characterSchema,VY$ as byteLength,Ly$ as booleanFooter,QY$ as asUUID,TY$ as alloc,Yy$ as addHeader,Ux$ as __loggerTestHooks,w2$ as VECTOR_DIMS,ig as TeeType,og as TEEMode,x8 as ServiceType,ug as ServiceBuilder,O8 as Service,qu$ as Sentry,yY$ as Semaphore,ng as SOCKET_MESSAGE_TYPE,gf as Role,Qg as PlatformPrefix,b6 as ModelType,dg as MemoryType,rY as MODEL_SETTINGS,lg as KnowledgeScope,Ku as IWebSearchService,ag as IWalletService,eg as IVideoService,qu as ITranscriptionService,rg as ITokenDataService,Pu as IPostService,sg as IPdfService,Yu as IMessageService,tg as ILpService,_u as IEmailService,$u as IBrowserService,mf as EventType,FS as Environment,CY$ as DatabaseAdapter,yf as ContentType,uf as ChannelType,Ug as CacheKeyPrefix,Y9 as BufferUtils,Df as BM25,Fg as AgentStatus,gY$ as AgentRuntime};
1101
1101
 
1102
- //# debugId=80F0812AD6514E7664756E2164756E21
1102
+ //# debugId=545512BAF5A7D8CF64756E2164756E21
1103
1103
  //# sourceMappingURL=index.browser.js.map