@cline/core 0.0.42 → 0.0.43
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cron/service/schedule-service.d.ts +1 -0
- package/dist/extensions/config/user-instruction-config-loader.d.ts +4 -0
- package/dist/extensions/index.d.ts +1 -1
- package/dist/extensions/plugin/plugin-config-loader.d.ts +3 -0
- package/dist/extensions/plugin/plugin-loader.d.ts +1 -0
- package/dist/extensions/plugin/plugin-sandbox.d.ts +7 -0
- package/dist/extensions/plugin-sandbox-bootstrap.js +1 -1
- package/dist/extensions/tools/helpers.d.ts +4 -1
- package/dist/extensions/tools/schemas.d.ts +8 -0
- package/dist/hub/daemon/entry.js +164 -163
- package/dist/hub/discovery/index.d.ts +1 -0
- package/dist/hub/index.js +163 -163
- package/dist/index.d.ts +4 -2
- package/dist/index.js +163 -163
- package/dist/runtime/host/runtime-host.d.ts +7 -0
- package/dist/runtime/orchestration/session-runtime.d.ts +1 -0
- package/dist/services/llms/apihandler-agent-model-adapter.d.ts +26 -0
- package/dist/services/plugin-uninstall.d.ts +13 -0
- package/dist/services/providers/provider-config-fields.d.ts +1 -1
- package/dist/services/telemetry/core-events.d.ts +18 -0
- package/dist/services/telemetry/index.js +1 -1
- package/dist/services/telemetry/tool-context.d.ts +3 -0
- package/dist/types.d.ts +1 -1
- package/package.json +4 -4
package/dist/index.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import{createRequire as
|
|
2
|
-
|
|
3
|
-
`)}function
|
|
4
|
-
|
|
5
|
-
`,"utf8"),GF()}function lJ(){return J$().telemetryOptOut}function UF($,f={}){I2({...J$(),telemetryOptOut:$},f)}function Q$($){return new Set($??J$().disabledTools??[])}function v4($){return new Set($??J$().disabledPlugins??[])}function DF($){return Q$().has($)}function pJ($){let f=J$(),J=new Set(f.disabledTools??[]),Q=J.has($);if(Q)J.delete($);else J.add($);return I2({...f,disabledTools:[...J]}),!Q}function v3($,f){let J=[...new Set($.map((W)=>W.trim()).filter(Boolean))];if(J.length===0)return;let Q=J$(),Z=Q$(Q.disabledTools);for(let W of J)if(f)Z.add(W);else Z.delete(W);I2({...Q,disabledTools:[...Z]})}function u3($,f){return v3([$],f),f}function RF($){return v4().has($)}function LF($,f){let J=$.trim();if(!J)return;let Q=J$(),Z=v4(Q.disabledPlugins);if(f)Z.add(J);else Z.delete(J);I2({...Q,disabledPlugins:[...Z]})}function rJ($,f){let J=v4(f);if(J.size===0)return[...$];return $.filter((Q)=>!J.has(Q))}function l1($,f){let J=Q$(f);if(J.size===0)return[...$];return $.filter((Q)=>!J.has(Q.name))}function iJ($,f){if(!$||$.length===0)return $;let J=Q$(f);if(J.size===0)return $;return $.map((Q)=>{if(!Q.setup)return Q;return{...Q,setup:(Z,W)=>Q.setup?.({...Z,registerTool:(j)=>{if(!J.has(j.name))Z.registerTool(j)}},W)}})}var m3,g4,m4;var Z$=i$(()=>{G0();m3=k2.preprocess(($)=>Array.isArray($)?$.filter((f)=>typeof f==="string").map((f)=>f.trim()).filter(Boolean):void 0,k2.array(k2.string()).optional()).transform(($)=>{if(!$)return;let f=[...new Set($)].sort((J,Q)=>J.localeCompare(Q));return f.length>0?f:void 0}),g4=k2.object({telemetryOptOut:k2.boolean().default(!1).catch(!1),disabledTools:m3.optional(),disabledPlugins:m3.optional()}).strip().transform(($)=>{let f={telemetryOptOut:$.telemetryOptOut};if($.disabledTools?.length)f.disabledTools=$.disabledTools;if($.disabledPlugins?.length)f.disabledPlugins=$.disabledPlugins;return f})});import{existsSync as QL,mkdirSync as ZL,readFileSync as WL,writeFileSync as jL}from"node:fs";import{resolve as XL}from"node:path";import{resolveSessionDataDir as HL}from"@cline/shared/storage";import{nanoid as YL}from"nanoid";import*as VL from"node-machine-id";function U1($){let f=$?.trim();if(f)return f;let J=GL();if(J)return J;return KL()}function BL(){let $=VL;return $.machineIdSync??$.default?.machineIdSync}function GL(){try{let $=BL();if(!$)return;return $().trim()||void 0}catch{return}}function KL(){let $=HL(),f=XL($,AL);try{if(QL(f)){let Q=WL(f,"utf8").trim();if(Q.length>0)return Q}}catch{}let J=`cl-${YL()}`;try{ZL($,{recursive:!0}),jL(f,J,"utf8")}catch{}return J}var AL="machine-id";var V6=()=>{};class N8{name;metadata;meter;logger;enabled;distinctId;commonProperties;counters=new Map;histograms=new Map;gauges=new Map;gaugeValues=new Map;meterProvider;loggerProvider;constructor($){this.name=$.name??"OpenTelemetryAdapter",this.metadata={...$.metadata},this.meterProvider=$.meterProvider,this.loggerProvider=$.loggerProvider,this.meter=$.meterProvider?.getMeter("cline")??null,this.logger=$.loggerProvider?.getLogger("cline")??null,this.enabled=$.enabled??!0,this.distinctId=$.distinctId,this.commonProperties=$.commonProperties?{...$.commonProperties}:{}}emit($,f){if(!this.isEnabled())return;this.emitLog($,f,!1)}emitRequired($,f){this.emitLog($,f,!0)}recordCounter($,f,J,Q,Z=!1){if(!this.meter||!Z&&!this.isEnabled())return;let W=this.counters.get($);if(!W)W=this.meter.createCounter($,Q?{description:Q}:void 0),this.counters.set($,W);W.add(f,this.flattenProperties(this.buildAttributes(J)))}recordHistogram($,f,J,Q,Z=!1){if(!this.meter||!Z&&!this.isEnabled())return;let W=this.histograms.get($);if(!W)W=this.meter.createHistogram($,Q?{description:Q}:void 0),this.histograms.set($,W);W.record(f,this.flattenProperties(this.buildAttributes(J)))}recordGauge($,f,J,Q,Z=!1){if(!this.meter||!Z&&!this.isEnabled())return;let W=this.buildAttributes(J),j=JSON.stringify(W),X=this.gaugeValues.get($);if(f===null){if(X){if(X.delete(j),X.size===0)this.gaugeValues.delete($),this.gauges.delete($)}return}let H=X;if(!H)H=new Map,this.gaugeValues.set($,H);if(!this.gauges.has($)){let Y=this.meter.createObservableGauge($,Q?{description:Q}:void 0);Y.addCallback((V)=>{for(let A of this.snapshotGaugeSeries($))V.observe(A.value,this.flattenProperties(A.attributes))}),this.gauges.set($,Y)}H.set(j,{value:f,attributes:W})}isEnabled(){return typeof this.enabled==="function"?this.enabled():this.enabled}setDistinctId($){this.distinctId=$}setCommonProperties($){this.commonProperties={...$}}updateCommonProperties($){this.commonProperties={...this.commonProperties,...$}}async flush(){await Promise.all([this.meterProvider?.forceFlush?.(),this.loggerProvider?.forceFlush?.()])}async dispose(){await Promise.all([this.meterProvider?.shutdown?.(),this.loggerProvider?.shutdown?.()])}emitLog($,f,J){if(!this.logger)return;let Q=this.flattenProperties(this.buildAttributes(f,J));this.logger.emit({severityText:"INFO",body:$,attributes:Q})}buildAttributes($,f=!1){return{...this.commonProperties,...this.metadata,...$,...this.distinctId?{distinct_id:this.distinctId}:{},...f?{_required:!0}:{}}}snapshotGaugeSeries($){let f=this.gaugeValues.get($);if(!f)return[];return Array.from(f.values(),(J)=>({value:J.value,attributes:J.attributes?{...J.attributes}:void 0}))}flattenProperties($,f="",J=new WeakSet,Q=0){if(!$)return{};let Z={},W=100,j=10;for(let[X,H]of Object.entries($)){if(X==="__proto__"||X==="constructor"||X==="prototype")continue;let Y=f?`${f}.${X}`:X;if(H===null||H===void 0){Z[Y]=String(H);continue}if(Array.isArray(H)){let V=H.length>W?H.slice(0,W):H;try{Z[Y]=JSON.stringify(V)}catch{Z[Y]="[UnserializableArray]"}if(H.length>W)Z[`${Y}_truncated`]=!0,Z[`${Y}_original_length`]=H.length;continue}if(typeof H==="object"){if(H instanceof Date){Z[Y]=H.toISOString();continue}if(H instanceof Error){Z[Y]=H.message;continue}if(J.has(H)){Z[Y]="[Circular]";continue}if(Q>=j){Z[Y]="[MaxDepthExceeded]";continue}J.add(H),Object.assign(Z,this.flattenProperties(H,Y,J,Q+1));continue}if(YN(H)){Z[Y]=H;continue}try{Z[Y]=JSON.stringify(H)}catch{Z[Y]=String(H)}}return Z}}function YN($){return typeof $==="string"||typeof $==="number"||typeof $==="boolean"}class n6{name;logger;enabled;constructor($={}){this.name=$.name??"TelemetryLoggerSink",this.logger=$.logger,this.enabled=$.enabled??!0}emit($,f){if(!this.isEnabled())return;this.logger?.log("telemetry.event",{telemetrySink:this.name,event:$,properties:f})}emitRequired($,f){this.logger?.log("telemetry.required_event",{telemetrySink:this.name,severity:"warn",event:$,properties:f})}recordCounter($,f,J,Q,Z){if(!Z&&!this.isEnabled())return;this.logger?.debug("telemetry.metric",{telemetrySink:this.name,instrument:"counter",name:$,value:f,attributes:J,description:Q,required:Z===!0})}recordHistogram($,f,J,Q,Z){if(!Z&&!this.isEnabled())return;this.logger?.debug("telemetry.metric",{telemetrySink:this.name,instrument:"histogram",name:$,value:f,attributes:J,description:Q,required:Z===!0})}recordGauge($,f,J,Q,Z){if(!Z&&!this.isEnabled())return;this.logger?.debug("telemetry.metric",{telemetrySink:this.name,instrument:"gauge",name:$,value:f,attributes:J,description:Q,required:Z===!0})}isEnabled(){return typeof this.enabled==="function"?this.enabled():this.enabled}async flush(){}async dispose(){}}class T8{adapters;metadata;distinctId;commonProperties;constructor($={}){if(this.adapters=[...$.adapters??[]],$.logger)this.adapters.push(new n6({logger:$.logger}));this.metadata={...$.metadata??{}},this.distinctId=$.distinctId,this.commonProperties={...$.commonProperties??{}}}addAdapter($){this.adapters.push($)}setDistinctId($){this.distinctId=$}setMetadata($){this.metadata={...$}}updateMetadata($){this.metadata={...this.metadata,...$}}setCommonProperties($){this.commonProperties={...$}}updateCommonProperties($){this.commonProperties={...this.commonProperties,...$}}isEnabled(){return this.adapters.some(($)=>$.isEnabled())}capture($){let f=this.buildAttributes($.properties);for(let J of this.adapters)J.emit($.event,f)}captureRequired($,f){let J=this.buildAttributes(f);for(let Q of this.adapters)Q.emitRequired($,J)}recordCounter($,f,J,Q,Z=!1){let W=this.buildAttributes(J);for(let j of this.adapters)j.recordCounter($,f,W,Q,Z)}recordHistogram($,f,J,Q,Z=!1){let W=this.buildAttributes(J);for(let j of this.adapters)j.recordHistogram($,f,W,Q,Z)}recordGauge($,f,J,Q,Z=!1){let W=this.buildAttributes(J);for(let j of this.adapters)j.recordGauge($,f,W,Q,Z)}async flush(){await Promise.all(this.adapters.map(($)=>$.flush()))}async dispose(){await Promise.all(this.adapters.map(($)=>$.dispose()))}buildAttributes($){return{...this.commonProperties,...$,...this.metadata,...this.distinctId?{distinct_id:this.distinctId}:{}}}}var j7=()=>{};import{metrics as VN,trace as AN}from"@opentelemetry/api";import{logs as BN}from"@opentelemetry/api-logs";import{OTLPLogExporter as GN}from"@opentelemetry/exporter-logs-otlp-http";import{OTLPMetricExporter as KN}from"@opentelemetry/exporter-metrics-otlp-http";import{OTLPTraceExporter as FN}from"@opentelemetry/exporter-trace-otlp-http";import{resourceFromAttributes as PN}from"@opentelemetry/resources";import{BatchLogRecordProcessor as UN,ConsoleLogRecordExporter as DN,LoggerProvider as RN}from"@opentelemetry/sdk-logs";import{ConsoleMetricExporter as LN,MeterProvider as ON,PeriodicExportingMetricReader as qH}from"@opentelemetry/sdk-metrics";import{BatchSpanProcessor as zN,ConsoleSpanExporter as _N,SimpleSpanProcessor as NN}from"@opentelemetry/sdk-trace-base";import{NodeTracerProvider as TN}from"@opentelemetry/sdk-trace-node";import{ATTR_SERVICE_NAME as MN,ATTR_SERVICE_VERSION as qN}from"@opentelemetry/semantic-conventions";class yH{distinctId;metadata;commonProperties;constructor($={}){this.distinctId=$.distinctId,this.metadata={...$.metadata??{}},this.commonProperties={...$.commonProperties??{}}}setDistinctId($){this.distinctId=$}setMetadata($){this.metadata={...$}}updateMetadata($){this.metadata={...this.metadata,...$}}setCommonProperties($){this.commonProperties={...$}}updateCommonProperties($){this.commonProperties={...this.commonProperties,...$}}isEnabled(){return!1}capture($){this.resolveProperties($.properties)}captureRequired($,f){this.resolveProperties(f)}recordCounter(){}recordHistogram(){}recordGauge(){}async flush(){}async dispose(){}resolveProperties($){return{...this.commonProperties,...$,...this.metadata,...this.distinctId?{distinct_id:this.distinctId}:{}}}}class M8{meterProvider;loggerProvider;tracerProvider;options;constructor($={}){this.options=$;let f=PN({[MN]:$.serviceName??"cline",...$.serviceVersion?{[qN]:$.serviceVersion}:{}});if(this.meterProvider=this.createMeterProvider(f),this.loggerProvider=this.createLoggerProvider(f),this.tracerProvider=this.createTracerProvider(f),this.meterProvider)VN.setGlobalMeterProvider(this.meterProvider);if(this.loggerProvider)BN.setGlobalLoggerProvider(this.loggerProvider);if(this.tracerProvider)this.tracerProvider.register()}getTracer($="cline",f){return AN.getTracer($,f??this.options.serviceVersion)}createAdapter($){return new N8({...$,meterProvider:this.meterProvider,loggerProvider:this.loggerProvider})}createTelemetryService($){let f=this.createAdapter({name:$.name,enabled:this.options.enabled,metadata:$.metadata});return new T8({...$,adapters:[f],distinctId:U1($.distinctId)})}async forceFlush(){await Promise.all([this.meterProvider?.forceFlush?.(),this.loggerProvider?.forceFlush?.(),this.tracerProvider?.forceFlush?.()])}async dispose(){await Promise.all([this.meterProvider?.shutdown?.(),this.loggerProvider?.shutdown?.(),this.tracerProvider?.shutdown?.()])}createMeterProvider($){let f=X7(this.options.metricsExporter);if(f.length===0)return null;let J=Math.max(1000,this.options.metricExportIntervalMs??this.options.metricExportInterval??60000),Q=Math.min(30000,Math.floor(J*0.8)),Z=f.map((W)=>SN(W,{endpoint:this.options.otlpEndpoint,headers:this.options.otlpHeaders,insecure:this.options.otlpInsecure??!1,protocol:"http/json",interval:J,timeout:Q})).filter((W)=>W!==null);if(Z.length===0)return null;return new ON({resource:$,readers:Z})}createTracerProvider($){let f=X7(this.options.tracesExporter);if(f.length===0)return null;let J=this.options.otlpTracesEndpoint??this.options.otlpEndpoint,Q=this.options.otlpTracesHeaders??this.options.otlpHeaders,Z=[];for(let W of f){let j=wN(W,{endpoint:J,headers:Q,insecure:this.options.otlpInsecure??!1,protocol:"http/json"});if(j)Z.push(j)}if(Z.length===0)return null;return new TN({resource:$,spanProcessors:Z})}createLoggerProvider($){let f=X7(this.options.logsExporter);if(f.length===0)return null;let J=f.map((Q)=>{let Z=yN(Q,{endpoint:this.options.otlpEndpoint,headers:this.options.otlpHeaders,insecure:this.options.otlpInsecure??!1,protocol:"http/json"});if(!Z)return null;return new UN(Z,{maxQueueSize:this.options.logMaxQueueSize??2048,maxExportBatchSize:this.options.logBatchSize??512,scheduledDelayMillis:this.options.logBatchTimeoutMs??this.options.logBatchTimeout??5000})}).filter((Q)=>Q!==null);if(J.length===0)return null;return new RN({resource:$,processors:J})}}function a6($){let f=new M8($),J=f.createTelemetryService($);return J.captureRequired("telemetry.provider_created",{provider:"opentelemetry",enabled:$.enabled??!0,logsExporter:Array.isArray($.logsExporter)?$.logsExporter.join(","):$.logsExporter,metricsExporter:Array.isArray($.metricsExporter)?$.metricsExporter.join(","):$.metricsExporter,tracesExporter:Array.isArray($.tracesExporter)?$.tracesExporter.join(","):$.tracesExporter,otlpProtocol:$.otlpProtocol,hasOtlpEndpoint:Boolean($.otlpEndpoint),serviceName:$.serviceName,serviceVersion:$.serviceVersion}),{provider:f,telemetry:J}}function T1($){if(lJ())return{telemetry:new yH($)};if($.enabled!==!0)return{telemetry:new T8({...$,distinctId:U1($.distinctId)})};return a6($)}function t6($){let{telemetry:f,provider:J}=T1($);return{telemetry:f,provider:J,flush:async()=>{let W=J;if(W&&typeof W.forceFlush==="function")try{await W.forceFlush()}catch{}},dispose:async()=>{await Promise.allSettled([f.dispose(),J?.dispose()])}}}function X7($){if(!$)return[];return(Array.isArray($)?$:$.split(",")).map((J)=>J.trim()).filter((J)=>J==="console"||J==="otlp")}function yN($,f){if($==="console")return new DN;if(!f.endpoint)return null;let J=H7(f.endpoint,"/v1/logs");return new GN({url:J,headers:f.headers})}function wN($,f){if($==="console")return new NN(new _N);if(!f.endpoint)return null;let J=H7(f.endpoint,"/v1/traces");return new zN(new FN({url:J,headers:f.headers}))}function SN($,f){if($==="console")return new qH({exporter:new LN,exportIntervalMillis:f.interval,exportTimeoutMillis:f.timeout});if(!f.endpoint)return null;let J=H7(f.endpoint,"/v1/metrics");return new qH({exporter:new KN({url:J,headers:f.headers}),exportIntervalMillis:f.interval,exportTimeoutMillis:f.timeout})}function H7($,f){let J=new URL($),Q=J.pathname.endsWith("/")?J.pathname.slice(0,-1):J.pathname;return J.pathname=Q.endsWith(f)?Q:`${Q}${f}`,J.toString()}var s6=i$(()=>{Z$();V6();j7()});var OY={};Xf(OY,{createOpenTelemetryTelemetryService:()=>a6,createConfiguredTelemetryService:()=>T1,createConfiguredTelemetryHandle:()=>t6,OpenTelemetryProvider:()=>M8,OpenTelemetryAdapter:()=>N8});var T7=i$(()=>{s6()});import*as zd from"@cline/llms";import{buildClineSystemPrompt as Nd,buildSdkErrorProperties as Td,ContributionRegistry as Md,captureSdkError as qd,createClineTelemetryServiceConfig as yd,createClineTelemetryServiceMetadata as wd,createContributionRegistry as Sd,createTool as hd,emptyWorkspaceManifest as Cd,formatDisplayUserInput as Ed,noopBasicLogger as bd,normalizeSdkError as kd,normalizeUserInput as Id,parseUserCommandEnvelope as xd,registerDisposable as md,SDK_ERROR_TELEMETRY_EVENT as gd}from"@cline/shared";export*from"@cline/shared/storage";function sY($){if(typeof $!=="object"||$===null||!("error"in $))return;let f=$.error;return typeof f==="string"&&f.trim()?f:void 0}function I7($,f,J){let Q=sY(J);if(Q)return Q;let Z=f.trim();if(Z){let W=Z.length>200?`${Z.slice(0,200)}...`:Z;return`Cline account request failed with status ${$}: ${W}`}return`Cline account request failed with status ${$}`}class Hf{apiBaseUrl;getAuthTokenFn;getCurrentUserIdFn;getOrganizationMemberIdFn;getHeadersFn;requestTimeoutMs;fetchImpl;constructor($){let f=$.apiBaseUrl.trim();if(!f)throw Error("apiBaseUrl is required");this.apiBaseUrl=f,this.getAuthTokenFn=$.getAuthToken,this.getCurrentUserIdFn=$.getCurrentUserId,this.getOrganizationMemberIdFn=$.getOrganizationMemberId,this.getHeadersFn=$.getHeaders,this.requestTimeoutMs=$.requestTimeoutMs??30000,this.fetchImpl=$.fetchImpl??fetch}async fetchMe(){return this.request("/api/v1/users/me")}async fetchRemoteConfig(){return this.request("/api/v1/users/me/remote-config")}async fetchFeaturebaseToken(){try{return await this.request("/api/v1/users/me/featurebase-token")}catch{return}}async fetchBalance($){let f=await this.resolveUserId($);return this.request(`/api/v1/users/${encodeURIComponent(f)}/balance`)}async fetchUsageTransactions($){let f=await this.resolveUserId($);return(await this.request(`/api/v1/users/${encodeURIComponent(f)}/usages`)).items??[]}async fetchPaymentTransactions($){let f=await this.resolveUserId($);return(await this.request(`/api/v1/users/${encodeURIComponent(f)}/payments`)).paymentTransactions??[]}async fetchUserOrganizations(){return(await this.fetchMe()).organizations??[]}async fetchOrganization($){let f=$.trim();if(!f)throw Error("organizationId is required");return this.request(`/api/v1/organizations/${encodeURIComponent(f)}`)}async fetchOrganizationBalance($){let f=$.trim();if(!f)throw Error("organizationId is required");return this.request(`/api/v1/organizations/${encodeURIComponent(f)}/balance`)}async fetchOrganizationUsageTransactions($){let f=$.organizationId.trim();if(!f)throw Error("organizationId is required");let J=await this.resolveOrganizationMemberId(f,$.memberId);return(await this.request(`/api/v1/organizations/${encodeURIComponent(f)}/members/${encodeURIComponent(J)}/usages`)).items??[]}async switchAccount($){await this.request("/api/v1/users/active-account",{method:"PUT",body:{organizationId:$?.trim()||null},expectNoContent:!0})}async resolveUserId($){let f=$?.trim();if(f)return f;let Q=(this.getCurrentUserIdFn?await this.getCurrentUserIdFn():void 0)?.trim();if(Q)return Q;let Z=await this.fetchMe();if(!Z.id?.trim())throw Error("Unable to resolve current user id");return Z.id}async resolveOrganizationMemberId($,f){let J=f?.trim();if(J)return J;let Z=(this.getOrganizationMemberIdFn?await this.getOrganizationMemberIdFn($):void 0)?.trim();if(Z)return Z;let j=(await this.fetchUserOrganizations()).find((X)=>X.organizationId===$)?.memberId;if(!j?.trim())throw Error(`Unable to resolve memberId for organization ${$}`);return j}async request($,f){let J=(await this.getAuthTokenFn())?.trim();if(!J)throw Error("No Cline account auth token found");let Q=this.getHeadersFn?await this.getHeadersFn():{},Z=new AbortController,W=setTimeout(()=>Z.abort(),this.requestTimeoutMs);try{let j=await this.fetchImpl(new URL($,this.apiBaseUrl),{method:f?.method??"GET",headers:{Authorization:`Bearer ${J}`,"Content-Type":"application/json",...Q??{}},body:f?.body!==void 0?JSON.stringify(f.body):void 0,signal:Z.signal});if(j.status===204||f?.expectNoContent){if(!j.ok)throw Error(`Cline account request failed with status ${j.status}`);return}let X=await j.text(),H;if(X.trim())try{H=JSON.parse(X)}catch{if(!j.ok)throw Error(I7(j.status,X,void 0));throw Error("Cline account response was not valid JSON")}if(!j.ok)throw Error(I7(j.status,X,H));if(typeof H==="object"&&H!==null){let Y=H;if(typeof Y.success==="boolean"){if(!Y.success)throw Error(Y.error||"Cline account request failed");if(Y.data!==void 0)return Y.data}}if(H===void 0||H===null)throw Error("Cline account response payload was empty");return H}finally{clearTimeout(W)}}}function x7($){return $.action==="clineAccount"}async function m7($,f){switch($.operation){case"fetchMe":return f.fetchMe();case"fetchBalance":return f.fetchBalance($.userId);case"fetchUsageTransactions":return f.fetchUsageTransactions($.userId);case"fetchPaymentTransactions":return f.fetchPaymentTransactions($.userId);case"fetchUserOrganizations":return f.fetchUserOrganizations();case"fetchOrganizationBalance":return f.fetchOrganizationBalance($.organizationId);case"fetchOrganizationUsageTransactions":return f.fetchOrganizationUsageTransactions({organizationId:$.organizationId,memberId:$.memberId});case"switchAccount":return await f.switchAccount($.organizationId),{updated:!0};case"fetchFeaturebaseToken":return f.fetchFeaturebaseToken?.();default:throw Error(`Unsupported Cline account operation: ${String($)}`)}}class Yf{executor;constructor($){this.executor=$}async fetchMe(){return this.request({action:"clineAccount",operation:"fetchMe"})}async fetchBalance($){return this.request({action:"clineAccount",operation:"fetchBalance",...$?.trim()?{userId:$.trim()}:{}})}async fetchUsageTransactions($){return this.request({action:"clineAccount",operation:"fetchUsageTransactions",...$?.trim()?{userId:$.trim()}:{}})}async fetchPaymentTransactions($){return this.request({action:"clineAccount",operation:"fetchPaymentTransactions",...$?.trim()?{userId:$.trim()}:{}})}async fetchUserOrganizations(){return this.request({action:"clineAccount",operation:"fetchUserOrganizations"})}async fetchOrganizationBalance($){let f=$.trim();if(!f)throw Error("organizationId is required");return this.request({action:"clineAccount",operation:"fetchOrganizationBalance",organizationId:f})}async fetchOrganizationUsageTransactions($){let f=$.organizationId.trim();if(!f)throw Error("organizationId is required");return this.request({action:"clineAccount",operation:"fetchOrganizationUsageTransactions",organizationId:f,...$.memberId?.trim()?{memberId:$.memberId.trim()}:{}})}async switchAccount($){await this.request({action:"clineAccount",operation:"switchAccount",organizationId:$?.trim()||null})}async fetchFeaturebaseToken(){return this.request({action:"clineAccount",operation:"fetchFeaturebaseToken"})}async request($){return(await this.executor.runProviderAction($)).result}}function Vf($){return{onAuth:({url:f,instructions:J})=>{if($.onOutput?.(J??"Complete sign-in in your browser."),$.openUrl)try{Promise.resolve($.openUrl(f)).catch((Q)=>{$.onOpenUrlError?.({url:f,error:Q})})}catch(Q){$.onOpenUrlError?.({url:f,error:Q})}$.onOutput?.(f)},onPrompt:$.onPrompt,onServerListening:$.onServerListening,onServerClose:$.onServerClose}}G0();import{getClineEnvironmentConfig as qf}from"@cline/shared";function WV(){let $;return{promise:new Promise((J)=>{$=J}),resolve:$}}async function e0($){let f=await import("node:http"),J=$.host??"127.0.0.1",Q=$.timeoutMs??300000,Z=$.successHtml??jV,W=WV(),j=!1,X=null,H=null,Y=null,V=(G)=>{if(j)return;j=!0,W.resolve(G)},A=()=>{if(X)clearTimeout(X),X=null;let G=Y;if(Y=null,H)H.close(),H=null;if(G!==null&&$.onClose)Promise.resolve($.onClose({host:J,port:G})).catch(()=>{})},B=async()=>{return X=setTimeout(()=>{A(),V(null)},Q),W.promise};for(let G of $.ports){let K=f.createServer((F,P)=>{try{let U=new URL(F.url||"",`http://${J}:${G}`);if(U.pathname!==$.callbackPath){P.statusCode=404,P.end("Not found");return}let z={url:U,code:U.searchParams.get("code")??void 0,state:U.searchParams.get("state")??void 0,provider:U.searchParams.get("provider")??void 0,error:U.searchParams.get("error")??void 0};if(z.error){P.statusCode=400,P.end(`Authentication failed: ${z.error}`),A(),V(z);return}if(!z.code){P.statusCode=400,P.end("Missing authorization code");return}if($.expectedState&&z.state!==$.expectedState){P.statusCode=400,P.end("State mismatch");return}P.statusCode=200,P.setHeader("Content-Type","text/html; charset=utf-8"),P.end(Z),A(),V(z)}catch{P.statusCode=500,P.end("Internal error")}}),D=await new Promise((F)=>{let P=(U)=>{K.off("error",P),F({bound:!1,error:U})};K.once("error",P),K.listen(G,J,()=>{K.off("error",P),H=K,F({bound:!0})})});if(D.error){if(D.error.code==="EADDRINUSE")continue;throw A(),D.error}if(D.bound){Y=G;let F=`http://${J}:${G}${$.callbackPath}`;if($.onListening)await Promise.resolve($.onListening({host:J,port:G,callbackUrl:F})).catch(()=>{});return{callbackUrl:F,waitForCallback:B,cancelWait:()=>{A(),V(null)},close:()=>{A(),V(null)}}}}return{callbackUrl:"",waitForCallback:async()=>null,cancelWait:()=>{},close:()=>{}}}var jV=`<!DOCTYPE html>
|
|
1
|
+
import{createRequire as pA}from"node:module";var cA=Object.defineProperty;var dA=($)=>$;function lA($,f){this[$]=dA.bind(null,f)}var b4=($,f)=>{for(var J in f)cA($,J,{get:f[J],enumerable:!0,configurable:!0,set:lA.bind(f,J)})};var $1=($,f)=>()=>($&&(f=$($=0)),f);var F9=pA(import.meta.url);import{SDK_ERROR_TELEMETRY_EVENT as iA}from"@cline/shared";function v($,f,J){$?.capture({event:f,properties:J})}function n2($){if(!$)return;return $.substring(0,nA)}function aA($){if(typeof $==="string")return"Error";return $.name?.trim()||$.constructor?.name||"Error"}function tA($){return typeof $==="string"?$:$.message}function L9($,f){return $.some((J)=>f.has(J.trim().toLowerCase()))}function sA($){v($,k.CLIENT.EXTENSION_ACTIVATED)}function m4($,f){let J=[...f.vcs_types],W={root_count:f.root_count,vcs_types:J,is_multi_root:f.root_count>1,has_git:L9(J,new Set(["git"])),has_mercurial:L9(J,new Set(["mercurial","hg"]))};if(f.init_duration_ms!==void 0)W.init_duration_ms=f.init_duration_ms;if(f.feature_flag_enabled!==void 0)W.feature_flag_enabled=f.feature_flag_enabled;if(f.is_remote_workspace!==void 0)W.is_remote_workspace=f.is_remote_workspace;v($,k.WORKSPACE.INITIALIZED,W)}function g4($,f,J){v($,k.WORKSPACE.INIT_ERROR,{error_type:aA(f),error_message:n2(tA(f)),fallback_to_single_root:J.fallback_to_single_root,workspace_count:J.workspace_count??0})}function oA($,f){v($,k.WORKSPACE.PATH_RESOLVED,{...f})}function R$($,f){v($,k.USER.AUTH_STARTED,{provider:f})}function D$($,f){v($,k.USER.AUTH_SUCCEEDED,{provider:f})}function L$($,f,J){v($,k.USER.AUTH_FAILED,{provider:f,errorMessage:n2(J)})}function f1($,f,J){v($,k.USER.AUTH_LOGGED_OUT,{provider:f,reason:J})}function eA($,f){v($,k.USER.PROVIDER_CONFIGURED,{provider:f})}function O9($,f){$?.captureRequired(k.USER.TELEMETRY_OPT_OUT,f)}function O$($,f){let J=f.id?.trim();if(J)$?.setDistinctId(J);$?.updateCommonProperties({account_id:f.id,account_email:f.email,provider:f.provider,organization_id:f.organizationId,organization_name:f.organizationName,member_id:f.memberId})}function v4($,f){v($,k.TASK.CREATED,f)}function u4($,f){v($,k.TASK.RESTARTED,f)}function a2($,f){v($,k.TASK.COMPLETED,f)}function Tf($,f){v($,k.TASK.CONVERSATION_TURN,{...f,timestamp:new Date().toISOString()})}function c4($,f){v($,k.TASK.TOKEN_USAGE,f)}function d4($,f,J){v($,k.TASK.MODE_SWITCH,{ulid:f,mode:J})}function l4($,f){v($,k.TASK.TOOL_USED,f)}function p4($,f){v($,k.TASK.SKILL_USED,f)}function r4($,f){v($,k.TASK.DIFF_EDIT_FAILED,f)}function t2($,f){v($,k.TASK.PROVIDER_API_ERROR,{...f,errorMessage:n2(f.errorMessage)??"unknown",timestamp:new Date().toISOString()})}function _9($,f){v($,k.SDK.TOOL_TIMEOUT,$V(f))}function $V($){let f={};for(let[J,W]of Object.entries($))if(W!==void 0)f[J]=W;return f}function i4($,f,J){v($,k.TASK.MENTION_USED,{mentionType:f,contentLength:J,timestamp:new Date().toISOString()})}function n4($,f,J,W){v($,k.TASK.MENTION_FAILED,{mentionType:f,errorType:J,errorMessage:n2(W),timestamp:new Date().toISOString()})}function a4($,f,J,W,Z){v($,k.TASK.MENTION_SEARCH_RESULTS,{queryLength:f.length,resultCount:J,searchType:W,isEmpty:Z,timestamp:new Date().toISOString()})}function J1($,f){v($,k.TASK.AGENT_CREATED,{...f,timestamp:new Date().toISOString()})}function t4($,f){v($,k.TASK.AGENT_TEAM_CREATED,{...f,timestamp:new Date().toISOString()})}function s2($,f){v($,f.event==="ended"?k.TASK.SUBAGENT_COMPLETED:k.TASK.SUBAGENT_STARTED,{...f,timestamp:new Date().toISOString()})}function s4($,f,J,W){v($,k.HOOKS.DISCOVERY_COMPLETED,{hookName:f,globalCount:J,workspaceCount:W,totalCount:J+W,timestamp:new Date().toISOString()})}function o4($,f){v($,k.TASK.COMPACTION_EXECUTED,{...f,timestamp:new Date().toISOString()})}function e4($,f){v($,k.TASK.COMPACTION_SKIPPED,{...f,timestamp:new Date().toISOString()})}var nA=500,k;var B0=$1(()=>{k={CLIENT:{EXTENSION_ACTIVATED:"user.extension_activated"},SESSION:{STARTED:"session.started",ENDED:"session.ended"},USER:{AUTH_STARTED:"user.auth_started",AUTH_SUCCEEDED:"user.auth_succeeded",AUTH_FAILED:"user.auth_failed",AUTH_LOGGED_OUT:"user.auth_logged_out",PROVIDER_CONFIGURED:"user.provider_configured",TELEMETRY_OPT_OUT:"user.opt_out"},TASK:{CREATED:"task.created",RESTARTED:"task.restarted",COMPLETED:"task.completed",CONVERSATION_TURN:"task.conversation_turn",TOKEN_USAGE:"task.tokens",MODE_SWITCH:"task.mode",TOOL_USED:"task.tool_used",SKILL_USED:"task.skill_used",DIFF_EDIT_FAILED:"task.diff_edit_failed",PROVIDER_API_ERROR:"task.provider_api_error",MENTION_USED:"task.mention_used",MENTION_FAILED:"task.mention_failed",MENTION_SEARCH_RESULTS:"task.mention_search_results",AGENT_CREATED:"task.agent_created",AGENT_TEAM_CREATED:"task.agent_team_created",SUBAGENT_STARTED:"task.subagent_started",SUBAGENT_COMPLETED:"task.subagent_completed",COMPACTION_EXECUTED:"task.compaction_executed",COMPACTION_SKIPPED:"task.compaction_skipped"},HOOKS:{DISCOVERY_COMPLETED:"hooks.discovery_completed"},WORKSPACE:{INITIALIZED:"workspace.initialized",INIT_ERROR:"workspace.init_error",PATH_RESOLVED:"workspace.path_resolved"},SDK:{ERROR:iA,TOOL_TIMEOUT:"sdk.tool_timeout"}}});import{mkdirSync as IB,readFileSync as xB,statSync as mB,writeFileSync as gB}from"node:fs";import{dirname as vB}from"node:path";import{resolveGlobalSettingsPath as PQ}from"@cline/shared/storage";import{z as qf}from"zod";function F8(){return R8.parse({})}function uB(){U8=void 0}function cB($){if($.disabledTools)Object.freeze($.disabledTools);if($.disabledPlugins)Object.freeze($.disabledPlugins);return Object.freeze($)}function dB($){let f;try{f=xB($,"utf8")}catch{return F8()}try{let J=R8.safeParse(JSON.parse(f));return J.success?J.data:F8()}catch{return F8()}}function lB(){let $=PQ(),f=mB($,{throwIfNoEntry:!1}),J=f?.mtimeMs??0,W=f?.size??0,Z=U8;if(Z&&Z.path===$&&Z.mtimeMs===J&&Z.size===W)return Z;let Q=cB(f?dB($):F8());return U8={path:$,mtimeMs:J,size:W,value:Q},U8}function c0(){return lB().value}function j1($,f={}){let J=PQ(),W=c0();IB(vB(J),{recursive:!0});let Z=R8.parse($);if(!W.telemetryOptOut&&Z.telemetryOptOut)O9(f.telemetry);gB(J,`${JSON.stringify(Z,null,2)}
|
|
2
|
+
`,"utf8"),uB()}function N6(){return c0().telemetryOptOut}function pB($,f={}){j1({...c0(),telemetryOptOut:$},f)}function Q$($){return new Set($??c0().disabledTools??[])}function D8($){return new Set($??c0().disabledPlugins??[])}function rB($){return Q$().has($)}function M6($){let f=c0(),J=new Set(f.disabledTools??[]),W=J.has($);if(W)J.delete($);else J.add($);return j1({...f,disabledTools:[...J]}),!W}function FQ($,f){let J=[...new Set($.map((Q)=>Q.trim()).filter(Boolean))];if(J.length===0)return;let W=c0(),Z=Q$(W.disabledTools);for(let Q of J)if(f)Z.add(Q);else Z.delete(Q);j1({...W,disabledTools:[...Z]})}function UQ($,f){return FQ([$],f),f}function iB($){return D8().has($)}function nB($,f){let J=$.trim();if(!J)return;let W=c0(),Z=D8(W.disabledPlugins);if(f)Z.add(J);else Z.delete(J);j1({...W,disabledPlugins:[...Z]})}function y6($,f){let J=D8(f);if(J.size===0)return[...$];return $.filter((W)=>!J.has(W))}function p1($,f){let J=Q$(f);if(J.size===0)return[...$];return $.filter((W)=>!J.has(W.name))}function q6($,f){if(!$||$.length===0)return $;let J=Q$(f);if(J.size===0)return $;return $.map((W)=>{if(!W.setup)return W;return{...W,setup:(Z,Q)=>W.setup?.({...Z,registerTool:(j)=>{if(!J.has(j.name))Z.registerTool(j)}},Q)}})}var GQ,R8,U8;var n0=$1(()=>{B0();GQ=qf.preprocess(($)=>Array.isArray($)?$.filter((f)=>typeof f==="string").map((f)=>f.trim()).filter(Boolean):void 0,qf.array(qf.string()).optional()).transform(($)=>{if(!$)return;let f=[...new Set($)].sort((J,W)=>J.localeCompare(W));return f.length>0?f:void 0}),R8=qf.object({telemetryOptOut:qf.boolean().default(!1).catch(!1),disabledTools:GQ.optional(),disabledPlugins:GQ.optional()}).strip().transform(($)=>{let f={telemetryOptOut:$.telemetryOptOut};if($.disabledTools?.length)f.disabledTools=$.disabledTools;if($.disabledPlugins?.length)f.disabledPlugins=$.disabledPlugins;return f})});var n7={};b4(n7,{normalizeUserMessage:()=>sP,buildInitialUserContent:()=>tP});async function tP($,f,J,W){let Z=oP(f),Q=await $F(J,W);if(Z.length===0&&!Q)return $;let j=[{type:"text",text:$},...Z];if(Q)j.push(...Q);return j}function sP($){if($==null)return"";if(typeof $==="string")return $;let f=$.content;if(typeof f==="string")return f;if(!Array.isArray(f))return"";let J=[];for(let W of f)if(W&&typeof W==="object"&&W.type==="text"){let Z=W.text;if(typeof Z==="string")J.push(Z)}return J.join(`
|
|
3
|
+
`)}function oP($){if(!$||$.length===0)return[];let f=[];for(let J of $){let W=eP(J);if(W)f.push(W)}return f}function eP($){let f=$.trim();if(!f)return;let J=f.match(/^data:([^;,]+);base64,(.+)$/);if(J){let W=J[1],Z=J[2];if(!W||!Z)return;return{type:"image",mediaType:W,data:Z}}return{type:"image",mediaType:"image/png",data:f}}async function $F($,f){if(!$||$.length===0)return;let J=f??(async()=>{throw Error("File loading is not configured in this runtime. Provide userFileContentLoader to enable userFiles support.")}),W=await Promise.all($.map(async(Z)=>{let Q=Z.replace(/\\/g,"/");try{let j=await J(Z);return{type:"file",path:Q,content:j}}catch(j){let H=j instanceof Error?j.message:String(j);return{type:"file",path:Q,content:`Error fetching content: ${H}`}}}));if(W.length===0)return;return W}var m3={};b4(m3,{updateMcpServerOAuthState:()=>$2,setMcpServerDisabled:()=>of,resolveMcpServerRegistrations:()=>h$,resolveDefaultMcpSettingsPath:()=>S0,registerMcpServersFromSettingsFile:()=>f2,normalizeMcpServerOAuthState:()=>Zf,loadMcpSettingsFile:()=>sf,listMcpServerOAuthStatuses:()=>h5,hasMcpSettingsFile:()=>P1,getMcpServerOAuthState:()=>ef});import{existsSync as cF,mkdirSync as C3,readFileSync as w5,writeFileSync as E3}from"node:fs";import{dirname as b3}from"node:path";import{resolveMcpSettingsPath as dF}from"@cline/shared/storage";import{z as y}from"zod";function q5($){if(!$)return;if($==="http")return"streamableHttp";return $}function S0(){return dF()}function $U($){let f=w5($,"utf8"),J;try{J=JSON.parse(f)}catch(W){let Z=W instanceof Error?W.message:String(W);throw Error(`Failed to parse MCP settings JSON at "${$}": ${Z}`)}if(!J||typeof J!=="object"||Array.isArray(J))throw Error(`Invalid MCP settings at "${$}": expected object.`);return J}function x3($,f){if(!Object.hasOwn($,f))return;let J=$[f];if(!J||typeof J!=="object"||Array.isArray(J))return;return J}function fU($,f,J){Object.defineProperty($,f,{value:J,enumerable:!0,configurable:!0,writable:!0})}function sf($={}){let f=$.filePath??S0(),J=w5(f,"utf8"),W;try{W=JSON.parse(J)}catch(Q){let j=Q instanceof Error?Q.message:String(Q);throw Error(`Failed to parse MCP settings JSON at "${f}": ${j}`)}let Z=eF.safeParse(W);if(!Z.success){let Q=Z.error.issues.map((j)=>{let H=j.path.join(".");return H?`${H}: ${j.message}`:j.message}).join("; ");throw Error(`Invalid MCP settings at "${f}": ${Q}`)}return Z.data}function JU($){let f=w5($,"utf8"),J;try{J=JSON.parse(f)}catch(Q){let j=Q instanceof Error?Q.message:String(Q);throw Error(`Failed to parse MCP settings JSON at "${$}": ${j}`)}if(!J||typeof J!=="object"||Array.isArray(J))throw Error(`Invalid MCP settings at "${$}": expected object`);let W=J,Z=W.mcpServers;if(!Z||typeof Z!=="object"||Array.isArray(Z))throw Error(`Invalid MCP settings at "${$}": mcpServers must be an object`);return W}function Zf($){if(!$)return;let f={...$.clientInformation?{clientInformation:$.clientInformation}:{},...$.tokens?{tokens:$.tokens}:{},...$.codeVerifier?{codeVerifier:$.codeVerifier}:{},...$.discoveryState?{discoveryState:$.discoveryState}:{},...$.redirectUrl?{redirectUrl:$.redirectUrl}:{},...$.lastError?{lastError:$.lastError}:{},...$.lastAuthenticatedAt?{lastAuthenticatedAt:$.lastAuthenticatedAt}:{}};return Object.keys(f).length>0?f:void 0}function WU($){if($===void 0)return;let f=S5.safeParse($);if(!f.success)return;return Zf(f.data)}function P1($={}){let f=$.filePath??S0();return cF(f)}function h$($={}){let f=sf($);return Object.entries(f.mcpServers).map(([J,W])=>({name:J,transport:W.transport,disabled:W.disabled,metadata:W.metadata,oauth:W.oauth}))}function of($){let f=$.filePath??S0(),J=$.name.trim();if(!J)throw Error("MCP server settings toggle requires a server name.");let W=$U(f),Z=W.mcpServers;if(!Z||typeof Z!=="object"||Array.isArray(Z))throw Error(`Invalid MCP settings at "${f}": mcpServers must be an object.`);let Q={...Z},j=x3(Q,J);if(!j)throw Error(`Unknown MCP server: ${J}`);let H={...j};if($.disabled)H.disabled=!0;else delete H.disabled;fU(Q,J,H),C3(b3(f),{recursive:!0}),E3(f,`${JSON.stringify({...W,mcpServers:Q},null,2)}
|
|
4
|
+
`)}function ef($,f={}){let J=sf(f);if(!Object.hasOwn(J.mcpServers,$))return;return Zf(J.mcpServers[$]?.oauth)}function $2($,f,J={}){let W=J.filePath??S0(),Z=JU(W),Q=Z.mcpServers,j=x3(Q,$);if(!j)throw Error(`Unknown MCP server: ${$}`);let H=WU(j.oauth)??{},X=Zf(f(H));if(X)j.oauth=X;else delete j.oauth;return C3(b3(W),{recursive:!0}),E3(W,`${JSON.stringify(Z,null,2)}
|
|
5
|
+
`,"utf8"),X??{}}function h5($={}){return h$($).map((J)=>{let W=J.transport.type!=="stdio",Z=J.oauth?.tokens?.access_token;return{serverName:J.name,oauthSupported:W,oauthConfigured:W&&typeof Z==="string"&&Z.trim().length>0,lastError:J.oauth?.lastError,lastAuthenticatedAt:J.oauth?.lastAuthenticatedAt}}).sort((J,W)=>J.serverName.localeCompare(W.serverName))}async function f2($,f={}){let J=h$(f);for(let W of J)await $.registerServer(W);return J}var tf,k3,S5,lF,pF,rF,iF,nF,aF,I3,tF,sF,oF,eF;var YJ=$1(()=>{tf=y.record(y.string(),y.string()),k3=y.record(y.string(),y.unknown()),S5=y.object({clientInformation:y.record(y.string(),y.unknown()).optional(),tokens:y.record(y.string(),y.unknown()).optional(),codeVerifier:y.string().optional(),discoveryState:y.record(y.string(),y.unknown()).optional(),redirectUrl:y.string().url().optional(),lastError:y.string().optional(),lastAuthenticatedAt:y.number().int().positive().optional()}).strip(),lF=y.object({type:y.literal("stdio"),command:y.string().min(1),args:y.array(y.string()).optional(),cwd:y.string().min(1).optional(),env:tf.optional()}),pF=y.object({type:y.literal("sse"),url:y.string().url(),headers:tf.optional()}),rF=y.object({type:y.literal("streamableHttp"),url:y.string().url(),headers:tf.optional()}),iF=y.discriminatedUnion("type",[lF,pF,rF]),nF=y.object({transport:iF,disabled:y.boolean().optional(),metadata:k3.optional(),oauth:S5.optional()}),aF=y.enum(["stdio","sse","http","streamableHttp"]).optional(),I3=y.object({type:y.enum(["stdio","sse","streamableHttp"]).optional(),transportType:aF,disabled:y.boolean().optional(),metadata:k3.optional(),oauth:S5.optional()});tF=I3.extend({command:y.string().min(1),args:y.array(y.string()).optional(),cwd:y.string().min(1).optional(),env:tf.optional()}).superRefine(($,f)=>{let J=$.type??q5($.transportType);if(J&&J!=="stdio")f.addIssue({code:y.ZodIssueCode.custom,message:'Expected type "stdio" for command-based MCP server',path:["type"]})}).transform(($)=>({transport:{type:"stdio",command:$.command,args:$.args,cwd:$.cwd,env:$.env},disabled:$.disabled,metadata:$.metadata,oauth:$.oauth})),sF=I3.extend({url:y.string().url(),headers:tf.optional()}).superRefine(($,f)=>{let J=$.type??q5($.transportType)??"sse";if(J!=="sse"&&J!=="streamableHttp")f.addIssue({code:y.ZodIssueCode.custom,message:'Expected type "sse" or "streamableHttp" for URL-based MCP server',path:["type"]})}).transform(($)=>{if(($.type??q5($.transportType)??"sse")==="streamableHttp")return{transport:{type:"streamableHttp",url:$.url,headers:$.headers},disabled:$.disabled,metadata:$.metadata,oauth:$.oauth};return{transport:{type:"sse",url:$.url,headers:$.headers},disabled:$.disabled,metadata:$.metadata,oauth:$.oauth}}),oF=y.union([nF,tF,sF]),eF=y.object({mcpServers:y.record(y.string(),oF)}).passthrough()});import{existsSync as DO,mkdirSync as LO,readFileSync as OO,writeFileSync as _O}from"node:fs";import{resolve as zO}from"node:path";import{resolveSessionDataDir as TO}from"@cline/shared/storage";import{nanoid as NO}from"nanoid";import*as MO from"node-machine-id";function y1($){let f=$?.trim();if(f)return f;let J=wO();if(J)return J;return SO()}function qO(){let $=MO;return $.machineIdSync??$.default?.machineIdSync}function wO(){try{let $=qO();if(!$)return;return $().trim()||void 0}catch{return}}function SO(){let $=TO(),f=zO($,yO);try{if(DO(f)){let W=OO(f,"utf8").trim();if(W.length>0)return W}}catch{}let J=`cl-${NO()}`;try{LO($,{recursive:!0}),_O(f,J,"utf8")}catch{}return J}var yO="machine-id";var EJ=()=>{};class c2{name;metadata;meter;logger;enabled;distinctId;commonProperties;counters=new Map;histograms=new Map;gauges=new Map;gaugeValues=new Map;meterProvider;loggerProvider;constructor($){this.name=$.name??"OpenTelemetryAdapter",this.metadata={...$.metadata},this.meterProvider=$.meterProvider,this.loggerProvider=$.loggerProvider,this.meter=$.meterProvider?.getMeter("cline")??null,this.logger=$.loggerProvider?.getLogger("cline")??null,this.enabled=$.enabled??!0,this.distinctId=$.distinctId,this.commonProperties=$.commonProperties?{...$.commonProperties}:{}}emit($,f){if(!this.isEnabled())return;this.emitLog($,f,!1)}emitRequired($,f){this.emitLog($,f,!0)}recordCounter($,f,J,W,Z=!1){if(!this.meter||!Z&&!this.isEnabled())return;let Q=this.counters.get($);if(!Q)Q=this.meter.createCounter($,W?{description:W}:void 0),this.counters.set($,Q);Q.add(f,this.flattenProperties(this.buildAttributes(J)))}recordHistogram($,f,J,W,Z=!1){if(!this.meter||!Z&&!this.isEnabled())return;let Q=this.histograms.get($);if(!Q)Q=this.meter.createHistogram($,W?{description:W}:void 0),this.histograms.set($,Q);Q.record(f,this.flattenProperties(this.buildAttributes(J)))}recordGauge($,f,J,W,Z=!1){if(!this.meter||!Z&&!this.isEnabled())return;let Q=this.buildAttributes(J),j=JSON.stringify(Q),H=this.gaugeValues.get($);if(f===null){if(H){if(H.delete(j),H.size===0)this.gaugeValues.delete($),this.gauges.delete($)}return}let X=H;if(!X)X=new Map,this.gaugeValues.set($,X);if(!this.gauges.has($)){let Y=this.meter.createObservableGauge($,W?{description:W}:void 0);Y.addCallback((A)=>{for(let V of this.snapshotGaugeSeries($))A.observe(V.value,this.flattenProperties(V.attributes))}),this.gauges.set($,Y)}X.set(j,{value:f,attributes:Q})}isEnabled(){return typeof this.enabled==="function"?this.enabled():this.enabled}setDistinctId($){this.distinctId=$}setCommonProperties($){this.commonProperties={...$}}updateCommonProperties($){this.commonProperties={...this.commonProperties,...$}}async flush(){await Promise.all([this.meterProvider?.forceFlush?.(),this.loggerProvider?.forceFlush?.()])}async dispose(){await Promise.all([this.meterProvider?.shutdown?.(),this.loggerProvider?.shutdown?.()])}emitLog($,f,J){if(!this.logger)return;let W=this.flattenProperties(this.buildAttributes(f,J));this.logger.emit({severityText:"INFO",body:$,attributes:W})}buildAttributes($,f=!1){return{...this.commonProperties,...this.metadata,...$,...this.distinctId?{distinct_id:this.distinctId}:{},...f?{_required:!0}:{}}}snapshotGaugeSeries($){let f=this.gaugeValues.get($);if(!f)return[];return Array.from(f.values(),(J)=>({value:J.value,attributes:J.attributes?{...J.attributes}:void 0}))}flattenProperties($,f="",J=new WeakSet,W=0){if(!$)return{};let Z={},Q=100,j=10;for(let[H,X]of Object.entries($)){if(H==="__proto__"||H==="constructor"||H==="prototype")continue;let Y=f?`${f}.${H}`:H;if(X===null||X===void 0){Z[Y]=String(X);continue}if(Array.isArray(X)){let A=X.length>Q?X.slice(0,Q):X;try{Z[Y]=JSON.stringify(A)}catch{Z[Y]="[UnserializableArray]"}if(X.length>Q)Z[`${Y}_truncated`]=!0,Z[`${Y}_original_length`]=X.length;continue}if(typeof X==="object"){if(X instanceof Date){Z[Y]=X.toISOString();continue}if(X instanceof Error){Z[Y]=X.message;continue}if(J.has(X)){Z[Y]="[Circular]";continue}if(W>=j){Z[Y]="[MaxDepthExceeded]";continue}J.add(X),Object.assign(Z,this.flattenProperties(X,Y,J,W+1));continue}if(zN(X)){Z[Y]=X;continue}try{Z[Y]=JSON.stringify(X)}catch{Z[Y]=String(X)}}return Z}}function zN($){return typeof $==="string"||typeof $==="number"||typeof $==="boolean"}class R4{name;logger;enabled;constructor($={}){this.name=$.name??"TelemetryLoggerSink",this.logger=$.logger,this.enabled=$.enabled??!0}emit($,f){if(!this.isEnabled())return;this.logger?.log("telemetry.event",{telemetrySink:this.name,event:$,properties:f})}emitRequired($,f){this.logger?.log("telemetry.required_event",{telemetrySink:this.name,severity:"warn",event:$,properties:f})}recordCounter($,f,J,W,Z){if(!Z&&!this.isEnabled())return;this.logger?.debug("telemetry.metric",{telemetrySink:this.name,instrument:"counter",name:$,value:f,attributes:J,description:W,required:Z===!0})}recordHistogram($,f,J,W,Z){if(!Z&&!this.isEnabled())return;this.logger?.debug("telemetry.metric",{telemetrySink:this.name,instrument:"histogram",name:$,value:f,attributes:J,description:W,required:Z===!0})}recordGauge($,f,J,W,Z){if(!Z&&!this.isEnabled())return;this.logger?.debug("telemetry.metric",{telemetrySink:this.name,instrument:"gauge",name:$,value:f,attributes:J,description:W,required:Z===!0})}isEnabled(){return typeof this.enabled==="function"?this.enabled():this.enabled}async flush(){}async dispose(){}}class d2{adapters;metadata;distinctId;commonProperties;constructor($={}){if(this.adapters=[...$.adapters??[]],$.logger)this.adapters.push(new R4({logger:$.logger}));this.metadata={...$.metadata??{}},this.distinctId=$.distinctId,this.commonProperties={...$.commonProperties??{}}}addAdapter($){this.adapters.push($)}setDistinctId($){this.distinctId=$}setMetadata($){this.metadata={...$}}updateMetadata($){this.metadata={...this.metadata,...$}}setCommonProperties($){this.commonProperties={...$}}updateCommonProperties($){this.commonProperties={...this.commonProperties,...$}}isEnabled(){return this.adapters.some(($)=>$.isEnabled())}capture($){let f=this.buildAttributes($.properties);for(let J of this.adapters)J.emit($.event,f)}captureRequired($,f){let J=this.buildAttributes(f);for(let W of this.adapters)W.emitRequired($,J)}recordCounter($,f,J,W,Z=!1){let Q=this.buildAttributes(J);for(let j of this.adapters)j.recordCounter($,f,Q,W,Z)}recordHistogram($,f,J,W,Z=!1){let Q=this.buildAttributes(J);for(let j of this.adapters)j.recordHistogram($,f,Q,W,Z)}recordGauge($,f,J,W,Z=!1){let Q=this.buildAttributes(J);for(let j of this.adapters)j.recordGauge($,f,Q,W,Z)}async flush(){await Promise.all(this.adapters.map(($)=>$.flush()))}async dispose(){await Promise.all(this.adapters.map(($)=>$.dispose()))}buildAttributes($){return{...this.commonProperties,...$,...this.metadata,...this.distinctId?{distinct_id:this.distinctId}:{}}}}var bZ=()=>{};import{metrics as TN,trace as NN}from"@opentelemetry/api";import{logs as MN}from"@opentelemetry/api-logs";import{OTLPLogExporter as yN}from"@opentelemetry/exporter-logs-otlp-http";import{OTLPMetricExporter as qN}from"@opentelemetry/exporter-metrics-otlp-http";import{OTLPTraceExporter as wN}from"@opentelemetry/exporter-trace-otlp-http";import{resourceFromAttributes as SN}from"@opentelemetry/resources";import{BatchLogRecordProcessor as hN,ConsoleLogRecordExporter as CN,LoggerProvider as EN}from"@opentelemetry/sdk-logs";import{ConsoleMetricExporter as bN,MeterProvider as kN,PeriodicExportingMetricReader as UY}from"@opentelemetry/sdk-metrics";import{BatchSpanProcessor as IN,ConsoleSpanExporter as xN,SimpleSpanProcessor as mN}from"@opentelemetry/sdk-trace-base";import{NodeTracerProvider as gN}from"@opentelemetry/sdk-trace-node";import{ATTR_SERVICE_NAME as vN,ATTR_SERVICE_VERSION as uN}from"@opentelemetry/semantic-conventions";class RY{distinctId;metadata;commonProperties;constructor($={}){this.distinctId=$.distinctId,this.metadata={...$.metadata??{}},this.commonProperties={...$.commonProperties??{}}}setDistinctId($){this.distinctId=$}setMetadata($){this.metadata={...$}}updateMetadata($){this.metadata={...this.metadata,...$}}setCommonProperties($){this.commonProperties={...$}}updateCommonProperties($){this.commonProperties={...this.commonProperties,...$}}isEnabled(){return!1}capture($){this.resolveProperties($.properties)}captureRequired($,f){this.resolveProperties(f)}recordCounter(){}recordHistogram(){}recordGauge(){}async flush(){}async dispose(){}resolveProperties($){return{...this.commonProperties,...$,...this.metadata,...this.distinctId?{distinct_id:this.distinctId}:{}}}}class l2{meterProvider;loggerProvider;tracerProvider;options;constructor($={}){this.options=$;let f=SN({[vN]:$.serviceName??"cline",...$.serviceVersion?{[uN]:$.serviceVersion}:{}});if(this.meterProvider=this.createMeterProvider(f),this.loggerProvider=this.createLoggerProvider(f),this.tracerProvider=this.createTracerProvider(f),this.meterProvider)TN.setGlobalMeterProvider(this.meterProvider);if(this.loggerProvider)MN.setGlobalLoggerProvider(this.loggerProvider);if(this.tracerProvider)this.tracerProvider.register()}getTracer($="cline",f){return NN.getTracer($,f??this.options.serviceVersion)}createAdapter($){return new c2({...$,meterProvider:this.meterProvider,loggerProvider:this.loggerProvider})}createTelemetryService($){let f=this.createAdapter({name:$.name,enabled:this.options.enabled,metadata:$.metadata});return new d2({...$,adapters:[f],distinctId:y1($.distinctId)})}async forceFlush(){await Promise.all([this.meterProvider?.forceFlush?.(),this.loggerProvider?.forceFlush?.(),this.tracerProvider?.forceFlush?.()])}async dispose(){await Promise.all([this.meterProvider?.shutdown?.(),this.loggerProvider?.shutdown?.(),this.tracerProvider?.shutdown?.()])}createMeterProvider($){let f=kZ(this.options.metricsExporter);if(f.length===0)return null;let J=Math.max(1000,this.options.metricExportIntervalMs??this.options.metricExportInterval??60000),W=Math.min(30000,Math.floor(J*0.8)),Z=f.map((Q)=>lN(Q,{endpoint:this.options.otlpEndpoint,headers:this.options.otlpHeaders,insecure:this.options.otlpInsecure??!1,protocol:"http/json",interval:J,timeout:W})).filter((Q)=>Q!==null);if(Z.length===0)return null;return new kN({resource:$,readers:Z})}createTracerProvider($){let f=kZ(this.options.tracesExporter);if(f.length===0)return null;let J=this.options.otlpTracesEndpoint??this.options.otlpEndpoint,W=this.options.otlpTracesHeaders??this.options.otlpHeaders,Z=[];for(let Q of f){let j=dN(Q,{endpoint:J,headers:W,insecure:this.options.otlpInsecure??!1,protocol:"http/json"});if(j)Z.push(j)}if(Z.length===0)return null;return new gN({resource:$,spanProcessors:Z})}createLoggerProvider($){let f=kZ(this.options.logsExporter);if(f.length===0)return null;let J=f.map((W)=>{let Z=cN(W,{endpoint:this.options.otlpEndpoint,headers:this.options.otlpHeaders,insecure:this.options.otlpInsecure??!1,protocol:"http/json"});if(!Z)return null;return new hN(Z,{maxQueueSize:this.options.logMaxQueueSize??2048,maxExportBatchSize:this.options.logBatchSize??512,scheduledDelayMillis:this.options.logBatchTimeoutMs??this.options.logBatchTimeout??5000})}).filter((W)=>W!==null);if(J.length===0)return null;return new EN({resource:$,processors:J})}}function D4($){let f=new l2($),J=f.createTelemetryService($);return J.captureRequired("telemetry.provider_created",{provider:"opentelemetry",enabled:$.enabled??!0,logsExporter:Array.isArray($.logsExporter)?$.logsExporter.join(","):$.logsExporter,metricsExporter:Array.isArray($.metricsExporter)?$.metricsExporter.join(","):$.metricsExporter,tracesExporter:Array.isArray($.tracesExporter)?$.tracesExporter.join(","):$.tracesExporter,otlpProtocol:$.otlpProtocol,hasOtlpEndpoint:Boolean($.otlpEndpoint),serviceName:$.serviceName,serviceVersion:$.serviceVersion}),{provider:f,telemetry:J}}function k1($){if(N6())return{telemetry:new RY($)};if($.enabled!==!0)return{telemetry:new d2({...$,distinctId:y1($.distinctId)})};return D4($)}function L4($){let{telemetry:f,provider:J}=k1($);return{telemetry:f,provider:J,flush:async()=>{let Q=J;if(Q&&typeof Q.forceFlush==="function")try{await Q.forceFlush()}catch{}},dispose:async()=>{await Promise.allSettled([f.dispose(),J?.dispose()])}}}function kZ($){if(!$)return[];return(Array.isArray($)?$:$.split(",")).map((J)=>J.trim()).filter((J)=>J==="console"||J==="otlp")}function cN($,f){if($==="console")return new CN;if(!f.endpoint)return null;let J=IZ(f.endpoint,"/v1/logs");return new yN({url:J,headers:f.headers})}function dN($,f){if($==="console")return new mN(new xN);if(!f.endpoint)return null;let J=IZ(f.endpoint,"/v1/traces");return new IN(new wN({url:J,headers:f.headers}))}function lN($,f){if($==="console")return new UY({exporter:new bN,exportIntervalMillis:f.interval,exportTimeoutMillis:f.timeout});if(!f.endpoint)return null;let J=IZ(f.endpoint,"/v1/metrics");return new UY({exporter:new qN({url:J,headers:f.headers}),exportIntervalMillis:f.interval,exportTimeoutMillis:f.timeout})}function IZ($,f){let J=new URL($),W=J.pathname.endsWith("/")?J.pathname.slice(0,-1):J.pathname;return J.pathname=W.endsWith(f)?W:`${W}${f}`,J.toString()}var O4=$1(()=>{n0();EJ();bZ()});var VA={};b4(VA,{createOpenTelemetryTelemetryService:()=>D4,createConfiguredTelemetryService:()=>k1,createConfiguredTelemetryHandle:()=>L4,OpenTelemetryProvider:()=>l2,OpenTelemetryAdapter:()=>c2});var eZ=$1(()=>{O4()});import*as Ep from"@cline/llms";import{buildClineSystemPrompt as kp,buildSdkErrorProperties as Ip,ContributionRegistry as xp,captureSdkError as mp,createClineTelemetryServiceConfig as gp,createClineTelemetryServiceMetadata as vp,createContributionRegistry as up,createTool as cp,emptyWorkspaceManifest as dp,formatDisplayUserInput as lp,noopBasicLogger as pp,normalizeSdkError as rp,normalizeUserInput as ip,parseUserCommandEnvelope as np,registerDisposable as ap,SDK_ERROR_TELEMETRY_EVENT as tp}from"@cline/shared";export*from"@cline/shared/storage";function rA($){if(typeof $!=="object"||$===null||!("error"in $))return;let f=$.error;return typeof f==="string"&&f.trim()?f:void 0}function U9($,f,J){let W=rA(J);if(W)return W;let Z=f.trim();if(Z){let Q=Z.length>200?`${Z.slice(0,200)}...`:Z;return`Cline account request failed with status ${$}: ${Q}`}return`Cline account request failed with status ${$}`}class k4{apiBaseUrl;getAuthTokenFn;getCurrentUserIdFn;getOrganizationMemberIdFn;getHeadersFn;requestTimeoutMs;fetchImpl;constructor($){let f=$.apiBaseUrl.trim();if(!f)throw Error("apiBaseUrl is required");this.apiBaseUrl=f,this.getAuthTokenFn=$.getAuthToken,this.getCurrentUserIdFn=$.getCurrentUserId,this.getOrganizationMemberIdFn=$.getOrganizationMemberId,this.getHeadersFn=$.getHeaders,this.requestTimeoutMs=$.requestTimeoutMs??30000,this.fetchImpl=$.fetchImpl??fetch}async fetchMe(){return this.request("/api/v1/users/me")}async fetchRemoteConfig(){return this.request("/api/v1/users/me/remote-config")}async fetchFeaturebaseToken(){try{return await this.request("/api/v1/users/me/featurebase-token")}catch{return}}async fetchBalance($){let f=await this.resolveUserId($);return this.request(`/api/v1/users/${encodeURIComponent(f)}/balance`)}async fetchUsageTransactions($){let f=await this.resolveUserId($);return(await this.request(`/api/v1/users/${encodeURIComponent(f)}/usages`)).items??[]}async fetchPaymentTransactions($){let f=await this.resolveUserId($);return(await this.request(`/api/v1/users/${encodeURIComponent(f)}/payments`)).paymentTransactions??[]}async fetchUserOrganizations(){return(await this.fetchMe()).organizations??[]}async fetchOrganization($){let f=$.trim();if(!f)throw Error("organizationId is required");return this.request(`/api/v1/organizations/${encodeURIComponent(f)}`)}async fetchOrganizationBalance($){let f=$.trim();if(!f)throw Error("organizationId is required");return this.request(`/api/v1/organizations/${encodeURIComponent(f)}/balance`)}async fetchOrganizationUsageTransactions($){let f=$.organizationId.trim();if(!f)throw Error("organizationId is required");let J=await this.resolveOrganizationMemberId(f,$.memberId);return(await this.request(`/api/v1/organizations/${encodeURIComponent(f)}/members/${encodeURIComponent(J)}/usages`)).items??[]}async switchAccount($){await this.request("/api/v1/users/active-account",{method:"PUT",body:{organizationId:$?.trim()||null},expectNoContent:!0})}async resolveUserId($){let f=$?.trim();if(f)return f;let W=(this.getCurrentUserIdFn?await this.getCurrentUserIdFn():void 0)?.trim();if(W)return W;let Z=await this.fetchMe();if(!Z.id?.trim())throw Error("Unable to resolve current user id");return Z.id}async resolveOrganizationMemberId($,f){let J=f?.trim();if(J)return J;let Z=(this.getOrganizationMemberIdFn?await this.getOrganizationMemberIdFn($):void 0)?.trim();if(Z)return Z;let j=(await this.fetchUserOrganizations()).find((H)=>H.organizationId===$)?.memberId;if(!j?.trim())throw Error(`Unable to resolve memberId for organization ${$}`);return j}async request($,f){let J=(await this.getAuthTokenFn())?.trim();if(!J)throw Error("No Cline account auth token found");let W=this.getHeadersFn?await this.getHeadersFn():{},Z=new AbortController,Q=setTimeout(()=>Z.abort(),this.requestTimeoutMs);try{let j=await this.fetchImpl(new URL($,this.apiBaseUrl),{method:f?.method??"GET",headers:{Authorization:`Bearer ${J}`,"Content-Type":"application/json",...W??{}},body:f?.body!==void 0?JSON.stringify(f.body):void 0,signal:Z.signal});if(j.status===204||f?.expectNoContent){if(!j.ok)throw Error(`Cline account request failed with status ${j.status}`);return}let H=await j.text(),X;if(H.trim())try{X=JSON.parse(H)}catch{if(!j.ok)throw Error(U9(j.status,H,void 0));throw Error("Cline account response was not valid JSON")}if(!j.ok)throw Error(U9(j.status,H,X));if(typeof X==="object"&&X!==null){let Y=X;if(typeof Y.success==="boolean"){if(!Y.success)throw Error(Y.error||"Cline account request failed");if(Y.data!==void 0)return Y.data}}if(X===void 0||X===null)throw Error("Cline account response payload was empty");return X}finally{clearTimeout(Q)}}}function R9($){return $.action==="clineAccount"}async function D9($,f){switch($.operation){case"fetchMe":return f.fetchMe();case"fetchBalance":return f.fetchBalance($.userId);case"fetchUsageTransactions":return f.fetchUsageTransactions($.userId);case"fetchPaymentTransactions":return f.fetchPaymentTransactions($.userId);case"fetchUserOrganizations":return f.fetchUserOrganizations();case"fetchOrganizationBalance":return f.fetchOrganizationBalance($.organizationId);case"fetchOrganizationUsageTransactions":return f.fetchOrganizationUsageTransactions({organizationId:$.organizationId,memberId:$.memberId});case"switchAccount":return await f.switchAccount($.organizationId),{updated:!0};case"fetchFeaturebaseToken":return f.fetchFeaturebaseToken?.();default:throw Error(`Unsupported Cline account operation: ${String($)}`)}}class I4{executor;constructor($){this.executor=$}async fetchMe(){return this.request({action:"clineAccount",operation:"fetchMe"})}async fetchBalance($){return this.request({action:"clineAccount",operation:"fetchBalance",...$?.trim()?{userId:$.trim()}:{}})}async fetchUsageTransactions($){return this.request({action:"clineAccount",operation:"fetchUsageTransactions",...$?.trim()?{userId:$.trim()}:{}})}async fetchPaymentTransactions($){return this.request({action:"clineAccount",operation:"fetchPaymentTransactions",...$?.trim()?{userId:$.trim()}:{}})}async fetchUserOrganizations(){return this.request({action:"clineAccount",operation:"fetchUserOrganizations"})}async fetchOrganizationBalance($){let f=$.trim();if(!f)throw Error("organizationId is required");return this.request({action:"clineAccount",operation:"fetchOrganizationBalance",organizationId:f})}async fetchOrganizationUsageTransactions($){let f=$.organizationId.trim();if(!f)throw Error("organizationId is required");return this.request({action:"clineAccount",operation:"fetchOrganizationUsageTransactions",organizationId:f,...$.memberId?.trim()?{memberId:$.memberId.trim()}:{}})}async switchAccount($){await this.request({action:"clineAccount",operation:"switchAccount",organizationId:$?.trim()||null})}async fetchFeaturebaseToken(){return this.request({action:"clineAccount",operation:"fetchFeaturebaseToken"})}async request($){return(await this.executor.runProviderAction($)).result}}function x4($){return{onAuth:({url:f,instructions:J})=>{if($.onOutput?.(J??"Complete sign-in in your browser."),$.openUrl)try{Promise.resolve($.openUrl(f)).catch((W)=>{$.onOpenUrlError?.({url:f,error:W})})}catch(W){$.onOpenUrlError?.({url:f,error:W})}$.onOutput?.(f)},onPrompt:$.onPrompt,onServerListening:$.onServerListening,onServerClose:$.onServerClose}}B0();import{getClineEnvironmentConfig as $6}from"@cline/shared";function fV(){let $;return{promise:new Promise((J)=>{$=J}),resolve:$}}async function W$($){let f=await import("node:http"),J=$.host??"127.0.0.1",W=$.timeoutMs??300000,Z=$.successHtml??JV,Q=fV(),j=!1,H=null,X=null,Y=null,A=(K)=>{if(j)return;j=!0,Q.resolve(K)},V=()=>{if(H)clearTimeout(H),H=null;let K=Y;if(Y=null,X)X.close(),X=null;if(K!==null&&$.onClose)Promise.resolve($.onClose({host:J,port:K})).catch(()=>{})},B=async()=>{return H=setTimeout(()=>{V(),A(null)},W),Q.promise};for(let K of $.ports){let G=f.createServer((P,F)=>{try{let U=new URL(P.url||"",`http://${J}:${K}`);if(U.pathname!==$.callbackPath){F.statusCode=404,F.end("Not found");return}let _={url:U,code:U.searchParams.get("code")??void 0,state:U.searchParams.get("state")??void 0,provider:U.searchParams.get("provider")??void 0,error:U.searchParams.get("error")??void 0};if(_.error){F.statusCode=400,F.end(`Authentication failed: ${_.error}`),V(),A(_);return}if(!_.code){F.statusCode=400,F.end("Missing authorization code");return}if($.expectedState&&_.state!==$.expectedState){F.statusCode=400,F.end("State mismatch");return}F.statusCode=200,F.setHeader("Content-Type","text/html; charset=utf-8"),F.end(Z),V(),A(_)}catch{F.statusCode=500,F.end("Internal error")}}),R=await new Promise((P)=>{let F=(U)=>{G.off("error",F),P({bound:!1,error:U})};G.once("error",F),G.listen(K,J,()=>{G.off("error",F),X=G,P({bound:!0})})});if(R.error){if(R.error.code==="EADDRINUSE")continue;throw V(),R.error}if(R.bound){Y=K;let P=`http://${J}:${K}${$.callbackPath}`;if($.onListening)await Promise.resolve($.onListening({host:J,port:K,callbackUrl:P})).catch(()=>{});return{callbackUrl:P,waitForCallback:B,cancelWait:()=>{V(),A(null)},close:()=>{V(),A(null)}}}}return{callbackUrl:"",waitForCallback:async()=>null,cancelWait:()=>{},close:()=>{}}}var JV=`<!DOCTYPE html>
|
|
6
6
|
<html lang="en">
|
|
7
7
|
<head>
|
|
8
8
|
<meta charset="utf-8">
|
|
@@ -43,17 +43,18 @@ import{createRequire as tY}from"node:module";var iY=Object.defineProperty;var nY
|
|
|
43
43
|
</div>
|
|
44
44
|
<script>setTimeout(() => window.close(), 3000);</script>
|
|
45
45
|
</body>
|
|
46
|
-
</html>`;function u7($){let f="";for(let J=0;J<$.length;J+=1)f+=String.fromCharCode($[J]??0);return btoa(f).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}async function XV($){let J=new TextEncoder().encode($),Q=await crypto.subtle.digest("SHA-256",J);return new Uint8Array(Q)}function HV($=32){let f=new Uint8Array($);return crypto.getRandomValues(f),u7(f)}async function b8(){let $=HV(),f=u7(await XV($));return{verifier:$,challenge:f}}function k8($){return $.endsWith("/")?$.slice(0,-1):$}function t$($,f){return new URL(f,`${k8($)}/`).toString()}function S1($,f={}){let J=$.trim();if(!J)return{};try{let Q=new URL(J);return{code:Q.searchParams.get("code")??void 0,state:Q.searchParams.get("state")??void 0,provider:f.includeProvider?Q.searchParams.get("provider")??void 0:void 0}}catch{}if(f.allowHashCodeState&&J.includes("#")){let[Q,Z]=J.split("#",2);return{code:Q||void 0,state:Z||void 0}}if(J.includes("code=")){let Q=new URLSearchParams(J);return{code:Q.get("code")??void 0,state:Q.get("state")??void 0,provider:f.includeProvider?Q.get("provider")??void 0:void 0}}return{code:J}}function YV($){if(typeof atob==="function")try{return atob($)}catch{return null}if(typeof Buffer<"u")try{return Buffer.from($,"base64").toString("utf8")}catch{return null}return null}function K0($){if(!$)return null;try{let f=$.split(".");if(f.length!==3)return null;let J=f[1];if(!J)return null;let Q=J.replace(/-/g,"+").replace(/_/g,"/"),Z=Q.padEnd(Q.length+(4-Q.length%4)%4,"="),W=YV(Z);if(!W)return null;return JSON.parse(W)}catch{return null}}function h1($){try{let f=JSON.parse($),J=f.error,Q=typeof J==="string"?J:J&&typeof J==="object"&&typeof J.type==="string"?J.type:void 0,Z=typeof f.error_description==="string"?f.error_description:typeof f.message==="string"?f.message:J&&typeof J==="object"&&typeof J.message==="string"?J.message:void 0;return{code:Q,message:Z}}catch{return{}}}function s$($,f){return Date.now()>=$.expires-f}async function C1($){if(!$.onManualCodeInput){let W=await $.waitForCallback();return{code:W?.code,state:W?.state,provider:W?.provider,error:W?.error}}let f,J,Q=$.onManualCodeInput().then((W)=>{f=W,$.cancelWait()}).catch((W)=>{J=W instanceof Error?W:Error(String(W)),$.cancelWait()}),Z=await $.waitForCallback();if(J)throw J;if(Z?.code||Z?.error)return{code:Z.code,state:Z.state,provider:Z.provider,error:Z.error};if(f)return S1(f,$.parseOptions);if(await Q,J)throw J;if(f)return S1(f,$.parseOptions);return{}}var I8={authorize:"/api/v1/auth/authorize",token:"/api/v1/auth/token",register:"/api/v1/auth/register",refresh:"/api/v1/auth/refresh"},p7={deviceAuthorization:"/user_management/authorize/device",authenticate:"/user_management/authenticate"},yf="https://api.workos.com",VV="/auth",c7=Array.from({length:11},($,f)=>48801+f),AV=300000,BV=30000,E1=30000,GV=300,KV=5;class D$ extends Error{status;errorCode;constructor($,f){super($);this.name="ClineOAuthTokenError",this.status=f?.status,this.errorCode=f?.errorCode}isLikelyInvalidGrant(){if(this.errorCode&&/invalid_grant|invalid_token|unauthorized/i.test(this.errorCode))return!0;if(this.status===400||this.status===401||this.status===403)return/invalid|expired|revoked|unauthorized/i.test(this.message);return!1}}function FV($){let f=Date.parse($);if(Number.isNaN(f))throw Error(`Invalid expiresAt value: ${$}`);return f}function wf($,f,J={}){let Q=$.userInfo.clineUserId??J.accountId,Z=$.refreshToken??J.refresh;if(!Z)throw Error("Token response did not include a refresh token");return{access:$.accessToken,refresh:Z,expires:FV($.expiresAt),accountId:Q??void 0,email:$.userInfo.email||J.email,metadata:{provider:f,tokenType:$.tokenType,userInfo:$.userInfo}}}async function Sf($){if(!$)return{};return typeof $==="function"?await $():$}function d7($,f){if(typeof $!=="number"||!Number.isFinite($)||$<=0)return f;return Math.floor($)}async function l7($){await new Promise((f)=>setTimeout(f,$))}function hf($,f){if(!$.success||!$.data?.accessToken)throw Error(f);return $.data}async function r7($,f){let J=await fetch(t$(yf,p7.deviceAuthorization),{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({client_id:$}),signal:AbortSignal.timeout(f?.requestTimeoutMs??E1)}),Q=await J.json().catch(()=>({}));if(!J.ok)throw new D$(`Device authorization failed: ${J.status}${Q.error_description?` - ${Q.error_description}`:""}`,{status:J.status,errorCode:Q.error});if(!Q.device_code||!Q.user_code||!Q.verification_uri)throw Error("Invalid WorkOS device authorization response");return{deviceCode:Q.device_code,userCode:Q.user_code,verificationUri:Q.verification_uri,verificationUriComplete:Q.verification_uri_complete,expiresInSeconds:d7(Q.expires_in,GV),pollIntervalSeconds:d7(Q.interval,KV)}}async function i7($){let f=Date.now()+$.expiresInSeconds*1000,J=Math.max(1,$.initialPollIntervalSeconds);while(Date.now()<=f){let Q=await fetch(t$($.workosApiBaseUrl,p7.authenticate),{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"urn:ietf:params:oauth:grant-type:device_code",device_code:$.deviceCode,client_id:$.clientId}),signal:AbortSignal.timeout($.requestTimeoutMs)}),Z=await Q.json().catch(()=>({}));if(Q.ok){if(!Z.access_token||!Z.refresh_token)throw Error("Invalid WorkOS token response");return{accessToken:Z.access_token,refreshToken:Z.refresh_token,tokenType:Z.token_type??"Bearer"}}switch(Z.error){case"authorization_pending":{await l7(J*1000);break}case"slow_down":{J+=1,await l7(J*1000);break}case"access_denied":case"expired_token":case"invalid_grant":throw new D$(Z.error_description||"WorkOS authorization failed",{status:Q.status,errorCode:Z.error});default:throw new D$(`WorkOS token polling failed: ${Q.status}${Z.error_description?` - ${Z.error_description}`:""}`,{status:Q.status,errorCode:Z.error})}$.onProgress?.("Waiting for browser authentication confirmation...")}throw Error("WorkOS device authorization timed out")}async function n7($,f,J){let Q={accessToken:$.accessToken,refreshToken:$.refreshToken},Z=await fetch(t$(f.apiBaseUrl,I8.register),{method:"POST",headers:{"Content-Type":"application/json",...await Sf(f.headers)},body:JSON.stringify(Q),signal:AbortSignal.timeout(f.requestTimeoutMs??E1)});if(!Z.ok){let j=await Z.text().catch(()=>""),X=h1(j);throw new D$(`Token registration failed: ${Z.status}${X.message?` - ${X.message}`:""}`,{status:Z.status,errorCode:X.code})}let W=await Z.json();return wf(hf(W,"Invalid token exchange response"),J??f.provider)}async function PV($,f,J,Q){let Z={grant_type:"authorization_code",code:$,client_type:"extension",redirect_uri:f,provider:Q??J.provider},W=await fetch(t$(J.apiBaseUrl,I8.token),{method:"POST",headers:{"Content-Type":"application/json",...await Sf(J.headers)},body:JSON.stringify(Z),signal:AbortSignal.timeout(J.requestTimeoutMs??E1)});if(!W.ok){let X=await W.text().catch(()=>""),H=h1(X);throw new D$(`Token exchange failed: ${W.status}${H.message?` - ${H.message}`:""}`,{status:W.status,errorCode:H.code})}let j=await W.json();return wf(hf(j,"Invalid token exchange response"),Q??J.provider)}async function x8($){K$($.telemetry,$.provider??"cline");let f=$.useWorkOSDeviceAuth??!0,J=$.callbackPorts?.length?$.callbackPorts:c7,Q=$.callbackPath??VV,Z=f?null:await e0({ports:J,callbackPath:Q,onListening:$.callbacks.onServerListening,onClose:$.callbacks.onServerClose}),W=Z?.callbackUrl||`http://127.0.0.1:${J[0]??c7[0]}${Q}`;try{let j;if(f){let X=qf().workOsClientId,H=await r7(X,$);$.callbacks.onAuth({url:H.verificationUriComplete??H.verificationUri,instructions:`Enter this code in your browser: ${H.userCode}`});let Y=await i7({clientId:X,deviceCode:H.deviceCode,expiresInSeconds:H.expiresInSeconds,initialPollIntervalSeconds:H.pollIntervalSeconds,requestTimeoutMs:$.requestTimeoutMs??E1,workosApiBaseUrl:yf,onProgress:$.callbacks.onProgress});j=await n7(Y,$,$.provider)}else{let X=new URL(t$($.apiBaseUrl,I8.authorize));X.searchParams.set("client_type","extension"),X.searchParams.set("callback_url",W),X.searchParams.set("redirect_uri",W),$.callbacks.onAuth({url:X.toString(),instructions:"Continue the authentication process in your browser."});let H,Y=$.provider,V=await C1({waitForCallback:Z?.waitForCallback??(async()=>null),cancelWait:Z?.cancelWait??(()=>{}),onManualCodeInput:$.callbacks.onManualCodeInput,parseOptions:{includeProvider:!0}});if(V.error)throw Error(`OAuth error: ${V.error}`);if(H=V.code,Y=V.provider??Y,!H){let A=await $.callbacks.onPrompt({message:"Paste the authorization code (or full redirect URL):"}),B=S1(A,{includeProvider:!0});H=B.code,Y=B.provider??Y}if(!H)throw Error("Missing authorization code");j=await PV(H,W,$,Y)}return F$($.telemetry,$.provider??"cline"),U$($.telemetry,{id:j.accountId,email:j.email,provider:$.provider??"cline"}),j}catch(j){throw P$($.telemetry,$.provider??"cline",j instanceof Error?j.message:String(j)),j}finally{Z?.close()}}async function UV($){return await r7(qf().workOsClientId,$)}async function DV($){let f=$.provider??"cline";K$($.telemetry,f);try{let J=await i7({clientId:qf().workOsClientId,deviceCode:$.deviceCode,expiresInSeconds:$.expiresInSeconds,initialPollIntervalSeconds:$.pollIntervalSeconds,requestTimeoutMs:$.requestTimeoutMs??E1,workosApiBaseUrl:yf}),Q=await n7(J,{apiBaseUrl:$.apiBaseUrl,headers:$.headers,requestTimeoutMs:$.requestTimeoutMs,provider:$.provider},$.provider);return F$($.telemetry,f),U$($.telemetry,{id:Q.accountId,email:Q.email,provider:f}),Q}catch(J){throw P$($.telemetry,f,J instanceof Error?J.message:String(J)),J}}async function Cf($,f){let J=await fetch(t$(f.apiBaseUrl,I8.refresh),{method:"POST",headers:{"Content-Type":"application/json",...await Sf(f.headers)},body:JSON.stringify({refreshToken:$.refresh,grantType:"refresh_token"}),signal:AbortSignal.timeout(f.requestTimeoutMs??E1)});if(!J.ok){let W=await J.text().catch(()=>""),j=h1(W);throw new D$(`Token refresh failed: ${J.status}${j.message?` - ${j.message}`:""}`,{status:J.status,errorCode:j.code})}let Q=await J.json(),Z=$.metadata?.provider??f.provider;return wf(hf(Q,"Invalid token refresh response"),Z,$)}async function Ef($,f,J){if(!$)return null;let Q=J?.refreshBufferMs??AV,Z=J?.retryableTokenGraceMs??BV;if(J?.forceRefresh!==!0&&!s$($,Q))return $;try{return await Cf($,f)}catch(j){if(j instanceof D$&&j.isLikelyInvalidGrant())return n$(f.telemetry,f.provider??"cline","invalid_grant"),null;if($.expires-Date.now()>Z)return $;return null}}function RV($){return{id:"cline",name:"Cline Account",usesCallbackServer:!($.useWorkOSDeviceAuth??!0),async login(f){return x8({...$,callbacks:f})},async refreshToken(f){return Cf(f,$)},getApiKey(f){return`workos:${f.access}`}}}G0();import{nanoid as LV}from"nanoid";var t={authorizationEndpoint:"https://auth.openai.com/oauth/authorize",tokenEndpoint:"https://auth.openai.com/oauth/token",clientId:"app_EMoamEEZ73f0CkXaXp7hrann",redirectUri:"http://localhost:1455/auth/callback",scopes:"openid profile email offline_access",callbackPort:1455,jwtClaimPath:"https://api.openai.com/auth",refreshBufferMs:300000,retryableTokenGraceMs:30000,httpTimeoutMs:30000};class m8 extends Error{status;errorCode;constructor($,f){super($);this.name="OpenAICodexOAuthTokenError",this.status=f?.status,this.errorCode=f?.errorCode}isLikelyInvalidGrant(){if(this.errorCode&&/invalid_grant/i.test(this.errorCode))return!0;if(this.status===400||this.status===401||this.status===403)return/invalid_grant|revoked|expired|invalid refresh/i.test(this.message);return!1}}async function OV($,f,J=t.redirectUri){let Q=await fetch(t.tokenEndpoint,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"authorization_code",client_id:t.clientId,code:$,code_verifier:f,redirect_uri:J}),signal:AbortSignal.timeout(t.httpTimeoutMs)});if(!Q.ok)return{type:"failed"};let Z=await Q.json();if(!Z.access_token||!Z.refresh_token||typeof Z.expires_in!=="number")return{type:"failed"};return{type:"success",access:Z.access_token,refresh:Z.refresh_token,expires:Date.now()+Z.expires_in*1000,email:Z.email,idToken:Z.id_token}}async function zV($){try{let f=await fetch(t.tokenEndpoint,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"refresh_token",refresh_token:$,client_id:t.clientId}),signal:AbortSignal.timeout(t.httpTimeoutMs)});if(!f.ok){let Q=await f.text().catch(()=>""),Z=h1(Q);throw new m8(`Token refresh failed: ${f.status}${Z.message?` - ${Z.message}`:""}`,{status:f.status,errorCode:Z.code})}let J=await f.json();if(!J.access_token||!J.refresh_token||typeof J.expires_in!=="number")return{type:"failed"};return{type:"success",access:J.access_token,refresh:J.refresh_token,expires:Date.now()+J.expires_in*1000,email:J.email,idToken:J.id_token}}catch(f){if(f instanceof m8)throw f;return{type:"failed"}}}async function _V($="pi"){let{verifier:f,challenge:J}=await b8(),Q=LV(32),Z=new URL(t.authorizationEndpoint);return Z.searchParams.set("response_type","code"),Z.searchParams.set("client_id",t.clientId),Z.searchParams.set("redirect_uri",t.redirectUri),Z.searchParams.set("scope",t.scopes),Z.searchParams.set("code_challenge",J),Z.searchParams.set("code_challenge_method","S256"),Z.searchParams.set("state",Q),Z.searchParams.set("id_token_add_organizations","true"),Z.searchParams.set("codex_cli_simplified_flow","true"),Z.searchParams.set("originator",$),{verifier:f,state:Q,url:Z.toString()}}function NV(){try{let $=new URL(t.redirectUri),f=$.port.length>0?Number.parseInt($.port,10):t.callbackPort;return{host:$.hostname||"localhost",port:Number.isFinite(f)?f:t.callbackPort,callbackPath:$.pathname||"/auth/callback",redirectUri:$.toString()}}catch{return{host:"localhost",port:t.callbackPort,callbackPath:"/auth/callback",redirectUri:t.redirectUri}}}function a7($,f){let J=f?K0(f):K0($),Q=J?J:K0($),W=Q?.[t.jwtClaimPath]?.chatgpt_account_id;if(typeof W==="string"&&W.length>0)return W;let j=Q?.organizations;if(Array.isArray(j)&&j.length>0){let H=j[0];if(typeof H?.id==="string"&&H.id.length>0)return H.id}let X=Q?.chatgpt_account_id;if(typeof X==="string"&&X.length>0)return X;return null}function t7($,f){let J=a7($.access,$.idToken)??f?.accountId;if(!J)throw Error("Failed to extract accountId from token");return{access:$.access,refresh:$.refresh||f?.refresh||"",expires:$.expires,accountId:J,email:$.email??f?.email,metadata:{...f?.metadata??{},provider:"openai-codex"}}}async function g8($){K$($.telemetry,"openai-codex");let f=NV(),{verifier:J,state:Q,url:Z}=await _V($.originator),W=await e0({host:f.host,ports:[f.port],callbackPath:f.callbackPath,expectedState:Q});$.onAuth({url:Z,instructions:"Continue the authentication process in your browser."});let j;try{let X=await C1({waitForCallback:W.waitForCallback,cancelWait:W.cancelWait,onManualCodeInput:$.onManualCodeInput,parseOptions:{allowHashCodeState:!0}});if(X.state&&X.state!==Q)throw Error("State mismatch");if(j=X.code,!j){let V=await $.onPrompt({message:"Paste the authorization code (or full redirect URL):"}),A=S1(V,{allowHashCodeState:!0});if(A.state&&A.state!==Q)throw Error("State mismatch");j=A.code}if(!j)throw Error("Missing authorization code");let H=await OV(j,J,f.redirectUri);if(H.type!=="success")throw Error("Token exchange failed");let Y=t7(H);return F$($.telemetry,"openai-codex"),U$($.telemetry,{id:Y.accountId,email:Y.email,provider:"openai-codex"}),Y}catch(X){throw P$($.telemetry,"openai-codex",X instanceof Error?X.message:String(X)),X}finally{W.close()}}async function bf($,f){let J=await zV($);if(J.type!=="success")throw Error("Failed to refresh OpenAI Codex token");let Q=t7(J,f);if(!Q.refresh)throw Error("Failed to refresh OpenAI Codex token: missing refresh token");return Q}async function kf($,f){if(!$)return null;let J=f?.refreshBufferMs??t.refreshBufferMs,Q=f?.retryableTokenGraceMs??t.retryableTokenGraceMs;if(f?.forceRefresh!==!0&&!s$($,J))return $;try{return await bf($.refresh,$)}catch(W){if(W instanceof m8&&W.isLikelyInvalidGrant())return n$(f?.telemetry,"openai-codex","invalid_grant"),null;if($.expires-Date.now()>Q)return $;return null}}function TV($,f=t.refreshBufferMs){return s$($,f)}function MV($){let f=$.accountId??a7($.access);if(!f)throw Error("Failed to extract accountId from token");return{...$,accountId:f,metadata:{...$.metadata??{},provider:"openai-codex"}}}var qV={id:"openai-codex",name:"ChatGPT Plus/Pro (ChatGPT Subscription)",usesCallbackServer:!0,async login($){return g8({onAuth:$.onAuth,onPrompt:$.onPrompt,onProgress:$.onProgress,onManualCodeInput:$.onManualCodeInput})},async refreshToken($){return bf($.refresh,$)},getApiKey($){return $.access}};G0();import{nanoid as s7}from"nanoid";class If{ttlMs;maxEntries;entries=new Map;constructor($,f){this.ttlMs=$;this.maxEntries=f}get($,f=Date.now()){this.pruneExpired(f);let J=this.entries.get($);if(!J)return;return this.entries.delete($),this.entries.set($,J),J.value}set($,f,J=Date.now(),Q=this.ttlMs){this.pruneExpired(J),this.entries.delete($);while(this.entries.size>=this.maxEntries){let Z=this.entries.keys().next().value;if(Z===void 0)break;this.entries.delete(Z)}this.entries.set($,{value:f,expiresAt:J+Q})}pruneExpired($){for(let[f,J]of this.entries)if(J.expiresAt<=$)this.entries.delete(f)}}var yV="a8331954c0cf48ba99b5dd223a14c6ea",wV="https://idcs-9dc693e80d9b469480d7afe00e743931.identity.oraclecloud.com",SV="openid offline_access",mf="https://code-internal.aiservice.us-chicago-1.oci.oraclecloud.com/20250206/app/litellm",hV="c1aba3deed5740659981a752714eba33",CV="https://login-ext.identity.oraclecloud.com",EV="openid offline_access",gf="https://code.aiservice.us-chicago-1.oci.oraclecloud.com/20250206/app/litellm",bV="opc-request-id",kV="/auth/oca",IV=Array.from({length:11},($,f)=>48801+f),xV=300000,mV=30000,o7=30000,gV=600000;class v8 extends Error{status;errorCode;constructor($,f){super($);this.name="OcaOAuthTokenError",this.status=f?.status,this.errorCode=f?.errorCode}isLikelyInvalidGrant(){if(this.errorCode&&/invalid_grant|invalid_token|unauthorized/i.test(this.errorCode))return!0;return this.status===400||this.status===401||this.status===403}}var R$={internal:{clientId:yV,idcsUrl:wV,scopes:SV,baseUrl:mf},external:{clientId:hV,idcsUrl:CV,scopes:EV,baseUrl:gf}},B2=new Map,vV=86400000,uV=300000,cV=32,xf=new If(vV,cV);function e7($){if(typeof $==="function")return $();return $??"internal"}function $Q($){return{internal:{clientId:$?.internal?.clientId??R$.internal.clientId,idcsUrl:$?.internal?.idcsUrl??R$.internal.idcsUrl,scopes:$?.internal?.scopes??R$.internal.scopes,baseUrl:$?.internal?.baseUrl??R$.internal.baseUrl},external:{clientId:$?.external?.clientId??R$.external.clientId,idcsUrl:$?.external?.idcsUrl??R$.external.idcsUrl,scopes:$?.external?.scopes??R$.external.scopes,baseUrl:$?.external?.baseUrl??R$.external.baseUrl}}}function dV($=Date.now()){let f=$-gV;for(let[J,Q]of B2.entries())if(Q.createdAt<f)B2.delete(J)}function lV($,f,J){if(typeof $.expires_in==="number"&&$.expires_in>0)return Date.now()+$.expires_in*1000;let Z=K0(f)?.exp;if(typeof Z==="number"&&Z>0)return Z*1000;let j=K0(J)?.exp;if(typeof j==="number"&&j>0)return j*1000;return Date.now()+3600000}function fQ($,f,J){let Q=$.access_token;if(!Q)throw Error("Token response did not include an access token");let Z=$.refresh_token??J?.refresh;if(!Z)throw Error("Token response did not include a refresh token");let W=K0($.id_token),j=K0(Q),X=W?.sub??j?.sub,H=W?.email??j?.email;return{access:Q,refresh:Z,expires:lV($,Q,$.id_token),accountId:X??J?.accountId,email:H??J?.email,metadata:{...J?.metadata??{},provider:"oca",mode:f,subject:X,idToken:$.id_token}}}async function JQ($,f){let J=k8($),Q=xf.get(J);if(Q)return Q;let Z=`${J}/.well-known/openid-configuration`,W=await fetch(Z,{method:"GET",signal:AbortSignal.timeout(f)});if(!W.ok){let H=`${J}/oauth2/v1/token`;return xf.set(J,H,Date.now(),uV),H}let X=(await W.json()).token_endpoint||`${J}/oauth2/v1/token`;return xf.set(J,X),X}function QQ($){return{code:$.error,message:$.error_description}}async function pV($){let f=B2.get($.state);if(!f)throw Error("No PKCE verifier found for this state");B2.delete($.state);let J=$.mode==="external"?$.config.external:$.config.internal,Q=await JQ(J.idcsUrl,$.requestTimeoutMs),Z=new URLSearchParams({grant_type:"authorization_code",code:$.code,redirect_uri:f.redirectUri,client_id:J.clientId,code_verifier:f.verifier}),W=await fetch(Q,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:Z,signal:AbortSignal.timeout($.requestTimeoutMs)}),j=await W.json();if(!W.ok){let H=QQ(j);throw new v8(`Token exchange failed: ${W.status}${H.message?` - ${H.message}`:""}`,{status:W.status,errorCode:H.code})}let X=K0(j.id_token);if(!j.id_token||!X)throw Error("No ID token received from OCA");if(X.nonce!==f.nonce)throw Error("OIDC nonce verification failed");return fQ(j,$.mode)}function rV($){let f=$.mode==="external"?$.config.external:$.config.internal,J=new URL(`${k8(f.idcsUrl)}/oauth2/v1/authorize`);return J.searchParams.set("client_id",f.clientId),J.searchParams.set("response_type","code"),J.searchParams.set("scope",f.scopes),J.searchParams.set("code_challenge",$.challenge),J.searchParams.set("code_challenge_method","S256"),J.searchParams.set("redirect_uri",$.callbackUrl),J.searchParams.set("state",$.state),J.searchParams.set("nonce",$.nonce),J.toString()}async function u8($){K$($.telemetry,"oca");let f=$Q($.config),J=e7($.mode),Q=$.callbackPorts?.length?$.callbackPorts:IV,Z=$.callbackPath??kV,W=$.requestTimeoutMs??o7,j=await e0({ports:Q,callbackPath:Z,onListening:$.callbacks.onServerListening,onClose:$.callbacks.onServerClose}),X=j.callbackUrl;if(!X)throw Error("Unable to bind local OAuth callback server");let H=s7(16),Y=s7(16),{verifier:V,challenge:A}=await b8();dV(),B2.set(H,{verifier:V,nonce:Y,mode:J,redirectUri:X,createdAt:Date.now()});let B=rV({callbackUrl:X,mode:J,state:H,nonce:Y,challenge:A,config:f});$.callbacks.onAuth({url:B,instructions:"Continue the authentication process in your browser."});try{let G=await C1({waitForCallback:j.waitForCallback,cancelWait:j.cancelWait,onManualCodeInput:$.callbacks.onManualCodeInput}),K=G.code,D=G.state;if(G.error)throw Error(`OAuth error: ${G.error}`);if(!K){if(!$.callbacks.onManualCodeInput)throw Error("Timed out waiting for OCA callback");throw Error("Missing authorization code")}if(!D||D!==H)throw Error("State mismatch");let F=await pV({code:K,state:D,mode:J,config:f,requestTimeoutMs:W});return F$($.telemetry,"oca"),U$($.telemetry,{id:F.accountId,email:F.email,provider:"oca"}),F}catch(G){throw P$($.telemetry,"oca",G instanceof Error?G.message:String(G)),G}finally{j.close()}}async function vf($,f={}){let J=$Q(f.config),Q=f.requestTimeoutMs??o7,Z=$.metadata?.mode,W=Z==="internal"||Z==="external"?Z:e7(f.mode),j=W==="external"?J.external:J.internal,X=await JQ(j.idcsUrl,Q),H=new URLSearchParams({grant_type:"refresh_token",refresh_token:$.refresh,client_id:j.clientId}),Y=await fetch(X,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:H,signal:AbortSignal.timeout(Q)}),V=await Y.json();if(!Y.ok){let A=QQ(V);throw new v8(`Token refresh failed: ${Y.status}${A.message?` - ${A.message}`:""}`,{status:Y.status,errorCode:A.code})}return fQ(V,W,$)}async function uf($,f,J){if(!$)return null;let Q=f?.refreshBufferMs??J?.refreshBufferMs??xV,Z=f?.retryableTokenGraceMs??J?.retryableTokenGraceMs??mV;if(f?.forceRefresh!==!0&&!s$($,Q))return $;try{return await vf($,J)}catch(j){if(j instanceof v8&&j.isLikelyInvalidGrant())return n$(J?.telemetry,"oca","invalid_grant"),null;if($.expires-Date.now()>Z)return $;return null}}function iV($={}){return{id:"oca",name:"Oracle Code Assist",usesCallbackServer:!0,async login(f){return u8({...$,callbacks:f})},async refreshToken(f){return vf(f,$)},getApiKey(f){return f.access}}}async function ZQ($,f){let J=new TextEncoder,Q=async(Y)=>{let V=await crypto.subtle.digest("SHA-256",J.encode(Y));return Array.from(new Uint8Array(V).slice(0,4),(A)=>A.toString(16).padStart(2,"0")).join("")},[Z,W]=await Promise.all([Q(f),Q($)]),j=Math.floor(Date.now()/1000).toString(16).padStart(8,"0"),X=new Uint32Array(1);crypto.getRandomValues(X);let H=(X[0]??0).toString(16).padStart(8,"0");return Z+W+j+H}async function nV($){let f=await ZQ($.taskId,$.accessToken);return{Authorization:`Bearer ${$.accessToken}`,"Content-Type":"application/json",client:$.metadata?.client??"Cline","client-version":$.metadata?.clientVersion??"unknown","client-ide":$.metadata?.clientIde??"unknown","client-ide-version":$.metadata?.clientIdeVersion??"unknown",[bV]:f}}import*as y0 from"@cline/llms";import{z as T}from"zod";import*as $0 from"@cline/llms";function cf($){if(!Array.isArray($))return[];return $.map((f)=>{if(typeof f==="string")return f.trim();if(f&&typeof f==="object"){let J=f;for(let Q of[J.id,J.name,J.model])if(typeof Q==="string"&&Q.trim())return Q.trim()}return""}).filter((f)=>f.length>0)}function aV($,f){let J=cf($);if(J.length>0)return J;if(!$||typeof $!=="object")return[];let Q=$,Z=cf(Q.data??Q.models);if(Z.length>0)return Z;if(Q.models&&typeof Q.models==="object"&&!Array.isArray(Q.models)){let j=Object.keys(Q.models).filter((X)=>X.trim().length>0);if(j.length>0)return j}let W=Q.providers?.[f];if(W&&typeof W==="object"){let X=cf(W.models??W);if(X.length>0)return X}return[]}async function c8($,f){let J=await fetch($,{method:"GET"});if(!J.ok)throw Error(`failed to fetch models from ${$}: HTTP ${J.status}`);return aV(await J.json(),f)}function WQ($){return $.replace(/\/+$/,"")}function d8($,f,J){let Q=J?.trim();if(!Q)return;let Z=$?.trim();if(!Z||!f?.trim())return Q;try{let W=new URL(Q),j=new URL(f),X=new URL(Z);if(W.origin!==j.origin)return Q;let H=WQ(j.pathname),Y=WQ(X.pathname);if(H&&W.pathname.startsWith(`${H}/`)){let V=W.pathname.slice(H.length);X.pathname=`${Y}${V}`}else X.pathname=W.pathname;return X.search=W.search,X.hash=W.hash,X.toString()}catch{return Q}}function tV($){return Object.fromEntries(Object.entries($).map(([f,J])=>[f,{...J}]))}function sV($){if($.baseUrl.length===0)return!1;switch($.client){case"openai-compatible":case"openai":case"openai-r1":case"fetch":return!0;default:return $.protocol==="openai-chat"}}var oV=Object.values($0.MODEL_COLLECTIONS_BY_PROVIDER_ID).map(($)=>({id:$.provider.id,baseUrl:$.provider.baseUrl??"",modelsSourceUrl:$.provider.modelsSourceUrl,modelId:$.provider.defaultModelId,knownModels:tV($.models),capabilities:$.provider.capabilities?[...$.provider.capabilities]:void 0,env:$.provider.env?[...$.provider.env]:void 0,client:$.provider.client,protocol:$.provider.protocol})),HQ=Object.fromEntries(oV.map(($)=>[$.id,$]));function eV($){return HQ[$]}function $A(){return Object.fromEntries(Object.entries(HQ).filter(([,$])=>sV($)))}function YQ($=[]){let f=$.flatMap((J)=>{switch(J){case"reasoning":case"prompt-cache":case"tools":case"oauth":return[J];default:return[]}});return f.length>0?f:void 0}var VQ="https://models.dev/api.json",fA=600000,AQ=300000,JA=5000,p8=new Map,G2=new Map,lf=new Map,l8=new Map;async function QA(){return $0.getGeneratedProviderModels()}async function ZA($,f={},J={},Q={},Z={},W={}){let j=await QA(),X=$0.resolveProviderModelCatalogKeys($),H=Object.assign({},...X.map((A)=>j[A]??{})),Y=Boolean($0.MODEL_COLLECTIONS_BY_PROVIDER_ID[$]?.provider.modelsSourceUrl),V=Object.keys(Z).length>0;if(Y&&V)return $0.sortModelsByReleaseDate({...Z,...W});if($==="openai-codex")return $0.sortModelsByReleaseDate({...f,...$0.filterOpenAICodexModels(J),...Z,...W});return $0.sortModelsByReleaseDate({...H,...f,...J,...Q,...Z,...W})}function WA($,f){let J=$0.resolveProviderModelCatalogKeys($);return Object.assign({},...J.map((Q)=>f[Q]??{}))}function r8($){let f=$?.trim();return f&&f.length>0?f:""}function pf($){let f=$.apiKey?.trim()||$.accessToken?.trim();return f&&f.length>0?f:void 0}function jA($){let f=2166136261;for(let J=0;J<$.length;J+=1)f^=$.charCodeAt(J),f+=(f<<1)+(f<<4)+(f<<7)+(f<<8)+(f<<24);return(f>>>0).toString(16)}function XA($,f){return`${$}:${r8(f.baseUrl)}:${jA(pf(f)??"")}`}async function i8($,f,J=JA){let Q=new AbortController,Z=setTimeout(()=>Q.abort(),J);try{return await fetch($,{...f,signal:Q.signal})}finally{clearTimeout(Z)}}function o$($,f,J){if(J&&!$.includes(f))$.push(f)}function n8($,f){let J=["streaming","tools"];return o$(J,"images",Boolean(f.supportsImages)),o$(J,"prompt-cache",Boolean(f.supportsPromptCache)),o$(J,"reasoning",Boolean(f.supportsReasoning)),{id:$,name:f.name??$,contextWindow:f.contextWindow,maxInputTokens:f.maxInputTokens,maxTokens:f.maxTokens,capabilities:J,releaseDate:f.releaseDate,status:"active"}}async function HA($,f){let J=await i8("https://inference.baseten.co/v1/models",{method:"GET",headers:{Authorization:`Bearer ${f}`,"Content-Type":"application/json"}});if(!J.ok)throw Error(`Baseten model refresh failed: HTTP ${J.status}`);let Z=(await J.json())?.data??[],W={};for(let j of Z){let X=j.id?.trim();if(!X)continue;if(X.includes("whisper")||X.includes("tts")||X.includes("embedding"))continue;let H=j.supported_features??[];W[X]=n8(X,{name:X,contextWindow:j.context_length,maxInputTokens:j.context_length,maxTokens:j.max_completion_tokens,supportsReasoning:H.includes("reasoning")||H.includes("reasoning_effort"),supportsImages:!1})}return W}function jQ($){if(typeof $==="number")return Number.isFinite($)?$:void 0;if(typeof $==="string"){let f=Number($);return Number.isFinite(f)?f:void 0}return}async function YA($,f){let J=await i8("https://api.hicap.ai/v2/openai/models",{method:"GET",headers:{"api-key":f}});if(!J.ok)throw Error(`Hicap model refresh failed: HTTP ${J.status}`);let Z=(await J.json())?.data??[],W={};for(let j of Z){let X=j.id?.trim();if(!X)continue;W[X]=n8(X,{name:X,maxInputTokens:128000,supportsImages:!0,supportsPromptCache:!0})}return W}async function VA($,f){let Q=`${(r8($.baseUrl)||"https://inference.poolside.ai/v1").replace(/\/+$/,"")}/models`,Z=await i8(Q,{method:"GET",headers:{Authorization:`Bearer ${f}`,accept:"application/json"}});if(!Z.ok)throw Error(`Poolside model refresh failed: HTTP ${Z.status}`);let j=(await Z.json())?.data??[],X={};for(let H of j){let Y=H.id?.trim();if(!Y)continue;let V=H.supported_features??[],A=H.supported_sampling_parameters??[],B=H.input_modalities??[],G=["streaming"];o$(G,"tools",V.includes("tools")),o$(G,"reasoning",V.includes("reasoning")),o$(G,"temperature",A.includes("temperature")),o$(G,"images",B.includes("image"));let K={input:jQ(H.pricing?.prompt),output:jQ(H.pricing?.completion)};X[Y]={id:Y,name:H.name??Y,description:H.description,contextWindow:H.context_length,maxInputTokens:H.context_length,maxTokens:H.max_completion_tokens,capabilities:G,pricing:K.input!==void 0||K.output!==void 0?K:void 0,status:"active"}}return X}function AA($){let f=r8($);if(!f)return"http://localhost:4000";return f.endsWith("/v1")?f.slice(0,-3):f}async function BA($,f){let Q=`${AA($.baseUrl)}/v1/model/info`,Z=async(Y)=>i8(Q,{method:"GET",headers:{accept:"application/json",...Y}}),W=await Z({"x-litellm-api-key":f});if(!W.ok)W=await Z({Authorization:`Bearer ${f}`});if(!W.ok)throw Error(`LiteLLM model refresh failed: HTTP ${W.status}`);let X=(await W.json())?.data??[],H={};for(let Y of X){let V=Y.model_name?.trim(),B=Y.litellm_params?.model?.trim()||V;if(!B)continue;let G=Y.model_info,K=n8(B,{name:V??B,maxTokens:G?.max_output_tokens??G?.max_tokens,maxInputTokens:G?.max_input_tokens??G?.max_tokens,supportsImages:G?.supports_vision,supportsPromptCache:G?.supports_prompt_caching,supportsReasoning:G?.supports_reasoning});if(H[B]=K,V)H[V]={...K,id:V,name:V}}return H}var BQ={baseten:HA,hicap:YA,litellm:BA,poolside:VA},XQ=new Map,df=new Map;function GA($,f){return`${$}:${r8(f.baseUrl)}`}async function KA($,f,J){let Q=$0.MODEL_COLLECTIONS_BY_PROVIDER_ID[$],Z=d8(J.baseUrl,Q?.provider.baseUrl,Q?.provider.modelsSourceUrl);if(!Z)return{};let W=f?.cacheTtlMs??AQ,j=GA($,J),X=Date.now(),H=XQ.get(j);if(H&&H.expiresAt>X)return H.data;let Y=df.get(j);if(Y)return Y;let V=c8(Z,$).then((A)=>{let B=Object.fromEntries(A.map((G)=>[G,n8(G,{name:G})]));return XQ.set(j,{data:B,expiresAt:X+W}),B}).finally(()=>{df.delete(j)});return df.set(j,V),V}async function FA($,f){let J=pf(f);if(!J)return{};let Q=BQ[$];if(!Q)return{};return Q(f,J)}function PA($,f,J){if(!J)return!1;if(!BQ[$])return!1;if(f?.loadPrivateOnAuth===!1)return!1;return Boolean(pf(J))}async function UA($,f,J){let Q=f?.cacheTtlMs??AQ,Z=XA($,J),W=Date.now(),j=lf.get(Z);if(j&&j.expiresAt>W)return j.data;let X=l8.get(Z);if(X)return X;let H=FA($,J).then((Y)=>{return lf.set(Z,{data:Y,expiresAt:W+Q}),Y}).finally(()=>{l8.delete(Z)});return l8.set(Z,H),H}async function DA($){return $0.fetchModelsDevProviderModels($,globalThis.fetch)}async function a8($={}){let f=$.url??VQ,J=$.cacheTtlMs??fA,Q=Date.now(),Z=p8.get(f);if(Z&&Z.expiresAt>Q)return Z.data;let W=G2.get(f);if(W)return W;let j=DA(f).then((X)=>{return p8.set(f,{data:X,expiresAt:Q+J}),X}).finally(()=>{G2.delete(f)});return G2.set(f,j),j}function RA($){if($){p8.delete($),G2.delete($);return}p8.clear(),G2.clear()}function LA(){lf.clear(),l8.clear()}function OA($){return Object.fromEntries(Object.entries($).map(([f,J])=>[f,{baseUrl:J.baseUrl,modelId:J.modelId,capabilities:YQ(J.capabilities)}]))}var rf=OA($A());function GQ($){let f=eV($);if(!f)return;return{baseUrl:f.baseUrl||void 0,modelId:f.modelId,knownModels:f.knownModels,capabilities:YQ(f.capabilities)}}async function nf($,f,J){let Q=GQ($);if(!Q)return;try{let Z=f?.loadLatestOnInit?await a8(f):void 0,W=Z?WA($,Z):{},j=J&&PA($,f,J)?await UA($,f,J):{},H=Boolean($0.MODEL_COLLECTIONS_BY_PROVIDER_ID[$]?.provider.modelsSourceUrl)?J??{providerId:$,modelId:Q.modelId,baseUrl:Q.baseUrl}:J,Y=H?await KA($,f,H).catch(()=>({})):{},V=await ZA($,Q.knownModels,W,j,Y,J?.knownModels);return{...Q,knownModels:V}}catch(Z){if(f?.failOnError)throw Z;return Q}}var af=y0.BUILT_IN_PROVIDER,zA=y0.BUILT_IN_PROVIDER_IDS,_A=y0.isBuiltInProviderId,t8=y0.normalizeProviderId,tf=T.string().min(1).regex(/^[a-z0-9][a-z0-9-]*$/i),KQ=T.enum(["anthropic","gemini","openai-chat","openai-responses","openai-r1","ai-sdk"]),FQ=T.enum(["anthropic","ai-sdk","ai-sdk-community","openai","openai-compatible","openai-r1","gemini","bedrock","custom","fetch","vertex"]),PQ=T.object({apiKey:T.string().optional(),accessToken:T.string().optional(),refreshToken:T.string().optional(),expiresAt:T.number().int().positive().optional(),accountId:T.string().optional()}),NA=T.enum(["none","low","medium","high","xhigh"]),UQ=T.object({enabled:T.boolean().optional(),effort:NA.optional(),budgetTokens:T.number().int().positive().optional()}),DQ=T.object({accessKey:T.string().optional(),secretKey:T.string().optional(),sessionToken:T.string().optional(),region:T.string().optional(),profile:T.string().optional(),authentication:T.enum(["iam","api-key","apikey","profile"]).optional(),usePromptCache:T.boolean().optional(),useCrossRegionInference:T.boolean().optional(),useGlobalInference:T.boolean().optional(),endpoint:T.string().url().optional(),customModelBaseId:T.string().optional()}),RQ=T.object({projectId:T.string().optional(),region:T.string().optional()}),LQ=T.object({apiVersion:T.string().optional(),useIdentity:T.boolean().optional()}),OQ=T.object({clientId:T.string().optional(),clientSecret:T.string().optional(),tokenUrl:T.string().url().optional(),resourceGroup:T.string().optional(),deploymentId:T.string().optional(),useOrchestrationMode:T.boolean().optional(),api:T.enum(["orchestration","foundation-models"]).optional(),defaultSettings:T.record(T.string(),T.unknown()).optional()}),zQ=T.object({mode:T.enum(["internal","external"]).optional(),usePromptCache:T.boolean().optional()}),_Q=T.object({loadLatestOnInit:T.boolean().optional(),loadPrivateOnAuth:T.boolean().optional(),url:T.string().url().optional(),cacheTtlMs:T.number().int().positive().optional(),failOnError:T.boolean().optional()}),b1=T.object({provider:tf,apiKey:T.string().optional(),auth:PQ.optional(),model:T.string().optional(),protocol:KQ.optional(),client:FQ.optional(),routingProviderId:tf.optional(),maxTokens:T.number().int().positive().optional(),contextWindow:T.number().int().positive().optional(),baseUrl:T.string().url().optional(),headers:T.record(T.string(),T.string()).optional(),timeout:T.number().int().positive().optional(),reasoning:UQ.optional(),aws:DQ.optional(),gcp:RQ.optional(),azure:LQ.optional(),sap:OQ.optional(),oca:zQ.optional(),region:T.string().optional(),apiLine:T.enum(["china","international"]).optional(),capabilities:T.array(T.enum(["reasoning","prompt-cache","streaming","tools","vision","computer-use","oauth","popular"])).optional(),modelCatalog:_Q.optional()});function NQ($){return b1.parse($)}function TQ($){return b1.safeParse($)}function TA($){return $.protocol==="openai-responses"||$.client==="openai"}function $$($,f={}){let J=$.provider,Q=t8(J),Z=f.includeKnownModels!==!1,W=$.reasoning?.effort||"none",j=W==="none"?void 0:W,X=rf[Q],H=Object.assign({},...y0.resolveProviderModelCatalogKeys(Q).map((D)=>y0.getGeneratedModelsForProvider(D))),Y=Object.keys(H)[0],V=$.auth?.accessToken??$.apiKey??$.auth?.apiKey,A=$.baseUrl??(Q==="oca"?$.oca?.mode==="internal"?mf:gf:X?.baseUrl),B=$.routingProviderId??(TA($)&&Q!==af.OPENAI_NATIVE?af.OPENAI_NATIVE:void 0),G=Z?X?.knownModels??(Object.keys(H).length>0?H:void 0):void 0,K={providerId:J,clientType:$.client,routingProviderId:B,modelId:$.model??X?.modelId??Y??"default",...Z?{knownModels:G}:{},apiKey:V,accessToken:$.auth?.accessToken,refreshToken:$.auth?.refreshToken,accountId:$.auth?.accountId,baseUrl:A,headers:$.headers,timeoutMs:$.timeout,maxOutputTokens:$.maxTokens,maxInputTokens:$.contextWindow,thinking:$.reasoning?.enabled,reasoningEffort:j,thinkingBudgetTokens:$.reasoning?.budgetTokens,region:$.region??$.aws?.region??$.gcp?.region,apiLine:$.apiLine,useCrossRegionInference:$.aws?.useCrossRegionInference,useGlobalInference:$.aws?.useGlobalInference,aws:$.aws?{accessKey:$.aws.accessKey,secretKey:$.aws.secretKey,sessionToken:$.aws.sessionToken,authentication:$.aws.authentication,profile:$.aws.profile,usePromptCache:$.aws.usePromptCache,endpoint:$.aws.endpoint,customModelBaseId:$.aws.customModelBaseId}:void 0,gcp:$.gcp?{projectId:$.gcp.projectId,region:$.gcp.region}:void 0,azure:$.azure,sap:$.sap,oca:$.oca,capabilities:$.capabilities??X?.capabilities,modelCatalog:$.modelCatalog?{loadLatestOnInit:$.modelCatalog.loadLatestOnInit,loadPrivateOnAuth:$.modelCatalog.loadPrivateOnAuth,url:$.modelCatalog.url,cacheTtlMs:$.modelCatalog.cacheTtlMs,failOnError:$.modelCatalog.failOnError}:void 0};return Object.fromEntries(Object.entries(K).filter(([D,F])=>F!==void 0))}function MA($){let f=NQ($);return $$(f)}function qA($){let f=TQ($);if(f.success)return{success:!0,config:$$(f.data)};return{success:!1,error:f.error}}import{SESSION_STATUS_VALUES as yA}from"@cline/shared";var sf=yA,wA=["idle","running","pending"];function SA($){return!wA.includes($)}function f0($){return!SA($)}var F0={CORE:"core",CLI:"cli",SUBAGENT:"subagent",DESKTOP:"desktop",KANBAN:"kanban",API:"api",WEB:"web",VSCODE:"vscode",ENTERPRISE:"enterprise",IDE:"ide",JETBRAINS:"jetbrains",NEOVIM:"neovim",UNKNOWN:"unknown"};function MQ($){if($===!0)return{};if(!$)return;return $}function qQ($){if($==="user")return"global";return $}class of{getService;constructor($){this.getService=$}async start(){await this.getService().start()}async stop(){await this.getService().stop()}async reconcileNow(){await this.getService().reconcileNow()}ingestEvent($){let f=this.getService().ingestEvent($);return{event:f.event,duplicate:f.duplicate,matchedSpecIds:f.matchedSpecs.map((J)=>J.specId),queuedRuns:f.queuedRuns,suppressions:f.suppressions}}listEvents($){return this.getService().listEventLogs($)}getEvent($){return this.getService().getEventLog($)}listSpecs($){return this.getService().listSpecs($)}listRuns($){return this.getService().listRuns($)}}function yQ($){let{host:f}=$;return{async startSession(J){let Q=(J.cwd?.trim()||J.workspaceRoot).trim(),Z=await f.startSession({source:J.source?.trim()||F0.CLI,interactive:!1,config:{providerId:t8(J.provider),modelId:J.model,apiKey:J.apiKey?.trim()||void 0,cwd:Q,workspaceRoot:J.workspaceRoot,systemPrompt:J.systemPrompt??"",mode:EA(J),maxIterations:J.maxIterations,enableTools:J.enableTools!==!1,enableSpawnAgent:J.enableSpawn!==!1,enableAgentTeams:J.enableTeams!==!1,disableMcpSettingsTools:J.disableMcpSettingsTools,missionLogIntervalSteps:J.missionStepInterval,missionLogIntervalMs:J.missionTimeIntervalMs},toolPolicies:J.toolPolicies??{"*":{autoApprove:J.autoApproveTools!==!1}},localRuntime:{extensionContext:$.getExtensionContext(),configExtensions:J.configExtensions}});return{sessionId:Z.sessionId,startResult:{sessionId:Z.sessionId,manifestPath:Z.manifestPath,messagesPath:Z.messagesPath}}},async sendSession(J,Q){let Z=await f.runTurn({sessionId:J,prompt:Q.prompt,userImages:Q.attachments?.userImages,userFiles:Q.attachments?.userFiles?.map((W)=>W.content),delivery:Q.delivery});if(!Z)throw Error("ClineCore automation runtime returned no result");return{result:CA(Z)}},async abortSession(J){return await f.abort(J,Error("ClineCore automation abort")),{applied:!0}},async stopSession(J){return await f.stopSession(J),{applied:!0}}}}function s8($){let f=hA($.automationService,$.automation),J=$.context?.client??($.clientName?{name:$.clientName}:void 0),Q=$.context?.user??($.distinctId?{distinctId:$.distinctId}:void 0),Z=$.context?.logger??$.logger,W=$.context?.telemetry??$.telemetry;if(!f&&!J&&!Q&&!Z&&!W)return $.context;return{...$.context??{},...J?{client:J}:{},...Q?{user:Q}:{},...Z?{logger:Z}:{},...W?{telemetry:W}:{},...f?{automation:f}:{}}}function hA($,f){if(!$)return;return{ingestEvent:(J)=>{f.ingestEvent(J)}}}function CA($){return{text:$.text,usage:{inputTokens:$.usage.inputTokens,outputTokens:$.usage.outputTokens,cacheReadTokens:$.usage.cacheReadTokens,cacheWriteTokens:$.usage.cacheWriteTokens,totalCost:$.usage.totalCost},inputTokens:$.usage.inputTokens,outputTokens:$.usage.outputTokens,iterations:$.iterations,finishReason:$.finishReason,toolCalls:$.toolCalls.map((f)=>({name:f.name,input:f.input,output:f.output,error:f.error,durationMs:f.durationMs}))}}function EA($){return $.mode==="plan"?"plan":$.mode==="yolo"?"yolo":"act"}import{existsSync as i4}from"node:fs";import{basename as YW,isAbsolute as DP,relative as RP}from"node:path";import{createHash as bA}from"node:crypto";import{watch as kA}from"node:fs";import{readdir as IA,readFile as xA}from"node:fs/promises";import{join as mA}from"node:path";function gA($){return bA("sha1").update($).digest("hex")}function hQ($){return Boolean($&&typeof $==="object"&&"code"in $)}function wQ($){return hQ($)&&$.code==="ENOENT"}function SQ($){return hQ($)&&($.code==="EACCES"||$.code==="EPERM")}class K2{definitions;debounceMs;emitParseErrors;listeners=new Set;recordsByType=new Map;watchersByDirectory=new Map;baseTypesByDirectory=new Map;watchedTypesByDirectory=new Map;discoveredDirectoriesByType=new Map;definitionsByType=new Map;pendingTypes=new Set;flushTimer;refreshQueue=Promise.resolve();started=!1;constructor($,f){if($.length===0)throw Error("UnifiedConfigFileWatcher requires at least one definition.");this.definitions=$,this.debounceMs=f?.debounceMs??75,this.emitParseErrors=f?.emitParseErrors??!1;for(let J of $){if(this.definitionsByType.has(J.type))throw Error(`Duplicate unified config definition type '${J.type}'.`);this.definitionsByType.set(J.type,J),this.recordsByType.set(J.type,new Map),this.discoveredDirectoriesByType.set(J.type,new Set);for(let Q of J.directories){let Z=this.baseTypesByDirectory.get(Q);if(Z)Z.add(J.type);else this.baseTypesByDirectory.set(Q,new Set([J.type]))}}}subscribe($){return this.listeners.add($),()=>{this.listeners.delete($)}}async start(){if(this.started)return;this.started=!0,await this.refreshAll(),this.startDirectoryWatchers()}stop(){if(this.started=!1,this.flushTimer)clearTimeout(this.flushTimer),this.flushTimer=void 0;this.pendingTypes.clear();for(let $ of this.watchersByDirectory.values())$.close();this.watchersByDirectory.clear(),this.watchedTypesByDirectory=new Map}async refreshAll(){await this.enqueueRefresh(async()=>{for(let $ of this.definitions)await this.refreshTypeInternal($)})}async refreshType($){let f=this.definitionsByType.get($);if(!f)throw Error(`Unknown unified config type '${$}'.`);await this.enqueueRefresh(async()=>{await this.refreshTypeInternal(f)})}getSnapshot($){let f=this.recordsByType.get($);return new Map([...f?.entries()??[]].map(([J,Q])=>[J,{...Q}]))}getAllSnapshots(){let $=new Map;for(let[f,J]of this.recordsByType.entries())$.set(f,new Map([...J.entries()].map(([Q,Z])=>[Q,{...Z}])));return $}emit($){for(let f of this.listeners)f($)}enqueueRefresh($){return this.refreshQueue=this.refreshQueue.then($,$),this.refreshQueue}startDirectoryWatchers(){this.syncDirectoryWatchers()}syncDirectoryWatchers(){let $=this.buildDesiredTypesByDirectory();for(let[f,J]of this.watchersByDirectory.entries()){if($.has(f))continue;J.close(),this.watchersByDirectory.delete(f)}this.watchedTypesByDirectory=$;for(let f of $.keys()){if(this.watchersByDirectory.has(f))continue;try{let J=kA(f,()=>{let Q=this.watchedTypesByDirectory.get(f);if(!Q)return;for(let Z of Q)this.pendingTypes.add(Z);this.scheduleFlush()});this.watchersByDirectory.set(f,J),J.on("error",(Q)=>{let Z=this.watchedTypesByDirectory.get(f);if(!Z)return;for(let W of Z)this.emit({kind:"error",type:W,error:Q,filePath:f})})}catch(J){if(!wQ(J)&&!SQ(J)){let Q=$.get(f);if(!Q)continue;for(let Z of Q)this.emit({kind:"error",type:Z,error:J,filePath:f})}}}}scheduleFlush(){if(this.flushTimer)clearTimeout(this.flushTimer);this.flushTimer=setTimeout(()=>{this.flushTimer=void 0;let $=[...this.pendingTypes];this.pendingTypes.clear(),this.enqueueRefresh(async()=>{for(let f of $){let J=this.definitionsByType.get(f);if(!J)continue;await this.refreshTypeInternal(J)}})},this.debounceMs)}async refreshTypeInternal($){let{records:f,discoveredDirectories:J}=await this.loadDefinition($),Q=this.recordsByType.get($.type)??new Map;for(let[Z,W]of Q.entries()){if(f.has(Z))continue;this.emit({kind:"remove",type:$.type,id:Z,filePath:W.filePath})}for(let[Z,W]of f.entries()){let j=Q.get(Z);if(j&&j.filePath===W.filePath&&j.fingerprint===W.fingerprint)continue;this.emit({kind:"upsert",record:{type:W.type,id:Z,item:W.item,filePath:W.filePath}})}if(this.recordsByType.set($.type,f),this.discoveredDirectoriesByType.set($.type,J),this.started)this.syncDirectoryWatchers()}async loadDefinition($){let f=new Map,J=new Set;for(let Q of $.directories){J.add(Q);let Z=$.discoverFiles?await $.discoverFiles(Q):await this.readDirectoryFileCandidates(Q);for(let W of Z){let{fileName:j,filePath:X}=W;if(J.add(W.directoryPath),$.includeFile&&!$.includeFile(j,X))continue;try{let H=await xA(X,"utf8"),Y={type:$.type,directoryPath:W.directoryPath,fileName:j,filePath:X,content:H},V=$.parseFile(Y),A=$.resolveId(V,Y).trim();if(!A)continue;f.set(A,{type:$.type,id:A,item:V,filePath:X,fingerprint:gA(H)})}catch(H){if(this.emitParseErrors)this.emit({kind:"error",type:$.type,error:H,filePath:X})}}}return{records:f,discoveredDirectories:J}}buildDesiredTypesByDirectory(){let $=new Map;for(let[f,J]of this.baseTypesByDirectory.entries())$.set(f,new Set(J));for(let[f,J]of this.discoveredDirectoriesByType.entries())for(let Q of J){let Z=$.get(Q);if(Z)Z.add(f);else $.set(Q,new Set([f]))}return $}async readDirectoryFileCandidates($){try{return(await IA($,{withFileTypes:!0})).filter((J)=>J.isFile()).map((J)=>({directoryPath:$,fileName:J.name,filePath:mA($,J.name)})).sort((J,Q)=>J.fileName.localeCompare(Q.fileName))}catch(f){if(wQ(f)||SQ(f))return[];throw f}}}import{readdir as ef,readFile as vA,stat as CQ}from"node:fs/promises";import{basename as e$,dirname as uA,extname as $J,join as O0}from"node:path";import{RULES_CONFIG_DIRECTORY_NAME as EQ,resolveRulesConfigSearchPaths as cA,resolveSkillsConfigSearchPaths as dA,resolveWorkflowsConfigSearchPaths as lA,SKILLS_CONFIG_DIRECTORY_NAME as fJ,WORKFLOWS_CONFIG_DIRECTORY_NAME as JJ}from"@cline/shared/storage";import pA from"yaml";var o8="SKILL.md",rA="managed.json",iA=new Set([".md",".markdown",".txt"]);function QJ($){return $.trim().toLowerCase()}function F2($){let f=$;return f?.code==="ENOENT"||f?.code==="EACCES"||f?.code==="EPERM"}function e8($){return iA.has($J($).toLowerCase())}async function ZJ($){try{let f=await ef($,{withFileTypes:!0}),J=[];for(let Q of f){if(!Q.isDirectory())continue;let Z=O0($,Q.name),W=O0(Z,rA);try{let j=await vA(W,"utf8"),X=JSON.parse(j);if(X&&typeof X==="object")J.push(Z)}catch(j){if(F2(j))continue;if(j?.name==="SyntaxError")continue;throw j}}return J.sort((Q,Z)=>Q.localeCompare(Z))}catch(f){if(F2(f))return[];throw f}}function WJ($){let f=/^---\r?\n([\s\S]*?)\r?\n---\r?\n?([\s\S]*)$/,J=$.match(f);if(!J)return{data:{},body:$,hadFrontmatter:!1};let[,Q,Z]=J;try{let W=pA.parse(Q);return{data:W&&typeof W==="object"&&!Array.isArray(W)?W:{},body:Z,hadFrontmatter:!0}}catch(W){let j=W instanceof Error?W.message:String(W);return{data:{},body:$,hadFrontmatter:!0,parseError:j}}}function $4($,f,J){if($===void 0||$===null){if(J)throw Error(`Missing required frontmatter field '${f}'.`);return}if(typeof $!=="string")throw Error(`Frontmatter field '${f}' must be a string.`);let Q=$.trim();if(!Q&&J)throw Error(`Frontmatter field '${f}' cannot be empty.`);return Q||void 0}function k1($,f){if($===void 0||$===null)return;if(typeof $!=="boolean")throw Error(`Frontmatter field '${f}' must be a boolean.`);return $}function jJ($,f){let{data:J,body:Q,parseError:Z}=WJ($);if(Z)throw Error(`Failed to parse YAML frontmatter: ${Z}`);let W=Q.trim();if(!W)throw Error("Missing instructions body in skill file.");let X=$4(J.name,"name",!1)??f.trim();if(!X)throw Error("Missing skill name.");return{name:X,description:$4(J.description,"description",!1),disabled:k1(J.disabled,"disabled")??(k1(J.enabled,"enabled")===!1?!0:void 0),instructions:W,frontmatter:J}}function XJ($,f){let{data:J,body:Q,parseError:Z}=WJ($);if(Z)throw Error(`Failed to parse YAML frontmatter: ${Z}`);let W=Q.trim();if(!W)throw Error("Missing instructions body in rule file.");let j=$4(J.name,"name",!1)??f.trim();if(!j)throw Error("Missing rule name.");return{name:j,disabled:k1(J.disabled,"disabled")??(k1(J.enabled,"enabled")===!1?!0:void 0),instructions:W,frontmatter:J}}function HJ($,f){let{data:J,body:Q,parseError:Z}=WJ($);if(Z)throw Error(`Failed to parse YAML frontmatter: ${Z}`);let W=Q.trim();if(!W)throw Error("Missing instructions body in workflow file.");let j=$4(J.name,"name",!1)??f.trim();if(!j)throw Error("Missing workflow name.");return{name:j,disabled:k1(J.disabled,"disabled")??(k1(J.enabled,"enabled")===!1?!0:void 0),instructions:W,frontmatter:J}}function YJ($){return dA($)}function VJ($){return cA($)}function AJ($){return lA($)}async function bQ($){if(e$($)===".cline"){let f=await ZJ($);return(await Promise.all(f.map((Q)=>bQ(O0(Q,fJ))))).flat()}try{let f=await ef($,{withFileTypes:!0}),J=[];for(let Q of f){if(Q.isFile()&&Q.name===o8){J.push({directoryPath:$,fileName:Q.name,filePath:O0($,Q.name)});continue}if(Q.isDirectory())J.push({directoryPath:O0($,Q.name),fileName:o8,filePath:O0($,Q.name,o8)})}return J}catch(f){if(F2(f))return[];throw f}}async function f4($){if(e$($)===".cline"){let f=await ZJ($);return(await Promise.all(f.map((Q)=>f4(O0(Q,"rules.md"))))).flat()}try{if((await CQ($)).isFile())return[{directoryPath:uA($),fileName:e$($),filePath:$}]}catch(f){if(!F2(f))throw f}try{let J=(await ef($,{withFileTypes:!0})).filter((Z)=>Z.isFile()&&e8(Z.name)).map((Z)=>({directoryPath:$,fileName:Z.name,filePath:O0($,Z.name)})),Q=O0($,"AGENTS.md");try{if((await CQ(Q)).isFile()){if(!J.some((j)=>j.fileName==="AGENTS.md"))J.push({directoryPath:$,fileName:"AGENTS.md",filePath:Q})}}catch{}return J}catch(f){if(F2(f))return[];throw f}}async function nA($){if(e$($)===".cline"){let f=await ZJ($);return(await Promise.all(f.map((Q)=>f4(O0(Q,JJ))))).flat()}return f4($)}function BJ($){let f=$?.directories??YJ($?.workspacePath),J=$?.workspacePath?O0($.workspacePath,".cline"):void 0;return{type:"skill",directories:J?[...f,J]:f,discoverFiles:bQ,includeFile:(Q)=>Q===o8,parseFile:(Q)=>jJ(Q.content,e$(Q.directoryPath)),resolveId:(Q)=>QJ(Q.name)}}function GJ($){let f=$?.directories??VJ($?.workspacePath),J=$?.workspacePath?O0($.workspacePath,".cline"):void 0;return{type:"rule",directories:J?[...f,J]:f,discoverFiles:f4,includeFile:(Q,Z)=>Q===".clinerules"||e8(Q)||e8(Z),parseFile:(Q)=>XJ(Q.content,e$(Q.filePath,$J(Q.filePath))),resolveId:(Q)=>QJ(Q.name)}}function KJ($){let f=$?.directories??AJ($?.workspacePath),J=$?.workspacePath?O0($.workspacePath,".cline"):void 0;return{type:"workflow",directories:J?[...f,J]:f,discoverFiles:nA,includeFile:(Q)=>e8(Q),parseFile:(Q)=>HJ(Q.content,e$(Q.filePath,$J(Q.filePath))),resolveId:(Q)=>QJ(Q.name)}}function kQ($){let f=[BJ($?.skills),GJ($?.rules),KJ($?.workflows)];return new K2(f,{debounceMs:$?.debounceMs,emitParseErrors:$?.emitParseErrors})}import{truncateSplit as IQ}from"@cline/shared";function aA($,f){if($.description?.trim())return IQ($.description,".");if(f==="workflow")return;return IQ($.instructions,".")}function tA($){return $.disabled!==!0}function xQ($,f){return[...$.getSnapshot(f).entries()].map(([J,Q])=>({id:J,record:Q})).filter(({record:J})=>tA(J.item)).map(({id:J,record:Q})=>({id:J,name:Q.item.name,instructions:Q.item.instructions,description:aA(Q.item,f),kind:f})).sort((J,Q)=>J.name.localeCompare(Q.name))}function P2($){let f=new Map;for(let J of[...xQ($,"workflow"),...xQ($,"skill")])if(!f.has(J.name))f.set(J.name,J);return[...f.values()].sort((J,Q)=>J.name.localeCompare(Q.name))}function mQ($,f){if(!$.startsWith("/")||$.length<2)return $;let J=$.match(/^\/(\S+)/);if(!J)return $;let Q=J[1];if(!Q)return $;let Z=Q.length+1,W=$.slice(Z),j=P2(f).find((X)=>X.name===Q);return j?`${j.instructions}${W}`:$}function gQ($){return $.disabled!==!0}function J4($){if($.length===0)return"";return`
|
|
46
|
+
</html>`;function z9($){let f="";for(let J=0;J<$.length;J+=1)f+=String.fromCharCode($[J]??0);return btoa(f).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}async function WV($){let J=new TextEncoder().encode($),W=await crypto.subtle.digest("SHA-256",J);return new Uint8Array(W)}function ZV($=32){let f=new Uint8Array($);return crypto.getRandomValues(f),z9(f)}async function o2(){let $=ZV(),f=z9(await WV($));return{verifier:$,challenge:f}}function e2($){return $.endsWith("/")?$.slice(0,-1):$}function W1($,f){return new URL(f,`${e2($)}/`).toString()}function v1($,f={}){let J=$.trim();if(!J)return{};try{let W=new URL(J);return{code:W.searchParams.get("code")??void 0,state:W.searchParams.get("state")??void 0,provider:f.includeProvider?W.searchParams.get("provider")??void 0:void 0}}catch{}if(f.allowHashCodeState&&J.includes("#")){let[W,Z]=J.split("#",2);return{code:W||void 0,state:Z||void 0}}if(J.includes("code=")){let W=new URLSearchParams(J);return{code:W.get("code")??void 0,state:W.get("state")??void 0,provider:f.includeProvider?W.get("provider")??void 0:void 0}}return{code:J}}function QV($){if(typeof atob==="function")try{return atob($)}catch{return null}if(typeof Buffer<"u")try{return Buffer.from($,"base64").toString("utf8")}catch{return null}return null}function P0($){if(!$)return null;try{let f=$.split(".");if(f.length!==3)return null;let J=f[1];if(!J)return null;let W=J.replace(/-/g,"+").replace(/_/g,"/"),Z=W.padEnd(W.length+(4-W.length%4)%4,"="),Q=QV(Z);if(!Q)return null;return JSON.parse(Q)}catch{return null}}function u1($){try{let f=JSON.parse($),J=f.error,W=typeof J==="string"?J:J&&typeof J==="object"&&typeof J.type==="string"?J.type:void 0,Z=typeof f.error_description==="string"?f.error_description:typeof f.message==="string"?f.message:J&&typeof J==="object"&&typeof J.message==="string"?J.message:void 0;return{code:W,message:Z}}catch{return{}}}function Z1($,f){return Date.now()>=$.expires-f}async function c1($){if(!$.onManualCodeInput){let Q=await $.waitForCallback();return{code:Q?.code,state:Q?.state,provider:Q?.provider,error:Q?.error}}let f,J,W=$.onManualCodeInput().then((Q)=>{f=Q,$.cancelWait()}).catch((Q)=>{J=Q instanceof Error?Q:Error(String(Q)),$.cancelWait()}),Z=await $.waitForCallback();if(J)throw J;if(Z?.code||Z?.error)return{code:Z.code,state:Z.state,provider:Z.provider,error:Z.error};if(f)return v1(f,$.parseOptions);if(await W,J)throw J;if(f)return v1(f,$.parseOptions);return{}}var $8={authorize:"/api/v1/auth/authorize",token:"/api/v1/auth/token",register:"/api/v1/auth/register",refresh:"/api/v1/auth/refresh"},y9={deviceAuthorization:"/user_management/authorize/device",authenticate:"/user_management/authenticate"},f6="https://api.workos.com",jV="/auth",T9=Array.from({length:11},($,f)=>48801+f),HV=300000,XV=30000,d1=30000,YV=300,AV=5;class _$ extends Error{status;errorCode;constructor($,f){super($);this.name="ClineOAuthTokenError",this.status=f?.status,this.errorCode=f?.errorCode}isLikelyInvalidGrant(){if(this.errorCode&&/invalid_grant|invalid_token|unauthorized/i.test(this.errorCode))return!0;if(this.status===400||this.status===401||this.status===403)return/invalid|expired|revoked|unauthorized/i.test(this.message);return!1}}function VV($){let f=Date.parse($);if(Number.isNaN(f))throw Error(`Invalid expiresAt value: ${$}`);return f}function J6($,f,J={}){let W=$.userInfo.clineUserId??J.accountId,Z=$.refreshToken??J.refresh;if(!Z)throw Error("Token response did not include a refresh token");return{access:$.accessToken,refresh:Z,expires:VV($.expiresAt),accountId:W??void 0,email:$.userInfo.email||J.email,metadata:{provider:f,tokenType:$.tokenType,userInfo:$.userInfo}}}async function W6($){if(!$)return{};return typeof $==="function"?await $():$}function N9($,f){if(typeof $!=="number"||!Number.isFinite($)||$<=0)return f;return Math.floor($)}async function M9($){await new Promise((f)=>setTimeout(f,$))}function Z6($,f){if(!$.success||!$.data?.accessToken)throw Error(f);return $.data}async function q9($,f){let J=await fetch(W1(f6,y9.deviceAuthorization),{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({client_id:$}),signal:AbortSignal.timeout(f?.requestTimeoutMs??d1)}),W=await J.json().catch(()=>({}));if(!J.ok)throw new _$(`Device authorization failed: ${J.status}${W.error_description?` - ${W.error_description}`:""}`,{status:J.status,errorCode:W.error});if(!W.device_code||!W.user_code||!W.verification_uri)throw Error("Invalid WorkOS device authorization response");return{deviceCode:W.device_code,userCode:W.user_code,verificationUri:W.verification_uri,verificationUriComplete:W.verification_uri_complete,expiresInSeconds:N9(W.expires_in,YV),pollIntervalSeconds:N9(W.interval,AV)}}async function w9($){let f=Date.now()+$.expiresInSeconds*1000,J=Math.max(1,$.initialPollIntervalSeconds);while(Date.now()<=f){let W=await fetch(W1($.workosApiBaseUrl,y9.authenticate),{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"urn:ietf:params:oauth:grant-type:device_code",device_code:$.deviceCode,client_id:$.clientId}),signal:AbortSignal.timeout($.requestTimeoutMs)}),Z=await W.json().catch(()=>({}));if(W.ok){if(!Z.access_token||!Z.refresh_token)throw Error("Invalid WorkOS token response");return{accessToken:Z.access_token,refreshToken:Z.refresh_token,tokenType:Z.token_type??"Bearer"}}switch(Z.error){case"authorization_pending":{await M9(J*1000);break}case"slow_down":{J+=1,await M9(J*1000);break}case"access_denied":case"expired_token":case"invalid_grant":throw new _$(Z.error_description||"WorkOS authorization failed",{status:W.status,errorCode:Z.error});default:throw new _$(`WorkOS token polling failed: ${W.status}${Z.error_description?` - ${Z.error_description}`:""}`,{status:W.status,errorCode:Z.error})}$.onProgress?.("Waiting for browser authentication confirmation...")}throw Error("WorkOS device authorization timed out")}async function S9($,f,J){let W={accessToken:$.accessToken,refreshToken:$.refreshToken},Z=await fetch(W1(f.apiBaseUrl,$8.register),{method:"POST",headers:{"Content-Type":"application/json",...await W6(f.headers)},body:JSON.stringify(W),signal:AbortSignal.timeout(f.requestTimeoutMs??d1)});if(!Z.ok){let j=await Z.text().catch(()=>""),H=u1(j);throw new _$(`Token registration failed: ${Z.status}${H.message?` - ${H.message}`:""}`,{status:Z.status,errorCode:H.code})}let Q=await Z.json();return J6(Z6(Q,"Invalid token exchange response"),J??f.provider)}async function BV($,f,J,W){let Z={grant_type:"authorization_code",code:$,client_type:"extension",redirect_uri:f,provider:W??J.provider},Q=await fetch(W1(J.apiBaseUrl,$8.token),{method:"POST",headers:{"Content-Type":"application/json",...await W6(J.headers)},body:JSON.stringify(Z),signal:AbortSignal.timeout(J.requestTimeoutMs??d1)});if(!Q.ok){let H=await Q.text().catch(()=>""),X=u1(H);throw new _$(`Token exchange failed: ${Q.status}${X.message?` - ${X.message}`:""}`,{status:Q.status,errorCode:X.code})}let j=await Q.json();return J6(Z6(j,"Invalid token exchange response"),W??J.provider)}async function f8($){R$($.telemetry,$.provider??"cline");let f=$.useWorkOSDeviceAuth??!0,J=$.callbackPorts?.length?$.callbackPorts:T9,W=$.callbackPath??jV,Z=f?null:await W$({ports:J,callbackPath:W,onListening:$.callbacks.onServerListening,onClose:$.callbacks.onServerClose}),Q=Z?.callbackUrl||`http://127.0.0.1:${J[0]??T9[0]}${W}`;try{let j;if(f){let H=$6().workOsClientId,X=await q9(H,$);$.callbacks.onAuth({url:X.verificationUriComplete??X.verificationUri,instructions:`Enter this code in your browser: ${X.userCode}`});let Y=await w9({clientId:H,deviceCode:X.deviceCode,expiresInSeconds:X.expiresInSeconds,initialPollIntervalSeconds:X.pollIntervalSeconds,requestTimeoutMs:$.requestTimeoutMs??d1,workosApiBaseUrl:f6,onProgress:$.callbacks.onProgress});j=await S9(Y,$,$.provider)}else{let H=new URL(W1($.apiBaseUrl,$8.authorize));H.searchParams.set("client_type","extension"),H.searchParams.set("callback_url",Q),H.searchParams.set("redirect_uri",Q),$.callbacks.onAuth({url:H.toString(),instructions:"Continue the authentication process in your browser."});let X,Y=$.provider,A=await c1({waitForCallback:Z?.waitForCallback??(async()=>null),cancelWait:Z?.cancelWait??(()=>{}),onManualCodeInput:$.callbacks.onManualCodeInput,parseOptions:{includeProvider:!0}});if(A.error)throw Error(`OAuth error: ${A.error}`);if(X=A.code,Y=A.provider??Y,!X){let V=await $.callbacks.onPrompt({message:"Paste the authorization code (or full redirect URL):"}),B=v1(V,{includeProvider:!0});X=B.code,Y=B.provider??Y}if(!X)throw Error("Missing authorization code");j=await BV(X,Q,$,Y)}return D$($.telemetry,$.provider??"cline"),O$($.telemetry,{id:j.accountId,email:j.email,provider:$.provider??"cline"}),j}catch(j){throw L$($.telemetry,$.provider??"cline",j instanceof Error?j.message:String(j)),j}finally{Z?.close()}}async function KV($){return await q9($6().workOsClientId,$)}async function GV($){let f=$.provider??"cline";R$($.telemetry,f);try{let J=await w9({clientId:$6().workOsClientId,deviceCode:$.deviceCode,expiresInSeconds:$.expiresInSeconds,initialPollIntervalSeconds:$.pollIntervalSeconds,requestTimeoutMs:$.requestTimeoutMs??d1,workosApiBaseUrl:f6}),W=await S9(J,{apiBaseUrl:$.apiBaseUrl,headers:$.headers,requestTimeoutMs:$.requestTimeoutMs,provider:$.provider},$.provider);return D$($.telemetry,f),O$($.telemetry,{id:W.accountId,email:W.email,provider:f}),W}catch(J){throw L$($.telemetry,f,J instanceof Error?J.message:String(J)),J}}async function Q6($,f){let J=await fetch(W1(f.apiBaseUrl,$8.refresh),{method:"POST",headers:{"Content-Type":"application/json",...await W6(f.headers)},body:JSON.stringify({refreshToken:$.refresh,grantType:"refresh_token"}),signal:AbortSignal.timeout(f.requestTimeoutMs??d1)});if(!J.ok){let Q=await J.text().catch(()=>""),j=u1(Q);throw new _$(`Token refresh failed: ${J.status}${j.message?` - ${j.message}`:""}`,{status:J.status,errorCode:j.code})}let W=await J.json(),Z=$.metadata?.provider??f.provider;return J6(Z6(W,"Invalid token refresh response"),Z,$)}async function j6($,f,J){if(!$)return null;let W=J?.refreshBufferMs??HV,Z=J?.retryableTokenGraceMs??XV;if(J?.forceRefresh!==!0&&!Z1($,W))return $;try{return await Q6($,f)}catch(j){if(j instanceof _$&&j.isLikelyInvalidGrant())return f1(f.telemetry,f.provider??"cline","invalid_grant"),null;if($.expires-Date.now()>Z)return $;return null}}function PV($){return{id:"cline",name:"Cline Account",usesCallbackServer:!($.useWorkOSDeviceAuth??!0),async login(f){return f8({...$,callbacks:f})},async refreshToken(f){return Q6(f,$)},getApiKey(f){return`workos:${f.access}`}}}B0();import{nanoid as FV}from"nanoid";var t={authorizationEndpoint:"https://auth.openai.com/oauth/authorize",tokenEndpoint:"https://auth.openai.com/oauth/token",clientId:"app_EMoamEEZ73f0CkXaXp7hrann",redirectUri:"http://localhost:1455/auth/callback",scopes:"openid profile email offline_access",callbackPort:1455,jwtClaimPath:"https://api.openai.com/auth",refreshBufferMs:300000,retryableTokenGraceMs:30000,httpTimeoutMs:30000};class J8 extends Error{status;errorCode;constructor($,f){super($);this.name="OpenAICodexOAuthTokenError",this.status=f?.status,this.errorCode=f?.errorCode}isLikelyInvalidGrant(){if(this.errorCode&&/invalid_grant/i.test(this.errorCode))return!0;if(this.status===400||this.status===401||this.status===403)return/invalid_grant|revoked|expired|invalid refresh/i.test(this.message);return!1}}async function UV($,f,J=t.redirectUri){let W=await fetch(t.tokenEndpoint,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"authorization_code",client_id:t.clientId,code:$,code_verifier:f,redirect_uri:J}),signal:AbortSignal.timeout(t.httpTimeoutMs)});if(!W.ok)return{type:"failed"};let Z=await W.json();if(!Z.access_token||!Z.refresh_token||typeof Z.expires_in!=="number")return{type:"failed"};return{type:"success",access:Z.access_token,refresh:Z.refresh_token,expires:Date.now()+Z.expires_in*1000,email:Z.email,idToken:Z.id_token}}async function RV($){try{let f=await fetch(t.tokenEndpoint,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"refresh_token",refresh_token:$,client_id:t.clientId}),signal:AbortSignal.timeout(t.httpTimeoutMs)});if(!f.ok){let W=await f.text().catch(()=>""),Z=u1(W);throw new J8(`Token refresh failed: ${f.status}${Z.message?` - ${Z.message}`:""}`,{status:f.status,errorCode:Z.code})}let J=await f.json();if(!J.access_token||!J.refresh_token||typeof J.expires_in!=="number")return{type:"failed"};return{type:"success",access:J.access_token,refresh:J.refresh_token,expires:Date.now()+J.expires_in*1000,email:J.email,idToken:J.id_token}}catch(f){if(f instanceof J8)throw f;return{type:"failed"}}}async function DV($="pi"){let{verifier:f,challenge:J}=await o2(),W=FV(32),Z=new URL(t.authorizationEndpoint);return Z.searchParams.set("response_type","code"),Z.searchParams.set("client_id",t.clientId),Z.searchParams.set("redirect_uri",t.redirectUri),Z.searchParams.set("scope",t.scopes),Z.searchParams.set("code_challenge",J),Z.searchParams.set("code_challenge_method","S256"),Z.searchParams.set("state",W),Z.searchParams.set("id_token_add_organizations","true"),Z.searchParams.set("codex_cli_simplified_flow","true"),Z.searchParams.set("originator",$),{verifier:f,state:W,url:Z.toString()}}function LV(){try{let $=new URL(t.redirectUri),f=$.port.length>0?Number.parseInt($.port,10):t.callbackPort;return{host:$.hostname||"localhost",port:Number.isFinite(f)?f:t.callbackPort,callbackPath:$.pathname||"/auth/callback",redirectUri:$.toString()}}catch{return{host:"localhost",port:t.callbackPort,callbackPath:"/auth/callback",redirectUri:t.redirectUri}}}function h9($,f){let J=f?P0(f):P0($),W=J?J:P0($),Q=W?.[t.jwtClaimPath]?.chatgpt_account_id;if(typeof Q==="string"&&Q.length>0)return Q;let j=W?.organizations;if(Array.isArray(j)&&j.length>0){let X=j[0];if(typeof X?.id==="string"&&X.id.length>0)return X.id}let H=W?.chatgpt_account_id;if(typeof H==="string"&&H.length>0)return H;return null}function C9($,f){let J=h9($.access,$.idToken)??f?.accountId;if(!J)throw Error("Failed to extract accountId from token");return{access:$.access,refresh:$.refresh||f?.refresh||"",expires:$.expires,accountId:J,email:$.email??f?.email,metadata:{...f?.metadata??{},provider:"openai-codex"}}}async function W8($){R$($.telemetry,"openai-codex");let f=LV(),{verifier:J,state:W,url:Z}=await DV($.originator),Q=await W$({host:f.host,ports:[f.port],callbackPath:f.callbackPath,expectedState:W});$.onAuth({url:Z,instructions:"Continue the authentication process in your browser."});let j;try{let H=await c1({waitForCallback:Q.waitForCallback,cancelWait:Q.cancelWait,onManualCodeInput:$.onManualCodeInput,parseOptions:{allowHashCodeState:!0}});if(H.state&&H.state!==W)throw Error("State mismatch");if(j=H.code,!j){let A=await $.onPrompt({message:"Paste the authorization code (or full redirect URL):"}),V=v1(A,{allowHashCodeState:!0});if(V.state&&V.state!==W)throw Error("State mismatch");j=V.code}if(!j)throw Error("Missing authorization code");let X=await UV(j,J,f.redirectUri);if(X.type!=="success")throw Error("Token exchange failed");let Y=C9(X);return D$($.telemetry,"openai-codex"),O$($.telemetry,{id:Y.accountId,email:Y.email,provider:"openai-codex"}),Y}catch(H){throw L$($.telemetry,"openai-codex",H instanceof Error?H.message:String(H)),H}finally{Q.close()}}async function H6($,f){let J=await RV($);if(J.type!=="success")throw Error("Failed to refresh OpenAI Codex token");let W=C9(J,f);if(!W.refresh)throw Error("Failed to refresh OpenAI Codex token: missing refresh token");return W}async function X6($,f){if(!$)return null;let J=f?.refreshBufferMs??t.refreshBufferMs,W=f?.retryableTokenGraceMs??t.retryableTokenGraceMs;if(f?.forceRefresh!==!0&&!Z1($,J))return $;try{return await H6($.refresh,$)}catch(Q){if(Q instanceof J8&&Q.isLikelyInvalidGrant())return f1(f?.telemetry,"openai-codex","invalid_grant"),null;if($.expires-Date.now()>W)return $;return null}}function OV($,f=t.refreshBufferMs){return Z1($,f)}function _V($){let f=$.accountId??h9($.access);if(!f)throw Error("Failed to extract accountId from token");return{...$,accountId:f,metadata:{...$.metadata??{},provider:"openai-codex"}}}var zV={id:"openai-codex",name:"ChatGPT Plus/Pro (ChatGPT Subscription)",usesCallbackServer:!0,async login($){return W8({onAuth:$.onAuth,onPrompt:$.onPrompt,onProgress:$.onProgress,onManualCodeInput:$.onManualCodeInput})},async refreshToken($){return H6($.refresh,$)},getApiKey($){return $.access}};B0();import{nanoid as E9}from"nanoid";class Y6{ttlMs;maxEntries;entries=new Map;constructor($,f){this.ttlMs=$;this.maxEntries=f}get($,f=Date.now()){this.pruneExpired(f);let J=this.entries.get($);if(!J)return;return this.entries.delete($),this.entries.set($,J),J.value}set($,f,J=Date.now(),W=this.ttlMs){this.pruneExpired(J),this.entries.delete($);while(this.entries.size>=this.maxEntries){let Z=this.entries.keys().next().value;if(Z===void 0)break;this.entries.delete(Z)}this.entries.set($,{value:f,expiresAt:J+W})}pruneExpired($){for(let[f,J]of this.entries)if(J.expiresAt<=$)this.entries.delete(f)}}var TV="a8331954c0cf48ba99b5dd223a14c6ea",NV="https://idcs-9dc693e80d9b469480d7afe00e743931.identity.oraclecloud.com",MV="openid offline_access",V6="https://code-internal.aiservice.us-chicago-1.oci.oraclecloud.com/20250206/app/litellm",yV="c1aba3deed5740659981a752714eba33",qV="https://login-ext.identity.oraclecloud.com",wV="openid offline_access",B6="https://code.aiservice.us-chicago-1.oci.oraclecloud.com/20250206/app/litellm",SV="opc-request-id",hV="/auth/oca",CV=Array.from({length:11},($,f)=>48801+f),EV=300000,bV=30000,b9=30000,kV=600000;class Z8 extends Error{status;errorCode;constructor($,f){super($);this.name="OcaOAuthTokenError",this.status=f?.status,this.errorCode=f?.errorCode}isLikelyInvalidGrant(){if(this.errorCode&&/invalid_grant|invalid_token|unauthorized/i.test(this.errorCode))return!0;return this.status===400||this.status===401||this.status===403}}var z$={internal:{clientId:TV,idcsUrl:NV,scopes:MV,baseUrl:V6},external:{clientId:yV,idcsUrl:qV,scopes:wV,baseUrl:B6}},Nf=new Map,IV=86400000,xV=300000,mV=32,A6=new Y6(IV,mV);function k9($){if(typeof $==="function")return $();return $??"internal"}function I9($){return{internal:{clientId:$?.internal?.clientId??z$.internal.clientId,idcsUrl:$?.internal?.idcsUrl??z$.internal.idcsUrl,scopes:$?.internal?.scopes??z$.internal.scopes,baseUrl:$?.internal?.baseUrl??z$.internal.baseUrl},external:{clientId:$?.external?.clientId??z$.external.clientId,idcsUrl:$?.external?.idcsUrl??z$.external.idcsUrl,scopes:$?.external?.scopes??z$.external.scopes,baseUrl:$?.external?.baseUrl??z$.external.baseUrl}}}function gV($=Date.now()){let f=$-kV;for(let[J,W]of Nf.entries())if(W.createdAt<f)Nf.delete(J)}function vV($,f,J){if(typeof $.expires_in==="number"&&$.expires_in>0)return Date.now()+$.expires_in*1000;let Z=P0(f)?.exp;if(typeof Z==="number"&&Z>0)return Z*1000;let j=P0(J)?.exp;if(typeof j==="number"&&j>0)return j*1000;return Date.now()+3600000}function x9($,f,J){let W=$.access_token;if(!W)throw Error("Token response did not include an access token");let Z=$.refresh_token??J?.refresh;if(!Z)throw Error("Token response did not include a refresh token");let Q=P0($.id_token),j=P0(W),H=Q?.sub??j?.sub,X=Q?.email??j?.email;return{access:W,refresh:Z,expires:vV($,W,$.id_token),accountId:H??J?.accountId,email:X??J?.email,metadata:{...J?.metadata??{},provider:"oca",mode:f,subject:H,idToken:$.id_token}}}async function m9($,f){let J=e2($),W=A6.get(J);if(W)return W;let Z=`${J}/.well-known/openid-configuration`,Q=await fetch(Z,{method:"GET",signal:AbortSignal.timeout(f)});if(!Q.ok){let X=`${J}/oauth2/v1/token`;return A6.set(J,X,Date.now(),xV),X}let H=(await Q.json()).token_endpoint||`${J}/oauth2/v1/token`;return A6.set(J,H),H}function g9($){return{code:$.error,message:$.error_description}}async function uV($){let f=Nf.get($.state);if(!f)throw Error("No PKCE verifier found for this state");Nf.delete($.state);let J=$.mode==="external"?$.config.external:$.config.internal,W=await m9(J.idcsUrl,$.requestTimeoutMs),Z=new URLSearchParams({grant_type:"authorization_code",code:$.code,redirect_uri:f.redirectUri,client_id:J.clientId,code_verifier:f.verifier}),Q=await fetch(W,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:Z,signal:AbortSignal.timeout($.requestTimeoutMs)}),j=await Q.json();if(!Q.ok){let X=g9(j);throw new Z8(`Token exchange failed: ${Q.status}${X.message?` - ${X.message}`:""}`,{status:Q.status,errorCode:X.code})}let H=P0(j.id_token);if(!j.id_token||!H)throw Error("No ID token received from OCA");if(H.nonce!==f.nonce)throw Error("OIDC nonce verification failed");return x9(j,$.mode)}function cV($){let f=$.mode==="external"?$.config.external:$.config.internal,J=new URL(`${e2(f.idcsUrl)}/oauth2/v1/authorize`);return J.searchParams.set("client_id",f.clientId),J.searchParams.set("response_type","code"),J.searchParams.set("scope",f.scopes),J.searchParams.set("code_challenge",$.challenge),J.searchParams.set("code_challenge_method","S256"),J.searchParams.set("redirect_uri",$.callbackUrl),J.searchParams.set("state",$.state),J.searchParams.set("nonce",$.nonce),J.toString()}async function Q8($){R$($.telemetry,"oca");let f=I9($.config),J=k9($.mode),W=$.callbackPorts?.length?$.callbackPorts:CV,Z=$.callbackPath??hV,Q=$.requestTimeoutMs??b9,j=await W$({ports:W,callbackPath:Z,onListening:$.callbacks.onServerListening,onClose:$.callbacks.onServerClose}),H=j.callbackUrl;if(!H)throw Error("Unable to bind local OAuth callback server");let X=E9(16),Y=E9(16),{verifier:A,challenge:V}=await o2();gV(),Nf.set(X,{verifier:A,nonce:Y,mode:J,redirectUri:H,createdAt:Date.now()});let B=cV({callbackUrl:H,mode:J,state:X,nonce:Y,challenge:V,config:f});$.callbacks.onAuth({url:B,instructions:"Continue the authentication process in your browser."});try{let K=await c1({waitForCallback:j.waitForCallback,cancelWait:j.cancelWait,onManualCodeInput:$.callbacks.onManualCodeInput}),G=K.code,R=K.state;if(K.error)throw Error(`OAuth error: ${K.error}`);if(!G){if(!$.callbacks.onManualCodeInput)throw Error("Timed out waiting for OCA callback");throw Error("Missing authorization code")}if(!R||R!==X)throw Error("State mismatch");let P=await uV({code:G,state:R,mode:J,config:f,requestTimeoutMs:Q});return D$($.telemetry,"oca"),O$($.telemetry,{id:P.accountId,email:P.email,provider:"oca"}),P}catch(K){throw L$($.telemetry,"oca",K instanceof Error?K.message:String(K)),K}finally{j.close()}}async function K6($,f={}){let J=I9(f.config),W=f.requestTimeoutMs??b9,Z=$.metadata?.mode,Q=Z==="internal"||Z==="external"?Z:k9(f.mode),j=Q==="external"?J.external:J.internal,H=await m9(j.idcsUrl,W),X=new URLSearchParams({grant_type:"refresh_token",refresh_token:$.refresh,client_id:j.clientId}),Y=await fetch(H,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:X,signal:AbortSignal.timeout(W)}),A=await Y.json();if(!Y.ok){let V=g9(A);throw new Z8(`Token refresh failed: ${Y.status}${V.message?` - ${V.message}`:""}`,{status:Y.status,errorCode:V.code})}return x9(A,Q,$)}async function G6($,f,J){if(!$)return null;let W=f?.refreshBufferMs??J?.refreshBufferMs??EV,Z=f?.retryableTokenGraceMs??J?.retryableTokenGraceMs??bV;if(f?.forceRefresh!==!0&&!Z1($,W))return $;try{return await K6($,J)}catch(j){if(j instanceof Z8&&j.isLikelyInvalidGrant())return f1(J?.telemetry,"oca","invalid_grant"),null;if($.expires-Date.now()>Z)return $;return null}}function dV($={}){return{id:"oca",name:"Oracle Code Assist",usesCallbackServer:!0,async login(f){return Q8({...$,callbacks:f})},async refreshToken(f){return K6(f,$)},getApiKey(f){return f.access}}}async function v9($,f){let J=new TextEncoder,W=async(Y)=>{let A=await crypto.subtle.digest("SHA-256",J.encode(Y));return Array.from(new Uint8Array(A).slice(0,4),(V)=>V.toString(16).padStart(2,"0")).join("")},[Z,Q]=await Promise.all([W(f),W($)]),j=Math.floor(Date.now()/1000).toString(16).padStart(8,"0"),H=new Uint32Array(1);crypto.getRandomValues(H);let X=(H[0]??0).toString(16).padStart(8,"0");return Z+Q+j+X}async function lV($){let f=await v9($.taskId,$.accessToken);return{Authorization:`Bearer ${$.accessToken}`,"Content-Type":"application/json",client:$.metadata?.client??"Cline","client-version":$.metadata?.clientVersion??"unknown","client-ide":$.metadata?.clientIde??"unknown","client-ide-version":$.metadata?.clientIdeVersion??"unknown",[SV]:f}}import*as M0 from"@cline/llms";import{z as N}from"zod";import*as e from"@cline/llms";function P6($){if(!Array.isArray($))return[];return $.map((f)=>{if(typeof f==="string")return f.trim();if(f&&typeof f==="object"){let J=f;for(let W of[J.id,J.name,J.model])if(typeof W==="string"&&W.trim())return W.trim()}return""}).filter((f)=>f.length>0)}function pV($,f){let J=P6($);if(J.length>0)return J;if(!$||typeof $!=="object")return[];let W=$,Z=P6(W.data??W.models);if(Z.length>0)return Z;if(W.models&&typeof W.models==="object"&&!Array.isArray(W.models)){let j=Object.keys(W.models).filter((H)=>H.trim().length>0);if(j.length>0)return j}let Q=W.providers?.[f];if(Q&&typeof Q==="object"){let H=P6(Q.models??Q);if(H.length>0)return H}return[]}async function j8($,f){let J=await fetch($,{method:"GET"});if(!J.ok)throw Error(`failed to fetch models from ${$}: HTTP ${J.status}`);return pV(await J.json(),f)}function u9($){return $.replace(/\/+$/,"")}function H8($,f,J){let W=J?.trim();if(!W)return;let Z=$?.trim();if(!Z||!f?.trim())return W;try{let Q=new URL(W),j=new URL(f),H=new URL(Z);if(Q.origin!==j.origin)return W;let X=u9(j.pathname),Y=u9(H.pathname);if(X&&Q.pathname.startsWith(`${X}/`)){let A=Q.pathname.slice(X.length);H.pathname=`${Y}${A}`}else H.pathname=Q.pathname;return H.search=Q.search,H.hash=Q.hash,H.toString()}catch{return W}}function rV($){return Object.fromEntries(Object.entries($).map(([f,J])=>[f,{...J}]))}function iV($){if($.baseUrl.length===0)return!1;switch($.client){case"openai-compatible":case"openai":case"openai-r1":case"fetch":return!0;default:return $.protocol==="openai-chat"}}var nV=Object.values(e.MODEL_COLLECTIONS_BY_PROVIDER_ID).map(($)=>({id:$.provider.id,baseUrl:$.provider.baseUrl??"",modelsSourceUrl:$.provider.modelsSourceUrl,modelId:$.provider.defaultModelId,knownModels:rV($.models),capabilities:$.provider.capabilities?[...$.provider.capabilities]:void 0,env:$.provider.env?[...$.provider.env]:void 0,client:$.provider.client,protocol:$.provider.protocol})),l9=Object.fromEntries(nV.map(($)=>[$.id,$]));function aV($){return l9[$]}function tV(){return Object.fromEntries(Object.entries(l9).filter(([,$])=>iV($)))}function p9($=[]){let f=$.flatMap((J)=>{switch(J){case"reasoning":case"prompt-cache":case"tools":case"oauth":return[J];default:return[]}});return f.length>0?f:void 0}var r9="https://models.dev/api.json",sV=600000,i9=300000,oV=5000,Y8=new Map,Mf=new Map,U6=new Map,X8=new Map;async function eV(){return e.getGeneratedProviderModels()}async function $B($,f={},J={},W={},Z={},Q={}){let j=await eV(),H=e.resolveProviderModelCatalogKeys($),X=Object.assign({},...H.map((V)=>j[V]??{})),Y=Boolean(e.MODEL_COLLECTIONS_BY_PROVIDER_ID[$]?.provider.modelsSourceUrl),A=Object.keys(Z).length>0;if(Y&&A)return e.sortModelsByReleaseDate({...Z,...Q});if($==="openai-codex")return e.sortModelsByReleaseDate({...f,...e.filterOpenAICodexModels(J),...Z,...Q});return e.sortModelsByReleaseDate({...X,...f,...J,...W,...Z,...Q})}function fB($,f){let J=e.resolveProviderModelCatalogKeys($);return Object.assign({},...J.map((W)=>f[W]??{}))}function A8($){let f=$?.trim();return f&&f.length>0?f:""}function R6($){let f=$.apiKey?.trim()||$.accessToken?.trim();return f&&f.length>0?f:void 0}function JB($){let f=2166136261;for(let J=0;J<$.length;J+=1)f^=$.charCodeAt(J),f+=(f<<1)+(f<<4)+(f<<7)+(f<<8)+(f<<24);return(f>>>0).toString(16)}function WB($,f){return`${$}:${A8(f.baseUrl)}:${JB(R6(f)??"")}`}async function V8($,f,J=oV){let W=new AbortController,Z=setTimeout(()=>W.abort(),J);try{return await fetch($,{...f,signal:W.signal})}finally{clearTimeout(Z)}}function Q1($,f,J){if(J&&!$.includes(f))$.push(f)}function B8($,f){let J=["streaming","tools"];return Q1(J,"images",Boolean(f.supportsImages)),Q1(J,"prompt-cache",Boolean(f.supportsPromptCache)),Q1(J,"reasoning",Boolean(f.supportsReasoning)),{id:$,name:f.name??$,contextWindow:f.contextWindow,maxInputTokens:f.maxInputTokens,maxTokens:f.maxTokens,capabilities:J,releaseDate:f.releaseDate,status:"active"}}async function ZB($,f){let J=await V8("https://inference.baseten.co/v1/models",{method:"GET",headers:{Authorization:`Bearer ${f}`,"Content-Type":"application/json"}});if(!J.ok)throw Error(`Baseten model refresh failed: HTTP ${J.status}`);let Z=(await J.json())?.data??[],Q={};for(let j of Z){let H=j.id?.trim();if(!H)continue;if(H.includes("whisper")||H.includes("tts")||H.includes("embedding"))continue;let X=j.supported_features??[];Q[H]=B8(H,{name:H,contextWindow:j.context_length,maxInputTokens:j.context_length,maxTokens:j.max_completion_tokens,supportsReasoning:X.includes("reasoning")||X.includes("reasoning_effort"),supportsImages:!1})}return Q}function c9($){if(typeof $==="number")return Number.isFinite($)?$:void 0;if(typeof $==="string"){let f=Number($);return Number.isFinite(f)?f:void 0}return}async function QB($,f){let J=await V8("https://api.hicap.ai/v2/openai/models",{method:"GET",headers:{"api-key":f}});if(!J.ok)throw Error(`Hicap model refresh failed: HTTP ${J.status}`);let Z=(await J.json())?.data??[],Q={};for(let j of Z){let H=j.id?.trim();if(!H)continue;Q[H]=B8(H,{name:H,maxInputTokens:128000,supportsImages:!0,supportsPromptCache:!0})}return Q}async function jB($,f){let W=`${(A8($.baseUrl)||"https://inference.poolside.ai/v1").replace(/\/+$/,"")}/models`,Z=await V8(W,{method:"GET",headers:{Authorization:`Bearer ${f}`,accept:"application/json"}});if(!Z.ok)throw Error(`Poolside model refresh failed: HTTP ${Z.status}`);let j=(await Z.json())?.data??[],H={};for(let X of j){let Y=X.id?.trim();if(!Y)continue;let A=X.supported_features??[],V=X.supported_sampling_parameters??[],B=X.input_modalities??[],K=["streaming"];Q1(K,"tools",A.includes("tools")),Q1(K,"reasoning",A.includes("reasoning")),Q1(K,"temperature",V.includes("temperature")),Q1(K,"images",B.includes("image"));let G={input:c9(X.pricing?.prompt),output:c9(X.pricing?.completion)};H[Y]={id:Y,name:X.name??Y,description:X.description,contextWindow:X.context_length,maxInputTokens:X.context_length,maxTokens:X.max_completion_tokens,capabilities:K,pricing:G.input!==void 0||G.output!==void 0?G:void 0,status:"active"}}return H}function HB($){let f=A8($);if(!f)return"http://localhost:4000";return f.endsWith("/v1")?f.slice(0,-3):f}async function XB($,f){let W=`${HB($.baseUrl)}/v1/model/info`,Z=async(Y)=>V8(W,{method:"GET",headers:{accept:"application/json",...Y}}),Q=await Z({"x-litellm-api-key":f});if(!Q.ok)Q=await Z({Authorization:`Bearer ${f}`});if(!Q.ok)throw Error(`LiteLLM model refresh failed: HTTP ${Q.status}`);let H=(await Q.json())?.data??[],X={};for(let Y of H){let A=Y.model_name?.trim(),B=Y.litellm_params?.model?.trim()||A;if(!B)continue;let K=Y.model_info,G=B8(B,{name:A??B,maxTokens:K?.max_output_tokens??K?.max_tokens,maxInputTokens:K?.max_input_tokens??K?.max_tokens,supportsImages:K?.supports_vision,supportsPromptCache:K?.supports_prompt_caching,supportsReasoning:K?.supports_reasoning});if(X[B]=G,A)X[A]={...G,id:A,name:A}}return X}var n9={baseten:ZB,hicap:QB,litellm:XB,poolside:jB},d9=new Map,F6=new Map;function YB($,f){return`${$}:${A8(f.baseUrl)}`}async function AB($,f,J){let W=e.MODEL_COLLECTIONS_BY_PROVIDER_ID[$],Z=H8(J.baseUrl,W?.provider.baseUrl,W?.provider.modelsSourceUrl);if(!Z)return{};let Q=f?.cacheTtlMs??i9,j=YB($,J),H=Date.now(),X=d9.get(j);if(X&&X.expiresAt>H)return X.data;let Y=F6.get(j);if(Y)return Y;let A=j8(Z,$).then((V)=>{let B=Object.fromEntries(V.map((K)=>[K,B8(K,{name:K})]));return d9.set(j,{data:B,expiresAt:H+Q}),B}).finally(()=>{F6.delete(j)});return F6.set(j,A),A}async function VB($,f){let J=R6(f);if(!J)return{};let W=n9[$];if(!W)return{};return W(f,J)}function BB($,f,J){if(!J)return!1;if(!n9[$])return!1;if(f?.loadPrivateOnAuth===!1)return!1;return Boolean(R6(J))}async function KB($,f,J){let W=f?.cacheTtlMs??i9,Z=WB($,J),Q=Date.now(),j=U6.get(Z);if(j&&j.expiresAt>Q)return j.data;let H=X8.get(Z);if(H)return H;let X=VB($,J).then((Y)=>{return U6.set(Z,{data:Y,expiresAt:Q+W}),Y}).finally(()=>{X8.delete(Z)});return X8.set(Z,X),X}async function GB($){return e.fetchModelsDevProviderModels($,globalThis.fetch)}async function K8($={}){let f=$.url??r9,J=$.cacheTtlMs??sV,W=Date.now(),Z=Y8.get(f);if(Z&&Z.expiresAt>W)return Z.data;let Q=Mf.get(f);if(Q)return Q;let j=GB(f).then((H)=>{return Y8.set(f,{data:H,expiresAt:W+J}),H}).finally(()=>{Mf.delete(f)});return Mf.set(f,j),j}function PB($){if($){Y8.delete($),Mf.delete($);return}Y8.clear(),Mf.clear()}function FB(){U6.clear(),X8.clear()}function UB($){return Object.fromEntries(Object.entries($).map(([f,J])=>[f,{baseUrl:J.baseUrl,modelId:J.modelId,capabilities:p9(J.capabilities)}]))}var D6=UB(tV());function a9($){let f=aV($);if(!f)return;return{baseUrl:f.baseUrl||void 0,modelId:f.modelId,knownModels:f.knownModels,capabilities:p9(f.capabilities)}}async function L6($,f,J){let W=a9($);if(!W)return;try{let Z=f?.loadLatestOnInit?await K8(f):void 0,Q=Z?fB($,Z):{},j=J&&BB($,f,J)?await KB($,f,J):{},X=Boolean(e.MODEL_COLLECTIONS_BY_PROVIDER_ID[$]?.provider.modelsSourceUrl)?J??{providerId:$,modelId:W.modelId,baseUrl:W.baseUrl}:J,Y=X?await AB($,f,X).catch(()=>({})):{},A=await $B($,W.knownModels,Q,j,Y,J?.knownModels);return{...W,knownModels:A}}catch(Z){if(f?.failOnError)throw Z;return W}}var O6=M0.BUILT_IN_PROVIDER,RB=M0.BUILT_IN_PROVIDER_IDS,DB=M0.isBuiltInProviderId,G8=M0.normalizeProviderId,_6=N.string().min(1).regex(/^[a-z0-9][a-z0-9-]*$/i),t9=N.enum(["anthropic","gemini","openai-chat","openai-responses","openai-r1","ai-sdk"]),s9=N.enum(["anthropic","ai-sdk","ai-sdk-community","openai","openai-compatible","openai-r1","gemini","bedrock","custom","fetch","vertex"]),o9=N.object({apiKey:N.string().optional(),accessToken:N.string().optional(),refreshToken:N.string().optional(),expiresAt:N.number().int().positive().optional(),accountId:N.string().optional()}),LB=N.enum(["none","low","medium","high","xhigh"]),e9=N.object({enabled:N.boolean().optional(),effort:LB.optional(),budgetTokens:N.number().int().positive().optional()}),$Q=N.object({accessKey:N.string().optional(),secretKey:N.string().optional(),sessionToken:N.string().optional(),region:N.string().optional(),profile:N.string().optional(),authentication:N.enum(["iam","api-key","apikey","profile"]).optional(),usePromptCache:N.boolean().optional(),useCrossRegionInference:N.boolean().optional(),useGlobalInference:N.boolean().optional(),endpoint:N.string().url().optional(),customModelBaseId:N.string().optional()}),fQ=N.object({projectId:N.string().optional(),region:N.string().optional()}),JQ=N.object({apiVersion:N.string().optional(),useIdentity:N.boolean().optional()}),WQ=N.object({clientId:N.string().optional(),clientSecret:N.string().optional(),tokenUrl:N.string().url().optional(),resourceGroup:N.string().optional(),deploymentId:N.string().optional(),useOrchestrationMode:N.boolean().optional(),api:N.enum(["orchestration","foundation-models"]).optional(),defaultSettings:N.record(N.string(),N.unknown()).optional()}),ZQ=N.object({mode:N.enum(["internal","external"]).optional(),usePromptCache:N.boolean().optional()}),QQ=N.object({loadLatestOnInit:N.boolean().optional(),loadPrivateOnAuth:N.boolean().optional(),url:N.string().url().optional(),cacheTtlMs:N.number().int().positive().optional(),failOnError:N.boolean().optional()}),l1=N.object({provider:_6,apiKey:N.string().optional(),auth:o9.optional(),model:N.string().optional(),protocol:t9.optional(),client:s9.optional(),routingProviderId:_6.optional(),maxTokens:N.number().int().positive().optional(),contextWindow:N.number().int().positive().optional(),baseUrl:N.string().url().optional(),headers:N.record(N.string(),N.string()).optional(),timeout:N.number().int().positive().optional(),reasoning:e9.optional(),aws:$Q.optional(),gcp:fQ.optional(),azure:JQ.optional(),sap:WQ.optional(),oca:ZQ.optional(),region:N.string().optional(),apiLine:N.enum(["china","international"]).optional(),capabilities:N.array(N.enum(["reasoning","prompt-cache","streaming","tools","vision","computer-use","oauth","popular"])).optional(),modelCatalog:QQ.optional()});function jQ($){return l1.parse($)}function HQ($){return l1.safeParse($)}function OB($){return $.protocol==="openai-responses"||$.client==="openai"}function Z$($,f={}){let J=$.provider,W=G8(J),Z=f.includeKnownModels!==!1,Q=$.reasoning?.effort||"none",j=Q==="none"?void 0:Q,H=D6[W],X=Object.assign({},...M0.resolveProviderModelCatalogKeys(W).map((R)=>M0.getGeneratedModelsForProvider(R))),Y=Object.keys(X)[0],A=$.auth?.accessToken??$.apiKey??$.auth?.apiKey,V=$.baseUrl??(W==="oca"?$.oca?.mode==="internal"?V6:B6:H?.baseUrl),B=$.routingProviderId??(OB($)&&W!==O6.OPENAI_NATIVE?O6.OPENAI_NATIVE:void 0),K=Z?H?.knownModels??(Object.keys(X).length>0?X:void 0):void 0,G={providerId:J,clientType:$.client,routingProviderId:B,modelId:$.model??H?.modelId??Y??"default",...Z?{knownModels:K}:{},apiKey:A,accessToken:$.auth?.accessToken,refreshToken:$.auth?.refreshToken,accountId:$.auth?.accountId,baseUrl:V,headers:$.headers,timeoutMs:$.timeout,maxOutputTokens:$.maxTokens,maxInputTokens:$.contextWindow,thinking:$.reasoning?.enabled,reasoningEffort:j,thinkingBudgetTokens:$.reasoning?.budgetTokens,region:$.region??$.aws?.region??$.gcp?.region,apiLine:$.apiLine,useCrossRegionInference:$.aws?.useCrossRegionInference,useGlobalInference:$.aws?.useGlobalInference,aws:$.aws?{accessKey:$.aws.accessKey,secretKey:$.aws.secretKey,sessionToken:$.aws.sessionToken,authentication:$.aws.authentication,profile:$.aws.profile,usePromptCache:$.aws.usePromptCache,endpoint:$.aws.endpoint,customModelBaseId:$.aws.customModelBaseId}:void 0,gcp:$.gcp?{projectId:$.gcp.projectId,region:$.gcp.region}:void 0,azure:$.azure,sap:$.sap,oca:$.oca,capabilities:$.capabilities??H?.capabilities,modelCatalog:$.modelCatalog?{loadLatestOnInit:$.modelCatalog.loadLatestOnInit,loadPrivateOnAuth:$.modelCatalog.loadPrivateOnAuth,url:$.modelCatalog.url,cacheTtlMs:$.modelCatalog.cacheTtlMs,failOnError:$.modelCatalog.failOnError}:void 0};return Object.fromEntries(Object.entries(G).filter(([R,P])=>P!==void 0))}function _B($){let f=jQ($);return Z$(f)}function zB($){let f=HQ($);if(f.success)return{success:!0,config:Z$(f.data)};return{success:!1,error:f.error}}import{SESSION_STATUS_VALUES as TB}from"@cline/shared";var z6=TB,NB=["idle","running","pending"];function MB($){return!NB.includes($)}function $0($){return!MB($)}var F0={CORE:"core",CLI:"cli",SUBAGENT:"subagent",DESKTOP:"desktop",KANBAN:"kanban",API:"api",WEB:"web",VSCODE:"vscode",ENTERPRISE:"enterprise",IDE:"ide",JETBRAINS:"jetbrains",NEOVIM:"neovim",UNKNOWN:"unknown"};function XQ($){if($===!0)return{};if(!$)return;return $}function YQ($){if($==="user")return"global";return $}class T6{getService;constructor($){this.getService=$}async start(){await this.getService().start()}async stop(){await this.getService().stop()}async reconcileNow(){await this.getService().reconcileNow()}ingestEvent($){let f=this.getService().ingestEvent($);return{event:f.event,duplicate:f.duplicate,matchedSpecIds:f.matchedSpecs.map((J)=>J.specId),queuedRuns:f.queuedRuns,suppressions:f.suppressions}}listEvents($){return this.getService().listEventLogs($)}getEvent($){return this.getService().getEventLog($)}listSpecs($){return this.getService().listSpecs($)}listRuns($){return this.getService().listRuns($)}}function AQ($){let{host:f}=$;return{async startSession(J){let W=(J.cwd?.trim()||J.workspaceRoot).trim(),Z=await f.startSession({source:J.source?.trim()||F0.CLI,interactive:!1,config:{providerId:G8(J.provider),modelId:J.model,apiKey:J.apiKey?.trim()||void 0,cwd:W,workspaceRoot:J.workspaceRoot,systemPrompt:J.systemPrompt??"",mode:wB(J),maxIterations:J.maxIterations,enableTools:J.enableTools!==!1,enableSpawnAgent:J.enableSpawn!==!1,enableAgentTeams:J.enableTeams!==!1,disableMcpSettingsTools:J.disableMcpSettingsTools,missionLogIntervalSteps:J.missionStepInterval,missionLogIntervalMs:J.missionTimeIntervalMs},toolPolicies:J.toolPolicies??{"*":{autoApprove:J.autoApproveTools!==!1}},localRuntime:{extensionContext:$.getExtensionContext(),configExtensions:J.configExtensions}});return{sessionId:Z.sessionId,startResult:{sessionId:Z.sessionId,manifestPath:Z.manifestPath,messagesPath:Z.messagesPath}}},async sendSession(J,W){let Z=await f.runTurn({sessionId:J,prompt:W.prompt,userImages:W.attachments?.userImages,userFiles:W.attachments?.userFiles?.map((Q)=>Q.content),delivery:W.delivery});if(!Z)throw Error("ClineCore automation runtime returned no result");return{result:qB(Z)}},async abortSession(J){return await f.abort(J,Error("ClineCore automation abort")),{applied:!0}},async stopSession(J){return await f.stopSession(J),{applied:!0}}}}function P8($){let f=yB($.automationService,$.automation),J=$.context?.client??($.clientName?{name:$.clientName}:void 0),W=$.context?.user??($.distinctId?{distinctId:$.distinctId}:void 0),Z=$.context?.logger??$.logger,Q=$.context?.telemetry??$.telemetry;if(!f&&!J&&!W&&!Z&&!Q)return $.context;return{...$.context??{},...J?{client:J}:{},...W?{user:W}:{},...Z?{logger:Z}:{},...Q?{telemetry:Q}:{},...f?{automation:f}:{}}}function yB($,f){if(!$)return;return{ingestEvent:(J)=>{f.ingestEvent(J)}}}function qB($){return{text:$.text,usage:{inputTokens:$.usage.inputTokens,outputTokens:$.usage.outputTokens,cacheReadTokens:$.usage.cacheReadTokens,cacheWriteTokens:$.usage.cacheWriteTokens,totalCost:$.usage.totalCost},inputTokens:$.usage.inputTokens,outputTokens:$.usage.outputTokens,iterations:$.iterations,finishReason:$.finishReason,toolCalls:$.toolCalls.map((f)=>({name:f.name,input:f.input,output:f.output,error:f.error,durationMs:f.durationMs}))}}function wB($){return $.mode==="plan"?"plan":$.mode==="yolo"?"yolo":"act"}import{existsSync as FJ}from"node:fs";import{basename as e3,isAbsolute as bU,relative as kU}from"node:path";import{createHash as SB}from"node:crypto";import{watch as hB}from"node:fs";import{readdir as CB,readFile as EB}from"node:fs/promises";import{join as bB}from"node:path";function kB($){return SB("sha1").update($).digest("hex")}function KQ($){return Boolean($&&typeof $==="object"&&"code"in $)}function VQ($){return KQ($)&&$.code==="ENOENT"}function BQ($){return KQ($)&&($.code==="EACCES"||$.code==="EPERM")}class yf{definitions;debounceMs;emitParseErrors;listeners=new Set;recordsByType=new Map;watchersByDirectory=new Map;baseTypesByDirectory=new Map;watchedTypesByDirectory=new Map;discoveredDirectoriesByType=new Map;definitionsByType=new Map;pendingTypes=new Set;flushTimer;refreshQueue=Promise.resolve();started=!1;constructor($,f){if($.length===0)throw Error("UnifiedConfigFileWatcher requires at least one definition.");this.definitions=$,this.debounceMs=f?.debounceMs??75,this.emitParseErrors=f?.emitParseErrors??!1;for(let J of $){if(this.definitionsByType.has(J.type))throw Error(`Duplicate unified config definition type '${J.type}'.`);this.definitionsByType.set(J.type,J),this.recordsByType.set(J.type,new Map),this.discoveredDirectoriesByType.set(J.type,new Set);for(let W of J.directories){let Z=this.baseTypesByDirectory.get(W);if(Z)Z.add(J.type);else this.baseTypesByDirectory.set(W,new Set([J.type]))}}}subscribe($){return this.listeners.add($),()=>{this.listeners.delete($)}}async start(){if(this.started)return;this.started=!0,await this.refreshAll(),this.startDirectoryWatchers()}stop(){if(this.started=!1,this.flushTimer)clearTimeout(this.flushTimer),this.flushTimer=void 0;this.pendingTypes.clear();for(let $ of this.watchersByDirectory.values())$.close();this.watchersByDirectory.clear(),this.watchedTypesByDirectory=new Map}async refreshAll(){await this.enqueueRefresh(async()=>{for(let $ of this.definitions)await this.refreshTypeInternal($)})}async refreshType($){let f=this.definitionsByType.get($);if(!f)throw Error(`Unknown unified config type '${$}'.`);await this.enqueueRefresh(async()=>{await this.refreshTypeInternal(f)})}getSnapshot($){let f=this.recordsByType.get($);return new Map([...f?.entries()??[]].map(([J,W])=>[J,{...W}]))}getAllSnapshots(){let $=new Map;for(let[f,J]of this.recordsByType.entries())$.set(f,new Map([...J.entries()].map(([W,Z])=>[W,{...Z}])));return $}emit($){for(let f of this.listeners)f($)}enqueueRefresh($){return this.refreshQueue=this.refreshQueue.then($,$),this.refreshQueue}startDirectoryWatchers(){this.syncDirectoryWatchers()}syncDirectoryWatchers(){let $=this.buildDesiredTypesByDirectory();for(let[f,J]of this.watchersByDirectory.entries()){if($.has(f))continue;J.close(),this.watchersByDirectory.delete(f)}this.watchedTypesByDirectory=$;for(let f of $.keys()){if(this.watchersByDirectory.has(f))continue;try{let J=hB(f,()=>{let W=this.watchedTypesByDirectory.get(f);if(!W)return;for(let Z of W)this.pendingTypes.add(Z);this.scheduleFlush()});this.watchersByDirectory.set(f,J),J.on("error",(W)=>{let Z=this.watchedTypesByDirectory.get(f);if(!Z)return;for(let Q of Z)this.emit({kind:"error",type:Q,error:W,filePath:f})})}catch(J){if(!VQ(J)&&!BQ(J)){let W=$.get(f);if(!W)continue;for(let Z of W)this.emit({kind:"error",type:Z,error:J,filePath:f})}}}}scheduleFlush(){if(this.flushTimer)clearTimeout(this.flushTimer);this.flushTimer=setTimeout(()=>{this.flushTimer=void 0;let $=[...this.pendingTypes];this.pendingTypes.clear(),this.enqueueRefresh(async()=>{for(let f of $){let J=this.definitionsByType.get(f);if(!J)continue;await this.refreshTypeInternal(J)}})},this.debounceMs)}async refreshTypeInternal($){let{records:f,discoveredDirectories:J}=await this.loadDefinition($),W=this.recordsByType.get($.type)??new Map;for(let[Z,Q]of W.entries()){if(f.has(Z))continue;this.emit({kind:"remove",type:$.type,id:Z,filePath:Q.filePath})}for(let[Z,Q]of f.entries()){let j=W.get(Z);if(j&&j.filePath===Q.filePath&&j.fingerprint===Q.fingerprint)continue;this.emit({kind:"upsert",record:{type:Q.type,id:Z,item:Q.item,filePath:Q.filePath}})}if(this.recordsByType.set($.type,f),this.discoveredDirectoriesByType.set($.type,J),this.started)this.syncDirectoryWatchers()}async loadDefinition($){let f=new Map,J=new Set;for(let W of $.directories){J.add(W);let Z=$.discoverFiles?await $.discoverFiles(W):await this.readDirectoryFileCandidates(W);for(let Q of Z){let{fileName:j,filePath:H}=Q;if(J.add(Q.directoryPath),$.includeFile&&!$.includeFile(j,H))continue;try{let X=await EB(H,"utf8"),Y={type:$.type,directoryPath:Q.directoryPath,fileName:j,filePath:H,content:X},A=$.parseFile(Y),V=$.resolveId(A,Y).trim();if(!V)continue;f.set(V,{type:$.type,id:V,item:A,filePath:H,fingerprint:kB(X)})}catch(X){if(this.emitParseErrors)this.emit({kind:"error",type:$.type,error:X,filePath:H})}}}return{records:f,discoveredDirectories:J}}buildDesiredTypesByDirectory(){let $=new Map;for(let[f,J]of this.baseTypesByDirectory.entries())$.set(f,new Set(J));for(let[f,J]of this.discoveredDirectoriesByType.entries())for(let W of J){let Z=$.get(W);if(Z)Z.add(f);else $.set(W,new Set([f]))}return $}async readDirectoryFileCandidates($){try{return(await CB($,{withFileTypes:!0})).filter((J)=>J.isFile()).map((J)=>({directoryPath:$,fileName:J.name,filePath:bB($,J.name)})).sort((J,W)=>J.fileName.localeCompare(W.fileName))}catch(f){if(VQ(f)||BQ(f))return[];throw f}}}import{readdir as r6,readFile as tK,stat as p6}from"node:fs/promises";import{basename as j$,dirname as sK,extname as S8,join as L0,resolve as kf}from"node:path";import{AGENTS_RULES_FILE_NAME as cQ,RULES_CONFIG_DIRECTORY_NAME as dQ,resolveGlobalAgentsRulesPath as oK,resolveRulesConfigSearchPaths as eK,resolveSkillsConfigSearchPaths as $G,resolveWorkflowsConfigSearchPaths as fG,SKILLS_CONFIG_DIRECTORY_NAME as i6,WORKFLOWS_CONFIG_DIRECTORY_NAME as n6}from"@cline/shared/storage";import JG from"yaml";n0();import{existsSync as M8,readFileSync as xK,statSync as mK}from"node:fs";import{basename as gK,dirname as T8,join as y8,resolve as N8}from"node:path";import{discoverPluginModulePaths as vK,resolveConfiguredPluginModulePaths as xQ,resolvePluginConfigSearchPaths as uK,SKILLS_CONFIG_DIRECTORY_NAME as cK}from"@cline/shared/storage";import{resolve as GK}from"node:path";import{normalizePluginManifest as PK}from"@cline/shared";import{existsSync as H0,readFileSync as i1}from"node:fs";import{builtinModules as aB,createRequire as C6}from"node:module";import{dirname as T$,extname as Sf,isAbsolute as tB,resolve as g}from"node:path";import{fileURLToPath as DQ}from"node:url";import{PLUGIN_FILE_EXTENSIONS as sB}from"@cline/shared";var LQ=T$(DQ(import.meta.url)),oB=C6(import.meta.url),eB=g(LQ,"..","..","..","..",".."),w6=JK(eB),$K=["@cline/sdk","@cline/agents","@cline/core","@cline/core/hub","@cline/core/hub/daemon-entry","@cline/core/telemetry","@cline/llms","@cline/llms/browser","@cline/shared","@cline/shared/automation","@cline/shared/browser","@cline/shared/storage","@cline/shared/db","@cline/shared/types"],E6=new Set(aB.flatMap(($)=>[$,$.replace(/^node:/,"")])),wf=new Set(sB),fK=["development","node","import","require","default"];function JK($){let f={},J={"@cline/sdk":g($,"packages/sdk/src/index.ts"),"@cline/agents":g($,"packages/agents/src/index.ts"),"@cline/core":g($,"packages/core/src/index.ts"),"@cline/llms":g($,"packages/llms/src/index.ts"),"@cline/shared":g($,"packages/shared/src/index.ts"),"@cline/shared/storage":g($,"packages/shared/src/storage/index.ts"),"@cline/shared/db":g($,"packages/shared/src/db/index.ts")};for(let[W,Z]of Object.entries(J))if(H0(Z))f[W]=Z;for(let W of["agents","core","llms","shared"]){let Z=g($,"packages",W),Q=g(Z,"package.json");if(!H0(Q))continue;try{let j=JSON.parse(i1(Q,"utf8"));if(typeof j.name!=="string"||!j.exports)continue;if(typeof j.exports==="string"){let H=g(Z,j.exports);if(H0(H))f[j.name]=H;continue}if(typeof j.exports!=="object")continue;for(let[H,X]of Object.entries(j.exports)){let Y=WK(Z,X);if(!Y)continue;let A=H==="."?j.name:`${j.name}/${H.replace(/^\.\//,"")}`;f[A]=Y}}catch{}}return f}function WK($,f){let J=b6(f);if(!J)return null;let W=OQ($,J);for(let Z of W)if(H0(Z))return Z;return null}function b6($,f=new Set){if(typeof $==="string")return $;if(!$||typeof $!=="object")return null;if(f.has($))return null;f.add($);let J=$;for(let W of fK){let Z=b6(J[W],f);if(Z)return Z}return null}function OQ($,f){let J=f.replace(/^\.\//,""),W=[g($,f)];if(J.startsWith("dist/")){let Z=J.replace(/^dist\//,"src/").replace(/\.(mjs|cjs|js)$/,"");return[g($,`${Z}.ts`),g($,`${Z}.tsx`),g($,`${Z}.mts`),g($,`${Z}.cts`),...W]}return W}function ZK($){return Object.fromEntries(Object.entries($).sort(([f],[J])=>J.length-f.length))}function L8($){return!($.startsWith(".")||$.startsWith("/")||$.startsWith("file:")||$.startsWith("data:")||$.startsWith("http:")||$.startsWith("https:"))}function r1($){if($.startsWith("@")){let[f,J]=$.split("/",3);return J?`${f}/${J}`:$}return $.split("/",1)[0]??$}function QK($){let f=r1($);if($===f)return".";return`.${$.slice(f.length)}`}function _Q($){return r1($).startsWith("@cline/")}function S6($,f){let J=r1(f),W=T$($);while(!0){let Z=g(W,"node_modules",J);if(H0(Z)||H0(g(Z,"package.json")))return!0;let Q=g(W,"..");if(Q===W)return!1;W=Q}}function RQ($){return h6($)!==null}function h6($){try{return oB.resolve($)}catch{}return jK($)}function jK($){let f=r1($),J=zQ(f);if(!J)return null;let W=g(J,"package.json");try{let Z=JSON.parse(i1(W,"utf8")),Q=QK($),j=Q==="."&&typeof Z.exports==="string"?Z.exports:Z.exports&&typeof Z.exports==="object"&&Object.hasOwn(Z.exports,Q)?Z.exports[Q]:void 0,H=b6(j)??(Q==="."&&typeof Z.main==="string"?Z.main:null);if(!H)return null;let X=g(J,H),Y=[X,...OQ(J,H).filter((A)=>A!==X)];for(let A of Y)if(H0(A))return A;return null}catch{return null}}function HK(){let $=[LQ],f=process.env.CLINE_WRAPPER_PATH?.trim();if(f)$.push(T$(T$(f)));let J=process.execPath?.trim();if(J)$.push(T$(J));return[...new Set($.map((W)=>g(W)))]}function XK($,f){let J=$;while(!0){let W=g(J,"package.json");if(H0(W))try{if(JSON.parse(i1(W,"utf8")).name===f)return J}catch{}let Z=g(J,"node_modules",f,"package.json");if(H0(Z))return T$(Z);let Q=g(J,"..");if(Q===J)return null;J=Q}}function zQ($){for(let f of HK()){let J=XK(f,$);if(J)return J}return null}function YK($){let J=T$($);for(let W=0;W<4;W++){let Z=g(J,"package.json");if(H0(Z))try{let j=JSON.parse(i1(Z,"utf8"));return j!=null&&typeof j==="object"&&"cline"in j}catch{return!1}let Q=g(J,"..");if(Q===J)return!1;J=Q}return!1}function TQ($,f){let J=f.startsWith("file:")?DQ(f):tB(f)?f:g(T$($),f);if(H0(J)&&wf.has(Sf(J)))return J;for(let W of wf){let Z=`${J}${W}`;if(H0(Z))return Z}for(let W of wf){let Z=g(J,`index${W}`);if(H0(Z))return Z}return null}function NQ($){let f=new Set,J=[/\bimport\s+(?:type\s+)?[^"'`]*?\bfrom\s*["'`]([^"'`]+)["'`]/g,/\bexport\s+[^"'`]*?\bfrom\s*["'`]([^"'`]+)["'`]/g,/\bimport\s*\(\s*["'`]([^"'`]+)["'`]\s*\)/g,/\brequire\s*\(\s*["'`]([^"'`]+)["'`]\s*\)/g];for(let W of J)for(let Z of $.matchAll(W)){let Q=Z[1];if(Q)f.add(Q)}return[...f]}function AK($){return Sf($)!==".ts"}function MQ($,f,J=new Set){if(J.has($)||!H0($))return;if(J.add($),!wf.has(Sf($)))return;let W=i1($,"utf8"),Z=AK($);for(let Q of NQ(W)){if(Q.startsWith("node:")||E6.has(Q))continue;if(L8(Q)){if(!Z)continue;if(Object.hasOwn(w6,Q)||Object.hasOwn(w6,r1(Q))||S6($,Q)||_Q(Q)&&RQ(Q)||f&&RQ(Q))continue;throw Error(`Cannot find module '${r1(Q)}'`)}let j=TQ($,Q);if(j)MQ(j,f,J)}}function yQ($,f=new Set,J=new Set){if(f.has($)||!H0($))return J;if(f.add($),!wf.has(Sf($)))return J;let W=i1($,"utf8");for(let Z of NQ(W)){if(J.add(Z),L8(Z))continue;let Q=TQ($,Z);if(Q)yQ(Q,f,J)}return J}function VK($,f){let J=C6($),W={},Z=yQ($),Q=new Set($K);for(let[j,H]of Object.entries(w6)){try{J.resolve(j);continue}catch{}W[j]=H}for(let j of Z)if(L8(j)&&(_Q(j)||f))Q.add(j);for(let j of Q){if(Object.hasOwn(W,j)||S6($,j))continue;let H=h6(j);if(H)W[j]=H}if(!f)return W;for(let j of Z){if(!L8(j)||Object.hasOwn(W,j)||S6($,j)||j.startsWith("node:")||E6.has(j))continue;let H=h6(j);if(H)W[j]=H}return W}function BK($){let f=Sf($);return f===".ts"||f===".tsx"||f===".mts"||f===".cts"}var H1;function KK(){if(H1!==void 0)return H1;let $=zQ("jiti");if(!$)return H1=null,null;let f=g($,"dist","babel.cjs");if(!H0(f))return H1=null,null;try{let W=C6(f)(f);H1=typeof W==="function"?W:null}catch{H1=null}return H1}async function qQ($,f={}){let J=!YK($);MQ($,J);let W=VK($,J),Z=ZK(W),Q=await import("jiti"),j=typeof Q==="function"?Q:typeof Q.default==="function"?Q.default:void 0;if(!j)throw Error("Unable to load jiti");let H=Object.entries(Z).filter(([,V])=>BK(V)).map(([V])=>V),X=KK(),Y=X?(V)=>X({...V,interopDefault:!0}):void 0;return await j($,{alias:Z,cache:f.useCache,requireCache:f.useCache,esmResolve:!0,interopDefault:!1,nativeModules:[...E6],transformModules:H,tryNative:!1,...Y?{transform:Y}:{}}).import($,{})}function wQ($,f){if(!$)return!0;if($.providerIds?.length){if(!f?.providerId||!$.providerIds.includes(f.providerId))return!1}if($.modelIds?.length){if(!f?.modelId||!$.modelIds.includes(f.modelId))return!1}return!0}function SQ($){return typeof $==="object"&&$!==null}function k6($){return Array.isArray($)&&$.every((f)=>typeof f==="string")}function FK($,f){if(!SQ($.manifest))throw Error(`Invalid plugin module at ${f}: missing required "manifest"`);if(!k6($.manifest.capabilities))throw Error(`Invalid plugin module at ${f}: manifest.capabilities must be a string array`);if($.manifest.capabilities.length===0)throw Error(`Invalid plugin module at ${f}: manifest.capabilities cannot be empty`);if(Object.hasOwn($.manifest,"providerIds")&&!k6($.manifest.providerIds))throw Error(`Invalid plugin module at ${f}: manifest.providerIds must be a string array when provided`);if(Object.hasOwn($.manifest,"modelIds")&&!k6($.manifest.modelIds))throw Error(`Invalid plugin module at ${f}: manifest.modelIds must be a string array when provided`)}function UK($,f){if(!SQ($))throw Error(`Invalid plugin module at ${f}: expected object export`);if(typeof $.name!=="string"||$.name.length===0)throw Error(`Invalid plugin module at ${f}: expected non-empty "name"`);if(!Object.hasOwn($,"manifest"))throw Error(`Invalid plugin module at ${f}: missing required "manifest"`);FK($,f)}async function I6($,f={}){let J=GK(f.cwd??process.cwd(),$),W=await qQ(J,{useCache:f.useCache}),Z=f.exportName??"plugin",Q=W.default??W[Z];UK(Q,J);let j=Q,H=j.setup,X=H?(Y,A)=>{let V={...f.session,...A.session},B={...A,session:Object.keys(V).length>0?V:void 0,client:f.client??A.client,user:f.user??A.user,workspaceInfo:f.workspaceInfo??A.workspaceInfo,automation:f.automation??A.automation,logger:f.logger??A.logger,telemetry:f.telemetry??A.telemetry};return H(Y,B)}:void 0;return{...j,manifest:PK(j.manifest),setup:X}}async function hQ($,f={}){return(await hf($,f)).plugins}async function hf($,f={}){let J=[],W=[],Z=new Map,Q=0;for(let H of $)try{let X=await I6(H,f);if(!wQ(X.manifest,f))continue;let Y=Z.get(X.name);if(Y)W.push({type:"duplicate_plugin_override",pluginName:X.name,pluginPath:H,overriddenPluginPath:Y.pluginPath,message:`Plugin "${X.name}" from ${H} overrides ${Y.pluginPath}`});Z.set(X.name,{plugin:X,pluginPath:H,order:Q++})}catch(X){let Y=X instanceof Error?X.message:String(X);J.push({pluginPath:H,phase:"load",message:Y,stack:X instanceof Error?X.stack:void 0})}let j=[...Z.values()].sort((H,X)=>H.order-X.order);return{plugins:j.map((H)=>H.plugin),pluginPaths:j.map((H)=>H.pluginPath),failures:J,warnings:W}}import{existsSync as g6}from"node:fs";import{createRequire as IQ}from"node:module";import{dirname as _8,join as n1}from"node:path";import{fileURLToPath as TK}from"node:url";import{spawn as RK}from"node:child_process";import{basename as DK}from"node:path";import{augmentNodeCommandForDebug as LK,withResolvedClineBuildEnv as OK}from"@cline/shared";function CQ($){if($ instanceof Error)return $;return Error(String($))}var _K="CLINE_JS_RUNTIME_PATH";function EQ($){let f=$?.trim();if(!f)return!1;let J=DK(f).toLowerCase();return J==="node"||J==="node.exe"||J==="bun"||J==="bun.exe"}function bQ($={}){let f=$.env??process.env,J=$.runtimeExecutable?.trim()||f[_K]?.trim();if(J)return J;let W=$.execPath?.trim()||process.execPath;if(EQ(W))return W;for(let Z of[f.BUN_EXEC_PATH,f.npm_node_execpath,f.NODE]){let Q=Z?.trim();if(Q&&EQ(Q))return Q}return"node"}function zK($,f={}){let J=bQ({env:f.env,execPath:f.execPath,runtimeExecutable:f.runtimeExecutable});return LK([J,...$],{env:f.env,execArgv:f.execArgv,debugRole:f.name==="plugin-sandbox"?"plugin-sandbox":"sandbox"})}class O8{options;process=null;requestCounter=0;pending=new Map;constructor($){this.options=$}get processLabel(){return this.options.name??"sandbox"}clearPendingRequest($){let f=this.pending.get($);if(!f)return;if(this.pending.delete($),f.timeout)clearTimeout(f.timeout);return f}start(){if(this.process&&this.process.exitCode===null)return;let $=this.options.bootstrapFile?[this.options.bootstrapFile]:["-e",this.options.bootstrapScript??""],f=zK($,{name:this.options.name,runtimeExecutable:this.options.runtimeExecutable}),J=RK(f[0]??bQ(this.options),f.slice(1),{stdio:["ignore","ignore","pipe","ipc"],env:OK(process.env)});this.process=J;let W="",Z=(Q)=>{let j=W+Q;W=j.length>4000?j.slice(-4000):j};J.stderr?.setEncoding("utf8"),J.stderr?.on("data",(Q)=>{Z(Q)}),J.on("message",(Q)=>{this.onMessage(Q)}),J.on("error",(Q)=>{this.failPending(Error(`${this.processLabel} process error: ${CQ(Q).message}`))}),J.on("exit",(Q,j)=>{this.process=null;let H=W.trim();this.failPending(Error(`${this.options.name??"sandbox"} process exited (code=${String(Q)}, signal=${String(j)})${H?`: ${H}`:""}`))})}async call($,f,J={}){this.start();let W=this.process;if(!W||W.exitCode!==null)throw Error(`${this.processLabel} process is not available`);let Z=`req_${++this.requestCounter}`,Q={type:"call",id:Z,method:$,args:f};return await new Promise((j,H)=>{let X={resolve:(Y)=>j(Y),reject:H};if((J.timeoutMs??0)>0)X.timeout=setTimeout(()=>{this.clearPendingRequest(Z),this.shutdown().catch(()=>{}),H(Error(`${this.processLabel} call timed out after ${J.timeoutMs}ms: ${$}`))},J.timeoutMs);this.pending.set(Z,X),W.send(Q,(Y)=>{if(!Y)return;let A=this.clearPendingRequest(Z);if(!A)return;A.reject(Error(`${this.processLabel} failed to send call "${$}": ${CQ(Y).message}`))})})}async shutdown(){let $=this.process;if(this.process=null,!$||$.exitCode!==null){this.failPending(Error(`${this.processLabel} shutdown`));return}await new Promise((f)=>{let J=setTimeout(()=>{try{$.kill("SIGKILL")}catch{}f()},300);$.once("exit",()=>{clearTimeout(J),f()});try{$.kill("SIGTERM")}catch{clearTimeout(J),f()}}),this.failPending(Error(`${this.processLabel} shutdown`))}onMessage($){if(!$)return;if($.type==="event"){if(typeof $.name==="string"&&$.name.length>0)this.options.onEvent?.({name:$.name,payload:$.payload});return}if($.type!=="response"||!$.id)return;let f=this.clearPendingRequest($.id);if(!f)return;if($.ok){f.resolve($.result);return}f.reject(Error($.error?.message||`${this.processLabel} call failed`))}failPending($){for(let[f,J]of this.pending.entries()){if(this.pending.delete(f),J.timeout)clearTimeout(J.timeout);J.reject($)}}}function NK($){return{...$,contributions:{tools:$.contributions?.tools??[],commands:$.contributions?.commands??[],rules:$.contributions?.rules??[],messageBuilders:$.contributions?.messageBuilders??[],providers:$.contributions?.providers??[],automationEventTypes:$.contributions?.automationEventTypes??[],shortcuts:$.contributions?.shortcuts??[],flags:$.contributions?.flags??[]}}}function Cf($){return($ instanceof Error?$.message:String($)).includes("Unknown sandbox plugin id:")}function MK(){return`@cline/cli-${process.platform==="win32"?"windows":process.platform}-${process.arch}`}function yK(){let $=process.env.CLINE_WRAPPER_PATH?.trim();if(!$)return;try{let J=IQ($).resolve(`${MK()}/package.json`),W=n1(_8(J),"extensions","plugin-sandbox-bootstrap.js");return g6(W)?W:void 0}catch{return}}function qK(){let $=process.execPath?.trim();if(!$)return;let f=n1(_8(_8($)),"extensions","plugin-sandbox-bootstrap.js");return g6(f)?f:void 0}function wK(){let $=_8(TK(import.meta.url)),f=IQ(import.meta.url),J=[n1($,"plugin-sandbox-bootstrap.js"),n1($,"extensions","plugin-sandbox-bootstrap.js"),n1($,"agents","plugin-sandbox-bootstrap.js"),yK(),qK()];for(let Q of J.filter((j)=>typeof j==="string"))if(g6(Q))return{file:Q};let W=n1($,"plugin-sandbox-bootstrap.ts"),Z="jiti";try{Z=f.resolve("jiti")}catch{}return{script:[`const createJiti = require(${JSON.stringify(Z)});`,`const jiti = createJiti(${JSON.stringify(W)}, { cache: false, requireCache: false, esmResolve: true, interopDefault: false });`,`Promise.resolve(jiti.import(${JSON.stringify(W)}, {})).catch((error) => {`," console.error(error);"," process.exitCode = 1;","});"].join(`
|
|
47
|
+
`)}}var x6=wK();function m6($,f,J){if(typeof $==="number"&&$>0)return $;if(J){let W=process.env[J];if(W){let Z=Number(W);if(Number.isInteger(Z)&&Z>0)return Z}}return f}async function z8($){let f=new O8({name:"plugin-sandbox",..."file"in x6?{bootstrapFile:x6.file}:{bootstrapScript:x6.script},onEvent:$.onEvent}),J=m6($.importTimeoutMs,4000,"CLINE_PLUGIN_IMPORT_TIMEOUT_MS"),W=m6($.hookTimeoutMs,3000),Z=m6($.contributionTimeoutMs,60000),Q={pluginPaths:$.pluginPaths,exportName:$.exportName,providerId:$.providerId,modelId:$.modelId,cwd:$.cwd,session:$.session,client:$.client,user:$.user,workspaceInfo:$.workspaceInfo,loggerEnabled:Boolean($.logger)},j,H=()=>{return j??=f.call("initialize",Q,{timeoutMs:J}).finally(()=>{j=void 0}),j},X;try{X=await f.call("initialize",Q,{timeoutMs:J})}catch(V){throw await f.shutdown().catch(()=>{}),V}let Y=X.plugins.map(NK);return{extensions:Y.map((V)=>{let B={name:V.name,__clinePluginPath:V.pluginPath,manifest:V.manifest,setup:(K)=>{SK(K,f,V,Z,H),hK(K,f,V,Z,H),CK(K,f,V,Z,H),bK(K,f,V,Z,H),EK(K,V)}};return B.hooks=IK(f,V,W,H),B}),failures:X.failures,pluginPaths:Y.map((V)=>V.pluginPath),shutdown:async()=>{await f.shutdown()},warnings:X.warnings}}function SK($,f,J,W,Z){for(let Q of J.contributions?.tools??[]){let j={name:Q.name,description:Q.description??"",inputSchema:Q.inputSchema??{type:"object",properties:{}},timeoutMs:Q.timeoutMs,retryable:Q.retryable,execute:async(H,X)=>{try{return await f.call("executeTool",{pluginId:J.pluginId,contributionId:Q.id,input:H,context:X},{timeoutMs:W})}catch(Y){if(!Cf(Y))throw Y;return await Z(),await f.call("executeTool",{pluginId:J.pluginId,contributionId:Q.id,input:H,context:X},{timeoutMs:W})}}};$.registerTool(j)}}function hK($,f,J,W,Z){for(let Q of J.contributions?.commands??[])$.registerCommand({name:Q.name,description:Q.description,handler:async(j)=>{try{return await f.call("executeCommand",{pluginId:J.pluginId,contributionId:Q.id,input:j},{timeoutMs:W})}catch(H){if(!Cf(H))throw H;return await Z(),await f.call("executeCommand",{pluginId:J.pluginId,contributionId:Q.id,input:j},{timeoutMs:W})}}})}function CK($,f,J,W,Z){for(let Q of J.contributions?.rules??[])$.registerRule({id:Q.ruleId,source:Q.source,content:Q.hasContentHandler===!0?async()=>{try{return await f.call("resolveRuleContent",{pluginId:J.pluginId,contributionId:Q.id},{timeoutMs:W})}catch(j){if(!Cf(j))throw j;return await Z(),await f.call("resolveRuleContent",{pluginId:J.pluginId,contributionId:Q.id},{timeoutMs:W})}}:Q.content??""})}function EK($,f){for(let J of f.contributions?.providers??[])$.registerProvider({name:J.name,description:J.description,metadata:J.metadata});for(let J of f.contributions?.automationEventTypes??[])$.registerAutomationEventType({eventType:J.eventType,source:J.source,description:J.description,attributesSchema:J.attributesSchema,payloadSchema:J.payloadSchema,examples:J.examples,metadata:J.metadata})}function bK($,f,J,W,Z){for(let Q of J.contributions?.messageBuilders??[])$.registerMessageBuilder({name:Q.name,async build(j){try{let H=await f.call("buildMessages",{pluginId:J.pluginId,contributionId:Q.id,messages:j},{timeoutMs:W});return kQ(H)?H:j}catch(H){if(!Cf(H))throw H;await Z();let X=await f.call("buildMessages",{pluginId:J.pluginId,contributionId:Q.id,messages:j},{timeoutMs:W});return kQ(X)?X:j}}})}function kQ($){return Array.isArray($)&&$.every((f)=>typeof f==="object"&&f!==null&&("role"in f)&&("content"in f))}function kK($,f,J,W,Z){return async(Q)=>{try{return await $.call("invokeHook",{pluginId:f,hookName:J,payload:Q},{timeoutMs:W})}catch(j){if(!Cf(j))throw j;return await Z(),await $.call("invokeHook",{pluginId:f,hookName:J,payload:Q},{timeoutMs:W})}}}function IK($,f,J,W){let Z={};for(let Q of f.hooks??[])Z[Q]=kK($,f.pluginId,Q,J,W);return Object.keys(Z).length>0?Z:void 0}var u6="package.json",dK="package";function c6($){return uK($)}function d6($){return vK($)}function lK($){try{return M8($)&&mK($).isDirectory()}catch{return!1}}function l6($){let f=[],J=new Set;for(let W of $){let Z=N8(W);if(J.has(Z))continue;J.add(Z),f.push(Z)}return f}function mQ($){let f=l6($);return y6(f)}function gQ($){return c6($).flatMap((f)=>d6(f)).filter((f)=>M8(f))}function pK($,f){let J=[];for(let W of $)try{J.push(...xQ([W],f))}catch{}return J}function v6($){return typeof $==="object"&&$!==null}function rK($){try{let f=JSON.parse(xK(y8($,u6),"utf8"));if(!v6(f)||!v6(f.cline))return[];let J=f.cline.plugins;if(!Array.isArray(J))return[];let W=[];for(let Z of J){if(typeof Z==="string"){W.push(Z);continue}if(!v6(Z)||!Array.isArray(Z.paths))continue;for(let Q of Z.paths)if(typeof Q==="string")W.push(Q)}return W}catch{return[]}}function vQ($,f){let J=N8(f);return rK($).some((W)=>N8($,W)===J)}function iK($,f){return gK($)===dK&&M8(y8(T8($),u6))&&vQ(T8($),f)}function nK($){let f=N8($),J=[],W=T8(f);while(!0){if(iK(W,f)){J.push(W);break}if(M8(y8(W,u6))){if(vQ(W,f))J.push(W);break}let Z=T8(W);if(Z===W)break;W=Z}return l6(J)}function Ef($={}){let f=$.cwd??process.cwd(),J=gQ($.workspacePath),W=xQ($.pluginPaths??[],f);return mQ([...W,...J])}function aK($={}){let f=$.cwd??process.cwd(),J=gQ($.workspacePath),W=pK($.pluginPaths??[],f);return mQ([...W,...J])}function bf($){let f=[];for(let J of $)for(let W of nK(J)){let Z=y8(W,cK);if(lK(Z))f.push(Z)}return l6(f)}function uQ($={}){return bf(aK($))}async function q8($={}){let f=Ef($);if(f.length===0)return{extensions:[],failures:[],warnings:[],pluginPaths:[]};if($.mode==="in_process"){let W=await hf(f,{cwd:$.cwd,exportName:$.exportName,providerId:$.providerId,modelId:$.modelId,session:$.session,client:$.client,user:$.user,workspaceInfo:$.workspaceInfo,automation:$.automation,logger:$.logger,telemetry:$.telemetry});return{extensions:W.plugins,failures:W.failures,pluginPaths:W.pluginPaths,warnings:W.warnings}}let J=await z8({pluginPaths:f,exportName:$.exportName,importTimeoutMs:$.importTimeoutMs,hookTimeoutMs:$.hookTimeoutMs,contributionTimeoutMs:$.contributionTimeoutMs,onEvent:$.onEvent,providerId:$.providerId,modelId:$.modelId,cwd:$.cwd,session:$.session,client:$.client,user:$.user,workspaceInfo:$.workspaceInfo,logger:$.logger});return{extensions:J.extensions??[],shutdown:J.shutdown,failures:J.failures,pluginPaths:J.pluginPaths,warnings:J.warnings}}var w8="SKILL.md",WG="managed.json",ZG=new Set([".md",".markdown",".txt"]);function a6($){return $.trim().toLowerCase()}function a1($){let f=$;return f?.code==="ENOENT"||f?.code==="EACCES"||f?.code==="EPERM"||f?.code==="ELOOP"}function h8($){return ZG.has(S8($).toLowerCase())}function lQ($){let f=[],J=new Set;for(let W of $){let Z=kf(W);if(J.has(Z))continue;J.add(Z),f.push(W)}return f}function QG($){let f=[...$?.directories??f5($?.workspacePath)];if($?.pluginSkillDirectories)f.push(...$.pluginSkillDirectories);else if($?.includePluginSkills)f.push(...uQ({pluginPaths:$.pluginPaths,workspacePath:$.workspacePath,cwd:$.cwd??$.workspacePath}));return lQ(f)}async function t6($){try{let f=await r6($,{withFileTypes:!0}),J=[];for(let W of f){if(!W.isDirectory())continue;let Z=L0($,W.name),Q=L0(Z,WG);try{let j=await tK(Q,"utf8"),H=JSON.parse(j);if(H&&typeof H==="object")J.push(Z)}catch(j){if(a1(j))continue;if(j?.name==="SyntaxError")continue;throw j}}return J.sort((W,Z)=>W.localeCompare(Z))}catch(f){if(a1(f))return[];throw f}}function s6($){let f=/^---\r?\n([\s\S]*?)\r?\n---\r?\n?([\s\S]*)$/,J=$.match(f);if(!J)return{data:{},body:$,hadFrontmatter:!1};let[,W,Z]=J;try{let Q=JG.parse(W);return{data:Q&&typeof Q==="object"&&!Array.isArray(Q)?Q:{},body:Z,hadFrontmatter:!0}}catch(Q){let j=Q instanceof Error?Q.message:String(Q);return{data:{},body:$,hadFrontmatter:!0,parseError:j}}}function C8($,f,J){if($===void 0||$===null){if(J)throw Error(`Missing required frontmatter field '${f}'.`);return}if(typeof $!=="string")throw Error(`Frontmatter field '${f}' must be a string.`);let W=$.trim();if(!W&&J)throw Error(`Frontmatter field '${f}' cannot be empty.`);return W||void 0}function t1($,f){if($===void 0||$===null)return;if(typeof $!=="boolean")throw Error(`Frontmatter field '${f}' must be a boolean.`);return $}function jG($,f){if(j$($.filePath).toLowerCase()!==cQ.toLowerCase())return j$($.filePath,S8($.filePath));if(f&&kf($.filePath)===kf(f,cQ))return"Workspace AGENTS.md";if(kf($.filePath)===kf(oK()))return"Global AGENTS.md";return j$($.filePath,S8($.filePath))}function o6($,f){let{data:J,body:W,parseError:Z}=s6($);if(Z)throw Error(`Failed to parse YAML frontmatter: ${Z}`);let Q=W.trim();if(!Q)throw Error("Missing instructions body in skill file.");let H=C8(J.name,"name",!1)??f.trim();if(!H)throw Error("Missing skill name.");return{name:H,description:C8(J.description,"description",!1),disabled:t1(J.disabled,"disabled")??(t1(J.enabled,"enabled")===!1?!0:void 0),instructions:Q,frontmatter:J}}function e6($,f){let{data:J,body:W,parseError:Z}=s6($);if(Z)throw Error(`Failed to parse YAML frontmatter: ${Z}`);let Q=W.trim();if(!Q)throw Error("Missing instructions body in rule file.");let j=C8(J.name,"name",!1)??f.trim();if(!j)throw Error("Missing rule name.");return{name:j,disabled:t1(J.disabled,"disabled")??(t1(J.enabled,"enabled")===!1?!0:void 0),instructions:Q,frontmatter:J}}function $5($,f){let{data:J,body:W,parseError:Z}=s6($);if(Z)throw Error(`Failed to parse YAML frontmatter: ${Z}`);let Q=W.trim();if(!Q)throw Error("Missing instructions body in workflow file.");let j=C8(J.name,"name",!1)??f.trim();if(!j)throw Error("Missing workflow name.");return{name:j,disabled:t1(J.disabled,"disabled")??(t1(J.enabled,"enabled")===!1?!0:void 0),instructions:Q,frontmatter:J}}function f5($){return $G($)}function J5($){return eK($)}function W5($){return fG($)}async function pQ($){if(j$($)===".cline"){let f=await t6($);return(await Promise.all(f.map((W)=>pQ(L0(W,i6))))).flat()}try{let f=await r6($,{withFileTypes:!0}),J=[];for(let W of f){if(W.isFile()&&W.name===w8){J.push({directoryPath:$,fileName:W.name,filePath:L0($,W.name)});continue}let Z=L0($,W.name);if(W.isDirectory()||W.isSymbolicLink()&&await p6(Z).then((j)=>j.isDirectory()).catch((j)=>{if(a1(j))return!1;throw j}))J.push({directoryPath:Z,fileName:w8,filePath:L0(Z,w8)})}return J}catch(f){if(a1(f))return[];throw f}}async function E8($){if(j$($)===".cline"){let f=await t6($);return(await Promise.all(f.map((W)=>E8(L0(W,"rules.md"))))).flat()}try{if((await p6($)).isFile())return[{directoryPath:sK($),fileName:j$($),filePath:$}]}catch(f){if(!a1(f))throw f}try{let J=(await r6($,{withFileTypes:!0})).filter((Z)=>Z.isFile()&&h8(Z.name)).map((Z)=>({directoryPath:$,fileName:Z.name,filePath:L0($,Z.name)})),W=L0($,"AGENTS.md");try{if((await p6(W)).isFile()){if(!J.some((j)=>j.fileName==="AGENTS.md"))J.push({directoryPath:$,fileName:"AGENTS.md",filePath:W})}}catch{}return J}catch(f){if(a1(f))return[];throw f}}async function HG($){if(j$($)===".cline"){let f=await t6($);return(await Promise.all(f.map((W)=>E8(L0(W,n6))))).flat()}return E8($)}function Z5($){let f=QG($),J=$?.workspacePath?L0($.workspacePath,".cline"):void 0;return{type:"skill",directories:J?lQ([...f,J]):f,discoverFiles:pQ,includeFile:(W)=>W===w8,parseFile:(W)=>o6(W.content,j$(W.directoryPath)),resolveId:(W)=>a6(W.name)}}function Q5($){let f=$?.directories??J5($?.workspacePath),J=$?.workspacePath?L0($.workspacePath,".cline"):void 0;return{type:"rule",directories:J?[...f,J]:f,discoverFiles:E8,includeFile:(W,Z)=>W===".clinerules"||h8(W)||h8(Z),parseFile:(W)=>e6(W.content,jG(W,$?.workspacePath)),resolveId:(W)=>a6(W.name)}}function j5($){let f=$?.directories??W5($?.workspacePath),J=$?.workspacePath?L0($.workspacePath,".cline"):void 0;return{type:"workflow",directories:J?[...f,J]:f,discoverFiles:HG,includeFile:(W)=>h8(W),parseFile:(W)=>$5(W.content,j$(W.filePath,S8(W.filePath))),resolveId:(W)=>a6(W.name)}}function rQ($){let f=[Z5($?.skills),Q5($?.rules),j5($?.workflows)];return new yf(f,{debounceMs:$?.debounceMs,emitParseErrors:$?.emitParseErrors})}import{truncateSplit as iQ}from"@cline/shared";function XG($,f){if($.description?.trim())return iQ($.description,".");if(f==="workflow")return;return iQ($.instructions,".")}function YG($){return $.disabled!==!0}function nQ($,f){return[...$.getSnapshot(f).entries()].map(([J,W])=>({id:J,record:W})).filter(({record:J})=>YG(J.item)).map(({id:J,record:W})=>({id:J,name:W.item.name,instructions:W.item.instructions,description:XG(W.item,f),kind:f})).sort((J,W)=>J.name.localeCompare(W.name))}function If($){let f=new Map;for(let J of[...nQ($,"workflow"),...nQ($,"skill")])if(!f.has(J.name))f.set(J.name,J);return[...f.values()].sort((J,W)=>J.name.localeCompare(W.name))}function aQ($,f){if(!$.startsWith("/")||$.length<2)return $;let J=$.match(/^\/(\S+)/);if(!J)return $;let W=J[1];if(!W)return $;let Z=W.length+1,Q=$.slice(Z),j=If(f).find((H)=>H.name===W);return j?`${j.instructions}${Q}`:$}function tQ($){return $.disabled!==!0}function b8($){if($.length===0)return"";return`
|
|
47
48
|
|
|
48
49
|
# Rules
|
|
49
50
|
${$.map((J)=>`## ${J.name}
|
|
50
51
|
${J.instructions}`).join(`
|
|
51
52
|
|
|
52
|
-
`)}`}function
|
|
53
|
+
`)}`}function k8($,f){let J=$?.trim(),W=f?.trim();if(J&&W)return`${J}
|
|
53
54
|
|
|
54
|
-
${
|
|
55
|
+
${W}`;return J||W||void 0}function AG($){return[...$.getSnapshot("rule").values()].map((J)=>J.item).filter(tQ).sort((J,W)=>J.name.localeCompare(W.name))}function sQ($){return b8(AG($))}import{validateWithZod as wC,zodToJsonSchema as SC}from"@cline/shared";var j0={READ_FILES:"read_files",SEARCH_CODEBASE:"search_codebase",RUN_COMMANDS:"run_commands",FETCH_WEB_CONTENT:"fetch_web_content",APPLY_PATCH:"apply_patch",EDITOR:"editor",SKILLS:"skills",ASK:"ask_question",SUBMIT_AND_EXIT:"submit_and_exit"},s1=[j0.READ_FILES,j0.SEARCH_CODEBASE,j0.RUN_COMMANDS,j0.FETCH_WEB_CONTENT,j0.APPLY_PATCH,j0.EDITOR,j0.SKILLS,j0.ASK,j0.SUBMIT_AND_EXIT];B0();import{createTool as H$,validateWithZod as X$,zodToJsonSchema as t0}from"@cline/shared";var oQ="__clineInternalTelemetry";function eQ($){let f=$?.__clineInternalTelemetry;return f&&typeof f==="object"&&"capture"in f&&typeof f.capture==="function"?f:void 0}import{validateWithZod as VG}from"@cline/shared";import{z as L}from"zod";var M$=6000,xf=L.string().describe("The absolute file path of a text file to read content from"),$7=L.object({start_line:L.number().int().positive().nullable().optional().describe("Optional one-based starting line number to read from; use null or omit for the start of the file"),end_line:L.number().int().positive().nullable().optional().describe("Optional one-based ending line number to read through; use null or omit for the end of the file")}).describe("Optional inclusive one-based file line range"),N$=L.object({path:xf,start_line:$7.shape.start_line,end_line:$7.shape.end_line}).describe("A file read request with optional inclusive one-based line bounds"),I8=L.object({files:L.array(N$).describe("Array of file read requests. Omit start_line/end_line or set them to null to return the full file content boundaries; provide integers to return only that inclusive one-based line range. Prefer this tool over running terminal command to get file content for better performance and reliability.")}),f7=L.union([I8,N$,L.array(N$),L.array(L.string()),L.string(),L.object({files:L.array(L.union([xf,N$]))}),L.object({files:N$}),L.object({files:xf}),L.object({file_paths:L.array(xf)}),L.object({file_paths:L.string()}),L.object({paths:L.array(L.union([xf,N$]))}),L.object({paths:N$}),L.object({paths:L.string()})]),x8=L.object({queries:L.array(L.string()).describe("Array of regex search queries to execute")}),J7=L.union([x8,L.array(L.string()),L.string(),L.object({queries:L.string()})]),X1=L.string().describe(`The non-interactive shell command to execute - MUST keep input short and concise (within ${M$*2} characters) to avoid timeouts.`),mf=L.object({commands:L.array(X1).describe("Array of shell commands to execute")}),W7=L.union([mf,L.object({commands:X1}),L.object({command:X1}),L.object({cmd:X1}),L.array(L.string()),L.string()]),H5=L.object({command:L.string().min(1).describe("The executable to run directly without shell parsing."),args:L.array(L.string()).optional().describe("Optional argv list passed directly to the executable.")}),Z7=L.union([X1,H5]),X5=L.object({commands:L.array(Z7).describe("Array of commands to execute. Prefer structured { command, args } entries for portability; plain strings are still supported and are interpreted by the active shell.")}),Q7=L.union([mf,X5,L.object({commands:Z7}),L.array(H5),H5,L.object({command:X1}),L.object({cmd:X1}),L.array(L.string()),L.string()]),j7=L.object({url:L.string().describe("The URL to fetch"),prompt:L.string().min(2).describe("Analysis prompt for the fetched content")}),m8=L.object({requests:L.array(j7).describe("Array of the URLs for the web fetch requests")}),g8=L.object({path:L.string().min(1).describe("The absolute file path for the action to be performed on"),old_text:L.string().nullable().optional().describe(`Exact text to replace (must match exactly once). Omit this when creating a missing file or inserting via insert_line. Keep this at or below ${M$} characters when possible; larger payloads should be split across multiple tool calls to avoid timeouts.`),new_text:L.string().describe(`The new content to write when creating a missing file, the replacement text for edits, or the inserted text when insert_line is provided. Keep this at or below ${M$} characters when possible; for large edits, use multiple calls with small chunks of old_text and new_text to iteratively edit the file.`),insert_line:L.number().int().nullable().optional().describe("Optional positive one-based boundary line. When provided, the tool inserts new_text before that line instead of performing a replacement edit; use line_count + 1 to append at EOF.")}).describe("Edit a text file by replacing old_text with new_text, create the file with new_text if it does not exist, or insert new_text at insert_line when insert_line is provided. Prefer using this tool for file edits over shell commands. IMPORTANT: large edits can time out, so use small chunks and multiple calls when possible."),v8=L.object({input:L.string().min(1).describe("The freeform apply_patch payload in the canonical patch grammar (e.g *** Begin Patch, *** Update File:, @@, and *** End Patch).")}).describe("Modify or create a text file by applying patches using the canonical apply_patch diff grammar. Prefer sending the patch body directly rather than wrapping it in shell syntax. IMPORTANT: large patches can time out, so use small chunks and multiple calls when possible."),H7=L.union([v8,L.string()]),u8=L.object({skill:L.string().min(1).describe("Name of the skill to execute."),args:L.string().nullable().optional().describe("Arguments for the skill; use null when omitted")}),c8=L.object({question:L.string().min(1).describe('The single question to ask the user. E.g. "How can I help you?"'),options:L.array(L.string().min(1)).min(2).max(5).describe("Array of 2-5 user-selectable answer options for the single question")}),d8=L.object({summary:L.string().min(10).describe("Summarization of the investigation, steps taken, and resolution status to submit at the end of the session. Before submitting, read the problem again along with any provided test's assertions carefully and confirm your fix produces the expected output."),verified:L.boolean().describe(`Have you verified that the issue is resolved to the best of your knowledge, including updating and creating all the requested files and items? 'True' if you have completed the investigation and taken all necessary steps to resolve the issue.
|
|
55
56
|
'False' if you have done all you can but cannot resolve the issue or if you are stuck and cannot proceed further. =
|
|
56
|
-
IMPORTANT: You must run the specific failing test(s) mentioned in the issue or test patch and include the test output in your reasoning. If the test still fails after your fix, you must revise. Do NOT submit with 'true' unless the test output shows the test passing.`)});function
|
|
57
|
+
IMPORTANT: You must run the specific failing test(s) mentioned in the issue or test patch and include the test output in your reasoning. If the test still fails after your fix, you must revise. Do NOT submit with 'true' unless the test output shows the test passing.`)});function y$($){if($ instanceof Error)return $.message;return String($)}function X7($){if(typeof $.old_text==="string"&&$.old_text.length>M$)return`Editor input too large: old_text was ${$.old_text.length} characters, exceeding the recommended limit of ${M$}. Split the edit into smaller tool calls so later tool calls are less likely to be truncated or time out.`;if($.new_text.length>M$)return`Editor input too large: new_text was ${$.new_text.length} characters, exceeding the recommended limit of ${M$}. Split the edit into smaller tool calls so later tool calls are less likely to be truncated or time out.`;return null}class Y1 extends Error{timeoutMs;constructor($,f){super($);this.name="TimeoutError",this.timeoutMs=f}}function a0($,f,J){return Promise.race([$,new Promise((W,Z)=>{setTimeout(()=>Z(new Y1(J,f)),f)})])}function l8($){let{path:f,start_line:J,end_line:W}=$;if(J==null&&W==null)return f;return`${f}:${J??1}-${W??"EOF"}`}function Y7($){let{start_line:f,end_line:J}=$;if(f==null||J==null||f<=J)return null;return`start_line must be less than or equal to end_line (received start_line: ${f}, end_line: ${J})`}function A7($){let f=VG(Q7,$);if(typeof f==="string")return[f];if(Array.isArray(f))return f;if("commands"in f)return Array.isArray(f.commands)?f.commands:[f.commands];if("command"in f)return"args"in f?[f]:[f.command];if("cmd"in f)return[f.cmd];return[f]}function Y5($){if(typeof $==="string")return $;let f=$.args??[];if(f.length===0)return $.command;let J=f.map((W)=>/[\s"]/u.test(W)?JSON.stringify(W):W);return`${$.command} ${J.join(" ")}`}function V7($,f){let J=$.metadata?.[f];return typeof J==="string"?J:void 0}function B7($,f){_9(eQ($.metadata),{tool_name:"run_commands",effective_timeout_ms:f.effectiveTimeoutMs,timeout_source:f.timeoutSource,command_count:f.commandCount,duration_ms:f.durationMs,ulid:$.sessionId,mode:V7($,"mode"),source:V7($,"source"),session_id:$.sessionId,agent_id:$.agentId,conversation_id:$.conversationId,run_id:$.runId,iteration:$.iteration,tool_call_id:$.toolCallId})}function K7($,f={}){let J=f.fileReadTimeoutMs??1e4;return H$({name:"read_files",description:"Read the full content of text or image files at the provided absolute paths, or return only an inclusive one-based line range when start_line/end_line are provided. Binary files that are not image and large files are not supported. Returns file contents or error messages for each path. ",inputSchema:t0(I8),timeoutMs:J*2,retryable:!0,maxRetries:1,execute:async(W,Z)=>{let Q=X$(f7,W),j;if(typeof Q==="string")j=[{path:Q}];else if(Array.isArray(Q))j=Q.map((H)=>typeof H==="string"?{path:H}:H);else if("files"in Q)j=(Array.isArray(Q.files)?Q.files:[Q.files]).map((X)=>typeof X==="string"?{path:X}:X);else if("file_paths"in Q)j=(Array.isArray(Q.file_paths)?Q.file_paths:[Q.file_paths]).map((X)=>({path:X}));else if("paths"in Q)j=(Array.isArray(Q.paths)?Q.paths:[Q.paths]).map((X)=>typeof X==="string"?{path:X}:X);else j=[Q];return Promise.all(j.map(async(H)=>{let X=Y7(H);if(X)return{query:l8(H),result:"",error:`Invalid file range: ${X}`,success:!1};try{let Y=await a0($(H,Z),J,`File read timed out after ${J}ms`);return{query:l8(H),result:Y,success:!0}}catch(Y){let A=y$(Y);return{query:l8(H),result:"",error:`Error reading file: ${A}`,success:!1}}}))}})}function G7($,f={}){let J=f.searchTimeoutMs??30000,W=f.cwd??process.cwd();return H$({name:"search_codebase",description:"Perform regex pattern searches across the codebase. Supports multiple parallel searches. Use for finding code patterns, function definitions, class names, imports, etc.",inputSchema:t0(x8),timeoutMs:J*2,retryable:!0,maxRetries:1,execute:async(Z,Q)=>{let j=X$(J7,Z),H=Array.isArray(j)?j:typeof j==="object"?Array.isArray(j.queries)?j.queries:[j.queries]:[j];return Promise.all(H.map(async(X)=>{try{let Y=await a0($(X,W,Q),J,`Search timed out after ${J}ms`),A=Y.length>0&&!Y.includes("No results found");return{query:X,result:Y,success:A}}catch(Y){let A=y$(Y);return{query:X,result:"",error:`Search failed: ${A}`,success:!1}}}))}})}function P7($,f={}){let J=f.bashTimeoutMs??30000,W=f.bashTimeoutMs===void 0?"default_setting":"configured_setting",Z=f.cwd??process.cwd();return H$({name:"run_commands",description:"Run shell commands from the root of the workspace. Use for listing files, checking git status, running builds, executing tests, etc. Commands should be properly shell-escaped and targeted to avoid error or timeout. For long-running commands, run them in background and redirect output to a tmp file that you can read from later.",inputSchema:t0(mf),timeoutMs:J*2,retryable:!1,maxRetries:0,execute:async(Q,j)=>{let H=X$(W7,Q),X;if(typeof H==="string")X=[H];else if(Array.isArray(H))X=H;else if("commands"in H)X=Array.isArray(H.commands)?H.commands:[H.commands];else if("command"in H)X=[H.command];else X=[H.cmd];return Promise.all(X.map(async(Y)=>{let A=Date.now();try{let V=await a0($(Y,Z,j),J,`Command timed out after ${J}ms`);return{query:Y,result:V,success:!0}}catch(V){if(V instanceof Y1)B7(j,{effectiveTimeoutMs:V.timeoutMs,timeoutSource:W,commandCount:X.length,durationMs:Date.now()-A});let B=y$(V);return{query:Y,result:"",error:`Command failed: ${B}`,success:!1}}}))}})}function F7($,f={}){let J=f.bashTimeoutMs??30000,W=f.bashTimeoutMs===void 0?"default_setting":"configured_setting",Z=f.cwd??process.cwd();return H$({name:"run_commands",description:"Run shell commands from the root of the workspacein Windows environment. Use for listing files, checking git status, running builds, executing tests, etc. Prefer structured { command, args } entries for portability; plain string commands should be properly shell-escaped.",inputSchema:t0(X5),timeoutMs:J*2,retryable:!1,maxRetries:0,execute:async(Q,j)=>{let H=A7(Q);return Promise.all(H.map(async(X)=>{let Y=Date.now();try{let A=await a0($(X,Z,j),J,`Command timed out after ${J}ms`);return{query:Y5(X),result:A,success:!0}}catch(A){if(A instanceof Y1)B7(j,{effectiveTimeoutMs:A.timeoutMs,timeoutSource:W,commandCount:H.length,durationMs:Date.now()-Y});let V=y$(A);return{query:Y5(X),result:"",error:`Command failed: ${V}`,success:!1}}}))}})}function U7($,f={}){let J=f.webFetchTimeoutMs??30000;return H$({name:"fetch_web_content",description:"Fetch content from URLs and analyze them using the provided prompts. Use for retrieving documentation, API references, or any web content. Each request includes a URL and a prompt describing what information to extract.",inputSchema:t0(m8),timeoutMs:J*2,retryable:!0,maxRetries:2,execute:async(W,Z)=>{let Q=X$(m8,W);return Promise.all(Q.requests.map(async(j)=>{try{let H=await a0($(j.url,j.prompt,Z),J,`Web fetch timed out after ${J}ms`);return{query:j.url,result:H,success:!0}}catch(H){let X=y$(H);return{query:j.url,result:"",error:`Error fetching web content: ${X}`,success:!1}}}))}})}var BG=`Use \`apply_patch\` to edit files with the canonical freeform patch grammar. Pass the patch text directly as the \`input\` string. Prefer the exact format below:
|
|
57
58
|
|
|
58
59
|
*** Begin Patch
|
|
59
60
|
*** Update File: path/to/file.ts
|
|
@@ -89,85 +90,84 @@ Example:
|
|
|
89
90
|
</div>
|
|
90
91
|
);
|
|
91
92
|
}
|
|
92
|
-
*** End Patch`;function
|
|
93
|
-
`),Z=0,
|
|
94
|
-
${this.lines[this.index]}`);if(
|
|
95
|
-
`);this.addWarning({path:this.currentPath||f,chunkIndex:J.chunks.length,message:`Could not find matching context (similarity: ${
|
|
96
|
-
`),chunks:[]}}}function
|
|
97
|
-
`));for(let Y=j;Y<$.length;Y++){let
|
|
98
|
-
`));if(
|
|
99
|
-
`)),
|
|
100
|
-
`));if(V
|
|
101
|
-
`)),
|
|
102
|
-
`));if(V
|
|
103
|
-
`)),
|
|
104
|
-
`).map((f)=>f.replace(/\r$/,""))}function
|
|
105
|
-
`),Z=[],
|
|
106
|
-
`)}async function
|
|
107
|
-
`)}return
|
|
108
|
-
`)}}import{spawn as
|
|
93
|
+
*** End Patch`;function R7($,f={}){let J=f.applyPatchTimeoutMs??30000,W=f.cwd??process.cwd();return H$({name:"apply_patch",description:BG,inputSchema:t0(v8),timeoutMs:J,retryable:!1,maxRetries:0,execute:async(Z,Q)=>{let j=X$(H7,Z),H=typeof j==="string"?j:j.input;try{return{query:"apply_patch",result:await a0($({input:H},W,Q),J,`apply_patch timed out after ${J}ms`),success:!0}}catch(X){return{query:"apply_patch",result:"",error:`apply_patch failed: ${y$(X)}`,success:!1}}}})}function D7($,f={}){let J=f.editorTimeoutMs??30000,W=f.cwd??process.cwd();return H$({name:"editor",description:"An editor for controlled filesystem edits on the text file at the provided path. Provide `insert_line` to insert `new_text` at a specific line number. Otherwise, the tool replaces `old_text` with `new_text`, or creates the file with `new_text` if file does not exist. Use this tools for making small, precise edits to existing files or creating new files over shell commands.",inputSchema:t0(g8),timeoutMs:J,retryable:!1,maxRetries:0,execute:async(Z,Q)=>{let j=X$(g8,Z),H=j.insert_line==null?"edit":"insert",X=X7(j);if(X)return{query:`${H}:${j.path}`,result:"",error:X,success:!1};try{let Y=await a0($(j,W,Q),J,`Editor operation timed out after ${J}ms`);return{query:`${H}:${j.path}`,result:Y,success:!0}}catch(Y){let A=y$(Y);return{query:`${H}:${j.path}`,result:"",error:`Editor operation failed: ${A}`,success:!1}}}})}function o1($,f={}){let J=f.skillsTimeoutMs??15000,W='Execute a skill within the main conversation. When users ask you to perform tasks, check if any available skills match. When users reference a slash command, invoke it with this tool. Input: `skill` (required) and optional `args`. Example: `skill: "pdf"`, `skill: "commit", args: "-m \\"Fix bug\\""`, `skill: "review-pr", args: "123"`, `skill: "ms-office-suite:pdf"`. When a skill matches the user\'s request, invoking this tool is a blocking requirement before any other response. Never mention a skill without invoking this tool.',Z=H$({name:"skills",description:W,inputSchema:t0(u8),timeoutMs:J,retryable:!1,maxRetries:0,execute:async(Q,j)=>{let H=X$(u8,Q);return a0($(H.skill,H.args||void 0,j),J,`Skills operation timed out after ${J}ms`)}});return Object.defineProperty(Z,"description",{get(){let Q=$.configuredSkills?.filter((j)=>!j.disabled).map((j)=>j.name);if(Q&&Q.length>0)return`${W} Available skills: ${Q.join(", ")}.`;return W},enumerable:!0,configurable:!0}),Z}function L7($){return{name:"ask_question",description:"Ask user a question for clarifying or gathering information needed to complete the task. For example, ask the user clarifying questions about a key implementation decision. You should only ask one question. Provide an array of 2-5 options for the user to choose from. Never include an option to toggle to Act mode.",inputSchema:t0(c8),retryable:!1,maxRetries:0,execute:async(f,J)=>{let W=X$(c8,f);return $(W.question,W.options,J)}}}function O7($,f={}){let J=f.submitTimeoutMs??15000;return H$({name:"submit_and_exit",description:"Submit the final answer and exit the conversation. For example, submit a summary of the investigation and confirm the issue is resolved. You should only submit once all necessary steps are completed. Make sure to verify your output matches the expected format, data types, and file locations specified. Provide a summary of the investigation and confirm the issue is resolved.",inputSchema:t0(d8),lifecycle:{completesRun:!0},timeoutMs:J,retryable:!1,maxRetries:0,execute:async(W,Z)=>{let Q=X$(d8,W);return a0($(Q.summary,Q.verified,Z),J,`submit_and_exit timed out after ${J}ms`)}})}function e1($){let{executors:f,enableReadFiles:J=!0,enableSearch:W=!0,enableBash:Z=!0,enableWebFetch:Q=!0,enableApplyPatch:j=!1,enableEditor:H=!0,enableSkills:X=!0,enableAskQuestion:Y=!0,enableSubmitAndExit:A=!1,...V}=$,B=[];if(J&&f.readFile)B.push(K7(f.readFile,V));if(W&&f.search)B.push(G7(f.search,V));if(Z&&f.bash)if(process.platform==="win32")B.push(F7(f.bash,V));else B.push(P7(f.bash,V));if(Q&&f.webFetch)B.push(U7(f.webFetch,V));if(H&&f.editor)B.push(D7(f.editor,V));else if(j&&f.applyPatch)B.push(R7(f.applyPatch,V));if(X&&f.skills)B.push(o1(f.skills,V));let K=A?f.submit:void 0;if(Y&&f.askQuestion&&!K)B.push(L7(f.askQuestion));if(K)B.push(O7(K,V));return B}import*as q0 from"node:fs/promises";import*as w0 from"node:path";var x={BEGIN:"*** Begin Patch",END:"*** End Patch",ADD:"*** Add File: ",UPDATE:"*** Update File: ",DELETE:"*** Delete File: ",MOVE:"*** Move to: ",SECTION:"@@",END_FILE:"*** End of File"},z7=["%%bash","apply_patch","EOF","```"];class f0 extends Error{constructor($){super($);this.name="DiffError"}}function y0($){let f={"‐":"-","‑":"-","‒":"-","–":"-","—":"-","−":"-","“":'"',"”":'"',"„":'"',"«":'"',"»":'"',"‘":"'","’":"'","‛":"'"," ":" "," ":" "};return $.normalize("NFC").replace(/./gu,(J)=>f[J]??J).replace(/\\`/g,"`").replace(/\\'/g,"'").replace(/\\"/g,'"')}class A5{lines;currentFiles;patch={actions:{},warnings:[]};index=0;fuzz=0;currentPath;constructor($,f){this.lines=$;this.currentFiles=f}parse(){this.skipBeginSentinel();while(this.hasMoreLines()&&!this.isEndMarker())this.parseNextAction();if(this.patch.warnings?.length===0)delete this.patch.warnings;return{patch:this.patch,fuzz:this.fuzz}}addWarning($){if(!this.patch.warnings)this.patch.warnings=[];this.patch.warnings.push($)}skipBeginSentinel(){if(this.lines[this.index]?.startsWith(x.BEGIN))this.index++}hasMoreLines(){return this.index<this.lines.length}isEndMarker(){return this.lines[this.index]?.startsWith(x.END)??!1}parseNextAction(){let $=this.lines[this.index];if($?.startsWith(x.UPDATE)){this.parseUpdate($.substring(x.UPDATE.length).trim());return}if($?.startsWith(x.DELETE)){this.parseDelete($.substring(x.DELETE.length).trim());return}if($?.startsWith(x.ADD)){this.parseAdd($.substring(x.ADD.length).trim());return}throw new f0(`Unknown line while parsing: ${$}`)}checkDuplicate($,f){if($ in this.patch.actions)throw new f0(`Duplicate ${f} for file: ${$}`)}parseUpdate($){this.checkDuplicate($,"update"),this.currentPath=$,this.index++;let f=this.lines[this.index]?.startsWith(x.MOVE)?(this.lines[this.index++]??"").substring(x.MOVE.length).trim():void 0;if(!($ in this.currentFiles))throw new f0(`Update File Error: Missing File: ${$}`);let J=this.currentFiles[$]??"",W=this.parseUpdateFile(J,$);W.movePath=f,this.patch.actions[$]=W,this.currentPath=void 0}parseUpdateFile($,f){let J={type:"update",chunks:[]},W=$.split(`
|
|
94
|
+
`),Z=0,Q=[x.END,x.UPDATE,x.DELETE,x.ADD,x.END_FILE];while(!Q.some((j)=>this.lines[this.index]?.startsWith(j.trim()))){let j=this.lines[this.index],H=j?.startsWith("@@ ")?j.substring(3):void 0;if(H!==void 0||(j==="@@"?j:void 0)!==void 0)this.index++;else if(Z!==0)throw new f0(`Invalid Line:
|
|
95
|
+
${this.lines[this.index]}`);if(H?.trim()){let P=y0(H.trim());for(let F=Z;F<W.length;F++){let U=W[F];if(U&&(y0(U)===P||y0(U.trim())===P)){if(Z=F+1,y0(U.trim())===P&&y0(U)!==P)this.fuzz++;break}}}let[Y,A,V,B]=PG(this.lines,this.index),[K,G,R]=GG(W,Y,Z,B);if(K===-1){let P=Y.join(`
|
|
96
|
+
`);this.addWarning({path:this.currentPath||f,chunkIndex:J.chunks.length,message:`Could not find matching context (similarity: ${R.toFixed(2)}). Chunk skipped.`,context:P.length>200?`${P.substring(0,200)}...`:P}),this.index=V}else{this.fuzz+=G;for(let P of A)P.origIndex+=K,J.chunks.push(P);Z=K+Y.length,this.index=V}}return J}parseDelete($){if(this.checkDuplicate($,"delete"),!($ in this.currentFiles))throw new f0(`Delete File Error: Missing File: ${$}`);this.patch.actions[$]={type:"delete",chunks:[]},this.index++}parseAdd($){if(this.checkDuplicate($,"add"),$ in this.currentFiles)throw new f0(`Add File Error: File already exists: ${$}`);this.index++;let f=[],J=[x.END,x.UPDATE,x.DELETE,x.ADD];while(this.hasMoreLines()&&!J.some((W)=>this.lines[this.index]?.startsWith(W.trim()))){let W=this.lines[this.index++];if(W===void 0)break;if(!W.startsWith("+"))throw new f0(`Invalid Add File line (missing '+'): ${W}`);f.push(W.substring(1))}this.patch.actions[$]={type:"add",newFile:f.join(`
|
|
97
|
+
`),chunks:[]}}}function _7($,f){let J=$.length>f.length?$:f,W=$.length>f.length?f:$;if(J.length===0)return 1;let Z=KG(W,J);return(J.length-Z)/J.length}function KG($,f){let J=f.length+1,W=$.length+1,Z=Array(J*W).fill(0),Q=(H,X)=>Z[H*W+X]??0,j=(H,X,Y)=>{Z[H*W+X]=Y};for(let H=0;H<=f.length;H++)j(H,0,H);for(let H=0;H<=$.length;H++)j(0,H,H);for(let H=1;H<=f.length;H++)for(let X=1;X<=$.length;X++)if(f[H-1]===$[X-1])j(H,X,Q(H-1,X-1));else j(H,X,1+Math.min(Q(H-1,X-1),Q(H,X-1),Q(H-1,X)));return Q(f.length,$.length)}function GG($,f,J,W){if(f.length===0)return[J,0,1];let Z=0,Q=(j)=>{let H=y0(f.join(`
|
|
98
|
+
`));for(let Y=j;Y<$.length;Y++){let A=y0($.slice(Y,Y+f.length).join(`
|
|
99
|
+
`));if(A===H)return[Y,0,1];let V=_7(A,H);if(V>Z)Z=V}for(let Y=j;Y<$.length;Y++){let A=y0($.slice(Y,Y+f.length).map((B)=>B.trimEnd()).join(`
|
|
100
|
+
`)),V=y0(f.map((B)=>B.trimEnd()).join(`
|
|
101
|
+
`));if(A===V)return[Y,1,1]}for(let Y=j;Y<$.length;Y++){let A=y0($.slice(Y,Y+f.length).map((B)=>B.trim()).join(`
|
|
102
|
+
`)),V=y0(f.map((B)=>B.trim()).join(`
|
|
103
|
+
`));if(A===V)return[Y,100,1]}let X=0.66;for(let Y=j;Y<$.length;Y++){let A=y0($.slice(Y,Y+f.length).join(`
|
|
104
|
+
`)),V=_7(A,H);if(V>=X)return[Y,1000,V];if(V>Z)Z=V}return[-1,0,Z]};if(W){let[j,H,X]=Q($.length-f.length);if(j!==-1)return[j,H,X];return[j,H,X]=Q(J),[j,H+1e4,X]}return Q(J)}function PG($,f){let J=f,W=[],Z=[],Q=[],j=[],H="keep",X=["@@",x.END,x.UPDATE,x.DELETE,x.ADD,x.END_FILE];while(J<$.length){let Y=$[J];if(!Y||X.some((B)=>Y.startsWith(B.trim())))break;if(Y==="***")break;if(Y.startsWith("***"))throw new f0(`Invalid line: ${Y}`);J++;let A=H,V=Y;if(V[0]==="+")H="add";else if(V[0]==="-")H="delete";else if(V[0]===" ")H="keep";else H="keep",V=` ${V}`;if(V=V.slice(1),H==="keep"&&A!==H){if(Q.length||Z.length)j.push({origIndex:W.length-Z.length,delLines:Z,insLines:Q});Z=[],Q=[]}if(H==="delete")Z.push(V),W.push(V);else if(H==="add")Q.push(V);else W.push(V)}if(Q.length||Z.length)j.push({origIndex:W.length-Z.length,delLines:Z,insLines:Q});if(J<$.length&&$[J]===x.END_FILE)return J++,[W,j,J,!0];return[W,j,J,!1]}function V5($,f,J){let W=w0.isAbsolute(f),Z=W?w0.normalize(f):w0.resolve($,f);if(!J||W)return Z;let Q=w0.relative($,Z);if(Q.startsWith("..")||w0.isAbsolute(Q))throw new f0(`Path must stay within cwd: ${f}`);return Z}function FG($){return $.split(`
|
|
105
|
+
`).map((f)=>f.replace(/\r$/,""))}function T7($){if($.trim()==="")return!1;return z7.some((f)=>$.startsWith(f))}function UG($){let f=0,J=$.length;while(f<J&&T7($[f]??""))f++;while(J>f&&T7($[J-1]??""))J--;return $.slice(f,J)}function RG($){let f=FG($),J=f.findIndex((j)=>j.startsWith(x.BEGIN)),W=-1;for(let j=f.length-1;j>=0;j--)if(f[j]?.startsWith(x.END)){W=j;break}if(J!==-1||W!==-1){if(J===-1||W===-1||W<J)throw new f0("Invalid patch text - incomplete sentinels. Try breaking it into smaller patches.");return{lines:f.slice(J,W+1)}}let Z=UG(f);while(Z.length>0&&Z[0]==="")Z.shift();while(Z.length>0&&Z[Z.length-1]==="")Z.pop();return{lines:[x.BEGIN,...Z,x.END]}}function DG($,f){let J=new Set;for(let W of $)for(let Z of f)if(W.startsWith(Z)){J.add(W.substring(Z.length).trim());break}return[...J]}function LG($,f,J){if(f.length===0)return $;let W=$.split(`
|
|
106
|
+
`),Z=[],Q=0;for(let j of f){if(j.origIndex>W.length)throw new f0(`${J}: chunk.origIndex ${j.origIndex} > lines.length ${W.length}`);if(Q>j.origIndex)throw new f0(`${J}: currentIndex ${Q} > chunk.origIndex ${j.origIndex}`);Z.push(...W.slice(Q,j.origIndex)),Z.push(...j.insLines),Q=j.origIndex+j.delLines.length}return Z.push(...W.slice(Q)),Z.join(`
|
|
107
|
+
`)}async function OG($,f,J,W){let Z=DG($,[x.UPDATE,x.DELETE]),Q={};for(let j of Z){let H=V5(f,j,W),X;try{X=await q0.readFile(H,J)}catch{throw new f0(`File not found: ${j}`)}Q[j]=X.replace(/\r\n/g,`
|
|
108
|
+
`)}return Q}function _G($,f){let J={};for(let[W,Z]of Object.entries($.actions))switch(Z.type){case"delete":J[W]={type:"delete",oldContent:f[W]};break;case"add":if(Z.newFile===void 0)throw new f0("ADD action without file content");J[W]={type:"add",newContent:Z.newFile};break;case"update":J[W]={type:"update",oldContent:f[W],newContent:LG(f[W]??"",Z.chunks,W),movePath:Z.movePath};break}return J}async function zG($,f,J,W){let Z=[];for(let[Q,j]of Object.entries($)){let H=V5(f,Q,W);switch(j.type){case"delete":await q0.rm(H,{force:!0}),Z.push(`${Q}: [deleted]`);break;case"add":if(j.newContent===void 0)throw new f0(`Cannot create ${Q} with no content`);await q0.mkdir(w0.dirname(H),{recursive:!0}),await q0.writeFile(H,j.newContent,{encoding:J}),Z.push(Q);break;case"update":{if(j.newContent===void 0)throw new f0(`UPDATE change for ${Q} has no new content`);if(j.movePath){let X=V5(f,j.movePath,W);await q0.mkdir(w0.dirname(X),{recursive:!0}),await q0.writeFile(X,j.newContent,{encoding:J}),await q0.rm(H,{force:!0}),Z.push(`${Q} -> ${j.movePath}`)}else await q0.writeFile(H,j.newContent,{encoding:J}),Z.push(Q);break}}}return Z}function p8($={}){let{encoding:f="utf-8",restrictToCwd:J=!0}=$;return async(W,Z,Q)=>{let j=RG(W.input),H=await OG(j.lines,Z,f,J),X=new A5(j.lines,H),{patch:Y,fuzz:A}=X.parse(),V=_G(Y,H),B=await zG(V,Z,f,J),K=["Successfully applied patch to the following files:"];for(let G of B)K.push(G);if(A>0)K.push(`Note: Patch applied with fuzz factor ${A}`);if(Y.warnings&&Y.warnings.length>0)for(let G of Y.warnings)K.push(`Warning (${G.path}): ${G.message}`);return K.join(`
|
|
109
|
+
`)}}import{spawn as N7}from"node:child_process";import{getDefaultShell as TG,getShellArgs as NG}from"@cline/shared";function MG($,f,J,W,Z){return new Promise((Q,j)=>{let H=process.platform==="win32",X=N7($.executable,$.args,{cwd:$.cwd,env:{...process.env,...$.env},stdio:["pipe","pipe","pipe"],detached:!H}),Y=X.pid,A="",V="",B=0,K=!1,G=!1,R=(D)=>{if(G)return;G=!0,D()},P=()=>{if(!Y)return;if(H){N7("taskkill",["/pid",String(Y),"/T","/F"],{stdio:"ignore",shell:!0,windowsHide:!0}).unref();return}try{process.kill(-Y,"SIGKILL")}catch{X.kill("SIGKILL")}},F=(D)=>{K=!0,P(),R(()=>j(D))},U=setTimeout(()=>F(new Y1(`Command timed out after ${J}ms`,J)),J),_=()=>F(Error("Command was aborted"));if(f.signal)f.signal.addEventListener("abort",_);let z=()=>{clearTimeout(U),f.signal?.removeEventListener("abort",_)};X.stdout?.on("data",(D)=>{if(B+=D.length,B<=W)A+=D.toString()}),X.stderr?.on("data",(D)=>{if(B+=D.length,B<=W)V+=D.toString()}),X.on("close",(D)=>{if(z(),K)return;let O=Z?A+(V?`
|
|
109
110
|
[stderr]
|
|
110
|
-
${
|
|
111
|
+
${V}`:""):A;if(B>W)O+=`
|
|
111
112
|
|
|
112
|
-
[Output truncated: ${B} bytes total, showing first ${
|
|
113
|
+
[Output truncated: ${B} bytes total, showing first ${W} bytes]`;if(D!==0)R(()=>j(Error(V||`Command exited with code ${D}`)));else R(()=>Q(O))}),X.on("error",(D)=>{z(),R(()=>j(Error(`Failed to execute command: ${D.message}`)))})})}function r8($={}){let{shell:f=TG(process.platform),timeoutMs:J=30000,maxOutputBytes:W=1e6,env:Z={},combineOutput:Q=!0}=$;return(j,H,X)=>{let Y=typeof j!=="string";return MG({executable:Y?j.command:f,args:Y?j.args??[]:NG(f,j),cwd:H,env:Z},X,J,W,Q)}}import*as l0 from"node:fs/promises";import*as d0 from"node:path";function yG($,f,J){let W=d0.isAbsolute(f),Z=W?d0.normalize(f):d0.resolve($,f);if(!J)return Z;if(W)return Z;let Q=d0.relative($,Z);if(Q.startsWith("..")||d0.isAbsolute(Q))throw Error(`Path must stay within cwd: ${f}`);return Z}function qG($,f){if(f.length===0)return 0;return $.split(f).length-1}function wG($,f,J){let W=$.split(`
|
|
113
114
|
`),Z=f.split(`
|
|
114
|
-
`),
|
|
115
|
-
`)}async function
|
|
116
|
-
${
|
|
117
|
-
`),j=
|
|
118
|
-
`)),await
|
|
119
|
-
`),{encoding:
|
|
120
|
-
`),
|
|
115
|
+
`),Q=Math.max(W.length,Z.length),j=["```diff"],H=0;for(let X=0;X<Q;X++){if(H>=J){j.push("... diff truncated ...");break}let Y=W[X],A=Z[X];if(Y===A)continue;let V=X+1;if(Y!==void 0)j.push(`-${V}: ${Y}`),H++;if(A!==void 0&&H<J)j.push(`+${V}: ${A}`),H++}return j.push("```"),j.join(`
|
|
116
|
+
`)}async function SG($,f,J){return await l0.mkdir(d0.dirname($),{recursive:!0}),await l0.writeFile($,f,{encoding:J}),`File created successfully at: ${$}`}async function hG($){try{return await l0.access($),!0}catch{return!1}}async function CG($,f,J,W,Z){let Q=await l0.readFile($,W),j=qG(Q,f);if(j===0)throw Error(`No replacement performed: text not found in ${$}.`);if(j>1)throw Error(`No replacement performed: multiple occurrences of text found in ${$}.`);let H=Q.replace(f,J??"");await l0.writeFile($,H,{encoding:W});let X=wG(Q,H,Z);return`Edited ${$}
|
|
117
|
+
${X}`}async function EG($,f,J,W){let Q=(await l0.readFile($,W)).split(`
|
|
118
|
+
`),j=Q.length+1;if(f<1||f>j)throw Error(`Invalid insert_line: ${f}. insert_line must be a positive one-based boundary line in the range 1-${j}. Use ${j} to append at EOF.`);let H=f-1;return Q.splice(H,0,...J.split(`
|
|
119
|
+
`)),await l0.writeFile($,Q.join(`
|
|
120
|
+
`),{encoding:W}),`Inserted content at line ${f} in ${$}.`}function i8($={}){let{encoding:f="utf-8",restrictToCwd:J=!0,maxDiffLines:W=200}=$;return async(Z,Q,j)=>{let H=yG(Q,Z.path,J);if(Z.insert_line!=null)return EG(H,Z.insert_line,Z.new_text,f);if(!await hG(H))return SG(H,Z.new_text,f);if(Z.old_text==null)throw Error("Parameter `old_text` is required when editing an existing file without `insert_line`");return CG(H,Z.old_text,Z.new_text,f,W)}}import*as gf from"node:fs/promises";import*as q$ from"node:path";import{resolveExistingFilePath as bG}from"@cline/shared/storage";var kG=new Map([[".gif","image/gif"],[".png","image/png"],[".jpg","image/jpeg"],[".jpeg","image/jpeg"],[".webp","image/webp"]]),IG={maxFileSizeBytes:1e7,encoding:"utf-8",includeLineNumbers:!0};function n8($={}){let{maxFileSizeBytes:f,encoding:J,includeLineNumbers:W}={...IG,...$};return async(Z,Q)=>{let{path:j,start_line:H,end_line:X}=Z,Y=q$.isAbsolute(j)?q$.normalize(j):q$.resolve(process.cwd(),j),A=bG(Y)??Y,V=q$.extname(A).toLowerCase(),B=kG.get(V),K=await gf.stat(A);if(!K.isFile())throw Error(`Path is not a file: ${A}`);if(K.size>f)throw Error(`File too large: ${K.size} bytes (max: ${f} bytes). Consider reading specific sections or using a different approach.`);if(B){if(Q.metadata?.modelSupportsImages!==!0)throw Error("Current model does not support image input");let _=await gf.readFile(A);return[{type:"text",text:"Successfully read image"},{type:"image",data:_.toString("base64"),mediaType:B}]}let R=(await gf.readFile(A,J)).split(`
|
|
121
|
+
`),P=Math.max((H??1)-1,0),F=Math.min(X??R.length,R.length),U=R.slice(P,F);if(W){let _=String(R.length).length;return U.map((z,D)=>`${String(P+D+1).padStart(_," ")} | ${z}`).join(`
|
|
121
122
|
`)}return U.join(`
|
|
122
|
-
`)}}import{spawn as
|
|
123
|
-
`).filter((
|
|
124
|
-
`)}let
|
|
125
|
-
`);for(let
|
|
126
|
-
Searched ${
|
|
127
|
-
`)}}function
|
|
123
|
+
`)}}import{spawn as C7}from"node:child_process";import*as E7 from"node:fs/promises";import*as s8 from"node:path";import{spawn as xG}from"node:child_process";import{readdir as mG}from"node:fs/promises";import K5 from"node:path";import{isMainThread as q7,parentPort as M7,Worker as gG}from"node:worker_threads";var vG=15000,uG=600000,cG=1000,dG=new Set([".git","node_modules","dist","build",".next","coverage",".turbo",".cache","target","out"]);function y7($){let f=$&&typeof $==="object"&&"code"in $?String($.code??""):"";return f==="EACCES"||f==="EPERM"||f==="ENOENT"}var $f=new Map;function lG(){if(!q7)return!1;return!0}function pG($){if($f.size<=1)return;for(let[f,J]of $f.entries()){if(J.pending)continue;if($-J.lastAccessedAt>uG)$f.delete(f)}}function rG($,f){return K5.relative($,f).split(K5.sep).join("/")}async function iG($){let J=(await new Promise((W,Z)=>{let Q=xG("rg",["--files","--hidden","-g","!.git"],{cwd:$,stdio:["ignore","pipe","pipe"]}),j="",H="";Q.stdout.on("data",(X)=>{j+=X.toString()}),Q.stderr.on("data",(X)=>{H+=X.toString()}),Q.on("error",Z),Q.on("close",(X)=>{if(X===0){W(j);return}Z(Error(H||`rg exited with code ${X}`))})})).split(/\r?\n/).map((W)=>W.trim()).filter((W)=>W.length>0).map((W)=>W.replace(/\\/g,"/"));return new Set(J)}async function w7($,f,J){let W;try{W=await mG(f,{withFileTypes:!0})}catch(Z){if(y7(Z))return;throw Z}for(let Z of W){let Q=K5.join(f,Z.name);if(Z.isDirectory()){if(dG.has(Z.name))continue;try{await w7($,Q,J)}catch(j){if(y7(j))continue;throw j}continue}if(Z.isFile())J.add(rG($,Q))}}async function nG($){let f=new Set;return await w7($,$,f),f}async function a8($){try{return await iG($)}catch{return nG($)}}function aG(){if(q7||!M7)return;let $=M7;$.on("message",(f)=>{if(f.type!=="index")return;a8(f.cwd).then((J)=>{let W={type:"indexResult",requestId:f.requestId,files:Array.from(J)};$.postMessage(W)}).catch((J)=>{let W={type:"indexResult",requestId:f.requestId,error:J instanceof Error?J.message:"Failed to build file index"};$.postMessage(W)})})}class S7{worker=new gG(new URL(import.meta.url));nextRequestId=0;pending=new Map;constructor(){this.worker.unref(),this.worker.on("message",($)=>{if($.type!=="indexResult")return;let f=this.pending.get($.requestId);if(!f)return;if(this.pending.delete($.requestId),$.error){f.reject(Error($.error));return}f.resolve($.files??[])}),this.worker.on("error",($)=>{this.flushPending($)}),this.worker.on("exit",($)=>{if($!==0)this.flushPending(Error(`File index worker exited with code ${$}`))})}requestIndex($){let f=++this.nextRequestId,J=new Promise((Z,Q)=>{let j=setTimeout(()=>{this.pending.delete(f),Z(null)},cG);j.unref(),this.pending.set(f,{resolve:(H)=>{clearTimeout(j),Z(H)},reject:(H)=>{clearTimeout(j),Q(H)}})}),W={type:"index",requestId:f,cwd:$};return this.worker.postMessage(W),J}flushPending($){for(let[f,J]of this.pending.entries())J.reject($),this.pending.delete(f)}}aG();var B5;function tG(){if(!lG())return null;if(B5===void 0)B5=new S7;return B5}async function sG($){let f=tG();if(!f)return a8($);try{let J=await f.requestIndex($);if(J===null)return a8($);return new Set(J)}catch{return a8($)}}async function A1($,f={}){let J=f.ttlMs??vG,W=Date.now();pG(W);let Z=$f.get($);if(Z&&J>0&&W-Z.lastBuiltAt<=J&&Z.files.size>0)return Z.lastAccessedAt=W,Z.files;if(Z?.pending)return Z.lastAccessedAt=W,Z.pending;let Q=sG($).then((j)=>{return $f.set($,{files:j,lastBuiltAt:Date.now(),lastAccessedAt:Date.now(),pending:null}),j});return $f.set($,{files:Z?.files??new Set,lastBuiltAt:Z?.lastBuiltAt??0,lastAccessedAt:W,pending:Q}),Q}async function h7($,f={}){await A1($,{...f,ttlMs:0})}import{stat as oG}from"node:fs/promises";import V1 from"node:path";var eG=/[),.:;!?`'"]+$/,$P=/^[(`'"]+/;function fP($){let f=$.matchAll(/(^|[\s])@([^\s]+)/g),J=[];for(let W of f){let Z=(W[2]??"").trim();if(Z.length===0)continue;let Q=Z.replace($P,"").replace(eG,"");if(Q.length===0||Q.includes("@"))continue;J.push(Q)}return Array.from(new Set(J))}function JP($,f){let J=$.replace(/\\/g,"/"),W=V1.isAbsolute(J)?V1.resolve(J):V1.resolve(f,J),Z=V1.relative(f,W);if(Z.startsWith("..")||V1.isAbsolute(Z))return;return Z.split(V1.sep).join("/")}async function t8($,f,J={}){let W=fP($);if(W.length===0)return{prompt:$,mentions:[],matchedFiles:[],ignoredMentions:[]};let{maxFiles:Z,maxFileBytes:Q,maxTotalBytes:j}=J,H=await A1(f,{ttlMs:J.ttlMs}),X=[],Y=[],A=[],V=0;for(let B of W){if(Z&&A.length>=Z){Y.push(B);continue}let K=JP(B,f);if(!K||!H.has(K)){Y.push(B);continue}if(!Q||!j){X.push(K);continue}let G=V1.join(f,K);try{if(!(await oG(G)).isFile()){Y.push(B);continue}let P=V+Q;if(P>j){Y.push(B);continue}V=P,X.push(K)}catch{Y.push(B)}}return{prompt:$,mentions:W,matchedFiles:X,ignoredMentions:Y}}var WP=["ts","tsx","js","jsx","mjs","cjs","json","md","mdx","txt","yaml","yml","toml","py","rb","go","rs","java","kt","swift","c","cpp","h","hpp","css","scss","less","html","vue","svelte","sql","sh","bash","zsh","fish","ps1","env","gitignore","dockerignore","editorconfig"],ZP=["node_modules",".git","dist","build",".next","coverage","__pycache__",".venv","venv",".cache",".turbo",".output","out","target","bin","obj"],B1=null;function QP(){if(B1!==null)return Promise.resolve(B1);return new Promise(($)=>{let f=C7("rg",["--version"],{stdio:["ignore","pipe","pipe"]});f.on("close",(J)=>{B1=J===0,$(B1)}),f.on("error",()=>{B1=!1,$(!1)}),setTimeout(()=>{if(!f.killed)f.kill("SIGTERM");if(B1===null)B1=!1,$(!1)},1000)})}function jP($,f,J,W,Z=5000,Q){return new Promise((j)=>{let H=C7("rg",["--json",`--context=${W}`,"--max-count=1","-i",$],{cwd:f,stdio:["ignore","pipe","pipe"]}),X="",Y=!1,A=()=>{if(!H.killed)H.kill("SIGTERM")},V=setTimeout(()=>{if(!Y)Y=!0,A(),j(null)},Z),B=(K)=>{if(!Y)Y=!0,clearTimeout(V),A(),j(K)};if(Q?.aborted){A(),j(null);return}Q?.addEventListener("abort",()=>{B(null)}),H.stdout.on("data",(K)=>{X+=K.toString()}),H.stderr.on("data",()=>{}),H.on("close",(K)=>{if(K===0||K===1){try{let G=[],R=X.split(`
|
|
124
|
+
`).filter((P)=>P.trim());for(let P of R){if(G.length>=J)break;let F=JSON.parse(P);if(F.type==="match"){let U=F.data,_=[];if(F.data.submatches&&F.data.submatches.length>0){let z=F.data.submatches[0];G.push({file:U.path.text,line:U.line_number,column:(z?.start??0)+1,match:z?.match?.text??"",context:_})}}else if(F.type==="context"&&G.length>0){let U=G[G.length-1],_=F.data.line_number===U.line?">":" ";U.context.push(`${_} ${F.data.line_number}: ${F.data.lines?.text??F.data.line?.text??""}`)}}B(G.length>0?G:null)}catch{B(null)}return}B(null)}),H.on("error",()=>{B(null)})})}function HP($,f,J,W){let Z=$.split("/"),Q=Z[Z.length-1]??"";if(Z.length-1>W)return!1;for(let X=0;X<Z.length-1;X++)if(f.has(Z[X]??""))return!1;let H=s8.posix.extname(Q).slice(1).toLowerCase();return J.has(H)||!H&&!Q.startsWith(".")}function o8($={}){let{includeExtensions:f=WP,excludeDirs:J=ZP,maxResults:W=100,contextLines:Z=2,maxDepth:Q=20}=$,j=new Set(J),H=new Set(f.map((X)=>X.toLowerCase()));return async(X,Y,A)=>{if(A.signal?.aborted)throw Error("Search operation aborted");let V=await QP(),B=null;if(V)B=await jP(X,Y,W,Z,5000,A.signal);if(B){let U=[`Found ${B.length} result${B.length===1?"":"s"} for pattern: ${X}`,""];for(let _ of B)U.push(`${_.file}:${_.line}:${_.column}`),U.push(..._.context),U.push("");if(B.length>=W)U.push(`(Showing first ${W} results. Refine your search for more specific results.)`);return U.join(`
|
|
125
|
+
`)}let K;try{K=new RegExp(X,"gim")}catch(U){throw Error(`Invalid regex pattern: ${X}. ${U instanceof Error?U.message:""}`)}let G=[],R=0,P=await A1(Y);for(let U of P){if(A.signal?.aborted)throw Error("Search operation aborted");if(!HP(U,j,H,Q))continue;if(G.length>=W)break;R++;let _=s8.join(Y,U);try{let D=(await E7.readFile(_,"utf-8")).split(`
|
|
126
|
+
`);for(let O=0;O<D.length;O++){let T=D[O];K.lastIndex=0;let M=K.exec(T);while(M!==null){if(G.length>=W)break;let s=Math.max(0,O-Z),Z0=Math.min(D.length-1,O+Z),a=[];for(let Q0=s;Q0<=Z0;Q0++){let l=Q0===O?">":" ";a.push(`${l} ${Q0+1}: ${D[Q0]}`)}if(G.push({file:U,line:O+1,column:M.index+1,match:M[0],context:a}),M.index===K.lastIndex)K.lastIndex++;M=K.exec(T)}}}catch{}}if(G.length===0)return`No results found for pattern: ${X}
|
|
127
|
+
Searched ${R} files.`;let F=[`Found ${G.length} result${G.length===1?"":"s"} for pattern: ${X}`,`Searched ${R} files.`,""];for(let U of G)F.push(`${U.file}:${U.line}:${U.column}`),F.push(...U.context),F.push("");if(G.length>=W)F.push(`(Showing first ${W} results. Refine your search for more specific results.)`);return F.join(`
|
|
128
|
+
`)}}function XP($){return $.replace(/<script[^>]*>[\s\S]*?<\/script>/gi,"").replace(/<style[^>]*>[\s\S]*?<\/style>/gi,"").replace(/<!--[\s\S]*?-->/g,"").replace(/<(p|div|br|hr|h[1-6]|li|tr)[^>]*>/gi,`
|
|
128
129
|
`).replace(/<[^>]+>/g," ").replace(/ /g," ").replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,'"').replace(/&#(\d+);/g,(f,J)=>String.fromCharCode(parseInt(J,10))).replace(/\s+/g," ").replace(/\n\s+/g,`
|
|
129
130
|
`).replace(/\n{3,}/g,`
|
|
130
131
|
|
|
131
|
-
`).trim()}function
|
|
132
|
-
[Content truncated: showing first 50000 of ${
|
|
133
|
-
`)}catch(G){if(clearTimeout(A),G instanceof Error){if(G.name==="AbortError")throw Error(`Request timed out after ${f}ms`);throw G}throw Error(`Fetch failed: ${String(G)}`)}finally{if(H.signal&&B)H.signal.removeEventListener("abort",B)}}}function z4($={}){return{readFile:P4($.fileRead),search:L4($.search),bash:K4($.bash),webFetch:O4($.webFetch),applyPatch:G4($.applyPatch),editor:F4($.editor)}}var nB={read_files:"enableReadFiles",search_codebase:"enableSearch",run_commands:"enableBash",fetch_web_content:"enableWebFetch",apply_patch:"enableApplyPatch",editor:"enableEditor",skills:"enableSkills",ask_question:"enableAskQuestion",submit_and_exit:"enableSubmitAndExit"},R2=[{name:"openai-native-use-apply-patch",mode:"act",providerIdIncludes:["openai-native"],enableTools:["apply_patch"],disableTools:["editor"]},{name:"codex-and-gpt-use-apply-patch",mode:"act",modelIdIncludes:["codex","gpt"],enableTools:["apply_patch"],disableTools:["editor"]}];function OZ($,f){if(!f||f.length===0)return!0;let J=$.toLowerCase();return f.some((Q)=>J.includes(Q.toLowerCase()))}function aB($,f,J,Q){if($.mode&&$.mode!=="any"&&$.mode!==Q)return!1;return OZ(f,$.providerIdIncludes)&&OZ(J,$.modelIdIncludes)}function L2($,f,J,Q){if(!Q||Q.length===0)return{};let Z=new Map;for(let j of Q){if(!aB(j,$,f,J))continue;for(let X of j.disableTools??[])Z.set(X,!1);for(let X of j.enableTools??[])Z.set(X,!0)}let W={};for(let[j,X]of Z.entries())W[nB[j]]=X;return W}var r0={act:{enableReadFiles:!0,enableSearch:!0,enableBash:!0,enableWebFetch:!0,enableApplyPatch:!1,enableEditor:!0,enableSkills:!0,enableAskQuestion:!0,enableSubmitAndExit:!1,enableSpawnAgent:!0,enableAgentTeams:!0},plan:{enableReadFiles:!0,enableSearch:!0,enableBash:!0,enableWebFetch:!0,enableApplyPatch:!1,enableEditor:!1,enableSkills:!0,enableAskQuestion:!0,enableSubmitAndExit:!1,enableSpawnAgent:!0,enableAgentTeams:!0},search:{enableReadFiles:!0,enableSearch:!0,enableBash:!1,enableWebFetch:!1,enableApplyPatch:!1,enableEditor:!1,enableSkills:!1,enableAskQuestion:!1,enableSubmitAndExit:!1,enableSpawnAgent:!0,enableAgentTeams:!0},minimal:{enableReadFiles:!1,enableSearch:!1,enableBash:!0,enableWebFetch:!1,enableApplyPatch:!1,enableEditor:!1,enableSkills:!1,enableAskQuestion:!1,enableSubmitAndExit:!1,enableSpawnAgent:!0,enableAgentTeams:!1},yolo:{enableReadFiles:!0,enableSearch:!1,enableBash:!0,enableWebFetch:!1,enableApplyPatch:!1,enableEditor:!0,enableSkills:!1,enableAskQuestion:!1,enableSubmitAndExit:!0,enableSpawnAgent:!1,enableAgentTeams:!1}};function N$($){if($.mode==="plan")return"plan";if($.mode==="yolo")return"yolo";return"act"}function zZ($){if($!=="yolo")return{};let f={enabled:!0,autoApprove:!0},J={"*":f};for(let Q of I1)J[Q]=f;return J}function _Z($,f){let J=r0[$],{enableSpawnAgent:Q,enableAgentTeams:Z,...W}=J;return m1({...W,...f})}import{createTool as lG,zodToJsonSchema as pG}from"@cline/shared";import{z as CJ}from"zod";import{createAgentRuntime as kG}from"@cline/agents";import{createContributionRegistry as IG}from"@cline/shared";import{createGateway as tB,MODEL_COLLECTIONS_BY_PROVIDER_ID as sB}from"@cline/llms";function oB($){let f=Object.fromEntries(Object.entries($).filter(([,J])=>J!==void 0));return Object.keys(f).length>0?f:void 0}function eB($){let f={region:$.region,apiLine:$.apiLine,openRouterProviderSorting:$.openRouterProviderSorting,modelCatalog:$.modelCatalog};if($.providerId==="bedrock")Object.assign(f,{authentication:$.aws?.authentication,profile:$.aws?.profile,accessKeyId:$.aws?.accessKey,secretAccessKey:$.aws?.secretKey,sessionToken:$.aws?.sessionToken,usePromptCache:$.aws?.usePromptCache,useCrossRegionInference:$.useCrossRegionInference,useGlobalInference:$.useGlobalInference,endpoint:$.aws?.endpoint,customModelBaseId:$.aws?.customModelBaseId});if($.providerId==="vertex"){let J=$.gcp?.region??$.region;Object.assign(f,{project:$.gcp?.projectId,projectId:$.gcp?.projectId,location:J,region:J})}return oB(f)}function _J($){let f=$.providerConfig;if(f?.knownModels)return f.knownModels;if($.knownModels)return $.knownModels;return sB[$.providerId]?.models??void 0}function $G($){if(!$?.length)return;let f=new Set;for(let J of $)switch(J){case"tools":case"reasoning":case"prompt-cache":case"images":f.add(J);break;case"structured_output":f.add("structured-output");break;default:f.add("text")}return f.add("text"),[...f]}function fG($,f){return{id:$,name:f.name??$,description:f.description,contextWindow:f.contextWindow,maxInputTokens:f.maxInputTokens,maxOutputTokens:f.maxTokens,capabilities:$G(f.capabilities),metadata:{family:f.family,pricing:f.pricing,status:f.status,releaseDate:f.releaseDate}}}function NZ($,f,J){let Q=$.providerConfig,Z=Q?.providerId===$.providerId?Q:void 0,W={...Z??{},providerId:$.providerId,modelId:$.modelId,apiKey:$.apiKey??Z?.apiKey,baseUrl:$.baseUrl??Z?.baseUrl,headers:$.headers??Z?.headers,knownModels:_J($),maxOutputTokens:$.maxTokensPerTurn,reasoningEffort:$.reasoningEffort,thinkingBudgetTokens:$.thinkingBudgetTokens,thinking:$.thinking,logger:f,extensionContext:$.extensionContext};return tB({providerConfigs:[{providerId:W.providerId,apiKey:W.apiKey,baseUrl:W.baseUrl,headers:W.headers,options:eB(W),models:W.knownModels?Object.entries(W.knownModels).map(([j,X])=>fG(j,X)):void 0}],logger:f,telemetry:J??$.telemetry??$.extensionContext?.telemetry}).createAgentModel({providerId:W.providerId,modelId:W.modelId},{maxTokens:W.maxOutputTokens})}import{normalizeUserInput as TZ}from"@cline/shared";var JG=50000,QG=6000000,MZ=8000,ZG=new Set(["read","read_files","search","search_codebase","bash","run_commands"]),WG=new Set(["read","read_files"]),W1="[outdated - see the latest file content]",qZ="Tool execution was interrupted before a result was produced.",jG=($)=>`
|
|
132
|
+
`).trim()}function e8($={}){let{timeoutMs:f=30000,maxResponseBytes:J=5000000,userAgent:W="Mozilla/5.0 (compatible; AgentBot/1.0)",headers:Z={},followRedirects:Q=!0}=$;return async(j,H,X)=>{let Y;try{Y=new URL(j)}catch{throw Error(`Invalid URL: ${j}`)}if(!["http:","https:"].includes(Y.protocol))throw Error(`Invalid protocol: ${Y.protocol}. Only http and https are supported.`);let A=new AbortController,V=setTimeout(()=>A.abort(),f),B;if(X.signal)B=()=>A.abort(),X.signal.addEventListener("abort",B);try{let K=await fetch(j,{method:"GET",headers:{"User-Agent":W,Accept:"text/html,application/xhtml+xml,application/xml;q=0.9,text/plain;q=0.8,*/*;q=0.7","Accept-Language":"en-US,en;q=0.9",...Z},redirect:Q?"follow":"manual",signal:A.signal});if(clearTimeout(V),!Q&&K.status>=300&&K.status<400)return`Redirect to: ${K.headers.get("location")}`;if(!K.ok)throw Error(`HTTP ${K.status}: ${K.statusText}`);let G=K.headers.get("content-type")||"",R=K.body?.getReader();if(!R)throw Error("Failed to read response body");let P=[],F=0;while(!0){let{done:T,value:M}=await R.read();if(T)break;if(F+=M.length,F>J)throw R.cancel(),Error(`Response too large: exceeded ${J} bytes`);P.push(M)}let U=new Uint8Array(F),_=0;for(let T of P)U.set(T,_),_+=T.length;let z=new TextDecoder("utf-8").decode(U),D;if(G.includes("text/html")||G.includes("application/xhtml"))D=XP(z);else if(G.includes("application/json"))try{let T=JSON.parse(z);D=JSON.stringify(T,null,2)}catch{D=z}else D=z;let O=[`URL: ${j}`,`Content-Type: ${G}`,`Size: ${F} bytes`,"","--- Content ---",D.slice(0,50000)];if(D.length>50000)O.push(`
|
|
133
|
+
[Content truncated: showing first 50000 of ${D.length} characters]`);return O.push("","--- Analysis Request ---",`Prompt: ${H}`),O.join(`
|
|
134
|
+
`)}catch(K){if(clearTimeout(V),K instanceof Error){if(K.name==="AbortError")throw Error(`Request timed out after ${f}ms`);throw K}throw Error(`Fetch failed: ${String(K)}`)}finally{if(X.signal&&B)X.signal.removeEventListener("abort",B)}}}function $J($={}){return{readFile:n8($.fileRead),search:o8($.search),bash:r8($.bash),webFetch:e8($.webFetch),applyPatch:p8($.applyPatch),editor:i8($.editor)}}var YP={read_files:"enableReadFiles",search_codebase:"enableSearch",run_commands:"enableBash",fetch_web_content:"enableWebFetch",apply_patch:"enableApplyPatch",editor:"enableEditor",skills:"enableSkills",ask_question:"enableAskQuestion",submit_and_exit:"enableSubmitAndExit"},vf=[{name:"openai-native-use-apply-patch",mode:"act",providerIdIncludes:["openai-native"],enableTools:["apply_patch"],disableTools:["editor"]},{name:"codex-and-gpt-use-apply-patch",mode:"act",modelIdIncludes:["codex","gpt"],enableTools:["apply_patch"],disableTools:["editor"]}];function b7($,f){if(!f||f.length===0)return!0;let J=$.toLowerCase();return f.some((W)=>J.includes(W.toLowerCase()))}function AP($,f,J,W){if($.mode&&$.mode!=="any"&&$.mode!==W)return!1;return b7(f,$.providerIdIncludes)&&b7(J,$.modelIdIncludes)}function uf($,f,J,W){if(!W||W.length===0)return{};let Z=new Map;for(let j of W){if(!AP(j,$,f,J))continue;for(let H of j.disableTools??[])Z.set(H,!1);for(let H of j.enableTools??[])Z.set(H,!0)}let Q={};for(let[j,H]of Z.entries())Q[YP[j]]=H;return Q}var s0={act:{enableReadFiles:!0,enableSearch:!0,enableBash:!0,enableWebFetch:!0,enableApplyPatch:!1,enableEditor:!0,enableSkills:!0,enableAskQuestion:!0,enableSubmitAndExit:!1,enableSpawnAgent:!0,enableAgentTeams:!0},plan:{enableReadFiles:!0,enableSearch:!0,enableBash:!0,enableWebFetch:!0,enableApplyPatch:!1,enableEditor:!1,enableSkills:!0,enableAskQuestion:!0,enableSubmitAndExit:!1,enableSpawnAgent:!0,enableAgentTeams:!0},search:{enableReadFiles:!0,enableSearch:!0,enableBash:!1,enableWebFetch:!1,enableApplyPatch:!1,enableEditor:!1,enableSkills:!1,enableAskQuestion:!1,enableSubmitAndExit:!1,enableSpawnAgent:!0,enableAgentTeams:!0},minimal:{enableReadFiles:!1,enableSearch:!1,enableBash:!0,enableWebFetch:!1,enableApplyPatch:!1,enableEditor:!1,enableSkills:!1,enableAskQuestion:!1,enableSubmitAndExit:!1,enableSpawnAgent:!0,enableAgentTeams:!1},yolo:{enableReadFiles:!0,enableSearch:!1,enableBash:!0,enableWebFetch:!1,enableApplyPatch:!1,enableEditor:!0,enableSkills:!1,enableAskQuestion:!1,enableSubmitAndExit:!0,enableSpawnAgent:!1,enableAgentTeams:!1}};function w$($){if($.mode==="plan")return"plan";if($.mode==="yolo")return"yolo";return"act"}function k7($){if($!=="yolo")return{};let f={enabled:!0,autoApprove:!0},J={"*":f};for(let W of s1)J[W]=f;return J}function I7($,f){let J=s0[$],{enableSpawnAgent:W,enableAgentTeams:Z,...Q}=J;return e1({...Q,...f})}import{createTool as AF,zodToJsonSchema as VF}from"@cline/shared";import{z as z5}from"zod";import{createAgentRuntime as fF}from"@cline/agents";import{createContributionRegistry as JF}from"@cline/shared";import{createGateway as DP,createHandlerAsync as LP,hasRegisteredHandler as OP,MODEL_COLLECTIONS_BY_PROVIDER_ID as _P,normalizeProviderId as zP}from"@cline/llms";function VP($){let f=KP($.content),J=[],W=$.id??FP(),Z=0,Q=[],j=()=>{if(Q.length===0)return;let H=Z===0?W:`${W}_part_${Z}`;Z+=1,J.push({id:H,role:$.role,content:Q.map(GP),createdAt:$.ts??Date.now(),metadata:$.metadata,modelInfo:$.modelInfo,metrics:x7($.metrics)}),Q=[]};if(f.length===0)return J.push({id:W,role:$.role,content:[],createdAt:$.ts??Date.now(),metadata:$.metadata,modelInfo:$.modelInfo,metrics:x7($.metrics)}),J;for(let H of f){if(H.type!=="tool_result"){Q.push(H);continue}j(),J.push({id:`${W}_tool_${H.tool_use_id}`,role:"tool",content:[g7(H)],createdAt:$.ts??Date.now(),metadata:$.metadata})}return j(),J}function fJ($){return $.flatMap(VP)}function BP($){let f=$.content.map(v7).filter((J)=>J!==void 0);return{id:$.id,role:$.role==="tool"?"user":$.role,content:f,ts:$.createdAt,metadata:$.metadata,modelInfo:$.modelInfo,metrics:PP($.metrics)}}function ff($){return $.map(BP)}function JJ($){let f=[];for(let J of $){let W=J.content.map(v7).filter((j)=>j!==void 0),Z=J.role==="tool"?"user":J.role,Q=f[f.length-1];if(Z==="user"&&W.length>0&&W.every((j)=>j.type==="tool_result")&&Q?.role==="user"&&Array.isArray(Q.content)&&Q.content.every((j)=>j.type==="tool_result")){Q.content.push(...W);continue}f.push({role:Z,content:W})}return f}function KP($){if(typeof $==="string")return $.length>0?[{type:"text",text:$}]:[];return[...$]}function GP($){switch($.type){case"text":return{type:"text",text:$.text};case"thinking":return{type:"reasoning",text:$.thinking,metadata:$.signature?{signature:$.signature,details:$.details}:$.details?{details:$.details}:void 0};case"redacted_thinking":return{type:"reasoning",text:"",redacted:!0,metadata:{data:$.data}};case"image":return{type:"image",image:$.data,mediaType:$.mediaType};case"file":return{type:"file",path:$.path,content:$.content};case"tool_use":return{type:"tool-call",toolCallId:$.id,toolName:$.name,input:$.input,metadata:$.signature?{signature:$.signature}:void 0};case"tool_result":return g7($)}}function g7($){return{type:"tool-result",toolCallId:$.tool_use_id,toolName:$.name,output:$.content,isError:$.is_error}}function v7($){switch($.type){case"text":return{type:"text",text:$.text};case"reasoning":{if($.redacted===!0)return{type:"redacted_thinking",data:$.metadata?.data??""};let f=$.metadata;return{type:"thinking",thinking:$.text,signature:f?.signature,details:f?.details}}case"image":return typeof $.image==="string"?{type:"image",data:$.image,mediaType:$.mediaType??"image/png"}:void 0;case"file":return{type:"file",path:$.path,content:$.content};case"tool-call":return{type:"tool_use",id:$.toolCallId,name:$.toolName,input:$.input??{},signature:$.metadata?.signature};case"tool-result":{let f=$.output,J=typeof f==="string"?f:Array.isArray(f)?f:JSON.stringify(f);return{type:"tool_result",tool_use_id:$.toolCallId,name:$.toolName,content:J,is_error:$.isError}}}}function x7($){if(!$)return;return{inputTokens:$.inputTokens??0,outputTokens:$.outputTokens??0,cacheReadTokens:$.cacheReadTokens??0,cacheWriteTokens:$.cacheWriteTokens??0,cost:$.cost}}function PP($){if(!$)return;return{inputTokens:$.inputTokens,outputTokens:$.outputTokens,cacheReadTokens:$.cacheReadTokens,cacheWriteTokens:$.cacheWriteTokens,cost:$.cost}}var m7=0;function FP(){return m7+=1,`msg_${Date.now().toString(36)}_${m7.toString(36)}`}function UP($){switch($.type){case"text":return[{type:"text-delta",text:$.text}];case"reasoning":return[{type:"reasoning-delta",text:$.reasoning,metadata:$.signature?{thoughtSignature:$.signature,details:$.details}:{details:$.details}}];case"tool_calls":{let f=$.tool_call.function,J=f.arguments;return[{type:"tool-call-delta",toolCallId:$.tool_call.call_id??f.id,toolName:f.name,inputText:typeof J==="string"?J:void 0,input:typeof J==="string"?void 0:J,...$.signature?{metadata:{thoughtSignature:$.signature}}:{}}]}case"usage":return[{type:"usage",usage:{inputTokens:$.inputTokens,outputTokens:$.outputTokens,cacheReadTokens:$.cacheReadTokens,cacheWriteTokens:$.cacheWriteTokens,totalCost:$.totalCost}}];case"done":return[{type:"finish",reason:RP($),error:$.error}];default:return[]}}function RP($){if($.success===!1)return"error";if($.incompleteReason==="max_output_tokens"||$.incompleteReason==="max-tokens")return"max-tokens";return"stop"}function u7($){return{async*stream(f){let J=!1,W=!1;try{let Z=typeof $==="function"?await $():$;Z.setAbortSignal?.(f.signal);let Q=JJ(f.messages),j=f.tools.map((H)=>({name:H.name,description:H.description,inputSchema:H.inputSchema}));for await(let H of Z.createMessage(f.systemPrompt??"",Q,j))for(let X of UP(H)){if(X.type==="finish")J=!0;else if(X.type==="tool-call-delta")W=!0;yield X}if(!J)yield{type:"finish",reason:W?"tool-calls":"stop"}}catch(Z){if(!J)yield{type:"finish",reason:f.signal?.aborted?"aborted":"error",error:Z instanceof Error?Z.message:String(Z)}}}}}function TP($){let f=Object.fromEntries(Object.entries($).filter(([,J])=>J!==void 0));return Object.keys(f).length>0?f:void 0}function NP($){let f={region:$.region,apiLine:$.apiLine,openRouterProviderSorting:$.openRouterProviderSorting,modelCatalog:$.modelCatalog};if($.providerId==="bedrock")Object.assign(f,{authentication:$.aws?.authentication,profile:$.aws?.profile,accessKeyId:$.aws?.accessKey,secretAccessKey:$.aws?.secretKey,sessionToken:$.aws?.sessionToken,usePromptCache:$.aws?.usePromptCache,useCrossRegionInference:$.useCrossRegionInference,useGlobalInference:$.useGlobalInference,endpoint:$.aws?.endpoint,customModelBaseId:$.aws?.customModelBaseId});if($.providerId==="vertex"){let J=$.gcp?.region??$.region;Object.assign(f,{project:$.gcp?.projectId,projectId:$.gcp?.projectId,location:J,region:J})}return TP(f)}function G5($){let f=$.providerConfig;if(f?.knownModels)return f.knownModels;if($.knownModels)return $.knownModels;return _P[$.providerId]?.models??void 0}function MP($){if(!$?.length)return;let f=new Set;for(let J of $)switch(J){case"tools":case"reasoning":case"prompt-cache":case"images":f.add(J);break;case"structured_output":f.add("structured-output");break;default:f.add("text")}return f.add("text"),[...f]}function yP($,f){return{id:$,name:f.name??$,description:f.description,contextWindow:f.contextWindow,maxInputTokens:f.maxInputTokens,maxOutputTokens:f.maxTokens,capabilities:MP(f.capabilities),metadata:{family:f.family,pricing:f.pricing,status:f.status,releaseDate:f.releaseDate}}}function c7($,f,J){let W=$.providerConfig,Z=W?.providerId===$.providerId?W:void 0,Q={...Z??{},providerId:$.providerId,modelId:$.modelId,apiKey:$.apiKey??Z?.apiKey,baseUrl:$.baseUrl??Z?.baseUrl,headers:$.headers??Z?.headers,knownModels:G5($),maxOutputTokens:$.maxTokensPerTurn,reasoningEffort:$.reasoningEffort,thinkingBudgetTokens:$.thinkingBudgetTokens,thinking:$.thinking,logger:f,extensionContext:$.extensionContext};if(OP(zP(Q.providerId)))return u7(()=>LP(Q));return DP({providerConfigs:[{providerId:Q.providerId,apiKey:Q.apiKey,baseUrl:Q.baseUrl,headers:Q.headers,options:NP(Q),models:Q.knownModels?Object.entries(Q.knownModels).map(([j,H])=>yP(j,H)):void 0}],logger:f,telemetry:J??$.telemetry??$.extensionContext?.telemetry}).createAgentModel({providerId:Q.providerId,modelId:Q.modelId},{maxTokens:Q.maxOutputTokens})}import{normalizeUserInput as d7}from"@cline/shared";var qP=50000,wP=6000000,l7=8000,SP=new Set(["read","read_files","search","search_codebase","bash","run_commands"]),hP=new Set(["read","read_files"]),K1="[outdated - see the latest file content]",p7="Tool execution was interrupted before a result was produced.",CP=($)=>`
|
|
134
135
|
|
|
135
136
|
...[truncated ${$} chars]...
|
|
136
137
|
|
|
137
|
-
`,
|
|
138
|
+
`,EP=($)=>`
|
|
138
139
|
|
|
139
140
|
...[truncated ${$} chars to fit provider request budget]...
|
|
140
141
|
|
|
141
|
-
`;class TJ{maxToolResultChars;targetToolNames;maxTotalTextBytes;indexedMessageCount=0;indexedTailRef;toolNameByIdCache=new Map;readLocatorsByToolUseIdCache=new Map;latestReadToolUseByLocatorCache=new Map;latestFullContentOwnerByPathCache=new Map;readResultLocatorCache=new WeakMap;constructor($=JG,f=ZG,J=QG){this.maxToolResultChars=$;this.targetToolNames=f;this.maxTotalTextBytes=J}buildForApi($){this.reindex($);let J=this.addMissingToolResults($).map((Q)=>{if(!Array.isArray(Q.content)){if(Q.role==="user"&&typeof Q.content==="string"){let j=TZ(Q.content);if(j!==Q.content)return{...Q,content:j}}return Q}let Z=!1,W=Q.content.map((j)=>{let X=this.transformBlock(j,Q.role);if(X!==j)Z=!0;return X});return Z?{...Q,content:W}:Q});return this.truncateToTotalTextBudget(J)}transformBlock($,f){if(f==="user"&&$.type==="text"&&typeof $.text==="string"){let Z=TZ($.text);if(Z!==$.text)return{...$,text:Z};return $}if($.type==="file"){let Z=this.truncateMiddle($.content);return Z===$.content?$:{...$,content:Z}}if($.type!=="tool_result")return $;let J=this.toolNameByIdCache.get($.tool_use_id),Q=$.content;if(this.isReadTool(J)&&$.is_error!==!0){let Z=this.getReadLocators($);if(Z.length>0){let W=Z.filter((j)=>this.isOutdatedReadLocator(j,$.tool_use_id));if(W.length>0)Q=this.replaceOutdatedReadContent(Q,W)}}if(this.shouldTruncateTool(J))Q=this.truncateToolResultContent(Q);return Q===$.content?$:{...$,content:Q}}reindex($){let f=this.indexedMessageCount===0||$.length>=this.indexedMessageCount&&$[this.indexedMessageCount-1]===this.indexedTailRef;if($.length<this.indexedMessageCount||!f)this.resetIndexes();for(let J=this.indexedMessageCount;J<$.length;J++){let Q=$[J];if(!Array.isArray(Q.content))continue;for(let Z=0;Z<Q.content.length;Z++){let W=Q.content[Z];if(W.type==="file")this.latestFullContentOwnerByPathCache.set(W.path,`file:${J}:${Z}`);else if(W.type==="tool_use"){let j=W.name.toLowerCase();if(this.toolNameByIdCache.set(W.id,j),this.isReadTool(j)){let X=this.extractLocatorsFromReadToolInput(W.input);if(X.length>0)this.readLocatorsByToolUseIdCache.set(W.id,X)}}else if(W.type==="tool_result"){let j=this.toolNameByIdCache.get(W.tool_use_id);if(!this.isReadTool(j)||W.is_error===!0)continue;let X=this.getReadLocators(W);for(let H of X)if(this.latestReadToolUseByLocatorCache.set(this.toReadLocatorKey(H),W.tool_use_id),this.isFullFileRead(H))this.latestFullContentOwnerByPathCache.set(H.path,W.tool_use_id)}}}this.indexedMessageCount=$.length,this.indexedTailRef=$.length>0?$[$.length-1]:void 0}addMissingToolResults($){let f=this.collectToolResultIds($),J=[],Q=new Map,Z=!1,W=()=>{if(Q.size===0)return;j(this.createMissingToolResultMessage(Q)),Q.clear(),Z=!0},j=(X)=>{let H=J.at(-1);if(this.shouldMergeUserAfterToolResults(H,X)){J[J.length-1]={...H,content:[...H.content,...this.contentBlocksForUserMerge(X.content)]},Z=!0;return}J.push(X)};for(let X of $){if(this.isToolResultOnlyMessage(X)){if(j(this.appendMissingToolResults(X,Q)),Q.size>0)Q.clear(),Z=!0;continue}if(Array.isArray(X.content)){let H=X.content.filter((V)=>V.type==="tool_result"),Y=X.content.filter((V)=>V.type!=="tool_result");if(H.length>0){let V=this.appendMissingToolResults({...X,role:"user",content:H},Q);if(j(V),Q.size>0)Q.clear();Z=!0}if(Y.length>0||H.length===0){if(H.length===0)W();let V=H.length>0?{...X,content:Y}:X;if(j(V),V.role==="assistant")this.trackMissingToolCalls(V,f,Q)}continue}W(),j(X)}return W(),Z?J:$}appendMissingToolResults($,f){if(f.size===0||!Array.isArray($.content))return $;return{...$,role:"user",content:[...$.content,...this.createMissingToolResultBlocks(f)]}}shouldMergeUserAfterToolResults($,f){return $?.role==="user"&&f.role==="user"&&this.isToolResultOnlyMessage($)&&this.contentBlocksForUserMerge(f.content).length>0}contentBlocksForUserMerge($){return typeof $==="string"?$.length>0?[{type:"text",text:$}]:[]:$}collectToolResultIds($){let f=new Set;for(let J of $){if(!Array.isArray(J.content))continue;for(let Q of J.content)if(Q.type==="tool_result")f.add(Q.tool_use_id)}return f}isToolResultOnlyMessage($){return $.role==="user"&&Array.isArray($.content)&&$.content.length>0&&$.content.every((f)=>f.type==="tool_result")}trackMissingToolCalls($,f,J){if(!Array.isArray($.content))return;for(let Q of $.content){if(Q.type!=="tool_use"||f.has(Q.id))continue;J.set(Q.id,Q.name)}}createMissingToolResultMessage($){return{role:"user",content:this.createMissingToolResultBlocks($)}}createMissingToolResultBlocks($){return Array.from($,([f,J])=>({type:"tool_result",tool_use_id:f,name:J,content:[{type:"text",text:this.formatMissingToolResultText(J)}],is_error:!0}))}formatMissingToolResultText($){return $?`${qZ} Tool: ${$}.`:qZ}resetIndexes(){this.indexedMessageCount=0,this.indexedTailRef=void 0,this.toolNameByIdCache.clear(),this.readLocatorsByToolUseIdCache.clear(),this.latestReadToolUseByLocatorCache.clear(),this.latestFullContentOwnerByPathCache.clear(),this.readResultLocatorCache=new WeakMap}getReadLocators($){let f=$,J=this.readResultLocatorCache.get(f);if(J===void 0)J=this.extractReadLocatorsFromToolResultContent($.content),this.readResultLocatorCache.set(f,J);if(J.length>0)return J;return this.readLocatorsByToolUseIdCache.get($.tool_use_id)??[]}extractLocatorsFromReadToolInput($){if(!$||typeof $!=="object")return[];let f=$,J=[],Q=this.extractLocatorFromReadRequest(f);if(Q)J.push(Q);if(Array.isArray(f.files))for(let Z of f.files){let W=this.extractLocatorFromReadRequest(Z);if(W)J.push(W)}if(Array.isArray(f.file_paths)){for(let Z of f.file_paths)if(typeof Z==="string"&&Z.length>0)J.push({path:Z,startLine:null,endLine:null})}return this.dedupeReadLocators(J)}extractReadLocatorsFromToolResultContent($){if(typeof $==="string")return this.tryParseReadLocators($);for(let f of $){if(f.type!=="text")continue;let J=this.tryParseReadLocators(f.text);if(J.length>0)return J}return[]}tryParseReadLocators($){try{return this.extractLocatorsFromParsedReadResult(JSON.parse($))}catch{return[]}}extractLocatorsFromParsedReadResult($){if(Array.isArray($)){let J=[];for(let Q of $){let Z=this.extractLocatorFromResultEntry(Q);if(Z)J.push(Z)}return this.dedupeReadLocators(J)}let f=this.extractLocatorFromResultEntry($);return f?[f]:[]}extractLocatorFromReadRequest($){if(!$||typeof $!=="object")return;let f=$,J=this.extractPath(f);if(!J)return;return{path:J,startLine:this.extractLineNumber(f.start_line),endLine:this.extractLineNumber(f.end_line)}}extractLocatorFromResultEntry($){if(!$||typeof $!=="object")return;let f=$,J=this.extractPath(f);if(J)return{path:J,startLine:this.extractLineNumber(f.start_line),endLine:this.extractLineNumber(f.end_line)};if(typeof f.query==="string"&&f.query.length>0)return this.parseReadQuery(f.query);return}extractPath($){let f=[$.path,$.file_path,$.filePath];for(let J of f)if(typeof J==="string"&&J.length>0)return J;return}extractLineNumber($){return typeof $==="number"&&Number.isInteger($)?$:null}parseReadQuery($){let f=/^(.*):(\d+)-(EOF|\d+)$/.exec($);if(!f)return{path:$,startLine:null,endLine:null};return{path:f[1],startLine:Number(f[2]),endLine:f[3]==="EOF"?null:Number(f[3])}}dedupeReadLocators($){let f=new Map;for(let J of $)f.set(this.toReadLocatorKey(J),J);return Array.from(f.values())}toReadLocatorKey($){if(this.isFullFileRead($))return $.path;return`${$.path}:${$.startLine??1}-${$.endLine??"EOF"}`}isFullFileRead($){return $.startLine==null&&$.endLine==null}isOutdatedReadLocator($,f){let J=this.latestFullContentOwnerByPathCache.get($.path);if(J&&J!==f)return!0;return this.latestReadToolUseByLocatorCache.get(this.toReadLocatorKey($))!==f}replaceOutdatedReadContent($,f){let J=new Set(f.map((W)=>this.toReadLocatorKey(W))),Q=new Set(f.map((W)=>W.path));if(typeof $==="string")return this.replaceOutdatedInString($,J)??W1;let Z=0;for(let W of $)if(W.type==="text")Z+=this.countOutdatedImageEntries(W.text,J);return $.map((W)=>{if(W.type==="file"){if(!Q.has(W.path))return W;return{...W,content:W1}}if(W.type==="image"){if(Z===0)return W;return Z-=1,{type:"text",text:W1}}if(W.type!=="text")return W;let j=this.replaceOutdatedInString(W.text,J);if(j===null)return{...W,text:W1};return j===W.text?W:{...W,text:j}})}countOutdatedImageEntries($,f){let J;try{J=JSON.parse($)}catch{return 0}let Q=Array.isArray(J)?J:[J],Z=0;for(let W of Q){if(!W||typeof W!=="object")continue;let j=W,X=this.extractLocatorFromResultEntry(j);if(!X)continue;if(!f.has(this.toReadLocatorKey(X)))continue;if(j.result==="Successfully read image"||j.content==="Successfully read image")Z+=1}return Z}replaceOutdatedInString($,f){let J;try{J=JSON.parse($)}catch{return null}let Q=Array.isArray(J)?J.map((Z)=>this.replaceOutdatedReadEntry(Z,f)):this.replaceOutdatedReadEntry(J,f);return JSON.stringify(Q)}replaceOutdatedReadEntry($,f){if(!$||typeof $!=="object")return $;let J=this.extractLocatorFromResultEntry($);if(!J||!f.has(this.toReadLocatorKey(J)))return $;let Q={...$};if(typeof Q.result==="string")Q.result=W1;else if(typeof Q.content==="string")Q.content=W1;else Q.result=W1;return Q}isReadTool($){return!!$&&WG.has($)}shouldTruncateTool($){return!!$&&this.targetToolNames.has($)}truncateToolResultContent($){if(typeof $==="string")return this.truncateMiddle($);return $.map((f)=>{if(f.type==="file"){let Q=this.truncateMiddle(f.content);return Q===f.content?f:{...f,content:Q}}if(f.type!=="text")return f;let J=this.truncateMiddle(f.text);return J===f.text?f:{...f,text:J}})}truncateMiddle($){return NJ($,this.maxToolResultChars,jG)}truncateToTotalTextBudget($){if(this.maxTotalTextBytes<=0)return $;let f=this.countMessageTextBytes($);if(f<=this.maxTotalTextBytes)return $;let J=$.map((Z)=>{if(!Array.isArray(Z.content))return Z;return{...Z,content:Z.content.map((W)=>YG(W))}}),Q=this.collectTruncationCandidates(J);for(let Z of Q){if(f<=this.maxTotalTextBytes)break;let W=Z.byteLength;if(W<=MZ)continue;let j=f-this.maxTotalTextBytes,X=Math.max(MZ,W-j),H=HG(Z.get(),X,XG);Z.set(H),f-=W-z0(H)}return J}countMessageTextBytes($){let f=0;for(let J of $){if(typeof J.content==="string"){f+=z0(J.content);continue}for(let Q of J.content)if(Q.type==="text")f+=z0(Q.text);else if(Q.type==="thinking")f+=z0(Q.thinking);else if(Q.type==="file")f+=z0(Q.content);else if(Q.type==="tool_result"){if(typeof Q.content==="string")f+=z0(Q.content);else for(let Z of Q.content)if(Z.type==="text")f+=z0(Z.text);else if(Z.type==="file")f+=z0(Z.content)}}return f}collectTruncationCandidates($){let f=[];for(let J of $){if(!Array.isArray(J.content))continue;for(let Q of J.content){if(Q.type!=="tool_result")continue;let Z=this.toolNameByIdCache.get(Q.tool_use_id);if(!this.shouldTruncateTool(Z))continue;if(typeof Q.content==="string"){f.push({byteLength:z0(Q.content),get:()=>Q.content,set:(W)=>{Q.content=W}});continue}for(let W of Q.content)if(W.type==="text")f.push({byteLength:z0(W.text),get:()=>W.text,set:(j)=>{W.text=j}});else if(W.type==="file")f.push({byteLength:z0(W.content),get:()=>W.content,set:(j)=>{W.content=j}})}}return f.sort((J,Q)=>Q.byteLength-J.byteLength)}}function z0($){return Buffer.byteLength($,"utf8")}function NJ($,f,J){if($.length<=f)return $;let Q=J($.length-f),Z=Math.max(0,Math.floor((f-Q.length)/2)),W=Math.max(0,$.length-Z*2),j=J(W),X=Math.max(0,Math.floor((f-j.length)/2)),H=$.slice(0,X),Y=X>0?$.slice(-X):"";return`${H}${j}${Y}`}function HG($,f,J){if(z0($)<=f)return $;let Q=0,Z=$.length,W=NJ($,0,J);while(Q<=Z){let j=Q+Z>>>1,X=NJ($,j,J);if(z0(X)<=f)W=X,Q=j+1;else Z=j-1}return W}function YG($){if($.type!=="tool_result"||typeof $.content==="string")return{...$};return{...$,content:$.content.map((f)=>({...f}))}}function MJ(){return`conv_${Date.now()}_${Math.random().toString(36).slice(2,9)}`}class qJ{messages=[];conversationId=MJ();sessionStarted=!1;constructor($){if(($?.length??0)>0)this.restore($??[])}getConversationId(){return this.conversationId}getMessages(){return[...this.messages]}appendMessage($){this.messages.push($)}appendMessages($){if($.length===0)return;this.messages.push(...$)}replaceMessages($){this.messages=[...$]}resetForRun(){this.messages=[],this.conversationId=MJ(),this.sessionStarted=!1}clearHistory(){this.messages=[],this.conversationId=MJ(),this.sessionStarted=!1}restore($){this.messages=[...$],this.sessionStarted=!1}isSessionStarted(){return this.sessionStarted}markSessionStarted(){this.sessionStarted=!0}}function VG($){let f=BG($.content),J=[],Q=$.id??FG(),Z=0,W=[],j=()=>{if(W.length===0)return;let X=Z===0?Q:`${Q}_part_${Z}`;Z+=1,J.push({id:X,role:$.role,content:W.map(GG),createdAt:$.ts??Date.now(),metadata:$.metadata,modelInfo:$.modelInfo,metrics:yZ($.metrics)}),W=[]};if(f.length===0)return J.push({id:Q,role:$.role,content:[],createdAt:$.ts??Date.now(),metadata:$.metadata,modelInfo:$.modelInfo,metrics:yZ($.metrics)}),J;for(let X of f){if(X.type!=="tool_result"){W.push(X);continue}j(),J.push({id:`${Q}_tool_${X.tool_use_id}`,role:"tool",content:[hZ(X)],createdAt:$.ts??Date.now(),metadata:$.metadata})}return j(),J}function _4($){return $.flatMap(VG)}function AG($){let f=$.content.map(CZ).filter((J)=>J!==void 0);return{id:$.id,role:$.role==="tool"?"user":$.role,content:f,ts:$.createdAt,metadata:$.metadata,modelInfo:$.modelInfo,metrics:KG($.metrics)}}function v1($){return $.map(AG)}function SZ($){let f=[];for(let J of $){let Q=J.content.map(CZ).filter((j)=>j!==void 0),Z=J.role==="tool"?"user":J.role,W=f[f.length-1];if(Z==="user"&&Q.length>0&&Q.every((j)=>j.type==="tool_result")&&W?.role==="user"&&Array.isArray(W.content)&&W.content.every((j)=>j.type==="tool_result")){W.content.push(...Q);continue}f.push({role:Z,content:Q})}return f}function BG($){if(typeof $==="string")return $.length>0?[{type:"text",text:$}]:[];return[...$]}function GG($){switch($.type){case"text":return{type:"text",text:$.text};case"thinking":return{type:"reasoning",text:$.thinking,metadata:$.signature?{signature:$.signature,details:$.details}:$.details?{details:$.details}:void 0};case"redacted_thinking":return{type:"reasoning",text:"",redacted:!0,metadata:{data:$.data}};case"image":return{type:"image",image:$.data,mediaType:$.mediaType};case"file":return{type:"file",path:$.path,content:$.content};case"tool_use":return{type:"tool-call",toolCallId:$.id,toolName:$.name,input:$.input,metadata:$.signature?{signature:$.signature}:void 0};case"tool_result":return hZ($)}}function hZ($){return{type:"tool-result",toolCallId:$.tool_use_id,toolName:$.name,output:$.content,isError:$.is_error}}function CZ($){switch($.type){case"text":return{type:"text",text:$.text};case"reasoning":{if($.redacted===!0)return{type:"redacted_thinking",data:$.metadata?.data??""};let f=$.metadata;return{type:"thinking",thinking:$.text,signature:f?.signature,details:f?.details}}case"image":return typeof $.image==="string"?{type:"image",data:$.image,mediaType:$.mediaType??"image/png"}:void 0;case"file":return{type:"file",path:$.path,content:$.content};case"tool-call":return{type:"tool_use",id:$.toolCallId,name:$.toolName,input:$.input??{},signature:$.metadata?.signature};case"tool-result":{let f=$.output,J=typeof f==="string"?f:Array.isArray(f)?f:JSON.stringify(f);return{type:"tool_result",tool_use_id:$.toolCallId,name:$.toolName,content:J,is_error:$.isError}}}}function yZ($){if(!$)return;return{inputTokens:$.inputTokens??0,outputTokens:$.outputTokens??0,cacheReadTokens:$.cacheReadTokens??0,cacheWriteTokens:$.cacheWriteTokens??0,cost:$.cost}}function KG($){if(!$)return;return{inputTokens:$.inputTokens,outputTokens:$.outputTokens,cacheReadTokens:$.cacheReadTokens,cacheWriteTokens:$.cacheWriteTokens,cost:$.cost}}var wZ=0;function FG(){return wZ+=1,`msg_${Date.now().toString(36)}_${wZ.toString(36)}`}function EZ($){let{agentConfig:f}=$,J=PG(f),Q=UG(f),Z=$.hooks,W=DG(f.maxParallelToolCalls);return{sessionId:$.sessionId??f.sessionId,agentId:$.agentId,conversationId:$.conversationId,parentAgentId:$.parentAgentId,agentRole:$.agentRole,systemPrompt:$.systemPrompt??f.systemPrompt,messageModelInfo:Q,model:$.model,modelOptions:J,tools:$.tools,hooks:Z,prepareTurn:$.prepareTurn,consumePendingUserMessage:f.consumePendingUserMessage,plugins:$.plugins,logger:$.logger??f.logger,telemetry:$.telemetry??f.telemetry,initialMessages:$.initialMessages,completionPolicy:f.completionPolicy,maxIterations:f.maxIterations,toolExecution:W,toolPolicies:f.toolPolicies,toolContextMetadata:$.toolContextMetadata,requestToolApproval:f.requestToolApproval}}function PG($){let f={};if($.thinking!==void 0)f.thinking=$.thinking;if($.reasoningEffort!==void 0)f.reasoningEffort=$.reasoningEffort;if($.thinkingBudgetTokens!==void 0)f.thinkingBudgetTokens=$.thinkingBudgetTokens;if($.maxTokensPerTurn!==void 0)f.maxTokensPerTurn=$.maxTokensPerTurn;if($.apiTimeoutMs!==void 0)f.apiTimeoutMs=$.apiTimeoutMs;return Object.keys(f).length>0?f:void 0}function UG($){let f=$.providerConfig?.family;return{id:$.modelId,provider:$.providerId,family:f}}function DG($){if($===void 0)return;return $>=2?"parallel":"sequential"}function RG(){return{lastToolName:"",lastToolSignature:"",consecutiveIdenticalCount:0}}function LG($){$.lastToolName="",$.lastToolSignature="",$.consecutiveIdenticalCount=0}function yJ($){if($==null||typeof $!=="object")return $;if(Array.isArray($))return $.map(yJ);let f={};for(let J of Object.keys($).sort())f[J]=yJ($[J]);return f}function OG($){if($==null)return"null";if(typeof $==="string")return $;if(typeof $!=="object")return String($);try{return JSON.stringify(yJ($))}catch{return String($)}}function zG($,f,J,Q){if(f===$.lastToolName&&J===$.lastToolSignature)$.consecutiveIdenticalCount++;else $.consecutiveIdenticalCount=1;return $.lastToolName=f,$.lastToolSignature=J,{softWarning:$.consecutiveIdenticalCount===Q.softThreshold,hardEscalation:$.consecutiveIdenticalCount>=Q.hardThreshold}}var bZ={softThreshold:3,hardThreshold:5};class wJ{config;state=RG();constructor($){this.config={softThreshold:$?.softThreshold??bZ.softThreshold,hardThreshold:$?.hardThreshold??bZ.hardThreshold}}inspect($){let f=OG($.input),J=zG(this.state,$.name,f,this.config);if(J.hardEscalation)return{kind:"hard",message:`Detected ${this.state.consecutiveIdenticalCount} consecutive identical calls to \`${$.name}\`; stopping to avoid a loop.`};if(J.softWarning)return{kind:"soft",message:`Detected ${this.state.consecutiveIdenticalCount} consecutive identical calls to \`${$.name}\`; consider trying a different approach.`};return{kind:"ok"}}reset(){LG(this.state)}}class SJ{consecutiveMistakes=0;options;constructor($){this.options=$}async record($){let f=this.options.maxConsecutiveMistakes,J=$.forceAtLimit&&f?f:this.consecutiveMistakes+1;this.consecutiveMistakes=J;let Q=$.details?.trim()||`consecutive mistake (${$.reason})`;if(this.options.emit({type:"error",error:Error(Q),recoverable:!0,iteration:$.iteration}),this.options.log("warn","Recorded consecutive mistake",{agentId:this.options.agentId,conversationId:this.options.getConversationId(),runId:this.options.getActiveRunId(),iteration:$.iteration,reason:$.reason,details:$.details,consecutiveMistakes:J,maxConsecutiveMistakes:this.options.maxConsecutiveMistakes}),!f||J<f)return{action:"continue"};let Z=await NG({iteration:$.iteration,consecutiveMistakes:J,maxConsecutiveMistakes:f,reason:$.reason,details:$.details},this.options.onLimitReached);if(Z.action==="continue"){let W=Z.guidance?.trim();if(W)this.options.appendRecoveryNotice(W,$.reason);return this.consecutiveMistakes=0,{action:"continue",guidance:W}}return{action:"stop",reason:Z.reason?.trim()||void 0,message:_G({iteration:$.iteration,consecutiveMistakes:J,maxConsecutiveMistakes:f,reason:$.reason,details:$.details,stopReason:Z.reason})}}reset(){this.consecutiveMistakes=0}get value(){return this.consecutiveMistakes}}function _G($){let f=[`Stopped after ${$.consecutiveMistakes}/${$.maxConsecutiveMistakes} consecutive mistakes (${$.reason}) at iteration ${$.iteration}.`],J=$.details?.trim();if(J)f.push(`Error: ${J}`);let Q=$.stopReason?.trim();if(Q)f.push(`Decision: ${Q}`);return f.push("Session state was preserved. Send a new prompt to resume from the latest state."),f.join(" ")}async function NG($,f){if(!f)return{action:"stop",reason:`maximum consecutive mistakes reached (${$.maxConsecutiveMistakes})`};try{return await f($)}catch(J){return{action:"stop",reason:J instanceof Error?J.message:`maximum consecutive mistakes reached (${$.maxConsecutiveMistakes})`}}}function TG($){let f=$.content.filter((J)=>J.type==="text");if(f.length===0)return;return f.map((J)=>J.text).join("")}function MG($){let f=$.content.filter((J)=>J.type==="reasoning");if(f.length===0)return;return{reasoning:f.map((J)=>J.text).join(""),redacted:f.some((J)=>J.redacted===!0)}}function qG($){return $.content.find((f)=>f.type==="tool-result")}function yG($){switch($){case"completed":return"completed";case"aborted":return"aborted";case"failed":return"error"}}function wG($){if(!$||$.isError!==!0)return;if(typeof $.output==="string")return $.output;if($.output instanceof Error)return $.output.message;try{return JSON.stringify($.output)}catch{return String($.output)}}class hJ{lastUsage={inputTokens:0,outputTokens:0,cacheReadTokens:0,cacheWriteTokens:0,totalCost:0};toolStartedAt=new Map;translate($){switch($.type){case"run-started":return[];case"message-added":return[];case"turn-started":return[{type:"iteration_start",iteration:$.iteration}];case"turn-finished":return[{type:"iteration_end",iteration:$.iteration,hadToolCalls:$.toolCallCount>0,toolCallCount:$.toolCallCount}];case"assistant-text-delta":return[{type:"content_start",contentType:"text",text:$.text,accumulated:$.accumulatedText}];case"assistant-reasoning-delta":return[{type:"content_start",contentType:"reasoning",reasoning:$.text,redacted:$.redacted===!0}];case"assistant-message":return this.translateAssistantMessage($.message);case"tool-started":return this.translateToolStarted($);case"tool-updated":return[{type:"content_update",contentType:"tool",toolName:$.toolCall.toolName,toolCallId:$.toolCall.toolCallId,update:$.update}];case"tool-finished":return this.translateToolFinished($);case"usage-updated":return this.translateUsage($.usage);case"status-notice":return[{type:"notice",noticeType:"status",displayRole:"status",message:$.message,reason:$.metadata?.reason==="auto_compaction"?"auto_compaction":void 0,metadata:$.metadata}];case"run-finished":return this.translateRunFinished($.result);case"run-failed":return[{type:"error",error:$.error,recoverable:!1,iteration:$.snapshot.iteration}];default:return $}}reset(){this.lastUsage={inputTokens:0,outputTokens:0,cacheReadTokens:0,cacheWriteTokens:0,totalCost:0},this.toolStartedAt.clear()}translateAssistantMessage($){let f=[],J=TG($);if(J!==void 0)f.push({type:"content_end",contentType:"text",text:J});let Q=MG($);if(Q!==void 0)f.push({type:"content_end",contentType:"reasoning",reasoning:Q.reasoning});return f}translateToolStarted($){return this.toolStartedAt.set($.toolCall.toolCallId,Date.now()),[{type:"content_start",contentType:"tool",toolName:$.toolCall.toolName,toolCallId:$.toolCall.toolCallId,input:$.toolCall.input}]}translateToolFinished($){let f=this.toolStartedAt.get($.toolCall.toolCallId),J=f===void 0?void 0:Date.now()-f;this.toolStartedAt.delete($.toolCall.toolCallId);let Q=qG($.message),Z=Q?.output,W=wG(Q);return[{type:"content_end",contentType:"tool",toolName:$.toolCall.toolName,toolCallId:$.toolCall.toolCallId,output:Z,error:W,durationMs:J}]}translateUsage($){let f=$.inputTokens-this.lastUsage.inputTokens,J=$.outputTokens-this.lastUsage.outputTokens,Q=$.cacheReadTokens-this.lastUsage.cacheReadTokens,Z=$.cacheWriteTokens-this.lastUsage.cacheWriteTokens,W=this.lastUsage.totalCost??0,X=($.totalCost??0)-W;return this.lastUsage={inputTokens:$.inputTokens,outputTokens:$.outputTokens,cacheReadTokens:$.cacheReadTokens,cacheWriteTokens:$.cacheWriteTokens,totalCost:$.totalCost},[{type:"usage",inputTokens:Math.max(0,f),outputTokens:Math.max(0,J),cacheReadTokens:Q===0?void 0:Math.max(0,Q),cacheWriteTokens:Z===0?void 0:Math.max(0,Z),cost:X===0?void 0:X,totalInputTokens:$.inputTokens,totalOutputTokens:$.outputTokens,totalCacheReadTokens:$.cacheReadTokens===0?void 0:$.cacheReadTokens,totalCacheWriteTokens:$.cacheWriteTokens===0?void 0:$.cacheWriteTokens,totalCost:$.totalCost}]}translateRunFinished($){let f={inputTokens:$.usage.inputTokens,outputTokens:$.usage.outputTokens,cacheReadTokens:$.usage.cacheReadTokens===0?void 0:$.usage.cacheReadTokens,cacheWriteTokens:$.usage.cacheWriteTokens===0?void 0:$.usage.cacheWriteTokens,totalCost:$.usage.totalCost};return[{type:"done",reason:yG($.status),text:$.outputText,iterations:$.iterations,usage:f}]}}function xG($){if(typeof $==="string")return $;if($ instanceof Error)return $.message;try{return JSON.stringify($)}catch{return String($)}}async function mG($){let J=(typeof $.content==="function"?await $.content():$.content).trim();return J.length>0?J:void 0}function gG($,f){let J=$.trim(),Q=f.map((Z)=>Z.trim()).filter(Boolean).join(`
|
|
142
|
+
`;class F5{maxToolResultChars;targetToolNames;maxTotalTextBytes;indexedMessageCount=0;indexedTailRef;toolNameByIdCache=new Map;readLocatorsByToolUseIdCache=new Map;latestReadToolUseByLocatorCache=new Map;latestFullContentOwnerByPathCache=new Map;readResultLocatorCache=new WeakMap;constructor($=qP,f=SP,J=wP){this.maxToolResultChars=$;this.targetToolNames=f;this.maxTotalTextBytes=J}buildForApi($){this.reindex($);let J=this.addMissingToolResults($).map((W)=>{if(!Array.isArray(W.content)){if(W.role==="user"&&typeof W.content==="string"){let j=d7(W.content);if(j!==W.content)return{...W,content:j}}return W}let Z=!1,Q=W.content.map((j)=>{let H=this.transformBlock(j,W.role);if(H!==j)Z=!0;return H});return Z?{...W,content:Q}:W});return this.truncateToTotalTextBudget(J)}transformBlock($,f){if(f==="user"&&$.type==="text"&&typeof $.text==="string"){let Z=d7($.text);if(Z!==$.text)return{...$,text:Z};return $}if($.type==="file"){let Z=this.truncateMiddle($.content);return Z===$.content?$:{...$,content:Z}}if($.type!=="tool_result")return $;let J=this.toolNameByIdCache.get($.tool_use_id),W=$.content;if(this.isReadTool(J)&&$.is_error!==!0){let Z=this.getReadLocators($);if(Z.length>0){let Q=Z.filter((j)=>this.isOutdatedReadLocator(j,$.tool_use_id));if(Q.length>0)W=this.replaceOutdatedReadContent(W,Q)}}if(this.shouldTruncateTool(J))W=this.truncateToolResultContent(W);return W===$.content?$:{...$,content:W}}reindex($){let f=this.indexedMessageCount===0||$.length>=this.indexedMessageCount&&$[this.indexedMessageCount-1]===this.indexedTailRef;if($.length<this.indexedMessageCount||!f)this.resetIndexes();for(let J=this.indexedMessageCount;J<$.length;J++){let W=$[J];if(!Array.isArray(W.content))continue;for(let Z=0;Z<W.content.length;Z++){let Q=W.content[Z];if(Q.type==="file")this.latestFullContentOwnerByPathCache.set(Q.path,`file:${J}:${Z}`);else if(Q.type==="tool_use"){let j=Q.name.toLowerCase();if(this.toolNameByIdCache.set(Q.id,j),this.isReadTool(j)){let H=this.extractLocatorsFromReadToolInput(Q.input);if(H.length>0)this.readLocatorsByToolUseIdCache.set(Q.id,H)}}else if(Q.type==="tool_result"){let j=this.toolNameByIdCache.get(Q.tool_use_id);if(!this.isReadTool(j)||Q.is_error===!0)continue;let H=this.getReadLocators(Q);for(let X of H)if(this.latestReadToolUseByLocatorCache.set(this.toReadLocatorKey(X),Q.tool_use_id),this.isFullFileRead(X))this.latestFullContentOwnerByPathCache.set(X.path,Q.tool_use_id)}}}this.indexedMessageCount=$.length,this.indexedTailRef=$.length>0?$[$.length-1]:void 0}addMissingToolResults($){let f=this.collectToolResultIds($),J=[],W=new Map,Z=!1,Q=()=>{if(W.size===0)return;j(this.createMissingToolResultMessage(W)),W.clear(),Z=!0},j=(H)=>{let X=J.at(-1);if(this.shouldMergeUserAfterToolResults(X,H)){J[J.length-1]={...X,content:[...X.content,...this.contentBlocksForUserMerge(H.content)]},Z=!0;return}J.push(H)};for(let H of $){if(this.isToolResultOnlyMessage(H)){if(j(this.appendMissingToolResults(H,W)),W.size>0)W.clear(),Z=!0;continue}if(Array.isArray(H.content)){let X=H.content.filter((A)=>A.type==="tool_result"),Y=H.content.filter((A)=>A.type!=="tool_result");if(X.length>0){let A=this.appendMissingToolResults({...H,role:"user",content:X},W);if(j(A),W.size>0)W.clear();Z=!0}if(Y.length>0||X.length===0){if(X.length===0)Q();let A=X.length>0?{...H,content:Y}:H;if(j(A),A.role==="assistant")this.trackMissingToolCalls(A,f,W)}continue}Q(),j(H)}return Q(),Z?J:$}appendMissingToolResults($,f){if(f.size===0||!Array.isArray($.content))return $;return{...$,role:"user",content:[...$.content,...this.createMissingToolResultBlocks(f)]}}shouldMergeUserAfterToolResults($,f){return $?.role==="user"&&f.role==="user"&&this.isToolResultOnlyMessage($)&&this.contentBlocksForUserMerge(f.content).length>0}contentBlocksForUserMerge($){return typeof $==="string"?$.length>0?[{type:"text",text:$}]:[]:$}collectToolResultIds($){let f=new Set;for(let J of $){if(!Array.isArray(J.content))continue;for(let W of J.content)if(W.type==="tool_result")f.add(W.tool_use_id)}return f}isToolResultOnlyMessage($){return $.role==="user"&&Array.isArray($.content)&&$.content.length>0&&$.content.every((f)=>f.type==="tool_result")}trackMissingToolCalls($,f,J){if(!Array.isArray($.content))return;for(let W of $.content){if(W.type!=="tool_use"||f.has(W.id))continue;J.set(W.id,W.name)}}createMissingToolResultMessage($){return{role:"user",content:this.createMissingToolResultBlocks($)}}createMissingToolResultBlocks($){return Array.from($,([f,J])=>({type:"tool_result",tool_use_id:f,name:J,content:[{type:"text",text:this.formatMissingToolResultText(J)}],is_error:!0}))}formatMissingToolResultText($){return $?`${p7} Tool: ${$}.`:p7}resetIndexes(){this.indexedMessageCount=0,this.indexedTailRef=void 0,this.toolNameByIdCache.clear(),this.readLocatorsByToolUseIdCache.clear(),this.latestReadToolUseByLocatorCache.clear(),this.latestFullContentOwnerByPathCache.clear(),this.readResultLocatorCache=new WeakMap}getReadLocators($){let f=$,J=this.readResultLocatorCache.get(f);if(J===void 0)J=this.extractReadLocatorsFromToolResultContent($.content),this.readResultLocatorCache.set(f,J);if(J.length>0)return J;return this.readLocatorsByToolUseIdCache.get($.tool_use_id)??[]}extractLocatorsFromReadToolInput($){if(!$||typeof $!=="object")return[];let f=$,J=[],W=this.extractLocatorFromReadRequest(f);if(W)J.push(W);if(Array.isArray(f.files))for(let Z of f.files){let Q=this.extractLocatorFromReadRequest(Z);if(Q)J.push(Q)}if(Array.isArray(f.file_paths)){for(let Z of f.file_paths)if(typeof Z==="string"&&Z.length>0)J.push({path:Z,startLine:null,endLine:null})}return this.dedupeReadLocators(J)}extractReadLocatorsFromToolResultContent($){if(typeof $==="string")return this.tryParseReadLocators($);for(let f of $){if(f.type!=="text")continue;let J=this.tryParseReadLocators(f.text);if(J.length>0)return J}return[]}tryParseReadLocators($){try{return this.extractLocatorsFromParsedReadResult(JSON.parse($))}catch{return[]}}extractLocatorsFromParsedReadResult($){if(Array.isArray($)){let J=[];for(let W of $){let Z=this.extractLocatorFromResultEntry(W);if(Z)J.push(Z)}return this.dedupeReadLocators(J)}let f=this.extractLocatorFromResultEntry($);return f?[f]:[]}extractLocatorFromReadRequest($){if(!$||typeof $!=="object")return;let f=$,J=this.extractPath(f);if(!J)return;return{path:J,startLine:this.extractLineNumber(f.start_line),endLine:this.extractLineNumber(f.end_line)}}extractLocatorFromResultEntry($){if(!$||typeof $!=="object")return;let f=$,J=this.extractPath(f);if(J)return{path:J,startLine:this.extractLineNumber(f.start_line),endLine:this.extractLineNumber(f.end_line)};if(typeof f.query==="string"&&f.query.length>0)return this.parseReadQuery(f.query);return}extractPath($){let f=[$.path,$.file_path,$.filePath];for(let J of f)if(typeof J==="string"&&J.length>0)return J;return}extractLineNumber($){return typeof $==="number"&&Number.isInteger($)?$:null}parseReadQuery($){let f=/^(.*):(\d+)-(EOF|\d+)$/.exec($);if(!f)return{path:$,startLine:null,endLine:null};return{path:f[1],startLine:Number(f[2]),endLine:f[3]==="EOF"?null:Number(f[3])}}dedupeReadLocators($){let f=new Map;for(let J of $)f.set(this.toReadLocatorKey(J),J);return Array.from(f.values())}toReadLocatorKey($){if(this.isFullFileRead($))return $.path;return`${$.path}:${$.startLine??1}-${$.endLine??"EOF"}`}isFullFileRead($){return $.startLine==null&&$.endLine==null}isOutdatedReadLocator($,f){let J=this.latestFullContentOwnerByPathCache.get($.path);if(J&&J!==f)return!0;return this.latestReadToolUseByLocatorCache.get(this.toReadLocatorKey($))!==f}replaceOutdatedReadContent($,f){let J=new Set(f.map((Q)=>this.toReadLocatorKey(Q))),W=new Set(f.map((Q)=>Q.path));if(typeof $==="string")return this.replaceOutdatedInString($,J)??K1;let Z=0;for(let Q of $)if(Q.type==="text")Z+=this.countOutdatedImageEntries(Q.text,J);return $.map((Q)=>{if(Q.type==="file"){if(!W.has(Q.path))return Q;return{...Q,content:K1}}if(Q.type==="image"){if(Z===0)return Q;return Z-=1,{type:"text",text:K1}}if(Q.type!=="text")return Q;let j=this.replaceOutdatedInString(Q.text,J);if(j===null)return{...Q,text:K1};return j===Q.text?Q:{...Q,text:j}})}countOutdatedImageEntries($,f){let J;try{J=JSON.parse($)}catch{return 0}let W=Array.isArray(J)?J:[J],Z=0;for(let Q of W){if(!Q||typeof Q!=="object")continue;let j=Q,H=this.extractLocatorFromResultEntry(j);if(!H)continue;if(!f.has(this.toReadLocatorKey(H)))continue;if(j.result==="Successfully read image"||j.content==="Successfully read image")Z+=1}return Z}replaceOutdatedInString($,f){let J;try{J=JSON.parse($)}catch{return null}let W=Array.isArray(J)?J.map((Z)=>this.replaceOutdatedReadEntry(Z,f)):this.replaceOutdatedReadEntry(J,f);return JSON.stringify(W)}replaceOutdatedReadEntry($,f){if(!$||typeof $!=="object")return $;let J=this.extractLocatorFromResultEntry($);if(!J||!f.has(this.toReadLocatorKey(J)))return $;let W={...$};if(typeof W.result==="string")W.result=K1;else if(typeof W.content==="string")W.content=K1;else W.result=K1;return W}isReadTool($){return!!$&&hP.has($)}shouldTruncateTool($){return!!$&&this.targetToolNames.has($)}truncateToolResultContent($){if(typeof $==="string")return this.truncateMiddle($);return $.map((f)=>{if(f.type==="file"){let W=this.truncateMiddle(f.content);return W===f.content?f:{...f,content:W}}if(f.type!=="text")return f;let J=this.truncateMiddle(f.text);return J===f.text?f:{...f,text:J}})}truncateMiddle($){return P5($,this.maxToolResultChars,CP)}truncateToTotalTextBudget($){if(this.maxTotalTextBytes<=0)return $;let f=this.countMessageTextBytes($);if(f<=this.maxTotalTextBytes)return $;let J=$.map((Z)=>{if(!Array.isArray(Z.content))return Z;return{...Z,content:Z.content.map((Q)=>kP(Q))}}),W=this.collectTruncationCandidates(J);for(let Z of W){if(f<=this.maxTotalTextBytes)break;let Q=Z.byteLength;if(Q<=l7)continue;let j=f-this.maxTotalTextBytes,H=Math.max(l7,Q-j),X=bP(Z.get(),H,EP);Z.set(X),f-=Q-O0(X)}return J}countMessageTextBytes($){let f=0;for(let J of $){if(typeof J.content==="string"){f+=O0(J.content);continue}for(let W of J.content)if(W.type==="text")f+=O0(W.text);else if(W.type==="thinking")f+=O0(W.thinking);else if(W.type==="file")f+=O0(W.content);else if(W.type==="tool_result"){if(typeof W.content==="string")f+=O0(W.content);else for(let Z of W.content)if(Z.type==="text")f+=O0(Z.text);else if(Z.type==="file")f+=O0(Z.content)}}return f}collectTruncationCandidates($){let f=[];for(let J of $){if(!Array.isArray(J.content))continue;for(let W of J.content){if(W.type!=="tool_result")continue;let Z=this.toolNameByIdCache.get(W.tool_use_id);if(!this.shouldTruncateTool(Z))continue;if(typeof W.content==="string"){f.push({byteLength:O0(W.content),get:()=>W.content,set:(Q)=>{W.content=Q}});continue}for(let Q of W.content)if(Q.type==="text")f.push({byteLength:O0(Q.text),get:()=>Q.text,set:(j)=>{Q.text=j}});else if(Q.type==="file")f.push({byteLength:O0(Q.content),get:()=>Q.content,set:(j)=>{Q.content=j}})}}return f.sort((J,W)=>W.byteLength-J.byteLength)}}function O0($){return Buffer.byteLength($,"utf8")}function P5($,f,J){if($.length<=f)return $;let W=J($.length-f),Z=Math.max(0,Math.floor((f-W.length)/2)),Q=Math.max(0,$.length-Z*2),j=J(Q),H=Math.max(0,Math.floor((f-j.length)/2)),X=$.slice(0,H),Y=H>0?$.slice(-H):"";return`${X}${j}${Y}`}function bP($,f,J){if(O0($)<=f)return $;let W=0,Z=$.length,Q=P5($,0,J);while(W<=Z){let j=W+Z>>>1,H=P5($,j,J);if(O0(H)<=f)Q=H,W=j+1;else Z=j-1}return Q}function kP($){if($.type!=="tool_result"||typeof $.content==="string")return{...$};return{...$,content:$.content.map((f)=>({...f}))}}function U5(){return`conv_${Date.now()}_${Math.random().toString(36).slice(2,9)}`}class R5{messages=[];conversationId=U5();sessionStarted=!1;constructor($){if(($?.length??0)>0)this.restore($??[])}getConversationId(){return this.conversationId}getMessages(){return[...this.messages]}appendMessage($){this.messages.push($)}appendMessages($){if($.length===0)return;this.messages.push(...$)}replaceMessages($){this.messages=[...$]}resetForRun(){this.messages=[],this.conversationId=U5(),this.sessionStarted=!1}clearHistory(){this.messages=[],this.conversationId=U5(),this.sessionStarted=!1}restore($){this.messages=[...$],this.sessionStarted=!1}isSessionStarted(){return this.sessionStarted}markSessionStarted(){this.sessionStarted=!0}}function r7($){let{agentConfig:f}=$,J=IP(f),W=xP(f),Z=$.hooks,Q=mP(f.maxParallelToolCalls);return{sessionId:$.sessionId??f.sessionId,agentId:$.agentId,conversationId:$.conversationId,parentAgentId:$.parentAgentId,agentRole:$.agentRole,systemPrompt:$.systemPrompt??f.systemPrompt,messageModelInfo:W,model:$.model,modelOptions:J,tools:$.tools,hooks:Z,prepareTurn:$.prepareTurn,consumePendingUserMessage:f.consumePendingUserMessage,plugins:$.plugins,logger:$.logger??f.logger,telemetry:$.telemetry??f.telemetry,initialMessages:$.initialMessages,completionPolicy:f.completionPolicy,maxIterations:f.maxIterations,toolExecution:Q,toolPolicies:f.toolPolicies,toolContextMetadata:$.toolContextMetadata,requestToolApproval:f.requestToolApproval}}function IP($){let f={};if($.thinking!==void 0)f.thinking=$.thinking;if($.reasoningEffort!==void 0)f.reasoningEffort=$.reasoningEffort;if($.thinkingBudgetTokens!==void 0)f.thinkingBudgetTokens=$.thinkingBudgetTokens;if($.maxTokensPerTurn!==void 0)f.maxTokensPerTurn=$.maxTokensPerTurn;if($.apiTimeoutMs!==void 0)f.apiTimeoutMs=$.apiTimeoutMs;return Object.keys(f).length>0?f:void 0}function xP($){let f=$.providerConfig?.family;return{id:$.modelId,provider:$.providerId,family:f}}function mP($){if($===void 0)return;return $>=2?"parallel":"sequential"}function gP(){return{lastToolName:"",lastToolSignature:"",consecutiveIdenticalCount:0}}function vP($){$.lastToolName="",$.lastToolSignature="",$.consecutiveIdenticalCount=0}function D5($){if($==null||typeof $!=="object")return $;if(Array.isArray($))return $.map(D5);let f={};for(let J of Object.keys($).sort())f[J]=D5($[J]);return f}function uP($){if($==null)return"null";if(typeof $==="string")return $;if(typeof $!=="object")return String($);try{return JSON.stringify(D5($))}catch{return String($)}}function cP($,f,J,W){if(f===$.lastToolName&&J===$.lastToolSignature)$.consecutiveIdenticalCount++;else $.consecutiveIdenticalCount=1;return $.lastToolName=f,$.lastToolSignature=J,{softWarning:$.consecutiveIdenticalCount===W.softThreshold,hardEscalation:$.consecutiveIdenticalCount>=W.hardThreshold}}var i7={softThreshold:3,hardThreshold:5};class L5{config;state=gP();constructor($){this.config={softThreshold:$?.softThreshold??i7.softThreshold,hardThreshold:$?.hardThreshold??i7.hardThreshold}}inspect($){let f=uP($.input),J=cP(this.state,$.name,f,this.config);if(J.hardEscalation)return{kind:"hard",message:`Detected ${this.state.consecutiveIdenticalCount} consecutive identical calls to \`${$.name}\`; stopping to avoid a loop.`};if(J.softWarning)return{kind:"soft",message:`Detected ${this.state.consecutiveIdenticalCount} consecutive identical calls to \`${$.name}\`; consider trying a different approach.`};return{kind:"ok"}}reset(){vP(this.state)}}class O5{consecutiveMistakes=0;options;constructor($){this.options=$}async record($){let f=this.options.maxConsecutiveMistakes,J=$.forceAtLimit&&f?f:this.consecutiveMistakes+1;this.consecutiveMistakes=J;let W=$.details?.trim()||`consecutive mistake (${$.reason})`;if(this.options.emit({type:"error",error:Error(W),recoverable:!0,iteration:$.iteration}),this.options.log("warn","Recorded consecutive mistake",{agentId:this.options.agentId,conversationId:this.options.getConversationId(),runId:this.options.getActiveRunId(),iteration:$.iteration,reason:$.reason,details:$.details,consecutiveMistakes:J,maxConsecutiveMistakes:this.options.maxConsecutiveMistakes}),!f||J<f)return{action:"continue"};let Z=await lP({iteration:$.iteration,consecutiveMistakes:J,maxConsecutiveMistakes:f,reason:$.reason,details:$.details},this.options.onLimitReached);if(Z.action==="continue"){let Q=Z.guidance?.trim();if(Q)this.options.appendRecoveryNotice(Q,$.reason);return this.consecutiveMistakes=0,{action:"continue",guidance:Q}}return{action:"stop",reason:Z.reason?.trim()||void 0,message:dP({iteration:$.iteration,consecutiveMistakes:J,maxConsecutiveMistakes:f,reason:$.reason,details:$.details,stopReason:Z.reason})}}reset(){this.consecutiveMistakes=0}get value(){return this.consecutiveMistakes}}function dP($){let f=[`Stopped after ${$.consecutiveMistakes}/${$.maxConsecutiveMistakes} consecutive mistakes (${$.reason}) at iteration ${$.iteration}.`],J=$.details?.trim();if(J)f.push(`Error: ${J}`);let W=$.stopReason?.trim();if(W)f.push(`Decision: ${W}`);return f.push("Session state was preserved. Send a new prompt to resume from the latest state."),f.join(" ")}async function lP($,f){if(!f)return{action:"stop",reason:`maximum consecutive mistakes reached (${$.maxConsecutiveMistakes})`};try{return await f($)}catch(J){return{action:"stop",reason:J instanceof Error?J.message:`maximum consecutive mistakes reached (${$.maxConsecutiveMistakes})`}}}function pP($){let f=$.content.filter((J)=>J.type==="text");if(f.length===0)return;return f.map((J)=>J.text).join("")}function rP($){let f=$.content.filter((J)=>J.type==="reasoning");if(f.length===0)return;return{reasoning:f.map((J)=>J.text).join(""),redacted:f.some((J)=>J.redacted===!0)}}function iP($){return $.content.find((f)=>f.type==="tool-result")}function nP($){switch($){case"completed":return"completed";case"aborted":return"aborted";case"failed":return"error"}}function aP($){if(!$||$.isError!==!0)return;if(typeof $.output==="string")return $.output;if($.output instanceof Error)return $.output.message;try{return JSON.stringify($.output)}catch{return String($.output)}}class _5{lastUsage={inputTokens:0,outputTokens:0,cacheReadTokens:0,cacheWriteTokens:0,totalCost:0};toolStartedAt=new Map;translate($){switch($.type){case"run-started":return[];case"message-added":return[];case"turn-started":return[{type:"iteration_start",iteration:$.iteration}];case"turn-finished":return[{type:"iteration_end",iteration:$.iteration,hadToolCalls:$.toolCallCount>0,toolCallCount:$.toolCallCount}];case"assistant-text-delta":return[{type:"content_start",contentType:"text",text:$.text,accumulated:$.accumulatedText}];case"assistant-reasoning-delta":return[{type:"content_start",contentType:"reasoning",reasoning:$.text,redacted:$.redacted===!0}];case"assistant-message":return this.translateAssistantMessage($.message);case"tool-started":return this.translateToolStarted($);case"tool-updated":return[{type:"content_update",contentType:"tool",toolName:$.toolCall.toolName,toolCallId:$.toolCall.toolCallId,update:$.update}];case"tool-finished":return this.translateToolFinished($);case"usage-updated":return this.translateUsage($.usage);case"status-notice":return[{type:"notice",noticeType:"status",displayRole:"status",message:$.message,reason:$.metadata?.reason==="auto_compaction"?"auto_compaction":void 0,metadata:$.metadata}];case"run-finished":return this.translateRunFinished($.result);case"run-failed":return[{type:"error",error:$.error,recoverable:!1,iteration:$.snapshot.iteration}];default:return $}}reset(){this.lastUsage={inputTokens:0,outputTokens:0,cacheReadTokens:0,cacheWriteTokens:0,totalCost:0},this.toolStartedAt.clear()}translateAssistantMessage($){let f=[],J=pP($);if(J!==void 0)f.push({type:"content_end",contentType:"text",text:J});let W=rP($);if(W!==void 0)f.push({type:"content_end",contentType:"reasoning",reasoning:W.reasoning});return f}translateToolStarted($){return this.toolStartedAt.set($.toolCall.toolCallId,Date.now()),[{type:"content_start",contentType:"tool",toolName:$.toolCall.toolName,toolCallId:$.toolCall.toolCallId,input:$.toolCall.input}]}translateToolFinished($){let f=this.toolStartedAt.get($.toolCall.toolCallId),J=f===void 0?void 0:Date.now()-f;this.toolStartedAt.delete($.toolCall.toolCallId);let W=iP($.message),Z=W?.output,Q=aP(W);return[{type:"content_end",contentType:"tool",toolName:$.toolCall.toolName,toolCallId:$.toolCall.toolCallId,output:Z,error:Q,durationMs:J}]}translateUsage($){let f=$.inputTokens-this.lastUsage.inputTokens,J=$.outputTokens-this.lastUsage.outputTokens,W=$.cacheReadTokens-this.lastUsage.cacheReadTokens,Z=$.cacheWriteTokens-this.lastUsage.cacheWriteTokens,Q=this.lastUsage.totalCost??0,H=($.totalCost??0)-Q;return this.lastUsage={inputTokens:$.inputTokens,outputTokens:$.outputTokens,cacheReadTokens:$.cacheReadTokens,cacheWriteTokens:$.cacheWriteTokens,totalCost:$.totalCost},[{type:"usage",inputTokens:Math.max(0,f),outputTokens:Math.max(0,J),cacheReadTokens:W===0?void 0:Math.max(0,W),cacheWriteTokens:Z===0?void 0:Math.max(0,Z),cost:H===0?void 0:H,totalInputTokens:$.inputTokens,totalOutputTokens:$.outputTokens,totalCacheReadTokens:$.cacheReadTokens===0?void 0:$.cacheReadTokens,totalCacheWriteTokens:$.cacheWriteTokens===0?void 0:$.cacheWriteTokens,totalCost:$.totalCost}]}translateRunFinished($){let f={inputTokens:$.usage.inputTokens,outputTokens:$.usage.outputTokens,cacheReadTokens:$.usage.cacheReadTokens===0?void 0:$.usage.cacheReadTokens,cacheWriteTokens:$.usage.cacheWriteTokens===0?void 0:$.usage.cacheWriteTokens,totalCost:$.usage.totalCost};return[{type:"done",reason:nP($.status),text:$.outputText,iterations:$.iterations,usage:f}]}}function WF($){if(typeof $==="string")return $;if($ instanceof Error)return $.message;try{return JSON.stringify($)}catch{return String($)}}async function ZF($){let J=(typeof $.content==="function"?await $.content():$.content).trim();return J.length>0?J:void 0}function QF($,f){let J=$.trim(),W=f.map((Z)=>Z.trim()).filter(Boolean).join(`
|
|
142
143
|
|
|
143
|
-
`);if(J&&
|
|
144
|
+
`);if(J&&W)return`${J}
|
|
144
145
|
|
|
145
|
-
${Q}`;return J||Q}function vG($){let f=$.filter((J)=>J!==void 0);if(f.length===0)return{};return{beforeRun:async(J)=>{for(let Q of f){let Z=await Q.beforeRun?.(J);if(Z?.stop)return Z}return},afterRun:async(J)=>{for(let Q of f)await Q.afterRun?.(J)},beforeModel:async(J)=>{let Q=J.request,Z;for(let W of f){let j=await W.beforeModel?.({...J,request:Q});if(!j)continue;if(j.stop)return j;Z={...Z,...j,options:{...Z?.options??{},...j.options??{}}},Q={...Q,...j.messages?{messages:j.messages}:{},...j.tools?{tools:j.tools}:{},...j.options?{options:{...Q.options??{},...j.options}}:{}}}return Z},afterModel:async(J)=>{for(let Q of f){let Z=await Q.afterModel?.(J);if(Z?.stop)return Z}return},beforeTool:async(J)=>{let Q=J.input,Z;for(let W of f){let j=await W.beforeTool?.({...J,input:Q});if(!j)continue;if(j.stop||j.skip)return j;if(Z={...Z,...j},Object.hasOwn(j,"input"))Q=j.input}return Z},afterTool:async(J)=>{let Q=J.result,Z;for(let W of f){let j=await W.afterTool?.({...J,result:Q});if(!j)continue;if(j.stop)return j;if(Z={...Z,...j},j.result)Q=j.result}return Z},onEvent:async(J)=>{for(let Q of f)await Q.onEvent?.(J)}}}class T${config;agentId;parentAgentId;logger;telemetry;conversation;mistakeTracker;loopTracker;loopDetectionDisabled;messageBuilder;contributionRegistry;extensionsInitialized=!1;listeners=new Set;createAgentRuntimeImpl;activeRunId=null;running=!1;abortRequested=!1;abortReason;activeRuntime=null;activeRunPromise=null;eventAdapter=new hJ;shutdownCalled=!1;currentRunToolCalls=[];currentRunUsage={inputTokens:0,outputTokens:0};toolStartedAt=new Map;toolInputs=new Map;currentTurnSuccessfulTools=0;currentTurnFailedTools=0;currentTurnFailureDetails=[];activeTrackerWork=Promise.resolve();trackerAbortInFlight=!1;constructor($,f={}){this.config=$,this.agentId=`agent_${Date.now()}_${Math.random().toString(36).slice(2,8)}`,this.parentAgentId=$.parentAgentId,this.logger=f.logger??$.logger,this.telemetry=f.telemetry??$.telemetry,this.createAgentRuntimeImpl=f.createAgentRuntimeImpl??kG,this.conversation=new qJ($.initialMessages),this.messageBuilder=new TJ,this.contributionRegistry=IG({extensions:$.extensions?[...$.extensions]:[],setupContext:{session:$.extensionContext?.session,client:$.extensionContext?.client,user:$.extensionContext?.user,workspaceInfo:$.extensionContext?.workspace,automation:$.extensionContext?.automation,logger:$.extensionContext?.logger??this.logger,telemetry:$.extensionContext?.telemetry??this.telemetry}}),this.contributionRegistry.resolve(),this.contributionRegistry.validate();let J=$.execution?.maxConsecutiveMistakes??6;this.mistakeTracker=new SJ({maxConsecutiveMistakes:J,onLimitReached:$.onConsecutiveMistakeLimitReached,emit:(W)=>this.emitLegacyEvent(W),log:(W,j,X)=>uG(this.logger,W,j,X),agentId:this.agentId,getConversationId:()=>this.conversation.getConversationId(),getActiveRunId:()=>this.activeRunId??"",appendRecoveryNotice:(W,j)=>{this.conversation.appendMessage({role:"user",content:[{type:"text",text:W}]})}});let Q=$.execution?.loopDetection;this.loopDetectionDisabled=Q===!1;let Z=Q===!1||Q===void 0?void 0:Q;this.loopTracker=new wJ(Z)}getAgentId(){return this.agentId}getConversationId(){return this.conversation.getConversationId()}getMessages(){return this.conversation.getMessages()}canStartRun(){return!this.running&&!this.shutdownCalled}getExtensionRegistry(){return this.contributionRegistry.getRegistrySnapshot()}addTools($){if($.length===0)return;let f=new Set(this.config.tools.map((Q)=>Q.name)),J=[...this.config.tools];for(let Q of $)if(!f.has(Q.name))J.push(Q),f.add(Q.name);this.config={...this.config,tools:J}}updateConnection($){let f={...this.config};if($.providerId!==void 0)f.providerId=$.providerId;if($.modelId!==void 0)f.modelId=$.modelId;if($.apiKey!==void 0)f.apiKey=$.apiKey;if($.baseUrl!==void 0)f.baseUrl=$.baseUrl;if($.headers!==void 0)f.headers=$.headers;if($.providerConfig!==void 0)f.providerConfig=$.providerConfig;if($.reasoningEffort!==void 0)f.reasoningEffort=$.reasoningEffort;if($.thinking!==void 0)f.thinking=$.thinking;if($.thinkingBudgetTokens!==void 0)f.thinkingBudgetTokens=$.thinkingBudgetTokens;this.config=f}clearHistory(){this.conversation.clearHistory(),this.resetConversationBoundaryTrackers()}restore($){this.conversation.restore($),this.resetConversationBoundaryTrackers()}resetConversationBoundaryTrackers(){this.mistakeTracker.reset(),this.loopTracker.reset()}subscribeEvents($){return this.listeners.add($),()=>{this.listeners.delete($)}}abort($){let f=typeof $==="string"?$:$ instanceof Error?$.message:$===void 0?void 0:String($);if(this.abortRequested=!0,this.abortReason=f,this.activeRunPromise)this.activeRunPromise.catch(()=>{});this.activeRuntime?.abort(f)}async shutdown($,f){if(this.running){if(!this.abortRequested||!this.activeRunPromise)throw Error(`SessionRuntime.shutdown called while a run is in progress (agentId=${this.agentId})`);await this.activeRunPromise}if(this.shutdownCalled)return;this.shutdownCalled=!0}run($,f,J){return this.conversation.resetForRun(),this.resetConversationBoundaryTrackers(),this.executeRun({userMessage:$,userImages:f,userFiles:J,isContinue:!1})}continue($,f,J){return this.executeRun({userMessage:$,userImages:f,userFiles:J,isContinue:!0})}async composeSystemPrompt(){let $=[];for(let f of this.contributionRegistry.getRegisteredRules()){let J=await mG(f);if(J)$.push(J)}return gG(this.config.systemPrompt,$)}executeRun($){let f;return f=this.executeRunInternal($).finally(()=>{if(this.activeRunPromise===f)this.activeRunPromise=null}),this.activeRunPromise=f,f}async executeRunInternal($){if(this.shutdownCalled)throw Error(`SessionRuntime.run called after shutdown (agentId=${this.agentId})`);if(this.running)throw Error(`SessionRuntime state is "running"; call canStartRun() first (agentId=${this.agentId})`);this.running=!0,this.abortRequested=!1,this.abortReason=void 0,this.activeRunId=`run_${Date.now()}_${Math.random().toString(36).slice(2,8)}`,await this.ensureExtensionsInitialized(),this.eventAdapter.reset(),this.currentRunToolCalls=[],this.currentRunUsage={inputTokens:0,outputTokens:0},this.toolStartedAt.clear(),this.toolInputs.clear(),this.currentTurnSuccessfulTools=0,this.currentTurnFailedTools=0,this.currentTurnFailureDetails=[],this.activeTrackerWork=Promise.resolve(),this.trackerAbortInFlight=!1;let f=new Date,J=$.userMessage;if(J!==void 0){let P=await dG(J,$.userImages,$.userFiles,this.config.userFileContentLoader);this.conversation.appendMessage({role:"user",content:P})}let Q=await this.composeSystemPrompt(),Z=NZ(this.config,this.logger,this.telemetry),W=this.contributionRegistry.getRegisteredTools(),j=new Map;for(let P of W)j.set(P.name,P);for(let P of this.config.tools)j.set(P.name,P);let X=this.conversation.getConversationId(),H=IZ(this.config),Y=Array.from(j.values()),V=_4(this.conversation.getMessages()),A=EZ({agentConfig:this.config,sessionId:this.config.sessionId,agentId:this.agentId,conversationId:X,parentAgentId:this.parentAgentId,model:Z,logger:this.logger,telemetry:this.telemetry,tools:Y,toolContextMetadata:{modelSupportsImages:H?.capabilities?.includes("images")??!0,...this.config.toolContextMetadata},hooks:this.createRuntimeHooks(),prepareTurn:this.createRuntimePrepareTurn(H,Y),initialMessages:V,systemPrompt:Q}),B=this.createAgentRuntimeImpl(A);if(this.activeRuntime=B,this.abortRequested)B.abort(this.abortReason);let G=B.subscribe((P)=>{this.handleRuntimeEvent(P)}),K,D;try{if($.isContinue)K=await B.continue(void 0);else K=await B.run("")}catch(P){D=P instanceof Error?P:Error(String(P))}finally{G();try{await this.activeTrackerWork}catch(P){this.logger?.error?.("SessionRuntime tracker work failed during drain",{agentId:this.agentId,error:P})}this.activeRuntime=null,this.running=!1,this.abortRequested=!1,this.abortReason=void 0}if(K&&K.messages.length>0){let P=v1(K.messages);this.conversation.replaceMessages(P)}let F=new Date;try{return this.buildLegacyResult({runResult:K,thrownError:D,startedAt:f,endedAt:F})}finally{this.activeRunId=null}}async ensureExtensionsInitialized(){if(this.extensionsInitialized)return;try{await this.contributionRegistry.initialize()}catch($){if(this.config.hookErrorMode==="throw")throw $;this.emitLegacyEvent({type:"error",error:$ instanceof Error?$:Error(String($)),recoverable:!0,iteration:0})}this.extensionsInitialized=!0}createRuntimeHooks(){let $=vG([this.config.hooks,...this.contributionRegistry.getValidatedExtensions().map((f)=>f.hooks)]);return{...$,beforeModel:async(f)=>{let J=await $.beforeModel?.(f);if(J?.stop)return J;let Q=J?.messages??f.request.messages,Z=await this.prepareMessagesForModelRequest(Q);return{...J,messages:Z}}}}createRuntimePrepareTurn($,f){let J=this.config.prepareTurn;if(!J)return;return async(Q)=>{let Z=v1(Q.messages),W=await this.prepareProviderMessagesForApi(Z),j=await J({agentId:Q.agentId,conversationId:Q.conversationId??this.conversation.getConversationId(),parentAgentId:Q.parentAgentId??null,iteration:Q.iteration,messages:Z,apiMessages:W,abortSignal:Q.signal??new AbortController().signal,systemPrompt:Q.systemPrompt??"",tools:f,model:{id:this.config.modelId,provider:this.config.providerId,info:$},emitStatusNotice:Q.emitStatusNotice});if(!j)return;return{...j.messages?{messages:_4(j.messages)}:{},...j.systemPrompt!==void 0?{systemPrompt:j.systemPrompt}:{}}}}async prepareMessagesForModelRequest($){let f=await this.prepareProviderMessagesForApi(SZ($));return _4(f)}async prepareProviderMessagesForApi($){let f=$,J=this.contributionRegistry.getRegistrySnapshot().messageBuilder;for(let Q of J)f=await Q.build(f);return this.messageBuilder.buildForApi(f)}handleRuntimeEvent($){switch($.type){case"message-added":case"assistant-message":{this.syncConversationFromRuntimeMessage($.snapshot.messages,[$.message]);break}case"turn-started":{this.currentTurnSuccessfulTools=0,this.currentTurnFailedTools=0,this.currentTurnFailureDetails=[];break}case"tool-started":{this.toolStartedAt.set($.toolCall.toolCallId,new Date),this.toolInputs.set($.toolCall.toolCallId,$.toolCall.input),this.inspectLoopForToolCall($.toolCall.toolName,$.toolCall.input,$.iteration);break}case"tool-finished":{let f=this.toolStartedAt.get($.toolCall.toolCallId),J=new Date,Q=this.toolInputs.get($.toolCall.toolCallId);this.toolStartedAt.delete($.toolCall.toolCallId),this.toolInputs.delete($.toolCall.toolCallId);let Z=$.message.content.find((H)=>H.type==="tool-result"),W=Z?.type==="tool-result"&&Z.isError===!0,j=W?xG(Z?.type==="tool-result"?Z.output:void 0):void 0,X={id:$.toolCall.toolCallId,name:$.toolCall.toolName,input:Q,output:Z?.type==="tool-result"?Z.output:void 0,error:j,durationMs:f===void 0?0:J.getTime()-f.getTime(),startedAt:f??J,endedAt:J};if(this.currentRunToolCalls.push(X),W){if(this.currentTurnFailedTools+=1,j)this.currentTurnFailureDetails.push(`[${$.toolCall.toolName}] ${j}`)}else this.currentTurnSuccessfulTools+=1;break}case"turn-finished":{let f=this.currentTurnFailedTools,J=this.currentTurnSuccessfulTools;if(f>0&&J===0){let Q=this.currentTurnFailureDetails.join("; ");this.enqueueMistakeRecord({iteration:$.iteration,reason:"tool_execution_failed",details:`${f} tool call(s) failed${Q?`: ${Q}`:""}`})}else if(J>0)this.mistakeTracker.reset();break}case"usage-updated":{this.currentRunUsage={inputTokens:$.usage.inputTokens,outputTokens:$.usage.outputTokens,cacheReadTokens:$.usage.cacheReadTokens>0?$.usage.cacheReadTokens:void 0,cacheWriteTokens:$.usage.cacheWriteTokens>0?$.usage.cacheWriteTokens:void 0,totalCost:$.usage.totalCost};break}default:break}for(let f of this.eventAdapter.translate($))this.emitLegacyEvent(f)}syncConversationFromRuntimeMessage($,f){if($.length>0){this.conversation.replaceMessages(v1($));return}if(f.length===0)return;let J=new Set(this.conversation.getMessages().map((Z)=>Z.id).filter((Z)=>typeof Z==="string")),Q=v1(f).filter((Z)=>!Z.id||!J.has(Z.id));if(Q.length===0)return;this.conversation.replaceMessages([...this.conversation.getMessages(),...Q])}emitLegacyEvent($){for(let f of this.listeners)try{f($)}catch(J){this.logger?.error?.("SessionRuntime event listener threw",{agentId:this.agentId,error:J})}}inspectLoopForToolCall($,f,J){if(this.trackerAbortInFlight||this.loopDetectionDisabled)return;let Q=this.loopTracker.inspect({name:$,input:f});if(Q.kind==="ok")return;if(Q.kind==="soft"){if(Q.message)this.conversation.appendMessage({role:"user",content:[{type:"text",text:Q.message}]});return}this.enqueueMistakeRecord({iteration:J,reason:"tool_execution_failed",forceAtLimit:!0,details:Q.message??`Detected repeated tool calls to \`${$}\`; stopping to avoid a loop.`})}enqueueMistakeRecord($){if(this.trackerAbortInFlight)return;this.activeTrackerWork=this.activeTrackerWork.then(async()=>{if(this.trackerAbortInFlight)return;let f=await this.mistakeTracker.record($);if(f.action==="stop")this.trackerAbortInFlight=!0,this.conversation.appendMessage({role:"user",content:[{type:"text",text:f.message}]}),this.activeRuntime?.abort(f.reason??f.message)})}buildLegacyResult($){let{runResult:f,thrownError:J,startedAt:Q,endedAt:Z}=$,W=Z.getTime()-Q.getTime(),j=J?"error":cG(f),X=f?.outputText||(f?.status==="failed"?f.error?.message:void 0)||"",H=f?{inputTokens:f.usage.inputTokens,outputTokens:f.usage.outputTokens,cacheReadTokens:f.usage.cacheReadTokens>0?f.usage.cacheReadTokens:void 0,cacheWriteTokens:f.usage.cacheWriteTokens>0?f.usage.cacheWriteTokens:void 0,totalCost:f.usage.totalCost}:this.currentRunUsage,Y=f?v1(f.messages):this.conversation.getMessages(),V=IZ(this.config);if(J)throw J;return{text:X,usage:H,messages:Y,toolCalls:this.currentRunToolCalls,iterations:f?.iterations??0,finishReason:j,model:{id:this.config.modelId,provider:this.config.providerId,info:V},startedAt:Q,endedAt:Z,durationMs:W}}}function uG($,f,J,Q){if(!$)return;if(f==="debug"){$.debug(J,Q);return}if(f==="error"&&$.error){$.error(J,Q);return}let Z=f==="warn"?"warn":f==="error"?"error":"info";$.log(J,{...Q,severity:Z})}function cG($){if(!$)return"error";switch($.status){case"completed":return"completed";case"aborted":return"aborted";case"failed":return"error"}}async function dG($,f,J,Q){let{buildInitialUserContent:Z}=await Promise.resolve().then(() => kZ);return Z($,f,J,Q)}function IZ($){if($.knownModels?.[$.modelId])return $.knownModels[$.modelId];let f=_J($);if(f?.[$.modelId])return f[$.modelId];return}import{buildClineSystemPrompt as xZ}from"@cline/shared";function mZ($,f){let J=$.trim();if(f.providerId.toLowerCase()!=="cline")return J;return xZ({ide:f.clineIdeName?.trim()||"Terminal",workspaceRoot:f.cwd?.trim()||"/",providerId:f.providerId,rules:`# Team Teammate Role
|
|
146
|
-
${J}`,platform:f.clinePlatform,metadata:f.workspaceMetadata})}function gZ($,f){let J=$.trim();if(f.providerId.toLowerCase()!=="cline")return J;return xZ({ide:f.clineIdeName||"Terminal",workspaceRoot:f.cwd?.trim()||"/",providerId:f.providerId,overridePrompt:J,metadata:f.workspaceMetadata,platform:f.clinePlatform})}function N4($){let f={...$};return{getRuntimeConfig:()=>f,getConnectionConfig:()=>({providerId:f.providerId,modelId:f.modelId,apiKey:f.apiKey,baseUrl:f.baseUrl,headers:f.headers,providerConfig:f.providerConfig,knownModels:f.knownModels,thinking:f.thinking}),updateConnectionDefaults:(J)=>{f={...f,...J}}}}function z2($){let f=$.configProvider.getRuntimeConfig(),J=$.kind==="teammate"?mZ($.prompt,f):gZ($.prompt,f);return{...$.configProvider.getConnectionConfig(),systemPrompt:J,tools:$.tools,maxIterations:$.maxIterations??f.maxIterations,parentAgentId:$.parentAgentId,abortSignal:$.abortSignal,onEvent:$.onEvent,hooks:f.hooks,extensions:f.extensions,hookErrorMode:$.hookErrorMode,toolPolicies:$.toolPolicies,requestToolApproval:$.requestToolApproval,logger:f.logger,role:$.role}}function T4($){let f=z2($),J=new T$(f);if(f.onEvent)J.subscribeEvents(f.onEvent);return J}var rG=CJ.object({systemPrompt:CJ.string().describe("System prompt defining the sub-agent's behavior"),task:CJ.string().describe("Task for the sub-agent to complete")});function u1($){return lG({name:"spawn_agent",description:"Spawn a sub-agent with a custom system prompt for specialized tasks. Use when delegating work that benefits from focused expertise.",inputSchema:pG(rG),execute:async(f,J)=>{let Q=$.createSubAgentTools?await $.createSubAgentTools(f,J):$.subAgentTools??[],Z=T4({kind:"subagent",prompt:f.systemPrompt,configProvider:$.configProvider,tools:Q,maxIterations:$.defaultMaxIterations,parentAgentId:J.agentId,abortSignal:J.signal,onEvent:$.onSubAgentEvent,hookErrorMode:$.hookErrorMode,toolPolicies:$.toolPolicies,requestToolApproval:$.requestToolApproval}),W=Z.getAgentId(),j=Z.getConversationId(),X=J.agentId;if($.onSubAgentStart)try{await $.onSubAgentStart({subAgentId:W,conversationId:j,parentAgentId:X,input:f})}catch{}try{let H=await Z.run(f.task),Y={text:H.text,iterations:H.iterations,finishReason:H.finishReason,usage:{inputTokens:H.usage.inputTokens,outputTokens:H.usage.outputTokens}};if($.onSubAgentEnd)try{await $.onSubAgentEnd({subAgentId:W,conversationId:j,parentAgentId:X,input:f,result:Y,agentResult:H})}catch{}return Y}catch(H){if($.onSubAgentEnd)try{await $.onSubAgentEnd({subAgentId:W,conversationId:j,parentAgentId:X,input:f,error:H instanceof Error?H:Error(String(H))})}catch{}throw H}},timeoutMs:300000,retryable:!1})}import{createTool as Q0,TEAM_AWAIT_TIMEOUT_MS as iG,TEAM_RUN_MESSAGE_PREVIEW_LIMIT as nG,TEAM_RUN_TEXT_PREVIEW_LIMIT as aG,TEAM_TASK_IGNORED_FIELDS_BY_ACTION as tG,TeamAttachOutcomeFragmentInputSchema as vZ,TeamAwaitRunsInputSchema as uZ,TeamBroadcastInputSchema as cZ,TeamBroadcastToolResultSchema as sG,TeamCancelRunInputSchema as dZ,TeamCancelRunToolResultSchema as oG,TeamCleanupInputSchema as lZ,TeamCleanupToolResultSchema as eG,TeamCreateOutcomeInputSchema as pZ,TeamCreateOutcomeToolResultSchema as $K,TeamFinalizeOutcomeInputSchema as rZ,TeamFinalizeOutcomeToolResultSchema as fK,TeamListOutcomesInputSchema as iZ,TeamListRunsInputSchema as nZ,TeamMailboxMessageToolResultSchema as JK,TeamMissionLogInputSchema as aZ,TeamMissionLogToolResultSchema as QK,TeamOutcomeFragmentToolResultSchema as tZ,TeamOutcomeToolResultSchema as ZK,TeamReadMailboxInputSchema as sZ,TeamReviewOutcomeFragmentInputSchema as oZ,TeamRunTaskInputSchema as eZ,TeamRunTaskToolResultSchema as EJ,TeamRunToolSummarySchema as bJ,TeamSendMessageInputSchema as $3,TeamSendMessageToolResultSchema as WK,TeamShutdownTeammateInputSchema as f3,TeamSimpleAgentStatusToolResultSchema as J3,TeamSpawnTeammateInputSchema as Q3,TeamStatusInputSchema as Z3,TeamStatusToolResultSchema as jK,TeamTaskInputSchema as W3,TeamTaskToolResultSchema as _2,validateWithZod as w,zodToJsonSchema as Z0}from"@cline/shared";function j3($,f){let J=$.replace(/\s+/g," ").trim();if(J.length<=f)return J;return`${J.slice(0,Math.max(0,f-3)).trimEnd()}...`}function j1($,f){if($===void 0)throw Error(`Missing required field: ${f}`);return $}function XK($){let f=$.result;if(!f)return;return{textPreview:j3(f.text,aG),iterations:f.iterations,finishReason:f.finishReason,durationMs:f.durationMs,usage:{inputTokens:f.usage.inputTokens,outputTokens:f.usage.outputTokens,cacheReadTokens:f.usage.cacheReadTokens,cacheWriteTokens:f.usage.cacheWriteTokens,totalCost:f.usage.totalCost}}}function M4($){return $?.toISOString()}function kJ($){return{id:$.id,agentId:$.agentId,taskId:$.taskId,status:$.status,messagePreview:j3($.message,nG),priority:$.priority,retryCount:$.retryCount,maxRetries:$.maxRetries,nextAttemptAt:M4($.nextAttemptAt),continueConversation:$.continueConversation,startedAt:$.startedAt.toISOString(),endedAt:M4($.endedAt),leaseOwner:$.leaseOwner,heartbeatAt:M4($.heartbeatAt),lastProgressAt:M4($.lastProgressAt),lastProgressMessage:$.lastProgressMessage,currentActivity:$.currentActivity,error:$.error,resultSummary:XK($)}}function HK($){if($.status==="failed")throw Error(`Run "${$.id}" failed${$.error?`: ${$.error}`:""}`);if($.status==="cancelled")throw Error(`Run "${$.id}" was cancelled${$.error?`: ${$.error}`:""}`);if($.status==="interrupted")throw Error(`Run "${$.id}" was interrupted${$.error?`: ${$.error}`:""}`)}var q4=["team_spawn_teammate","team_shutdown_teammate","team_status","team_task","team_run_task","team_cancel_run","team_list_runs","team_await_runs","team_send_message","team_broadcast","team_read_mailbox","team_mission_log","team_cleanup","team_create_outcome","team_attach_outcome_fragment","team_review_outcome_fragment","team_finalize_outcome","team_list_outcomes"];function X3($){let f=[];if($.createBaseTools)f.push(...$.createBaseTools());f.push(...N2({runtime:$.runtime,requesterId:$.spec.agentId,teammateConfigProvider:$.teammateConfigProvider,createBaseTools:$.createBaseTools,allowSpawn:!1})),$.runtime.spawnTeammate({agentId:$.spec.agentId,config:z2({kind:"teammate",prompt:$.spec.rolePrompt,role:$.spec.rolePrompt,configProvider:$.teammateConfigProvider,tools:f,maxIterations:$.spec.maxIterations,cwd:$.teammateConfigProvider.getRuntimeConfig().cwd})})}function y4($){let f=$.leadAgentId??"lead",J=$.restoredFromPersistence===!0,Q=N2({runtime:$.runtime,requesterId:f,teammateConfigProvider:$.teammateConfigProvider,createBaseTools:$.createBaseTools,allowSpawn:!0,includeSpawnTool:$.includeLeadSpawnTool,includeManagementTools:$.includeLeadManagementTools,onLeadToolsUnlocked:$.onLeadToolsUnlocked}),Z=[];for(let W of $.restoredTeammates??[]){if($.runtime.isTeammateActive(W.agentId))continue;X3({runtime:$.runtime,requesterId:f,teammateConfigProvider:$.teammateConfigProvider,createBaseTools:$.createBaseTools,spec:W}),Z.push(W.agentId)}return{tools:Q,restoredFromPersistence:J,restoredTeammates:Z}}function N2($){let f=$.allowSpawn??!0,J=$.includeSpawnTool??!0,Q=$.includeManagementTools??!0,Z=[];if(J)Z.push(Q0({name:"team_spawn_teammate",description:"Spawn a teammate with a required agentId and rolePrompt.",inputSchema:Z0(Q3),execute:async(j)=>{let X=w(Q3,j);if($.runtime.getMemberRole($.requesterId)!=="lead")throw Error("Only the lead agent can manage teammates.");if(!f)throw Error("Spawning teammates is disabled in this context.");let H={agentId:X.agentId,rolePrompt:X.rolePrompt};if(X3({runtime:$.runtime,requesterId:$.requesterId,teammateConfigProvider:$.teammateConfigProvider,createBaseTools:$.createBaseTools,spec:H}),!Q)$.onLeadToolsUnlocked?.(N2({...$,includeSpawnTool:!1,includeManagementTools:!0,onLeadToolsUnlocked:void 0}));return w(J3,{agentId:X.agentId,status:"spawned"})}}));if(!Q)return Z;Z.push(Q0({name:"team_shutdown_teammate",description:"Shutdown a teammate by agentId.",inputSchema:Z0(f3),execute:async(j)=>{let X=w(f3,j);if($.runtime.getMemberRole($.requesterId)!=="lead")throw Error("Only the lead agent can manage teammates.");return $.runtime.shutdownTeammate(X.agentId,X.reason),w(J3,{agentId:X.agentId,status:"stopped"})}})),Z.push(Q0({name:"team_status",description:"Return a snapshot of team members, task counts, mailbox, and mission log stats.",inputSchema:Z0(Z3),execute:async(j)=>{return w(Z3,j),w(jK,$.runtime.getSnapshot())}})),Z.push(Q0({name:"team_task",description:"Manage shared team tasks with action-specific payloads. create requires title and description, with optional dependsOn and assignee. list accepts optional status, assignee. claim requires taskId. complete requires taskId and summary. block requires taskId and reason. Do not include fields from other actions.",inputSchema:Z0(W3),execute:async(j)=>{let X=w(W3,j);switch(X.action){case"create":{let H=new Set(tG.create??[]),Y=Object.entries(j).filter(([A,B])=>H.has(A)&&B!=null).map(([A])=>A),V=$.runtime.createTask({title:j1(X.title,"title"),description:j1(X.description,"description"),dependsOn:X.dependsOn,assignee:X.assignee,createdBy:$.requesterId});return w(_2,{action:"create",taskId:V.id,status:V.status,...Y.length>0?{ignoredFields:Y,note:`Ignored fields for action=create: ${Y.join(", ")}`}:{}})}case"list":return w(_2,{action:"list",tasks:$.runtime.listTaskItems({status:X.status,assignee:X.assignee})});case"claim":{let H=$.runtime.claimTask(j1(X.taskId,"taskId"),$.requesterId);return w(_2,{action:"claim",taskId:H.id,status:H.status,nextStep:"Task is now in_progress. Execute the work using team_run_task or your own tools, then call team_task with action=complete when done."})}case"complete":{let H=$.runtime.completeTask(j1(X.taskId,"taskId"),$.requesterId,j1(X.summary,"summary"));return w(_2,{action:"complete",taskId:H.id,status:H.status})}case"block":{let H=$.runtime.blockTask(j1(X.taskId,"taskId"),$.requesterId,j1(X.reason,"reason"));return w(_2,{action:"block",taskId:H.id,status:H.status})}}}}));let W=new Map;return Z.push(Q0({name:"team_run_task",description:"Route a delegated task to a teammate. Choose sync (wait) or async (run in background).",inputSchema:Z0(eZ),execute:async(j)=>{let X=w(eZ,j);if(X.runMode==="async"){let V=$.runtime.startTeammateRun(X.agentId,X.task,{taskId:X.taskId||void 0,fromAgentId:$.requesterId,continueConversation:X.continueConversation||void 0});return w(EJ,{agentId:X.agentId,mode:"async",status:"queued",dispatched:!0,message:`Task dispatched to ${X.agentId} and queued as ${V.id}.`,runId:V.id})}let H=W.get(X.agentId);if(H){let V=await H;return w(EJ,{...V,status:"joined",deduped:!0,message:`Task for ${X.agentId} was already dispatched in this tool batch; joined the existing in-flight run.`})}let Y=$.runtime.routeToTeammate(X.agentId,X.task,{taskId:X.taskId||void 0,fromAgentId:$.requesterId,continueConversation:X.continueConversation||void 0}).then((V)=>w(EJ,{agentId:X.agentId,mode:"sync",status:"running",dispatched:!0,message:`Task dispatched to ${X.agentId} and completed in sync mode.`,text:V.text,iterations:V.iterations})).finally(()=>{W.delete(X.agentId)});return W.set(X.agentId,Y),await Y}})),Z.push(Q0({name:"team_cancel_run",description:"Cancel one async teammate run.",inputSchema:Z0(dZ),execute:async(j)=>{let X=w(dZ,j),H=$.runtime.cancelRun(X.runId,X.reason);return w(oG,{runId:H.id,status:H.status})}})),Z.push(Q0({name:"team_list_runs",description:"List teammate runs started with team_run_task in async mode, including live activity/progress fields when available.",inputSchema:Z0(nZ),execute:async(j)=>w(bJ.array(),$.runtime.listRuns(w(nZ,j)).map(kJ))})),Z.push(Q0({name:"team_await_runs",description:"Wait for async teammate runs. Provide runId to wait for one run, or omit it to wait for all active async runs. Uses a long timeout for legitimate teammate work.",inputSchema:Z0(uZ),timeoutMs:iG,execute:async(j)=>{let X=w(uZ,j);if(X.runId){let V=await $.runtime.awaitRun(X.runId);return HK(V),w(bJ,kJ(V))}let H=await $.runtime.awaitAllRuns(),Y=H.filter((V)=>["failed","cancelled","interrupted"].includes(V.status));if(Y.length>0){let V=Y.map((A)=>`${A.id}:${A.status}${A.error?`(${A.error})`:""}`).join(", ");throw Error(`One or more runs did not complete successfully: ${V}`)}return w(bJ.array(),H.map(kJ))}})),Z.push(Q0({name:"team_send_message",description:"Send a mailbox message to a specific teammate.",inputSchema:Z0($3),execute:async(j)=>{let X=w($3,j),H=$.runtime.sendMessage($.requesterId,X.toAgentId,X.subject,X.body,X.taskId??void 0);return w(WK,{id:H.id,toAgentId:H.toAgentId})}})),Z.push(Q0({name:"team_broadcast",description:"Broadcast a message to all teammates.",inputSchema:Z0(cZ),execute:async(j)=>{let X=w(cZ,j),H=$.runtime.broadcast($.requesterId,X.subject,X.body,{taskId:X.taskId??void 0});return w(sG,{delivered:H.length})}})),Z.push(Q0({name:"team_read_mailbox",description:"Read the current agent mailbox.",inputSchema:Z0(sZ),execute:async(j)=>{let X=w(sZ,j);return w(JK.array(),$.runtime.listMailbox($.requesterId,{unreadOnly:X.unreadOnly,markRead:!0}))}})),Z.push(Q0({name:"team_mission_log",description:"Append a mission log update for your team.",inputSchema:Z0(aZ),execute:async(j)=>{let X=w(aZ,j),H=$.runtime.appendMissionLog({agentId:$.requesterId,taskId:X.taskId||void 0,kind:X.kind,summary:X.summary,evidence:X.evidence?.length?X.evidence:void 0,nextAction:X.nextAction||void 0});return w(QK,{id:H.id})}})),Z.push(Q0({name:"team_cleanup",description:"Clean up the team runtime. Fails if teammates are still running.",inputSchema:Z0(lZ),execute:async(j)=>{if(w(lZ,j),$.runtime.getMemberRole($.requesterId)!=="lead")throw Error("Only the lead agent can run cleanup.");return $.runtime.cleanup(),w(eG,{status:"cleaned"})}})),Z.push(Q0({name:"team_create_outcome",description:"Create a converged team outcome.",inputSchema:Z0(pZ),execute:async(j)=>{let X=w(pZ,j),H=$.runtime.createOutcome({title:X.title,requiredSections:X.requiredSections,createdBy:$.requesterId});return w($K,{outcomeId:H.id,status:H.status,requiredSections:H.requiredSections})}})),Z.push(Q0({name:"team_attach_outcome_fragment",description:"Attach a fragment to an outcome section.",inputSchema:Z0(vZ),execute:async(j)=>{let X=w(vZ,j),H=$.runtime.attachOutcomeFragment({outcomeId:X.outcomeId,section:X.section,sourceAgentId:$.requesterId,sourceRunId:X.sourceRunId||void 0,content:X.content});return w(tZ,{fragmentId:H.id,status:H.status})}})),Z.push(Q0({name:"team_review_outcome_fragment",description:"Review one outcome fragment.",inputSchema:Z0(oZ),execute:async(j)=>{let X=w(oZ,j),H=$.runtime.reviewOutcomeFragment({fragmentId:X.fragmentId,reviewedBy:$.requesterId,approved:X.approved});return w(tZ,{fragmentId:H.id,status:H.status})}})),Z.push(Q0({name:"team_finalize_outcome",description:"Finalize one outcome.",inputSchema:Z0(rZ),execute:async(j)=>{let X=w(rZ,j),H=$.runtime.finalizeOutcome(X.outcomeId);return w(fK,{outcomeId:H.id,status:H.status})}})),Z.push(Q0({name:"team_list_outcomes",description:"List team outcomes.",inputSchema:Z0(iZ),execute:async(j)=>{return w(iZ,j),w(ZK.array(),$.runtime.listOutcomes())}})),Z}function H3($){return{...$,tasks:$.tasks.map((f)=>({...f,createdAt:new Date(f.createdAt),updatedAt:new Date(f.updatedAt)})),mailbox:$.mailbox.map((f)=>({...f,sentAt:new Date(f.sentAt),readAt:f.readAt?new Date(f.readAt):void 0})),missionLog:$.missionLog.map((f)=>({...f,ts:new Date(f.ts)})),runs:($.runs??[]).map((f)=>({...f,startedAt:new Date(f.startedAt),endedAt:f.endedAt?new Date(f.endedAt):void 0,nextAttemptAt:f.nextAttemptAt?new Date(f.nextAttemptAt):void 0,heartbeatAt:f.heartbeatAt?new Date(f.heartbeatAt):void 0})),outcomes:($.outcomes??[]).map((f)=>({...f,createdAt:new Date(f.createdAt),finalizedAt:f.finalizedAt?new Date(f.finalizedAt):void 0})),outcomeFragments:($.outcomeFragments??[]).map((f)=>({...f,createdAt:new Date(f.createdAt),reviewedAt:f.reviewedAt?new Date(f.reviewedAt):void 0}))}}var YK=[{id:"read_files",description:"Read the full content of text or image files at the provided absolute paths, or return only an inclusive one-based line range when start_line/end_line are provided.",headlessToolNames:["read_files"]},{id:"search_codebase",description:"Perform regex pattern searches across the codebase for code patterns, definitions, imports, and other text matches.",headlessToolNames:["search_codebase"]},{id:"run_commands",description:"Run shell commands from the root of the workspace for listing files, checking git status, builds, tests, and similar tasks.",headlessToolNames:["run_commands"]},{id:"editor",description:"Make controlled filesystem edits on text files with create, replace, and insert operations.",headlessToolNames:["editor"]},{id:"fetch_web_content",description:"Fetch URL content and analyze it with a prompt describing what to extract.",headlessToolNames:["fetch_web_content"]},{id:"skills",description:"Execute a configured skill within the main conversation when a matching skill exists for the task.",headlessToolNames:["skills"]},{id:"ask_question",description:"Ask the user a single clarifying question with 2-5 selectable options.",headlessToolNames:["ask_question"]},{id:"spawn_agent",description:u1({configProvider:{}}).description,headlessToolNames:["spawn_agent"]},{id:"teams",description:"Enable team collaboration tools for teammate management, task coordination, mailbox messaging, mission logs, and outcomes.",headlessToolNames:[...q4]}],VK={read_files:"enableReadFiles",search_codebase:"enableSearch",run_commands:"enableBash",fetch_web_content:"enableWebFetch",apply_patch:"enableApplyPatch",editor:"enableEditor",skills:"enableSkills",ask_question:"enableAskQuestion"};function AK($){return $==="plan"||$==="yolo"?$:"act"}function V3($){let f=AK($.mode),J=r0[N$({mode:f})],Q=L2($.providerId??"",$.modelId??"",f,R2);return{mode:f,flags:{...J,...Q,...typeof $.enableSpawnAgent==="boolean"?{enableSpawnAgent:$.enableSpawnAgent}:{},...typeof $.enableAgentTeams==="boolean"?{enableAgentTeams:$.enableAgentTeams}:{}}}}function Y3($,f){if(f.disabledToolIds?.has($))return!1;let{flags:J}=V3(f);if($==="spawn_agent")return J.enableSpawnAgent===!0;if($==="teams")return J.enableAgentTeams===!0;if($==="editor")return J.enableEditor===!0||J.enableApplyPatch===!0;let Q=VK[$];return Q?J[Q]===!0:!1}function BK($,f){if($.id==="editor"){let{flags:J}=V3(f),Q=J.enableApplyPatch===!0&&J.enableEditor!==!0;return{...$,defaultEnabled:Y3($.id,f),headlessToolNames:[Q?"apply_patch":"editor"]}}return{...$,defaultEnabled:Y3($.id,f)}}function T2($={}){return YK.map((f)=>BK(f,$))}function A3($={}){return T2($).filter((f)=>f.defaultEnabled).map((f)=>f.id)}function B3($){if(!$.enabled)return new Set;let f=T2($.availabilityContext),J=new Set(f.map((Q)=>Q.id));if(!$.allowlist||$.allowlist.length===0)return new Set(f.filter((Q)=>Q.defaultEnabled).map((Q)=>Q.id));for(let Q of $.allowlist)if(!J.has(Q))throw Error(`Unknown tool "${Q}". Available tools: ${f.map((Z)=>Z.id).join(", ")}`);return new Set($.allowlist)}function IJ($,f={}){return T2(f).filter((J)=>$.has(J.id)).flatMap((J)=>J.headlessToolNames)}function G3($,f={}){return IJ($,f)}function M2($={}){let{executorOptions:f={},executors:J,...Q}=$,Z={...z4(f),...J??{}};return m1({...Q,executors:Z})}function w4($){return $.trim().replace(/^\/+/,"").toLowerCase()}function GK($){if(!$||$.length===0)return;let f=$.map(w4).filter((J)=>J.length>0);return f.length>0?new Set(f):void 0}function KK($,f,J){if(!J)return!0;let Q=w4($),Z=w4(f),W=Q.includes(":")?Q.split(":").at(-1)??Q:Q,j=Z.includes(":")?Z.split(":").at(-1)??Z:Z;return J.has(Q)||J.has(Z)||J.has(W)||J.has(j)}function q2($,f){let J=GK(f);return[...$.getSnapshot("skill").entries()].map(([Z,W])=>{let j=W.item;return{id:Z,name:j.name.trim(),description:j.description?.trim(),disabled:j.disabled===!0,skill:j}}).filter((Z)=>KK(Z.id,Z.name,J))}function FK($,f){return q2($,f).filter((J)=>!J.disabled).map((J)=>J.name.trim()).filter((J)=>J.length>0).sort((J,Q)=>J.localeCompare(Q))}function PK($,f,J){let Q=w4(f);if(!Q)return{error:"Missing skill name."};let Z=q2($,J),W=Z.find((V)=>V.id===Q);if(W){let{skill:V}=W;if(V.disabled===!0)return{error:`Skill "${V.name}" is configured but disabled.`};return{id:W.id,skill:V}}let j=Q.includes(":")?Q.split(":").at(-1)??Q:Q,X=Z.filter(({id:V})=>{if(V===j)return!0;return V.endsWith(`:${j}`)}),H=X.filter(({skill:V})=>V.disabled!==!0);if(H.length===1){let{id:V,skill:A}=H[0];return{id:V,skill:A}}if(H.length>1)return{error:`Skill "${f}" is ambiguous. Use one of: ${H.map(({id:V})=>V).join(", ")}`};if(X.length===1){let{skill:V}=X[0];return{error:`Skill "${V.name}" is configured but disabled.`}}if(X.length>1)return{error:`Skill "${f}" is ambiguous, and all matches are disabled: ${X.map(({id:V})=>V).join(", ")}`};let Y=FK($,J);return{error:Y.length>0?`Skill "${f}" not found. Available skills: ${Y.join(", ")}`:"No skills are currently available."}}function UK($,f=Promise.resolve(),J){let Q=new Set,Z=async(W,j)=>{await f;let X=PK($,W,J);if("error"in X)return X.error;let{id:H,skill:Y}=X;if(Q.has(H))return`Skill "${Y.name}" is already running.`;Q.add(H);try{let V=j?.trim(),A=V?`
|
|
147
|
-
<command-args>${
|
|
146
|
+
${W}`;return J||W}function jF($){let f=$.filter((J)=>J!==void 0);if(f.length===0)return{};return{beforeRun:async(J)=>{for(let W of f){let Z=await W.beforeRun?.(J);if(Z?.stop)return Z}return},afterRun:async(J)=>{for(let W of f)await W.afterRun?.(J)},beforeModel:async(J)=>{let W=J.request,Z;for(let Q of f){let j=await Q.beforeModel?.({...J,request:W});if(!j)continue;if(j.stop)return j;Z={...Z,...j,options:{...Z?.options??{},...j.options??{}}},W={...W,...j.messages?{messages:j.messages}:{},...j.tools?{tools:j.tools}:{},...j.options?{options:{...W.options??{},...j.options}}:{}}}return Z},afterModel:async(J)=>{for(let W of f){let Z=await W.afterModel?.(J);if(Z?.stop)return Z}return},beforeTool:async(J)=>{let W=J.input,Z;for(let Q of f){let j=await Q.beforeTool?.({...J,input:W});if(!j)continue;if(j.stop||j.skip)return j;if(Z={...Z,...j},Object.hasOwn(j,"input"))W=j.input}return Z},afterTool:async(J)=>{let W=J.result,Z;for(let Q of f){let j=await Q.afterTool?.({...J,result:W});if(!j)continue;if(j.stop)return j;if(Z={...Z,...j},j.result)W=j.result}return Z},onEvent:async(J)=>{for(let W of f)await W.onEvent?.(J)}}}class S${config;agentId;parentAgentId;logger;telemetry;conversation;mistakeTracker;loopTracker;loopDetectionDisabled;messageBuilder;contributionRegistry;extensionsInitialized=!1;listeners=new Set;createAgentRuntimeImpl;activeRunId=null;running=!1;abortRequested=!1;abortReason;activeRuntime=null;activeRunPromise=null;eventAdapter=new _5;shutdownCalled=!1;currentRunToolCalls=[];currentRunUsage={inputTokens:0,outputTokens:0};toolStartedAt=new Map;toolInputs=new Map;currentTurnSuccessfulTools=0;currentTurnFailedTools=0;currentTurnFailureDetails=[];activeTrackerWork=Promise.resolve();trackerAbortInFlight=!1;constructor($,f={}){this.config=$,this.agentId=`agent_${Date.now()}_${Math.random().toString(36).slice(2,8)}`,this.parentAgentId=$.parentAgentId,this.logger=f.logger??$.logger,this.telemetry=f.telemetry??$.telemetry,this.createAgentRuntimeImpl=f.createAgentRuntimeImpl??fF,this.conversation=new R5($.initialMessages),this.messageBuilder=new F5,this.contributionRegistry=JF({extensions:$.extensions?[...$.extensions]:[],setupContext:{session:$.extensionContext?.session,client:$.extensionContext?.client,user:$.extensionContext?.user,workspaceInfo:$.extensionContext?.workspace,automation:$.extensionContext?.automation,logger:$.extensionContext?.logger??this.logger,telemetry:$.extensionContext?.telemetry??this.telemetry}}),this.contributionRegistry.resolve(),this.contributionRegistry.validate();let J=$.execution?.maxConsecutiveMistakes??6;this.mistakeTracker=new O5({maxConsecutiveMistakes:J,onLimitReached:$.onConsecutiveMistakeLimitReached,emit:(Q)=>this.emitLegacyEvent(Q),log:(Q,j,H)=>HF(this.logger,Q,j,H),agentId:this.agentId,getConversationId:()=>this.conversation.getConversationId(),getActiveRunId:()=>this.activeRunId??"",appendRecoveryNotice:(Q,j)=>{this.conversation.appendMessage({role:"user",content:[{type:"text",text:Q}]})}});let W=$.execution?.loopDetection;this.loopDetectionDisabled=W===!1;let Z=W===!1||W===void 0?void 0:W;this.loopTracker=new L5(Z)}getAgentId(){return this.agentId}getConversationId(){return this.conversation.getConversationId()}getMessages(){return this.conversation.getMessages()}canStartRun(){return!this.running&&!this.shutdownCalled}getExtensionRegistry(){return this.contributionRegistry.getRegistrySnapshot()}addTools($){if($.length===0)return;let f=new Set(this.config.tools.map((W)=>W.name)),J=[...this.config.tools];for(let W of $)if(!f.has(W.name))J.push(W),f.add(W.name);this.config={...this.config,tools:J}}updateConnection($){let f={...this.config};if($.providerId!==void 0)f.providerId=$.providerId;if($.modelId!==void 0)f.modelId=$.modelId;if($.apiKey!==void 0)f.apiKey=$.apiKey;if($.baseUrl!==void 0)f.baseUrl=$.baseUrl;if($.headers!==void 0)f.headers=$.headers;if($.providerConfig!==void 0)f.providerConfig=$.providerConfig;if($.reasoningEffort!==void 0)f.reasoningEffort=$.reasoningEffort;if($.thinking!==void 0)f.thinking=$.thinking;if($.thinkingBudgetTokens!==void 0)f.thinkingBudgetTokens=$.thinkingBudgetTokens;this.config=f}clearHistory(){this.conversation.clearHistory(),this.resetConversationBoundaryTrackers()}restore($){this.conversation.restore($),this.resetConversationBoundaryTrackers()}resetConversationBoundaryTrackers(){this.mistakeTracker.reset(),this.loopTracker.reset()}subscribeEvents($){return this.listeners.add($),()=>{this.listeners.delete($)}}abort($){let f=typeof $==="string"?$:$ instanceof Error?$.message:$===void 0?void 0:String($);if(this.abortRequested=!0,this.abortReason=f,this.activeRunPromise)this.activeRunPromise.catch(()=>{});this.activeRuntime?.abort(f)}async shutdown($,f){if(this.running){if(!this.abortRequested||!this.activeRunPromise)throw Error(`SessionRuntime.shutdown called while a run is in progress (agentId=${this.agentId})`);await this.activeRunPromise}if(this.shutdownCalled)return;this.shutdownCalled=!0}run($,f,J){return this.conversation.resetForRun(),this.resetConversationBoundaryTrackers(),this.executeRun({userMessage:$,userImages:f,userFiles:J,isContinue:!1})}continue($,f,J){return this.executeRun({userMessage:$,userImages:f,userFiles:J,isContinue:!0})}async composeSystemPrompt(){let $=[];for(let f of this.contributionRegistry.getRegisteredRules()){let J=await ZF(f);if(J)$.push(J)}return QF(this.config.systemPrompt,$)}executeRun($){let f;return f=this.executeRunInternal($).finally(()=>{if(this.activeRunPromise===f)this.activeRunPromise=null}),this.activeRunPromise=f,f}async executeRunInternal($){if(this.shutdownCalled)throw Error(`SessionRuntime.run called after shutdown (agentId=${this.agentId})`);if(this.running)throw Error(`SessionRuntime state is "running"; call canStartRun() first (agentId=${this.agentId})`);this.running=!0,this.abortRequested=!1,this.abortReason=void 0,this.activeRunId=`run_${Date.now()}_${Math.random().toString(36).slice(2,8)}`,await this.ensureExtensionsInitialized(),this.eventAdapter.reset(),this.currentRunToolCalls=[],this.currentRunUsage={inputTokens:0,outputTokens:0},this.toolStartedAt.clear(),this.toolInputs.clear(),this.currentTurnSuccessfulTools=0,this.currentTurnFailedTools=0,this.currentTurnFailureDetails=[],this.activeTrackerWork=Promise.resolve(),this.trackerAbortInFlight=!1;let f=new Date,J=$.userMessage;if(J!==void 0){let F=await YF(J,$.userImages,$.userFiles,this.config.userFileContentLoader);this.conversation.appendMessage({role:"user",content:F})}let W=await this.composeSystemPrompt(),Z=c7(this.config,this.logger,this.telemetry),Q=this.contributionRegistry.getRegisteredTools(),j=new Map;for(let F of Q)j.set(F.name,F);for(let F of this.config.tools)j.set(F.name,F);let H=this.conversation.getConversationId(),X=a7(this.config),Y=Array.from(j.values()),A=fJ(this.conversation.getMessages()),V=r7({agentConfig:this.config,sessionId:this.config.sessionId,agentId:this.agentId,conversationId:H,parentAgentId:this.parentAgentId,model:Z,logger:this.logger,telemetry:this.telemetry,tools:Y,toolContextMetadata:{modelSupportsImages:X?.capabilities?.includes("images")??!0,...this.config.toolContextMetadata,[oQ]:this.telemetry},hooks:this.createRuntimeHooks(),prepareTurn:this.createRuntimePrepareTurn(X,Y),initialMessages:A,systemPrompt:W}),B=this.createAgentRuntimeImpl(V);if(this.activeRuntime=B,this.abortRequested)B.abort(this.abortReason);let K=B.subscribe((F)=>{this.handleRuntimeEvent(F)}),G,R;try{if($.isContinue)G=await B.continue(void 0);else G=await B.run("")}catch(F){R=F instanceof Error?F:Error(String(F))}finally{K();try{await this.activeTrackerWork}catch(F){this.logger?.error?.("SessionRuntime tracker work failed during drain",{agentId:this.agentId,error:F})}this.activeRuntime=null,this.running=!1,this.abortRequested=!1,this.abortReason=void 0}if(G&&G.messages.length>0){let F=ff(G.messages);this.conversation.replaceMessages(F)}let P=new Date;try{return this.buildLegacyResult({runResult:G,thrownError:R,startedAt:f,endedAt:P})}finally{this.activeRunId=null}}async ensureExtensionsInitialized(){if(this.extensionsInitialized)return;try{await this.contributionRegistry.initialize()}catch($){if(this.config.hookErrorMode==="throw")throw $;this.emitLegacyEvent({type:"error",error:$ instanceof Error?$:Error(String($)),recoverable:!0,iteration:0})}this.extensionsInitialized=!0}createRuntimeHooks(){let $=jF([this.config.hooks,...this.contributionRegistry.getValidatedExtensions().map((f)=>f.hooks)]);return{...$,beforeModel:async(f)=>{let J=await $.beforeModel?.(f);if(J?.stop)return J;let W=J?.messages??f.request.messages,Z=await this.prepareMessagesForModelRequest(W);return{...J,messages:Z}}}}createRuntimePrepareTurn($,f){let J=this.config.prepareTurn;if(!J)return;return async(W)=>{let Z=ff(W.messages),Q=await this.prepareProviderMessagesForApi(Z),j=await J({agentId:W.agentId,conversationId:W.conversationId??this.conversation.getConversationId(),parentAgentId:W.parentAgentId??null,iteration:W.iteration,messages:Z,apiMessages:Q,abortSignal:W.signal??new AbortController().signal,systemPrompt:W.systemPrompt??"",tools:f,model:{id:this.config.modelId,provider:this.config.providerId,info:$},emitStatusNotice:W.emitStatusNotice});if(!j)return;return{...j.messages?{messages:fJ(j.messages)}:{},...j.systemPrompt!==void 0?{systemPrompt:j.systemPrompt}:{}}}}async prepareMessagesForModelRequest($){let f=await this.prepareProviderMessagesForApi(JJ($));return fJ(f)}async prepareProviderMessagesForApi($){let f=$,J=this.contributionRegistry.getRegistrySnapshot().messageBuilder;for(let W of J)f=await W.build(f);return this.messageBuilder.buildForApi(f)}handleRuntimeEvent($){switch($.type){case"message-added":case"assistant-message":{this.syncConversationFromRuntimeMessage($.snapshot.messages,[$.message]);break}case"turn-started":{this.currentTurnSuccessfulTools=0,this.currentTurnFailedTools=0,this.currentTurnFailureDetails=[];break}case"tool-started":{this.toolStartedAt.set($.toolCall.toolCallId,new Date),this.toolInputs.set($.toolCall.toolCallId,$.toolCall.input),this.inspectLoopForToolCall($.toolCall.toolName,$.toolCall.input,$.iteration);break}case"tool-finished":{let f=this.toolStartedAt.get($.toolCall.toolCallId),J=new Date,W=this.toolInputs.get($.toolCall.toolCallId);this.toolStartedAt.delete($.toolCall.toolCallId),this.toolInputs.delete($.toolCall.toolCallId);let Z=$.message.content.find((X)=>X.type==="tool-result"),Q=Z?.type==="tool-result"&&Z.isError===!0,j=Q?WF(Z?.type==="tool-result"?Z.output:void 0):void 0,H={id:$.toolCall.toolCallId,name:$.toolCall.toolName,input:W,output:Z?.type==="tool-result"?Z.output:void 0,error:j,durationMs:f===void 0?0:J.getTime()-f.getTime(),startedAt:f??J,endedAt:J};if(this.currentRunToolCalls.push(H),Q){if(this.currentTurnFailedTools+=1,j)this.currentTurnFailureDetails.push(`[${$.toolCall.toolName}] ${j}`)}else this.currentTurnSuccessfulTools+=1;break}case"turn-finished":{let f=this.currentTurnFailedTools,J=this.currentTurnSuccessfulTools;if(f>0&&J===0){let W=this.currentTurnFailureDetails.join("; ");this.enqueueMistakeRecord({iteration:$.iteration,reason:"tool_execution_failed",details:`${f} tool call(s) failed${W?`: ${W}`:""}`})}else if(J>0)this.mistakeTracker.reset();break}case"usage-updated":{this.currentRunUsage={inputTokens:$.usage.inputTokens,outputTokens:$.usage.outputTokens,cacheReadTokens:$.usage.cacheReadTokens>0?$.usage.cacheReadTokens:void 0,cacheWriteTokens:$.usage.cacheWriteTokens>0?$.usage.cacheWriteTokens:void 0,totalCost:$.usage.totalCost};break}default:break}for(let f of this.eventAdapter.translate($))this.emitLegacyEvent(f)}syncConversationFromRuntimeMessage($,f){if($.length>0){this.conversation.replaceMessages(ff($));return}if(f.length===0)return;let J=new Set(this.conversation.getMessages().map((Z)=>Z.id).filter((Z)=>typeof Z==="string")),W=ff(f).filter((Z)=>!Z.id||!J.has(Z.id));if(W.length===0)return;this.conversation.replaceMessages([...this.conversation.getMessages(),...W])}emitLegacyEvent($){for(let f of this.listeners)try{f($)}catch(J){this.logger?.error?.("SessionRuntime event listener threw",{agentId:this.agentId,error:J})}}inspectLoopForToolCall($,f,J){if(this.trackerAbortInFlight||this.loopDetectionDisabled)return;let W=this.loopTracker.inspect({name:$,input:f});if(W.kind==="ok")return;if(W.kind==="soft"){if(W.message)this.conversation.appendMessage({role:"user",content:[{type:"text",text:W.message}]});return}this.enqueueMistakeRecord({iteration:J,reason:"tool_execution_failed",forceAtLimit:!0,details:W.message??`Detected repeated tool calls to \`${$}\`; stopping to avoid a loop.`})}enqueueMistakeRecord($){if(this.trackerAbortInFlight)return;this.activeTrackerWork=this.activeTrackerWork.then(async()=>{if(this.trackerAbortInFlight)return;let f=await this.mistakeTracker.record($);if(f.action==="stop")this.trackerAbortInFlight=!0,this.conversation.appendMessage({role:"user",content:[{type:"text",text:f.message}]}),this.activeRuntime?.abort(f.reason??f.message)})}buildLegacyResult($){let{runResult:f,thrownError:J,startedAt:W,endedAt:Z}=$,Q=Z.getTime()-W.getTime(),j=J?"error":XF(f),H=f?.outputText||(f?.status==="failed"?f.error?.message:void 0)||"",X=f?{inputTokens:f.usage.inputTokens,outputTokens:f.usage.outputTokens,cacheReadTokens:f.usage.cacheReadTokens>0?f.usage.cacheReadTokens:void 0,cacheWriteTokens:f.usage.cacheWriteTokens>0?f.usage.cacheWriteTokens:void 0,totalCost:f.usage.totalCost}:this.currentRunUsage,Y=f?ff(f.messages):this.conversation.getMessages(),A=a7(this.config);if(J)throw J;return{text:H,usage:X,messages:Y,toolCalls:this.currentRunToolCalls,iterations:f?.iterations??0,finishReason:j,model:{id:this.config.modelId,provider:this.config.providerId,info:A},startedAt:W,endedAt:Z,durationMs:Q}}}function HF($,f,J,W){if(!$)return;if(f==="debug"){$.debug(J,W);return}if(f==="error"&&$.error){$.error(J,W);return}let Z=f==="warn"?"warn":f==="error"?"error":"info";$.log(J,{...W,severity:Z})}function XF($){if(!$)return"error";switch($.status){case"completed":return"completed";case"aborted":return"aborted";case"failed":return"error"}}async function YF($,f,J,W){let{buildInitialUserContent:Z}=await Promise.resolve().then(() => n7);return Z($,f,J,W)}function a7($){if($.knownModels?.[$.modelId])return $.knownModels[$.modelId];let f=G5($);if(f?.[$.modelId])return f[$.modelId];return}import{buildClineSystemPrompt as t7}from"@cline/shared";function s7($,f){let J=$.trim();if(f.providerId.toLowerCase()!=="cline")return J;return t7({ide:f.clineIdeName?.trim()||"Terminal",workspaceRoot:f.cwd?.trim()||"/",providerId:f.providerId,rules:`# Team Teammate Role
|
|
147
|
+
${J}`,platform:f.clinePlatform,metadata:f.workspaceMetadata})}function o7($,f){let J=$.trim();if(f.providerId.toLowerCase()!=="cline")return J;return t7({ide:f.clineIdeName||"Terminal",workspaceRoot:f.cwd?.trim()||"/",providerId:f.providerId,overridePrompt:J,metadata:f.workspaceMetadata,platform:f.clinePlatform})}function WJ($){let f={...$};return{getRuntimeConfig:()=>f,getConnectionConfig:()=>({providerId:f.providerId,modelId:f.modelId,apiKey:f.apiKey,baseUrl:f.baseUrl,headers:f.headers,providerConfig:f.providerConfig,knownModels:f.knownModels,thinking:f.thinking}),updateConnectionDefaults:(J)=>{f={...f,...J}}}}function df($){let f=$.configProvider.getRuntimeConfig(),J=$.kind==="teammate"?s7($.prompt,f):o7($.prompt,f);return{...$.configProvider.getConnectionConfig(),systemPrompt:J,tools:$.tools,maxIterations:$.maxIterations??f.maxIterations,parentAgentId:$.parentAgentId,abortSignal:$.abortSignal,onEvent:$.onEvent,hooks:f.hooks,extensions:f.extensions,hookErrorMode:$.hookErrorMode,toolPolicies:$.toolPolicies,requestToolApproval:$.requestToolApproval,logger:f.logger,role:$.role}}function ZJ($){let f=df($),J=new S$(f);if(f.onEvent)J.subscribeEvents(f.onEvent);return J}var BF=z5.object({systemPrompt:z5.string().describe("System prompt defining the sub-agent's behavior"),task:z5.string().describe("Task for the sub-agent to complete")});function Jf($){return AF({name:"spawn_agent",description:"Spawn a sub-agent with a custom system prompt for specialized tasks. Use when delegating work that benefits from focused expertise.",inputSchema:VF(BF),execute:async(f,J)=>{let W=$.createSubAgentTools?await $.createSubAgentTools(f,J):$.subAgentTools??[],Z=ZJ({kind:"subagent",prompt:f.systemPrompt,configProvider:$.configProvider,tools:W,maxIterations:$.defaultMaxIterations,parentAgentId:J.agentId,abortSignal:J.signal,onEvent:$.onSubAgentEvent,hookErrorMode:$.hookErrorMode,toolPolicies:$.toolPolicies,requestToolApproval:$.requestToolApproval}),Q=Z.getAgentId(),j=Z.getConversationId(),H=J.agentId;if($.onSubAgentStart)try{await $.onSubAgentStart({subAgentId:Q,conversationId:j,parentAgentId:H,input:f})}catch{}try{let X=await Z.run(f.task),Y={text:X.text,iterations:X.iterations,finishReason:X.finishReason,usage:{inputTokens:X.usage.inputTokens,outputTokens:X.usage.outputTokens}};if($.onSubAgentEnd)try{await $.onSubAgentEnd({subAgentId:Q,conversationId:j,parentAgentId:H,input:f,result:Y,agentResult:X})}catch{}return Y}catch(X){if($.onSubAgentEnd)try{await $.onSubAgentEnd({subAgentId:Q,conversationId:j,parentAgentId:H,input:f,error:X instanceof Error?X:Error(String(X))})}catch{}throw X}},timeoutMs:300000,retryable:!1})}import{createTool as J0,TEAM_AWAIT_TIMEOUT_MS as KF,TEAM_RUN_MESSAGE_PREVIEW_LIMIT as GF,TEAM_RUN_TEXT_PREVIEW_LIMIT as PF,TEAM_TASK_IGNORED_FIELDS_BY_ACTION as FF,TeamAttachOutcomeFragmentInputSchema as e7,TeamAwaitRunsInputSchema as $3,TeamBroadcastInputSchema as f3,TeamBroadcastToolResultSchema as UF,TeamCancelRunInputSchema as J3,TeamCancelRunToolResultSchema as RF,TeamCleanupInputSchema as W3,TeamCleanupToolResultSchema as DF,TeamCreateOutcomeInputSchema as Z3,TeamCreateOutcomeToolResultSchema as LF,TeamFinalizeOutcomeInputSchema as Q3,TeamFinalizeOutcomeToolResultSchema as OF,TeamListOutcomesInputSchema as j3,TeamListRunsInputSchema as H3,TeamMailboxMessageToolResultSchema as _F,TeamMissionLogInputSchema as X3,TeamMissionLogToolResultSchema as zF,TeamOutcomeFragmentToolResultSchema as Y3,TeamOutcomeToolResultSchema as TF,TeamReadMailboxInputSchema as A3,TeamReviewOutcomeFragmentInputSchema as V3,TeamRunTaskInputSchema as B3,TeamRunTaskToolResultSchema as T5,TeamRunToolSummarySchema as N5,TeamSendMessageInputSchema as K3,TeamSendMessageToolResultSchema as NF,TeamShutdownTeammateInputSchema as G3,TeamSimpleAgentStatusToolResultSchema as P3,TeamSpawnTeammateInputSchema as F3,TeamStatusInputSchema as U3,TeamStatusToolResultSchema as MF,TeamTaskInputSchema as R3,TeamTaskToolResultSchema as lf,validateWithZod as S,zodToJsonSchema as W0}from"@cline/shared";function D3($,f){let J=$.replace(/\s+/g," ").trim();if(J.length<=f)return J;return`${J.slice(0,Math.max(0,f-3)).trimEnd()}...`}function G1($,f){if($===void 0)throw Error(`Missing required field: ${f}`);return $}function yF($){let f=$.result;if(!f)return;return{textPreview:D3(f.text,PF),iterations:f.iterations,finishReason:f.finishReason,durationMs:f.durationMs,usage:{inputTokens:f.usage.inputTokens,outputTokens:f.usage.outputTokens,cacheReadTokens:f.usage.cacheReadTokens,cacheWriteTokens:f.usage.cacheWriteTokens,totalCost:f.usage.totalCost}}}function QJ($){return $?.toISOString()}function M5($){return{id:$.id,agentId:$.agentId,taskId:$.taskId,status:$.status,messagePreview:D3($.message,GF),priority:$.priority,retryCount:$.retryCount,maxRetries:$.maxRetries,nextAttemptAt:QJ($.nextAttemptAt),continueConversation:$.continueConversation,startedAt:$.startedAt.toISOString(),endedAt:QJ($.endedAt),leaseOwner:$.leaseOwner,heartbeatAt:QJ($.heartbeatAt),lastProgressAt:QJ($.lastProgressAt),lastProgressMessage:$.lastProgressMessage,currentActivity:$.currentActivity,error:$.error,resultSummary:yF($)}}function qF($){if($.status==="failed")throw Error(`Run "${$.id}" failed${$.error?`: ${$.error}`:""}`);if($.status==="cancelled")throw Error(`Run "${$.id}" was cancelled${$.error?`: ${$.error}`:""}`);if($.status==="interrupted")throw Error(`Run "${$.id}" was interrupted${$.error?`: ${$.error}`:""}`)}var jJ=["team_spawn_teammate","team_shutdown_teammate","team_status","team_task","team_run_task","team_cancel_run","team_list_runs","team_await_runs","team_send_message","team_broadcast","team_read_mailbox","team_mission_log","team_cleanup","team_create_outcome","team_attach_outcome_fragment","team_review_outcome_fragment","team_finalize_outcome","team_list_outcomes"];function L3($){let f=[];if($.createBaseTools)f.push(...$.createBaseTools());f.push(...pf({runtime:$.runtime,requesterId:$.spec.agentId,teammateConfigProvider:$.teammateConfigProvider,createBaseTools:$.createBaseTools,allowSpawn:!1})),$.runtime.spawnTeammate({agentId:$.spec.agentId,config:df({kind:"teammate",prompt:$.spec.rolePrompt,role:$.spec.rolePrompt,configProvider:$.teammateConfigProvider,tools:f,maxIterations:$.spec.maxIterations,cwd:$.teammateConfigProvider.getRuntimeConfig().cwd})})}function HJ($){let f=$.leadAgentId??"lead",J=$.restoredFromPersistence===!0,W=pf({runtime:$.runtime,requesterId:f,teammateConfigProvider:$.teammateConfigProvider,createBaseTools:$.createBaseTools,allowSpawn:!0,includeSpawnTool:$.includeLeadSpawnTool,includeManagementTools:$.includeLeadManagementTools,onLeadToolsUnlocked:$.onLeadToolsUnlocked}),Z=[];for(let Q of $.restoredTeammates??[]){if($.runtime.isTeammateActive(Q.agentId))continue;L3({runtime:$.runtime,requesterId:f,teammateConfigProvider:$.teammateConfigProvider,createBaseTools:$.createBaseTools,spec:Q}),Z.push(Q.agentId)}return{tools:W,restoredFromPersistence:J,restoredTeammates:Z}}function pf($){let f=$.allowSpawn??!0,J=$.includeSpawnTool??!0,W=$.includeManagementTools??!0,Z=[];if(J)Z.push(J0({name:"team_spawn_teammate",description:"Spawn a teammate with a required agentId and rolePrompt.",inputSchema:W0(F3),execute:async(j)=>{let H=S(F3,j);if($.runtime.getMemberRole($.requesterId)!=="lead")throw Error("Only the lead agent can manage teammates.");if(!f)throw Error("Spawning teammates is disabled in this context.");let X={agentId:H.agentId,rolePrompt:H.rolePrompt};if(L3({runtime:$.runtime,requesterId:$.requesterId,teammateConfigProvider:$.teammateConfigProvider,createBaseTools:$.createBaseTools,spec:X}),!W)$.onLeadToolsUnlocked?.(pf({...$,includeSpawnTool:!1,includeManagementTools:!0,onLeadToolsUnlocked:void 0}));return S(P3,{agentId:H.agentId,status:"spawned"})}}));if(!W)return Z;Z.push(J0({name:"team_shutdown_teammate",description:"Shutdown a teammate by agentId.",inputSchema:W0(G3),execute:async(j)=>{let H=S(G3,j);if($.runtime.getMemberRole($.requesterId)!=="lead")throw Error("Only the lead agent can manage teammates.");return $.runtime.shutdownTeammate(H.agentId,H.reason),S(P3,{agentId:H.agentId,status:"stopped"})}})),Z.push(J0({name:"team_status",description:"Return a snapshot of team members, task counts, mailbox, and mission log stats.",inputSchema:W0(U3),execute:async(j)=>{return S(U3,j),S(MF,$.runtime.getSnapshot())}})),Z.push(J0({name:"team_task",description:"Manage shared team tasks with action-specific payloads. create requires title and description, with optional dependsOn and assignee. list accepts optional status, assignee. claim requires taskId. complete requires taskId and summary. block requires taskId and reason. Do not include fields from other actions.",inputSchema:W0(R3),execute:async(j)=>{let H=S(R3,j);switch(H.action){case"create":{let X=new Set(FF.create??[]),Y=Object.entries(j).filter(([V,B])=>X.has(V)&&B!=null).map(([V])=>V),A=$.runtime.createTask({title:G1(H.title,"title"),description:G1(H.description,"description"),dependsOn:H.dependsOn,assignee:H.assignee,createdBy:$.requesterId});return S(lf,{action:"create",taskId:A.id,status:A.status,...Y.length>0?{ignoredFields:Y,note:`Ignored fields for action=create: ${Y.join(", ")}`}:{}})}case"list":return S(lf,{action:"list",tasks:$.runtime.listTaskItems({status:H.status,assignee:H.assignee})});case"claim":{let X=$.runtime.claimTask(G1(H.taskId,"taskId"),$.requesterId);return S(lf,{action:"claim",taskId:X.id,status:X.status,nextStep:"Task is now in_progress. Execute the work using team_run_task or your own tools, then call team_task with action=complete when done."})}case"complete":{let X=$.runtime.completeTask(G1(H.taskId,"taskId"),$.requesterId,G1(H.summary,"summary"));return S(lf,{action:"complete",taskId:X.id,status:X.status})}case"block":{let X=$.runtime.blockTask(G1(H.taskId,"taskId"),$.requesterId,G1(H.reason,"reason"));return S(lf,{action:"block",taskId:X.id,status:X.status})}}}}));let Q=new Map;return Z.push(J0({name:"team_run_task",description:"Route a delegated task to a teammate. Choose sync (wait) or async (run in background).",inputSchema:W0(B3),execute:async(j)=>{let H=S(B3,j);if(H.runMode==="async"){let A=$.runtime.startTeammateRun(H.agentId,H.task,{taskId:H.taskId||void 0,fromAgentId:$.requesterId,continueConversation:H.continueConversation||void 0});return S(T5,{agentId:H.agentId,mode:"async",status:"queued",dispatched:!0,message:`Task dispatched to ${H.agentId} and queued as ${A.id}.`,runId:A.id})}let X=Q.get(H.agentId);if(X){let A=await X;return S(T5,{...A,status:"joined",deduped:!0,message:`Task for ${H.agentId} was already dispatched in this tool batch; joined the existing in-flight run.`})}let Y=$.runtime.routeToTeammate(H.agentId,H.task,{taskId:H.taskId||void 0,fromAgentId:$.requesterId,continueConversation:H.continueConversation||void 0}).then((A)=>S(T5,{agentId:H.agentId,mode:"sync",status:"running",dispatched:!0,message:`Task dispatched to ${H.agentId} and completed in sync mode.`,text:A.text,iterations:A.iterations})).finally(()=>{Q.delete(H.agentId)});return Q.set(H.agentId,Y),await Y}})),Z.push(J0({name:"team_cancel_run",description:"Cancel one async teammate run.",inputSchema:W0(J3),execute:async(j)=>{let H=S(J3,j),X=$.runtime.cancelRun(H.runId,H.reason);return S(RF,{runId:X.id,status:X.status})}})),Z.push(J0({name:"team_list_runs",description:"List teammate runs started with team_run_task in async mode, including live activity/progress fields when available.",inputSchema:W0(H3),execute:async(j)=>S(N5.array(),$.runtime.listRuns(S(H3,j)).map(M5))})),Z.push(J0({name:"team_await_runs",description:"Wait for async teammate runs. Provide runId to wait for one run, or omit it to wait for all active async runs. Uses a long timeout for legitimate teammate work.",inputSchema:W0($3),timeoutMs:KF,execute:async(j)=>{let H=S($3,j);if(H.runId){let A=await $.runtime.awaitRun(H.runId);return qF(A),S(N5,M5(A))}let X=await $.runtime.awaitAllRuns(),Y=X.filter((A)=>["failed","cancelled","interrupted"].includes(A.status));if(Y.length>0){let A=Y.map((V)=>`${V.id}:${V.status}${V.error?`(${V.error})`:""}`).join(", ");throw Error(`One or more runs did not complete successfully: ${A}`)}return S(N5.array(),X.map(M5))}})),Z.push(J0({name:"team_send_message",description:"Send a mailbox message to a specific teammate.",inputSchema:W0(K3),execute:async(j)=>{let H=S(K3,j),X=$.runtime.sendMessage($.requesterId,H.toAgentId,H.subject,H.body,H.taskId??void 0);return S(NF,{id:X.id,toAgentId:X.toAgentId})}})),Z.push(J0({name:"team_broadcast",description:"Broadcast a message to all teammates.",inputSchema:W0(f3),execute:async(j)=>{let H=S(f3,j),X=$.runtime.broadcast($.requesterId,H.subject,H.body,{taskId:H.taskId??void 0});return S(UF,{delivered:X.length})}})),Z.push(J0({name:"team_read_mailbox",description:"Read the current agent mailbox.",inputSchema:W0(A3),execute:async(j)=>{let H=S(A3,j);return S(_F.array(),$.runtime.listMailbox($.requesterId,{unreadOnly:H.unreadOnly,markRead:!0}))}})),Z.push(J0({name:"team_mission_log",description:"Append a mission log update for your team.",inputSchema:W0(X3),execute:async(j)=>{let H=S(X3,j),X=$.runtime.appendMissionLog({agentId:$.requesterId,taskId:H.taskId||void 0,kind:H.kind,summary:H.summary,evidence:H.evidence?.length?H.evidence:void 0,nextAction:H.nextAction||void 0});return S(zF,{id:X.id})}})),Z.push(J0({name:"team_cleanup",description:"Clean up the team runtime. Fails if teammates are still running.",inputSchema:W0(W3),execute:async(j)=>{if(S(W3,j),$.runtime.getMemberRole($.requesterId)!=="lead")throw Error("Only the lead agent can run cleanup.");return $.runtime.cleanup(),S(DF,{status:"cleaned"})}})),Z.push(J0({name:"team_create_outcome",description:"Create a converged team outcome.",inputSchema:W0(Z3),execute:async(j)=>{let H=S(Z3,j),X=$.runtime.createOutcome({title:H.title,requiredSections:H.requiredSections,createdBy:$.requesterId});return S(LF,{outcomeId:X.id,status:X.status,requiredSections:X.requiredSections})}})),Z.push(J0({name:"team_attach_outcome_fragment",description:"Attach a fragment to an outcome section.",inputSchema:W0(e7),execute:async(j)=>{let H=S(e7,j),X=$.runtime.attachOutcomeFragment({outcomeId:H.outcomeId,section:H.section,sourceAgentId:$.requesterId,sourceRunId:H.sourceRunId||void 0,content:H.content});return S(Y3,{fragmentId:X.id,status:X.status})}})),Z.push(J0({name:"team_review_outcome_fragment",description:"Review one outcome fragment.",inputSchema:W0(V3),execute:async(j)=>{let H=S(V3,j),X=$.runtime.reviewOutcomeFragment({fragmentId:H.fragmentId,reviewedBy:$.requesterId,approved:H.approved});return S(Y3,{fragmentId:X.id,status:X.status})}})),Z.push(J0({name:"team_finalize_outcome",description:"Finalize one outcome.",inputSchema:W0(Q3),execute:async(j)=>{let H=S(Q3,j),X=$.runtime.finalizeOutcome(H.outcomeId);return S(OF,{outcomeId:X.id,status:X.status})}})),Z.push(J0({name:"team_list_outcomes",description:"List team outcomes.",inputSchema:W0(j3),execute:async(j)=>{return S(j3,j),S(TF.array(),$.runtime.listOutcomes())}})),Z}function O3($){return{...$,tasks:$.tasks.map((f)=>({...f,createdAt:new Date(f.createdAt),updatedAt:new Date(f.updatedAt)})),mailbox:$.mailbox.map((f)=>({...f,sentAt:new Date(f.sentAt),readAt:f.readAt?new Date(f.readAt):void 0})),missionLog:$.missionLog.map((f)=>({...f,ts:new Date(f.ts)})),runs:($.runs??[]).map((f)=>({...f,startedAt:new Date(f.startedAt),endedAt:f.endedAt?new Date(f.endedAt):void 0,nextAttemptAt:f.nextAttemptAt?new Date(f.nextAttemptAt):void 0,heartbeatAt:f.heartbeatAt?new Date(f.heartbeatAt):void 0})),outcomes:($.outcomes??[]).map((f)=>({...f,createdAt:new Date(f.createdAt),finalizedAt:f.finalizedAt?new Date(f.finalizedAt):void 0})),outcomeFragments:($.outcomeFragments??[]).map((f)=>({...f,createdAt:new Date(f.createdAt),reviewedAt:f.reviewedAt?new Date(f.reviewedAt):void 0}))}}var wF=[{id:"read_files",description:"Read the full content of text or image files at the provided absolute paths, or return only an inclusive one-based line range when start_line/end_line are provided.",headlessToolNames:["read_files"]},{id:"search_codebase",description:"Perform regex pattern searches across the codebase for code patterns, definitions, imports, and other text matches.",headlessToolNames:["search_codebase"]},{id:"run_commands",description:"Run shell commands from the root of the workspace for listing files, checking git status, builds, tests, and similar tasks.",headlessToolNames:["run_commands"]},{id:"editor",description:"Make controlled filesystem edits on text files with create, replace, and insert operations.",headlessToolNames:["editor"]},{id:"fetch_web_content",description:"Fetch URL content and analyze it with a prompt describing what to extract.",headlessToolNames:["fetch_web_content"]},{id:"skills",description:"Execute a configured skill within the main conversation when a matching skill exists for the task.",headlessToolNames:["skills"]},{id:"ask_question",description:"Ask the user a single clarifying question with 2-5 selectable options.",headlessToolNames:["ask_question"]},{id:"spawn_agent",description:Jf({configProvider:{}}).description,headlessToolNames:["spawn_agent"]},{id:"teams",description:"Enable team collaboration tools for teammate management, task coordination, mailbox messaging, mission logs, and outcomes.",headlessToolNames:[...jJ]}],SF={read_files:"enableReadFiles",search_codebase:"enableSearch",run_commands:"enableBash",fetch_web_content:"enableWebFetch",apply_patch:"enableApplyPatch",editor:"enableEditor",skills:"enableSkills",ask_question:"enableAskQuestion"};function hF($){return $==="plan"||$==="yolo"?$:"act"}function z3($){let f=hF($.mode),J=s0[w$({mode:f})],W=uf($.providerId??"",$.modelId??"",f,vf);return{mode:f,flags:{...J,...W,...typeof $.enableSpawnAgent==="boolean"?{enableSpawnAgent:$.enableSpawnAgent}:{},...typeof $.enableAgentTeams==="boolean"?{enableAgentTeams:$.enableAgentTeams}:{}}}}function _3($,f){if(f.disabledToolIds?.has($))return!1;let{flags:J}=z3(f);if($==="spawn_agent")return J.enableSpawnAgent===!0;if($==="teams")return J.enableAgentTeams===!0;if($==="editor")return J.enableEditor===!0||J.enableApplyPatch===!0;let W=SF[$];return W?J[W]===!0:!1}function CF($,f){if($.id==="editor"){let{flags:J}=z3(f),W=J.enableApplyPatch===!0&&J.enableEditor!==!0;return{...$,defaultEnabled:_3($.id,f),headlessToolNames:[W?"apply_patch":"editor"]}}return{...$,defaultEnabled:_3($.id,f)}}function rf($={}){return wF.map((f)=>CF(f,$))}function T3($={}){return rf($).filter((f)=>f.defaultEnabled).map((f)=>f.id)}function N3($){if(!$.enabled)return new Set;let f=rf($.availabilityContext),J=new Set(f.map((W)=>W.id));if(!$.allowlist||$.allowlist.length===0)return new Set(f.filter((W)=>W.defaultEnabled).map((W)=>W.id));for(let W of $.allowlist)if(!J.has(W))throw Error(`Unknown tool "${W}". Available tools: ${f.map((Z)=>Z.id).join(", ")}`);return new Set($.allowlist)}function y5($,f={}){return rf(f).filter((J)=>$.has(J.id)).flatMap((J)=>J.headlessToolNames)}function M3($,f={}){return y5($,f)}function nf($={}){let{executorOptions:f={},executors:J,...W}=$,Z={...$J(f),...J??{}};return e1({...W,executors:Z})}function XJ($){return $.trim().replace(/^\/+/,"").toLowerCase()}function EF($){if(!$||$.length===0)return;let f=$.map(XJ).filter((J)=>J.length>0);return f.length>0?new Set(f):void 0}function bF($,f,J){if(!J)return!0;let W=XJ($),Z=XJ(f),Q=W.includes(":")?W.split(":").at(-1)??W:W,j=Z.includes(":")?Z.split(":").at(-1)??Z:Z;return J.has(W)||J.has(Z)||J.has(Q)||J.has(j)}function af($,f){let J=EF(f);return[...$.getSnapshot("skill").entries()].map(([Z,Q])=>{let j=Q.item;return{id:Z,name:j.name.trim(),description:j.description?.trim(),disabled:j.disabled===!0,skill:j}}).filter((Z)=>bF(Z.id,Z.name,J))}function kF($,f){return af($,f).filter((J)=>!J.disabled).map((J)=>J.name.trim()).filter((J)=>J.length>0).sort((J,W)=>J.localeCompare(W))}function IF($,f,J){let W=XJ(f);if(!W)return{error:"Missing skill name."};let Z=af($,J),Q=Z.find((A)=>A.id===W);if(Q){let{skill:A}=Q;if(A.disabled===!0)return{error:`Skill "${A.name}" is configured but disabled.`};return{id:Q.id,skill:A}}let j=W.includes(":")?W.split(":").at(-1)??W:W,H=Z.filter(({id:A})=>{if(A===j)return!0;return A.endsWith(`:${j}`)}),X=H.filter(({skill:A})=>A.disabled!==!0);if(X.length===1){let{id:A,skill:V}=X[0];return{id:A,skill:V}}if(X.length>1)return{error:`Skill "${f}" is ambiguous. Use one of: ${X.map(({id:A})=>A).join(", ")}`};if(H.length===1){let{skill:A}=H[0];return{error:`Skill "${A.name}" is configured but disabled.`}}if(H.length>1)return{error:`Skill "${f}" is ambiguous, and all matches are disabled: ${H.map(({id:A})=>A).join(", ")}`};let Y=kF($,J);return{error:Y.length>0?`Skill "${f}" not found. Available skills: ${Y.join(", ")}`:"No skills are currently available."}}function xF($,f=Promise.resolve(),J){let W=new Set,Z=async(Q,j)=>{await f;let H=IF($,Q,J);if("error"in H)return H.error;let{id:X,skill:Y}=H;if(W.has(X))return`Skill "${Y.name}" is already running.`;W.add(X);try{let A=j?.trim(),V=A?`
|
|
148
|
+
<command-args>${A}</command-args>`:"",B=Y.description?.trim()?`Description: ${Y.description.trim()}
|
|
148
149
|
|
|
149
|
-
`:"";return`<command-name>${Y.name}</command-name>${
|
|
150
|
+
`:"";return`<command-name>${Y.name}</command-name>${V}
|
|
150
151
|
<command-instructions>
|
|
151
152
|
${B}${Y.instructions}
|
|
152
|
-
</command-instructions>`}finally{
|
|
153
|
+
</command-instructions>`}finally{W.delete(X)}};return Object.defineProperty(Z,"configuredSkills",{get:()=>af($,J).map(({skill:Q,...j})=>j),enumerable:!0,configurable:!1}),Z}function y3($){let f=$.watcherReady??Promise.resolve();return{name:"cline-user-instructions",manifest:{capabilities:[$.includeRules?"rules":void 0,$.registerSkillsTool?"tools":void 0,$.includeSkills||$.includeWorkflows?"commands":void 0].filter((W)=>Boolean(W))},async setup(W){if(await f,$.includeRules)W.registerRule({id:"cline-user-instructions:rules",source:"user-instruction-watcher",content:()=>sQ($.watcher)});if($.registerSkillsTool)W.registerTool(o1(xF($.watcher,f,$.allowedSkillNames)));for(let Z of If($.watcher).filter((Q)=>Q.kind==="skill"&&$.includeSkills||Q.kind==="workflow"&&$.includeWorkflows))W.registerCommand({name:Z.name,description:Z.description,handler:(Q)=>{let j=Q.trim();return j?`${Z.instructions}
|
|
153
154
|
|
|
154
|
-
${j}`:Z.instructions}})}}}class
|
|
155
|
-
${
|
|
155
|
+
${j}`:Z.instructions}})}}}class q3{watcher;ready;stopped=!1;constructor($){this.watcher=rQ($)}start(){if(!this.ready)this.stopped=!1,this.ready=this.watcher.start();return this.ready}stop(){if(this.stopped)return;this.stopped=!0,this.watcher.stop(),this.ready=void 0}async refreshType($){await this.start(),await this.watcher.refreshType($)}listRecords($){return[...this.watcher.getSnapshot($).entries()].map(([f,J])=>({type:$,id:f,filePath:J.filePath,item:J.item}))}listRuntimeCommands(){return If(this.watcher)}resolveRuntimeSlashCommand($){return aQ($,this.watcher)}hasConfiguredSkills($){return af(this.watcher,$).some((f)=>!f.disabled)}createExtension($){return y3({...$,watcher:this.watcher,watcherReady:(this.ready??Promise.resolve()).catch(()=>{})})}}function Wf($){return new q3($)}import{readFile as mF,writeFile as gF}from"node:fs/promises";import S3 from"yaml";function vF($){let f=/^---\r?\n([\s\S]*?)\r?\n---\r?\n?([\s\S]*)$/,J=$.match(f);if(!J)return{data:{},body:$,hadFrontmatter:!1};let[,W,Z]=J,Q=S3.parse(W);return{data:Q&&typeof Q==="object"&&!Array.isArray(Q)?Q:{},body:Z,hadFrontmatter:!0}}function w3($,f){return`---
|
|
156
|
+
${S3.stringify($).trimEnd()}
|
|
156
157
|
---
|
|
157
|
-
${f}`}function
|
|
158
|
+
${f}`}function uF($,f){let{data:J,body:W,hadFrontmatter:Z}=vF($);if(!Z&&f)return $;if(f){if(delete J.disabled,J.enabled===!1)delete J.enabled;if(Object.keys(J).length===0)return W;return w3(J,W)}return J.disabled=!0,w3(J,W)}async function h3({filePath:$,enabled:f}){let J=await mF($,"utf8"),W=uF(J,f);return await gF($,W),{filePath:$,enabled:f,disabled:!f}}import{spawn as GU}from"node:child_process";import{StringDecoder as p3}from"node:string_decoder";import{UnauthorizedError as u3}from"@modelcontextprotocol/sdk/client/auth.js";import{Client as PU}from"@modelcontextprotocol/sdk/client/index.js";import{randomUUID as ZU}from"node:crypto";import{UnauthorizedError as QU}from"@modelcontextprotocol/sdk/client/auth.js";import{Client as jU}from"@modelcontextprotocol/sdk/client/index.js";import{SSEClientTransport as HU}from"@modelcontextprotocol/sdk/client/sse.js";import{StreamableHTTPClientTransport as XU}from"@modelcontextprotocol/sdk/client/streamableHttp.js";YJ();var YU="/mcp/oauth/callback",AU=[1456,1457,1458],VU=300000;function BU($){if($ instanceof Error){let f=$.message.trim();if(f.length>0)return f}return String($)}function KU($){return{client_name:"Cline",redirect_uris:[$],grant_types:["authorization_code","refresh_token"],response_types:["code"],token_endpoint_auth_method:"none"}}function VJ($){let f={};try{f=ef($.serverName,{filePath:$.settingsPath})??{}}catch{f={}}let J,W,Z=async(j)=>{let H=Zf(j(f))??{};try{f=$2($.serverName,()=>H,{filePath:$.settingsPath})}catch{f=H}};return{provider:{get redirectUrl(){return f.redirectUrl??$.redirectUrl},get clientMetadata(){return KU(f.redirectUrl??$.redirectUrl)},state:()=>{return W=ZU(),W},clientInformation:()=>f.clientInformation,saveClientInformation:async(j)=>{await Z((H)=>({...H,clientInformation:j,redirectUrl:$.redirectUrl,lastError:void 0}))},tokens:()=>f.tokens,saveTokens:async(j)=>{await Z((H)=>({...H,tokens:j,redirectUrl:$.redirectUrl,lastError:void 0,lastAuthenticatedAt:Date.now()}))},redirectToAuthorization:async(j)=>{J=j.toString(),await $.onAuthorizationUrl?.(J)},saveCodeVerifier:async(j)=>{await Z((H)=>({...H,codeVerifier:j,redirectUrl:$.redirectUrl}))},codeVerifier:()=>{if(!f.codeVerifier)throw Error(`Missing OAuth code verifier for MCP server "${$.serverName}".`);return f.codeVerifier},invalidateCredentials:async(j)=>{await Z((H)=>{if(j==="all")return{lastError:H.lastError,redirectUrl:H.redirectUrl};return{...H,...j==="client"?{clientInformation:void 0}:{},...j==="tokens"?{tokens:void 0,lastAuthenticatedAt:void 0}:{},...j==="verifier"?{codeVerifier:void 0}:{},...j==="discovery"?{discoveryState:void 0}:{}}})},saveDiscoveryState:async(j)=>{await Z((H)=>({...H,discoveryState:j}))},discoveryState:()=>f.discoveryState},getLastAuthorizationUrl:()=>J,getLastOAuthState:()=>W,resetInteractiveState:async()=>{await Z((j)=>({...j,clientInformation:void 0,codeVerifier:void 0,discoveryState:void 0,lastError:void 0,redirectUrl:$.redirectUrl}))},markError:async(j)=>{await Z((H)=>({...H,lastError:j}))},clearError:async()=>{await Z((j)=>({...j,lastError:void 0}))}}}function AJ($){let f=$.registration.transport;if(f.type==="stdio")throw Error(`MCP server "${$.registration.name}" uses stdio transport and does not support OAuth browser flow.`);let J=f.headers?{headers:f.headers}:void 0;if(f.type==="sse")return new HU(new URL(f.url),{authProvider:$.oauthProvider,requestInit:J,fetch:$.fetch});return new XU(new URL(f.url),{authProvider:$.oauthProvider,requestInit:J,fetch:$.fetch})}function g3($){return new jU({name:$.clientName?.trim()||"@cline/core",version:$.clientVersion?.trim()||"0.0.0"})}async function v3($){let f=$.serverName.trim();if(!f)throw Error("MCP server name cannot be empty.");let{resolveMcpServerRegistrations:J}=await Promise.resolve().then(() => (YJ(),m3)),W=J({filePath:$.filePath}).find((X)=>X.name===f);if(!W)throw Error(`MCP server "${f}" is not configured.`);if(W.disabled)throw Error(`MCP server "${f}" is disabled. Enable it before running OAuth.`);if(W.transport.type==="stdio")throw Error(`MCP server "${f}" uses stdio transport and does not support OAuth browser flow.`);let Z=await W$({host:$.callbackHost,ports:$.callbackPorts?.length?$.callbackPorts:AU,callbackPath:$.callbackPath??YU,timeoutMs:$.timeoutMs??VU,successHtml:$.successHtml,onListening:$.onServerListening,onClose:$.onServerClose});if(!Z.callbackUrl)throw Error("Unable to bind local MCP OAuth callback server.");let Q=VJ({settingsPath:$.filePath,serverName:f,redirectUrl:Z.callbackUrl,onAuthorizationUrl:async(X)=>{await $.openUrl?.(X)}});await Q.resetInteractiveState();let j=g3($),H;try{let X=AJ({registration:W,oauthProvider:Q.provider,fetch:$.fetch});try{return await j.connect(X),await j.listTools(),await Q.clearError(),{serverName:f,authorized:!0,message:`MCP server "${f}" is already authorized.`}}catch(Y){if(!(Y instanceof QU))throw Y;if(!Q.getLastAuthorizationUrl())throw Error(`MCP server "${f}" did not provide an authorization URL.`);let V=await Z.waitForCallback();if(!V)throw Error("Timed out waiting for MCP OAuth authorization callback.");if(V.error)throw Error(`OAuth authorization failed: ${V.error}`);if(!V.code)throw Error("OAuth callback did not include an authorization code.");let B=Q.getLastOAuthState();if(!B)throw Error(`MCP server "${f}" did not start an OAuth stateful authorization flow.`);if(V.state!==B)throw Error("OAuth authorization failed: state mismatch.");await X.finishAuth(V.code),H=g3($);let K=AJ({registration:W,oauthProvider:Q.provider,fetch:$.fetch});return await H.connect(K),await H.listTools(),await Q.clearError(),{serverName:f,authorized:!0,message:`MCP server "${f}" OAuth authorization completed.`}}}catch(X){let Y=BU(X);throw await Q.markError(Y),Error(Y)}finally{await j.close().catch(()=>{return}),await H?.close().catch(()=>{return}),Z.close()}}var FU="2024-11-05",UU=5000,RU=1500,c3="http://127.0.0.1:1456/mcp/oauth/callback";function BJ($){return $ instanceof Error?$.message:String($)}function d3($){let f=Buffer.from(JSON.stringify($),"utf8"),J=Buffer.from(`Content-Length: ${f.byteLength}\r
|
|
158
159
|
\r
|
|
159
|
-
`,"utf8");return Buffer.concat([J,f])}function
|
|
160
|
-
`,"utf8")}class
|
|
160
|
+
`,"utf8");return Buffer.concat([J,f])}function l3($){return Buffer.from(`${JSON.stringify($)}
|
|
161
|
+
`,"utf8")}class C5{buffer="";decoder=new p3("utf8");push($){this.buffer+=this.decoder.write($);let f=[];while(!0){let J=this.buffer.indexOf(`\r
|
|
161
162
|
\r
|
|
162
|
-
`);if(J<0)break;let Z=this.buffer.slice(0,J).match(/(?:^|\r\n)Content-Length:\s*(\d+)(?:\r\n|$)/i);if(!Z)throw Error("Invalid MCP stdio frame: missing Content-Length header.");let
|
|
163
|
-
`);if(J<0)break;let Q=this.buffer.slice(0,J).trim();if(this.buffer=this.buffer.slice(J+1),Q.length>0)f.push(Q)}return f}}class E3{registration;process;nextRequestId=1;pending=new Map;framedParser=new uJ;newlineParser=new cJ;stderrBuffer="";connected=!1;protocolMode="newline";constructor($){this.registration=$}async connect(){if(this.connected)return;if(this.registration.transport.type!=="stdio")throw Error(`Unsupported MCP transport for "${this.registration.name}": ${this.registration.transport.type}`);let $=["newline","framed"],f;for(let J of $){await this.disconnect().catch(()=>{}),this.spawnProcess(J);try{await this.request("initialize",{protocolVersion:tK,capabilities:{},clientInfo:{name:"@cline/core",version:"0.0.0"}},oK),this.notify("notifications/initialized"),this.connected=!0,this.protocolMode=J;return}catch(Q){f=Q instanceof Error?Q:Error(String(Q))}}throw f??Error(`Failed to connect to MCP server "${this.registration.name}".`)}async disconnect(){let $=this.process;if(this.connected=!1,this.process=void 0,this.failAllPending(Error(`Disconnected from MCP server "${this.registration.name}".`)),!$)return;$.kill()}async listTools(){return((await this.request("tools/list")).tools??[]).filter((f)=>typeof f?.name==="string"&&typeof f.inputSchema==="object"&&f.inputSchema!==null).map((f)=>({name:f.name,description:f.description,inputSchema:f.inputSchema}))}async callTool($){return this.request("tools/call",{name:$.name,arguments:$.arguments??{}})}spawnProcess($){let f=this.registration.transport;if(f.type!=="stdio")throw Error(`Unsupported MCP transport for "${this.registration.name}": ${f.type}`);this.framedParser=new uJ,this.newlineParser=new cJ,this.stderrBuffer="",this.protocolMode=$;let J=process.platform==="win32"?{windowsHide:!0,shell:!0}:{},Q=nK(f.command,f.args??[],{cwd:f.cwd,env:{...process.env,...f.env??{}},stdio:["pipe","pipe","pipe"],...J});this.process=Q,Q.stdout.on("data",(Z)=>this.handleStdout(Z)),Q.stderr.on("data",(Z)=>{if(this.process!==Q)return;if(this.stderrBuffer+=Z.toString("utf8"),this.stderrBuffer.length>16384)this.stderrBuffer=this.stderrBuffer.slice(-16384)}),Q.once("error",(Z)=>{if(this.process!==Q)return;this.failAllPending(Error(`MCP process error: ${E4(Z)}`))}),Q.once("exit",(Z,W)=>{if(this.process!==Q)return;this.connected=!1,this.process=void 0;let j=this.stderrBuffer.trim()?` stderr: ${this.stderrBuffer.trim()}`:"";this.failAllPending(Error(`MCP process exited for "${this.registration.name}" (code=${Z??"null"}, signal=${W??"null"}).${j}`))})}handleStdout($){try{let f=this.protocolMode==="framed"?this.framedParser.push($):this.newlineParser.push($);for(let J of f){let Q=JSON.parse(J);if(typeof Q.id!=="number")continue;let Z=this.pending.get(Q.id);if(!Z)continue;if(this.pending.delete(Q.id),clearTimeout(Z.timeout),Q.error){let W=Q.error.message||`MCP request failed with code ${Q.error.code??"unknown"}`;Z.reject(Error(W));continue}Z.resolve(Q.result)}}catch(f){this.handleProtocolFailure(f)}}handleProtocolFailure($){let f=this.process;if(!f)return;this.connected=!1,this.process=void 0;let J=this.stderrBuffer.trim()?` stderr: ${this.stderrBuffer.trim()}`:"";this.failAllPending(Error(`Invalid MCP response from "${this.registration.name}": ${E4($)}.${J}`)),f.kill()}async request($,f,J=sK){let Q=this.process;if(!Q?.stdin.writable)throw Error(`MCP server "${this.registration.name}" is not connected.`);let Z=this.nextRequestId++,W={jsonrpc:"2.0",id:Z,method:$,...f?{params:f}:{}},j=new Promise((X,H)=>{let Y=setTimeout(()=>{this.pending.delete(Z),H(Error(`MCP request timed out for "${this.registration.name}" (${$}).`))},J);this.pending.set(Z,{resolve:X,reject:H,timeout:Y})});try{Q.stdin.write(this.protocolMode==="framed"?S3(W):h3(W))}catch(X){let H=this.pending.get(Z);if(H)clearTimeout(H.timeout),this.pending.delete(Z);throw X}return j}notify($,f){let J=this.process;if(!J?.stdin.writable)return;let Q={jsonrpc:"2.0",method:$,...f?{params:f}:{}};J.stdin.write(this.protocolMode==="framed"?S3(Q):h3(Q))}failAllPending($){for(let[f,J]of this.pending)clearTimeout(J.timeout),this.pending.delete(f),J.reject($)}}class b3{registration;options;client;authContext;constructor($,f){this.registration=$;this.options=f}async connect(){if(this.client)return;if(this.registration.transport.type==="stdio")throw Error(`Unsupported MCP transport for "${this.registration.name}": ${this.registration.transport.type}`);let $=C4({settingsPath:this.options.settingsPath,serverName:this.registration.name,redirectUrl:this.registration.oauth?.redirectUrl??w3});this.authContext=$;try{let f=new aK({name:this.options.clientName?.trim()||"@cline/core",version:this.options.clientVersion?.trim()||"0.0.0"}),J=h4({registration:this.registration,oauthProvider:$.provider,fetch:this.options.fetch});await f.connect(J),await $.clearError(),this.client=f}catch(f){let J=f instanceof y3?this.formatUnauthorizedMessage($.getLastAuthorizationUrl()):E4(f);throw await $.markError(J),Error(J)}}async disconnect(){let $=this.client;this.client=void 0,await $?.close()}async listTools(){let $=await this.ensureConnectedClient();try{return(await $.listTools()).tools.map((J)=>({name:J.name,description:J.description,inputSchema:J.inputSchema&&typeof J.inputSchema==="object"&&!Array.isArray(J.inputSchema)?J.inputSchema:{}}))}catch(f){return await this.handleOperationError(f)}}async callTool($){let f=await this.ensureConnectedClient();try{return await f.callTool({name:$.name,arguments:$.arguments??{}})}catch(J){return await this.handleOperationError(J)}}async ensureConnectedClient(){if(!this.client)await this.connect();if(!this.client)throw Error(`MCP server "${this.registration.name}" is not connected.`);return this.client}formatUnauthorizedMessage($){let f=`MCP server "${this.registration.name}" requires OAuth authorization.`;if(!$)return`${f} Run authorizeMcpServerOAuth for this server.`;return`${f} Run authorizeMcpServerOAuth for this server and complete this URL: ${$}`}async handleOperationError($){let f=this.authContext??C4({settingsPath:this.options.settingsPath,serverName:this.registration.name,redirectUrl:this.registration.oauth?.redirectUrl??w3}),J=$ instanceof y3?this.formatUnauthorizedMessage(f.getLastAuthorizationUrl()):E4($);throw await f.markError(J),Error(J)}}function b4($={}){return(f)=>f.transport.type==="stdio"?new E3(f):new b3(f,$)}S4();function E0(){return Date.now()}function eK($){return $.map((f)=>({name:f.name,description:f.description,inputSchema:f.inputSchema}))}class b2{toolsCacheTtlMs;clientFactory;servers=new Map;operationLocks=new Map;constructor($){this.clientFactory=$.clientFactory,this.toolsCacheTtlMs=$.toolsCacheTtlMs??5000}async registerServer($){await this.runExclusive($.name,async()=>{let f=this.servers.get($.name);if(!f){this.servers.set($.name,{registration:{...$},status:"disconnected",updatedAt:E0()});return}let J=JSON.stringify(f.registration.transport)!==JSON.stringify($.transport);if(f.registration={...$},f.updatedAt=E0(),J)await this.disconnectState(f),f.client=void 0,f.toolCache=void 0,f.toolCacheUpdatedAt=void 0})}async unregisterServer($){await this.runExclusive($,async()=>{let f=this.requireServer($);await this.disconnectState(f),this.servers.delete($)})}async connectServer($){await this.runExclusive($,async()=>{let f=this.requireServer($);await this.connectState(f)})}async disconnectServer($){await this.runExclusive($,async()=>{let f=this.requireServer($);await this.disconnectState(f)})}async setServerDisabled($,f){await this.runExclusive($,async()=>{let J=this.requireServer($);if(J.registration={...J.registration,disabled:f},J.updatedAt=E0(),f)await this.disconnectState(J)})}listServers(){return[...this.servers.values()].map(($)=>({name:$.registration.name,status:$.status,disabled:$.registration.disabled===!0,lastError:$.lastError,toolCount:$.toolCache?.length??0,updatedAt:$.updatedAt,metadata:$.registration.metadata})).sort(($,f)=>$.name.localeCompare(f.name))}async listTools($){let f=this.requireServer($),J=f.toolCacheUpdatedAt??0;if(f.toolCache&&E0()-J<=this.toolsCacheTtlMs)return f.toolCache;return this.refreshTools($)}async refreshTools($){return this.runExclusive($,async()=>{let f=this.requireServer($),Q=await(await this.ensureConnectedClient(f)).listTools(),Z=eK(Q);return f.toolCache=Z,f.toolCacheUpdatedAt=E0(),f.updatedAt=E0(),Z})}async callTool($){return this.runExclusive($.serverName,async()=>{let f=this.requireServer($.serverName),J=await this.ensureConnectedClient(f);return f.updatedAt=E0(),J.callTool({name:$.toolName,arguments:$.arguments,context:$.context})})}async dispose(){let $=[...this.servers.keys()];for(let f of $)await this.unregisterServer(f)}async ensureConnectedClient($){if(await this.connectState($),!$.client)throw Error(`MCP server "${$.registration.name}" does not have an initialized client.`);return $.client}async connectState($){if($.registration.disabled)throw Error(`MCP server "${$.registration.name}" is disabled and cannot be connected.`);if($.status==="connected"&&$.client)return;$.status="connecting",$.updatedAt=E0();try{let f=$.client??await this.clientFactory($.registration);await f.connect(),$.client=f,$.status="connected",$.lastError=void 0,$.updatedAt=E0()}catch(f){throw $.status="disconnected",$.lastError=f instanceof Error?f.message:String(f),$.updatedAt=E0(),f}}async disconnectState($){if(!$.client){$.status="disconnected",$.updatedAt=E0();return}try{await $.client.disconnect()}finally{$.status="disconnected",$.updatedAt=E0()}}requireServer($){let f=this.servers.get($);if(!f)throw Error(`Unknown MCP server: ${$}`);return f}async runExclusive($,f){let J=this.operationLocks.get($)??Promise.resolve(),Q,Z=new Promise((j)=>{Q=j}),W=J.catch(()=>{return}).then(()=>Z);this.operationLocks.set($,W),await J.catch(()=>{return});try{return await f()}finally{if(Q?.(),this.operationLocks.get($)===W)this.operationLocks.delete($)}}}import{createHash as $F}from"node:crypto";var k3=128,fF=/[^a-zA-Z0-9_-]+/g,I3=8,JF=1,QF="mcp_tool";function ZF($){return $F("sha1").update($).digest("hex").slice(0,I3)}function WF($){return $.replace(fF,"_")}var k4=({serverName:$,toolName:f})=>{let J=`${$}__${f}`,Q=WF(J);if(Q===J&&J.length<=k3)return J;let Z=ZF(J),W=k3-JF-I3;return`${Q.slice(0,W)||QF}_${Z}`};function dJ($){return{[($.nameTransform??k4)({serverName:$.serverName,toolName:$.toolName})]:{enabled:!1}}}function x3($){let f={};for(let J of $.toolNames)Object.assign(f,dJ({serverName:$.serverName,toolName:J,nameTransform:$.nameTransform}));return f}import{createTool as jF}from"@cline/shared";function XF($,f){let J=f.description?.trim();if(J)return J;return`Execute MCP tool "${f.name}" from server "${$}".`}async function I4($){let f=await $.provider.listTools($.serverName),J=$.nameTransform??k4;return f.map((Q)=>{let Z=J({serverName:$.serverName,toolName:Q.name});return jF({name:Z,description:XF($.serverName,Q),inputSchema:Q.inputSchema,timeoutMs:$.timeoutMs,retryable:$.retryable,maxRetries:$.maxRetries,execute:async(W,j)=>$.provider.callTool({serverName:$.serverName,toolName:Q.name,arguments:W&&typeof W==="object"&&!Array.isArray(W)?W:void 0,context:j})})})}Z$();import{stat as BP}from"node:fs/promises";Z$();import{existsSync as HP}from"node:fs";import{discoverPluginModulePaths as YP,resolveConfiguredPluginModulePaths as VP,resolvePluginConfigSearchPaths as AP}from"@cline/shared/storage";import{resolve as vF}from"node:path";import{normalizePluginManifest as uF}from"@cline/shared";import{existsSync as j0,readFileSync as r1}from"node:fs";import{builtinModules as OF,createRequire as sJ}from"node:module";import{dirname as q$,extname as m2,isAbsolute as zF,resolve as g}from"node:path";import{fileURLToPath as d3}from"node:url";import{PLUGIN_FILE_EXTENSIONS as _F}from"@cline/shared";var l3=q$(d3(import.meta.url)),NF=sJ(import.meta.url),TF=g(l3,"..","..","..","..",".."),nJ=yF(TF),MF=["@cline/sdk","@cline/agents","@cline/core","@cline/core/hub","@cline/core/hub/daemon-entry","@cline/core/telemetry","@cline/llms","@cline/llms/browser","@cline/shared","@cline/shared/automation","@cline/shared/browser","@cline/shared/storage","@cline/shared/db","@cline/shared/types"],oJ=new Set(OF.flatMap(($)=>[$,$.replace(/^node:/,"")])),x2=new Set(_F),qF=["development","node","import","require","default"];function yF($){let f={},J={"@cline/sdk":g($,"packages/sdk/src/index.ts"),"@cline/agents":g($,"packages/agents/src/index.ts"),"@cline/core":g($,"packages/core/src/index.ts"),"@cline/llms":g($,"packages/llms/src/index.ts"),"@cline/shared":g($,"packages/shared/src/index.ts"),"@cline/shared/storage":g($,"packages/shared/src/storage/index.ts"),"@cline/shared/db":g($,"packages/shared/src/db/index.ts")};for(let[Q,Z]of Object.entries(J))if(j0(Z))f[Q]=Z;for(let Q of["agents","core","llms","shared"]){let Z=g($,"packages",Q),W=g(Z,"package.json");if(!j0(W))continue;try{let j=JSON.parse(r1(W,"utf8"));if(typeof j.name!=="string"||!j.exports)continue;if(typeof j.exports==="string"){let X=g(Z,j.exports);if(j0(X))f[j.name]=X;continue}if(typeof j.exports!=="object")continue;for(let[X,H]of Object.entries(j.exports)){let Y=wF(Z,H);if(!Y)continue;let V=X==="."?j.name:`${j.name}/${X.replace(/^\.\//,"")}`;f[V]=Y}}catch{}}return f}function wF($,f){let J=eJ(f);if(!J)return null;let Q=p3($,J);for(let Z of Q)if(j0(Z))return Z;return null}function eJ($,f=new Set){if(typeof $==="string")return $;if(!$||typeof $!=="object")return null;if(f.has($))return null;f.add($);let J=$;for(let Q of qF){let Z=eJ(J[Q],f);if(Z)return Z}return null}function p3($,f){let J=f.replace(/^\.\//,""),Q=[g($,f)];if(J.startsWith("dist/")){let Z=J.replace(/^dist\//,"src/").replace(/\.(mjs|cjs|js)$/,"");return[g($,`${Z}.ts`),g($,`${Z}.tsx`),g($,`${Z}.mts`),g($,`${Z}.cts`),...Q]}return Q}function SF($){return Object.fromEntries(Object.entries($).sort(([f],[J])=>J.length-f.length))}function u4($){return!($.startsWith(".")||$.startsWith("/")||$.startsWith("file:")||$.startsWith("data:")||$.startsWith("http:")||$.startsWith("https:"))}function p1($){if($.startsWith("@")){let[f,J]=$.split("/",3);return J?`${f}/${J}`:$}return $.split("/",1)[0]??$}function hF($){let f=p1($);if($===f)return".";return`.${$.slice(f.length)}`}function r3($){return p1($).startsWith("@cline/")}function aJ($,f){let J=p1(f),Q=q$($);while(!0){let Z=g(Q,"node_modules",J);if(j0(Z)||j0(g(Z,"package.json")))return!0;let W=g(Q,"..");if(W===Q)return!1;Q=W}}function c3($){return tJ($)!==null}function tJ($){try{return NF.resolve($)}catch{}return CF($)}function CF($){let f=p1($),J=i3(f);if(!J)return null;let Q=g(J,"package.json");try{let Z=JSON.parse(r1(Q,"utf8")),W=hF($),j=W==="."&&typeof Z.exports==="string"?Z.exports:Z.exports&&typeof Z.exports==="object"&&Object.hasOwn(Z.exports,W)?Z.exports[W]:void 0,X=eJ(j)??(W==="."&&typeof Z.main==="string"?Z.main:null);if(!X)return null;let H=g(J,X),Y=[H,...p3(J,X).filter((V)=>V!==H)];for(let V of Y)if(j0(V))return V;return null}catch{return null}}function EF(){let $=[l3],f=process.env.CLINE_WRAPPER_PATH?.trim();if(f)$.push(q$(q$(f)));let J=process.execPath?.trim();if(J)$.push(q$(J));return[...new Set($.map((Q)=>g(Q)))]}function bF($,f){let J=$;while(!0){let Q=g(J,"package.json");if(j0(Q))try{if(JSON.parse(r1(Q,"utf8")).name===f)return J}catch{}let Z=g(J,"node_modules",f,"package.json");if(j0(Z))return q$(Z);let W=g(J,"..");if(W===J)return null;J=W}}function i3($){for(let f of EF()){let J=bF(f,$);if(J)return J}return null}function kF($){let J=q$($);for(let Q=0;Q<4;Q++){let Z=g(J,"package.json");if(j0(Z))try{let j=JSON.parse(r1(Z,"utf8"));return j!=null&&typeof j==="object"&&"cline"in j}catch{return!1}let W=g(J,"..");if(W===J)return!1;J=W}return!1}function n3($,f){let J=f.startsWith("file:")?d3(f):zF(f)?f:g(q$($),f);if(j0(J)&&x2.has(m2(J)))return J;for(let Q of x2){let Z=`${J}${Q}`;if(j0(Z))return Z}for(let Q of x2){let Z=g(J,`index${Q}`);if(j0(Z))return Z}return null}function a3($){let f=new Set,J=[/\bimport\s+(?:type\s+)?[^"'`]*?\bfrom\s*["'`]([^"'`]+)["'`]/g,/\bexport\s+[^"'`]*?\bfrom\s*["'`]([^"'`]+)["'`]/g,/\bimport\s*\(\s*["'`]([^"'`]+)["'`]\s*\)/g,/\brequire\s*\(\s*["'`]([^"'`]+)["'`]\s*\)/g];for(let Q of J)for(let Z of $.matchAll(Q)){let W=Z[1];if(W)f.add(W)}return[...f]}function IF($){return m2($)!==".ts"}function t3($,f,J=new Set){if(J.has($)||!j0($))return;if(J.add($),!x2.has(m2($)))return;let Q=r1($,"utf8"),Z=IF($);for(let W of a3(Q)){if(W.startsWith("node:")||oJ.has(W))continue;if(u4(W)){if(!Z)continue;if(Object.hasOwn(nJ,W)||Object.hasOwn(nJ,p1(W))||aJ($,W)||r3(W)&&c3(W)||f&&c3(W))continue;throw Error(`Cannot find module '${p1(W)}'`)}let j=n3($,W);if(j)t3(j,f,J)}}function s3($,f=new Set,J=new Set){if(f.has($)||!j0($))return J;if(f.add($),!x2.has(m2($)))return J;let Q=r1($,"utf8");for(let Z of a3(Q)){if(J.add(Z),u4(Z))continue;let W=n3($,Z);if(W)s3(W,f,J)}return J}function xF($,f){let J=sJ($),Q={},Z=s3($),W=new Set(MF);for(let[j,X]of Object.entries(nJ)){try{J.resolve(j);continue}catch{}Q[j]=X}for(let j of Z)if(u4(j)&&(r3(j)||f))W.add(j);for(let j of W){if(Object.hasOwn(Q,j)||aJ($,j))continue;let X=tJ(j);if(X)Q[j]=X}if(!f)return Q;for(let j of Z){if(!u4(j)||Object.hasOwn(Q,j)||aJ($,j)||j.startsWith("node:")||oJ.has(j))continue;let X=tJ(j);if(X)Q[j]=X}return Q}function mF($){let f=m2($);return f===".ts"||f===".tsx"||f===".mts"||f===".cts"}var H1;function gF(){if(H1!==void 0)return H1;let $=i3("jiti");if(!$)return H1=null,null;let f=g($,"dist","babel.cjs");if(!j0(f))return H1=null,null;try{let Q=sJ(f)(f);H1=typeof Q==="function"?Q:null}catch{H1=null}return H1}async function o3($,f={}){let J=!kF($);t3($,J);let Q=xF($,J),Z=SF(Q),W=await import("jiti"),j=typeof W==="function"?W:typeof W.default==="function"?W.default:void 0;if(!j)throw Error("Unable to load jiti");let X=Object.entries(Z).filter(([,A])=>mF(A)).map(([A])=>A),H=gF(),Y=H?(A)=>H({...A,interopDefault:!0}):void 0;return await j($,{alias:Z,cache:f.useCache,requireCache:f.useCache,esmResolve:!0,interopDefault:!1,nativeModules:[...oJ],transformModules:X,tryNative:!1,...Y?{transform:Y}:{}}).import($,{})}function e3($,f){if(!$)return!0;if($.providerIds?.length){if(!f?.providerId||!$.providerIds.includes(f.providerId))return!1}if($.modelIds?.length){if(!f?.modelId||!$.modelIds.includes(f.modelId))return!1}return!0}function $W($){return typeof $==="object"&&$!==null}function $5($){return Array.isArray($)&&$.every((f)=>typeof f==="string")}function cF($,f){if(!$W($.manifest))throw Error(`Invalid plugin module at ${f}: missing required "manifest"`);if(!$5($.manifest.capabilities))throw Error(`Invalid plugin module at ${f}: manifest.capabilities must be a string array`);if($.manifest.capabilities.length===0)throw Error(`Invalid plugin module at ${f}: manifest.capabilities cannot be empty`);if(Object.hasOwn($.manifest,"providerIds")&&!$5($.manifest.providerIds))throw Error(`Invalid plugin module at ${f}: manifest.providerIds must be a string array when provided`);if(Object.hasOwn($.manifest,"modelIds")&&!$5($.manifest.modelIds))throw Error(`Invalid plugin module at ${f}: manifest.modelIds must be a string array when provided`)}function dF($,f){if(!$W($))throw Error(`Invalid plugin module at ${f}: expected object export`);if(typeof $.name!=="string"||$.name.length===0)throw Error(`Invalid plugin module at ${f}: expected non-empty "name"`);if(!Object.hasOwn($,"manifest"))throw Error(`Invalid plugin module at ${f}: missing required "manifest"`);cF($,f)}async function f5($,f={}){let J=vF(f.cwd??process.cwd(),$),Q=await o3(J,{useCache:f.useCache}),Z=f.exportName??"plugin",W=Q.default??Q[Z];dF(W,J);let j=W,X=j.setup,H=X?(Y,V)=>{let A={...f.session,...V.session},B={...V,session:Object.keys(A).length>0?A:void 0,client:f.client??V.client,user:f.user??V.user,workspaceInfo:f.workspaceInfo??V.workspaceInfo,automation:f.automation??V.automation,logger:f.logger??V.logger,telemetry:f.telemetry??V.telemetry};return X(Y,B)}:void 0;return{...j,manifest:uF(j.manifest),setup:H}}async function fW($,f={}){return(await g2($,f)).plugins}async function g2($,f={}){let J=[],Q=[],Z=new Map,W=0;for(let j of $)try{let X=await f5(j,f);if(!e3(X.manifest,f))continue;let H=Z.get(X.name);if(H)Q.push({type:"duplicate_plugin_override",pluginName:X.name,pluginPath:j,overriddenPluginPath:H.pluginPath,message:`Plugin "${X.name}" from ${j} overrides ${H.pluginPath}`});Z.set(X.name,{plugin:X,pluginPath:j,order:W++})}catch(X){let H=X instanceof Error?X.message:String(X);J.push({pluginPath:j,phase:"load",message:H,stack:X instanceof Error?X.stack:void 0})}return{plugins:[...Z.values()].sort((j,X)=>j.order-X.order).map((j)=>j.plugin),failures:J,warnings:Q}}import{existsSync as Z5}from"node:fs";import{createRequire as jW}from"node:module";import{dirname as d4,join as i1}from"node:path";import{fileURLToPath as tF}from"node:url";import{spawn as lF}from"node:child_process";import{basename as pF}from"node:path";import{augmentNodeCommandForDebug as rF,withResolvedClineBuildEnv as iF}from"@cline/shared";function JW($){if($ instanceof Error)return $;return Error(String($))}var nF="CLINE_JS_RUNTIME_PATH";function QW($){let f=$?.trim();if(!f)return!1;let J=pF(f).toLowerCase();return J==="node"||J==="node.exe"||J==="bun"||J==="bun.exe"}function ZW($={}){let f=$.env??process.env,J=$.runtimeExecutable?.trim()||f[nF]?.trim();if(J)return J;let Q=$.execPath?.trim()||process.execPath;if(QW(Q))return Q;for(let Z of[f.BUN_EXEC_PATH,f.npm_node_execpath,f.NODE]){let W=Z?.trim();if(W&&QW(W))return W}return"node"}function aF($,f={}){let J=ZW({env:f.env,execPath:f.execPath,runtimeExecutable:f.runtimeExecutable});return rF([J,...$],{env:f.env,execArgv:f.execArgv,debugRole:f.name==="plugin-sandbox"?"plugin-sandbox":"sandbox"})}class c4{options;process=null;requestCounter=0;pending=new Map;constructor($){this.options=$}get processLabel(){return this.options.name??"sandbox"}clearPendingRequest($){let f=this.pending.get($);if(!f)return;if(this.pending.delete($),f.timeout)clearTimeout(f.timeout);return f}start(){if(this.process&&this.process.exitCode===null)return;let $=this.options.bootstrapFile?[this.options.bootstrapFile]:["-e",this.options.bootstrapScript??""],f=aF($,{name:this.options.name,runtimeExecutable:this.options.runtimeExecutable}),J=lF(f[0]??ZW(this.options),f.slice(1),{stdio:["ignore","ignore","pipe","ipc"],env:iF(process.env)});this.process=J;let Q="",Z=(W)=>{let j=Q+W;Q=j.length>4000?j.slice(-4000):j};J.stderr?.setEncoding("utf8"),J.stderr?.on("data",(W)=>{Z(W)}),J.on("message",(W)=>{this.onMessage(W)}),J.on("error",(W)=>{this.failPending(Error(`${this.processLabel} process error: ${JW(W).message}`))}),J.on("exit",(W,j)=>{this.process=null;let X=Q.trim();this.failPending(Error(`${this.options.name??"sandbox"} process exited (code=${String(W)}, signal=${String(j)})${X?`: ${X}`:""}`))})}async call($,f,J={}){this.start();let Q=this.process;if(!Q||Q.exitCode!==null)throw Error(`${this.processLabel} process is not available`);let Z=`req_${++this.requestCounter}`,W={type:"call",id:Z,method:$,args:f};return await new Promise((j,X)=>{let H={resolve:(Y)=>j(Y),reject:X};if((J.timeoutMs??0)>0)H.timeout=setTimeout(()=>{this.clearPendingRequest(Z),this.shutdown().catch(()=>{}),X(Error(`${this.processLabel} call timed out after ${J.timeoutMs}ms: ${$}`))},J.timeoutMs);this.pending.set(Z,H),Q.send(W,(Y)=>{if(!Y)return;let V=this.clearPendingRequest(Z);if(!V)return;V.reject(Error(`${this.processLabel} failed to send call "${$}": ${JW(Y).message}`))})})}async shutdown(){let $=this.process;if(this.process=null,!$||$.exitCode!==null){this.failPending(Error(`${this.processLabel} shutdown`));return}await new Promise((f)=>{let J=setTimeout(()=>{try{$.kill("SIGKILL")}catch{}f()},300);$.once("exit",()=>{clearTimeout(J),f()});try{$.kill("SIGTERM")}catch{clearTimeout(J),f()}}),this.failPending(Error(`${this.processLabel} shutdown`))}onMessage($){if(!$)return;if($.type==="event"){if(typeof $.name==="string"&&$.name.length>0)this.options.onEvent?.({name:$.name,payload:$.payload});return}if($.type!=="response"||!$.id)return;let f=this.clearPendingRequest($.id);if(!f)return;if($.ok){f.resolve($.result);return}f.reject(Error($.error?.message||`${this.processLabel} call failed`))}failPending($){for(let[f,J]of this.pending.entries()){if(this.pending.delete(f),J.timeout)clearTimeout(J.timeout);J.reject($)}}}function sF($){return{...$,contributions:{tools:$.contributions?.tools??[],commands:$.contributions?.commands??[],messageBuilders:$.contributions?.messageBuilders??[],providers:$.contributions?.providers??[],automationEventTypes:$.contributions?.automationEventTypes??[],shortcuts:$.contributions?.shortcuts??[],flags:$.contributions?.flags??[]}}}function l4($){return($ instanceof Error?$.message:String($)).includes("Unknown sandbox plugin id:")}function oF(){return`@cline/cli-${process.platform==="win32"?"windows":process.platform}-${process.arch}`}function eF(){let $=process.env.CLINE_WRAPPER_PATH?.trim();if(!$)return;try{let J=jW($).resolve(`${oF()}/package.json`),Q=i1(d4(J),"extensions","plugin-sandbox-bootstrap.js");return Z5(Q)?Q:void 0}catch{return}}function $P(){let $=process.execPath?.trim();if(!$)return;let f=i1(d4(d4($)),"extensions","plugin-sandbox-bootstrap.js");return Z5(f)?f:void 0}function fP(){let $=d4(tF(import.meta.url)),f=jW(import.meta.url),J=[i1($,"plugin-sandbox-bootstrap.js"),i1($,"extensions","plugin-sandbox-bootstrap.js"),i1($,"agents","plugin-sandbox-bootstrap.js"),eF(),$P()];for(let W of J.filter((j)=>typeof j==="string"))if(Z5(W))return{file:W};let Q=i1($,"plugin-sandbox-bootstrap.ts"),Z="jiti";try{Z=f.resolve("jiti")}catch{}return{script:[`const createJiti = require(${JSON.stringify(Z)});`,`const jiti = createJiti(${JSON.stringify(Q)}, { cache: false, requireCache: false, esmResolve: true, interopDefault: false });`,`Promise.resolve(jiti.import(${JSON.stringify(Q)}, {})).catch((error) => {`," console.error(error);"," process.exitCode = 1;","});"].join(`
|
|
164
|
-
`)}}var J5=fP();function Q5($,f){return typeof $==="number"&&$>0?$:f}async function p4($){let f=new c4({name:"plugin-sandbox",..."file"in J5?{bootstrapFile:J5.file}:{bootstrapScript:J5.script},onEvent:$.onEvent}),J=Q5($.importTimeoutMs,4000),Q=Q5($.hookTimeoutMs,3000),Z=Q5($.contributionTimeoutMs,60000),W={pluginPaths:$.pluginPaths,exportName:$.exportName,providerId:$.providerId,modelId:$.modelId,cwd:$.cwd,session:$.session,client:$.client,user:$.user,workspaceInfo:$.workspaceInfo,loggerEnabled:Boolean($.logger)},j,X=()=>{return j??=f.call("initialize",W,{timeoutMs:J}).finally(()=>{j=void 0}),j},H;try{H=await f.call("initialize",W,{timeoutMs:J})}catch(A){throw await f.shutdown().catch(()=>{}),A}return{extensions:H.plugins.map(sF).map((A)=>{let B={name:A.name,__clinePluginPath:A.pluginPath,manifest:A.manifest,setup:(G)=>{JP(G,f,A,Z,X),QP(G,f,A,Z,X),WP(G,f,A,Z,X),ZP(G,A)}};return B.hooks=XP(f,A,Q,X),B}),failures:H.failures,shutdown:async()=>{await f.shutdown()},warnings:H.warnings}}function JP($,f,J,Q,Z){for(let W of J.contributions?.tools??[]){let j={name:W.name,description:W.description??"",inputSchema:W.inputSchema??{type:"object",properties:{}},timeoutMs:W.timeoutMs,retryable:W.retryable,execute:async(X,H)=>{try{return await f.call("executeTool",{pluginId:J.pluginId,contributionId:W.id,input:X,context:H},{timeoutMs:Q})}catch(Y){if(!l4(Y))throw Y;return await Z(),await f.call("executeTool",{pluginId:J.pluginId,contributionId:W.id,input:X,context:H},{timeoutMs:Q})}}};$.registerTool(j)}}function QP($,f,J,Q,Z){for(let W of J.contributions?.commands??[])$.registerCommand({name:W.name,description:W.description,handler:async(j)=>{try{return await f.call("executeCommand",{pluginId:J.pluginId,contributionId:W.id,input:j},{timeoutMs:Q})}catch(X){if(!l4(X))throw X;return await Z(),await f.call("executeCommand",{pluginId:J.pluginId,contributionId:W.id,input:j},{timeoutMs:Q})}}})}function ZP($,f){for(let J of f.contributions?.providers??[])$.registerProvider({name:J.name,description:J.description,metadata:J.metadata});for(let J of f.contributions?.automationEventTypes??[])$.registerAutomationEventType({eventType:J.eventType,source:J.source,description:J.description,attributesSchema:J.attributesSchema,payloadSchema:J.payloadSchema,examples:J.examples,metadata:J.metadata})}function WP($,f,J,Q,Z){for(let W of J.contributions?.messageBuilders??[])$.registerMessageBuilder({name:W.name,async build(j){try{let X=await f.call("buildMessages",{pluginId:J.pluginId,contributionId:W.id,messages:j},{timeoutMs:Q});return WW(X)?X:j}catch(X){if(!l4(X))throw X;await Z();let H=await f.call("buildMessages",{pluginId:J.pluginId,contributionId:W.id,messages:j},{timeoutMs:Q});return WW(H)?H:j}}})}function WW($){return Array.isArray($)&&$.every((f)=>typeof f==="object"&&f!==null&&("role"in f)&&("content"in f))}function jP($,f,J,Q,Z){return async(W)=>{try{return await $.call("invokeHook",{pluginId:f,hookName:J,payload:W},{timeoutMs:Q})}catch(j){if(!l4(j))throw j;return await Z(),await $.call("invokeHook",{pluginId:f,hookName:J,payload:W},{timeoutMs:Q})}}}function XP($,f,J,Q){let Z={};for(let W of f.hooks??[])Z[W]=jP($,f.pluginId,W,J,Q);return Object.keys(Z).length>0?Z:void 0}function W5($){return AP($)}function j5($){return YP($)}function v2($={}){let f=$.cwd??process.cwd(),J=W5($.workspacePath).flatMap((j)=>j5(j)).filter((j)=>HP(j)),Q=VP($.pluginPaths??[],f),Z=[],W=new Set;for(let j of[...Q,...J]){if(W.has(j))continue;W.add(j),Z.push(j)}return rJ(Z)}async function r4($={}){let f=v2($);if(f.length===0)return{extensions:[],failures:[],warnings:[]};if($.mode==="in_process"){let Q=await g2(f,{cwd:$.cwd,exportName:$.exportName,providerId:$.providerId,modelId:$.modelId,session:$.session,client:$.client,user:$.user,workspaceInfo:$.workspaceInfo,automation:$.automation,logger:$.logger,telemetry:$.telemetry});return{extensions:Q.plugins,failures:Q.failures,warnings:Q.warnings}}let J=await p4({pluginPaths:f,exportName:$.exportName,importTimeoutMs:$.importTimeoutMs,hookTimeoutMs:$.hookTimeoutMs,contributionTimeoutMs:$.contributionTimeoutMs,onEvent:$.onEvent,providerId:$.providerId,modelId:$.modelId,cwd:$.cwd,session:$.session,client:$.client,user:$.user,workspaceInfo:$.workspaceInfo,logger:$.logger});return{extensions:J.extensions??[],shutdown:J.shutdown,failures:J.failures,warnings:J.warnings}}Z$();var GP=32,n1=new Map;function KP($,f){if(!n1.has($)&&n1.size>=GP){let J=n1.keys().next().value;if(J)n1.delete(J)}n1.set($,f)}async function FP($){let f=await Promise.all($.pluginPaths.map(async(J)=>{try{let Q=await BP(J);return`${J}:${Q.mtimeMs}:${Q.size}`}catch{return`${J}:missing`}}));return JSON.stringify({workspacePath:$.workspacePath,cwd:$.cwd,providerId:$.providerId,modelId:$.modelId,pathStats:f})}function XW($,f){return $.map((J)=>({...J,enabled:!f.has(J.name)}))}function PP($){return $.sort((f,J)=>{let Q=f.name.localeCompare(J.name);if(Q!==0)return Q;return f.path.localeCompare(J.path)})}function UP($,f){if(!$.setup)return[];let J=[],Q={registerTool:(Z)=>J.push(Z),registerCommand:()=>{},registerMessageBuilder:()=>{},registerRule:()=>{},registerProvider:()=>{},registerAutomationEventType:()=>{}};return $.setup(Q,{workspaceInfo:f}),J}async function HW($){let f=v2({workspacePath:$.workspacePath,cwd:$.cwd}),J=Q$($.disabledToolNames);if(f.length===0)return{tools:[],failures:[],warnings:[]};let Q=await FP({pluginPaths:f,workspacePath:$.workspacePath,cwd:$.cwd,providerId:$.providerId,modelId:$.modelId}),Z=n1.get(Q);if(Z)return{tools:XW(Z.tools,J),failures:Z.failures,warnings:Z.warnings};let W=[],j=[],X=[],H;try{H=await p4({pluginPaths:f,cwd:$.cwd,providerId:$.providerId,modelId:$.modelId,workspaceInfo:{rootPath:$.workspacePath}}),j=[...H.failures],X=[...H.warnings];for(let A of H.extensions??[]){let B=A.__clinePluginPath;if(!B)continue;for(let G of UP(A,{rootPath:$.workspacePath}))W.push({name:G.name,pluginName:A.name,path:B,source:B.startsWith($.workspacePath)?"workspace-plugin":"global-plugin",description:G.description?.trim()||void 0})}}catch(A){j=f.map((B)=>({pluginPath:B,phase:"load",message:A instanceof Error?A.message:String(A),stack:A instanceof Error?A.stack:void 0}))}finally{await H?.shutdown().catch(()=>{})}let Y=PP(W);return KP(Q,{tools:Y,failures:j,warnings:X}),{tools:XW(Y,J),failures:j,warnings:X}}async function X5($){return(await HW($)).tools}function n4($,f){if(!f)return"global";let J=RP(f,$);return!J.startsWith("..")&&!DP(J)?"workspace":"global"}function u2($){return[...$].sort((f,J)=>{let Q=(Z)=>{switch(Z){case"workspace":case"workspace-plugin":return 0;case"global":case"global-plugin":return 1;case"builtin":return 2}};if(f.source!==J.source)return Q(f.source)-Q(J.source);return f.name.localeCompare(J.name)})}function AW($){return $.workspaceRoot?.trim()||$.cwd?.trim()||""}async function VW($,f){if($.userInstructionService)return await f($.userInstructionService);let J=AW($);if(!J)return await f(void 0);let Q=c1({skills:{workspacePath:J},rules:{workspacePath:J},workflows:{workspacePath:J}});try{return await Q.start(),await f(Q)}finally{Q.stop()}}function LP($,f){if(!$)return;let J=$.listRecords("skill");if(f.id){let Q=J.find((Z)=>Z.id===f.id);if(Q)return Q}for(let Q of J)if(Q.filePath===f.path||Q.item.name===f.name||Q.id===f.name)return Q;return}class a1{async list($={}){return await VW($,async(f)=>{let J=AW($),Q=[],Z=[],W=[],j=[],X=[];if(f){for(let Y of f.listRecords("workflow")){let V=Y.item;Q.push({id:Y.id,name:V.name,path:Y.filePath,enabled:V.disabled!==!0,kind:"workflow",source:n4(Y.filePath,J),description:V.instructions,toggleable:!1})}for(let Y of f.listRecords("rule")){let V=Y.item;Z.push({id:Y.id,name:V.name,path:Y.filePath,enabled:V.disabled!==!0,kind:"rule",source:n4(Y.filePath,J),description:V.instructions,toggleable:!1})}for(let Y of f.listRecords("skill")){let V=Y.item;W.push({id:Y.id,name:V.name,path:Y.filePath,enabled:V.disabled!==!0,kind:"skill",source:n4(Y.filePath,J),description:V.description,toggleable:!0})}}if(J)try{for(let Y of await X5({workspacePath:J,cwd:$.cwd,providerId:$.availabilityContext?.providerId,modelId:$.availabilityContext?.modelId}))j.push({id:`${Y.pluginName}:${Y.name}:${Y.path}`,name:Y.name,path:Y.path,enabled:Y.enabled,kind:"tool",source:Y.source,description:Y.description,toggleable:!0})}catch{}let H=C0();if(X1({filePath:H}))try{for(let Y of M$({filePath:H}))X.push({id:Y.name,name:Y.name,path:H,enabled:Y.disabled!==!0,kind:"mcp",source:n4(H,J),description:Y.transport.type,toggleable:!0})}catch{}return{workflows:u2(Q.filter((Y)=>i4(Y.path))),rules:u2(Z.filter((Y)=>i4(Y.path))),skills:u2(W.filter((Y)=>i4(Y.path))),tools:u2(j),mcp:u2(X.filter((Y)=>i4(Y.path)))}})}async toggle($){if($.type==="skills")return await VW($,async(f)=>{let J=LP(f,$),Q=J?.filePath;if(!Q)throw Error(`Unable to resolve skill setting '${$.id??$.name??YW($.path??"")}'.`);let Z=J?.item&&"disabled"in J.item?J.item.disabled!==!0:void 0,W=$.enabled??(Z!==void 0?!Z:void 0);if(W===void 0)throw Error(`Cannot determine toggle state for skill '${$.id??$.name??YW($.path??"")}'; provide an explicit enabled value or a resolvable workspace context.`);return await D3({filePath:Q,enabled:W}),await f?.refreshType("skill"),{snapshot:await this.list({...$,userInstructionService:f}),changedTypes:["skills"]}});if($.type==="tools"){if(!$.name?.trim())throw Error("Tool settings toggle requires a tool name.");if($.enabled===void 0)pJ($.name);else u3($.name,!$.enabled);return{snapshot:await this.list($),changedTypes:["tools"]}}if($.type==="mcp"){let f=$.name?.trim()||$.id?.trim();if(!f)throw Error("MCP server settings toggle requires a server name.");let J=$.path?.trim()||C0(),Q=$.enabled;if(Q===void 0){let Z=M$({filePath:J}).find((W)=>W.name===f);if(!Z)throw Error(`Unknown MCP server: ${f}`);Q=Z.disabled===!0}return S2({filePath:J,name:f,disabled:!Q}),{snapshot:await this.list($),changedTypes:["mcp"]}}throw Error(`Settings type '${$.type}' does not support toggles.`)}}function c2(){return new a1}function BW($){return{async list(f){let J=$;if(J.listSettings)return await J.listSettings(f);return await c2().list(f)},async toggle(f){let J=$;if(J.toggleSetting)return await J.toggleSetting(f);return await c2().toggle(f)}}}function GW($){function f(){let J=$.pendingPrompts;if(!J)throw Error("Pending prompt service is not available.");return J}return{list(J){return f().list(J)},update(J){return f().update(J)},delete(J){return f().delete(J)}}}function P0(...$){let f,J;for(let Z of $){if(!Z)continue;if(Z.toolExecutors)f={...f??{},...Z.toolExecutors};if(Z.requestToolApproval)J=Z.requestToolApproval}let Q=f&&Object.keys(f).length>0;if(!Q&&!J)return;return{...Q?{toolExecutors:f}:{},...J?{requestToolApproval:J}:{}}}function H5($){let{hooks:f,logger:J,telemetry:Q,extensionContext:Z,extraTools:W,extensions:j,onTeamEvent:X,onConsecutiveMistakeLimitReached:H,checkpoint:Y,compaction:V,...A}=$,B={};if(f)B.hooks=f;if(J)B.logger=J;if(Q)B.telemetry=Q;if(Z)B.extensionContext=Z;if(W)B.extraTools=W;if(j)B.extensions=j;if(X)B.onTeamEvent=X;if(H)B.onConsecutiveMistakeLimitReached=H;if(Y?.createCheckpoint)B.checkpoint=Y;if(V?.compact)B.compaction=V;let G=Object.keys(B).length>0?B:void 0;return{config:{...A,...Y?{checkpoint:{enabled:Y.enabled}}:{},...V?{compaction:{enabled:V.enabled,strategy:V.strategy,thresholdRatio:V.thresholdRatio,reserveTokens:V.reserveTokens,preserveRecentTokens:V.preserveRecentTokens,maxInputTokens:V.maxInputTokens,summarizer:V.summarizer}}:{}},...G?{localRuntime:G}:{}}}function KW($){let f=$.config;return"providerId"in f?{...$,config:{...f,...OP($.localRuntime)},localRuntime:$.localRuntime}:$}function Y5($,f={}){let J=H5($.config),Q=P0(f.defaultCapabilities,$.capabilities),Z=zP(J.localRuntime,$.localRuntime),W=f.withExtensionContext?.(Z?.extensionContext);if(W)Z={...Z??{},extensionContext:W};return{...$,...J,...Z?{localRuntime:Z}:{},...Q?{capabilities:Q}:{}}}function OP($){if(!$)return{};let{modelCatalogDefaults:f,userInstructionService:J,configExtensions:Q,onTeamRestored:Z,...W}=$;return W}function zP(...$){let f={};for(let J of $)if(J)Object.assign(f,J);return Object.keys(f).length>0?f:void 0}G0();function FW($){let f=$.input.config.telemetry??$.telemetry;if(!f)return;f.capture({event:k.SESSION.STARTED,properties:{sessionId:$.sessionId,source:$.input.source??F0.CORE,providerId:$.input.config.providerId,modelId:$.input.config.modelId,enableTools:$.input.config.enableTools,enableSpawnAgent:$.input.config.enableSpawnAgent,enableAgentTeams:$.input.config.enableAgentTeams,clientName:$.clientName,runtimeAddress:$.runtimeAddress}})}function d2($){return!!$&&typeof $==="object"&&!Array.isArray($)}function V5($){let f=$?.trim();return f?f:void 0}function _P($,f){let J=$?.trim();if(!J)return f;let Q=Date.parse(J);if(!Number.isFinite(Q))return f;return new Date(Q).toISOString()}function PW($,f){return new Date(new Date($).getTime()+Math.max(0,Math.floor(f))*1000).toISOString()}function UW($,f){return new Date(new Date($).getTime()-Math.max(0,Math.floor(f))*1000).toISOString()}function NP($,f){if(!$)return f;return new Date($).getTime()>=new Date(f).getTime()?$:f}function TP($,f){let J=$.eventId.trim(),Q=$.eventType.trim(),Z=$.source.trim(),W=V5($.subject),j=V5($.dedupeKey)??`${Q}:${Z}:${W??J}`;return{eventId:J,eventType:Q,source:Z,subject:W,occurredAt:_P($.occurredAt,f),workspaceRoot:V5($.workspaceRoot),payload:d2($.payload)?$.payload:void 0,attributes:d2($.attributes)?$.attributes:void 0,dedupeKey:j}}function A5($,f){if(!f)return;let J=f.split("."),Q=$;for(let Z of J){if(!d2(Q))return;Q=Q[Z]}return Q}function MP($,f){if($.attributes&&Object.hasOwn($.attributes,f))return $.attributes[f];if($.payload&&Object.hasOwn($.payload,f))return $.payload[f];let J={eventId:$.eventId,eventType:$.eventType,source:$.source,subject:$.subject,occurredAt:$.occurredAt,workspaceRoot:$.workspaceRoot,dedupeKey:$.dedupeKey,attributes:$.attributes,payload:$.payload},Q=A5(J,f);if(Q!==void 0)return Q;if($.attributes){let Z=A5($.attributes,f);if(Z!==void 0)return Z}if($.payload)return A5($.payload,f);return}function a4($,f){if(Array.isArray(f))return f.some((J)=>a4($,J));if(Array.isArray($))return $.some((J)=>a4(J,f));if(d2(f)){if(!d2($))return!1;return Object.entries(f).every(([J,Q])=>a4($[J],Q))}return Object.is($,f)}function qP($,f){if(!f||Object.keys(f).length===0)return!0;return Object.entries(f).every(([J,Q])=>a4(MP($,J),Q))}class B5{store;nowFn;logger;constructor($){this.store=$.store,this.nowFn=$.now??(()=>Date.now()),this.logger=$.logger}ingestEvent($){let f=new Date(this.nowFn()).toISOString(),J=TP($,f),Q=this.store.insertEventLog(J,{receivedAtIso:f});if(!Q.created)return this.logger?.debug("cron.event.duplicate",{eventId:Q.record.eventId,eventType:Q.record.eventType,source:Q.record.source}),{event:Q.record,duplicate:!0,matchedSpecs:[],queuedRuns:[],suppressions:[{reason:"duplicate_event",dedupeKey:Q.record.dedupeKey}]};try{let Z=this.store.listEventSpecsForType(J.eventType),W=[],j=[],X=[];for(let V of Z){if(!qP(J,V.filters)){W.push({specId:V.specId,externalId:V.externalId,reason:"filter_mismatch",dedupeKey:J.dedupeKey});continue}j.push(V);let A=this.materializeForSpec(V,J,Q.record.receivedAt);if(A.run)X.push(A.run);else W.push({specId:V.specId,externalId:V.externalId,reason:A.reason,dedupeKey:J.dedupeKey})}let H=j.length===0?"unmatched":X.length>0?"queued":"suppressed";this.store.updateEventLogProcessing(Q.record.eventId,{status:H,matchedSpecCount:j.length,queuedRunCount:X.length,suppressedCount:W.filter((V)=>V.reason!=="filter_mismatch").length});let Y=this.store.getEventLog(Q.record.eventId);return this.logger?.debug("cron.event.processed",{eventId:Q.record.eventId,eventType:Q.record.eventType,status:H,matchedSpecCount:j.length,queuedRunCount:X.length}),{event:Y??Q.record,duplicate:!1,matchedSpecs:j,queuedRuns:X,suppressions:W}}catch(Z){if(this.store.updateEventLogProcessing(Q.record.eventId,{status:"failed",error:Z instanceof Error?Z.message:String(Z)}),this.logger?.error)this.logger.error("cron.event.failed",{eventId:Q.record.eventId,eventType:Q.record.eventType,error:Z});throw Z}}materializeForSpec($,f,J){let Q=f.dedupeKey??f.eventId,Z=$.debounceSeconds??0;if(Z>0){let H=this.store.findQueuedEventRunForDedupe({specId:$.specId,dedupeKey:Q});if(H){let Y=NP(H.scheduledFor,PW(J,Z)),V=this.store.updateQueuedEventRunForDebounce({runId:H.runId,triggerEventId:f.eventId,scheduledFor:Y});if(V)return{run:V,reason:"dedupe_window"}}}let W=$.dedupeWindowSeconds??0;if(W>0&&this.store.hasRecentEventRunForDedupe({specId:$.specId,dedupeKey:Q,sinceIso:UW(J,W)}))return{reason:"dedupe_window"};let j=$.cooldownSeconds??0;if(j>0&&this.store.hasRecentEventRunForSpec({specId:$.specId,sinceIso:UW(J,j)}))return{reason:"cooldown"};return{run:this.store.enqueueRun({specId:$.specId,specRevision:$.revision,triggerKind:"event",triggerEventId:f.eventId,scheduledFor:Z>0?PW(J,Z):J}),reason:"dedupe_window"}}}class l2{store;nowFn;constructor($){this.store=$.store,this.nowFn=$.now??(()=>Date.now())}materializeAll(){let $={oneOffQueued:0,scheduleQueued:0},f=this.store.listSpecs({triggerKind:"one_off",enabled:!0,parseStatus:"valid"});for(let Q of f)if(this.materializeOneOff(Q))$.oneOffQueued+=1;let J=this.store.listSpecs({triggerKind:"schedule",enabled:!0,parseStatus:"valid"});for(let Q of J)try{if(this.materializeSchedule(Q))$.scheduleQueued+=1}catch{}return $}materializeOneOff($){if($.triggerKind!=="one_off")return!1;if(!$.enabled||$.removed)return!1;if(this.store.hasOneOffRunForRevision($.specId,$.revision))return!1;return this.store.enqueueRun({specId:$.specId,specRevision:$.revision,triggerKind:"one_off",scheduledFor:new Date(this.nowFn()).toISOString()}),!0}materializeSchedule($){if($.triggerKind!=="schedule")return!1;if(!$.enabled||$.removed)return!1;if(!$.scheduleExpr)return!1;return this.store.materializeDueScheduleRun({specId:$.specId,nowMs:this.nowFn()}).queued}}import{basename as xP}from"node:path";import{buildClineSystemPrompt as mP}from"@cline/shared";import{nowIso as OW}from"@cline/shared/db";import{basename as yP,resolve as wP}from"node:path";import{performance as DW}from"node:perf_hooks";import{processWorkspaceInfo as RW}from"@cline/shared";import SP from"simple-git";function Y1($){return wP($)}async function s4($){return(await G5($)).info}function t4($){if($ instanceof Error)return{errorType:$.name?.trim()||$.constructor.name||"Error",message:$.message};return{errorType:"Error",message:String($)}}async function G5($){let f=Y1($),J={rootPath:f,hint:yP(f)},Q;try{let Z=SP({baseDir:f});if(!await Z.checkIsRepo())return{info:J,vcsType:"none"};try{let j=await Z.getRemotes(!0);if(j.length>0){let X=j.map((H)=>{let Y=H.refs.fetch||H.refs.push;return`${H.name}: ${Y}`});J.associatedRemoteUrls=X}}catch(j){Q??=t4(j)}try{let j=(await Z.revparse(["HEAD"])).trim();if(j.length>0)J.latestGitCommitHash=j}catch(j){Q??=t4(j)}try{let j=(await Z.branch()).current.trim();if(j.length>0)J.latestGitBranchName=j}catch(j){Q??=t4(j)}return{info:J,vcsType:"git",error:Q}}catch(Z){return{info:J,vcsType:"none",error:t4(Z)}}}async function K5($){let f=await s4($);return RW(f)}async function LW($){let f=DW.now(),J=await G5($),Q=DW.now()-f,Z=J.info;return{workspaceInfo:Z,workspaceMetadata:RW(Z),durationMs:Q,vcsType:J.vcsType,initError:J.error}}import{mkdirSync as hP,writeFileSync as CP}from"node:fs";import{join as EP}from"node:path";import{resolveCronReportsDir as bP}from"@cline/shared/storage";function y$($){if(/[:#\n]/.test($)||$.includes('"'))return JSON.stringify($);return $}function V1($,f){if(f===void 0||f===null)return;return`${$}: ${y$(f)}`}function kP($,f,J){let Q=[`runId: ${y$($.runId)}`,`specId: ${y$(f.specId)}`,`externalId: ${y$(f.externalId)}`,`title: ${y$(f.title)}`,`triggerKind: ${y$($.triggerKind)}`,`status: ${y$($.status)}`,`sourcePath: ${y$(f.sourcePath)}`],Z=[V1("sessionId",$.sessionId),V1("startedAt",$.startedAt),V1("completedAt",$.completedAt),V1("triggerEventId",$.triggerEventId),V1("triggerEventType",J?.eventType),V1("triggerEventSource",J?.source),V1("triggerEventSubject",J?.subject)];for(let W of Z)if(W)Q.push(W);return`---
|
|
165
|
-
${Q.join(`
|
|
163
|
+
`);if(J<0)break;let Z=this.buffer.slice(0,J).match(/(?:^|\r\n)Content-Length:\s*(\d+)(?:\r\n|$)/i);if(!Z)throw Error("Invalid MCP stdio frame: missing Content-Length header.");let Q=Number.parseInt(Z[1],10),j=J+4,H=j+Q;if(this.buffer.length<H)break;f.push(this.buffer.slice(j,H)),this.buffer=this.buffer.slice(H)}return f}}class E5{buffer="";decoder=new p3("utf8");push($){this.buffer+=this.decoder.write($);let f=[];while(!0){let J=this.buffer.indexOf(`
|
|
164
|
+
`);if(J<0)break;let W=this.buffer.slice(0,J).trim();if(this.buffer=this.buffer.slice(J+1),W.length>0)f.push(W)}return f}}class r3{registration;process;nextRequestId=1;pending=new Map;framedParser=new C5;newlineParser=new E5;stderrBuffer="";connected=!1;protocolMode="newline";constructor($){this.registration=$}async connect(){if(this.connected)return;if(this.registration.transport.type!=="stdio")throw Error(`Unsupported MCP transport for "${this.registration.name}": ${this.registration.transport.type}`);let $=["newline","framed"],f;for(let J of $){await this.disconnect().catch(()=>{}),this.spawnProcess(J);try{await this.request("initialize",{protocolVersion:FU,capabilities:{},clientInfo:{name:"@cline/core",version:"0.0.0"}},RU),this.notify("notifications/initialized"),this.connected=!0,this.protocolMode=J;return}catch(W){f=W instanceof Error?W:Error(String(W))}}throw f??Error(`Failed to connect to MCP server "${this.registration.name}".`)}async disconnect(){let $=this.process;if(this.connected=!1,this.process=void 0,this.failAllPending(Error(`Disconnected from MCP server "${this.registration.name}".`)),!$)return;$.kill()}async listTools(){return((await this.request("tools/list")).tools??[]).filter((f)=>typeof f?.name==="string"&&typeof f.inputSchema==="object"&&f.inputSchema!==null).map((f)=>({name:f.name,description:f.description,inputSchema:f.inputSchema}))}async callTool($){return this.request("tools/call",{name:$.name,arguments:$.arguments??{}})}spawnProcess($){let f=this.registration.transport;if(f.type!=="stdio")throw Error(`Unsupported MCP transport for "${this.registration.name}": ${f.type}`);this.framedParser=new C5,this.newlineParser=new E5,this.stderrBuffer="",this.protocolMode=$;let J=process.platform==="win32"?{windowsHide:!0,shell:!0}:{},W=GU(f.command,f.args??[],{cwd:f.cwd,env:{...process.env,...f.env??{}},stdio:["pipe","pipe","pipe"],...J});this.process=W,W.stdout.on("data",(Z)=>this.handleStdout(Z)),W.stderr.on("data",(Z)=>{if(this.process!==W)return;if(this.stderrBuffer+=Z.toString("utf8"),this.stderrBuffer.length>16384)this.stderrBuffer=this.stderrBuffer.slice(-16384)}),W.once("error",(Z)=>{if(this.process!==W)return;this.failAllPending(Error(`MCP process error: ${BJ(Z)}`))}),W.once("exit",(Z,Q)=>{if(this.process!==W)return;this.connected=!1,this.process=void 0;let j=this.stderrBuffer.trim()?` stderr: ${this.stderrBuffer.trim()}`:"";this.failAllPending(Error(`MCP process exited for "${this.registration.name}" (code=${Z??"null"}, signal=${Q??"null"}).${j}`))})}handleStdout($){try{let f=this.protocolMode==="framed"?this.framedParser.push($):this.newlineParser.push($);for(let J of f){let W=JSON.parse(J);if(typeof W.id!=="number")continue;let Z=this.pending.get(W.id);if(!Z)continue;if(this.pending.delete(W.id),clearTimeout(Z.timeout),W.error){let Q=W.error.message||`MCP request failed with code ${W.error.code??"unknown"}`;Z.reject(Error(Q));continue}Z.resolve(W.result)}}catch(f){this.handleProtocolFailure(f)}}handleProtocolFailure($){let f=this.process;if(!f)return;this.connected=!1,this.process=void 0;let J=this.stderrBuffer.trim()?` stderr: ${this.stderrBuffer.trim()}`:"";this.failAllPending(Error(`Invalid MCP response from "${this.registration.name}": ${BJ($)}.${J}`)),f.kill()}async request($,f,J=UU){let W=this.process;if(!W?.stdin.writable)throw Error(`MCP server "${this.registration.name}" is not connected.`);let Z=this.nextRequestId++,Q={jsonrpc:"2.0",id:Z,method:$,...f?{params:f}:{}},j=new Promise((H,X)=>{let Y=setTimeout(()=>{this.pending.delete(Z),X(Error(`MCP request timed out for "${this.registration.name}" (${$}).`))},J);this.pending.set(Z,{resolve:H,reject:X,timeout:Y})});try{W.stdin.write(this.protocolMode==="framed"?d3(Q):l3(Q))}catch(H){let X=this.pending.get(Z);if(X)clearTimeout(X.timeout),this.pending.delete(Z);throw H}return j}notify($,f){let J=this.process;if(!J?.stdin.writable)return;let W={jsonrpc:"2.0",method:$,...f?{params:f}:{}};J.stdin.write(this.protocolMode==="framed"?d3(W):l3(W))}failAllPending($){for(let[f,J]of this.pending)clearTimeout(J.timeout),this.pending.delete(f),J.reject($)}}class i3{registration;options;client;authContext;constructor($,f){this.registration=$;this.options=f}async connect(){if(this.client)return;if(this.registration.transport.type==="stdio")throw Error(`Unsupported MCP transport for "${this.registration.name}": ${this.registration.transport.type}`);let $=VJ({settingsPath:this.options.settingsPath,serverName:this.registration.name,redirectUrl:this.registration.oauth?.redirectUrl??c3});this.authContext=$;try{let f=new PU({name:this.options.clientName?.trim()||"@cline/core",version:this.options.clientVersion?.trim()||"0.0.0"}),J=AJ({registration:this.registration,oauthProvider:$.provider,fetch:this.options.fetch});await f.connect(J),await $.clearError(),this.client=f}catch(f){let J=f instanceof u3?this.formatUnauthorizedMessage($.getLastAuthorizationUrl()):BJ(f);throw await $.markError(J),Error(J)}}async disconnect(){let $=this.client;this.client=void 0,await $?.close()}async listTools(){let $=await this.ensureConnectedClient();try{return(await $.listTools()).tools.map((J)=>({name:J.name,description:J.description,inputSchema:J.inputSchema&&typeof J.inputSchema==="object"&&!Array.isArray(J.inputSchema)?J.inputSchema:{}}))}catch(f){return await this.handleOperationError(f)}}async callTool($){let f=await this.ensureConnectedClient();try{return await f.callTool({name:$.name,arguments:$.arguments??{}})}catch(J){return await this.handleOperationError(J)}}async ensureConnectedClient(){if(!this.client)await this.connect();if(!this.client)throw Error(`MCP server "${this.registration.name}" is not connected.`);return this.client}formatUnauthorizedMessage($){let f=`MCP server "${this.registration.name}" requires OAuth authorization.`;if(!$)return`${f} Run authorizeMcpServerOAuth for this server.`;return`${f} Run authorizeMcpServerOAuth for this server and complete this URL: ${$}`}async handleOperationError($){let f=this.authContext??VJ({settingsPath:this.options.settingsPath,serverName:this.registration.name,redirectUrl:this.registration.oauth?.redirectUrl??c3}),J=$ instanceof u3?this.formatUnauthorizedMessage(f.getLastAuthorizationUrl()):BJ($);throw await f.markError(J),Error(J)}}function KJ($={}){return(f)=>f.transport.type==="stdio"?new r3(f):new i3(f,$)}YJ();function h0(){return Date.now()}function DU($){return $.map((f)=>({name:f.name,description:f.description,inputSchema:f.inputSchema}))}class J2{toolsCacheTtlMs;clientFactory;servers=new Map;operationLocks=new Map;constructor($){this.clientFactory=$.clientFactory,this.toolsCacheTtlMs=$.toolsCacheTtlMs??5000}async registerServer($){await this.runExclusive($.name,async()=>{let f=this.servers.get($.name);if(!f){this.servers.set($.name,{registration:{...$},status:"disconnected",updatedAt:h0()});return}let J=JSON.stringify(f.registration.transport)!==JSON.stringify($.transport);if(f.registration={...$},f.updatedAt=h0(),J)await this.disconnectState(f),f.client=void 0,f.toolCache=void 0,f.toolCacheUpdatedAt=void 0})}async unregisterServer($){await this.runExclusive($,async()=>{let f=this.requireServer($);await this.disconnectState(f),this.servers.delete($)})}async connectServer($){await this.runExclusive($,async()=>{let f=this.requireServer($);await this.connectState(f)})}async disconnectServer($){await this.runExclusive($,async()=>{let f=this.requireServer($);await this.disconnectState(f)})}async setServerDisabled($,f){await this.runExclusive($,async()=>{let J=this.requireServer($);if(J.registration={...J.registration,disabled:f},J.updatedAt=h0(),f)await this.disconnectState(J)})}listServers(){return[...this.servers.values()].map(($)=>({name:$.registration.name,status:$.status,disabled:$.registration.disabled===!0,lastError:$.lastError,toolCount:$.toolCache?.length??0,updatedAt:$.updatedAt,metadata:$.registration.metadata})).sort(($,f)=>$.name.localeCompare(f.name))}async listTools($){let f=this.requireServer($),J=f.toolCacheUpdatedAt??0;if(f.toolCache&&h0()-J<=this.toolsCacheTtlMs)return f.toolCache;return this.refreshTools($)}async refreshTools($){return this.runExclusive($,async()=>{let f=this.requireServer($),W=await(await this.ensureConnectedClient(f)).listTools(),Z=DU(W);return f.toolCache=Z,f.toolCacheUpdatedAt=h0(),f.updatedAt=h0(),Z})}async callTool($){return this.runExclusive($.serverName,async()=>{let f=this.requireServer($.serverName),J=await this.ensureConnectedClient(f);return f.updatedAt=h0(),J.callTool({name:$.toolName,arguments:$.arguments,context:$.context})})}async dispose(){let $=[...this.servers.keys()];for(let f of $)await this.unregisterServer(f)}async ensureConnectedClient($){if(await this.connectState($),!$.client)throw Error(`MCP server "${$.registration.name}" does not have an initialized client.`);return $.client}async connectState($){if($.registration.disabled)throw Error(`MCP server "${$.registration.name}" is disabled and cannot be connected.`);if($.status==="connected"&&$.client)return;$.status="connecting",$.updatedAt=h0();try{let f=$.client??await this.clientFactory($.registration);await f.connect(),$.client=f,$.status="connected",$.lastError=void 0,$.updatedAt=h0()}catch(f){throw $.status="disconnected",$.lastError=f instanceof Error?f.message:String(f),$.updatedAt=h0(),f}}async disconnectState($){if(!$.client){$.status="disconnected",$.updatedAt=h0();return}try{await $.client.disconnect()}finally{$.status="disconnected",$.updatedAt=h0()}}requireServer($){let f=this.servers.get($);if(!f)throw Error(`Unknown MCP server: ${$}`);return f}async runExclusive($,f){let J=this.operationLocks.get($)??Promise.resolve(),W,Z=new Promise((j)=>{W=j}),Q=J.catch(()=>{return}).then(()=>Z);this.operationLocks.set($,Q),await J.catch(()=>{return});try{return await f()}finally{if(W?.(),this.operationLocks.get($)===Q)this.operationLocks.delete($)}}}import{createHash as LU}from"node:crypto";var n3=128,OU=/[^a-zA-Z0-9_-]+/g,a3=8,_U=1,zU="mcp_tool";function TU($){return LU("sha1").update($).digest("hex").slice(0,a3)}function NU($){return $.replace(OU,"_")}var GJ=({serverName:$,toolName:f})=>{let J=`${$}__${f}`,W=NU(J);if(W===J&&J.length<=n3)return J;let Z=TU(J),Q=n3-_U-a3;return`${W.slice(0,Q)||zU}_${Z}`};function b5($){return{[($.nameTransform??GJ)({serverName:$.serverName,toolName:$.toolName})]:{enabled:!1}}}function t3($){let f={};for(let J of $.toolNames)Object.assign(f,b5({serverName:$.serverName,toolName:J,nameTransform:$.nameTransform}));return f}import{createTool as MU}from"@cline/shared";function yU($,f){let J=f.description?.trim();if(J)return J;return`Execute MCP tool "${f.name}" from server "${$}".`}async function PJ($){let f=await $.provider.listTools($.serverName),J=$.nameTransform??GJ;return f.map((W)=>{let Z=J({serverName:$.serverName,toolName:W.name});return MU({name:Z,description:yU($.serverName,W),inputSchema:W.inputSchema,timeoutMs:$.timeoutMs,retryable:$.retryable,maxRetries:$.maxRetries,execute:async(Q,j)=>$.provider.callTool({serverName:$.serverName,toolName:W.name,arguments:Q&&typeof Q==="object"&&!Array.isArray(Q)?Q:void 0,context:j})})})}n0();import{stat as qU}from"node:fs/promises";n0();var wU=32,Qf=new Map;function SU($,f){if(!Qf.has($)&&Qf.size>=wU){let J=Qf.keys().next().value;if(J)Qf.delete(J)}Qf.set($,f)}async function hU($){let f=await Promise.all($.pluginPaths.map(async(J)=>{try{let W=await qU(J);return`${J}:${W.mtimeMs}:${W.size}`}catch{return`${J}:missing`}}));return JSON.stringify({workspacePath:$.workspacePath,cwd:$.cwd,providerId:$.providerId,modelId:$.modelId,pathStats:f})}function s3($,f){return $.map((J)=>({...J,enabled:!f.has(J.name)}))}function CU($){return $.sort((f,J)=>{let W=f.name.localeCompare(J.name);if(W!==0)return W;return f.path.localeCompare(J.path)})}function EU($,f){if(!$.setup)return[];let J=[],W={registerTool:(Z)=>J.push(Z),registerCommand:()=>{},registerMessageBuilder:()=>{},registerRule:()=>{},registerProvider:()=>{},registerAutomationEventType:()=>{}};return $.setup(W,{workspaceInfo:f}),J}async function o3($){let f=Ef({workspacePath:$.workspacePath,cwd:$.cwd}),J=Q$($.disabledToolNames);if(f.length===0)return{tools:[],failures:[],warnings:[]};let W=await hU({pluginPaths:f,workspacePath:$.workspacePath,cwd:$.cwd,providerId:$.providerId,modelId:$.modelId}),Z=Qf.get(W);if(Z)return{tools:s3(Z.tools,J),failures:Z.failures,warnings:Z.warnings};let Q=[],j=[],H=[],X;try{X=await z8({pluginPaths:f,cwd:$.cwd,providerId:$.providerId,modelId:$.modelId,workspaceInfo:{rootPath:$.workspacePath}}),j=[...X.failures],H=[...X.warnings];for(let V of X.extensions??[]){let B=V.__clinePluginPath;if(!B)continue;for(let K of EU(V,{rootPath:$.workspacePath}))Q.push({name:K.name,pluginName:V.name,path:B,source:B.startsWith($.workspacePath)?"workspace-plugin":"global-plugin",description:K.description?.trim()||void 0})}}catch(V){j=f.map((B)=>({pluginPath:B,phase:"load",message:V instanceof Error?V.message:String(V),stack:V instanceof Error?V.stack:void 0}))}finally{await X?.shutdown().catch(()=>{})}let Y=CU(Q);return SU(W,{tools:Y,failures:j,warnings:H}),{tools:s3(Y,J),failures:j,warnings:H}}async function k5($){return(await o3($)).tools}function UJ($,f){if(!f)return"global";let J=kU(f,$);return!J.startsWith("..")&&!bU(J)?"workspace":"global"}function W2($){return[...$].sort((f,J)=>{let W=(Z)=>{switch(Z){case"workspace":case"workspace-plugin":return 0;case"global":case"global-plugin":return 1;case"builtin":return 2}};if(f.source!==J.source)return W(f.source)-W(J.source);return f.name.localeCompare(J.name)})}function fj($){return $.workspaceRoot?.trim()||$.cwd?.trim()||""}async function $j($,f){if($.userInstructionService)return await f($.userInstructionService);let J=fj($);if(!J)return await f(void 0);let W=$.cwd?.trim()||J,Z=Wf({skills:{workspacePath:J,includePluginSkills:!0,cwd:W},rules:{workspacePath:J},workflows:{workspacePath:J}});try{return await Z.start(),await f(Z)}finally{Z.stop()}}function IU($,f){if(!$)return;let J=$.listRecords("skill");if(f.id){let W=J.find((Z)=>Z.id===f.id);if(W)return W}for(let W of J)if(W.filePath===f.path||W.item.name===f.name||W.id===f.name)return W;return}class jf{async list($={}){return await $j($,async(f)=>{let J=fj($),W=[],Z=[],Q=[],j=[],H=[];if(f){for(let Y of f.listRecords("workflow")){let A=Y.item;W.push({id:Y.id,name:A.name,path:Y.filePath,enabled:A.disabled!==!0,kind:"workflow",source:UJ(Y.filePath,J),description:A.instructions,toggleable:!1})}for(let Y of f.listRecords("rule")){let A=Y.item;Z.push({id:Y.id,name:A.name,path:Y.filePath,enabled:A.disabled!==!0,kind:"rule",source:UJ(Y.filePath,J),description:A.instructions,toggleable:!1})}for(let Y of f.listRecords("skill")){let A=Y.item;Q.push({id:Y.id,name:A.name,path:Y.filePath,enabled:A.disabled!==!0,kind:"skill",source:UJ(Y.filePath,J),description:A.description,toggleable:!0})}}if(J)try{for(let Y of await k5({workspacePath:J,cwd:$.cwd,providerId:$.availabilityContext?.providerId,modelId:$.availabilityContext?.modelId}))j.push({id:`${Y.pluginName}:${Y.name}:${Y.path}`,name:Y.name,path:Y.path,enabled:Y.enabled,kind:"tool",source:Y.source,description:Y.description,toggleable:!0})}catch{}let X=S0();if(P1({filePath:X}))try{for(let Y of h$({filePath:X}))H.push({id:Y.name,name:Y.name,path:X,enabled:Y.disabled!==!0,kind:"mcp",source:UJ(X,J),description:Y.transport.type,toggleable:!0})}catch{}return{workflows:W2(W.filter((Y)=>FJ(Y.path))),rules:W2(Z.filter((Y)=>FJ(Y.path))),skills:W2(Q.filter((Y)=>FJ(Y.path))),tools:W2(j),mcp:W2(H.filter((Y)=>FJ(Y.path)))}})}async toggle($){if($.type==="skills")return await $j($,async(f)=>{let J=IU(f,$),W=J?.filePath;if(!W)throw Error(`Unable to resolve skill setting '${$.id??$.name??e3($.path??"")}'.`);let Z=J?.item&&"disabled"in J.item?J.item.disabled!==!0:void 0,Q=$.enabled??(Z!==void 0?!Z:void 0);if(Q===void 0)throw Error(`Cannot determine toggle state for skill '${$.id??$.name??e3($.path??"")}'; provide an explicit enabled value or a resolvable workspace context.`);return await h3({filePath:W,enabled:Q}),await f?.refreshType("skill"),{snapshot:await this.list({...$,userInstructionService:f}),changedTypes:["skills"]}});if($.type==="tools"){if(!$.name?.trim())throw Error("Tool settings toggle requires a tool name.");if($.enabled===void 0)M6($.name);else UQ($.name,!$.enabled);return{snapshot:await this.list($),changedTypes:["tools"]}}if($.type==="mcp"){let f=$.name?.trim()||$.id?.trim();if(!f)throw Error("MCP server settings toggle requires a server name.");let J=$.path?.trim()||S0(),W=$.enabled;if(W===void 0){let Z=h$({filePath:J}).find((Q)=>Q.name===f);if(!Z)throw Error(`Unknown MCP server: ${f}`);W=Z.disabled===!0}return of({filePath:J,name:f,disabled:!W}),{snapshot:await this.list($),changedTypes:["mcp"]}}throw Error(`Settings type '${$.type}' does not support toggles.`)}}function Z2(){return new jf}function Jj($){return{async list(f){let J=$;if(J.listSettings)return await J.listSettings(f);return await Z2().list(f)},async toggle(f){let J=$;if(J.toggleSetting)return await J.toggleSetting(f);return await Z2().toggle(f)}}}function Wj($){function f(){let J=$.pendingPrompts;if(!J)throw Error("Pending prompt service is not available.");return J}return{list(J){return f().list(J)},update(J){return f().update(J)},delete(J){return f().delete(J)}}}function U0(...$){let f,J;for(let Z of $){if(!Z)continue;if(Z.toolExecutors)f={...f??{},...Z.toolExecutors};if(Z.requestToolApproval)J=Z.requestToolApproval}let W=f&&Object.keys(f).length>0;if(!W&&!J)return;return{...W?{toolExecutors:f}:{},...J?{requestToolApproval:J}:{}}}var Q2="session_not_found";class F1 extends Error{sessionId;code="session_not_found";constructor($,f){super(f??($?`session not found: ${$}`:"session not found"));this.sessionId=$;this.name="SessionNotFoundError"}}function U1($){return $ instanceof F1||typeof $==="object"&&$!==null&&"code"in $&&$.code==="session_not_found"}function I5($){let{hooks:f,logger:J,telemetry:W,extensionContext:Z,extraTools:Q,extensions:j,onTeamEvent:H,onConsecutiveMistakeLimitReached:X,checkpoint:Y,compaction:A,...V}=$,B={};if(f)B.hooks=f;if(J)B.logger=J;if(W)B.telemetry=W;if(Z)B.extensionContext=Z;if(Q)B.extraTools=Q;if(j)B.extensions=j;if(H)B.onTeamEvent=H;if(X)B.onConsecutiveMistakeLimitReached=X;if(Y?.createCheckpoint)B.checkpoint=Y;if(A?.compact)B.compaction=A;let K=Object.keys(B).length>0?B:void 0;return{config:{...V,...Y?{checkpoint:{enabled:Y.enabled}}:{},...A?{compaction:{enabled:A.enabled,strategy:A.strategy,thresholdRatio:A.thresholdRatio,reserveTokens:A.reserveTokens,preserveRecentTokens:A.preserveRecentTokens,maxInputTokens:A.maxInputTokens,summarizer:A.summarizer}}:{}},...K?{localRuntime:K}:{}}}function Zj($){let f=$.config;return"providerId"in f?{...$,config:{...f,...xU($.localRuntime)},localRuntime:$.localRuntime}:$}function x5($,f={}){let J=I5($.config),W=U0(f.defaultCapabilities,$.capabilities),Z=mU(J.localRuntime,$.localRuntime),Q=f.withExtensionContext?.(Z?.extensionContext);if(Q)Z={...Z??{},extensionContext:Q};return{...$,...J,...Z?{localRuntime:Z}:{},...W?{capabilities:W}:{}}}function xU($){if(!$)return{};let{modelCatalogDefaults:f,userInstructionService:J,configExtensions:W,onTeamRestored:Z,...Q}=$;return Q}function mU(...$){let f={};for(let J of $)if(J)Object.assign(f,J);return Object.keys(f).length>0?f:void 0}B0();function Qj($){let f=$.input.config.telemetry??$.telemetry;if(!f)return;f.capture({event:k.SESSION.STARTED,properties:{sessionId:$.sessionId,source:$.input.source??F0.CORE,providerId:$.input.config.providerId,modelId:$.input.config.modelId,enableTools:$.input.config.enableTools,enableSpawnAgent:$.input.config.enableSpawnAgent,enableAgentTeams:$.input.config.enableAgentTeams,clientName:$.clientName,runtimeAddress:$.runtimeAddress}})}function j2($){return!!$&&typeof $==="object"&&!Array.isArray($)}function m5($){let f=$?.trim();return f?f:void 0}function gU($,f){let J=$?.trim();if(!J)return f;let W=Date.parse(J);if(!Number.isFinite(W))return f;return new Date(W).toISOString()}function jj($,f){return new Date(new Date($).getTime()+Math.max(0,Math.floor(f))*1000).toISOString()}function Hj($,f){return new Date(new Date($).getTime()-Math.max(0,Math.floor(f))*1000).toISOString()}function vU($,f){if(!$)return f;return new Date($).getTime()>=new Date(f).getTime()?$:f}function uU($,f){let J=$.eventId.trim(),W=$.eventType.trim(),Z=$.source.trim(),Q=m5($.subject),j=m5($.dedupeKey)??`${W}:${Z}:${Q??J}`;return{eventId:J,eventType:W,source:Z,subject:Q,occurredAt:gU($.occurredAt,f),workspaceRoot:m5($.workspaceRoot),payload:j2($.payload)?$.payload:void 0,attributes:j2($.attributes)?$.attributes:void 0,dedupeKey:j}}function g5($,f){if(!f)return;let J=f.split("."),W=$;for(let Z of J){if(!j2(W))return;W=W[Z]}return W}function cU($,f){if($.attributes&&Object.hasOwn($.attributes,f))return $.attributes[f];if($.payload&&Object.hasOwn($.payload,f))return $.payload[f];let J={eventId:$.eventId,eventType:$.eventType,source:$.source,subject:$.subject,occurredAt:$.occurredAt,workspaceRoot:$.workspaceRoot,dedupeKey:$.dedupeKey,attributes:$.attributes,payload:$.payload},W=g5(J,f);if(W!==void 0)return W;if($.attributes){let Z=g5($.attributes,f);if(Z!==void 0)return Z}if($.payload)return g5($.payload,f);return}function RJ($,f){if(Array.isArray(f))return f.some((J)=>RJ($,J));if(Array.isArray($))return $.some((J)=>RJ(J,f));if(j2(f)){if(!j2($))return!1;return Object.entries(f).every(([J,W])=>RJ($[J],W))}return Object.is($,f)}function dU($,f){if(!f||Object.keys(f).length===0)return!0;return Object.entries(f).every(([J,W])=>RJ(cU($,J),W))}class v5{store;nowFn;logger;constructor($){this.store=$.store,this.nowFn=$.now??(()=>Date.now()),this.logger=$.logger}ingestEvent($){let f=new Date(this.nowFn()).toISOString(),J=uU($,f),W=this.store.insertEventLog(J,{receivedAtIso:f});if(!W.created)return this.logger?.debug("cron.event.duplicate",{eventId:W.record.eventId,eventType:W.record.eventType,source:W.record.source}),{event:W.record,duplicate:!0,matchedSpecs:[],queuedRuns:[],suppressions:[{reason:"duplicate_event",dedupeKey:W.record.dedupeKey}]};try{let Z=this.store.listEventSpecsForType(J.eventType),Q=[],j=[],H=[];for(let A of Z){if(!dU(J,A.filters)){Q.push({specId:A.specId,externalId:A.externalId,reason:"filter_mismatch",dedupeKey:J.dedupeKey});continue}j.push(A);let V=this.materializeForSpec(A,J,W.record.receivedAt);if(V.run)H.push(V.run);else Q.push({specId:A.specId,externalId:A.externalId,reason:V.reason,dedupeKey:J.dedupeKey})}let X=j.length===0?"unmatched":H.length>0?"queued":"suppressed";this.store.updateEventLogProcessing(W.record.eventId,{status:X,matchedSpecCount:j.length,queuedRunCount:H.length,suppressedCount:Q.filter((A)=>A.reason!=="filter_mismatch").length});let Y=this.store.getEventLog(W.record.eventId);return this.logger?.debug("cron.event.processed",{eventId:W.record.eventId,eventType:W.record.eventType,status:X,matchedSpecCount:j.length,queuedRunCount:H.length}),{event:Y??W.record,duplicate:!1,matchedSpecs:j,queuedRuns:H,suppressions:Q}}catch(Z){if(this.store.updateEventLogProcessing(W.record.eventId,{status:"failed",error:Z instanceof Error?Z.message:String(Z)}),this.logger?.error)this.logger.error("cron.event.failed",{eventId:W.record.eventId,eventType:W.record.eventType,error:Z});throw Z}}materializeForSpec($,f,J){let W=f.dedupeKey??f.eventId,Z=$.debounceSeconds??0;if(Z>0){let X=this.store.findQueuedEventRunForDedupe({specId:$.specId,dedupeKey:W});if(X){let Y=vU(X.scheduledFor,jj(J,Z)),A=this.store.updateQueuedEventRunForDebounce({runId:X.runId,triggerEventId:f.eventId,scheduledFor:Y});if(A)return{run:A,reason:"dedupe_window"}}}let Q=$.dedupeWindowSeconds??0;if(Q>0&&this.store.hasRecentEventRunForDedupe({specId:$.specId,dedupeKey:W,sinceIso:Hj(J,Q)}))return{reason:"dedupe_window"};let j=$.cooldownSeconds??0;if(j>0&&this.store.hasRecentEventRunForSpec({specId:$.specId,sinceIso:Hj(J,j)}))return{reason:"cooldown"};return{run:this.store.enqueueRun({specId:$.specId,specRevision:$.revision,triggerKind:"event",triggerEventId:f.eventId,scheduledFor:Z>0?jj(J,Z):J}),reason:"dedupe_window"}}}class H2{store;nowFn;constructor($){this.store=$.store,this.nowFn=$.now??(()=>Date.now())}materializeAll(){let $={oneOffQueued:0,scheduleQueued:0},f=this.store.listSpecs({triggerKind:"one_off",enabled:!0,parseStatus:"valid"});for(let W of f)if(this.materializeOneOff(W))$.oneOffQueued+=1;let J=this.store.listSpecs({triggerKind:"schedule",enabled:!0,parseStatus:"valid"});for(let W of J)try{if(this.materializeSchedule(W))$.scheduleQueued+=1}catch{}return $}materializeOneOff($){if($.triggerKind!=="one_off")return!1;if(!$.enabled||$.removed)return!1;if(this.store.hasOneOffRunForRevision($.specId,$.revision))return!1;return this.store.enqueueRun({specId:$.specId,specRevision:$.revision,triggerKind:"one_off",scheduledFor:new Date(this.nowFn()).toISOString()}),!0}materializeSchedule($){if($.triggerKind!=="schedule")return!1;if(!$.enabled||$.removed)return!1;if(!$.scheduleExpr)return!1;return this.store.materializeDueScheduleRun({specId:$.specId,nowMs:this.nowFn()}).queued}}import{basename as eU}from"node:path";import{buildClineSystemPrompt as $R}from"@cline/shared";import{nowIso as Vj}from"@cline/shared/db";import{basename as lU,resolve as pU}from"node:path";import{performance as Xj}from"node:perf_hooks";import{processWorkspaceInfo as Yj}from"@cline/shared";import rU from"simple-git";function R1($){return pU($)}async function LJ($){return(await u5($)).info}function DJ($){if($ instanceof Error)return{errorType:$.name?.trim()||$.constructor.name||"Error",message:$.message};return{errorType:"Error",message:String($)}}async function u5($){let f=R1($),J={rootPath:f,hint:lU(f)},W;try{let Z=rU({baseDir:f});if(!await Z.checkIsRepo())return{info:J,vcsType:"none"};try{let j=await Z.getRemotes(!0);if(j.length>0){let H=j.map((X)=>{let Y=X.refs.fetch||X.refs.push;return`${X.name}: ${Y}`});J.associatedRemoteUrls=H}}catch(j){W??=DJ(j)}try{let j=(await Z.revparse(["HEAD"])).trim();if(j.length>0)J.latestGitCommitHash=j}catch(j){W??=DJ(j)}try{let j=(await Z.branch()).current.trim();if(j.length>0)J.latestGitBranchName=j}catch(j){W??=DJ(j)}return{info:J,vcsType:"git",error:W}}catch(Z){return{info:J,vcsType:"none",error:DJ(Z)}}}async function c5($){let f=await LJ($);return Yj(f)}async function Aj($){let f=Xj.now(),J=await u5($),W=Xj.now()-f,Z=J.info;return{workspaceInfo:Z,workspaceMetadata:Yj(Z),durationMs:W,vcsType:J.vcsType,initError:J.error}}import{mkdirSync as iU,writeFileSync as nU}from"node:fs";import{join as aU}from"node:path";import{resolveCronReportsDir as tU}from"@cline/shared/storage";function C$($){if(/[:#\n]/.test($)||$.includes('"'))return JSON.stringify($);return $}function D1($,f){if(f===void 0||f===null)return;return`${$}: ${C$(f)}`}function sU($,f,J){let W=[`runId: ${C$($.runId)}`,`specId: ${C$(f.specId)}`,`externalId: ${C$(f.externalId)}`,`title: ${C$(f.title)}`,`triggerKind: ${C$($.triggerKind)}`,`status: ${C$($.status)}`,`sourcePath: ${C$(f.sourcePath)}`],Z=[D1("sessionId",$.sessionId),D1("startedAt",$.startedAt),D1("completedAt",$.completedAt),D1("triggerEventId",$.triggerEventId),D1("triggerEventType",J?.eventType),D1("triggerEventSource",J?.source),D1("triggerEventSubject",J?.subject)];for(let Q of Z)if(Q)W.push(Q);return`---
|
|
165
|
+
${W.join(`
|
|
166
166
|
`)}
|
|
167
167
|
---
|
|
168
|
-
`}function
|
|
168
|
+
`}function oU($){let f=[];if($.triggerEvent){let J=$.triggerEvent,W=[`- eventId: ${J.eventId}`,`- eventType: ${J.eventType}`,`- source: ${J.source}`,J.subject?`- subject: ${J.subject}`:"",`- occurredAt: ${J.occurredAt}`,J.dedupeKey?`- dedupeKey: ${J.dedupeKey}`:"",J.attributes?`- attributes: ${JSON.stringify(J.attributes)}`:""].filter((Z)=>Z.length>0);f.push(`## Trigger Event
|
|
169
169
|
|
|
170
|
-
${
|
|
170
|
+
${W.join(`
|
|
171
171
|
`)}
|
|
172
172
|
`)}if($.error)f.push(`## Error
|
|
173
173
|
|
|
@@ -175,26 +175,26 @@ ${$.error}
|
|
|
175
175
|
`);if($.finalText&&$.finalText.trim().length>0)f.push(`## Summary
|
|
176
176
|
|
|
177
177
|
${$.finalText.trim()}
|
|
178
|
-
`);if($.usage){let J=$.usage,
|
|
178
|
+
`);if($.usage){let J=$.usage,W=[J.inputTokens!==void 0?`- inputTokens: ${J.inputTokens}`:"",J.outputTokens!==void 0?`- outputTokens: ${J.outputTokens}`:"",J.cacheReadTokens!==void 0?`- cacheReadTokens: ${J.cacheReadTokens}`:"",J.cacheWriteTokens!==void 0?`- cacheWriteTokens: ${J.cacheWriteTokens}`:"",J.totalCost!==void 0?`- totalCostUsd: ${J.totalCost}`:"",$.durationMs!==void 0?`- durationMs: ${$.durationMs}`:""].filter((Z)=>Z.length>0);if(W.length>0)f.push(`## Usage
|
|
179
179
|
|
|
180
|
-
${
|
|
180
|
+
${W.join(`
|
|
181
181
|
`)}
|
|
182
|
-
`)}if($.toolCalls&&$.toolCalls.length>0){let J=$.toolCalls.map((
|
|
182
|
+
`)}if($.toolCalls&&$.toolCalls.length>0){let J=$.toolCalls.map((W)=>{let Z=[`- ${W.name}`];if(W.durationMs!==void 0)Z.push(`(${W.durationMs}ms)`);if(W.error)Z.push(`error: ${W.error}`);return Z.join(" ")});f.push(`## Tool Calls
|
|
183
183
|
|
|
184
184
|
${J.join(`
|
|
185
185
|
`)}
|
|
186
186
|
`)}return f.join(`
|
|
187
|
-
`)}function
|
|
188
|
-
${
|
|
189
|
-
`)}class
|
|
187
|
+
`)}function d5($){let f=tU($.specs);iU(f,{recursive:!0});let J=aU(f,`${$.run.runId}.md`),W=`${sU($.run,$.spec,$.data.triggerEvent)}
|
|
188
|
+
${oU($.data)}`;return nU(J,W,"utf8"),J}class l5{globalMaxConcurrency;activeExecutions=new Map;constructor($){this.globalMaxConcurrency=Math.max(1,Math.floor($))}acquire($,f,J){if(this.getGlobalActiveCount()>=this.globalMaxConcurrency)return!1;let W=Math.max(1,Math.floor(J)),Z=this.activeExecutions.get($)??new Set;if(Z.size>=W)return!1;return Z.add(f),this.activeExecutions.set($,Z),!0}release($,f){let J=this.activeExecutions.get($);if(!J)return;if(J.delete(f),J.size===0)this.activeExecutions.delete($)}getGlobalActiveCount(){let $=0;for(let f of this.activeExecutions.values())$+=f.size;return $}}var fR=15000,JR=90,Bj=["rules","skills","plugins"];function WR($,f){return new Set($.extensions??Bj).has(f)}function ZR($,f){if($.tools===void 0)return{"*":{autoApprove:!0}};let J={"*":{enabled:!1,autoApprove:!0}};for(let W of $.tools)J[W]={enabled:!0,autoApprove:!0};if(f==="yolo")J[j0.SUBMIT_AND_EXIT]={enabled:!0,autoApprove:!0};return J}function QR($){let f=$?.trim();if(!f)return;return["# Notes Directory",`Use ${f} for durable notes related to this automation.`,"Before starting, inspect relevant existing notes there when useful. During or after the run, write concise notes there when they would help future runs continue with context."].join(`
|
|
189
|
+
`)}class p5 extends Error{constructor($){super($);this.name="TimeoutError"}}async function jR($,f){if(f<=0)return $;let J,W=new Promise((Z,Q)=>{J=setTimeout(()=>{Q(new p5("cron run timed out"))},f)});try{return await Promise.race([$,W])}finally{if(J)clearTimeout(J)}}class X2{store;materializer;options;limiter;claimLeaseMs;timer;started=!1;ticking=!1;disposed=!1;stopping=!1;activeRuns=new Map;constructor($){this.store=$.store,this.materializer=$.materializer,this.options=$,this.limiter=new l5($.globalMaxConcurrency??10),this.claimLeaseMs=Math.max(5000,($.claimLeaseSeconds??JR)*1000)}async start(){if(this.disposed)throw Error("CronRunner disposed");if(this.started)return;this.stopping=!1,this.started=!0;let $=Math.max(2000,this.options.pollIntervalMs??fR);await this.tick(),this.timer=setInterval(()=>void this.tick(),$)}async stop(){let $=this.started;if(this.started=!1,this.stopping=!0,this.timer)clearInterval(this.timer),this.timer=void 0;if(!$)return;let f=[...this.activeRuns.entries()];await Promise.all(f.map(async([J,W])=>{if(W.sessionId)try{await this.options.runtimeHandlers.abortSession(W.sessionId)}catch{}try{this.store.requeueRun({runId:J,claimToken:W.claimToken,error:"runner stopped before completion"})}catch{}}))}async dispose(){if(this.disposed)return;this.disposed=!0,await this.stop()}async tick(){if(this.ticking)return;this.ticking=!0;try{this.materializer.materializeAll();let $=this.store.claimDueRuns({nowIso:Vj(),leaseMs:this.claimLeaseMs});await Promise.allSettled($.map((f)=>this.executeClaim(f)))}catch($){let f=this.options.logger;if(f)if(f.error)f.error("cron.runner.tick.failed",{error:$});else f.log("cron.runner.tick.failed",{error:$})}finally{this.ticking=!1}}getActiveRuns(){return[...this.activeRuns.entries()].flatMap(([$,f])=>{let J=this.store.getRun($);return J?[{...J,...f}]:[]})}async executeClaim($){let f=$.run,J=this.store.getSpec(f.specId);if(!J){this.store.completeRun(f.runId,{status:"failed",error:"spec not found",claimToken:$.claimToken});return}if(!J.enabled||J.removed){this.store.completeRun(f.runId,{status:"cancelled",error:"spec disabled or removed",claimToken:$.claimToken});return}let W=J.maxParallel&&J.maxParallel>0?J.maxParallel:1;if(!this.limiter.acquire(J.specId,f.runId,W)){this.store.requeueRun({runId:f.runId,claimToken:$.claimToken,error:"concurrency limit reached"});return}if(this.stopping){this.limiter.release(J.specId,f.runId),this.store.requeueRun({runId:f.runId,claimToken:$.claimToken,error:"runner stopped before execution"});return}this.activeRuns.set(f.runId,{claimToken:$.claimToken});let Q=f.triggerEventId?this.store.getEventLog(f.triggerEventId):void 0,j,H,X=Date.now(),Y;if(J.timeoutSeconds&&J.timeoutSeconds>0)Y=X+J.timeoutSeconds*1000;try{H=this.startClaimLeaseHeartbeat($);let A=await this.buildStartRequest(J);if(j=(await this.options.runtimeHandlers.startSession(A)).sessionId.trim(),!j)throw Error("runtime returned empty sessionId");this.activeRuns.set(f.runId,{claimToken:$.claimToken,sessionId:j}),this.store.attachSessionIdToRun(f.runId,j);let B={config:A,prompt:this.buildPrompt(J,Q)},K=this.options.runtimeHandlers.sendSession(j,B),G=Y?Math.max(1,Y-Date.now()):0,P=(await jR(K,G)).result,F=Date.now(),U=d5({specs:this.options.specs,workspaceRoot:this.options.workspaceRoot,run:{...f,sessionId:j,status:"done"},spec:J,data:{finalText:P.text,usage:P.usage,toolCalls:P.toolCalls,durationMs:F-X,triggerEvent:Q}});this.store.completeRun(f.runId,{status:"done",sessionId:j,reportPath:U,claimToken:$.claimToken}),this.publishScheduleExecutionEvent("schedule.execution.completed",J,f.runId),this.store.updateSpecLastRunAt(J.specId,Vj())}catch(A){let V=A instanceof p5;if(j&&V)try{await this.options.runtimeHandlers.abortSession(j)}catch{}let B=A instanceof Error?A.message:String(A),K=Date.now(),G=d5({specs:this.options.specs,workspaceRoot:this.options.workspaceRoot,run:{...f,sessionId:j,status:"failed"},spec:J,data:{error:B,durationMs:K-X,triggerEvent:Q}});this.store.completeRun(f.runId,{status:"failed",sessionId:j,reportPath:G,error:B,claimToken:$.claimToken}),this.publishScheduleExecutionEvent("schedule.execution.failed",J,f.runId)}finally{if(H?.(),j)try{await this.options.runtimeHandlers.stopSession(j)}catch{}this.activeRuns.delete(f.runId),this.limiter.release(J.specId,f.runId)}}publishScheduleExecutionEvent($,f,J){if(f.source!=="hub-schedule"||!this.options.eventPublisher)return;let W=this.store.getRun(J);if(!W)return;let Z=W.status==="done"?"success":W.status==="cancelled"?"aborted":W.status==="running"?"running":W.status==="queued"?"pending":"failed";this.options.eventPublisher($,{scheduleId:f.externalId,executionId:W.runId,sessionId:W.sessionId,triggeredAt:new Date(W.scheduledFor??W.createdAt).getTime(),startedAt:W.startedAt?new Date(W.startedAt).getTime():void 0,endedAt:W.completedAt?new Date(W.completedAt).getTime():void 0,status:Z,errorMessage:W.error})}buildPrompt($,f){let J=$.prompt??"";if(!f)return J;let W={eventId:f.eventId,eventType:f.eventType,source:f.source,subject:f.subject,occurredAt:f.occurredAt,workspaceRoot:f.workspaceRoot,dedupeKey:f.dedupeKey,attributes:f.attributes,payload:f.payload};return`${J}
|
|
190
190
|
|
|
191
191
|
Trigger event:
|
|
192
|
-
${JSON.stringify(
|
|
192
|
+
${JSON.stringify(W,null,2)}`}startClaimLeaseHeartbeat($){let f=Math.max(1000,Math.floor(this.claimLeaseMs/2)),J=setInterval(()=>{let W=new Date(Date.now()+this.claimLeaseMs).toISOString();if(!this.store.renewClaim($.run.runId,$.claimToken,W))clearInterval(J)},f);return()=>clearInterval(J)}async buildSystemPrompt($,f,J,W){let Z=QR($.notesDirectory),Q=k8(void 0,Z),j=await c5(f),H=$R({ide:"Cline Cron",workspaceRoot:f,workspaceName:eU(f),metadata:j,rules:$.systemPrompt?void 0:Q,mode:J,providerId:W,overridePrompt:$.systemPrompt,platform:typeof process<"u"&&process?.platform||"unknown"});return $.systemPrompt?k8(H,Q)??H:H}async buildStartRequest($){let f=($.workspaceRoot??"").trim(),J=($.providerId??"").trim(),W=($.modelId??"").trim(),Z=$.metadata?.__hubRuntimeOptions&&typeof $.metadata.__hubRuntimeOptions==="object"&&!Array.isArray($.metadata.__hubRuntimeOptions)?$.metadata.__hubRuntimeOptions:void 0,Q=typeof $.metadata?.__hubScheduleCwd==="string"&&$.metadata.__hubScheduleCwd.trim()?$.metadata.__hubScheduleCwd.trim():f;if(!f)throw Error("cron spec requires workspaceRoot");let j=$.mode==="plan"?"plan":$.mode==="act"?"act":"yolo";return{workspaceRoot:f,cwd:Q,provider:J,model:W,mode:j,source:$.source?.trim()||"user",systemPrompt:await this.buildSystemPrompt($,f,j,J),maxIterations:$.maxIterations,enableTools:Z?.enableTools??!0,enableSpawn:Z?.enableSpawn??!0,enableTeams:Z?.enableTeams??!0,autoApproveTools:Z?.autoApproveTools??!0,toolPolicies:ZR($,j),configExtensions:Bj.filter((H)=>WR($,H))}}}import{existsSync as wR,readdirSync as SR,readFileSync as hR,statSync as CR}from"node:fs";import{relative as ER}from"node:path";import{resolveCronSpecsDir as bR}from"@cline/shared/storage";function Y2($,f,J,W){let Z=new Set;function Q(j){let H=j.toLowerCase();if(W){let Y=W.indexOf(H);if(Y!==-1)return Y+f}let X=Number(j);if(!Number.isInteger(X)||X<f||X>J)throw Error(`Invalid cron value "${j}" for range [${f}-${J}]`);return X}for(let j of $.split(",")){if(j==="*"){for(let Y=f;Y<=J;Y+=1)Z.add(Y);continue}let H=j.indexOf("/");if(H!==-1){let Y=j.slice(0,H),A=Number(j.slice(H+1));if(!Number.isInteger(A)||A<1)throw Error(`Invalid step "${j.slice(H+1)}"`);let V=f,B=J;if(Y!=="*"){let K=Y.indexOf("-");if(K!==-1)V=Q(Y.slice(0,K)),B=Q(Y.slice(K+1));else V=Q(Y)}if(V>B)throw Error(`Invalid cron range "${Y}"`);for(let K=V;K<=B;K+=A)Z.add(K);continue}let X=j.indexOf("-");if(X!==-1){let Y=Q(j.slice(0,X)),A=Q(j.slice(X+1));if(Y>A)throw Error(`Invalid cron range "${j}"`);for(let V=Y;V<=A;V+=1)Z.add(V);continue}Z.add(Q(j))}return[...Z].sort((j,H)=>j-H)}var HR=["jan","feb","mar","apr","may","jun","jul","aug","sep","oct","nov","dec"],Gj=["sun","mon","tue","wed","thu","fri","sat"];function A2($,f,J){let W=$[f];if(typeof W!=="string")throw Error(`Invalid cron pattern "${J}": missing field ${f+1}`);return W}function r5($,f){let J=$[0];if(typeof J!=="number")throw Error(`Invalid cron pattern: no values parsed for ${f}`);return J}function i5($){let f=$.trim().split(/\s+/);if(f.length!==5)throw Error(`Invalid cron pattern "${$}": expected 5 fields, got ${f.length}`);return{minutes:Y2(A2(f,0,$),0,59),hours:Y2(A2(f,1,$),0,23),daysOfMonth:Y2(A2(f,2,$),1,31),months:Y2(A2(f,3,$),1,12,HR),daysOfWeek:Y2(A2(f,4,$),0,6,Gj)}}function n5($){i5($)}function Pj($,f,J=Date.now()){L1($,J,f)}var Kj=new Map,XR=new Map(Gj.map(($,f)=>[$,f]));function Fj($){let f=$?.trim();return f?f:void 0}function Uj($){let f=Kj.get($);if(f)return f;let J=new Intl.DateTimeFormat("en-US",{timeZone:$,calendar:"gregory",numberingSystem:"latn",year:"numeric",month:"2-digit",day:"2-digit",weekday:"short",hour:"2-digit",minute:"2-digit",hourCycle:"h23"});return Kj.set($,J),J}function YR($){let f=Fj($);if(!f)return;Uj(f).format(new Date)}function AR($,f){let J=Uj(f).formatToParts(new Date($)),W=new Map(J.map((j)=>[j.type,j.value])),Z=W.get("weekday")?.toLowerCase().slice(0,3)??"",Q=XR.get(Z);if(Q===void 0)throw Error(`Unable to resolve weekday for timezone "${f}"`);return{month:Number(W.get("month")),dayOfMonth:Number(W.get("day")),dayOfWeek:Q,hour:Number(W.get("hour")),minute:Number(W.get("minute"))}}function VR($){let f=new Date($);return{month:f.getMonth()+1,dayOfMonth:f.getDate(),dayOfWeek:f.getDay(),hour:f.getHours(),minute:f.getMinutes()}}function BR($,f){return $.months.includes(f.month)&&$.daysOfMonth.includes(f.dayOfMonth)&&$.daysOfWeek.includes(f.dayOfWeek)&&$.hours.includes(f.hour)&&$.minutes.includes(f.minute)}function KR($,f,J){let W=i5($),Z=new Date(f);Z.setSeconds(0,0);let Q=Z.getTime()+60000,j=new Date(f);j.setFullYear(j.getFullYear()+4);let H=j.getTime();while(Q<=H){if(BR(W,AR(Q,J)))return Q;Q+=60000}throw Error(`No cron occurrence found within 4 years for pattern "${$}" in timezone "${J}"`)}function L1($,f,J){let W=Fj(J);if(W)return YR(W),KR($,f,W);let Z=i5($),Q=new Date(f);Q.setSeconds(0,0),Q=new Date(Q.getTime()+60000);let j=new Date(f);j.setFullYear(j.getFullYear()+4);while(Q<=j){let{month:H,dayOfMonth:X,dayOfWeek:Y,hour:A,minute:V}=VR(Q.getTime());if(!Z.months.includes(H)){let B=Z.months.find((G)=>G>H)??r5(Z.months,"months"),K=B<=H?1:0;Q=new Date(Q.getFullYear()+K,B-1,1,0,0,0,0);continue}if(!Z.daysOfMonth.includes(X)||!Z.daysOfWeek.includes(Y)){Q=new Date(Q.getFullYear(),Q.getMonth(),X+1,0,0,0,0);continue}if(!Z.hours.includes(A)){let B=Z.hours.find((G)=>G>A)??r5(Z.hours,"hours"),K=B<=A?1:0;Q=new Date(Q.getFullYear(),Q.getMonth(),Q.getDate()+K,B,0,0,0);continue}if(!Z.minutes.includes(V)){let B=Z.minutes.find((G)=>G>V)??r5(Z.minutes,"minutes"),K=B<=V?1:0;Q=new Date(Q.getFullYear(),Q.getMonth(),Q.getDate(),Q.getHours()+K,B,0,0);continue}return Q.getTime()}throw Error(`No cron occurrence found within 4 years for pattern "${$}"`)}import{createHash as GR}from"node:crypto";import PR from"yaml";function FR($){let f=$.replace(/\\/g,"/");if(f.startsWith("events/")&&f.endsWith(".event.md"))return"event";if(f.endsWith(".cron.md"))return"schedule";return"one_off"}function UR($){let f=$.replace(/\r\n/g,`
|
|
193
193
|
`);if(!f.startsWith(`---
|
|
194
|
-
`))return{frontmatter:void 0,body:$};let J=f.slice(4),
|
|
195
|
-
---`);if(
|
|
196
|
-
`))
|
|
197
|
-
`),J.update(f),J.digest("hex")}function
|
|
194
|
+
`))return{frontmatter:void 0,body:$};let J=f.slice(4),W=J.indexOf(`
|
|
195
|
+
---`);if(W===-1)return{frontmatter:void 0,body:$};let Z=J.slice(0,W),Q=J.slice(W+4);if(Q.startsWith(`
|
|
196
|
+
`))Q=Q.slice(1);return{frontmatter:Z,body:Q}}function C0($){if(typeof $!=="string")return;let f=$.trim();return f.length>0?f:void 0}function RR($){if(!Array.isArray($))return;let f=$.map((J)=>typeof J==="string"?J.trim():"").filter((J)=>J.length>0);return f.length>0?f:void 0}function s5($){if(!$||typeof $!=="object"||Array.isArray($))return;return $}function DR($){let f=s5($);if(!f)return;let J=C0(f.providerId),W=C0(f.modelId);if(J===void 0&&W===void 0)return;return{providerId:J,modelId:W}}function LR($){if(typeof $!=="string")return;let f=$.trim().toLowerCase();if(f==="act"||f==="plan"||f==="yolo")return f;return}function Dj($,f={}){let J=Array.isArray($)?$:typeof $==="string"?$.split(","):void 0;if(!J)return;let W=[...new Set(J.map((Z)=>typeof Z==="string"?Z.trim():"").filter((Z)=>Z.length>0))];if(Array.isArray($)&&f.preserveEmptyArray)return W;return W.length>0?W:void 0}var OR=new Set(s1);function _R($){let f=Dj($,{preserveEmptyArray:!0});if(!f)return;let J=f.filter((W)=>!OR.has(W));if(J.length>0)throw Error(`unknown tool(s): ${J.join(", ")}`);return f}var zR=new Set(["rules","skills","plugins"]);function TR($){let f=Dj($,{preserveEmptyArray:!0});if(!f)return;let J=f.filter((W)=>!zR.has(W));if(J.length>0)throw Error(`unknown extension(s): ${J.join(", ")}`);return f}function a5($){if(typeof $!=="number"||!Number.isFinite($)||$<=0)return;return Math.floor($)}function t5($){if(typeof $!=="number"||!Number.isFinite($)||$<0)return;return Math.floor($)}function o5($){if($===null||typeof $!=="object")return JSON.stringify($??null);if(Array.isArray($))return`[${$.map((J)=>o5(J)).join(",")}]`;let f=Object.entries($).filter(([,J])=>J!==void 0);return f.sort(([J],[W])=>J<W?-1:J>W?1:0),`{${f.map(([J,W])=>`${JSON.stringify(J)}:${o5(W)}`).join(",")}}`}function Lj($,f){let J=GR("sha256");return J.update(o5($)),J.update(`
|
|
197
|
+
`),J.update(f),J.digest("hex")}function NR($){return($.split("/").pop()??$).replace(/\.event\.md$/,"").replace(/\.cron\.md$/,"").replace(/\.md$/,"")}var MR=["schedule","timezone"],yR=["event","filters","debounceSeconds","dedupeWindowSeconds","cooldownSeconds","maxParallel"],qR=["cwd"];function Rj($,f,J,W,Z){return{externalId:$,relativePath:$,triggerKind:f,body:J,contentHash:Lj(W,J),error:Z}}function o0($,f,J,W,Z,Q){return{externalId:$,relativePath:f,triggerKind:J,body:W,contentHash:Z,error:Q}}function Oj($){let f=$.relativePath.replace(/\\/g,"/"),J=FR(f),{frontmatter:W,body:Z}=UR($.raw),Q={};if(W!==void 0&&W.trim().length>0)try{let U=PR.parse(W);if(U&&typeof U==="object"&&!Array.isArray(U))Q=U;else if(U!==null&&U!==void 0)return Rj(f,J,Z,{},"frontmatter must be a YAML mapping")}catch(U){return Rj(f,J,Z,{},U instanceof Error?`failed to parse frontmatter: ${U.message}`:"failed to parse frontmatter")}let j=Lj(Q,Z),H=C0(Q.id),X=H??f;if(J!=="schedule"){for(let U of MR)if(Q[U]!==void 0)return o0(X,f,J,Z,j,`field "${U}" is only allowed on *.cron.md specs`)}for(let U of qR)if(Q[U]!==void 0)return o0(X,f,J,Z,j,`field "${U}" is no longer supported; cron specs use workspaceRoot as cwd`);if(J!=="event"){for(let U of yR)if(Q[U]!==void 0)return o0(X,f,J,Z,j,`field "${U}" is only allowed on .event.md specs`)}let Y=C0(Q.prompt),A=Z.trim(),V=Y??(A.length>0?A:void 0);if(!V)return o0(X,f,J,Z,j,"prompt is required (frontmatter `prompt` or markdown body)");let B=C0(Q.workspaceRoot);if(!B)return o0(X,f,J,Z,j,"workspaceRoot is required");let K,G;try{K=_R(Q.tools),G=TR(Q.extensions)}catch(U){return o0(X,f,J,Z,j,U instanceof Error?U.message:String(U))}let R=LR(Q.mode);if(Q.mode!==void 0&&R===void 0)return o0(X,f,J,Z,j,"mode must be one of: act, plan, yolo");let P={id:H,title:C0(Q.title)??H??NR(f),prompt:V,workspaceRoot:B,mode:R??"yolo",systemPrompt:C0(Q.systemPrompt),modelSelection:DR(Q.modelSelection),maxIterations:a5(Q.maxIterations),timeoutSeconds:a5(Q.timeoutSeconds),tools:K,notesDirectory:C0(Q.notesDirectory),extensions:G,source:C0(Q.source)??"user",tags:RR(Q.tags),enabled:typeof Q.enabled==="boolean"?Q.enabled:!0,metadata:s5(Q.metadata)},F;if(J==="schedule"){let U=C0(Q.schedule);if(!U)return o0(X,f,J,Z,j,"schedule is required for *.cron.md specs");let _=C0(Q.timezone);try{Pj(U,_)}catch(D){return o0(X,f,J,Z,j,D instanceof Error?D.message:String(D))}F={...P,triggerKind:"schedule",schedule:U,timezone:_}}else if(J==="event"){let U=C0(Q.event);if(!U)return o0(X,f,J,Z,j,"event is required for .event.md specs");F={...P,triggerKind:"event",event:U,filters:s5(Q.filters),debounceSeconds:t5(Q.debounceSeconds),dedupeWindowSeconds:t5(Q.dedupeWindowSeconds),cooldownSeconds:t5(Q.cooldownSeconds),maxParallel:a5(Q.maxParallel)}}else F={...P,triggerKind:"one_off"};return{externalId:X,relativePath:f,triggerKind:J,body:Z,contentHash:j,spec:F}}function kR($,f){return ER($,f).replace(/\\/g,"/")}function IR($){if(!wR($))return[];let f=[],J=[$];while(J.length>0){let W=J.pop();if(!W)continue;let Z;try{Z=SR(W,{withFileTypes:!0})}catch{continue}for(let Q of Z){let j=`${W}/${Q.name}`;if(Q.isDirectory()){if(Q.name==="reports")continue;J.push(j);continue}if(!Q.isFile())continue;if(!Q.name.endsWith(".md"))continue;f.push(j)}}return f}class e5{store;cronDir;constructor($){this.store=$.store,this.cronDir=bR($.specs??($.workspaceRoot?{scope:"workspace",workspaceRoot:$.workspaceRoot}:void 0))}getCronDir(){return this.cronDir}async reconcileAll(){let $={scanned:0,upserted:0,invalidParses:0,removed:0,changes:[]},f=IR(this.cronDir),J=new Set;for(let Z of f){let Q=kR(this.cronDir,Z);J.add(Q),$.scanned+=1;let j=await this.reconcileFile(Q,Z);if(j){if($.changes.push(j),$.upserted+=1,j.parse.error)$.invalidParses+=1}}let W=this.store.listSpecs({includeRemoved:!1,limit:1e4});for(let Z of W)if(!J.has(Z.sourcePath))this.handleFileDeleted(Z),$.removed+=1;return this.refreshScheduleNextRunAt(),$}async reconcileFile($,f){let J=this.store.getSpecBySourcePath($),W,Z;try{W=hR(f,"utf8"),Z=CR(f).mtimeMs}catch{return}let j=Oj({relativePath:$,raw:W}),H=this.store.upsertSpec({externalId:j.externalId,sourcePath:$,triggerKind:j.triggerKind,sourceMtimeMs:Z,sourceHash:j.contentHash,parseStatus:j.error?"invalid":"valid",parseError:j.error,spec:j.spec});if(!j.error&&j.triggerKind==="schedule"&&H.record.enabled)this.applyScheduleNextRunAt(H.record,{forceReset:!J||J.removed||!J.enabled||J.scheduleExpr!==H.record.scheduleExpr||J.timezone!==H.record.timezone});return{relativePath:$,result:H,parse:j}}handleFileDeleted($){this.store.markSpecRemoved($.specId),this.store.cancelQueuedRunsForSpec($.specId)}refreshScheduleNextRunAt(){let $=this.store.listSpecs({triggerKind:"schedule",enabled:!0,parseStatus:"valid"});for(let f of $)this.applyScheduleNextRunAt(f,{forceReset:!1})}applyScheduleNextRunAt($,f){if(!$.scheduleExpr)return;if(!f.forceReset&&$.nextRunAt)return;try{let J=Date.now(),W=$.lastRunAt?Math.max(J,new Date($.lastRunAt).getTime()):J,Z=L1($.scheduleExpr,W,$.timezone),Q=new Date(Z).toISOString();if($.nextRunAt!==Q)this.store.updateSpecNextRunAt($.specId,Q)}catch{}}}import{existsSync as xR,mkdirSync as mR,watch as gR}from"node:fs";import{relative as vR,resolve as uR}from"node:path";var cR=250;class $W{reconciler;debounceMs;onError;onReconciled;watcher;pending=new Map;disposed=!1;constructor($){this.reconciler=$.reconciler,this.debounceMs=Math.max(0,$.debounceMs??cR),this.onError=$.onError??(()=>{}),this.onReconciled=$.onReconciled??(()=>{})}start(){if(this.disposed)throw Error("CronWatcher disposed");if(this.watcher)return;let $=this.reconciler.getCronDir();try{mR($,{recursive:!0}),this.watcher=gR($,{recursive:!0},(f,J)=>{if(!J)return;let W=String(J).replace(/\\/g,"/");if(!W.endsWith(".md"))return;if(W.startsWith("reports/"))return;this.scheduleReconcile(W)}),this.watcher.on("error",this.onError)}catch(f){this.onError(f)}}stop(){for(let $ of this.pending.values())clearTimeout($);this.pending.clear(),this.watcher?.close(),this.watcher=void 0}dispose(){this.disposed=!0,this.stop()}scheduleReconcile($){let f=this.pending.get($);if(f)clearTimeout(f);let J=setTimeout(()=>{this.pending.delete($),this.reconcileNow($)},this.debounceMs);this.pending.set($,J)}async reconcileNow($){try{let f=uR(this.reconciler.getCronDir(),$);if(!xR(f)){await this.reconciler.reconcileAll(),await this.onReconciled();return}let J=vR(this.reconciler.getCronDir(),f).replace(/\\/g,"/");await this.reconciler.reconcileFile(J,f),await this.onReconciled()}catch(f){this.onError(f)}}}import{randomUUID as V2}from"node:crypto";import{asOptionalString as E,asString as r,loadSqliteDb as lR,nowIso as X0}from"@cline/shared/db";import{resolveCronDbPath as pR}from"@cline/shared/storage";var dR=[`CREATE TABLE IF NOT EXISTS cron_specs (
|
|
198
198
|
spec_id TEXT PRIMARY KEY,
|
|
199
199
|
external_id TEXT NOT NULL,
|
|
200
200
|
source_path TEXT NOT NULL UNIQUE,
|
|
@@ -285,17 +285,17 @@ ${JSON.stringify(Q,null,2)}`}startClaimLeaseHeartbeat($){let f=Math.max(1000,Mat
|
|
|
285
285
|
ON cron_specs(trigger_kind, enabled, next_run_at);`,`CREATE INDEX IF NOT EXISTS cron_specs_event_match_idx
|
|
286
286
|
ON cron_specs(trigger_kind, event_type, enabled);`,`CREATE INDEX IF NOT EXISTS cron_specs_parse_status_idx
|
|
287
287
|
ON cron_specs(parse_status, updated_at DESC);`,`CREATE INDEX IF NOT EXISTS cron_specs_source_path_idx
|
|
288
|
-
ON cron_specs(source_path);`];function
|
|
288
|
+
ON cron_specs(source_path);`];function _j($){$.exec("PRAGMA journal_mode = WAL;"),$.exec("PRAGMA busy_timeout = 5000;"),$.exec("PRAGMA foreign_keys = ON;");for(let f of dR)$.exec(f)}function OJ($){if(!$)return;try{let f=JSON.parse($);if(f&&typeof f==="object"&&!Array.isArray(f))return f}catch{}return}function fW($,f={}){if(!$)return;try{let J=JSON.parse($);if(!Array.isArray(J))return;let W=J.map((Z)=>typeof Z==="string"?Z.trim():"").filter((Z)=>Z.length>0);if(f.preserveEmpty)return W;return W.length>0?W:void 0}catch{return}}function O1($){if(typeof $==="number"&&Number.isFinite($))return $;if(typeof $==="bigint")return Number($);return}function E$($){return{specId:r($.spec_id),externalId:r($.external_id),sourcePath:r($.source_path),triggerKind:r($.trigger_kind),sourceMtimeMs:O1($.source_mtime_ms),sourceHash:E($.source_hash),parseStatus:r($.parse_status)==="invalid"?"invalid":"valid",parseError:E($.parse_error),enabled:Number($.enabled??0)===1,removed:Number($.removed??0)===1,title:r($.title),prompt:E($.prompt),workspaceRoot:E($.workspace_root),scheduleExpr:E($.schedule_expr),timezone:E($.timezone),eventType:E($.event_type),filters:OJ(E($.filters_json)),debounceSeconds:O1($.debounce_seconds),dedupeWindowSeconds:O1($.dedupe_window_seconds),cooldownSeconds:O1($.cooldown_seconds),mode:E($.mode),systemPrompt:E($.system_prompt),providerId:E($.provider_id),modelId:E($.model_id),maxIterations:O1($.max_iterations),timeoutSeconds:O1($.timeout_seconds),maxParallel:O1($.max_parallel),tools:fW(E($.tools_json),{preserveEmpty:!0}),notesDirectory:E($.notes_directory),extensions:fW(E($.extensions_json),{preserveEmpty:!0}),source:E($.source),tags:fW(E($.tags_json)),metadata:OJ(E($.metadata_json)),revision:Number($.revision??1),lastMaterializedRunId:E($.last_materialized_run_id),lastRunAt:E($.last_run_at),nextRunAt:E($.next_run_at),createdAt:r($.created_at),updatedAt:r($.updated_at)}}function JW($){return{runId:r($.run_id),specId:r($.spec_id),specRevision:Number($.spec_revision??1),triggerKind:r($.trigger_kind),status:r($.status),claimToken:E($.claim_token),claimStartedAt:E($.claim_started_at),claimUntilAt:E($.claim_until_at),scheduledFor:E($.scheduled_for),triggerEventId:E($.trigger_event_id),startedAt:E($.started_at),completedAt:E($.completed_at),sessionId:E($.session_id),reportPath:E($.report_path),error:E($.error),attemptCount:Number($.attempt_count??0),createdAt:r($.created_at),updatedAt:r($.updated_at)}}function zj($){return{eventId:r($.event_id),eventType:r($.event_type),source:r($.source),subject:E($.subject),occurredAt:r($.occurred_at),receivedAt:r($.received_at),workspaceRoot:E($.workspace_root),dedupeKey:E($.dedupe_key),payload:OJ(E($.payload_json)),attributes:OJ(E($.attributes_json)),processingStatus:r($.processing_status),matchedSpecCount:Number($.matched_spec_count??0),queuedRunCount:Number($.queued_run_count??0),suppressedCount:Number($.suppressed_count??0),error:E($.error),createdAt:r($.created_at),updatedAt:r($.updated_at)}}function Tj($){return $?JSON.stringify($):null}var rR=["prompt","workspaceRoot","mode","systemPrompt","providerId","modelId","maxIterations","timeoutSeconds","maxParallel","tools","notesDirectory","extensions","source","scheduleExpr","timezone","eventType","filters","debounceSeconds","dedupeWindowSeconds","cooldownSeconds"];function Nj($){if($===void 0)return null;if($&&typeof $==="object")return JSON.stringify($);return $}function iR($,f,J,W){for(let Z of rR){let Q=$[Z],j=f[Z];if(Nj(Q)!==Nj(j))return!0}if(J===!1&&W===!0)return!0;return!1}function nR($){return($.split("/").pop()??$).replace(/\.event\.md$/,"").replace(/\.cron\.md$/,"").replace(/\.md$/,"")}function aR($){return`hub/schedules/${$}.cron.md`}function tR($){let f={...$.metadata??{},...$.createdBy?{__hubScheduleCreatedBy:$.createdBy}:{},...$.cwd?{__hubScheduleCwd:$.cwd}:{},...$.runtimeOptions?{__hubRuntimeOptions:$.runtimeOptions}:{}};return Object.keys(f).length>0?f:void 0}function WW($){return{triggerKind:"schedule",title:$.name.trim(),prompt:$.prompt,workspaceRoot:$.workspaceRoot.trim(),schedule:$.cronPattern.trim(),mode:$.mode??"act",systemPrompt:$.systemPrompt,modelSelection:$.modelSelection?JSON.parse(JSON.stringify($.modelSelection)):void 0,maxIterations:typeof $.maxIterations==="number"?Math.floor($.maxIterations):void 0,timeoutSeconds:typeof $.timeoutSeconds==="number"?Math.floor($.timeoutSeconds):void 0,maxParallel:typeof $.maxParallel==="number"?Math.max(1,Math.floor($.maxParallel)):1,source:"hub-schedule",tags:$.tags?.filter((f)=>f.trim().length>0),enabled:$.enabled!==!1,metadata:tR($)}}function Mj($){return JSON.stringify(WW($))}function sR($,f){let J=$.metadata?{...$.metadata}:{},W=f.createdBy===null?void 0:f.createdBy!==void 0?f.createdBy:typeof J.__hubScheduleCreatedBy==="string"?J.__hubScheduleCreatedBy:void 0,Z=f.cwd!==void 0?f.cwd:typeof J.__hubScheduleCwd==="string"?J.__hubScheduleCwd:void 0,Q=f.runtimeOptions!==void 0?f.runtimeOptions:J.__hubRuntimeOptions&&typeof J.__hubRuntimeOptions==="object"&&!Array.isArray(J.__hubRuntimeOptions)?J.__hubRuntimeOptions:void 0;return delete J.__hubScheduleCreatedBy,delete J.__hubScheduleCwd,delete J.__hubRuntimeOptions,{name:f.name??$.title,cronPattern:f.cronPattern??$.scheduleExpr??"",prompt:f.prompt??$.prompt??"",workspaceRoot:f.workspaceRoot??$.workspaceRoot??"",cwd:Z,modelSelection:f.modelSelection!==void 0?f.modelSelection:$.providerId||$.modelId?{providerId:$.providerId??"",modelId:$.modelId??""}:void 0,enabled:f.enabled??$.enabled,mode:f.mode??($.mode==="plan"?"plan":$.mode==="yolo"?"yolo":"act"),systemPrompt:f.systemPrompt===null?void 0:f.systemPrompt!==void 0?f.systemPrompt:$.systemPrompt,maxIterations:f.maxIterations===null?void 0:f.maxIterations!==void 0?f.maxIterations:$.maxIterations,timeoutSeconds:f.timeoutSeconds===null?void 0:f.timeoutSeconds!==void 0?f.timeoutSeconds:$.timeoutSeconds,maxParallel:f.maxParallel??$.maxParallel??1,createdBy:W,tags:f.tags??$.tags,runtimeOptions:Q,metadata:f.metadata!==void 0?f.metadata:Object.keys(J).length>0?J:void 0}}class B2{db;constructor($={}){let f=$.dbPath??pR();this.db=lR(f),_j(this.db)}close(){this.db.close?.()}getSpecBySourcePath($){let f=this.db.prepare("SELECT * FROM cron_specs WHERE source_path = ?").get($);return f?E$(f):void 0}getSpec($){let f=this.db.prepare("SELECT * FROM cron_specs WHERE spec_id = ?").get($);return f?E$(f):void 0}getSpecByExternalId($){let f=this.db.prepare("SELECT * FROM cron_specs WHERE external_id = ? ORDER BY created_at ASC LIMIT 1").get($);return f?E$(f):void 0}listSpecs($={}){let f=[],J=[];if($.triggerKind)f.push("trigger_kind = ?"),J.push($.triggerKind);if(typeof $.enabled==="boolean")f.push("enabled = ?"),J.push($.enabled?1:0);if($.parseStatus)f.push("parse_status = ?"),J.push($.parseStatus);if(!$.includeRemoved)f.push("removed = 0");let W=f.length>0?`WHERE ${f.join(" AND ")}`:"",Z=Math.max(1,Math.floor($.limit??500));return this.db.prepare(`SELECT * FROM cron_specs ${W} ORDER BY created_at DESC LIMIT ?`).all(...J,Z).map((j)=>E$(j))}createHubSchedule($){let f=`sched_${V2()}`,J=this.upsertSpec({externalId:f,sourcePath:aR(f),triggerKind:"schedule",sourceHash:Mj($),parseStatus:"valid",spec:WW($)});this.initializeScheduleNextRun(J.record.specId);let W=this.getSpec(J.record.specId);if(!W)throw Error("failed to create hub schedule");return W}getHubSchedule($){let f=this.db.prepare(`SELECT * FROM cron_specs
|
|
289
289
|
WHERE external_id = ? AND source = 'hub-schedule' AND removed = 0
|
|
290
|
-
ORDER BY created_at ASC LIMIT 1`).get($);return f?
|
|
290
|
+
ORDER BY created_at ASC LIMIT 1`).get($);return f?E$(f):void 0}listHubSchedules($={}){let f=["source = 'hub-schedule'","trigger_kind = 'schedule'","removed = 0"],J=[];if(typeof $.enabled==="boolean")f.push("enabled = ?"),J.push($.enabled?1:0);if($.tags&&$.tags.length>0)for(let Q of $.tags)f.push("tags_json LIKE ?"),J.push(`%"${Q.trim()}"%`);let W=Math.max(1,Math.floor($.limit??200));return this.db.prepare(`SELECT * FROM cron_specs
|
|
291
291
|
WHERE ${f.join(" AND ")}
|
|
292
|
-
ORDER BY created_at DESC LIMIT ?`).all(...J,
|
|
292
|
+
ORDER BY created_at DESC LIMIT ?`).all(...J,W).map((Q)=>E$(Q))}updateHubSchedule($,f){let J=this.getHubSchedule($);if(!J)return;let W=sR(J,f),Z=this.upsertSpec({externalId:$,sourcePath:J.sourcePath,triggerKind:"schedule",sourceHash:Mj(W),parseStatus:"valid",spec:WW(W)});if(f.cronPattern!==void 0||f.enabled!==void 0)this.initializeScheduleNextRun(Z.record.specId);return this.getSpec(Z.record.specId)}deleteHubSchedule($){let f=this.getHubSchedule($);if(!f)return!1;return this.markSpecRemoved(f.specId),this.cancelQueuedRunsForSpec(f.specId),!0}enqueueHubScheduleRun($,f="manual"){let J=this.getHubSchedule($);if(!J||!J.enabled||J.removed||J.parseStatus!=="valid")return;return this.enqueueRun({specId:J.specId,specRevision:J.revision,triggerKind:f,scheduledFor:X0()})}listEventSpecsForType($){return this.db.prepare(`SELECT * FROM cron_specs
|
|
293
293
|
WHERE trigger_kind = 'event'
|
|
294
294
|
AND event_type = ?
|
|
295
295
|
AND enabled = 1
|
|
296
296
|
AND removed = 0
|
|
297
297
|
AND parse_status = 'valid'
|
|
298
|
-
ORDER BY created_at ASC`).all($).map((J)=>
|
|
298
|
+
ORDER BY created_at ASC`).all($).map((J)=>E$(J))}upsertSpec($){let f=X0(),J=this.getSpecBySourcePath($.sourcePath),W=$.spec,Z={title:W?.title??J?.title??nR($.sourcePath),prompt:W?.prompt,workspaceRoot:W?.workspaceRoot,scheduleExpr:W?.triggerKind==="schedule"?W.schedule:void 0,timezone:W?.triggerKind==="schedule"?W.timezone:void 0,eventType:W?.triggerKind==="event"?W.event:void 0,filters:W?.triggerKind==="event"?W.filters:void 0,debounceSeconds:W?.triggerKind==="event"?W.debounceSeconds:void 0,dedupeWindowSeconds:W?.triggerKind==="event"?W.dedupeWindowSeconds:void 0,cooldownSeconds:W?.triggerKind==="event"?W.cooldownSeconds:void 0,mode:W?.mode,systemPrompt:W?.systemPrompt,providerId:W?.modelSelection?.providerId,modelId:W?.modelSelection?.modelId,maxIterations:W?.maxIterations,timeoutSeconds:W?.timeoutSeconds,maxParallel:W&&"maxParallel"in W?W.maxParallel:void 0,tools:W?.tools,notesDirectory:W?.notesDirectory,extensions:W?.extensions,source:W?.source},Q=$.parseStatus==="valid"&&(W?.enabled??!0);if(!J){let A=`cspec_${V2()}`;this.insertSpecRow(A,$,Z,Q,f);let V=this.getSpec(A);if(!V)throw Error("failed to insert cron_spec row");return{record:V,created:!0,revisionChanged:!0}}let H=J.sourceHash!==$.sourceHash&&iR(J,Z,J.enabled,Q),X=H?J.revision+1:J.revision;this.updateSpecRow(J.specId,$,Z,Q,X,f);let Y=this.getSpec(J.specId);if(!Y)throw Error("failed to reload cron_spec after update");return{record:Y,created:!1,revisionChanged:H}}insertSpecRow($,f,J,W,Z){let Q=f.spec;this.db.prepare(`INSERT INTO cron_specs (
|
|
299
299
|
spec_id, external_id, source_path, trigger_kind,
|
|
300
300
|
source_mtime_ms, source_hash, parse_status, parse_error,
|
|
301
301
|
enabled, removed, title, prompt, workspace_root,
|
|
@@ -306,7 +306,7 @@ ${JSON.stringify(Q,null,2)}`}startClaimLeaseHeartbeat($){let f=Math.max(1000,Mat
|
|
|
306
306
|
tools_json, notes_directory, extensions_json, source,
|
|
307
307
|
tags_json, metadata_json, revision,
|
|
308
308
|
created_at, updated_at
|
|
309
|
-
) VALUES (${Array.from({length:36},()=>"?").join(",")})`).run($,f.externalId,f.sourcePath,f.triggerKind,f.sourceMtimeMs??null,f.sourceHash,f.parseStatus,f.parseError??null,
|
|
309
|
+
) VALUES (${Array.from({length:36},()=>"?").join(",")})`).run($,f.externalId,f.sourcePath,f.triggerKind,f.sourceMtimeMs??null,f.sourceHash,f.parseStatus,f.parseError??null,W?1:0,0,J.title??"",J.prompt??null,J.workspaceRoot??null,J.scheduleExpr??null,J.timezone??null,J.eventType??null,J.filters?JSON.stringify(J.filters):null,J.debounceSeconds??null,J.dedupeWindowSeconds??null,J.cooldownSeconds??null,J.mode??null,J.systemPrompt??null,J.providerId??null,J.modelId??null,J.maxIterations??null,J.timeoutSeconds??null,J.maxParallel??null,J.tools?JSON.stringify(J.tools):null,J.notesDirectory??null,J.extensions?JSON.stringify(J.extensions):null,J.source??null,Q?.tags?JSON.stringify(Q.tags):null,Q?.metadata?JSON.stringify(Q.metadata):null,1,Z,Z)}updateSpecRow($,f,J,W,Z,Q){let j=f.spec;this.db.prepare(`UPDATE cron_specs SET
|
|
310
310
|
external_id = ?, trigger_kind = ?,
|
|
311
311
|
source_mtime_ms = ?, source_hash = ?, parse_status = ?, parse_error = ?,
|
|
312
312
|
enabled = ?, removed = 0, title = ?, prompt = ?,
|
|
@@ -318,31 +318,31 @@ ${JSON.stringify(Q,null,2)}`}startClaimLeaseHeartbeat($){let f=Math.max(1000,Mat
|
|
|
318
318
|
tools_json = ?, notes_directory = ?, extensions_json = ?, source = ?,
|
|
319
319
|
tags_json = ?, metadata_json = ?,
|
|
320
320
|
revision = ?, updated_at = ?
|
|
321
|
-
WHERE spec_id = ?`).run(f.externalId,f.triggerKind,f.sourceMtimeMs??null,f.sourceHash,f.parseStatus,f.parseError??null,
|
|
321
|
+
WHERE spec_id = ?`).run(f.externalId,f.triggerKind,f.sourceMtimeMs??null,f.sourceHash,f.parseStatus,f.parseError??null,W?1:0,J.title??"",J.prompt??null,J.workspaceRoot??null,J.scheduleExpr??null,J.timezone??null,J.eventType??null,J.filters?JSON.stringify(J.filters):null,J.debounceSeconds??null,J.dedupeWindowSeconds??null,J.cooldownSeconds??null,J.mode??null,J.systemPrompt??null,J.providerId??null,J.modelId??null,J.maxIterations??null,J.timeoutSeconds??null,J.maxParallel??null,J.tools?JSON.stringify(J.tools):null,J.notesDirectory??null,J.extensions?JSON.stringify(J.extensions):null,J.source??null,j?.tags?JSON.stringify(j.tags):null,j?.metadata?JSON.stringify(j.metadata):null,Z,Q,$)}markSpecRemoved($){this.db.prepare("UPDATE cron_specs SET removed = 1, enabled = 0, updated_at = ? WHERE spec_id = ?").run(X0(),$)}updateSpecNextRunAt($,f){this.db.prepare("UPDATE cron_specs SET next_run_at = ?, updated_at = ? WHERE spec_id = ?").run(f??null,X0(),$)}updateSpecLastRunAt($,f){this.db.prepare("UPDATE cron_specs SET last_run_at = ?, updated_at = ? WHERE spec_id = ?").run(f,X0(),$)}updateLastMaterializedRunId($,f){this.db.prepare("UPDATE cron_specs SET last_materialized_run_id = ?, updated_at = ? WHERE spec_id = ?").run(f,X0(),$)}initializeScheduleNextRun($){let f=this.getSpec($);if(!f||f.triggerKind!=="schedule"||!f.enabled||!f.scheduleExpr){this.updateSpecNextRunAt($,void 0);return}let J=new Date(L1(f.scheduleExpr,Date.now(),f.timezone)).toISOString();this.updateSpecNextRunAt($,J)}materializeDueScheduleRun($){let f=$.nowMs,J=new Date(f).toISOString();this.db.exec("BEGIN IMMEDIATE;");try{let W=this.db.prepare("SELECT * FROM cron_specs WHERE spec_id = ?").get($.specId);if(!W)return this.db.exec("COMMIT;"),{queued:!1};let Z=E$(W);if(Z.triggerKind!=="schedule"||!Z.enabled||Z.removed||Z.parseStatus!=="valid"||!Z.scheduleExpr)return this.db.exec("COMMIT;"),{queued:!1};let Q=Z.nextRunAt;if(!Q){let X=new Date(L1(Z.scheduleExpr,f,Z.timezone)).toISOString();return this.db.prepare("UPDATE cron_specs SET next_run_at = ?, updated_at = ? WHERE spec_id = ?").run(X,J,Z.specId),this.db.exec("COMMIT;"),{queued:!1,nextRunAt:X}}if(new Date(Q).getTime()>f)return this.db.exec("COMMIT;"),{queued:!1,nextRunAt:Q};let j=`crun_${V2()}`,H;try{H=new Date(L1(Z.scheduleExpr,f,Z.timezone)).toISOString()}catch{H=void 0}return this.db.prepare(`INSERT INTO cron_runs (
|
|
322
322
|
run_id, spec_id, spec_revision, trigger_kind, status,
|
|
323
323
|
scheduled_for, trigger_event_id, attempt_count,
|
|
324
324
|
created_at, updated_at
|
|
325
|
-
) VALUES (?,?,?,?,?, ?,?,?, ?,?)`).run(j,Z.specId,Z.revision,"schedule","queued",
|
|
325
|
+
) VALUES (?,?,?,?,?, ?,?,?, ?,?)`).run(j,Z.specId,Z.revision,"schedule","queued",Q,null,0,J,J),this.db.prepare(`UPDATE cron_specs SET
|
|
326
326
|
last_materialized_run_id = ?,
|
|
327
327
|
last_run_at = ?,
|
|
328
328
|
next_run_at = ?,
|
|
329
329
|
updated_at = ?
|
|
330
|
-
WHERE spec_id = ?`).run(j,J,
|
|
330
|
+
WHERE spec_id = ?`).run(j,J,H??null,J,Z.specId),this.db.exec("COMMIT;"),{queued:!0,run:this.getRun(j),nextRunAt:H}}catch(W){throw this.db.exec("ROLLBACK;"),W}}getRun($){let f=this.db.prepare("SELECT * FROM cron_runs WHERE run_id = ?").get($);return f?JW(f):void 0}insertEventLog($,f={}){let J=X0(),W=f.receivedAtIso??J,Z=$.eventId.trim();if(!Z)throw Error("automation event requires eventId");let Q=$.eventType.trim();if(!Q)throw Error("automation event requires eventType");let j=$.source.trim();if(!j)throw Error("automation event requires source");let H=$.occurredAt.trim()||W,X=this.db.prepare(`INSERT OR IGNORE INTO cron_event_log (
|
|
331
331
|
event_id, event_type, source, subject,
|
|
332
332
|
occurred_at, received_at, workspace_root, dedupe_key,
|
|
333
333
|
payload_json, attributes_json, processing_status,
|
|
334
334
|
matched_spec_count, queued_run_count, suppressed_count,
|
|
335
335
|
error, created_at, updated_at
|
|
336
|
-
) VALUES (?,?,?,?, ?,?,?,?, ?,?,?, ?,?,?, ?,?,?)`).run(Z,
|
|
336
|
+
) VALUES (?,?,?,?, ?,?,?,?, ?,?,?, ?,?,?, ?,?,?)`).run(Z,Q,j,$.subject?.trim()||null,H,W,$.workspaceRoot?.trim()||null,$.dedupeKey?.trim()||null,Tj($.payload),Tj($.attributes),"received",0,0,0,null,J,J).changes??0,Y=this.getEventLog(Z);if(!Y)throw Error("failed to insert cron_event_log row");return{record:Y,created:X===1}}getEventLog($){let f=this.db.prepare("SELECT * FROM cron_event_log WHERE event_id = ?").get($);return f?zj(f):void 0}listEventLogs($={}){let f=[],J=[];if($.eventType)f.push("event_type = ?"),J.push($.eventType);if($.source)f.push("source = ?"),J.push($.source);if($.processingStatus)f.push("processing_status = ?"),J.push($.processingStatus);let W=f.length>0?`WHERE ${f.join(" AND ")}`:"",Z=Math.max(1,Math.floor($.limit??200));return this.db.prepare(`SELECT * FROM cron_event_log ${W}
|
|
337
337
|
ORDER BY received_at DESC, created_at DESC
|
|
338
|
-
LIMIT ?`).all(...J,Z).map((j)=>
|
|
338
|
+
LIMIT ?`).all(...J,Z).map((j)=>zj(j))}updateEventLogProcessing($,f){return(this.db.prepare(`UPDATE cron_event_log SET
|
|
339
339
|
processing_status = ?,
|
|
340
340
|
matched_spec_count = COALESCE(?, matched_spec_count),
|
|
341
341
|
queued_run_count = COALESCE(?, queued_run_count),
|
|
342
342
|
suppressed_count = COALESCE(?, suppressed_count),
|
|
343
343
|
error = ?,
|
|
344
344
|
updated_at = ?
|
|
345
|
-
WHERE event_id = ?`).run(f.status,f.matchedSpecCount??null,f.queuedRunCount??null,f.suppressedCount??null,f.error??null,X0(),$).changes??0)===1}listRuns($={}){let f=[],J=[];if($.specId)f.push("spec_id = ?"),J.push($.specId);if($.status){let j=Array.isArray($.status)?$.status:[$.status];if(j.length>0){let
|
|
345
|
+
WHERE event_id = ?`).run(f.status,f.matchedSpecCount??null,f.queuedRunCount??null,f.suppressedCount??null,f.error??null,X0(),$).changes??0)===1}listRuns($={}){let f=[],J=[];if($.specId)f.push("spec_id = ?"),J.push($.specId);if($.status){let j=Array.isArray($.status)?$.status:[$.status];if(j.length>0){let H=j.map(()=>"?").join(",");f.push(`status IN (${H})`);for(let X of j)J.push(X)}}let W=f.length>0?`WHERE ${f.join(" AND ")}`:"",Z=Math.max(1,Math.floor($.limit??200));return this.db.prepare(`SELECT * FROM cron_runs ${W} ORDER BY created_at DESC LIMIT ?`).all(...J,Z).map((j)=>JW(j))}hasRecentEventRunForDedupe($){return!!this.db.prepare(`SELECT r.run_id FROM cron_runs r
|
|
346
346
|
INNER JOIN cron_event_log e ON e.event_id = r.trigger_event_id
|
|
347
347
|
WHERE r.spec_id = ?
|
|
348
348
|
AND r.trigger_kind = 'event'
|
|
@@ -360,7 +360,7 @@ ${JSON.stringify(Q,null,2)}`}startClaimLeaseHeartbeat($){let f=Math.max(1000,Mat
|
|
|
360
360
|
AND r.status = 'queued'
|
|
361
361
|
AND e.dedupe_key = ?
|
|
362
362
|
ORDER BY COALESCE(r.scheduled_for, r.created_at) DESC
|
|
363
|
-
LIMIT 1`).get($.specId,$.dedupeKey);return f?
|
|
363
|
+
LIMIT 1`).get($.specId,$.dedupeKey);return f?JW(f):void 0}updateQueuedEventRunForDebounce($){let f=X0();if((this.db.prepare(`UPDATE cron_runs SET
|
|
364
364
|
trigger_event_id = ?,
|
|
365
365
|
scheduled_for = ?,
|
|
366
366
|
updated_at = ?
|
|
@@ -369,12 +369,12 @@ ${JSON.stringify(Q,null,2)}`}startClaimLeaseHeartbeat($){let f=Math.max(1000,Mat
|
|
|
369
369
|
AND status = 'queued'`).run($.triggerEventId,$.scheduledFor,f,$.runId).changes??0)!==1)return;return this.getRun($.runId)}hasOneOffRunForRevision($,f){return!!this.db.prepare(`SELECT run_id FROM cron_runs
|
|
370
370
|
WHERE spec_id = ? AND spec_revision = ?
|
|
371
371
|
AND trigger_kind = 'one_off'
|
|
372
|
-
LIMIT 1`).get($,f)}enqueueRun($){let f=`crun_${
|
|
372
|
+
LIMIT 1`).get($,f)}enqueueRun($){let f=`crun_${V2()}`,J=X0();this.db.prepare(`INSERT INTO cron_runs (
|
|
373
373
|
run_id, spec_id, spec_revision, trigger_kind, status,
|
|
374
374
|
scheduled_for, trigger_event_id, attempt_count,
|
|
375
375
|
created_at, updated_at
|
|
376
|
-
) VALUES (?,?,?,?,?, ?,?,?, ?,?)`).run(f,$.specId,$.specRevision,$.triggerKind,"queued",$.scheduledFor??null,$.triggerEventId??null,0,J,J),this.updateLastMaterializedRunId($.specId,f);let
|
|
377
|
-
WHERE spec_id = ? AND status = 'queued'`).run(X0(),$).changes??0}claimDueRuns($){let f=$.nowIso,J=Math.max(1000,Math.floor($.leaseMs)),
|
|
376
|
+
) VALUES (?,?,?,?,?, ?,?,?, ?,?)`).run(f,$.specId,$.specRevision,$.triggerKind,"queued",$.scheduledFor??null,$.triggerEventId??null,0,J,J),this.updateLastMaterializedRunId($.specId,f);let W=this.getRun(f);if(!W)throw Error("failed to insert cron_run row");return W}cancelQueuedRunsForSpec($){return this.db.prepare(`UPDATE cron_runs SET status = 'cancelled', updated_at = ?
|
|
377
|
+
WHERE spec_id = ? AND status = 'queued'`).run(X0(),$).changes??0}claimDueRuns($){let f=$.nowIso,J=Math.max(1000,Math.floor($.leaseMs)),W=new Date(new Date(f).getTime()+J).toISOString(),Z=Math.max(1,Math.floor($.limit??25)),Q=[];this.db.exec("BEGIN IMMEDIATE;");try{let j=this.db.prepare(`SELECT * FROM cron_runs
|
|
378
378
|
WHERE (
|
|
379
379
|
status = 'queued'
|
|
380
380
|
OR (
|
|
@@ -386,7 +386,7 @@ ${JSON.stringify(Q,null,2)}`}startClaimLeaseHeartbeat($){let f=Math.max(1000,Mat
|
|
|
386
386
|
)
|
|
387
387
|
AND (scheduled_for IS NULL OR scheduled_for <= ?)
|
|
388
388
|
ORDER BY COALESCE(scheduled_for, created_at) ASC
|
|
389
|
-
LIMIT ?`).all(f,f,Z);for(let
|
|
389
|
+
LIMIT ?`).all(f,f,Z);for(let H of j){let X=r(H.run_id);if(!X)continue;let Y=`cclaim_${V2()}`;if((this.db.prepare(`UPDATE cron_runs SET
|
|
390
390
|
status = 'running',
|
|
391
391
|
claim_token = ?,
|
|
392
392
|
claim_started_at = ?,
|
|
@@ -407,8 +407,8 @@ ${JSON.stringify(Q,null,2)}`}startClaimLeaseHeartbeat($){let f=Math.max(1000,Mat
|
|
|
407
407
|
AND claim_until_at <= ?
|
|
408
408
|
AND completed_at IS NULL
|
|
409
409
|
)
|
|
410
|
-
)`).run(Y,f,
|
|
411
|
-
WHERE run_id = ? AND claim_token = ?`).run(J,X0(),$,f).changes??0)===1}completeRun($,f){let J=f.completedAtIso??X0(),
|
|
410
|
+
)`).run(Y,f,W,f,f,X,f).changes??0)!==1)continue;let V=this.getRun(X);if(!V)continue;Q.push({run:V,claimToken:Y,claimUntilAt:W})}this.db.exec("COMMIT;")}catch(j){throw this.db.exec("ROLLBACK;"),j}return Q}renewClaim($,f,J){return(this.db.prepare(`UPDATE cron_runs SET claim_until_at = ?, updated_at = ?
|
|
411
|
+
WHERE run_id = ? AND claim_token = ?`).run(J,X0(),$,f).changes??0)===1}completeRun($,f){let J=f.completedAtIso??X0(),W=f.claimToken?"WHERE run_id = ? AND claim_token = ?":"WHERE run_id = ?";return(this.db.prepare(`UPDATE cron_runs SET
|
|
412
412
|
status = ?,
|
|
413
413
|
session_id = COALESCE(?, session_id),
|
|
414
414
|
report_path = COALESCE(?, report_path),
|
|
@@ -418,7 +418,7 @@ ${JSON.stringify(Q,null,2)}`}startClaimLeaseHeartbeat($){let f=Math.max(1000,Mat
|
|
|
418
418
|
claim_token = NULL,
|
|
419
419
|
claim_until_at = NULL,
|
|
420
420
|
updated_at = ?
|
|
421
|
-
${
|
|
421
|
+
${W}`).run(f.status,f.sessionId??null,f.reportPath??null,f.error??null,J,J,$,...f.claimToken?[f.claimToken]:[]).changes??0)>0}requeueRun($){let f=X0();return(this.db.prepare(`UPDATE cron_runs SET
|
|
422
422
|
status = 'queued',
|
|
423
423
|
claim_started_at = NULL,
|
|
424
424
|
claim_token = NULL,
|
|
@@ -430,41 +430,41 @@ ${JSON.stringify(Q,null,2)}`}startClaimLeaseHeartbeat($){let f=Math.max(1000,Mat
|
|
|
430
430
|
error = ?,
|
|
431
431
|
scheduled_for = COALESCE(?, scheduled_for),
|
|
432
432
|
updated_at = ?
|
|
433
|
-
WHERE run_id = ? AND claim_token = ?`).run($.error??null,$.scheduledFor??null,f,$.runId,$.claimToken).changes??0)>0}attachSessionIdToRun($,f){this.db.prepare("UPDATE cron_runs SET session_id = ?, updated_at = ? WHERE run_id = ?").run(f,X0(),$)}attachReportPathToRun($,f){this.db.prepare("UPDATE cron_runs SET report_path = ?, updated_at = ? WHERE run_id = ?").run(f,X0(),$)}}class
|
|
434
|
-
`)[0]?.trim())}function
|
|
435
|
-
`,"utf8")}function
|
|
436
|
-
`).trim()}function
|
|
437
|
-
`)[0]??Z);return
|
|
438
|
-
`,{encoding:"utf8",mode:384}),await
|
|
439
|
-
`,"utf8");try{return await f()}finally{await eW(J)}}catch(Z){if((Z instanceof Error&&"code"in Z?String(Z.code):"")!=="EEXIST")throw Z;let j=await yD(J),X=j?Date.now()-Date.parse(j.acquiredAt):oW+1;if(!j||!TD(j.pid)||X>oW){await eW(J);continue}if(Date.now()>=Q)throw Error(`Timed out waiting for hub startup lock ${J}`);await MD(zD)}}async function U0($){try{let f=await fetch(wD($));if(!f.ok)return;return await f.json()}catch{return}}function j$($,f,J="/hub"){return new URL(`ws://${$}:${f}${J}`).toString()}function wD($){let f=new URL($);return f.protocol=f.protocol==="wss:"?"https:":"http:",f.pathname="/health",f.search="",f.toString()}function kE($){return UD($)}import{CLINE_HUB_DEV_PORT as SD,CLINE_HUB_PORT as hD,resolveClineBuildEnv as CD}from"@cline/shared";var ED="CLINE_HUB_HOST",bD="CLINE_HUB_PORT",kD="CLINE_HUB_PATHNAME",ID="127.0.0.1",xD=hD,mD="/hub";function jj($){return CD($)==="development"?SD:xD}function gD($={}){return($.env??process.env)[ED]?.trim()||ID}function Z6($={}){let J=($.env??process.env)[bD]?.trim();if(!J)return jj($);let Q=Number.parseInt(J,10);if(!Number.isInteger(Q)||Q<1||Q>65535)return jj($);return Q}function vD($={}){return($.env??process.env)[kD]?.trim()||mD}function C$($={},f={}){return{host:$.host??gD(f),port:$.port??Z6(f),pathname:$.pathname??vD(f)}}var uD="shared:cline";function uE($){let f=Y1($.trim());return K1(`workspace:${f||$.trim()}`)}function D0($=uD){return K1($)}var oD=8000,eD=200,$R=3000,fR=100,JR=[100,250,500,1000,2000],QR="--cline-hub-daemon";function ZR($){return[...$.host?["--host",$.host]:[],...typeof $.port==="number"?["--port",String($.port)]:[],...$.pathname?["--pathname",$.pathname]:[]]}function WR(){try{let $=nD(p5(),"logs","hub-daemon.log");return lD(iD($),{recursive:!0}),{fd:pD($,"a"),logPath:$}}catch{return}}function Q8($){let f=$.buildId?.trim();return!!f&&f===t1()}async function jR($,f){let J=Date.now()+f;while(Date.now()<J){if(!(await U0($).catch(()=>{return}))?.url)return!0;await new Promise((Z)=>setTimeout(Z,fR))}return!1}async function Z8($,f){if(Q8($))return;if(await r5($.url,$.authToken).catch(()=>!1),$.pid)try{process.kill($.pid,"SIGTERM")}catch{}await jR($.url,$R),await n0(f).catch(()=>{return})}function XR(){let $=import.meta.url.endsWith(".ts")?"ts":"js";return aD(new URL(`./entry.${$}`,import.meta.url))}function HR($,f){let J=XR(),Q=process.execPath?.trim();if(!Q)throw Error("unable to resolve runtime executable for hub daemon");let Z=rD(Q).toLowerCase().includes("bun"),W=J.startsWith("/$bunfs/"),j=Z&&J.toLowerCase().endsWith(".ts"),X=W?[QR]:[...j?["--conditions=development"]:[],J];return{launcher:Q,args:[...X,"--cwd",$,...ZR(f)],cwd:$,env:{...sD(process.env),CLINE_NO_INTERACTIVE:"1",[tD]:"1"}}}function YR($){if(!$||typeof $!=="object")return!1;if(("code"in $?$.code:void 0)==="ETXTBSY")return!0;let J="message"in $?$.message:void 0;return typeof J==="string"&&J.includes("ETXTBSY")}function VR($,f={}){if(Xj())return;let J=HR($,f),Q=WR();try{cD(J.launcher,J.args,{detached:!0,stdio:Q?["ignore",Q.fd,Q.fd]:"ignore",env:J.env,cwd:J.cwd}).unref()}finally{if(Q)dD(Q.fd)}}async function W6($,f={}){for(let J=0;;J++)try{VR($,f);return}catch(Q){let Z=JR[J];if(!YR(Q)||Z===void 0)throw Q;await new Promise((W)=>setTimeout(W,Z))}}function Hj($,f={}){if(Xj())return;let J=D0(),Q=f.port!==void 0||!!process.env.CLINE_HUB_PORT?.trim(),Z=C$(f),W=j$(Z.host,Z.port,Z.pathname);A0(J.discoveryPath).then(async(j)=>{if(j?.url){let V=await U0(j.url);if(V?.url&&Q8(V)&&await E$(V.url,{authToken:j.authToken}))return;if(V?.url)await Z8({...V,authToken:j.authToken},J.discoveryPath);else await n0(J.discoveryPath).catch(()=>{return})}let X=await U0(W);if(X?.url)await Z8(X,J.discoveryPath);let Y=!Q&&Z.port!==0?{...Z,port:0}:Z;await W6($,Y)}).catch(()=>{})}async function oE($,f={}){let J=D0(),Q=f.host!==void 0||f.port!==void 0||f.pathname!==void 0||!!process.env.CLINE_HUB_PORT?.trim(),Z=f.port!==void 0||!!process.env.CLINE_HUB_PORT?.trim(),W=C$(f),j=j$(W.host,W.port,W.pathname),X=(G)=>{if(!Q)s1(G.url,G.authToken);return G},H=await A0(J.discoveryPath);if(H?.url){let G=await U0(H.url);if(G?.url&&Q8(G)&&await E$(G.url,{authToken:H.authToken}))return X({url:G.url,authToken:H.authToken});if(G?.url)await Z8({...G,authToken:H.authToken},J.discoveryPath);else await n0(J.discoveryPath).catch(()=>{return})}let Y=await U0(j);if(Y?.url)await Z8(Y,J.discoveryPath);let A=!Z&&W.port!==0?{...W,port:0}:W;await W6($,A);let B=Date.now()+oD;while(Date.now()<B){let G=await A0(J.discoveryPath);if(G?.url){let D=await U0(G.url);if(D?.url&&Q8(D)&&await E$(D.url,{authToken:G.authToken}))return X({url:D.url,authToken:G.authToken})}let K=await U0(j);if(K?.url&&!Q8(K))await Z8(K,J.discoveryPath);await new Promise((D)=>setTimeout(D,eD))}throw Error("Timed out waiting for detached hub startup.")}function GR(){let $=globalThis.WebSocket;if(!$)throw Error("Global WebSocket is not available in this runtime. Node 22+ is required for hub mode.");return $}function Gj($){if(typeof $==="string")return $;if($ instanceof Uint8Array)return Buffer.from($).toString();if($ instanceof ArrayBuffer)return Buffer.from($).toString();if(Array.isArray($))return Buffer.concat($.map((f)=>Buffer.from(f))).toString();if($&&typeof $==="object"&&"data"in $&&typeof $.data<"u")return Gj($.data);return String($)}function KR($){if(typeof $==="string")return $;if($ instanceof Uint8Array)return Buffer.from($).toString("utf8");if($ instanceof ArrayBuffer)return Buffer.from($).toString("utf8");return""}function Yj($){let f=$,J=KR(f.reason);return new I0("hub_connection_closed",f.code||J?`Hub connection closed (code=${f.code??0}${J?`, reason=${J}`:""})`:i5,{closeCode:f.code,closeReason:J||void 0})}function FR($,f){if($ instanceof I0)return $;if($ instanceof Error)return new I0("hub_connect_failed",$.message);if($&&typeof $==="object"&&"error"in $&&$.error instanceof Error)return new I0("hub_connect_failed",$.error.message);let J=$&&typeof $==="object"&&"message"in $&&typeof $.message==="string"?$.message.trim():"";if(J)return new I0("hub_connect_failed",J);let Q=$&&typeof $==="object"&&"type"in $&&typeof $.type==="string"?$.type.trim():"";return new I0("hub_connect_failed",Q?`Failed to connect to hub at ${f.toString()} (${Q} event before socket open).`:`Failed to connect to hub at ${f.toString()}.`)}var PR=8000,UR=200,Vj="*",Aj=8000,DR="cline-hub-auth.",Kj=new Map,Fj=new Set,RR=3000,LR=3000,OR=100,i5="Hub connection closed",zR=250,_R=5000,Bj=0.5;class I0 extends Error{code;details;constructor($,f,J){super(f);this.code=$;this.details=J;this.name="HubTransportError"}}function NR($){return $ instanceof I0}class j6 extends Error{command;code;constructor($,f,J){super(J);this.command=$;this.code=f;this.name="HubCommandError"}}function Pj($,f){return $ instanceof j6&&$.code==="hub_command_timeout"&&(f===void 0||$.command===f)}function Uj($){let f=$.searchParams.get("authToken")?.trim();if($.searchParams.delete("authToken"),f)return f;let J=t5($.toString());return J?Kj.get(J):void 0}function TR($){try{let J=new URL($).hostname.toLowerCase().replace(/^\[|\]$/g,"");return J==="localhost"||J==="127.0.0.1"||J==="::1"}catch{return!1}}function t5($){if(!TR($))return;let f=new URL(o1($));return f.search="",f.hash="",f.toString()}function n5($){let f=t5($);return!!f&&Fj.has(f)}function s1($,f){let J=t5($);if(J){if(Fj.add(J),f?.trim())Kj.set(J,f)}return $}class X${options;socket;connectPromise;clientId;currentUrl;recoveryPromise;pendingReplies=new Map;listeners=new Set;subscriptionCounts=new Map;reconnectTimer;reconnectAttempt=0;closedByClient=!1;lastCloseError=new I0("hub_connection_closed",i5);sawSocketClose=!1;registered=!1;constructor($){this.options=$;this.clientId=$.clientId??`core-${Math.random().toString(36).slice(2,10)}-${Date.now().toString(36)}`,this.currentUrl=$.url}getClientId(){return this.clientId}getUrl(){return this.currentUrl}async connect(){if(this.socket&&(this.socket.readyState===1||this.socket.readyState===0))return this.connectPromise??Promise.resolve();this.closedByClient=!1,this.clearReconnectTimer();let $=new URL(this.currentUrl),f=this.options.authToken?.trim()||Uj($);$.hash="";let Q=new(GR())($.toString(),f?[`${DR}${f}`]:void 0);this.socket=Q;let Z=!1;this.connectPromise=new Promise((W,j)=>{let X=!1,H=setTimeout(()=>{if(X)return;X=!0,Z=!0,this.lastCloseError=new I0("hub_connect_timeout",`Timed out connecting to hub after ${Aj}ms`),this.sawSocketClose=!1,this.connectPromise=void 0,this.socket=void 0;try{Q.close()}catch{}j(this.lastCloseError)},Aj);Q.addEventListener("open",()=>{if(X)return;X=!0,clearTimeout(H),W()}),Q.addEventListener("error",(Y)=>{if(X)return;X=!0,clearTimeout(H),this.lastCloseError=FR(Y,$),this.sawSocketClose=!1,this.connectPromise=void 0,this.socket=void 0,j(this.lastCloseError)}),Q.addEventListener("close",(Y)=>{if(X)return;if(X=!0,clearTimeout(H),!Z)this.lastCloseError=Yj(Y),this.sawSocketClose=!0;this.connectPromise=void 0,this.socket=void 0,j(this.lastCloseError)})}),Q.addEventListener("message",(W)=>{this.handleFrame(JSON.parse(Gj(W)))}),Q.addEventListener("close",(W)=>{if(this.socket!==Q)return;if(!Z)this.lastCloseError=Yj(W),this.sawSocketClose=!0;this.registered=!1;for(let j of this.pendingReplies.values())j.reject(this.lastCloseError);if(this.pendingReplies.clear(),this.connectPromise=void 0,this.socket=void 0,!this.closedByClient&&this.hasActiveSubscriptions())this.scheduleReconnect()}),await this.connectPromise,await this.command("client.register",{clientId:this.clientId,clientType:this.options.clientType??"core",displayName:this.options.displayName??"core",transport:"native",actorKind:"client",workspaceContext:{workspaceRoot:this.options.workspaceRoot,cwd:this.options.cwd}}),this.registered=!0;for(let W of this.subscriptionCounts.keys())this.sendSubscriptionFrame("stream.subscribe",this.subscriptionSessionIdFromKey(W));this.reconnectAttempt=0}subscribe($,f){let J=f?.sessionId?.trim()||void 0,Q={listener:$,sessionId:J};return this.listeners.add(Q),this.adjustSubscriptionCount(J,1),()=>{if(!this.listeners.delete(Q))return;this.adjustSubscriptionCount(J,-1)}}async command($,f,J,Q){let Z=0,W=$!=="client.register"&&$!=="client.unregister";while(!0)try{return await this.commandOnce($,f,J,Q)}catch(j){if(!W||Z>=1||!await this.recoverLocalHubTransport(j))throw j;Z+=1}}async commandOnce($,f,J,Q){await this.connect();let Z=AR("hubreq_"),W=BR($,Q?.timeoutMs),j=new Promise((H,Y)=>{let V=W===null?void 0:setTimeout(()=>{if(!this.pendingReplies.delete(Z))return;Y(new j6($,"hub_command_timeout",`Hub command ${$} timed out after ${W}ms (hub=${this.currentUrl}, requestId=${Z}, clientId=${this.clientId}). Check hub-daemon.log for matching command.start/command.slow entries, or run 'cline doctor fix' to restart the hub.`))},W);this.pendingReplies.set(Z,{resolve:(A)=>{if(V)clearTimeout(V);H(A)},reject:(A)=>{if(V)clearTimeout(V);Y(A)}})});try{this.sendFrame({kind:"command",envelope:{version:"v1",command:$,requestId:Z,clientId:this.clientId,sessionId:J,timeoutMs:W,payload:f}})}catch(H){throw this.pendingReplies.delete(Z),H}let X=await j;if(!X.ok)throw new j6($,X.error?.code,X.error?.message??`Hub command ${$} failed`);return X}async recoverLocalHubTransport($){if(!n5(this.currentUrl)||!NR($))return!1;if(this.recoveryPromise)return await this.recoveryPromise;return this.recoveryPromise=(async()=>{let f=await W8({workspaceRoot:this.options.workspaceRoot,cwd:this.options.cwd}).catch(()=>{return});if(!f)return!1;return this.currentUrl=f,this.close(),!0})().finally(()=>{this.recoveryPromise=void 0}),await this.recoveryPromise}hasActiveSubscriptions(){return this.subscriptionCounts.size>0}clearReconnectTimer(){if(!this.reconnectTimer)return;clearTimeout(this.reconnectTimer),this.reconnectTimer=void 0}scheduleReconnect(){if(this.reconnectTimer||this.closedByClient||!this.hasActiveSubscriptions())return;let $=Math.min(zR*2**this.reconnectAttempt,_R),f=Math.round($*(1-Bj)+Math.random()*$*Bj);this.reconnectTimer=setTimeout(()=>{this.reconnectTimer=void 0,this.reconnectSubscribedTransport()},f)}async reconnectSubscribedTransport(){if(this.closedByClient||!this.hasActiveSubscriptions())return;try{await this.connect(),this.reconnectAttempt=0}catch{if(!n5(this.currentUrl)){this.reconnectAttempt+=1,this.scheduleReconnect();return}try{let $=await W8({workspaceRoot:this.options.workspaceRoot,cwd:this.options.cwd});if($){this.currentUrl=$,await this.connect(),this.reconnectAttempt=0;return}}catch{}this.reconnectAttempt+=1,this.scheduleReconnect()}}close(){let $=this.socket;if(this.closedByClient=!0,this.clearReconnectTimer(),this.registered=!1,!$)return;this.lastCloseError=new I0("hub_connection_closed",i5),this.sawSocketClose=!1;for(let f of this.pendingReplies.values())f.reject(this.lastCloseError);this.pendingReplies.clear(),this.connectPromise=void 0,this.socket=void 0;try{$.close()}catch{}}async dispose(){if(this.socket?.readyState===1&&this.registered)try{await this.command("client.unregister",void 0,void 0,{timeoutMs:2000})}catch{}this.close()}sendFrame($){if(!this.socket||this.socket.readyState!==1){if(this.lastCloseError.code==="hub_connection_closed"&&!this.sawSocketClose)throw new I0("hub_connection_not_open","Hub connection is not open.");throw this.lastCloseError}this.socket.send(JSON.stringify($))}sendSubscriptionFrame($,f){this.sendFrame({kind:$,clientId:this.clientId,...f?{sessionId:f}:{}})}adjustSubscriptionCount($,f){let J=this.subscriptionKeyForSessionId($),Q=(this.subscriptionCounts.get(J)??0)+f;if(Q<=0){if(this.subscriptionCounts.delete(J),!this.hasActiveSubscriptions())this.clearReconnectTimer();if(f<0&&this.socket?.readyState===1)this.sendSubscriptionFrame("stream.unsubscribe",$);return}if(this.subscriptionCounts.set(J,Q),f>0&&Q===1&&this.socket?.readyState===1)this.sendSubscriptionFrame("stream.subscribe",$)}subscriptionKeyForSessionId($){return $??Vj}subscriptionSessionIdFromKey($){return $===Vj?void 0:$}handleFrame($){switch($.kind){case"reply":{let f=$.envelope.requestId;if(!f)return;let J=this.pendingReplies.get(f);if(!J)return;this.pendingReplies.delete(f),J.resolve($.envelope);return}case"event":for(let f of this.listeners){if(f.sessionId&&f.sessionId!==$.envelope.sessionId?.trim())continue;f.listener($.envelope)}return;case"command":case"stream.subscribe":case"stream.unsubscribe":return}}}function o1($){let f=new URL($);if(f.protocol==="http:")f.protocol="ws:";else if(f.protocol==="https:")f.protocol="wss:";return f.toString()}async function E$($,f){let J=new X$({url:$,authToken:f?.authToken,clientType:"hub-healthcheck",displayName:"hub healthcheck",workspaceRoot:f?.workspaceRoot,cwd:f?.cwd});try{return await J.connect(),!0}catch{return!1}finally{J.close()}}async function a5($,f){let J=o1($),Q=await U0(J);if(!Q)return{status:"unreachable",url:J};let Z=t1(),W=Q.buildId?.trim();if(!W||W!==Z)return{status:"build_mismatch",url:J};if(f?.verifyConnection===!0&&!await E$(J,{workspaceRoot:f.workspaceRoot,cwd:f.cwd,authToken:f.authToken}))return{status:"unreachable",url:J};return{status:"compatible",url:J}}async function MR($){let f=Date.now()+PR;while(Date.now()<f){let J=await A0($.discoveryPath);if(J?.url){let Q=await a5(J.url,{verifyConnection:!0,authToken:J.authToken});if(Q.status==="compatible")return s1(Q.url,J.authToken)}await new Promise((Q)=>setTimeout(Q,UR))}return}async function qR($){let f=Date.now()+LR;while(Date.now()<f){if(!(await U0($).catch(()=>{return}))?.url)return!0;await new Promise((Q)=>setTimeout(Q,OR))}return!1}function yR($,f){try{return o1($)===o1(f)}catch{return!1}}function wR($){return($&&typeof $==="object"&&Array.isArray($.sessions)?$.sessions:[]).some((J)=>{if(!J||typeof J!=="object")return!1;let Q=J;if(Q.status==="running"||Q.status==="idle"||Q.status==="pending")return!0;return Array.isArray(Q.participants)&&Q.participants.length>0})}async function SR($,f,J){let Q=new X$({url:$,authToken:f,clientType:"hub-recovery-check",displayName:"hub recovery check",workspaceRoot:J?.workspaceRoot,cwd:J?.cwd});try{let Z=await Q.command("session.list",{limit:500},void 0,{timeoutMs:RR});return!wR(Z.payload)}catch{return!1}finally{await Q.dispose().catch(()=>{return})}}async function s5($={}){if($.endpoint?.trim()){let Z=await a5($.endpoint);return Z.status==="compatible"?Z.url:void 0}let f=D0(),J=await A0(f.discoveryPath);if(!J?.url)return;let Q=await a5(J.url);if(Q.status==="compatible")return s1(Q.url,J.authToken);if(Q.status==="build_mismatch")await n0(f.discoveryPath).catch(()=>{return});return}async function W8($={}){let f=await s5($);if(f&&await E$(f,{workspaceRoot:$.workspaceRoot,cwd:$.cwd}))return f;if($.endpoint?.trim())return;let J=D0();return await W6($.workspaceRoot??process.cwd()),await MR(J)}async function r5($,f){let J=new URL($),Q=f?.trim()||Uj(J);if(J.protocol==="ws:")J.protocol="http:";else if(J.protocol==="wss:")J.protocol="https:";return J.pathname="/shutdown",J.hash="",(await fetch(J,{method:"POST",headers:Q?{authorization:`Bearer ${Q}`}:void 0})).ok}async function hR(){let $=D0(),f=await A0($.discoveryPath);if(!f?.url)return!1;try{if(await r5(f.url,f.authToken))return!0}catch{}return!1}async function Dj($){if(!n5($.url))return;let f=D0(),J=await A0(f.discoveryPath);if(!J?.url||!yR(J.url,$.url))return;if(!await SR(J.url,J.authToken,{workspaceRoot:$.workspaceRoot,cwd:$.cwd}))return;if(!await hR())return;if(!await qR(J.url))return;return await n0(f.discoveryPath).catch(()=>{return}),await W8({workspaceRoot:$.workspaceRoot,cwd:$.cwd})}import{captureSdkError as Rj,createSessionId as Lj,HUB_CHECKPOINT_CAPABILITY as kR,HUB_COMPACTION_CAPABILITY as IR,HUB_CUSTOM_TOOL_CAPABILITY_PREFIX as xR,HUB_HOOK_CAPABILITY_PREFIX as mR,HUB_MISTAKE_LIMIT_CAPABILITY as gR,HUB_TOOL_EXECUTOR_CAPABILITY_PREFIX as vR,HUB_USER_INSTRUCTIONS_SNAPSHOT_CAPABILITY as uR,isHubToolExecutorName as cR}from"@cline/shared";function CR($){return $?JSON.parse(JSON.stringify($)):void 0}function ER($){return $?JSON.parse(JSON.stringify($)):void 0}function bR($){let f=$?.checkpoint&&typeof $.checkpoint==="object"&&!Array.isArray($.checkpoint)?$.checkpoint:void 0,Q=(Array.isArray(f?.history)?f.history:[]).filter((j)=>!!j&&typeof j==="object"&&!Array.isArray(j)).flatMap((j)=>{let X=typeof j.ref==="string"?j.ref.trim():"",H=Number(j.createdAt),Y=Number(j.runCount);if(!X||!Number.isFinite(H)||!Number.isInteger(Y))return[];return[{ref:X,createdAt:H,runCount:Y,...j.kind==="stash"||j.kind==="commit"?{kind:j.kind}:{}}]}),Z=Q.at(-1),W=$?.checkpointEnabled===!0?!0:void 0;if(!W&&Q.length===0)return;return{...W?{enabled:W}:{},...Z?{latest:Z}:{},history:Q}}function b$($){let{session:f}=$,J=CR(f.metadata);return{version:1,sessionId:f.sessionId,source:f.source,status:f.status,createdAt:f.startedAt,updatedAt:f.updatedAt,endedAt:f.endedAt??null,exitCode:f.exitCode??null,interactive:f.interactive,workspace:{cwd:f.cwd,root:f.workspaceRoot},model:{providerId:f.provider,modelId:f.model},capabilities:{enableTools:f.enableTools,enableSpawn:f.enableSpawn,enableTeams:f.enableTeams},lineage:{...f.parentSessionId?{parentSessionId:f.parentSessionId}:{},...f.parentAgentId?{parentAgentId:f.parentAgentId}:{},...f.agentId?{agentId:f.agentId}:{},...f.conversationId?{conversationId:f.conversationId}:{},isSubagent:f.isSubagent},...f.teamName?{team:{name:f.teamName}}:{},...f.prompt?{prompt:f.prompt}:{},...J?{metadata:J}:{},...f.messagesPath?{artifacts:{messagesPath:f.messagesPath}}:{},...$.messages?{messages:ER($.messages)}:{},...$.usage?{usage:{...$.usage}}:{},...$.aggregateUsage?{aggregateUsage:{...$.aggregateUsage}}:{},...(()=>{let Q=bR(J);return Q?{checkpoint:Q}:{}})()}}function o5($){return{sessionId:$.sessionId,parentSessionId:$.lineage.parentSessionId,agentId:$.lineage.agentId,parentAgentId:$.lineage.parentAgentId,conversationId:$.lineage.conversationId,isSubagent:$.lineage.isSubagent,source:$.source,startedAt:$.createdAt,endedAt:$.endedAt??void 0,exitCode:$.exitCode??void 0,status:$.status,interactive:$.interactive,provider:$.model.providerId,model:$.model.modelId,cwd:$.workspace.cwd,workspaceRoot:$.workspace.root,teamName:$.team?.name,enableTools:$.capabilities.enableTools,enableSpawn:$.capabilities.enableSpawn,enableTeams:$.capabilities.enableTeams,prompt:$.prompt,metadata:$.metadata,updatedAt:$.updatedAt,messagesPath:$.artifacts?.messagesPath}}function e1($){if(!$)return;return JSON.parse(JSON.stringify($))}var dR=["beforeRun","afterRun","beforeModel","afterModel","beforeTool","afterTool","onEvent"];function Oj($){if(!$||typeof $!=="object"||Array.isArray($))return;return JSON.parse(JSON.stringify($))}function zj($){if(!$)return;let{userInstructionService:f,...J}=$;return JSON.parse(JSON.stringify(J))}function _j($){let f=$&&typeof $==="object"&&!Array.isArray($)?$:{};return{agentId:typeof f.agentId==="string"?f.agentId:"",conversationId:typeof f.conversationId==="string"?f.conversationId:"",iteration:typeof f.iteration==="number"?f.iteration:0,metadata:f.metadata&&typeof f.metadata==="object"&&!Array.isArray(f.metadata)?f.metadata:void 0}}function F1($,f,J){$.manifest.push(f),$.handlers.set(f.capabilityName,J)}function Nj($,f){let J={manifest:[],handlers:new Map};for(let Z of Object.keys(f.toolExecutors??{}).filter(cR)){let W=f.toolExecutors?.[Z];if(typeof W!=="function")continue;F1(J,{kind:"toolExecutor",executor:Z,capabilityName:`${vR}${Z}`},async({payload:j,abortSignal:X})=>{let H=Array.isArray(j.args)?[...j.args]:[],Y={..._j(j.context),signal:X};return{result:await W(...H,Y)}})}for(let Z of $?.extraTools??[])F1(J,{kind:"tool",name:Z.name,description:Z.description,inputSchema:e1(Z.inputSchema)??{},...Z.lifecycle?{lifecycle:e1(Z.lifecycle)}:{},capabilityName:`${xR}${Z.name}`},async({payload:W,abortSignal:j,progress:X})=>{let H={..._j(W.context),signal:j};return{result:await Z.execute(W.input,{...H,emitUpdate:(V)=>{X({update:V})}})}});let Q=$?.hooks;if(Q)for(let Z of dR){let W=Q[Z];if(typeof W!=="function")continue;F1(J,{kind:"hook",name:Z,capabilityName:`${mR}${Z}`},async({payload:j})=>({control:await W(j.context)}))}if($?.compaction?.compact){let Z=$.compaction.compact;F1(J,{kind:"compaction",capabilityName:IR,config:Oj($.compaction)},async({payload:W})=>({result:await Z(W.context)}))}if($?.checkpoint?.createCheckpoint){let Z=$.checkpoint.createCheckpoint;F1(J,{kind:"checkpoint",capabilityName:kR,config:Oj($.checkpoint)},async({payload:W})=>({result:await Z(W.context)}))}if($?.onConsecutiveMistakeLimitReached){let Z=$.onConsecutiveMistakeLimitReached;F1(J,{kind:"mistakeLimit",capabilityName:gR},async({payload:W})=>({result:await Z(W.context)}))}if($?.userInstructionService){let Z=$.userInstructionService;F1(J,{kind:"userInstructionService",capabilityName:uR},async()=>{return await Z.start().catch(()=>{}),{snapshot:{records:{skill:Z.listRecords("skill"),rule:Z.listRecords("rule"),workflow:Z.listRecords("workflow")},runtimeCommands:Z.listRuntimeCommands()}}})}return J}function yj($){if(typeof $==="string"&&$.trim())return $.trim();if($ instanceof Error)return $.message.trim()||void 0;if($&&typeof $==="object"&&"message"in $){let f=$.message;if(typeof f==="string"&&f.trim())return f.trim()}return}function lR($){return yj($)??"Capability request was cancelled."}function pR($){if(typeof $!=="string")return $;try{return JSON.parse($)}catch{return $}}function rR($){return $==="completed"||$==="max_iterations"||$==="aborted"||$==="mistake_limit"||$==="error"}function iR($){if(!$||typeof $!=="object"||Array.isArray($))return;let f=$,J=typeof f.inputTokens==="number"?f.inputTokens:void 0,Q=typeof f.outputTokens==="number"?f.outputTokens:void 0;if(J===void 0||Q===void 0)return;return{inputTokens:J,outputTokens:Q,cacheReadTokens:typeof f.cacheReadTokens==="number"?f.cacheReadTokens:0,cacheWriteTokens:typeof f.cacheWriteTokens==="number"?f.cacheWriteTokens:0,totalCost:typeof f.totalCost==="number"?f.totalCost:0}}function Tj($){if(!$)return;return{inputTokens:typeof $.inputTokens==="number"?$.inputTokens:0,outputTokens:typeof $.outputTokens==="number"?$.outputTokens:0,cacheReadTokens:typeof $.cacheReadTokens==="number"?$.cacheReadTokens:0,cacheWriteTokens:typeof $.cacheWriteTokens==="number"?$.cacheWriteTokens:0,totalCost:typeof $.totalCost==="number"?$.totalCost:0}}function e5($){return typeof $==="number"&&Number.isFinite($)?$:void 0}function k$($,f){return e5($?.[f])??0}function nR($){let f=$?.delta&&typeof $.delta==="object"?$.delta:void 0,J=$?.totals&&typeof $.totals==="object"?$.totals:void 0,Q=$?.agent&&typeof $.agent==="object"?$.agent:void 0,Z=Q?.teamRole==="teammate"||Q?.teamRole==="lead"?Q.teamRole:void 0;return{event:{type:"usage",agentId:typeof Q?.agentId==="string"?Q.agentId:void 0,conversationId:typeof Q?.conversationId==="string"?Q.conversationId:void 0,parentAgentId:typeof Q?.parentAgentId==="string"?Q.parentAgentId:void 0,inputTokens:k$(f,"inputTokens"),outputTokens:k$(f,"outputTokens"),cacheReadTokens:k$(f,"cacheReadTokens"),cacheWriteTokens:k$(f,"cacheWriteTokens"),cost:e5(f?.totalCost),totalInputTokens:k$(J,"inputTokens"),totalOutputTokens:k$(J,"outputTokens"),totalCacheReadTokens:k$(J,"cacheReadTokens"),totalCacheWriteTokens:k$(J,"cacheWriteTokens"),totalCost:e5(J?.totalCost)},teamAgentId:typeof Q?.teamAgentId==="string"?Q.teamAgentId:void 0,teamRole:Z}}function aR($){let f=$?.result&&typeof $.result==="object"&&!Array.isArray($.result)?$.result:void 0,J=$?.reason??f?.finishReason,Q=rR(J)?J:J==="failed"?"error":"completed",Z=iR($?.usage??f?.usage);return{type:"done",reason:Q,text:typeof $?.text==="string"?$.text:typeof f?.text==="string"?f.text:"",iterations:typeof $?.iterations==="number"?$.iterations:typeof f?.iterations==="number"?f.iterations:0,usage:Z}}function X6($,f){return $.error?.message??`hub command failed: ${f}`}function j8($){switch($){case"idle":case"completed":return"completed";case"failed":return"failed";case"aborted":return"cancelled";default:return"running"}}function wj($){let f=$.metadata&&typeof $.metadata==="object"?JSON.parse(JSON.stringify($.metadata)):void 0;return{sessionId:$.sessionId,parentSessionId:typeof f?.parentSessionId==="string"?f.parentSessionId:void 0,agentId:$.runtimeSession?.agentId||(typeof f?.agentId==="string"?f.agentId:void 0),parentAgentId:typeof f?.parentAgentId==="string"?f.parentAgentId:void 0,conversationId:typeof f?.conversationId==="string"?f.conversationId:void 0,isSubagent:typeof f?.isSubagent==="boolean"?f.isSubagent:!1,source:typeof f?.source==="string"?f.source:F0.CORE,pid:typeof f?.pid==="number"?f.pid:void 0,startedAt:new Date($.createdAt).toISOString(),endedAt:j8($.status)==="running"?void 0:new Date($.updatedAt).toISOString(),exitCode:j8($.status)==="completed"?0:j8($.status)==="failed"?1:void 0,status:j8($.status),interactive:f?.interactive===!0,provider:typeof f?.provider==="string"?f.provider:"hub",model:typeof f?.model==="string"?f.model:"hub",cwd:$.cwd?.trim()||$.workspaceRoot,workspaceRoot:$.workspaceRoot,teamName:typeof f?.teamName==="string"?f.teamName:void 0,enableTools:$.runtimeOptions?.enableTools??f?.enableTools===!0,enableSpawn:$.runtimeOptions?.enableSpawn??f?.enableSpawn===!0,enableTeams:$.runtimeOptions?.enableTeams??f?.enableTeams===!0,prompt:typeof f?.prompt==="string"?f.prompt:void 0,metadata:f,updatedAt:new Date($.updatedAt).toISOString(),messagesPath:typeof f?.messagesPath==="string"?f.messagesPath:void 0,hookPath:typeof f?.hookPath==="string"?f.hookPath:void 0}}function I$($){if(!$||typeof $!=="object"||Array.isArray($))return;let f=$;return f.version===1&&typeof f.sessionId==="string"?JSON.parse(JSON.stringify(f)):void 0}function tR($){let f=I$($?.snapshot);if(f)return o5(f);let J=$?.session;return J?wj(J):void 0}function Mj($,f,J){let Q=J?.workspaceRoot?.trim()||f.config.workspaceRoot||f.config.cwd;return _0.parse({version:1,session_id:$,source:f.source??F0.CORE,pid:process.pid,started_at:new Date(J?.createdAt??Date.now()).toISOString(),status:j8(J?.status),interactive:f.interactive===!0,provider:f.config.providerId,model:f.config.modelId,cwd:J?.cwd?.trim()||f.config.cwd,workspace_root:Q,team_name:f.config.teamName,enable_tools:f.config.enableTools,enable_spawn:f.config.enableSpawnAgent,enable_teams:f.config.enableAgentTeams,prompt:f.prompt?.trim()||void 0,metadata:f.sessionMetadata&&Object.keys(f.sessionMetadata).length>0?f.sessionMetadata:void 0})}function qj($,f){return _0.parse({version:1,session_id:$.sessionId,source:$.source,pid:process.pid,started_at:$.createdAt,status:$.status,interactive:$.interactive,provider:$.model.providerId,model:$.model.modelId,cwd:$.workspace.cwd,workspace_root:$.workspace.root,team_name:$.team?.name,enable_tools:$.capabilities.enableTools,enable_spawn:$.capabilities.enableSpawn,enable_teams:$.capabilities.enableTeams,prompt:($.prompt??f.prompt?.trim())||void 0,metadata:$.metadata,messages_path:$.artifacts?.messagesPath})}class P1{runtimeAddress;pendingPrompts;client;clientOptions;clientContext;events=new f8;sessionCapabilities=new Map;sessionClientContributionHandlers=new Map;sessionSubscriptions=new Map;pendingApprovalToolCallIds=new Set;agentDoneEmittedForCurrentRunBySession=new Set;activeCapabilityAbortControllers=new Map;defaultCapabilities;telemetry;constructor($,f){this.clientContext=f,this.clientOptions={authToken:$.authToken,clientType:$.clientType??"core-hub-runtime",displayName:$.displayName??"core hub runtime",workspaceRoot:f?.workspaceRoot,cwd:f?.cwd},this.defaultCapabilities=P0($.capabilities)??{},this.telemetry=$.telemetry,this.runtimeAddress=$.url,this.pendingPrompts={list:(J)=>this.requestPendingPromptsList(J),update:(J)=>this.requestPendingPromptUpdate(J),delete:(J)=>this.requestPendingPromptDelete(J)},this.client=this.createClient($.url)}createClient($){return new X$({...this.clientOptions,url:$})}async replaceClient($){let f=this.client;this.client=this.createClient($),this.runtimeAddress=$,await Promise.resolve(f.dispose()).catch(()=>{return})}async recoverLocalHubStartupDeadlock($){if(!Pj($,"session.create"))return!1;let f=await Dj({url:this.client.getUrl(),workspaceRoot:this.clientContext?.workspaceRoot,cwd:this.clientContext?.cwd}).catch(()=>{return});if(!f)return!1;return await this.replaceClient(f),!0}registerPlannedSession($,f,J){if(this.sessionCapabilities.set($,f),J.size>0)this.sessionClientContributionHandlers.set($,J);this.ensureSessionSubscription($)}cleanupPlannedSession($){this.sessionCapabilities.delete($),this.sessionClientContributionHandlers.delete($),this.disposeSessionSubscription($)}async connect(){await this.client.connect()}async startSession($){let f=this.resolveCapabilities($),J=Nj($.localRuntime,f),Q=$.config.sessionId?.trim()||Lj(),Z=()=>this.client.command("session.create",{workspaceRoot:$.config.workspaceRoot?.trim()||$.config.cwd,cwd:$.config.cwd,sessionConfig:e1({...$.config,sessionId:Q}),metadata:{...$.sessionMetadata??{},source:$.source??F0.CORE,provider:$.config.providerId,model:$.config.modelId,enableTools:$.config.enableTools,enableSpawn:$.config.enableSpawnAgent,enableTeams:$.config.enableAgentTeams,teamName:$.config.teamName,prompt:$.prompt,interactive:$.interactive===!0},runtimeOptions:{...J.manifest.length>0?{clientContributions:J.manifest}:{},...$.localRuntime?.configExtensions?{configExtensions:$.localRuntime.configExtensions}:{}},toolPolicies:e1($.toolPolicies),initialMessages:$.initialMessages});this.registerPlannedSession(Q,f,J.handlers);let W;try{W=await Z()}catch(Y){if(this.cleanupPlannedSession(Q),await this.recoverLocalHubStartupDeadlock(Y)){this.registerPlannedSession(Q,f,J.handlers);try{W=await Z()}catch(V){throw this.cleanupPlannedSession(Q),V}}else throw Y}let j=I$(W.payload?.snapshot),X=W.payload?.session,H=(j?.sessionId??X?.sessionId)?.trim();if(!H)throw this.cleanupPlannedSession(Q),Error("Hub runtime did not return a session id.");if(H!==Q)this.cleanupPlannedSession(Q),this.registerPlannedSession(H,f,J.handlers);return{sessionId:H,manifest:j?qj(j,$):Mj(H,$,X),manifestPath:"",messagesPath:"",result:void 0}}async restoreSession($){let f=$.sessionId.trim();if(!f)throw Error("sessionId is required");let J=$.restore?.messages!==!1;if(J&&!$.start)throw Error("start is required when restore.messages is true");let Q=$.start,Z=Q?this.resolveCapabilities(Q):void 0,W=Q?Nj(Q.localRuntime,Z??{}):{manifest:[],handlers:new Map},j=Q?Q.config.sessionId?.trim()||Lj():void 0;if(j&&Z)this.sessionCapabilities.set(j,Z);if(j&&W.handlers.size>0)this.sessionClientContributionHandlers.set(j,W.handlers),this.ensureSessionSubscription(j);let X;try{X=await this.client.command("session.restore",{sessionId:f,checkpointRunCount:$.checkpointRunCount,restore:$.restore,...Q?{workspaceRoot:Q.config.workspaceRoot?.trim()||Q.config.cwd,cwd:Q.config.cwd??$.cwd,sessionConfig:e1({...Q.config,sessionId:j}),metadata:{...Q.sessionMetadata??{},source:Q.source??F0.CORE,provider:Q.config.providerId,model:Q.config.modelId,enableTools:Q.config.enableTools,enableSpawn:Q.config.enableSpawnAgent,enableTeams:Q.config.enableAgentTeams,teamName:Q.config.teamName,prompt:Q.prompt,interactive:Q.interactive===!0},runtimeOptions:{...W.manifest.length>0?{clientContributions:W.manifest}:{},...Q.localRuntime?.configExtensions?{configExtensions:Q.localRuntime.configExtensions}:{}},toolPolicies:e1(Q.toolPolicies)}:{}},f)}catch(G){if(j)this.sessionCapabilities.delete(j),this.sessionClientContributionHandlers.delete(j),this.disposeSessionSubscription(j);throw G}if(!X.ok){let G=typeof X.payload?.error==="string"?X.payload.error:"session.restore failed";if(j)this.sessionCapabilities.delete(j),this.sessionClientContributionHandlers.delete(j),this.disposeSessionSubscription(j);throw Error(G)}let H=I$(X.payload?.snapshot),Y=X.payload?.session,V=(H?.sessionId??Y?.sessionId)?.trim();if(J&&!V){if(j)this.sessionCapabilities.delete(j),this.sessionClientContributionHandlers.delete(j),this.disposeSessionSubscription(j);throw Error("Hub checkpoint restore returned no session id")}if(V&&j&&V!==j)this.sessionCapabilities.delete(j),this.sessionClientContributionHandlers.delete(j),this.disposeSessionSubscription(j);if(V&&Z)this.sessionCapabilities.set(V,Z);if(V&&W.handlers.size>0)this.sessionClientContributionHandlers.set(V,W.handlers);if(V)this.ensureSessionSubscription(V);let A=Array.isArray(X.payload?.messages)?X.payload.messages:void 0,B=X.payload?.checkpoint;if(!B)throw Error("Hub checkpoint restore returned no checkpoint");return{sessionId:V,startResult:V?{sessionId:V,manifest:H?qj(H,Q??{}):Mj(V,Q??{},Y),manifestPath:"",messagesPath:"",result:void 0}:void 0,messages:A,checkpoint:B}}async runTurn($){return this.ensureSessionSubscription($.sessionId),(await this.client.command("run.start",{sessionId:$.sessionId,input:$.prompt,mode:$.mode,attachments:($.userImages?.length??0)>0||($.userFiles?.length??0)>0?{...$.userImages?.length?{userImages:$.userImages}:{},...$.userFiles?.length?{userFiles:$.userFiles}:{}}:void 0,delivery:$.delivery,timeoutMs:$.timeoutMs},$.sessionId,{timeoutMs:null})).payload?.result}async requestPendingPromptsList($){this.ensureSessionSubscription($.sessionId);let f=await this.client.command("session.pending_prompts",{sessionId:$.sessionId},$.sessionId);return Array.isArray(f.payload?.prompts)?f.payload.prompts:[]}async requestPendingPromptUpdate($){this.ensureSessionSubscription($.sessionId);let f=await this.client.command("session.update_pending_prompt",{...$},$.sessionId);return{sessionId:$.sessionId,prompts:Array.isArray(f.payload?.prompts)?f.payload.prompts:[],prompt:f.payload?.prompt,updated:f.payload?.updated===!0}}async requestPendingPromptDelete($){this.ensureSessionSubscription($.sessionId);let f=await this.client.command("session.remove_pending_prompt",{...$},$.sessionId);return{sessionId:$.sessionId,prompts:Array.isArray(f.payload?.prompts)?f.payload.prompts:[],prompt:f.payload?.prompt,removed:f.payload?.removed===!0}}async getAccumulatedUsage($){let f=await this.client.command("session.get",{includeSnapshot:!0},$),J=I$(f.payload?.snapshot);if(J){let j=J.usage?{...J.usage}:void 0,X=J.aggregateUsage?{...J.aggregateUsage}:void 0;return j||X?{usage:j,aggregateUsage:X}:void 0}let Q=f.payload?.session,Z=Tj(Q?.usage),W=Tj(Q?.aggregateUsage);return Z||W?{usage:Z,aggregateUsage:W}:void 0}async abort($,f){await this.client.command("run.abort",{sessionId:$,reason:yj(f)},$)}async stopSession($){this.sessionCapabilities.delete($),this.disposeSessionSubscription($),await this.client.command("session.detach",{sessionId:$},$)}async dispose(){for(let[$,f]of this.sessionSubscriptions){f();try{await this.client.command("session.detach",{sessionId:$},$)}catch{}}this.sessionSubscriptions.clear(),this.sessionCapabilities.clear(),this.agentDoneEmittedForCurrentRunBySession.clear();for(let $ of this.activeCapabilityAbortControllers.values())$.abort("Hub runtime host disposed.");this.activeCapabilityAbortControllers.clear(),await this.client.dispose()}async getSession($){let f=await this.client.command("session.get",void 0,$);return tR(f.payload)}async listSessions($=100){let f=await this.client.command("session.list",{limit:$}),J=Array.isArray(f.payload?.snapshots)?f.payload.snapshots.flatMap((Z)=>{let W=I$(Z);return W?[o5(W)]:[]}):[];if(J.length>0)return J;return(f.payload?.sessions??[]).map(wj)}async listSettings($){let f=await this.client.command("settings.list",zj($));if(!f.ok)throw Error(X6(f,"settings.list"));return f.payload?.snapshot}async toggleSetting($){let f=await this.client.command("settings.toggle",zj($));if(!f.ok)throw Error(X6(f,"settings.toggle"));return{snapshot:f.payload?.snapshot,changedTypes:Array.isArray(f.payload?.changedTypes)?f.payload.changedTypes:[]}}async deleteSession($){return this.sessionCapabilities.delete($),this.disposeSessionSubscription($),(await this.client.command("session.delete",{sessionId:$})).payload?.deleted===!0}async updateSession($,f){let J={...f.metadata??{}};if(typeof f.prompt==="string")J.prompt=f.prompt;if(typeof f.title==="string")J.title=f.title;return{updated:(await this.client.command("session.update",{sessionId:$,metadata:J})).ok}}async readSessionMessages($){let f=$.trim();if(!f)return[];let J=await this.client.command("session.messages",{sessionId:f},f);if(!J.ok)throw Rj(this.telemetry,{component:"core",operation:"hub.runtime_host.read_session_messages",error:Error(X6(J,"session.messages")),severity:J.error?.code==="session_not_found"?"warn":"error",handled:!0,context:{command:"session.messages",sessionId:f,errorCode:J.error?.code,runtimeAddress:this.runtimeAddress}}),Error(X6(J,"session.messages"));let Q=J.payload?.messages;return Array.isArray(Q)?Q:[]}async dispatchHookEvent($){await this.client.command("session.hook",{payload:$})}subscribe($,f){return this.events.subscribe($,f)}ensureSessionSubscription($){let f=$.trim();if(!f||this.sessionSubscriptions.has(f))return;let J=this.client.subscribe((Q)=>{this.handleHubEvent(Q)},{sessionId:f});this.sessionSubscriptions.set(f,typeof J==="function"?J:()=>{})}disposeSessionSubscription($){let f=$.trim();if(!f)return;this.sessionSubscriptions.get(f)?.(),this.sessionSubscriptions.delete(f),this.agentDoneEmittedForCurrentRunBySession.delete(f)}resolveCapabilities($){return P0(this.defaultCapabilities,$.capabilities)??{}}emitToolCallContentStart($){this.events.emit({type:"agent_event",payload:{sessionId:$.sessionId,event:{type:"content_start",contentType:"tool",toolCallId:$.toolCallId,toolName:$.toolName,input:$.toolInput}}})}emitAgentDoneIfNeeded($){if(this.agentDoneEmittedForCurrentRunBySession.has($.sessionId))return;this.agentDoneEmittedForCurrentRunBySession.add($.sessionId),this.events.emit({type:"agent_event",payload:{sessionId:$.sessionId,event:aR($.payload)}})}handleHubEvent($){let f=$.sessionId?.trim();if($.event==="capability.requested"){this.handleCapabilityRequest($).catch((J)=>{this.captureDetachedHubEventError("hub.runtime_host.capability_request",J,$)});return}if($.event==="capability.resolved"){this.handleCapabilityResolved($);return}if($.event==="approval.requested"){this.handleApprovalRequested($).catch((J)=>{this.captureDetachedHubEventError("hub.runtime_host.approval_request",J,$)});return}if(!f)return;switch($.event){case"run.started":{this.agentDoneEmittedForCurrentRunBySession.delete(f);let J=I$($.payload?.snapshot),Q=$.payload?.session;if(J)this.events.emit({type:"session_snapshot",payload:{sessionId:f,snapshot:J}});this.events.emit({type:"status",payload:{sessionId:f,status:Q?.status??"running"}});return}case"iteration.started":{this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"iteration_start",iteration:typeof $.payload?.iteration==="number"?$.payload.iteration:0}}});return}case"iteration.finished":{this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"iteration_end",iteration:typeof $.payload?.iteration==="number"?$.payload.iteration:0,hadToolCalls:$.payload?.hadToolCalls===!0,toolCallCount:typeof $.payload?.toolCallCount==="number"?$.payload.toolCallCount:0}}});return}case"assistant.delta":{let J=typeof $.payload?.text==="string"?$.payload.text:"";if(!J)return;this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"content_start",contentType:"text",text:J}}});return}case"assistant.finished":{this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"content_end",contentType:"text",text:typeof $.payload?.text==="string"?$.payload.text:void 0}}});return}case"reasoning.delta":{let J=typeof $.payload?.text==="string"?$.payload.text:"",Q=$.payload?.redacted===!0;if(!J&&!Q)return;this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"content_start",contentType:"reasoning",reasoning:J,redacted:Q}}});return}case"reasoning.finished":{this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"content_end",contentType:"reasoning",reasoning:typeof $.payload?.reasoning==="string"?$.payload.reasoning:void 0}}});return}case"agent.done":{this.emitAgentDoneIfNeeded({sessionId:f,payload:$.payload});return}case"usage.updated":{let J=nR($.payload);this.events.emit({type:"agent_event",payload:{sessionId:f,event:J.event,teamAgentId:J.teamAgentId,teamRole:J.teamRole}});return}case"tool.started":{let J=typeof $.payload?.toolCallId==="string"?$.payload.toolCallId:void 0;if(J&&this.pendingApprovalToolCallIds.delete(J))return;this.emitToolCallContentStart({sessionId:f,toolCallId:J,toolName:typeof $.payload?.toolName==="string"?$.payload.toolName:void 0,toolInput:$.payload?.input});return}case"tool.finished":{let J=typeof $.payload?.toolCallId==="string"?$.payload.toolCallId:void 0;if(J)this.pendingApprovalToolCallIds.delete(J);this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"content_end",contentType:"tool",toolCallId:J,toolName:typeof $.payload?.toolName==="string"?$.payload.toolName:void 0,output:$.payload?.output,error:typeof $.payload?.error==="string"?$.payload.error:void 0}}});return}case"session.created":case"session.updated":case"session.attached":case"session.detached":{let J=I$($.payload?.snapshot),Q=$.payload?.session;if(J)this.events.emit({type:"session_snapshot",payload:{sessionId:f,snapshot:J}});this.events.emit({type:"status",payload:{sessionId:f,status:Q?.status??"running"}});return}case"session.pending_prompts":{this.events.emit({type:"pending_prompts",payload:{sessionId:f,prompts:Array.isArray($.payload?.prompts)?$.payload.prompts:[]}});return}case"session.pending_prompt_submitted":{let J=$.payload?.prompt;if(!J)return;this.events.emit({type:"pending_prompt_submitted",payload:{sessionId:f,id:J.id,prompt:J.prompt,delivery:J.delivery,attachmentCount:J.attachmentCount}});return}case"run.completed":case"run.failed":case"run.aborted":{let J=I$($.payload?.snapshot),Q=typeof $.payload?.reason==="string"?$.payload.reason:$.event==="run.aborted"?"aborted":$.event==="run.failed"?"error":"completed";if(this.emitAgentDoneIfNeeded({sessionId:f,payload:{...$.payload,reason:Q}}),J?.interactive===!0&&f0(J.status))return;this.events.emit({type:"ended",payload:{sessionId:f,reason:Q,ts:$.timestamp??Date.now()}});return}default:return}}captureDetachedHubEventError($,f,J){try{Rj(this.telemetry,{component:"core",operation:$,error:f,severity:"warn",handled:!0,context:{event:J.event,sessionId:J.sessionId,runtimeAddress:this.runtimeAddress}})}catch{}}async handleCapabilityRequest($){let f=$.sessionId?.trim();if(!f)return;let J=typeof $.payload?.targetClientId==="string"?$.payload.targetClientId:void 0;if(J&&J!==this.client.getClientId())return;let Q=typeof $.payload?.requestId==="string"?$.payload.requestId:"",Z=typeof $.payload?.capabilityName==="string"?$.payload.capabilityName:"";if(!Q)return;let W=this.sessionClientContributionHandlers.get(f)?.get(Z);if(!W){await this.client.command("capability.respond",{requestId:Q,ok:!1,error:`No client contribution handler registered for capability ${Z} in session ${f}.`},f).catch(()=>{});return}let j=$.payload?.payload&&typeof $.payload.payload==="object"&&!Array.isArray($.payload.payload)?$.payload.payload:{},X=new AbortController;this.activeCapabilityAbortControllers.set(Q,X);let H=(Y)=>{this.client.command("capability.progress",{requestId:Q,payload:Y},f).catch((V)=>{this.captureDetachedHubEventError("hub.runtime_host.capability_progress",V,$)})};try{let Y=await W({payload:j,abortSignal:X.signal,progress:H});if(X.signal.aborted)return;await this.client.command("capability.respond",{requestId:Q,ok:!0,payload:Y},f)}catch(Y){if(X.signal.aborted)return;await this.client.command("capability.respond",{requestId:Q,ok:!1,error:Y instanceof Error?Y.message:String(Y)},f)}finally{this.activeCapabilityAbortControllers.delete(Q)}}handleCapabilityResolved($){if($.payload?.cancelled!==!0)return;let f=typeof $.payload.requestId==="string"?$.payload.requestId.trim():"";if(!f)return;let J=this.activeCapabilityAbortControllers.get(f);if(!J)return;J.abort(lR($.payload.error))}async handleApprovalRequested($){let f=$.sessionId?.trim();if(!f)return;let J=this.sessionCapabilities.get(f)?.requestToolApproval??this.defaultCapabilities.requestToolApproval;if(!J)return;let Q=typeof $.payload?.approvalId==="string"?$.payload.approvalId.trim():"",Z=typeof $.payload?.toolCallId==="string"?$.payload.toolCallId:"",W=typeof $.payload?.toolName==="string"?$.payload.toolName:"";if(!Q||!Z||!W)return;let j=$.payload?.policy&&typeof $.payload.policy==="object"&&!Array.isArray($.payload.policy)?$.payload.policy:{autoApprove:!1},X=pR($.payload?.inputJson);this.pendingApprovalToolCallIds.add(Z),this.emitToolCallContentStart({sessionId:f,toolCallId:Z,toolName:W,toolInput:X});let H=await Promise.resolve(J({sessionId:f,agentId:typeof $.payload?.agentId==="string"?$.payload.agentId:"",conversationId:typeof $.payload?.conversationId==="string"?$.payload.conversationId:f,iteration:typeof $.payload?.iteration==="number"?$.payload.iteration:0,toolCallId:Z,toolName:W,input:X,policy:j})).catch((Y)=>({approved:!1,reason:Y instanceof Error?Y.message:`Tool approval request failed: ${String(Y)}`}));await this.client.command("approval.respond",{approvalId:Q,approved:H.approved,reason:H.reason},f).catch(()=>{})}}class H6 extends P1{constructor($){super({url:o1($.endpoint),authToken:$.authToken,clientType:$.clientType??"core-remote-runtime",displayName:$.displayName??"core remote runtime",capabilities:$.capabilities},{workspaceRoot:$.workspaceRoot,cwd:$.cwd})}}import{existsSync as sR,mkdirSync as oR}from"node:fs";import{join as eR}from"node:path";import{asBool as X8,asOptionalString as a0,asString as H$,ensureSessionSchema as $L,loadSqliteDb as fL,nowIso as Y6,toBoolInt as H8}from"@cline/shared/db";import{resolveDbDataDir as JL}from"@cline/shared/storage";class x${sessionsDirPath;db;constructor($={}){this.sessionsDirPath=$.sessionsDir??JL()}init(){this.getRawDb()}ensureSessionsDir(){if(!sR(this.sessionsDirPath))oR(this.sessionsDirPath,{recursive:!0});return this.sessionsDirPath}sessionDbPath(){return eR(this.ensureSessionsDir(),"sessions.db")}getRawDb(){if(this.db)return this.db;let $=fL(this.sessionDbPath());return $L($,{includeLegacyMigrations:!0}),this.db=$,$}close(){this.db?.close?.(),this.db=void 0}run($,f=[]){return this.getRawDb().prepare($).run(...f)}queryOne($,f=[]){return this.getRawDb().prepare($).get(...f)??void 0}queryAll($,f=[]){return this.getRawDb().prepare($).all(...f)}create($){let f=Y6();this.run(`INSERT OR REPLACE INTO sessions (
|
|
433
|
+
WHERE run_id = ? AND claim_token = ?`).run($.error??null,$.scheduledFor??null,f,$.runId,$.claimToken).changes??0)>0}attachSessionIdToRun($,f){this.db.prepare("UPDATE cron_runs SET session_id = ?, updated_at = ? WHERE run_id = ?").run(f,X0(),$)}attachReportPathToRun($,f){this.db.prepare("UPDATE cron_runs SET report_path = ?, updated_at = ? WHERE run_id = ?").run(f,X0(),$)}}class K2{store;reconciler;watcher;eventIngress;materializer;runner;started=!1;disposed=!1;constructor($){this.store=new B2({dbPath:$.dbPath});let f=$.specs;this.reconciler=new e5({store:this.store,specs:f}),this.materializer=new H2({store:this.store}),this.eventIngress=new v5({store:this.store,logger:$.logger}),this.runner=new X2({store:this.store,materializer:this.materializer,runtimeHandlers:$.runtimeHandlers,workspaceRoot:$.workspaceRoot,specs:f,logger:$.logger,pollIntervalMs:$.pollIntervalMs,claimLeaseSeconds:$.claimLeaseSeconds,globalMaxConcurrency:$.globalMaxConcurrency}),this.watcher=new $W({reconciler:this.reconciler,debounceMs:$.watcherDebounceMs,onReconciled:()=>{this.materializer.materializeAll()},onError:(J)=>{let W=$.logger;if(W)if(W.error)W.error("cron.watcher.failed",{error:J});else W.log("cron.watcher.failed",{error:J})}})}async start(){if(this.disposed)throw Error("CronService disposed");if(this.started)return;this.started=!0,await this.reconciler.reconcileAll(),this.materializer.materializeAll(),this.watcher.start(),await this.runner.start()}async stop(){this.watcher.stop(),await this.runner.stop(),this.started=!1}async dispose(){if(this.disposed)return;this.disposed=!0,this.watcher.dispose(),await this.runner.dispose(),this.store.close()}listSpecs($){return this.store.listSpecs($)}getSpec($){return this.store.getSpec($)}listRuns($){return this.store.listRuns($)}getRun($){return this.store.getRun($)}listActiveRuns(){return this.store.listRuns({status:"running",limit:200})}listUpcomingRuns($=20){return this.store.listRuns({status:"queued",limit:$})}async reconcileNow(){await this.reconciler.reconcileAll(),this.materializer.materializeAll()}ingestEvent($){return this.eventIngress.ingestEvent($)}listEventLogs($){return this.store.listEventLogs($)}getEventLog($){return this.store.getEventLog($)}}import{readdir as YD,readFile as Ij}from"node:fs/promises";import{join as xj}from"node:path";import{formatDisplayUserInput as AD,normalizeUserInput as VD}from"@cline/shared";import{resolveSessionDataDir as mj}from"@cline/shared/storage";import{mkdirSync as $D,writeFileSync as fD}from"node:fs";import{dirname as JD}from"node:path";import{normalizeUserInput as WD}from"@cline/shared";import{nanoid as ZD}from"nanoid";import{nanoid as oR}from"nanoid";function G2($){return $.replace(/[^a-zA-Z0-9._-]+/g,"_")}function _J($,f){let J=G2($),W=G2(f),Z=`${J}__${W}`;return Z.length>180?Z.slice(0,180):Z}function ZW($,f){let J=G2($),W=G2(f);return`${J}__teamtask__${W}__${oR(6)}`}function P2($){let J=$.indexOf("__teamtask__");if(J<=0)return null;let W=$.slice(0,J),Z=$.slice(J+12),Q=Z.lastIndexOf("__");if(Q<=0)return null;let j=Z.slice(0,Q),H=Z.slice(Q+2);if(!W||!j||!H)return null;return{rootSessionId:W,agentId:j,teamTaskId:H}}function zJ($){if(P2($))return null;let f="__",J=$.indexOf(f);if(J<=0)return null;let W=$.slice(0,J),Z=$.slice(J+f.length);if(!W||!Z)return null;return{rootSessionId:W,agentId:Z}}function QW($){switch($.hookName){case"agent_end":return"completed";case"agent_error":return"failed";case"session_shutdown":{let f=String($.reason??"").toLowerCase();if(f.includes("cancel")||f.includes("abort")||f.includes("interrupt"))return"cancelled";if(f.includes("fail")||f.includes("error"))return"failed";return"completed"}default:return"running"}}import{z as i}from"zod";var eR=i.enum(z6),_0=i.object({version:i.literal(1),session_id:i.string().min(1),source:i.string().min(1),pid:i.number().int(),started_at:i.string().min(1),ended_at:i.string().min(1).optional(),exit_code:i.number().int().nullable().optional(),status:eR,interactive:i.boolean(),provider:i.string().min(1),model:i.string().min(1),cwd:i.string().min(1),workspace_root:i.string().min(1),team_name:i.string().min(1).optional(),enable_tools:i.boolean(),enable_spawn:i.boolean(),enable_teams:i.boolean(),prompt:i.string().optional(),metadata:i.record(i.string(),i.unknown()).optional(),messages_path:i.string().min(1).optional()});function yj($){if(!$)return!1;return Object.values($).some((f)=>typeof f==="function")}function HW($,f){let J=[...$??[],...f??[]];if(J.length===0)return;let W=[],Z=new Set;for(let Q of J){if(Z.has(Q.name))continue;Z.add(Q.name),W.push(Q)}return W}function qj($){return JSON.stringify($,(f,J)=>{if(J instanceof Error)return{name:J.name,message:J.message,stack:J.stack};return J})}function Y$($){return typeof $==="string"&&$.trim()?$.trim():void 0}function jW($,f){let J={...$};J.id=Y$(J.id)??ZD();let W=J.modelInfo&&typeof J.modelInfo==="object"?{...J.modelInfo}:void 0,Z={id:Y$(W?.id)??Y$(J.modelId)??Y$(f?.id),provider:Y$(W?.provider)??Y$(J.providerId)??Y$(f?.provider),family:Y$(W?.family)??Y$(f?.family)};if(delete J.providerId,delete J.modelId,Z.id&&Z.provider)J.modelInfo={id:Z.id,provider:Z.provider,...Z.family?{family:Z.family}:{}};else delete J.modelInfo;return J}function TJ($){return $.map((f)=>jW(f))}function NJ($,f,J=[]){let W=$.map((X,Y)=>{let A=J[Y],B=A?.role===X.role&&JSON.stringify(A.content)===JSON.stringify(X.content)?{...A,...X}:{...X};return jW(B)}),Z=J.length,Q=[];for(let X=Z;X<W.length;X+=1)if(W[X]?.role==="assistant")Q.push(X);if(Q.length===0){let X=[...W].reverse().findIndex((Y)=>Y.role==="assistant");if(X===-1)return W;Q.push(W.length-1-X)}let j=Q[Q.length-1],H=Q.some((X)=>W[X]?.metrics);for(let X of Q){let Y=W[X],A=Y.metrics;if(!A&&X===j&&!H){let V=f.usage;A={inputTokens:V.inputTokens,outputTokens:V.outputTokens,cacheReadTokens:V.cacheReadTokens??0,cacheWriteTokens:V.cacheWriteTokens??0,cost:V.totalCost}}W[X]={...jW(Y,{id:f.model.id,provider:f.model.provider,family:f.model.info?.family}),...A?{metrics:A}:{},ts:Y.ts??f.endedAt.getTime()}}return W}function F2($){return{sessionId:$.sessionId,source:$.source,pid:$.pid,startedAt:$.startedAt,endedAt:$.endedAt??null,exitCode:$.exitCode??null,status:$.status,interactive:$.interactive,provider:$.provider,model:$.model,cwd:$.cwd,workspaceRoot:$.workspaceRoot,teamName:$.teamName??void 0,enableTools:$.enableTools,enableSpawn:$.enableSpawn,enableTeams:$.enableTeams,parentSessionId:$.parentSessionId??void 0,parentAgentId:$.parentAgentId??void 0,agentId:$.agentId??void 0,conversationId:$.conversationId??void 0,isSubagent:$.isSubagent,prompt:$.prompt??void 0,metadata:$.metadata??void 0,messagesPath:$.messagesPath??void 0,updatedAt:$.updatedAt}}var QD=120;function _1($){let f=$?.trim();return f?f.slice(0,QD):void 0}function XW($){let f=WD($??"").trim();if(!f)return;return _1(f.split(`
|
|
434
|
+
`)[0]?.trim())}function b$($){if(!$)return;let f={...$},J=_1(typeof f.title==="string"?f.title:void 0);if(J)f.title=J;else delete f.title;return Object.keys(f).length>0?f:void 0}function U2($){let f=b$($.metadata)??{},J=$.title!==void 0?_1($.title):XW($.prompt);if(J)f.title=J;return Object.keys(f).length>0?f:void 0}function YW($){let f=P2($);if(f)return{agent:"teammate",sessionId:f.rootSessionId,taskType:"team"};let J=zJ($);if(J)return{agent:"subagent",sessionId:J.rootSessionId,taskType:"subagent_task"};return{agent:"lead",sessionId:$}}function AW($){return{version:1,updated_at:$.updatedAt,agent:$.context.agent,sessionId:$.context.sessionId,...$.context.taskType?{taskType:$.context.taskType}:{},messages:TJ($.messages),...$.systemPrompt?{system_prompt:$.systemPrompt}:{}}}function wj($,f,J){$D(JD($),{recursive:!0}),fD($,`${JSON.stringify(AW({updatedAt:f,context:J,messages:[]}),null,2)}
|
|
435
|
+
`,"utf8")}function Sj($,f){return _0.parse({version:1,session_id:$.sessionId,source:$.source,pid:$.pid,started_at:$.startedAt,ended_at:f?.endedAt??$.endedAt??void 0,exit_code:f?.exitCode??$.exitCode??void 0,status:f?.status??$.status,interactive:$.interactive,provider:$.provider,model:$.model,cwd:$.cwd,workspace_root:$.workspaceRoot,team_name:$.teamName??void 0,enable_tools:$.enableTools,enable_spawn:$.enableSpawn,enable_teams:$.enableTeams,prompt:$.prompt??void 0,metadata:f?.metadata??$.metadata??void 0,messages_path:$.messagesPath??void 0})}async function hj($,f,J){let W=0;while(!0){let Z=await $();if(Z===void 0)return{updated:!1};let Q=await f(Z);if(typeof Q==="object"&&Q!==null&&"updated"in Q&&Q.updated===!1){if(W+=1,W>=J)return Q;continue}return Q}}import{existsSync as jD}from"node:fs";import{readFile as HD}from"node:fs/promises";import{formatDisplayUserInput as Cj}from"@cline/shared";class R2{listeners=new Set;subscribe($,f){let J={listener:$,sessionId:f?.sessionId?.trim()||void 0};return this.listeners.add(J),()=>{this.listeners.delete(J)}}emit($){let f=$.payload.sessionId?.trim();for(let J of this.listeners){if(J.sessionId&&J.sessionId!==f)continue;J.listener($)}}get size(){return this.listeners.size}}async function k$($){let f=$?.trim();if(!f||!jD(f))return[];try{let J=(await HD(f,"utf8")).trim();if(!J)return[];let W=JSON.parse(J);if(Array.isArray(W))return Ej(W);if(W&&typeof W==="object"&&!Array.isArray(W)){let Z=W.messages;if(Array.isArray(Z))return Ej(Z)}return[]}catch{return[]}}function XD($){if($.role!=="user")return $;if(typeof $.content==="string")return{...$,content:Cj($.content)};return{...$,content:$.content.map((f)=>{if(f.type!=="text"||typeof f.text!=="string")return f;return{...f,text:Cj(f.text)}})}}function Ej($){return $.map(XD)}function VW($){return $?{...$}:void 0}async function bj($,f){if(!($.hookName==="tool_call"||!!$.parent_agent_id))return;await f.queueSpawnRequest($);let W=await f.upsertSubagentSessionFromHook($);if(!W)return;await f.appendSubagentHookAudit(W,$),await f.applySubagentStatus(W,$)}function D2($){if(typeof $!=="string")return;let f=$.trim();return f.length>0?f:void 0}function E0($){let f=D2($);if(!f)return;return f.toLowerCase()==="unknown"?void 0:f}function MJ($){return typeof $==="number"&&Number.isFinite($)?$:void 0}function BD($){if(!$||typeof $!=="object"||Array.isArray($))return;return{...$}}function KW($){let f=$??200;return Number.isFinite(f)?Math.max(0,Math.floor(f)):200}function KD($){if($===0)return 0;return Math.min(Math.max($*2,20),2000)}function GD($){return $.isSubagent!==!0&&!D2($.parentSessionId)}function PD($){let f=$.match(/\d{13,}/g);if(!f||f.length===0)return 0;let J=0;for(let W of f){let Z=Number.parseInt(W,10);if(Number.isFinite(Z)&&Z>J)J=Z}return J}function GW($){return{sessionId:$.session_id,source:$.source,pid:$.pid,startedAt:$.started_at,endedAt:$.ended_at??null,exitCode:$.exit_code??null,status:$.status,interactive:$.interactive,provider:$.provider,model:$.model,cwd:$.cwd,workspaceRoot:$.workspace_root,teamName:$.team_name,enableTools:$.enable_tools,enableSpawn:$.enable_spawn,enableTeams:$.enable_teams,isSubagent:!1,prompt:$.prompt,metadata:$.metadata,messagesPath:$.messages_path,updatedAt:$.ended_at??$.started_at}}async function FD($){let f=KW($);if(f===0)return[];let J=mj(),Z=(await YD(J,{withFileTypes:!0}).catch(()=>[])).filter((j)=>j.isDirectory()).map((j)=>({entry:j,recency:PD(j.name.trim())})).sort((j,H)=>H.recency-j.recency||H.entry.name.localeCompare(j.entry.name));return(await Promise.all(Z.map(async({entry:j})=>{let H=j.name.trim();if(!H)return;let X=xj(J,H,`${H}.json`),Y=await Ij(X,"utf8").catch(()=>{return});if(!Y)return;let A;try{A=JSON.parse(Y)}catch{return}let V=_0.safeParse(A);if(!V.success)return;return GW(V.data)}))).filter((j)=>Boolean(j)).sort((j,H)=>H.startedAt.localeCompare(j.startedAt)).slice(0,f)}async function UD($,f,J){let W=KW(f);if(W===0)return await $.listSessions(0),[];let Z=J.includeSubagents?W:KD(W),Q=await $.listSessions(Z);return(J.includeSubagents?Q:Q.filter(GD)).slice(0,W)}function RD($){if(typeof $==="string")return $.trim();let f=[];for(let J of $){if(!J||typeof J!=="object")continue;let W=J;if(W.type!=="text")continue;let Z=W.text?.trim();if(Z)f.push(Z)}return f.join(`
|
|
436
|
+
`).trim()}function kj($){return $.replace(/\s+/g," ").trim()}function DD($,f){if($.length<=f)return $;return`${$.slice(0,Math.max(0,f-3)).trimEnd()}...`}function LD($){for(let f of["user","assistant"])for(let J of $){if(J.role!==f)continue;let W=kj(RD(J.content));if(!W)continue;let Z=f==="user"?kj(AD(W)):W,Q=VD(Z.split(`
|
|
437
|
+
`)[0]??Z);return DD(Q,50)}return}function OD($){let f=0;for(let J of $)f+=MJ(J.metrics?.cost)??0;return f}function _D($){let f,J;for(let W=$.length-1;W>=0;W-=1){let Z=$[W];if(!f)f=E0(Z.modelInfo?.provider);if(!J)J=E0(Z.modelInfo?.id);if(f&&J)break}return{provider:f,model:J}}function zD($){return E0($?.provider)??E0($?.provider&&typeof $.provider==="object"&&!Array.isArray($.provider)?$.provider.id:void 0)}function TD($){return E0($?.model)??E0($?.model&&typeof $.model==="object"&&!Array.isArray($.model)?$.model.id:void 0)}function BW($,f){let J=BD($.metadata),W=D2(f?.title)??D2(J?.title),Z=MJ(f?.totalCost)??MJ(J?.totalCost),Q=J||W!==void 0||Z!==void 0?{...J??{},...W!==void 0?{title:W}:{},...Z!==void 0?{totalCost:Z}:{}}:void 0;return{...$,provider:E0(f?.provider)??E0($.provider)??zD(J)??"",model:E0(f?.model)??E0($.model)??TD(J)??"",metadata:Q}}function ND($){let f=$.content;if(!Array.isArray(f))return!1;return f.some((J)=>!!J&&typeof J==="object"&&J.type==="tool-call")}function MD($,f){if($.status!=="running"||$.interactive!==!0)return!1;let J=f.at(-1);return J?.role==="assistant"&&!ND(J)}async function yD($,f){return await Promise.all(f.map(async(J)=>{if(J.status!=="running"||J.interactive!==!0)return J;let W=await $.readSessionMessages(J.sessionId);return MD(J,W)?{...J,status:"idle"}:J}))}async function qD($,f){return await Promise.all(f.map(async(J)=>{let W=BW(J),Z=Boolean(D2(W.metadata?.title)),Q=Boolean(E0(W.provider)),j=Boolean(E0(W.model)),H=MJ(W.metadata?.totalCost),X=H!==void 0&&H>0;if(Z&&Q&&j&&X)return W;let Y=await $.readSessionMessages(J.sessionId);if(Y.length===0)return W;let A=_D(Y),V=OD(Y);return BW(J,{title:Z?void 0:LD(Y),provider:Q?void 0:A.provider,model:j?void 0:A.model,totalCost:X||V<=0?void 0:V})}))}async function PW($,f={}){let J=KW(f.limit),W=f.includeSubagents===!0,Z=await UD($,J,{includeSubagents:W}),Q=f.includeManifestFallback===!0&&Z.length<J?await FD(Math.min(Math.max(J*2,100),500)):[],j=new Map;for(let Y of[...Z,...Q]){if(j.has(Y.sessionId))continue;j.set(Y.sessionId,Y)}let H=Q.length===0?Z:Array.from(j.values()).sort((Y,A)=>A.startedAt.localeCompare(Y.startedAt)).slice(0,J),X=await yD($,H);if(f.hydrate===!1)return X.map((Y)=>BW(Y));return await qD($,X)}async function wD($){let f=$.trim();if(!f)return;let J=xj(mj(),f,`${f}.json`),W=await Ij(J,"utf8").catch(()=>{return});if(!W)return;try{let Z=_0.safeParse(JSON.parse(W));return Z.success?Z.data.messages_path:void 0}catch{return}}async function SD($,f={}){let J=new Map;return await PW({listSessions:async(Z)=>{let Q=await $.listSessions(Z);J.clear();for(let j of Q)J.set(j.sessionId,j);return Q.map(F2)},readSessionMessages:async(Z)=>{let Q=J.get(Z)?.messagesPath??await wD(Z);return await k$(Q)}},f)}import{captureSdkError as YY}from"@cline/shared";import{createSessionId as yL,resolveHubCommandTimeoutMs as qL}from"@cline/shared";import{spawn as ZL}from"node:child_process";import{closeSync as QL,mkdirSync as jL,openSync as HL}from"node:fs";import{basename as XL,dirname as YL,join as AL}from"node:path";import{fileURLToPath as VL}from"node:url";import{CLINE_RUN_AS_HUB_DAEMON_ENV as BL,isHubDaemonProcess as tj,withResolvedClineBuildEnv as KL}from"@cline/shared";import{createHash as hD,randomBytes as CD}from"node:crypto";import{existsSync as ED}from"node:fs";import{chmod as bD,mkdir as FW,readFile as dj,rm as UW,writeFile as lj}from"node:fs/promises";import{dirname as pj,join as RW}from"node:path";import{resolveClineDataDir as DW,resolveClineDir as Ck}from"@cline/shared/storage";var vj="0.0.43";var L2={name:"@cline/core",description:"Cline Core SDK for Node Runtime",version:vj,repository:{type:"git",url:"https://github.com/cline/cline",directory:"sdk/packages/core"},type:"module",types:"./dist/index.d.ts",main:"./dist/index.js",private:!1,publishConfig:{access:"public"},exports:{".":{types:"./dist/index.d.ts",import:"./dist/index.js"},"./hub":{types:"./dist/hub/index.d.ts",import:"./dist/hub/index.js"},"./hub/daemon-entry":{types:"./dist/hub/daemon/entry.d.ts",import:"./dist/hub/daemon/entry.js"},"./telemetry":{types:"./dist/services/telemetry/index.d.ts",import:"./dist/services/telemetry/index.js"}},scripts:{build:"bun run ./bun.mts && bun tsc -p tsconfig.build.json",typecheck:"bun tsc -p tsconfig.dev.json --noEmit && bun run typecheck:smoke","typecheck:smoke":"bun tsc -p tsconfig.smoke.json --noEmit",test:"bun run test:unit && bun run test:e2e","test:live":"vitest run --config vitest.config.ts src/extensions/context/compaction.live.test.ts","test:unit":"vitest run --config vitest.config.ts","test:e2e":"vitest run --config vitest.e2e.config.ts","verify:routines":"zsh -lc 'bunx vitest run src/cron/schedule-service.test.ts --config vitest.config.ts'","test:watch":"vitest --config vitest.config.ts"},dependencies:{"@cline/agents":"workspace:*","@cline/shared":"workspace:*","@cline/llms":"workspace:*","@modelcontextprotocol/sdk":"^1.29.0","@opentelemetry/api":"^1.9.0","@opentelemetry/api-logs":"^0.214.0","@opentelemetry/exporter-logs-otlp-http":"^0.214.0","@opentelemetry/exporter-metrics-otlp-http":"^0.214.0","@opentelemetry/exporter-trace-otlp-http":"^0.214.0","@opentelemetry/resources":"^2.6.1","@opentelemetry/sdk-logs":"^0.214.0","@opentelemetry/sdk-metrics":"^2.6.1","@opentelemetry/sdk-trace-base":"^2.6.1","@opentelemetry/sdk-trace-node":"^2.6.1","@opentelemetry/semantic-conventions":"^1.40.0",jiti:"^2.7.0","node-machine-id":"^1.1.12",nanoid:"^5.1.7","simple-git":"3.36.0",ws:"^8.20.0",yaml:"^2.8.2",zod:"^4.3.6"},devDependencies:{"@types/ws":"^8.18.1"},engines:{node:">=22"},files:["dist","!dist/**/*.d.ts.map"]};var kD="CLINE_HUB_DISCOVERY_PATH",ID="CLINE_HUB_BUILD_ID",uj=30000,xD=15000,mD=100;function gD($){return $.replace(/[^a-zA-Z0-9_.-]+/g,"_")}function vD($){return hD("sha256").update($).digest("hex").slice(0,12)}function uD($){if(!Number.isInteger($)||!$||$<=0)return!1;try{return process.kill($,0),!0}catch(f){return f instanceof Error&&"code"in f?String(f.code)==="EPERM":!1}}function rj(){return CD(32).toString("hex")}function cD($){return new Promise((f)=>setTimeout(f,$))}function dD($){return`${$}.lock`}async function lD($){try{let f=JSON.parse(await dj(RW($,"owner.json"),"utf8"));if(typeof f.pid!=="number"||typeof f.acquiredAt!=="string")return;return{pid:f.pid,acquiredAt:f.acquiredAt}}catch{return}}async function cj($){await UW($,{recursive:!0,force:!0}).catch(()=>{return})}function Hf(){return process.env[ID]?.trim()||String(L2.version)}function z1($=process.argv[1]?.trim()||process.cwd()){let f=`hub-${vD($)}`,J=process.env[kD]?.trim()||RW(DW(),"locks","hub","owners",`${gD(f)}.json`);return{ownerId:f,discoveryPath:J}}function bk($=`hub-${Date.now().toString(36)}`){return z1($)}async function K0($){try{let f=JSON.parse(await dj($,"utf8"));if(typeof f.hubId!=="string"||typeof f.protocolVersion!=="string"||typeof f.authToken!=="string"||typeof f.host!=="string"||typeof f.port!=="number"||typeof f.url!=="string"||typeof f.startedAt!=="string"||typeof f.updatedAt!=="string")return;return{hubId:f.hubId,protocolVersion:f.protocolVersion,coreVersion:typeof f.coreVersion==="string"?f.coreVersion:void 0,buildId:typeof f.buildId==="string"?f.buildId:void 0,authToken:f.authToken,host:f.host,port:f.port,url:f.url,pid:typeof f.pid==="number"?f.pid:void 0,startedAt:f.startedAt,updatedAt:f.updatedAt}}catch{return}}async function ij($,f){await FW(pj($),{recursive:!0}),await UW($,{force:!0}).catch(()=>{return}),await lj($,`${JSON.stringify(f,null,2)}
|
|
438
|
+
`,{encoding:"utf8",mode:384}),await bD($,384)}async function e0($){await UW($,{force:!0}).catch(()=>{return})}async function nj($,f){let J=dD($);await FW(pj(J),{recursive:!0});let W=Date.now()+xD;while(!0)try{await FW(J,{recursive:!1}),await lj(RW(J,"owner.json"),`${JSON.stringify({pid:process.pid,acquiredAt:new Date().toISOString()},null,2)}
|
|
439
|
+
`,"utf8");try{return await f()}finally{await cj(J)}}catch(Z){if((Z instanceof Error&&"code"in Z?String(Z.code):"")!=="EEXIST")throw Z;let j=await lD(J),H=j?Date.now()-Date.parse(j.acquiredAt):uj+1;if(!j||!uD(j.pid)||H>uj){await cj(J);continue}if(Date.now()>=W)throw Error(`Timed out waiting for hub startup lock ${J}`);await cD(mD)}}async function I$($){try{let f=await fetch(pD($));if(!f.ok)return;return await f.json()}catch{return}}function A$($,f,J="/hub"){return new URL(`ws://${$}:${f}${J}`).toString()}function pD($){let f=new URL($);return f.protocol=f.protocol==="wss:"?"https:":"http:",f.pathname="/health",f.search="",f.toString()}function kk($){return ED($)}import{CLINE_HUB_DEV_PORT as rD,CLINE_HUB_PORT as iD,resolveClineBuildEnv as nD}from"@cline/shared";var aD="CLINE_HUB_HOST",tD="CLINE_HUB_PORT",sD="CLINE_HUB_PATHNAME",oD="127.0.0.1",eD=iD,$L="/hub";function aj($){return nD($)==="development"?rD:eD}function fL($={}){return($.env??process.env)[aD]?.trim()||oD}function yJ($={}){let J=($.env??process.env)[tD]?.trim();if(!J)return aj($);let W=Number.parseInt(J,10);if(!Number.isInteger(W)||W<1||W>65535)return aj($);return W}function JL($={}){return($.env??process.env)[sD]?.trim()||$L}function x$($={},f={}){return{host:$.host??fL(f),port:$.port??yJ(f),pathname:$.pathname??JL(f)}}var WL="shared:cline";function uk($){let f=R1($.trim());return z1(`workspace:${f||$.trim()}`)}function R0($=WL){return z1($)}var GL=8000,PL=200,FL=3000,UL=100,RL=[100,250,500,1000,2000],DL="--cline-hub-daemon";function LL($){return[...$.host?["--host",$.host]:[],...typeof $.port==="number"?["--port",String($.port)]:[],...$.pathname?["--pathname",$.pathname]:[]]}function OL(){try{let $=AL(DW(),"logs","hub-daemon.log");return jL(YL($),{recursive:!0}),{fd:HL($,"a"),logPath:$}}catch{return}}function O2($){let f=$.buildId?.trim();return!!f&&f===Hf()}async function T1($){try{return await I$($)}catch{return}}async function _L($,f){let J=Date.now()+f;while(Date.now()<J){if(!(await T1($))?.url)return!0;await new Promise((Z)=>setTimeout(Z,UL))}return!1}async function _2($,f){if(O2($))return;if(await LW($.url,$.authToken).catch(()=>!1),$.pid)try{process.kill($.pid,"SIGTERM")}catch{}await _L($.url,FL),await e0(f).catch(()=>{return})}function zL(){let $=import.meta.url.endsWith(".ts")?"ts":"js";return VL(new URL(`./entry.${$}`,import.meta.url))}function TL($,f){let J=zL(),W=process.execPath?.trim();if(!W)throw Error("unable to resolve runtime executable for hub daemon");let Z=XL(W).toLowerCase().includes("bun"),Q=J.startsWith("/$bunfs/"),j=Z&&J.toLowerCase().endsWith(".ts"),H=Q?[DL]:[...j?["--conditions=development"]:[],J];return{launcher:W,args:[...H,"--cwd",$,...LL(f)],cwd:$,env:{...KL(process.env),CLINE_NO_INTERACTIVE:"1",[BL]:"1"}}}function NL($){if(!$||typeof $!=="object")return!1;if(("code"in $?$.code:void 0)==="ETXTBSY")return!0;let J="message"in $?$.message:void 0;return typeof J==="string"&&J.includes("ETXTBSY")}function ML($,f={}){if(tj())return;let J=TL($,f),W=OL();try{ZL(J.launcher,J.args,{detached:!0,stdio:W?["ignore",W.fd,W.fd]:"ignore",env:J.env,cwd:J.cwd}).unref()}finally{if(W)QL(W.fd)}}async function qJ($,f={}){for(let J=0;;J++)try{ML($,f);return}catch(W){let Z=RL[J];if(!NL(W)||Z===void 0)throw W;await new Promise((Q)=>setTimeout(Q,Z))}}function sj($,f={}){if(tj())return;let J=R0(),W=f.port!==void 0||!!process.env.CLINE_HUB_PORT?.trim(),Z=x$(f),Q=A$(Z.host,Z.port,Z.pathname);K0(J.discoveryPath).then(async(j)=>{if(j?.url){let A=await T1(j.url);if(A?.url&&O2(A)&&await m$(A.url,{authToken:j.authToken}))return;if(A?.url)await _2({...A,authToken:j.authToken},J.discoveryPath);else await e0(J.discoveryPath).catch(()=>{return})}let H=await T1(Q);if(H?.url)await _2(H,J.discoveryPath);let Y=!W&&Z.port!==0?{...Z,port:0}:Z;await qJ($,Y)}).catch(()=>{})}async function ok($,f={}){let J=R0(),W=f.host!==void 0||f.port!==void 0||f.pathname!==void 0||!!process.env.CLINE_HUB_PORT?.trim(),Z=f.port!==void 0||!!process.env.CLINE_HUB_PORT?.trim(),Q=x$(f),j=A$(Q.host,Q.port,Q.pathname),H=(K)=>{if(!W)Xf(K.url,K.authToken);return K},X=await K0(J.discoveryPath);if(X?.url){let K=await T1(X.url);if(K?.url&&O2(K)&&await m$(K.url,{authToken:X.authToken}))return H({url:K.url,authToken:X.authToken});if(K?.url)await _2({...K,authToken:X.authToken},J.discoveryPath);else await e0(J.discoveryPath).catch(()=>{return})}let Y=await T1(j);if(Y?.url)await _2(Y,J.discoveryPath);let V=!Z&&Q.port!==0?{...Q,port:0}:Q;await qJ($,V);let B=Date.now()+GL;while(Date.now()<B){let K=await K0(J.discoveryPath);if(K?.url){let R=await T1(K.url);if(R?.url&&O2(R)&&await m$(R.url,{authToken:K.authToken}))return H({url:R.url,authToken:K.authToken})}let G=await T1(j);if(G?.url&&!O2(G))await _2(G,J.discoveryPath);await new Promise((R)=>setTimeout(R,PL))}throw Error("Timed out waiting for detached hub startup.")}function wL(){let $=globalThis.WebSocket;if(!$)throw Error("Global WebSocket is not available in this runtime. Node 22+ is required for hub mode.");return $}function JH($){if(typeof $==="string")return $;if($ instanceof Uint8Array)return Buffer.from($).toString();if($ instanceof ArrayBuffer)return Buffer.from($).toString();if(Array.isArray($))return Buffer.concat($.map((f)=>Buffer.from(f))).toString();if($&&typeof $==="object"&&"data"in $&&typeof $.data<"u")return JH($.data);return String($)}function SL($){if(typeof $==="string")return $;if($ instanceof Uint8Array)return Buffer.from($).toString("utf8");if($ instanceof ArrayBuffer)return Buffer.from($).toString("utf8");return""}function oj($){let f=$,J=SL(f.reason);return new b0("hub_connection_closed",f.code||J?`Hub connection closed (code=${f.code??0}${J?`, reason=${J}`:""})`:OW,{closeCode:f.code,closeReason:J||void 0})}function hL($,f){if($ instanceof b0)return $;if($ instanceof Error)return new b0("hub_connect_failed",$.message);if($&&typeof $==="object"&&"error"in $&&$.error instanceof Error)return new b0("hub_connect_failed",$.error.message);let J=$&&typeof $==="object"&&"message"in $&&typeof $.message==="string"?$.message.trim():"";if(J)return new b0("hub_connect_failed",J);let W=$&&typeof $==="object"&&"type"in $&&typeof $.type==="string"?$.type.trim():"";return new b0("hub_connect_failed",W?`Failed to connect to hub at ${f.toString()} (${W} event before socket open).`:`Failed to connect to hub at ${f.toString()}.`)}var CL=8000,EL=200,ej="*",$H=8000,bL="cline-hub-auth.",WH=new Map,ZH=new Set,kL=3000,IL=3000,xL=100,OW="Hub connection closed",mL=250,gL=5000,fH=0.5;class b0 extends Error{code;details;constructor($,f,J){super(f);this.code=$;this.details=J;this.name="HubTransportError"}}function vL($){return $ instanceof b0}class wJ extends Error{command;code;constructor($,f,J){super(J);this.command=$;this.code=f;this.name="HubCommandError"}}function QH($,f){return $ instanceof wJ&&$.code==="hub_command_timeout"&&(f===void 0||$.command===f)}function jH($){let f=$.searchParams.get("authToken")?.trim();if($.searchParams.delete("authToken"),f)return f;let J=TW($.toString());return J?WH.get(J):void 0}function uL($){try{let J=new URL($).hostname.toLowerCase().replace(/^\[|\]$/g,"");return J==="localhost"||J==="127.0.0.1"||J==="::1"}catch{return!1}}function TW($){if(!uL($))return;let f=new URL(Yf($));return f.search="",f.hash="",f.toString()}function _W($){let f=TW($);return!!f&&ZH.has(f)}function Xf($,f){let J=TW($);if(J){if(ZH.add(J),f?.trim())WH.set(J,f)}return $}class V${options;socket;connectPromise;clientId;currentUrl;recoveryPromise;pendingReplies=new Map;listeners=new Set;subscriptionCounts=new Map;reconnectTimer;reconnectAttempt=0;closedByClient=!1;lastCloseError=new b0("hub_connection_closed",OW);sawSocketClose=!1;registered=!1;constructor($){this.options=$;this.clientId=$.clientId??`core-${Math.random().toString(36).slice(2,10)}-${Date.now().toString(36)}`,this.currentUrl=$.url}getClientId(){return this.clientId}getUrl(){return this.currentUrl}async connect(){if(this.socket&&(this.socket.readyState===1||this.socket.readyState===0))return this.connectPromise??Promise.resolve();this.closedByClient=!1,this.clearReconnectTimer();let $=new URL(this.currentUrl),f=this.options.authToken?.trim()||jH($);$.hash="";let W=new(wL())($.toString(),f?[`${bL}${f}`]:void 0);this.socket=W;let Z=!1;this.connectPromise=new Promise((Q,j)=>{let H=!1,X=setTimeout(()=>{if(H)return;H=!0,Z=!0,this.lastCloseError=new b0("hub_connect_timeout",`Timed out connecting to hub after ${$H}ms`),this.sawSocketClose=!1,this.connectPromise=void 0,this.socket=void 0;try{W.close()}catch{}j(this.lastCloseError)},$H);W.addEventListener("open",()=>{if(H)return;H=!0,clearTimeout(X),Q()}),W.addEventListener("error",(Y)=>{if(H)return;H=!0,clearTimeout(X),this.lastCloseError=hL(Y,$),this.sawSocketClose=!1,this.connectPromise=void 0,this.socket=void 0,j(this.lastCloseError)}),W.addEventListener("close",(Y)=>{if(H)return;if(H=!0,clearTimeout(X),!Z)this.lastCloseError=oj(Y),this.sawSocketClose=!0;this.connectPromise=void 0,this.socket=void 0,j(this.lastCloseError)})}),W.addEventListener("message",(Q)=>{this.handleFrame(JSON.parse(JH(Q)))}),W.addEventListener("close",(Q)=>{if(this.socket!==W)return;if(!Z)this.lastCloseError=oj(Q),this.sawSocketClose=!0;this.registered=!1;for(let j of this.pendingReplies.values())j.reject(this.lastCloseError);if(this.pendingReplies.clear(),this.connectPromise=void 0,this.socket=void 0,!this.closedByClient&&this.hasActiveSubscriptions())this.scheduleReconnect()}),await this.connectPromise,await this.command("client.register",{clientId:this.clientId,clientType:this.options.clientType??"core",displayName:this.options.displayName??"core",transport:"native",actorKind:"client",workspaceContext:{workspaceRoot:this.options.workspaceRoot,cwd:this.options.cwd}}),this.registered=!0;for(let Q of this.subscriptionCounts.keys())this.sendSubscriptionFrame("stream.subscribe",this.subscriptionSessionIdFromKey(Q));this.reconnectAttempt=0}subscribe($,f){let J=f?.sessionId?.trim()||void 0,W={listener:$,sessionId:J};return this.listeners.add(W),this.adjustSubscriptionCount(J,1),()=>{if(!this.listeners.delete(W))return;this.adjustSubscriptionCount(J,-1)}}async command($,f,J,W){let Z=0,Q=$!=="client.register"&&$!=="client.unregister";while(!0)try{return await this.commandOnce($,f,J,W)}catch(j){if(!Q||Z>=1||!await this.recoverLocalHubTransport(j))throw j;Z+=1}}async commandOnce($,f,J,W){await this.connect();let Z=yL("hubreq_"),Q=qL($,W?.timeoutMs),j=new Promise((X,Y)=>{let A=Q===null?void 0:setTimeout(()=>{if(!this.pendingReplies.delete(Z))return;Y(new wJ($,"hub_command_timeout",`Hub command ${$} timed out after ${Q}ms (hub=${this.currentUrl}, requestId=${Z}, clientId=${this.clientId}). Check hub-daemon.log for matching command.start/command.slow entries, or run 'cline doctor fix' to restart the hub.`))},Q);this.pendingReplies.set(Z,{resolve:(V)=>{if(A)clearTimeout(A);X(V)},reject:(V)=>{if(A)clearTimeout(A);Y(V)}})});try{this.sendFrame({kind:"command",envelope:{version:"v1",command:$,requestId:Z,clientId:this.clientId,sessionId:J,timeoutMs:Q,payload:f}})}catch(X){throw this.pendingReplies.delete(Z),X}let H=await j;if(!H.ok){if(H.error?.code===Q2){let X=J??(typeof f?.sessionId==="string"?f.sessionId:void 0);throw new F1(X,H.error.message)}throw new wJ($,H.error?.code,H.error?.message??`Hub command ${$} failed`)}return H}async recoverLocalHubTransport($){if(!_W(this.currentUrl)||!vL($))return!1;if(this.recoveryPromise)return await this.recoveryPromise;return this.recoveryPromise=(async()=>{let f=await z2({workspaceRoot:this.options.workspaceRoot,cwd:this.options.cwd}).catch(()=>{return});if(!f)return!1;return this.currentUrl=f,this.close(),!0})().finally(()=>{this.recoveryPromise=void 0}),await this.recoveryPromise}hasActiveSubscriptions(){return this.subscriptionCounts.size>0}clearReconnectTimer(){if(!this.reconnectTimer)return;clearTimeout(this.reconnectTimer),this.reconnectTimer=void 0}scheduleReconnect(){if(this.reconnectTimer||this.closedByClient||!this.hasActiveSubscriptions())return;let $=Math.min(mL*2**this.reconnectAttempt,gL),f=Math.round($*(1-fH)+Math.random()*$*fH);this.reconnectTimer=setTimeout(()=>{this.reconnectTimer=void 0,this.reconnectSubscribedTransport()},f)}async reconnectSubscribedTransport(){if(this.closedByClient||!this.hasActiveSubscriptions())return;try{await this.connect(),this.reconnectAttempt=0}catch{if(!_W(this.currentUrl)){this.reconnectAttempt+=1,this.scheduleReconnect();return}try{let $=await z2({workspaceRoot:this.options.workspaceRoot,cwd:this.options.cwd});if($){this.currentUrl=$,await this.connect(),this.reconnectAttempt=0;return}}catch{}this.reconnectAttempt+=1,this.scheduleReconnect()}}close(){let $=this.socket;if(this.closedByClient=!0,this.clearReconnectTimer(),this.registered=!1,!$)return;this.lastCloseError=new b0("hub_connection_closed",OW),this.sawSocketClose=!1;for(let f of this.pendingReplies.values())f.reject(this.lastCloseError);this.pendingReplies.clear(),this.connectPromise=void 0,this.socket=void 0;try{$.close()}catch{}}async dispose(){if(this.socket?.readyState===1&&this.registered)try{await this.command("client.unregister",void 0,void 0,{timeoutMs:2000})}catch{}this.close()}sendFrame($){if(!this.socket||this.socket.readyState!==1){if(this.lastCloseError.code==="hub_connection_closed"&&!this.sawSocketClose)throw new b0("hub_connection_not_open","Hub connection is not open.");throw this.lastCloseError}this.socket.send(JSON.stringify($))}sendSubscriptionFrame($,f){this.sendFrame({kind:$,clientId:this.clientId,...f?{sessionId:f}:{}})}adjustSubscriptionCount($,f){let J=this.subscriptionKeyForSessionId($),W=(this.subscriptionCounts.get(J)??0)+f;if(W<=0){if(this.subscriptionCounts.delete(J),!this.hasActiveSubscriptions())this.clearReconnectTimer();if(f<0&&this.socket?.readyState===1)this.sendSubscriptionFrame("stream.unsubscribe",$);return}if(this.subscriptionCounts.set(J,W),f>0&&W===1&&this.socket?.readyState===1)this.sendSubscriptionFrame("stream.subscribe",$)}subscriptionKeyForSessionId($){return $??ej}subscriptionSessionIdFromKey($){return $===ej?void 0:$}handleFrame($){switch($.kind){case"reply":{let f=$.envelope.requestId;if(!f)return;let J=this.pendingReplies.get(f);if(!J)return;this.pendingReplies.delete(f),J.resolve($.envelope);return}case"event":for(let f of this.listeners){if(f.sessionId&&f.sessionId!==$.envelope.sessionId?.trim())continue;f.listener($.envelope)}return;case"command":case"stream.subscribe":case"stream.unsubscribe":return}}}function Yf($){let f=new URL($);if(f.protocol==="http:")f.protocol="ws:";else if(f.protocol==="https:")f.protocol="wss:";return f.toString()}async function m$($,f){let J=new V$({url:$,authToken:f?.authToken,clientType:"hub-healthcheck",displayName:"hub healthcheck",workspaceRoot:f?.workspaceRoot,cwd:f?.cwd});try{return await J.connect(),!0}catch{return!1}finally{J.close()}}async function zW($,f){let J=Yf($),W=await I$(J);if(!W)return{status:"unreachable",url:J};let Z=Hf(),Q=W.buildId?.trim();if(!Q||Q!==Z)return{status:"build_mismatch",url:J};if(f?.verifyConnection===!0&&!await m$(J,{workspaceRoot:f.workspaceRoot,cwd:f.cwd,authToken:f.authToken}))return{status:"unreachable",url:J};return{status:"compatible",url:J}}async function cL($){let f=Date.now()+CL;while(Date.now()<f){let J=await K0($.discoveryPath);if(J?.url){let W=await zW(J.url,{verifyConnection:!0,authToken:J.authToken});if(W.status==="compatible")return Xf(W.url,J.authToken)}await new Promise((W)=>setTimeout(W,EL))}return}async function dL($){let f=Date.now()+IL;while(Date.now()<f){if(!(await I$($).catch(()=>{return}))?.url)return!0;await new Promise((W)=>setTimeout(W,xL))}return!1}function lL($,f){try{return Yf($)===Yf(f)}catch{return!1}}function pL($){return($&&typeof $==="object"&&Array.isArray($.sessions)?$.sessions:[]).some((J)=>{if(!J||typeof J!=="object")return!1;let W=J;if(W.status==="running"||W.status==="idle"||W.status==="pending")return!0;return Array.isArray(W.participants)&&W.participants.length>0})}async function rL($,f,J){let W=new V$({url:$,authToken:f,clientType:"hub-recovery-check",displayName:"hub recovery check",workspaceRoot:J?.workspaceRoot,cwd:J?.cwd});try{let Z=await W.command("session.list",{limit:500},void 0,{timeoutMs:kL});return!pL(Z.payload)}catch{return!1}finally{await W.dispose().catch(()=>{return})}}async function NW($={}){if($.endpoint?.trim()){let Z=await zW($.endpoint);return Z.status==="compatible"?Z.url:void 0}let f=R0(),J=await K0(f.discoveryPath);if(!J?.url)return;let W=await zW(J.url);if(W.status==="compatible")return Xf(W.url,J.authToken);if(W.status==="build_mismatch")await e0(f.discoveryPath).catch(()=>{return});return}async function z2($={}){let f=await NW($);if(f&&await m$(f,{workspaceRoot:$.workspaceRoot,cwd:$.cwd}))return f;if($.endpoint?.trim())return;let J=R0();return await qJ($.workspaceRoot??process.cwd()),await cL(J)}async function LW($,f){let J=new URL($),W=f?.trim()||jH(J);if(J.protocol==="ws:")J.protocol="http:";else if(J.protocol==="wss:")J.protocol="https:";return J.pathname="/shutdown",J.hash="",(await fetch(J,{method:"POST",headers:W?{authorization:`Bearer ${W}`}:void 0})).ok}async function iL(){let $=R0(),f=await K0($.discoveryPath);if(!f?.url)return!1;try{if(await LW(f.url,f.authToken))return!0}catch{}return!1}async function HH($){if(!_W($.url))return;let f=R0(),J=await K0(f.discoveryPath);if(!J?.url||!lL(J.url,$.url))return;if(!await rL(J.url,J.authToken,{workspaceRoot:$.workspaceRoot,cwd:$.cwd}))return;if(!await iL())return;if(!await dL(J.url))return;return await e0(f.discoveryPath).catch(()=>{return}),await z2({workspaceRoot:$.workspaceRoot,cwd:$.cwd})}import{captureSdkError as XH,createSessionId as YH,HUB_CHECKPOINT_CAPABILITY as sL,HUB_COMPACTION_CAPABILITY as oL,HUB_CUSTOM_TOOL_CAPABILITY_PREFIX as eL,HUB_HOOK_CAPABILITY_PREFIX as $O,HUB_MISTAKE_LIMIT_CAPABILITY as fO,HUB_TOOL_EXECUTOR_CAPABILITY_PREFIX as JO,HUB_USER_INSTRUCTIONS_SNAPSHOT_CAPABILITY as WO,isHubToolExecutorName as ZO}from"@cline/shared";function nL($){return $?JSON.parse(JSON.stringify($)):void 0}function aL($){return $?JSON.parse(JSON.stringify($)):void 0}function tL($){let f=$?.checkpoint&&typeof $.checkpoint==="object"&&!Array.isArray($.checkpoint)?$.checkpoint:void 0,W=(Array.isArray(f?.history)?f.history:[]).filter((j)=>!!j&&typeof j==="object"&&!Array.isArray(j)).flatMap((j)=>{let H=typeof j.ref==="string"?j.ref.trim():"",X=Number(j.createdAt),Y=Number(j.runCount);if(!H||!Number.isFinite(X)||!Number.isInteger(Y))return[];return[{ref:H,createdAt:X,runCount:Y,...j.kind==="stash"||j.kind==="commit"?{kind:j.kind}:{}}]}),Z=W.at(-1),Q=$?.checkpointEnabled===!0?!0:void 0;if(!Q&&W.length===0)return;return{...Q?{enabled:Q}:{},...Z?{latest:Z}:{},history:W}}function g$($){let{session:f}=$,J=nL(f.metadata);return{version:1,sessionId:f.sessionId,source:f.source,status:f.status,createdAt:f.startedAt,updatedAt:f.updatedAt,endedAt:f.endedAt??null,exitCode:f.exitCode??null,interactive:f.interactive,workspace:{cwd:f.cwd,root:f.workspaceRoot},model:{providerId:f.provider,modelId:f.model},capabilities:{enableTools:f.enableTools,enableSpawn:f.enableSpawn,enableTeams:f.enableTeams},lineage:{...f.parentSessionId?{parentSessionId:f.parentSessionId}:{},...f.parentAgentId?{parentAgentId:f.parentAgentId}:{},...f.agentId?{agentId:f.agentId}:{},...f.conversationId?{conversationId:f.conversationId}:{},isSubagent:f.isSubagent},...f.teamName?{team:{name:f.teamName}}:{},...f.prompt?{prompt:f.prompt}:{},...J?{metadata:J}:{},...f.messagesPath?{artifacts:{messagesPath:f.messagesPath}}:{},...$.messages?{messages:aL($.messages)}:{},...$.usage?{usage:{...$.usage}}:{},...$.aggregateUsage?{aggregateUsage:{...$.aggregateUsage}}:{},...(()=>{let W=tL(J);return W?{checkpoint:W}:{}})()}}function MW($){return{sessionId:$.sessionId,parentSessionId:$.lineage.parentSessionId,agentId:$.lineage.agentId,parentAgentId:$.lineage.parentAgentId,conversationId:$.lineage.conversationId,isSubagent:$.lineage.isSubagent,source:$.source,startedAt:$.createdAt,endedAt:$.endedAt??void 0,exitCode:$.exitCode??void 0,status:$.status,interactive:$.interactive,provider:$.model.providerId,model:$.model.modelId,cwd:$.workspace.cwd,workspaceRoot:$.workspace.root,teamName:$.team?.name,enableTools:$.capabilities.enableTools,enableSpawn:$.capabilities.enableSpawn,enableTeams:$.capabilities.enableTeams,prompt:$.prompt,metadata:$.metadata,updatedAt:$.updatedAt,messagesPath:$.artifacts?.messagesPath}}function Af($){if(!$)return;return JSON.parse(JSON.stringify($))}var QO=["beforeRun","afterRun","beforeModel","afterModel","beforeTool","afterTool","onEvent"];function AH($){if(!$||typeof $!=="object"||Array.isArray($))return;return JSON.parse(JSON.stringify($))}function VH($){if(!$)return;let{userInstructionService:f,...J}=$;return JSON.parse(JSON.stringify(J))}function BH($){let f=$&&typeof $==="object"&&!Array.isArray($)?$:{};return{agentId:typeof f.agentId==="string"?f.agentId:"",conversationId:typeof f.conversationId==="string"?f.conversationId:"",iteration:typeof f.iteration==="number"?f.iteration:0,metadata:f.metadata&&typeof f.metadata==="object"&&!Array.isArray(f.metadata)?f.metadata:void 0}}function N1($,f,J){$.manifest.push(f),$.handlers.set(f.capabilityName,J)}function KH($,f){let J={manifest:[],handlers:new Map};for(let Z of Object.keys(f.toolExecutors??{}).filter(ZO)){let Q=f.toolExecutors?.[Z];if(typeof Q!=="function")continue;N1(J,{kind:"toolExecutor",executor:Z,capabilityName:`${JO}${Z}`},async({payload:j,abortSignal:H})=>{let X=Array.isArray(j.args)?[...j.args]:[],Y={...BH(j.context),signal:H};return{result:await Q(...X,Y)}})}for(let Z of $?.extraTools??[])N1(J,{kind:"tool",name:Z.name,description:Z.description,inputSchema:Af(Z.inputSchema)??{},...Z.lifecycle?{lifecycle:Af(Z.lifecycle)}:{},capabilityName:`${eL}${Z.name}`},async({payload:Q,abortSignal:j,progress:H})=>{let X={...BH(Q.context),signal:j};return{result:await Z.execute(Q.input,{...X,emitUpdate:(A)=>{H({update:A})}})}});let W=$?.hooks;if(W)for(let Z of QO){let Q=W[Z];if(typeof Q!=="function")continue;N1(J,{kind:"hook",name:Z,capabilityName:`${$O}${Z}`},async({payload:j})=>({control:await Q(j.context)}))}if($?.compaction?.compact){let Z=$.compaction.compact;N1(J,{kind:"compaction",capabilityName:oL,config:AH($.compaction)},async({payload:Q})=>({result:await Z(Q.context)}))}if($?.checkpoint?.createCheckpoint){let Z=$.checkpoint.createCheckpoint;N1(J,{kind:"checkpoint",capabilityName:sL,config:AH($.checkpoint)},async({payload:Q})=>({result:await Z(Q.context)}))}if($?.onConsecutiveMistakeLimitReached){let Z=$.onConsecutiveMistakeLimitReached;N1(J,{kind:"mistakeLimit",capabilityName:fO},async({payload:Q})=>({result:await Z(Q.context)}))}if($?.userInstructionService){let Z=$.userInstructionService;N1(J,{kind:"userInstructionService",capabilityName:WO},async()=>{return await Z.start().catch(()=>{}),{snapshot:{records:{skill:Z.listRecords("skill"),rule:Z.listRecords("rule"),workflow:Z.listRecords("workflow")},runtimeCommands:Z.listRuntimeCommands()}}})}return J}function UH($){if(typeof $==="string"&&$.trim())return $.trim();if($ instanceof Error)return $.message.trim()||void 0;if($&&typeof $==="object"&&"message"in $){let f=$.message;if(typeof f==="string"&&f.trim())return f.trim()}return}function jO($){return UH($)??"Capability request was cancelled."}function HO($){if(typeof $!=="string")return $;try{return JSON.parse($)}catch{return $}}function XO($){return $==="completed"||$==="max_iterations"||$==="aborted"||$==="mistake_limit"||$==="error"}function YO($){if(!$||typeof $!=="object"||Array.isArray($))return;let f=$,J=typeof f.inputTokens==="number"?f.inputTokens:void 0,W=typeof f.outputTokens==="number"?f.outputTokens:void 0;if(J===void 0||W===void 0)return;return{inputTokens:J,outputTokens:W,cacheReadTokens:typeof f.cacheReadTokens==="number"?f.cacheReadTokens:0,cacheWriteTokens:typeof f.cacheWriteTokens==="number"?f.cacheWriteTokens:0,totalCost:typeof f.totalCost==="number"?f.totalCost:0}}function GH($){if(!$)return;return{inputTokens:typeof $.inputTokens==="number"?$.inputTokens:0,outputTokens:typeof $.outputTokens==="number"?$.outputTokens:0,cacheReadTokens:typeof $.cacheReadTokens==="number"?$.cacheReadTokens:0,cacheWriteTokens:typeof $.cacheWriteTokens==="number"?$.cacheWriteTokens:0,totalCost:typeof $.totalCost==="number"?$.totalCost:0}}function yW($){return typeof $==="number"&&Number.isFinite($)?$:void 0}function v$($,f){return yW($?.[f])??0}function AO($){let f=$?.delta&&typeof $.delta==="object"?$.delta:void 0,J=$?.totals&&typeof $.totals==="object"?$.totals:void 0,W=$?.agent&&typeof $.agent==="object"?$.agent:void 0,Z=W?.teamRole==="teammate"||W?.teamRole==="lead"?W.teamRole:void 0;return{event:{type:"usage",agentId:typeof W?.agentId==="string"?W.agentId:void 0,conversationId:typeof W?.conversationId==="string"?W.conversationId:void 0,parentAgentId:typeof W?.parentAgentId==="string"?W.parentAgentId:void 0,inputTokens:v$(f,"inputTokens"),outputTokens:v$(f,"outputTokens"),cacheReadTokens:v$(f,"cacheReadTokens"),cacheWriteTokens:v$(f,"cacheWriteTokens"),cost:yW(f?.totalCost),totalInputTokens:v$(J,"inputTokens"),totalOutputTokens:v$(J,"outputTokens"),totalCacheReadTokens:v$(J,"cacheReadTokens"),totalCacheWriteTokens:v$(J,"cacheWriteTokens"),totalCost:yW(J?.totalCost)},teamAgentId:typeof W?.teamAgentId==="string"?W.teamAgentId:void 0,teamRole:Z}}function VO($){let f=$?.result&&typeof $.result==="object"&&!Array.isArray($.result)?$.result:void 0,J=$?.reason??f?.finishReason,W=XO(J)?J:J==="failed"?"error":"completed",Z=YO($?.usage??f?.usage);return{type:"done",reason:W,text:typeof $?.text==="string"?$.text:typeof f?.text==="string"?f.text:"",iterations:typeof $?.iterations==="number"?$.iterations:typeof f?.iterations==="number"?f.iterations:0,usage:Z}}function SJ($,f){return $.error?.message??`hub command failed: ${f}`}function T2($){switch($){case"idle":case"completed":return"completed";case"failed":return"failed";case"aborted":return"cancelled";default:return"running"}}function RH($){let f=$.metadata&&typeof $.metadata==="object"?JSON.parse(JSON.stringify($.metadata)):void 0;return{sessionId:$.sessionId,parentSessionId:typeof f?.parentSessionId==="string"?f.parentSessionId:void 0,agentId:$.runtimeSession?.agentId||(typeof f?.agentId==="string"?f.agentId:void 0),parentAgentId:typeof f?.parentAgentId==="string"?f.parentAgentId:void 0,conversationId:typeof f?.conversationId==="string"?f.conversationId:void 0,isSubagent:typeof f?.isSubagent==="boolean"?f.isSubagent:!1,source:typeof f?.source==="string"?f.source:F0.CORE,pid:typeof f?.pid==="number"?f.pid:void 0,startedAt:new Date($.createdAt).toISOString(),endedAt:T2($.status)==="running"?void 0:new Date($.updatedAt).toISOString(),exitCode:T2($.status)==="completed"?0:T2($.status)==="failed"?1:void 0,status:T2($.status),interactive:f?.interactive===!0,provider:typeof f?.provider==="string"?f.provider:"hub",model:typeof f?.model==="string"?f.model:"hub",cwd:$.cwd?.trim()||$.workspaceRoot,workspaceRoot:$.workspaceRoot,teamName:typeof f?.teamName==="string"?f.teamName:void 0,enableTools:$.runtimeOptions?.enableTools??f?.enableTools===!0,enableSpawn:$.runtimeOptions?.enableSpawn??f?.enableSpawn===!0,enableTeams:$.runtimeOptions?.enableTeams??f?.enableTeams===!0,prompt:typeof f?.prompt==="string"?f.prompt:void 0,metadata:f,updatedAt:new Date($.updatedAt).toISOString(),messagesPath:typeof f?.messagesPath==="string"?f.messagesPath:void 0,hookPath:typeof f?.hookPath==="string"?f.hookPath:void 0}}function u$($){if(!$||typeof $!=="object"||Array.isArray($))return;let f=$;return f.version===1&&typeof f.sessionId==="string"?JSON.parse(JSON.stringify(f)):void 0}function BO($){let f=u$($?.snapshot);if(f)return MW(f);let J=$?.session;return J?RH(J):void 0}function PH($,f,J){let W=J?.workspaceRoot?.trim()||f.config.workspaceRoot||f.config.cwd;return _0.parse({version:1,session_id:$,source:f.source??F0.CORE,pid:process.pid,started_at:new Date(J?.createdAt??Date.now()).toISOString(),status:T2(J?.status),interactive:f.interactive===!0,provider:f.config.providerId,model:f.config.modelId,cwd:J?.cwd?.trim()||f.config.cwd,workspace_root:W,team_name:f.config.teamName,enable_tools:f.config.enableTools,enable_spawn:f.config.enableSpawnAgent,enable_teams:f.config.enableAgentTeams,prompt:f.prompt?.trim()||void 0,metadata:f.sessionMetadata&&Object.keys(f.sessionMetadata).length>0?f.sessionMetadata:void 0})}function FH($,f){return _0.parse({version:1,session_id:$.sessionId,source:$.source,pid:process.pid,started_at:$.createdAt,status:$.status,interactive:$.interactive,provider:$.model.providerId,model:$.model.modelId,cwd:$.workspace.cwd,workspace_root:$.workspace.root,team_name:$.team?.name,enable_tools:$.capabilities.enableTools,enable_spawn:$.capabilities.enableSpawn,enable_teams:$.capabilities.enableTeams,prompt:($.prompt??f.prompt?.trim())||void 0,metadata:$.metadata,messages_path:$.artifacts?.messagesPath})}class M1{runtimeAddress;pendingPrompts;client;clientOptions;clientContext;events=new R2;sessionCapabilities=new Map;sessionClientContributionHandlers=new Map;sessionSubscriptions=new Map;pendingApprovalToolCallIds=new Set;agentDoneEmittedForCurrentRunBySession=new Set;activeCapabilityAbortControllers=new Map;defaultCapabilities;telemetry;constructor($,f){this.clientContext=f,this.clientOptions={authToken:$.authToken,clientType:$.clientType??"core-hub-runtime",displayName:$.displayName??"core hub runtime",workspaceRoot:f?.workspaceRoot,cwd:f?.cwd},this.defaultCapabilities=U0($.capabilities)??{},this.telemetry=$.telemetry,this.runtimeAddress=$.url,this.pendingPrompts={list:(J)=>this.requestPendingPromptsList(J),update:(J)=>this.requestPendingPromptUpdate(J),delete:(J)=>this.requestPendingPromptDelete(J)},this.client=this.createClient($.url)}createClient($){return new V$({...this.clientOptions,url:$})}async replaceClient($){let f=this.client;this.client=this.createClient($),this.runtimeAddress=$,await Promise.resolve(f.dispose()).catch(()=>{return})}async recoverLocalHubStartupDeadlock($){if(!QH($,"session.create"))return!1;let f=await HH({url:this.client.getUrl(),workspaceRoot:this.clientContext?.workspaceRoot,cwd:this.clientContext?.cwd}).catch(()=>{return});if(!f)return!1;return await this.replaceClient(f),!0}registerPlannedSession($,f,J){if(this.sessionCapabilities.set($,f),J.size>0)this.sessionClientContributionHandlers.set($,J);this.ensureSessionSubscription($)}cleanupPlannedSession($){this.sessionCapabilities.delete($),this.sessionClientContributionHandlers.delete($),this.disposeSessionSubscription($)}async connect(){await this.client.connect()}async startSession($){let f=this.resolveCapabilities($),J=KH($.localRuntime,f),W=$.config.sessionId?.trim()||YH(),Z=()=>this.client.command("session.create",{workspaceRoot:$.config.workspaceRoot?.trim()||$.config.cwd,cwd:$.config.cwd,sessionConfig:Af({...$.config,sessionId:W}),metadata:{...$.sessionMetadata??{},source:$.source??F0.CORE,provider:$.config.providerId,model:$.config.modelId,enableTools:$.config.enableTools,enableSpawn:$.config.enableSpawnAgent,enableTeams:$.config.enableAgentTeams,teamName:$.config.teamName,prompt:$.prompt,interactive:$.interactive===!0},runtimeOptions:{...J.manifest.length>0?{clientContributions:J.manifest}:{},...$.localRuntime?.configExtensions?{configExtensions:$.localRuntime.configExtensions}:{}},toolPolicies:Af($.toolPolicies),initialMessages:$.initialMessages});this.registerPlannedSession(W,f,J.handlers);let Q;try{Q=await Z()}catch(Y){if(this.cleanupPlannedSession(W),await this.recoverLocalHubStartupDeadlock(Y)){this.registerPlannedSession(W,f,J.handlers);try{Q=await Z()}catch(A){throw this.cleanupPlannedSession(W),A}}else throw Y}let j=u$(Q.payload?.snapshot),H=Q.payload?.session,X=(j?.sessionId??H?.sessionId)?.trim();if(!X)throw this.cleanupPlannedSession(W),Error("Hub runtime did not return a session id.");if(X!==W)this.cleanupPlannedSession(W),this.registerPlannedSession(X,f,J.handlers);return{sessionId:X,manifest:j?FH(j,$):PH(X,$,H),manifestPath:"",messagesPath:"",result:void 0}}async restoreSession($){let f=$.sessionId.trim();if(!f)throw Error("sessionId is required");let J=$.restore?.messages!==!1;if(J&&!$.start)throw Error("start is required when restore.messages is true");let W=$.start,Z=W?this.resolveCapabilities(W):void 0,Q=W?KH(W.localRuntime,Z??{}):{manifest:[],handlers:new Map},j=W?W.config.sessionId?.trim()||YH():void 0;if(j&&Z)this.sessionCapabilities.set(j,Z);if(j&&Q.handlers.size>0)this.sessionClientContributionHandlers.set(j,Q.handlers),this.ensureSessionSubscription(j);let H;try{H=await this.client.command("session.restore",{sessionId:f,checkpointRunCount:$.checkpointRunCount,restore:$.restore,...W?{workspaceRoot:W.config.workspaceRoot?.trim()||W.config.cwd,cwd:W.config.cwd??$.cwd,sessionConfig:Af({...W.config,sessionId:j}),metadata:{...W.sessionMetadata??{},source:W.source??F0.CORE,provider:W.config.providerId,model:W.config.modelId,enableTools:W.config.enableTools,enableSpawn:W.config.enableSpawnAgent,enableTeams:W.config.enableAgentTeams,teamName:W.config.teamName,prompt:W.prompt,interactive:W.interactive===!0},runtimeOptions:{...Q.manifest.length>0?{clientContributions:Q.manifest}:{},...W.localRuntime?.configExtensions?{configExtensions:W.localRuntime.configExtensions}:{}},toolPolicies:Af(W.toolPolicies)}:{}},f)}catch(K){if(j)this.sessionCapabilities.delete(j),this.sessionClientContributionHandlers.delete(j),this.disposeSessionSubscription(j);throw K}if(!H.ok){let K=typeof H.payload?.error==="string"?H.payload.error:"session.restore failed";if(j)this.sessionCapabilities.delete(j),this.sessionClientContributionHandlers.delete(j),this.disposeSessionSubscription(j);throw Error(K)}let X=u$(H.payload?.snapshot),Y=H.payload?.session,A=(X?.sessionId??Y?.sessionId)?.trim();if(J&&!A){if(j)this.sessionCapabilities.delete(j),this.sessionClientContributionHandlers.delete(j),this.disposeSessionSubscription(j);throw Error("Hub checkpoint restore returned no session id")}if(A&&j&&A!==j)this.sessionCapabilities.delete(j),this.sessionClientContributionHandlers.delete(j),this.disposeSessionSubscription(j);if(A&&Z)this.sessionCapabilities.set(A,Z);if(A&&Q.handlers.size>0)this.sessionClientContributionHandlers.set(A,Q.handlers);if(A)this.ensureSessionSubscription(A);let V=Array.isArray(H.payload?.messages)?H.payload.messages:void 0,B=H.payload?.checkpoint;if(!B)throw Error("Hub checkpoint restore returned no checkpoint");return{sessionId:A,startResult:A?{sessionId:A,manifest:X?FH(X,W??{}):PH(A,W??{},Y),manifestPath:"",messagesPath:"",result:void 0}:void 0,messages:V,checkpoint:B}}async runTurn($){return this.ensureSessionSubscription($.sessionId),(await this.client.command("run.start",{sessionId:$.sessionId,input:$.prompt,mode:$.mode,attachments:($.userImages?.length??0)>0||($.userFiles?.length??0)>0?{...$.userImages?.length?{userImages:$.userImages}:{},...$.userFiles?.length?{userFiles:$.userFiles}:{}}:void 0,delivery:$.delivery,timeoutMs:$.timeoutMs},$.sessionId,{timeoutMs:null})).payload?.result}async requestPendingPromptsList($){this.ensureSessionSubscription($.sessionId);let f=await this.client.command("session.pending_prompts",{sessionId:$.sessionId},$.sessionId);return Array.isArray(f.payload?.prompts)?f.payload.prompts:[]}async requestPendingPromptUpdate($){this.ensureSessionSubscription($.sessionId);let f=await this.client.command("session.update_pending_prompt",{...$},$.sessionId);return{sessionId:$.sessionId,prompts:Array.isArray(f.payload?.prompts)?f.payload.prompts:[],prompt:f.payload?.prompt,updated:f.payload?.updated===!0}}async requestPendingPromptDelete($){this.ensureSessionSubscription($.sessionId);let f=await this.client.command("session.remove_pending_prompt",{...$},$.sessionId);return{sessionId:$.sessionId,prompts:Array.isArray(f.payload?.prompts)?f.payload.prompts:[],prompt:f.payload?.prompt,removed:f.payload?.removed===!0}}async getAccumulatedUsage($){let f=await this.client.command("session.get",{includeSnapshot:!0},$),J=u$(f.payload?.snapshot);if(J){let j=J.usage?{...J.usage}:void 0,H=J.aggregateUsage?{...J.aggregateUsage}:void 0;return j||H?{usage:j,aggregateUsage:H}:void 0}let W=f.payload?.session,Z=GH(W?.usage),Q=GH(W?.aggregateUsage);return Z||Q?{usage:Z,aggregateUsage:Q}:void 0}async abort($,f){await this.client.command("run.abort",{sessionId:$,reason:UH(f)},$)}async stopSession($){this.sessionCapabilities.delete($),this.disposeSessionSubscription($),await this.client.command("session.detach",{sessionId:$},$)}async dispose(){for(let[$,f]of this.sessionSubscriptions){f();try{await this.client.command("session.detach",{sessionId:$},$)}catch{}}this.sessionSubscriptions.clear(),this.sessionCapabilities.clear(),this.agentDoneEmittedForCurrentRunBySession.clear();for(let $ of this.activeCapabilityAbortControllers.values())$.abort("Hub runtime host disposed.");this.activeCapabilityAbortControllers.clear(),await this.client.dispose()}async getSession($){let f;try{f=await this.client.command("session.get",void 0,$)}catch(J){if(U1(J))return;throw J}return BO(f.payload)}async listSessions($=100){let f=await this.client.command("session.list",{limit:$}),J=Array.isArray(f.payload?.snapshots)?f.payload.snapshots.flatMap((Z)=>{let Q=u$(Z);return Q?[MW(Q)]:[]}):[];if(J.length>0)return J;return(f.payload?.sessions??[]).map(RH)}async listSettings($){let f=await this.client.command("settings.list",VH($));if(!f.ok)throw Error(SJ(f,"settings.list"));return f.payload?.snapshot}async toggleSetting($){let f=await this.client.command("settings.toggle",VH($));if(!f.ok)throw Error(SJ(f,"settings.toggle"));return{snapshot:f.payload?.snapshot,changedTypes:Array.isArray(f.payload?.changedTypes)?f.payload.changedTypes:[]}}async deleteSession($){return this.sessionCapabilities.delete($),this.disposeSessionSubscription($),(await this.client.command("session.delete",{sessionId:$})).payload?.deleted===!0}async updateSession($,f){let J={...f.metadata??{}};if(typeof f.prompt==="string")J.prompt=f.prompt;if(typeof f.title==="string")J.title=f.title;return{updated:(await this.client.command("session.update",{sessionId:$,metadata:J})).ok}}async readSessionMessages($){let f=$.trim();if(!f)return[];let J=await this.client.command("session.messages",{sessionId:f},f);if(!J.ok)throw XH(this.telemetry,{component:"core",operation:"hub.runtime_host.read_session_messages",error:Error(SJ(J,"session.messages")),severity:J.error?.code==="session_not_found"?"warn":"error",handled:!0,context:{command:"session.messages",sessionId:f,errorCode:J.error?.code,runtimeAddress:this.runtimeAddress}}),Error(SJ(J,"session.messages"));let W=J.payload?.messages;return Array.isArray(W)?W:[]}async dispatchHookEvent($){await this.client.command("session.hook",{payload:$})}subscribe($,f){return this.events.subscribe($,f)}ensureSessionSubscription($){let f=$.trim();if(!f||this.sessionSubscriptions.has(f))return;let J=this.client.subscribe((W)=>{this.handleHubEvent(W)},{sessionId:f});this.sessionSubscriptions.set(f,typeof J==="function"?J:()=>{})}disposeSessionSubscription($){let f=$.trim();if(!f)return;this.sessionSubscriptions.get(f)?.(),this.sessionSubscriptions.delete(f),this.agentDoneEmittedForCurrentRunBySession.delete(f)}resolveCapabilities($){return U0(this.defaultCapabilities,$.capabilities)??{}}emitToolCallContentStart($){this.events.emit({type:"agent_event",payload:{sessionId:$.sessionId,event:{type:"content_start",contentType:"tool",toolCallId:$.toolCallId,toolName:$.toolName,input:$.toolInput}}})}emitAgentDoneIfNeeded($){if(this.agentDoneEmittedForCurrentRunBySession.has($.sessionId))return;this.agentDoneEmittedForCurrentRunBySession.add($.sessionId),this.events.emit({type:"agent_event",payload:{sessionId:$.sessionId,event:VO($.payload)}})}handleHubEvent($){let f=$.sessionId?.trim();if($.event==="capability.requested"){this.handleCapabilityRequest($).catch((J)=>{this.captureDetachedHubEventError("hub.runtime_host.capability_request",J,$)});return}if($.event==="capability.resolved"){this.handleCapabilityResolved($);return}if($.event==="approval.requested"){this.handleApprovalRequested($).catch((J)=>{this.captureDetachedHubEventError("hub.runtime_host.approval_request",J,$)});return}if(!f)return;switch($.event){case"run.started":{this.agentDoneEmittedForCurrentRunBySession.delete(f);let J=u$($.payload?.snapshot),W=$.payload?.session;if(J)this.events.emit({type:"session_snapshot",payload:{sessionId:f,snapshot:J}});this.events.emit({type:"status",payload:{sessionId:f,status:W?.status??"running"}});return}case"iteration.started":{this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"iteration_start",iteration:typeof $.payload?.iteration==="number"?$.payload.iteration:0}}});return}case"iteration.finished":{this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"iteration_end",iteration:typeof $.payload?.iteration==="number"?$.payload.iteration:0,hadToolCalls:$.payload?.hadToolCalls===!0,toolCallCount:typeof $.payload?.toolCallCount==="number"?$.payload.toolCallCount:0}}});return}case"assistant.delta":{let J=typeof $.payload?.text==="string"?$.payload.text:"";if(!J)return;this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"content_start",contentType:"text",text:J}}});return}case"assistant.finished":{this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"content_end",contentType:"text",text:typeof $.payload?.text==="string"?$.payload.text:void 0}}});return}case"reasoning.delta":{let J=typeof $.payload?.text==="string"?$.payload.text:"",W=$.payload?.redacted===!0;if(!J&&!W)return;this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"content_start",contentType:"reasoning",reasoning:J,redacted:W}}});return}case"reasoning.finished":{this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"content_end",contentType:"reasoning",reasoning:typeof $.payload?.reasoning==="string"?$.payload.reasoning:void 0}}});return}case"agent.done":{this.emitAgentDoneIfNeeded({sessionId:f,payload:$.payload});return}case"usage.updated":{let J=AO($.payload);this.events.emit({type:"agent_event",payload:{sessionId:f,event:J.event,teamAgentId:J.teamAgentId,teamRole:J.teamRole}});return}case"tool.started":{let J=typeof $.payload?.toolCallId==="string"?$.payload.toolCallId:void 0;if(J&&this.pendingApprovalToolCallIds.delete(J))return;this.emitToolCallContentStart({sessionId:f,toolCallId:J,toolName:typeof $.payload?.toolName==="string"?$.payload.toolName:void 0,toolInput:$.payload?.input});return}case"tool.finished":{let J=typeof $.payload?.toolCallId==="string"?$.payload.toolCallId:void 0;if(J)this.pendingApprovalToolCallIds.delete(J);this.events.emit({type:"agent_event",payload:{sessionId:f,event:{type:"content_end",contentType:"tool",toolCallId:J,toolName:typeof $.payload?.toolName==="string"?$.payload.toolName:void 0,output:$.payload?.output,error:typeof $.payload?.error==="string"?$.payload.error:void 0}}});return}case"session.created":case"session.updated":case"session.attached":case"session.detached":{let J=u$($.payload?.snapshot),W=$.payload?.session;if(J)this.events.emit({type:"session_snapshot",payload:{sessionId:f,snapshot:J}});this.events.emit({type:"status",payload:{sessionId:f,status:W?.status??"running"}});return}case"session.pending_prompts":{this.events.emit({type:"pending_prompts",payload:{sessionId:f,prompts:Array.isArray($.payload?.prompts)?$.payload.prompts:[]}});return}case"session.pending_prompt_submitted":{let J=$.payload?.prompt;if(!J)return;this.events.emit({type:"pending_prompt_submitted",payload:{sessionId:f,id:J.id,prompt:J.prompt,delivery:J.delivery,attachmentCount:J.attachmentCount}});return}case"run.completed":case"run.failed":case"run.aborted":{let J=u$($.payload?.snapshot),W=typeof $.payload?.reason==="string"?$.payload.reason:$.event==="run.aborted"?"aborted":$.event==="run.failed"?"error":"completed";if(this.emitAgentDoneIfNeeded({sessionId:f,payload:{...$.payload,reason:W}}),J?.interactive===!0&&$0(J.status))return;this.events.emit({type:"ended",payload:{sessionId:f,reason:W,ts:$.timestamp??Date.now()}});return}default:return}}captureDetachedHubEventError($,f,J){try{XH(this.telemetry,{component:"core",operation:$,error:f,severity:"warn",handled:!0,context:{event:J.event,sessionId:J.sessionId,runtimeAddress:this.runtimeAddress}})}catch{}}async handleCapabilityRequest($){let f=$.sessionId?.trim();if(!f)return;let J=typeof $.payload?.targetClientId==="string"?$.payload.targetClientId:void 0;if(J&&J!==this.client.getClientId())return;let W=typeof $.payload?.requestId==="string"?$.payload.requestId:"",Z=typeof $.payload?.capabilityName==="string"?$.payload.capabilityName:"";if(!W)return;let Q=this.sessionClientContributionHandlers.get(f)?.get(Z);if(!Q){await this.client.command("capability.respond",{requestId:W,ok:!1,error:`No client contribution handler registered for capability ${Z} in session ${f}.`},f).catch(()=>{});return}let j=$.payload?.payload&&typeof $.payload.payload==="object"&&!Array.isArray($.payload.payload)?$.payload.payload:{},H=new AbortController;this.activeCapabilityAbortControllers.set(W,H);let X=(Y)=>{this.client.command("capability.progress",{requestId:W,payload:Y},f).catch((A)=>{this.captureDetachedHubEventError("hub.runtime_host.capability_progress",A,$)})};try{let Y=await Q({payload:j,abortSignal:H.signal,progress:X});if(H.signal.aborted)return;await this.client.command("capability.respond",{requestId:W,ok:!0,payload:Y},f)}catch(Y){if(H.signal.aborted)return;await this.client.command("capability.respond",{requestId:W,ok:!1,error:Y instanceof Error?Y.message:String(Y)},f)}finally{this.activeCapabilityAbortControllers.delete(W)}}handleCapabilityResolved($){if($.payload?.cancelled!==!0)return;let f=typeof $.payload.requestId==="string"?$.payload.requestId.trim():"";if(!f)return;let J=this.activeCapabilityAbortControllers.get(f);if(!J)return;J.abort(jO($.payload.error))}async handleApprovalRequested($){let f=$.sessionId?.trim();if(!f)return;let J=this.sessionCapabilities.get(f)?.requestToolApproval??this.defaultCapabilities.requestToolApproval;if(!J)return;let W=typeof $.payload?.approvalId==="string"?$.payload.approvalId.trim():"",Z=typeof $.payload?.toolCallId==="string"?$.payload.toolCallId:"",Q=typeof $.payload?.toolName==="string"?$.payload.toolName:"";if(!W||!Z||!Q)return;let j=$.payload?.policy&&typeof $.payload.policy==="object"&&!Array.isArray($.payload.policy)?$.payload.policy:{autoApprove:!1},H=HO($.payload?.inputJson);this.pendingApprovalToolCallIds.add(Z),this.emitToolCallContentStart({sessionId:f,toolCallId:Z,toolName:Q,toolInput:H});let X=await Promise.resolve(J({sessionId:f,agentId:typeof $.payload?.agentId==="string"?$.payload.agentId:"",conversationId:typeof $.payload?.conversationId==="string"?$.payload.conversationId:f,iteration:typeof $.payload?.iteration==="number"?$.payload.iteration:0,toolCallId:Z,toolName:Q,input:H,policy:j})).catch((Y)=>({approved:!1,reason:Y instanceof Error?Y.message:`Tool approval request failed: ${String(Y)}`}));await this.client.command("approval.respond",{approvalId:W,approved:X.approved,reason:X.reason},f).catch(()=>{})}}class hJ extends M1{constructor($){super({url:Yf($.endpoint),authToken:$.authToken,clientType:$.clientType??"core-remote-runtime",displayName:$.displayName??"core remote runtime",capabilities:$.capabilities},{workspaceRoot:$.workspaceRoot,cwd:$.cwd})}}import{existsSync as KO,mkdirSync as GO}from"node:fs";import{join as PO}from"node:path";import{asBool as N2,asOptionalString as $$,asString as B$,ensureSessionSchema as FO,loadSqliteDb as UO,nowIso as CJ,toBoolInt as M2}from"@cline/shared/db";import{resolveDbDataDir as RO}from"@cline/shared/storage";class c${sessionsDirPath;db;constructor($={}){this.sessionsDirPath=$.sessionsDir??RO()}init(){this.getRawDb()}ensureSessionsDir(){if(!KO(this.sessionsDirPath))GO(this.sessionsDirPath,{recursive:!0});return this.sessionsDirPath}sessionDbPath(){return PO(this.ensureSessionsDir(),"sessions.db")}getRawDb(){if(this.db)return this.db;let $=UO(this.sessionDbPath());return FO($,{includeLegacyMigrations:!0}),this.db=$,$}close(){this.db?.close?.(),this.db=void 0}run($,f=[]){return this.getRawDb().prepare($).run(...f)}queryOne($,f=[]){return this.getRawDb().prepare($).get(...f)??void 0}queryAll($,f=[]){return this.getRawDb().prepare($).all(...f)}create($){let f=CJ();this.run(`INSERT OR REPLACE INTO sessions (
|
|
440
440
|
session_id, source, pid, started_at, ended_at, exit_code, status, status_lock, interactive,
|
|
441
441
|
provider, model, cwd, workspace_root, team_name, enable_tools, enable_spawn, enable_teams,
|
|
442
442
|
parent_session_id, parent_agent_id, agent_id, conversation_id, is_subagent, prompt,
|
|
443
443
|
metadata_json, transcript_path, hook_path, messages_path, updated_at
|
|
444
|
-
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,[$.sessionId,$.source,$.pid,$.startedAt,$.endedAt??null,$.exitCode??null,$.status,0,
|
|
444
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,[$.sessionId,$.source,$.pid,$.startedAt,$.endedAt??null,$.exitCode??null,$.status,0,M2($.interactive),$.provider,$.model,$.cwd,$.workspaceRoot,$.teamName??null,M2($.enableTools),M2($.enableSpawn),M2($.enableTeams),$.parentSessionId??null,$.parentAgentId??null,$.agentId??null,$.conversationId??null,M2($.isSubagent),$.prompt??null,$.metadata?JSON.stringify($.metadata):null,"",$.hookPath??"",$.messagesPath??null,f])}update($){let f=[],J=[];if($.endedAt!==void 0)f.push("ended_at = ?"),J.push($.endedAt);if($.exitCode!==void 0)f.push("exit_code = ?"),J.push($.exitCode);if($.status!==void 0)f.push("status = ?"),J.push($.status);if($.prompt!==void 0)f.push("prompt = ?"),J.push($.prompt);if($.metadata!==void 0)f.push("metadata_json = ?"),J.push($.metadata?JSON.stringify($.metadata):null);if($.parentSessionId!==void 0)f.push("parent_session_id = ?"),J.push($.parentSessionId);if($.parentAgentId!==void 0)f.push("parent_agent_id = ?"),J.push($.parentAgentId);if($.agentId!==void 0)f.push("agent_id = ?"),J.push($.agentId);if($.conversationId!==void 0)f.push("conversation_id = ?"),J.push($.conversationId);if(f.length===0)return;f.push("updated_at = ?"),J.push(CJ()),J.push($.sessionId),this.run(`UPDATE sessions SET ${f.join(", ")} WHERE session_id = ?`,J)}updateStatus($,f,J){this.update({sessionId:$,status:f,endedAt:$0(f)?null:CJ(),exitCode:$0(f)?null:J??(f==="failed"?1:0)})}get($){let f=this.queryOne(`SELECT session_id, source, pid, started_at, ended_at, exit_code, status, interactive,
|
|
445
445
|
provider, model, cwd, workspace_root, team_name,
|
|
446
446
|
enable_tools, enable_spawn, enable_teams,
|
|
447
447
|
parent_session_id, parent_agent_id, agent_id, conversation_id, is_subagent,
|
|
448
448
|
prompt, metadata_json, hook_path, messages_path, updated_at
|
|
449
|
-
FROM sessions WHERE session_id = ?`,[$]);if(!f)return;return{sessionId:
|
|
450
|
-
`).filter(Boolean);await Promise.allSettled(Z.map((
|
|
451
|
-
`,"utf8")}readSessionManifest($){return this.readManifestFile($).manifest}readManifestFile($){let f=this.artifacts.sessionManifestPath($,!1);if(!
|
|
452
|
-
`;if(
|
|
453
|
-
`,"utf8")}}import{appendFileSync as
|
|
454
|
-
`,"utf8")}}import{formatUserInputBlock as
|
|
449
|
+
FROM sessions WHERE session_id = ?`,[$]);if(!f)return;return{sessionId:B$(f.session_id),source:B$(f.source),pid:Number(f.pid??0),startedAt:B$(f.started_at),endedAt:f.ended_at??null,exitCode:f.exit_code??null,status:B$(f.status),interactive:N2(f.interactive),provider:B$(f.provider),model:B$(f.model),cwd:B$(f.cwd),workspaceRoot:B$(f.workspace_root),teamName:$$(f.team_name),enableTools:N2(f.enable_tools),enableSpawn:N2(f.enable_spawn),enableTeams:N2(f.enable_teams),parentSessionId:$$(f.parent_session_id),parentAgentId:$$(f.parent_agent_id),agentId:$$(f.agent_id),conversationId:$$(f.conversation_id),isSubagent:N2(f.is_subagent),prompt:$$(f.prompt),metadata:(()=>{let J=$$(f.metadata_json);if(!J)return;try{let W=JSON.parse(J);if(W&&typeof W==="object"&&!Array.isArray(W))return W}catch{}return})(),hookPath:$$(f.hook_path),messagesPath:$$(f.messages_path),updatedAt:$$(f.updated_at)??CJ()}}list($=200){let f=this.queryAll("SELECT session_id FROM sessions ORDER BY started_at DESC LIMIT ?",[$]),J=[];for(let W of f){let Z=this.get(B$(W.session_id));if(Z)J.push(Z)}return J}delete($,f=!1){let J=this.run("DELETE FROM sessions WHERE session_id = ?",[$]).changes??0;if(f)this.run("DELETE FROM sessions WHERE parent_session_id = ?",[$]);return J>0}}EJ();import{existsSync as cW,mkdirSync as j_,readFileSync as SH,renameSync as H_,writeFileSync as X_}from"node:fs";import{join as hH}from"node:path";import{resolveSessionDataDir as Y_}from"@cline/shared/storage";import{dirname as Z_}from"node:path";import{nanoid as Q_}from"nanoid";import{execFile as hO}from"node:child_process";import{promisify as CO}from"node:util";var EO=CO(hO);function qW($,f){$?.log(f,{severity:"warn"})}function bO($){let f=$?.checkpoint;if(!f||typeof f!=="object"||Array.isArray(f))return;let J=f;if(!J.latest||!Array.isArray(J.history))return;let W=J.latest,Z=J.history.filter((Q)=>!!Q&&typeof Q==="object"&&typeof Q.ref==="string"&&typeof Q.createdAt==="number"&&typeof Q.runCount==="number");if(typeof W.ref!=="string"||typeof W.createdAt!=="number"||typeof W.runCount!=="number")return;return{latest:W,history:Z}}async function q1($,f){let J=await EO("git",["-C",$,...f],{windowsHide:!0});return{stdout:J.stdout.trim(),stderr:J.stderr.trim()}}async function wW($,f){if(!$)return;let J=`refs/cline/checkpoints/${f}/`;try{let{stdout:W}=await q1($,["for-each-ref","--format=%(refname)",J]),Z=W.trim().split(`
|
|
450
|
+
`).filter(Boolean);await Promise.allSettled(Z.map((Q)=>q1($,["update-ref","-d",Q])))}catch{}}async function DH($,f,J){if(!$||J.length===0)return;await Promise.allSettled(J.map((W)=>q1($,["update-ref",`refs/cline/checkpoints/${f}/${W.runCount}`,W.ref])))}function kO($,f){let J=$.findIndex((W)=>W.runCount===f.runCount);if(J<0)return[...$,f];return $.map((W,Z)=>Z===J?f:W)}function LH($){let f=$.initialRunCount??0,J,W=async()=>{if(J!==void 0)return J;try{J=(await q1($.cwd,["rev-parse","--is-inside-work-tree"])).stdout==="true"}catch{J=!1}return J},Z=async()=>{if($.createCheckpoint)return await $.createCheckpoint({cwd:$.cwd,sessionId:$.sessionId,runCount:f});if(!await W())return;let Q=async(Y)=>{try{let V=(await q1($.cwd,["rev-parse","HEAD"])).stdout.trim();if(!V)return;return{ref:V,createdAt:Date.now(),runCount:f,kind:"commit"}}catch(A){qW($.logger,`${Y}: ${A instanceof Error?A.message:String(A)}`);return}},j=`cline checkpoint session=${$.sessionId} run=${f}`,H="";try{H=(await q1($.cwd,["stash","create",j])).stdout.trim()}catch(Y){return qW($.logger,`Checkpoint snapshot failed: ${Y instanceof Error?Y.message:String(Y)}`),Q("Checkpoint HEAD fallback failed")}if(!H)return Q("Checkpoint HEAD fallback failed");let X=`refs/cline/checkpoints/${$.sessionId}/${f}`;try{await q1($.cwd,["update-ref",X,H])}catch(Y){qW($.logger,`Checkpoint store failed: ${Y instanceof Error?Y.message:String(Y)}`);return}return{ref:H,createdAt:Date.now(),runCount:f,kind:"stash"}};return{beforeRun:async({snapshot:Q})=>{if(Q.parentAgentId!=null)return;f+=1;return},beforeModel:async({snapshot:Q})=>{if(Q.parentAgentId!=null||Q.iteration!==1||f<1)return;let j=await Z();if(!j)return;let H=await $.readSessionMetadata(),X=bO(H);if(X?.latest.ref===j.ref)return;let Y=kO(X?.history??[],j);await $.writeSessionMetadata({...H??{},checkpoint:{latest:j,history:Y}});return}}}import{existsSync as kJ,mkdirSync as IO,readdirSync as xO,rmdirSync as mO,rmSync as gO,unlinkSync as vO}from"node:fs";import{dirname as OH,join as bJ}from"node:path";function n(){return new Date().toISOString()}function y2($){if(!$||!kJ($))return;try{vO($)}catch{}}function uO($){let f=P2($);if(f)return{rootSessionId:f.rootSessionId,fileStem:`${f.agentId}__${f.teamTaskId}`};let J=zJ($);if(J)return{rootSessionId:J.rootSessionId,fileStem:J.agentId};return{rootSessionId:$,fileStem:$}}class SW{ensureSessionsDir;constructor($){this.ensureSessionsDir=$}sessionArtifactsDir($){return bJ(this.ensureSessionsDir(),$)}ensureSessionArtifactsDir($){let f=this.sessionArtifactsDir($);if(!kJ(f))IO(f,{recursive:!0});return f}sessionMessagesPath($){return bJ(this.sessionArtifactsDir($),`${$}.messages.json`)}sessionManifestPath($,f=!1){let J=f?this.ensureSessionArtifactsDir($):this.sessionArtifactsDir($);return bJ(J,`${$}.json`)}removeSessionDirIfEmpty($){let f=this.sessionArtifactsDir($),J=this.ensureSessionsDir();while(f.startsWith(J)&&f!==J){if(!kJ(f)){f=OH(f);continue}try{if(xO(f).length>0)break;mO(f)}catch{break}f=OH(f)}}removeSessionDir($){this.removeDir(this.sessionArtifactsDir($))}removeDir($){if(!kJ($))return;try{gO($,{recursive:!0,force:!0})}catch{}}subagentArtifactPaths($,f,J){let{rootSessionId:W,fileStem:Z}=uO($),Q=this.sessionArtifactsDir(W);return{messagesPath:bJ(Q,`${Z}.messages.json`)}}}import{appendFileSync as cO,existsSync as dO,mkdirSync as _H,readFileSync as lO,writeFileSync as zH}from"node:fs";import{dirname as TH,join as pO}from"node:path";import{ensureHookLogDir as rO}from"@cline/shared/storage";class hW{adapter;messagesArtifactUploader;logger;artifacts;constructor($,f,J){this.adapter=$;this.messagesArtifactUploader=f;this.logger=J;this.artifacts=new SW(()=>this.ensureSessionsDir())}ensureSessionsDir(){return this.adapter.ensureSessionsDir()}initializeMessagesFile($,f,J){wj(f,J,YW($))}writeSessionManifest($,f){_H(TH($),{recursive:!0}),zH($,`${JSON.stringify(_0.parse(f),null,2)}
|
|
451
|
+
`,"utf8")}readSessionManifest($){return this.readManifestFile($).manifest}readManifestFile($){let f=this.artifacts.sessionManifestPath($,!1);if(!dO(f))return{path:f};try{return{path:f,manifest:_0.parse(JSON.parse(lO(f,"utf8")))}}catch{return{path:f}}}async resolveArtifactPath($,f,J){let Z=(await this.adapter.getSession($))?.[f];return typeof Z==="string"&&Z.trim().length>0?Z:J($)}async persistSessionMessages($,f,J){let W=await this.resolveArtifactPath($,"messagesPath",(j)=>this.artifacts.sessionMessagesPath(j)),Z=AW({updatedAt:n(),context:YW($),messages:f,systemPrompt:J}),Q=`${JSON.stringify(Z,null,2)}
|
|
452
|
+
`;if(_H(TH(W),{recursive:!0}),zH(W,Q,"utf8"),!this.messagesArtifactUploader)return;try{let j=await this.adapter.getSession($);await this.messagesArtifactUploader.uploadMessagesFile({sessionId:$,path:W,contents:Q,row:j})}catch(j){this.logger?.debug("Failed to upload persisted session messages",{sessionId:$,error:j})}}appendStaleSessionHookLog($,f,J,W,Z){let j=(process.env.CLINE_HOOKS_LOG_PATH?.trim()||void 0)??pO(rO(),"hooks.jsonl");cO(j,`${JSON.stringify({ts:$,hookName:"session_shutdown",reason:W,sessionId:f,pid:J,source:Z})}
|
|
453
|
+
`,"utf8")}}import{appendFileSync as iO}from"node:fs";import{join as nO}from"node:path";import{resolveRootSessionId as NH}from"@cline/shared";import{ensureHookLogDir as aO}from"@cline/shared/storage";import{z as CW}from"zod";var tO="subagent",sO=CW.looseObject({task:CW.string().optional(),systemPrompt:CW.string().optional()});class IJ{adapter;manifestStore;toPersistedMessages;heartbeatLogIntervalMs;teamTaskSessionsByAgent=new Map;teamTaskLastHeartbeatBySession=new Map;teamTaskLastProgressLineBySession=new Map;constructor($,f,J,W){this.adapter=$;this.manifestStore=f;this.toPersistedMessages=J;this.heartbeatLogIntervalMs=W}teamTaskQueueKey($,f){return`${$}::${f}`}activeTeamTaskSessionId($,f){return this.teamTaskSessionsByAgent.get(this.teamTaskQueueKey($,f))?.at(-1)}buildSubsessionRow($,f){return{sessionId:f.sessionId,source:tO,pid:process.ppid,startedAt:f.startedAt,endedAt:null,exitCode:null,status:"running",statusLock:0,interactive:!1,provider:$.provider,model:$.model,cwd:$.cwd,workspaceRoot:$.workspaceRoot,teamName:$.teamName??null,enableTools:$.enableTools,enableSpawn:$.enableSpawn,enableTeams:$.enableTeams,parentSessionId:f.parentSessionId,parentAgentId:f.parentAgentId,agentId:f.agentId,conversationId:f.conversationId??null,isSubagent:!0,prompt:f.prompt,metadata:U2({prompt:f.prompt}),hookPath:"",messagesPath:f.messagesPath,updatedAt:f.startedAt}}async queueSpawnRequest($){if($.hookName!=="tool_call"||$.parent_agent_id!==null)return;if($.tool_call?.name!=="spawn_agent")return;let f=NH($.sessionContext);if(!f)return;let J=sO.safeParse($.tool_call.input);await this.adapter.enqueueSpawnRequest({rootSessionId:f,parentAgentId:$.agent_id,task:J.success?J.data.task:void 0,systemPrompt:J.success?J.data.systemPrompt:void 0})}async upsertSubagentSession($){let f=$.rootSessionId;if(!f)return;let J=await this.adapter.getSession(f);if(!J)return;let W=_J(f,$.agentId),Z=await this.adapter.getSession(W),Q=n(),j=this.manifestStore.artifacts.subagentArtifactPaths(W,$.agentId,this.activeTeamTaskSessionId(f,$.parentAgentId)),H=$.prompt??Z?.prompt??void 0;if(!H)H=await this.adapter.claimSpawnRequest(f,$.parentAgentId)??`Subagent run by ${$.parentAgentId}`;if(!Z)return await this.adapter.upsertSession(this.buildSubsessionRow(J,{sessionId:W,parentSessionId:f,parentAgentId:$.parentAgentId,agentId:$.agentId,conversationId:$.conversationId,prompt:H,startedAt:Q,...j})),this.manifestStore.initializeMessagesFile(W,j.messagesPath,Q),W;return await this.adapter.updateSession({sessionId:W,setRunning:!0,parentSessionId:f,parentAgentId:$.parentAgentId,agentId:$.agentId,conversationId:$.conversationId,prompt:Z.prompt??H??null,metadata:U2({metadata:Z.metadata??void 0,prompt:Z.prompt??H??null}),expectedStatusLock:Z.statusLock}),W}async upsertSubagentSessionFromHook($){if(!$.parent_agent_id)return;let f=NH($.sessionContext);if(!f)return;if($.hookName==="session_shutdown"){let J=_J(f,$.agent_id);return await this.adapter.getSession(J)?J:void 0}return await this.upsertSubagentSession({agentId:$.agent_id,parentAgentId:$.parent_agent_id,conversationId:$.taskId,rootSessionId:f})}async applySubagentStatus($,f){await this.applySubagentStatusBySessionId($,QW(f))}async applySubagentStatusBySessionId($,f){let J=await this.adapter.getSession($);if(!J)return;let W=$0(f)?null:n(),Z=$0(f)?null:f==="failed"?1:0;await this.adapter.updateSession({sessionId:$,status:f,endedAt:W,exitCode:Z,expectedStatusLock:J.statusLock})}async applyStatusToRunningChildSessions($,f){if(!$)return;let J=await this.adapter.listSessions({limit:2000,parentSessionId:$,status:"running"});for(let W of J)await this.applySubagentStatusBySessionId(W.sessionId,f)}async onTeamTaskStart($,f,J){let W=await this.adapter.getSession($);if(!W)return;let Z=ZW($,f),Q=n(),{messagesPath:j}=this.manifestStore.artifacts.subagentArtifactPaths(Z,f);await this.adapter.upsertSession(this.buildSubsessionRow(W,{sessionId:Z,parentSessionId:$,parentAgentId:"lead",agentId:f,prompt:J||`Team task for ${f}`,startedAt:Q,messagesPath:j})),this.manifestStore.initializeMessagesFile(Z,j,Q);let H=this.teamTaskQueueKey($,f),X=this.teamTaskSessionsByAgent.get(H)??[];X.push(Z),this.teamTaskSessionsByAgent.set(H,X)}async onTeamTaskEnd($,f,J,W,Z,Q){let j=this.teamTaskQueueKey($,f),H=this.teamTaskSessionsByAgent.get(j);if(!H||H.length===0)return;let X=H.shift();if(H.length===0)this.teamTaskSessionsByAgent.delete(j);if(!X)return;let Y=Z?.messages??Q,A=this.toPersistedMessages(Y,Z,Q);if(A)await this.manifestStore.persistSessionMessages(X,A);await this.applySubagentStatusBySessionId(X,J),this.teamTaskLastHeartbeatBySession.delete(X),this.teamTaskLastProgressLineBySession.delete(X)}async onTeamTaskProgress($,f,J,W){let Z=this.teamTaskQueueKey($,f),Q=this.teamTaskSessionsByAgent.get(Z)?.[0];if(!Q)return;let j=J.trim();if(!j)return;let H=W?.kind??"progress";if(H==="heartbeat"){let Y=Date.now(),A=this.teamTaskLastHeartbeatBySession.get(Q)??0;if(Y-A<this.heartbeatLogIntervalMs)return;this.teamTaskLastHeartbeatBySession.set(Q,Y)}let X=H==="heartbeat"?"[progress] heartbeat":H==="text"?`[progress] text: ${j}`:`[progress] ${j}`;if(this.teamTaskLastProgressLineBySession.get(Q)===X)return;this.teamTaskLastProgressLineBySession.set(Q,X)}async handleSubAgentStart($,f){let J=await this.upsertSubagentSession({agentId:f.subAgentId,parentAgentId:f.parentAgentId,conversationId:f.conversationId,prompt:f.input.task,rootSessionId:$});if(!J)return;await this.applySubagentStatusBySessionId(J,"running")}async handleSubAgentEnd($,f){let J=await this.upsertSubagentSession({agentId:f.subAgentId,parentAgentId:f.parentAgentId,conversationId:f.conversationId,prompt:f.input.task,rootSessionId:$});if(!J)return;if(f.error){await this.applySubagentStatusBySessionId(J,"failed");return}let W=this.toPersistedMessages(f.agentResult?.messages,f.agentResult);if(W)await this.manifestStore.persistSessionMessages(J,W);let Z=f.result?.finishReason??"completed";await this.applySubagentStatusBySessionId(J,Z==="aborted"?"cancelled":"completed")}appendSubagentHookAudit($){let J=(process.env.CLINE_HOOKS_LOG_PATH?.trim()||void 0)??nO(aO(),"hooks.jsonl");iO(J,`${JSON.stringify({ts:n(),...$})}
|
|
454
|
+
`,"utf8")}}import{formatUserInputBlock as W_}from"@cline/shared";function f$(){return new Date().toISOString()}function MH($,f){if(f<=0)return 0;return Math.round($/f*100)}function oO($,f){let J=new Set;for(let Z of f)if(Z.status==="reviewed")J.add(`${Z.outcomeId}:${Z.section}`);let W=new Set;for(let Z of $){if(Z.status==="finalized")continue;for(let Q of Z.requiredSections)if(!J.has(`${Z.id}:${Q}`))W.add(`${Z.id}:${Q}`)}return[...W].sort((Z,Q)=>Z.localeCompare(Q))}function xJ($,f){let J={idle:0,running:0,stopped:0},W={pending:0,in_progress:0,blocked:0,completed:0},Z={queued:0,running:0,completed:0,failed:0,cancelled:0,interrupted:0},Q={draft:0,in_review:0,finalized:0},j={draft:0,reviewed:0,rejected:0},H=0,X=0;for(let P of f.members)if(J[P.status]+=1,P.role==="lead")H+=1;else X+=1;let Y=[],A=[],V=f.tasks.filter((P)=>P.status==="completed").length,B=new Map(f.tasks.map((P)=>[P.id,P]));for(let P of f.tasks){if(W[P.status]+=1,P.status==="blocked"){Y.push(P.id);continue}if(P.status!=="pending")continue;if(P.dependsOn.every((U)=>{return B.get(U)?.status==="completed"}))A.push(P.id)}let K=[],G,R=0;for(let P of f.runs){if(Z[P.status]+=1,P.status==="queued"||P.status==="running")K.push(P.id);let F=P.startedAt.getTime();if(F>=R)R=F,G=P.id}for(let P of f.outcomes)Q[P.status]+=1;for(let P of f.outcomeFragments)j[P.status]+=1;return{teamName:$,updatedAt:f$(),members:{total:f.members.length,byStatus:J,leadCount:H,teammateCount:X},tasks:{total:f.tasks.length,byStatus:W,blockedTaskIds:Y,readyTaskIds:A,completionPct:MH(V,f.tasks.length)},runs:{total:f.runs.length,byStatus:Z,activeRunIds:K,latestRunId:G},outcomes:{total:f.outcomes.length,byStatus:Q,finalizedPct:MH(Q.finalized,f.outcomes.length),missingRequiredSections:oO(f.outcomes,f.outcomeFragments)},fragments:{total:f.outcomeFragments.length,byStatus:j}}}function mJ($){let{event:f}=$;switch(f.type){case"team_task_updated":return{teamName:$.teamName,sessionId:$.sessionId,eventType:f.type,ts:f$(),taskId:f.task.id,agentId:f.task.assignee??f.task.createdBy};case"run_queued":case"run_started":case"run_completed":case"run_failed":case"run_cancelled":case"run_interrupted":return{teamName:$.teamName,sessionId:$.sessionId,eventType:f.type,ts:f$(),runId:f.run.id,taskId:f.run.taskId,agentId:f.run.agentId,message:f.run.error};case"run_progress":return{teamName:$.teamName,sessionId:$.sessionId,eventType:f.type,ts:f$(),runId:f.run.id,taskId:f.run.taskId,agentId:f.run.agentId,message:f.message};case"outcome_created":case"outcome_finalized":return{teamName:$.teamName,sessionId:$.sessionId,eventType:f.type,ts:f$(),outcomeId:f.outcome.id};case"outcome_fragment_attached":case"outcome_fragment_reviewed":return{teamName:$.teamName,sessionId:$.sessionId,eventType:f.type,ts:f$(),outcomeId:f.fragment.outcomeId,fragmentId:f.fragment.id,agentId:f.fragment.sourceAgentId};case"team_message":return{teamName:$.teamName,sessionId:$.sessionId,eventType:f.type,ts:f$(),taskId:f.message.taskId,agentId:f.message.fromAgentId,message:f.message.subject};case"team_mission_log":return{teamName:$.teamName,sessionId:$.sessionId,eventType:f.type,ts:f$(),taskId:f.entry.taskId,agentId:f.entry.agentId,message:f.entry.summary};case"teammate_spawned":case"teammate_shutdown":case"task_start":case"task_end":case"agent_event":return{teamName:$.teamName,sessionId:$.sessionId,eventType:f.type,ts:f$(),agentId:f.agentId}}return{teamName:$.teamName,sessionId:$.sessionId,eventType:f.type,ts:f$()}}import{sanitizeFileName as eO,TeamMessageType as h}from"@cline/shared";import{nanoid as $_}from"nanoid";import{TeamMessageType as jx}from"@cline/shared";function EW($){if(typeof DOMException<"u"&&$ instanceof DOMException&&$.name==="AbortError")return!0;if(!($ instanceof Error))return!1;return $.name==="AbortError"||$.message.toLowerCase().includes("aborted")}function yH($,f){return $?.status==="stopped"&&EW(f)}var f_=600000,qH="recovered_queued";function J_($){return`This is an automatic recovery of interrupted team run ${$.id}. The previous process stopped before completion. Continue the task safely, inspect the current workspace state before making changes, and avoid duplicating completed work.
|
|
455
455
|
|
|
456
|
-
${$.message}`}class
|
|
457
|
-
${
|
|
456
|
+
${$.message}`}class bW{agents=new Map;configs=new Map;onTeamEvent;constructor($,f){if(this.onTeamEvent=f,$)for(let[J,W]of Object.entries($))this.addAgent(J,W)}addAgent($,f){if(this.agents.has($))throw Error(`Agent with id "${$}" already exists in the team`);let J={...f,onEvent:(Z)=>{f.onEvent?.(Z),this.emitEvent({type:h.AgentEvent,agentId:$,event:Z})}},W=new S$(J);if(J.onEvent)W.subscribeEvents(J.onEvent);this.agents.set($,W),this.configs.set($,f)}removeAgent($){return this.configs.delete($),this.agents.delete($)}getAgent($){return this.agents.get($)}getAgentIds(){return Array.from(this.agents.keys())}get size(){return this.agents.size}async routeTo($,f){let J=this.agents.get($);if(!J)throw Error(`Agent "${$}" not found in team`);this.emitEvent({type:h.TaskStart,agentId:$,message:f});try{let W=await J.run(f);return this.emitEvent({type:h.TaskEnd,agentId:$,result:W}),W}catch(W){let Z=W instanceof Error?W:Error(String(W));throw this.emitEvent({type:h.TaskEnd,agentId:$,error:Z,messages:J.getMessages()}),W}}async continueTo($,f){let J=this.agents.get($);if(!J)throw Error(`Agent "${$}" not found in team`);this.emitEvent({type:h.TaskStart,agentId:$,message:f});try{let W=await J.continue(f);return this.emitEvent({type:h.TaskEnd,agentId:$,result:W}),W}catch(W){let Z=W instanceof Error?W:Error(String(W));throw this.emitEvent({type:h.TaskEnd,agentId:$,error:Z,messages:J.getMessages()}),W}}async runParallel($){let f=$.map(async(J)=>{let W=this.agents.get(J.agentId);if(!W)return{agentId:J.agentId,result:void 0,error:Error(`Agent "${J.agentId}" not found in team`),metadata:J.metadata};this.emitEvent({type:h.TaskStart,agentId:J.agentId,message:J.message});try{let Z=await W.run(J.message);return this.emitEvent({type:h.TaskEnd,agentId:J.agentId,result:Z}),{agentId:J.agentId,result:Z,metadata:J.metadata}}catch(Z){let Q=Z instanceof Error?Z:Error(String(Z));return this.emitEvent({type:h.TaskEnd,agentId:J.agentId,error:Q,messages:W.getMessages()}),{agentId:J.agentId,result:void 0,error:Q,metadata:J.metadata}}});return Promise.all(f)}async runSequential($){let f=[];for(let J of $){let W=this.agents.get(J.agentId);if(!W){f.push({agentId:J.agentId,result:void 0,error:Error(`Agent "${J.agentId}" not found in team`),metadata:J.metadata});continue}this.emitEvent({type:h.TaskStart,agentId:J.agentId,message:J.message});try{let Z=await W.run(J.message);this.emitEvent({type:h.TaskEnd,agentId:J.agentId,result:Z}),f.push({agentId:J.agentId,result:Z,metadata:J.metadata})}catch(Z){let Q=Z instanceof Error?Z:Error(String(Z));this.emitEvent({type:h.TaskEnd,agentId:J.agentId,error:Q,messages:W.getMessages()}),f.push({agentId:J.agentId,result:void 0,error:Q,metadata:J.metadata})}}return f}async runPipeline($,f,J){let W=[],Z=f;for(let Q of $){let j=this.agents.get(Q);if(!j){W.push({agentId:Q,result:void 0,error:Error(`Agent "${Q}" not found in team`)});break}this.emitEvent({type:h.TaskStart,agentId:Q,message:Z});try{let H=await j.run(Z);this.emitEvent({type:h.TaskEnd,agentId:Q,result:H}),W.push({agentId:Q,result:H});let X=$.indexOf(Q)+1;if(X<$.length){let Y=$[X];Z=J?J(H,Y):`Previous agent output:
|
|
457
|
+
${H.text}
|
|
458
458
|
|
|
459
|
-
Please continue from here.`}}catch(
|
|
459
|
+
Please continue from here.`}}catch(H){let X=H instanceof Error?H:Error(String(H));this.emitEvent({type:h.TaskEnd,agentId:Q,error:X,messages:j.getMessages()}),W.push({agentId:Q,result:void 0,error:X});break}}return W}abortAll(){for(let $ of this.agents.values())$.abort(Error("Agent team abortAll requested"))}clear(){this.abortAll(),this.agents.clear(),this.configs.clear()}emitEvent($){try{this.onTeamEvent?.($)}catch{}}}class q2{teamId;teamName;onTeamEvent;members=new Map;tasks=new Map;missionLog=[];mailbox=[];missionStepCounter=0;taskCounter=0;messageCounter=0;missionCounter=0;runCounter=0;outcomeCounter=0;outcomeFragmentCounter=0;runs=new Map;runQueue=[];queuedRunDispatchTimer;outcomes=new Map;outcomeFragments=new Map;missionLogIntervalSteps;missionLogIntervalMs;maxConcurrentRuns;constructor($){this.teamName=$.teamName,this.teamId=`t_${eO($_(10))}`,this.onTeamEvent=$.onTeamEvent,this.missionLogIntervalSteps=Math.max(1,$.missionLogIntervalSteps??3),this.missionLogIntervalMs=Math.max(1000,$.missionLogIntervalMs??120000),this.maxConcurrentRuns=Math.max(1,$.maxConcurrentRuns??2);let f=$.leadAgentId??"lead";this.members.set(f,{agentId:f,role:"lead",status:"idle",runningCount:0,lastMissionStep:0,lastMissionAt:Date.now()})}getTeamId(){return this.teamId}getTeamName(){return this.teamName}getMemberRole($){return this.members.get($)?.role}getMemberIds(){return Array.from(this.members.keys())}getTeammateIds(){return Array.from(this.members.values()).filter(($)=>$.role==="teammate").map(($)=>$.agentId)}getTask($){return this.tasks.get($)}listTasks(){return Array.from(this.tasks.values())}listTaskItems($){return Array.from(this.tasks.values()).map((f)=>{let J=this.getUnresolvedDependencies(f);return{...f,blockedBy:J,isReady:f.status==="pending"&&!f.assignee&&J.length===0}}).filter((f)=>{if($?.status&&f.status!==$.status)return!1;if($?.assignee&&f.assignee!==$.assignee)return!1;return!0})}listMissionLog($){if(!$||$<=0)return[...this.missionLog];return this.missionLog.slice(Math.max(0,this.missionLog.length-$))}listMailbox($,f){let J=f?.unreadOnly??!0,W=f?.markRead??!0,Z=f?.limit,Q=this.mailbox.filter((H)=>H.toAgentId===$&&(!J||!H.readAt)),j=typeof Z==="number"&&Z>0?Q.slice(Math.max(0,Q.length-Z)):Q;if(W){let H=new Date;for(let X of j)if(!X.readAt)X.readAt=H}return j.map((H)=>({...H}))}getSnapshot(){let $={pending:0,in_progress:0,blocked:0,completed:0};for(let J of this.tasks.values())$[J.status]++;let f={draft:0,in_review:0,finalized:0};for(let J of this.outcomes.values())f[J.status]++;return{teamId:this.teamId,teamName:this.teamName,members:Array.from(this.members.values()).map((J)=>({agentId:J.agentId,role:J.role,description:J.description,status:J.status})),taskCounts:$,unreadMessages:this.mailbox.filter((J)=>!J.readAt).length,missionLogEntries:this.missionLog.length,activeRuns:Array.from(this.runs.values()).filter((J)=>J.status==="running").length,queuedRuns:Array.from(this.runs.values()).filter((J)=>J.status==="queued").length,outcomeCounts:f}}exportState(){return{teamId:this.teamId,teamName:this.teamName,members:Array.from(this.members.values()).map(($)=>({agentId:$.agentId,role:$.role,description:$.description,status:$.status})),tasks:Array.from(this.tasks.values()).map(($)=>({...$})),mailbox:this.mailbox.map(($)=>({...$})),missionLog:this.missionLog.map(($)=>({...$})),runs:Array.from(this.runs.values()).map(($)=>({...$})),outcomes:Array.from(this.outcomes.values()).map(($)=>({...$})),outcomeFragments:Array.from(this.outcomeFragments.values()).map(($)=>({...$}))}}hydrateState($){this.clearQueuedRunDispatchTimer(),this.tasks.clear();for(let J of $.tasks)this.tasks.set(J.id,{...J});this.mailbox.length=0,this.mailbox.push(...$.mailbox.map((J)=>({...J}))),this.missionLog.length=0,this.missionLog.push(...$.missionLog.map((J)=>({...J}))),this.runs.clear();for(let J of $.runs??[])this.runs.set(J.id,{...J});this.runQueue.length=0,this.runQueue.push(...Array.from(this.runs.values()).filter((J)=>J.status==="queued").map((J)=>J.id)),this.outcomes.clear();for(let J of $.outcomes??[])this.outcomes.set(J.id,{...J});this.outcomeFragments.clear();for(let J of $.outcomeFragments??[])this.outcomeFragments.set(J.id,{...J});let f=Array.from(this.members.values()).filter((J)=>J.role==="lead");this.members.clear();for(let J of f)this.members.set(J.agentId,{...J,status:"idle",runningCount:0,lastMissionStep:this.missionStepCounter,lastMissionAt:Date.now()});for(let J of $.members){if(J.role!=="teammate")continue;this.members.set(J.agentId,{agentId:J.agentId,role:"teammate",description:J.description,status:"stopped",agent:void 0,runningCount:0,lastMissionStep:this.missionStepCounter,lastMissionAt:Date.now()})}this.taskCounter=Math.max(this.taskCounter,Vf($.tasks.map((J)=>J.id),"task_")),this.messageCounter=Math.max(this.messageCounter,Vf($.mailbox.map((J)=>J.id),"msg_")),this.missionCounter=Math.max(this.missionCounter,Vf($.missionLog.map((J)=>J.id),"log_")),this.runCounter=Math.max(this.runCounter,Vf(($.runs??[]).map((J)=>J.id),"run_")),this.outcomeCounter=Math.max(this.outcomeCounter,Vf(($.outcomes??[]).map((J)=>J.id),"out_")),this.outcomeFragmentCounter=Math.max(this.outcomeFragmentCounter,Vf(($.outcomeFragments??[]).map((J)=>J.id),"frag_"))}isTeammateActive($){let f=this.members.get($);return!!f&&f.role==="teammate"&&!!f.agent}spawnTeammate({agentId:$,config:f}){let J=this.members.get($);if(J&&J.role!=="teammate")throw Error(`Team member "${$}" already exists and is not a teammate`);if(J&&J.runningCount>0)throw Error(`Teammate "${$}" is currently running and cannot be respawned`);let W={...f,apiTimeoutMs:f_,consumePendingUserMessage:()=>{let j=this.members.get($);if(!j||!j.pendingSteerMessage)return;let H=j.pendingSteerMessage;return j.pendingSteerMessage=void 0,H},onEvent:(j)=>{f.onEvent?.(j),this.emitEvent({type:h.AgentEvent,agentId:$,event:j}),this.trackMeaningfulEvent($,j)}},Z=new S$(W);if(W.onEvent)Z.subscribeEvents(W.onEvent);let Q={agentId:$,role:"teammate",description:f.role,status:"idle",agent:Z,runningCount:0,lastMissionStep:0,lastMissionAt:Date.now()};return this.members.set($,Q),this.emitEvent({type:h.TeammateSpawned,agentId:$,role:f.role,teammate:{rolePrompt:f.systemPrompt,modelId:f.modelId,maxIterations:f.maxIterations,runtimeAgentId:Z.getAgentId(),conversationId:Z.getConversationId(),parentAgentId:null}}),{agentId:Q.agentId,role:Q.role,description:Q.description,status:Q.status}}shutdownTeammate($,f){let J=this.members.get($);if(!J||J.role!=="teammate")throw Error(`Teammate "${$}" was not found`);try{J.agent?.abort()}catch(W){if(!EW(W))throw W}J.status="stopped",this.emitEvent({type:h.TeammateShutdown,agentId:$,reason:f})}updateTeammateConnections($){for(let f of this.members.values()){if(f.role!=="teammate"||!f.agent)continue;f.agent.updateConnection($)}}createTask($){let f=`task_${String(++this.taskCounter).padStart(4,"0")}`,J=new Date,W={id:f,title:$.title,description:$.description,status:$.assignee?"in_progress":"pending",createdAt:J,updatedAt:J,createdBy:$.createdBy,assignee:$.assignee,dependsOn:$.dependsOn??[]};return this.tasks.set(f,W),this.emitEvent({type:h.TeamTaskUpdated,task:{...W}}),{...W}}claimTask($,f){let J=this.requireTask($);return this.assertDependenciesResolved(J),J.status="in_progress",J.assignee=f,J.updatedAt=new Date,this.emitEvent({type:h.TeamTaskUpdated,task:{...J}}),this.appendMissionLog({agentId:f,taskId:$,kind:"progress",summary:`Claimed task "${J.title}"`}),{...J}}blockTask($,f,J){let W=this.requireTask($);return W.status="blocked",W.updatedAt=new Date,W.summary=J,this.emitEvent({type:h.TeamTaskUpdated,task:{...W}}),this.appendMissionLog({agentId:f,taskId:$,kind:"blocked",summary:J}),{...W}}completeTask($,f,J){let W=this.requireTask($);if(W.status="completed",W.updatedAt=new Date,W.summary=J,!W.assignee)W.assignee=f;return this.emitEvent({type:h.TeamTaskUpdated,task:{...W}}),this.appendMissionLog({agentId:f,taskId:$,kind:"done",summary:J}),{...W}}async routeToTeammate($,f,J){let W=this.members.get($);if(!W||W.role!=="teammate"||!W.agent)throw Error(`Teammate "${$}" was not found`);if(!W.agent.canStartRun())throw Error("Cannot start a new run while another run is already in progress");W.runningCount++,W.status="running",this.emitEvent({type:h.TaskStart,agentId:$,message:f});try{let Z=this.listMailbox($,{unreadOnly:!0,markRead:!0}),Q=Z.length>0?`${this.buildMailboxNotification(Z)}
|
|
460
460
|
|
|
461
|
-
${f}`:f,j=J?.continueConversation?await Q.agent.continue(W):await Q.agent.run(W);return this.emitEvent({type:S.TaskEnd,agentId:$,result:j}),this.recordProgressStep($,`Completed a delegated run (${j.iterations} iterations)`,J?.taskId,!0),j}catch(Z){let W=Z instanceof Error?Z:Error(String(Z));if(this.emitEvent({type:S.TaskEnd,agentId:$,error:W,messages:Q.agent.getMessages()}),!mj(Q,W))this.appendMissionLog({agentId:$,taskId:J?.taskId,kind:"error",summary:W.message});throw W}finally{if(Q.runningCount--,Q.runningCount<=0&&this.members.get($)?.status!=="stopped")Q.status="idle"}}startTeammateRun($,f,J){let Q=`run_${String(++this.runCounter).padStart(5,"0")}`,Z={id:Q,agentId:$,taskId:J?.taskId,status:"queued",message:f,priority:J?.priority??0,retryCount:0,maxRetries:Math.max(0,J?.maxRetries??0),continueConversation:J?.continueConversation,startedAt:new Date(0),leaseOwner:J?.leaseOwner,heartbeatAt:void 0,lastProgressAt:new Date,lastProgressMessage:"queued",currentActivity:"queued"};return this.runs.set(Q,Z),this.runQueue.push(Q),this.emitEvent({type:S.RunQueued,run:{...Z}}),this.dispatchQueuedRuns(),{...Z}}dispatchQueuedRuns(){this.clearQueuedRunDispatchTimer();let $;while(this.countActiveRuns()<this.maxConcurrentRuns&&this.runQueue.length>0){let f=this.selectNextDispatchableQueuedRun();$=f.nextDelayedAttemptAt;let J=f.index;if(J<0){this.scheduleQueuedRunDispatch($);return}let[Q]=this.runQueue.splice(J,1),Z=Q?this.runs.get(Q):void 0;if(!Z||Z.status!=="queued")continue;this.executeQueuedRun(Z)}this.scheduleQueuedRunDispatch($)}selectNextDispatchableQueuedRun(){let $=-1,f=Number.NEGATIVE_INFINITY,J,Q=Date.now();for(let Z=0;Z<this.runQueue.length;Z++){let W=this.runs.get(this.runQueue[Z]);if(!W||W.status!=="queued")continue;if(W.nextAttemptAt&&W.nextAttemptAt.getTime()>Q){if(!J||W.nextAttemptAt<J)J=W.nextAttemptAt;continue}if(W.priority>f)f=W.priority,$=Z}return{index:$,nextDelayedAttemptAt:J}}scheduleQueuedRunDispatch($){if(!$)return;let f=Math.max(0,$.getTime()-Date.now());this.queuedRunDispatchTimer=setTimeout(()=>{this.queuedRunDispatchTimer=void 0,this.dispatchQueuedRuns()},f)}clearQueuedRunDispatchTimer(){if(!this.queuedRunDispatchTimer)return;clearTimeout(this.queuedRunDispatchTimer),this.queuedRunDispatchTimer=void 0}countActiveRuns(){let $=0;for(let f of this.runs.values())if(f.status==="running")$++;return $}async executeQueuedRun($){let f=$.currentActivity===gj;$.nextAttemptAt=void 0,$.status="running",$.startedAt=new Date,$.heartbeatAt=new Date,$.currentActivity="run_started",this.emitEvent({type:S.RunStarted,run:{...$}});let J=setInterval(()=>{if($.status!=="running")return;this.recordRunProgress($,"heartbeat")},2000);try{let Q=f?vL($):$.message,Z=await this.routeToTeammate($.agentId,Q,{taskId:$.taskId,continueConversation:$.continueConversation});$.status="completed",$.result=Z,$.endedAt=new Date,$.currentActivity="completed",this.emitEvent({type:S.RunCompleted,run:{...$}})}catch(Q){let Z=Q instanceof Error?Q.message:String(Q??"Unknown error");$.error=Z,$.endedAt=new Date;let W=this.members.get($.agentId);if(mj(W,Q))$.status="cancelled",$.currentActivity="cancelled",this.emitEvent({type:S.RunCancelled,run:{...$},reason:Z});else if($.retryCount<$.maxRetries)$.retryCount++,$.status="queued",$.nextAttemptAt=new Date(Date.now()+Math.min(30000,1000*2**$.retryCount)),this.runQueue.push($.id),this.recordRunProgress($,`retry_scheduled_${$.retryCount}`);else $.status="failed",$.currentActivity="failed",this.emitEvent({type:S.RunFailed,run:{...$}})}finally{clearInterval(J),this.dispatchQueuedRuns()}}listRuns($){let f=$?.includeCompleted??!0;return Array.from(this.runs.values()).filter((J)=>{if(!f&&!["running","queued"].includes(J.status))return!1;if($?.status&&J.status!==$.status)return!1;if($?.agentId&&J.agentId!==$.agentId)return!1;return!0}).map((J)=>({...J}))}getRun($){let f=this.runs.get($);return f?{...f}:void 0}async awaitRun($,f=250){let J=this.runs.get($);if(!J)throw Error(`Run "${$}" was not found`);while(J.status==="queued"||J.status==="running")await vj(f);return{...J}}async awaitAllRuns($=250){while(Array.from(this.runs.values()).some((f)=>["queued","running"].includes(f.status)))await vj($);return this.listRuns()}cancelRun($,f){let J=this.runs.get($);if(!J)throw Error(`Run "${$}" was not found`);if(J.status==="completed"||J.status==="failed")return{...J};J.status="cancelled",J.error=f,J.endedAt=new Date,J.currentActivity="cancelled";let Q=this.runQueue.indexOf($);if(Q>=0)this.runQueue.splice(Q,1);return this.emitEvent({type:S.RunCancelled,run:{...J},reason:f}),{...J}}recoverActiveRuns($="runtime_recovered"){let f=[];for(let J of this.runs.values()){if(!["queued","running"].includes(J.status))continue;let Q=this.members.get(J.agentId);if(!Q||Q.role!=="teammate"||!Q.agent){J.status="interrupted",J.error="teammate_unavailable_after_recovery",J.endedAt=new Date,J.currentActivity="interrupted",this.emitEvent({type:S.RunInterrupted,run:{...J},reason:J.error});continue}let Z=new Date;if(J.status="queued",J.error=void 0,J.endedAt=void 0,J.heartbeatAt=Z,J.lastProgressAt=Z,J.lastProgressMessage=$,J.currentActivity=gj,!this.runQueue.includes(J.id))this.runQueue.push(J.id);f.push({...J}),this.emitEvent({type:S.RunQueued,run:{...J}})}return this.dispatchQueuedRuns(),f}markStaleRunsInterrupted($="runtime_recovered"){let f=[];for(let J of this.runs.values()){if(!["queued","running"].includes(J.status))continue;J.status="interrupted",J.error=$,J.endedAt=new Date,J.currentActivity="interrupted",f.push({...J}),this.emitEvent({type:S.RunInterrupted,run:{...J},reason:$})}return this.runQueue.length=0,this.clearQueuedRunDispatchTimer(),f}sendMessage($,f,J,Q,Z){if(!this.members.has($))throw Error(`Unknown sender "${$}"`);let W=this.members.get(f);if(!W)throw Error(`Unknown recipient "${f}"`);let j={id:`msg_${String(++this.messageCounter).padStart(5,"0")}`,teamId:this.teamId,fromAgentId:$,toAgentId:f,subject:J,body:Q,taskId:Z,sentAt:new Date};if(this.mailbox.push(j),this.emitEvent({type:S.TeamMessage,message:{...j}}),W.role==="teammate"&&W.runningCount>0&&W.agent)W.pendingSteerMessage=`[MAILBOX] You got a message from ${$}. Subject: "${J}". Use the team_read_mailbox tool to read it at your convenience.`;return{...j}}broadcast($,f,J,Q){let Z=[];for(let W of this.members.values()){if(W.agentId===$)continue;if(W.role==="lead")continue;Z.push(this.sendMessage($,W.agentId,f,J,Q?.taskId))}return Z}appendMissionLog($){if(!this.members.has($.agentId))throw Error(`Unknown team member "${$.agentId}"`);let f={id:`log_${String(++this.missionCounter).padStart(6,"0")}`,ts:new Date,teamId:this.teamId,agentId:$.agentId,taskId:$.taskId,kind:$.kind,summary:$.summary,evidence:$.evidence,nextAction:$.nextAction};this.missionLog.push(f);let J=this.members.get($.agentId);if(J)J.lastMissionAt=Date.now(),J.lastMissionStep=this.missionStepCounter;return this.emitEvent({type:S.TeamMissionLog,entry:{...f}}),{...f}}createOutcome($){let f={id:`out_${String(++this.outcomeCounter).padStart(4,"0")}`,teamId:this.teamId,title:$.title,status:"draft",requiredSections:[...new Set($.requiredSections)],createdBy:$.createdBy,createdAt:new Date};return this.outcomes.set(f.id,f),this.emitEvent({type:S.OutcomeCreated,outcome:{...f}}),{...f}}listOutcomes(){return Array.from(this.outcomes.values()).map(($)=>({...$}))}attachOutcomeFragment($){let f=this.outcomes.get($.outcomeId);if(!f)throw Error(`Outcome "${$.outcomeId}" was not found`);if(!f.requiredSections.includes($.section))throw Error(`Section "${$.section}" is not part of outcome "${$.outcomeId}"`);let J={id:`frag_${String(++this.outcomeFragmentCounter).padStart(5,"0")}`,teamId:this.teamId,outcomeId:$.outcomeId,section:$.section,sourceAgentId:$.sourceAgentId,sourceRunId:$.sourceRunId,content:$.content,status:"draft",createdAt:new Date};if(this.outcomeFragments.set(J.id,J),f.status==="draft")f.status="in_review";return this.emitEvent({type:S.OutcomeFragmentAttached,fragment:{...J}}),{...J}}reviewOutcomeFragment($){let f=this.outcomeFragments.get($.fragmentId);if(!f)throw Error(`Fragment "${$.fragmentId}" was not found`);return f.status=$.approved?"reviewed":"rejected",f.reviewedBy=$.reviewedBy,f.reviewedAt=new Date,this.emitEvent({type:S.OutcomeFragmentReviewed,fragment:{...f}}),{...f}}listOutcomeFragments($){return Array.from(this.outcomeFragments.values()).filter((f)=>f.outcomeId===$).map((f)=>({...f}))}finalizeOutcome($){let f=this.outcomes.get($);if(!f)throw Error(`Outcome "${$}" was not found`);let J=this.listOutcomeFragments($);for(let Q of f.requiredSections)if(!J.some((W)=>W.section===Q&&W.status==="reviewed"))throw Error(`Outcome "${$}" cannot be finalized. Section "${Q}" is missing a reviewed fragment.`);return f.status="finalized",f.finalizedAt=new Date,this.emitEvent({type:S.OutcomeFinalized,outcome:{...f}}),{...f}}cleanup(){for(let $ of this.members.values())if($.role==="teammate"&&$.runningCount>0)throw Error(`Cannot cleanup team while teammate "${$.agentId}" is still running`);if(Array.from(this.runs.values()).some(($)=>["queued","running"].includes($.status)))throw Error("Cannot cleanup team while async teammate runs are still active");for(let $ of this.members.values())if($.role==="teammate")try{$.agent?.abort()}catch(f){if(!W9(f))throw f}this.tasks.clear(),this.mailbox.length=0,this.missionLog.length=0,this.runs.clear(),this.runQueue.length=0,this.clearQueuedRunDispatchTimer(),this.outcomes.clear(),this.outcomeFragments.clear();for(let[$,f]of this.members.entries())if(f.role==="teammate")this.members.delete($)}requireTask($){let f=this.tasks.get($);if(!f)throw Error(`Task "${$}" was not found`);return f}assertDependenciesResolved($){let f=this.getUnresolvedDependencies($);if(f.length>0)throw Error(`Task "${$.id}" is blocked by "${f[0]}"`)}getUnresolvedDependencies($){return $.dependsOn.filter((f)=>{let J=this.tasks.get(f);return!J||J.status!=="completed"})}trackMeaningfulEvent($,f){if(this.recordRunActivityFromAgentEvent($,f),f.type==="iteration_end"&&f.hadToolCalls){this.recordProgressStep($,`Completed iteration ${f.iteration} with ${f.toolCallCount} tool call(s)`);return}if(f.type==="content_end"&&f.contentType==="tool"&&!f.error){this.recordProgressStep($,`Finished tool "${f.toolName??"unknown"}"`);return}if(f.type==="done"){this.appendMissionLog({agentId:$,kind:"done",summary:`Completed a delegated run (${f.iterations} iterations)`});return}if(f.type==="error")this.appendMissionLog({agentId:$,kind:"error",summary:f.error.message})}recordRunActivityFromAgentEvent($,f){let J;switch(f.type){case"iteration_start":J=`iteration_${f.iteration}_started`;break;case"content_start":if(f.contentType==="tool")J=`running_tool_${f.toolName??"unknown"}`;break;case"content_end":if(f.contentType==="tool")J=f.error?this.formatProgressErrorActivity(`tool_${f.toolName??"unknown"}_error`,f.error):`finished_tool_${f.toolName??"unknown"}`;break;case"done":J="finalizing_response";break;case"error":J=this.formatProgressErrorActivity("run_error",f.error.message);break;default:break}if(!J)return;for(let Q of this.runs.values()){if(Q.agentId!==$||Q.status!=="running")continue;this.recordRunProgress(Q,J)}}recordRunProgress($,f){let J=new Date;$.heartbeatAt=J,$.lastProgressAt=J,$.lastProgressMessage=f,$.currentActivity=f,this.emitEvent({type:S.RunProgress,run:{...$},message:f})}formatProgressErrorActivity($,f){let J=f.replace(/\s+/g," ").trim();if(J.length===0)return $;let Q=J.length>240?`${J.slice(0,237).trimEnd()}...`:J;return`${$}: ${Q}`}recordProgressStep($,f,J,Q=!1){this.missionStepCounter++;let Z=this.members.get($);if(!Z)return;let W=this.missionStepCounter-Z.lastMissionStep,j=Date.now()-Z.lastMissionAt;if(!Q&&W<this.missionLogIntervalSteps&&j<this.missionLogIntervalMs)return;this.appendMissionLog({agentId:$,taskId:J,kind:"progress",summary:f})}buildMailboxNotification($){if($.length===0)return"";let f=[`[MAILBOX] You have ${$.length} unread message(s):`];for(let J of $)f.push(`--- Message from ${J.fromAgentId} | subject: ${J.subject} ---`),f.push(J.body);return f.push("---"),f.join(`
|
|
462
|
-
`)}emitEvent($){try{this.onTeamEvent?.($)}catch{}}}function
|
|
461
|
+
${f}`:f,j=J?.continueConversation?await W.agent.continue(Q):await W.agent.run(Q);return this.emitEvent({type:h.TaskEnd,agentId:$,result:j}),this.recordProgressStep($,`Completed a delegated run (${j.iterations} iterations)`,J?.taskId,!0),j}catch(Z){let Q=Z instanceof Error?Z:Error(String(Z));if(this.emitEvent({type:h.TaskEnd,agentId:$,error:Q,messages:W.agent.getMessages()}),!yH(W,Q))this.appendMissionLog({agentId:$,taskId:J?.taskId,kind:"error",summary:Q.message});throw Q}finally{if(W.runningCount--,W.runningCount<=0&&this.members.get($)?.status!=="stopped")W.status="idle"}}startTeammateRun($,f,J){let W=`run_${String(++this.runCounter).padStart(5,"0")}`,Z={id:W,agentId:$,taskId:J?.taskId,status:"queued",message:f,priority:J?.priority??0,retryCount:0,maxRetries:Math.max(0,J?.maxRetries??0),continueConversation:J?.continueConversation,startedAt:new Date(0),leaseOwner:J?.leaseOwner,heartbeatAt:void 0,lastProgressAt:new Date,lastProgressMessage:"queued",currentActivity:"queued"};return this.runs.set(W,Z),this.runQueue.push(W),this.emitEvent({type:h.RunQueued,run:{...Z}}),this.dispatchQueuedRuns(),{...Z}}dispatchQueuedRuns(){this.clearQueuedRunDispatchTimer();let $;while(this.countActiveRuns()<this.maxConcurrentRuns&&this.runQueue.length>0){let f=this.selectNextDispatchableQueuedRun();$=f.nextDelayedAttemptAt;let J=f.index;if(J<0){this.scheduleQueuedRunDispatch($);return}let[W]=this.runQueue.splice(J,1),Z=W?this.runs.get(W):void 0;if(!Z||Z.status!=="queued")continue;this.executeQueuedRun(Z)}this.scheduleQueuedRunDispatch($)}selectNextDispatchableQueuedRun(){let $=-1,f=Number.NEGATIVE_INFINITY,J,W=Date.now();for(let Z=0;Z<this.runQueue.length;Z++){let Q=this.runs.get(this.runQueue[Z]);if(!Q||Q.status!=="queued")continue;if(Q.nextAttemptAt&&Q.nextAttemptAt.getTime()>W){if(!J||Q.nextAttemptAt<J)J=Q.nextAttemptAt;continue}if(Q.priority>f)f=Q.priority,$=Z}return{index:$,nextDelayedAttemptAt:J}}scheduleQueuedRunDispatch($){if(!$)return;let f=Math.max(0,$.getTime()-Date.now());this.queuedRunDispatchTimer=setTimeout(()=>{this.queuedRunDispatchTimer=void 0,this.dispatchQueuedRuns()},f)}clearQueuedRunDispatchTimer(){if(!this.queuedRunDispatchTimer)return;clearTimeout(this.queuedRunDispatchTimer),this.queuedRunDispatchTimer=void 0}countActiveRuns(){let $=0;for(let f of this.runs.values())if(f.status==="running")$++;return $}async executeQueuedRun($){let f=$.currentActivity===qH;$.nextAttemptAt=void 0,$.status="running",$.startedAt=new Date,$.heartbeatAt=new Date,$.currentActivity="run_started",this.emitEvent({type:h.RunStarted,run:{...$}});let J=setInterval(()=>{if($.status!=="running")return;this.recordRunProgress($,"heartbeat")},2000);try{let W=f?J_($):$.message,Z=await this.routeToTeammate($.agentId,W,{taskId:$.taskId,continueConversation:$.continueConversation});$.status="completed",$.result=Z,$.endedAt=new Date,$.currentActivity="completed",this.emitEvent({type:h.RunCompleted,run:{...$}})}catch(W){let Z=W instanceof Error?W.message:String(W??"Unknown error");$.error=Z,$.endedAt=new Date;let Q=this.members.get($.agentId);if(yH(Q,W))$.status="cancelled",$.currentActivity="cancelled",this.emitEvent({type:h.RunCancelled,run:{...$},reason:Z});else if($.retryCount<$.maxRetries)$.retryCount++,$.status="queued",$.nextAttemptAt=new Date(Date.now()+Math.min(30000,1000*2**$.retryCount)),this.runQueue.push($.id),this.recordRunProgress($,`retry_scheduled_${$.retryCount}`);else $.status="failed",$.currentActivity="failed",this.emitEvent({type:h.RunFailed,run:{...$}})}finally{clearInterval(J),this.dispatchQueuedRuns()}}listRuns($){let f=$?.includeCompleted??!0;return Array.from(this.runs.values()).filter((J)=>{if(!f&&!["running","queued"].includes(J.status))return!1;if($?.status&&J.status!==$.status)return!1;if($?.agentId&&J.agentId!==$.agentId)return!1;return!0}).map((J)=>({...J}))}getRun($){let f=this.runs.get($);return f?{...f}:void 0}async awaitRun($,f=250){let J=this.runs.get($);if(!J)throw Error(`Run "${$}" was not found`);while(J.status==="queued"||J.status==="running")await wH(f);return{...J}}async awaitAllRuns($=250){while(Array.from(this.runs.values()).some((f)=>["queued","running"].includes(f.status)))await wH($);return this.listRuns()}cancelRun($,f){let J=this.runs.get($);if(!J)throw Error(`Run "${$}" was not found`);if(J.status==="completed"||J.status==="failed")return{...J};J.status="cancelled",J.error=f,J.endedAt=new Date,J.currentActivity="cancelled";let W=this.runQueue.indexOf($);if(W>=0)this.runQueue.splice(W,1);return this.emitEvent({type:h.RunCancelled,run:{...J},reason:f}),{...J}}recoverActiveRuns($="runtime_recovered"){let f=[];for(let J of this.runs.values()){if(!["queued","running"].includes(J.status))continue;let W=this.members.get(J.agentId);if(!W||W.role!=="teammate"||!W.agent){J.status="interrupted",J.error="teammate_unavailable_after_recovery",J.endedAt=new Date,J.currentActivity="interrupted",this.emitEvent({type:h.RunInterrupted,run:{...J},reason:J.error});continue}let Z=new Date;if(J.status="queued",J.error=void 0,J.endedAt=void 0,J.heartbeatAt=Z,J.lastProgressAt=Z,J.lastProgressMessage=$,J.currentActivity=qH,!this.runQueue.includes(J.id))this.runQueue.push(J.id);f.push({...J}),this.emitEvent({type:h.RunQueued,run:{...J}})}return this.dispatchQueuedRuns(),f}markStaleRunsInterrupted($="runtime_recovered"){let f=[];for(let J of this.runs.values()){if(!["queued","running"].includes(J.status))continue;J.status="interrupted",J.error=$,J.endedAt=new Date,J.currentActivity="interrupted",f.push({...J}),this.emitEvent({type:h.RunInterrupted,run:{...J},reason:$})}return this.runQueue.length=0,this.clearQueuedRunDispatchTimer(),f}sendMessage($,f,J,W,Z){if(!this.members.has($))throw Error(`Unknown sender "${$}"`);let Q=this.members.get(f);if(!Q)throw Error(`Unknown recipient "${f}"`);let j={id:`msg_${String(++this.messageCounter).padStart(5,"0")}`,teamId:this.teamId,fromAgentId:$,toAgentId:f,subject:J,body:W,taskId:Z,sentAt:new Date};if(this.mailbox.push(j),this.emitEvent({type:h.TeamMessage,message:{...j}}),Q.role==="teammate"&&Q.runningCount>0&&Q.agent)Q.pendingSteerMessage=`[MAILBOX] You got a message from ${$}. Subject: "${J}". Use the team_read_mailbox tool to read it at your convenience.`;return{...j}}broadcast($,f,J,W){let Z=[];for(let Q of this.members.values()){if(Q.agentId===$)continue;if(Q.role==="lead")continue;Z.push(this.sendMessage($,Q.agentId,f,J,W?.taskId))}return Z}appendMissionLog($){if(!this.members.has($.agentId))throw Error(`Unknown team member "${$.agentId}"`);let f={id:`log_${String(++this.missionCounter).padStart(6,"0")}`,ts:new Date,teamId:this.teamId,agentId:$.agentId,taskId:$.taskId,kind:$.kind,summary:$.summary,evidence:$.evidence,nextAction:$.nextAction};this.missionLog.push(f);let J=this.members.get($.agentId);if(J)J.lastMissionAt=Date.now(),J.lastMissionStep=this.missionStepCounter;return this.emitEvent({type:h.TeamMissionLog,entry:{...f}}),{...f}}createOutcome($){let f={id:`out_${String(++this.outcomeCounter).padStart(4,"0")}`,teamId:this.teamId,title:$.title,status:"draft",requiredSections:[...new Set($.requiredSections)],createdBy:$.createdBy,createdAt:new Date};return this.outcomes.set(f.id,f),this.emitEvent({type:h.OutcomeCreated,outcome:{...f}}),{...f}}listOutcomes(){return Array.from(this.outcomes.values()).map(($)=>({...$}))}attachOutcomeFragment($){let f=this.outcomes.get($.outcomeId);if(!f)throw Error(`Outcome "${$.outcomeId}" was not found`);if(!f.requiredSections.includes($.section))throw Error(`Section "${$.section}" is not part of outcome "${$.outcomeId}"`);let J={id:`frag_${String(++this.outcomeFragmentCounter).padStart(5,"0")}`,teamId:this.teamId,outcomeId:$.outcomeId,section:$.section,sourceAgentId:$.sourceAgentId,sourceRunId:$.sourceRunId,content:$.content,status:"draft",createdAt:new Date};if(this.outcomeFragments.set(J.id,J),f.status==="draft")f.status="in_review";return this.emitEvent({type:h.OutcomeFragmentAttached,fragment:{...J}}),{...J}}reviewOutcomeFragment($){let f=this.outcomeFragments.get($.fragmentId);if(!f)throw Error(`Fragment "${$.fragmentId}" was not found`);return f.status=$.approved?"reviewed":"rejected",f.reviewedBy=$.reviewedBy,f.reviewedAt=new Date,this.emitEvent({type:h.OutcomeFragmentReviewed,fragment:{...f}}),{...f}}listOutcomeFragments($){return Array.from(this.outcomeFragments.values()).filter((f)=>f.outcomeId===$).map((f)=>({...f}))}finalizeOutcome($){let f=this.outcomes.get($);if(!f)throw Error(`Outcome "${$}" was not found`);let J=this.listOutcomeFragments($);for(let W of f.requiredSections)if(!J.some((Q)=>Q.section===W&&Q.status==="reviewed"))throw Error(`Outcome "${$}" cannot be finalized. Section "${W}" is missing a reviewed fragment.`);return f.status="finalized",f.finalizedAt=new Date,this.emitEvent({type:h.OutcomeFinalized,outcome:{...f}}),{...f}}cleanup(){for(let $ of this.members.values())if($.role==="teammate"&&$.runningCount>0)throw Error(`Cannot cleanup team while teammate "${$.agentId}" is still running`);if(Array.from(this.runs.values()).some(($)=>["queued","running"].includes($.status)))throw Error("Cannot cleanup team while async teammate runs are still active");for(let $ of this.members.values())if($.role==="teammate")try{$.agent?.abort()}catch(f){if(!EW(f))throw f}this.tasks.clear(),this.mailbox.length=0,this.missionLog.length=0,this.runs.clear(),this.runQueue.length=0,this.clearQueuedRunDispatchTimer(),this.outcomes.clear(),this.outcomeFragments.clear();for(let[$,f]of this.members.entries())if(f.role==="teammate")this.members.delete($)}requireTask($){let f=this.tasks.get($);if(!f)throw Error(`Task "${$}" was not found`);return f}assertDependenciesResolved($){let f=this.getUnresolvedDependencies($);if(f.length>0)throw Error(`Task "${$.id}" is blocked by "${f[0]}"`)}getUnresolvedDependencies($){return $.dependsOn.filter((f)=>{let J=this.tasks.get(f);return!J||J.status!=="completed"})}trackMeaningfulEvent($,f){if(this.recordRunActivityFromAgentEvent($,f),f.type==="iteration_end"&&f.hadToolCalls){this.recordProgressStep($,`Completed iteration ${f.iteration} with ${f.toolCallCount} tool call(s)`);return}if(f.type==="content_end"&&f.contentType==="tool"&&!f.error){this.recordProgressStep($,`Finished tool "${f.toolName??"unknown"}"`);return}if(f.type==="done"){this.appendMissionLog({agentId:$,kind:"done",summary:`Completed a delegated run (${f.iterations} iterations)`});return}if(f.type==="error")this.appendMissionLog({agentId:$,kind:"error",summary:f.error.message})}recordRunActivityFromAgentEvent($,f){let J;switch(f.type){case"iteration_start":J=`iteration_${f.iteration}_started`;break;case"content_start":if(f.contentType==="tool")J=`running_tool_${f.toolName??"unknown"}`;break;case"content_end":if(f.contentType==="tool")J=f.error?this.formatProgressErrorActivity(`tool_${f.toolName??"unknown"}_error`,f.error):`finished_tool_${f.toolName??"unknown"}`;break;case"done":J="finalizing_response";break;case"error":J=this.formatProgressErrorActivity("run_error",f.error.message);break;default:break}if(!J)return;for(let W of this.runs.values()){if(W.agentId!==$||W.status!=="running")continue;this.recordRunProgress(W,J)}}recordRunProgress($,f){let J=new Date;$.heartbeatAt=J,$.lastProgressAt=J,$.lastProgressMessage=f,$.currentActivity=f,this.emitEvent({type:h.RunProgress,run:{...$},message:f})}formatProgressErrorActivity($,f){let J=f.replace(/\s+/g," ").trim();if(J.length===0)return $;let W=J.length>240?`${J.slice(0,237).trimEnd()}...`:J;return`${$}: ${W}`}recordProgressStep($,f,J,W=!1){this.missionStepCounter++;let Z=this.members.get($);if(!Z)return;let Q=this.missionStepCounter-Z.lastMissionStep,j=Date.now()-Z.lastMissionAt;if(!W&&Q<this.missionLogIntervalSteps&&j<this.missionLogIntervalMs)return;this.appendMissionLog({agentId:$,taskId:J,kind:"progress",summary:f})}buildMailboxNotification($){if($.length===0)return"";let f=[`[MAILBOX] You have ${$.length} unread message(s):`];for(let J of $)f.push(`--- Message from ${J.fromAgentId} | subject: ${J.subject} ---`),f.push(J.body);return f.push("---"),f.join(`
|
|
462
|
+
`)}emitEvent($){try{this.onTeamEvent?.($)}catch{}}}function wH($){return new Promise((f)=>setTimeout(f,$))}function Vf($,f){let J=0;for(let W of $){if(!W.startsWith(f))continue;let Z=Number.parseInt(W.slice(f.length),10);if(Number.isFinite(Z))J=Math.max(J,Z)}return J}function kW($,f){switch(f.type){case"run_queued":case"run_started":$.activeTeamRunIds.add(f.run.id);break;case"run_completed":case"run_failed":case"run_cancelled":case"run_interrupted":{let J;if(f.type==="run_failed")J=f.run.error;else if(f.type==="run_cancelled"||f.type==="run_interrupted")J=f.run.error??f.reason;$.activeTeamRunIds.delete(f.run.id),$.pendingTeamRunUpdates.push({runId:f.run.id,agentId:f.run.agentId,taskId:f.run.taskId,status:f.type.replace("run_",""),error:J,iterations:f.run.result?.iterations}),gJ($);break}default:break}}async function IW($,f,J){switch(f.type){case"run_progress":await J("onTeamTaskProgress",$,f.run.agentId,f.message,{kind:f.message==="heartbeat"?"heartbeat":"progress"});break;case"agent_event":if(f.event.type==="content_start"&&f.event.contentType==="text"&&typeof f.event.text==="string"){let W=f.event.text.replace(/\s+/g," ").trim().slice(0,120);if(W)await J("onTeamTaskProgress",$,f.agentId,W,{kind:"text"})}break;case"task_start":await J("onTeamTaskStart",$,f.agentId,f.message);break;case"task_end":{if(f.error)await J("onTeamTaskEnd",$,f.agentId,"failed",`[error] ${f.error.message}`,void 0,f.messages);else if(f.result?.finishReason==="aborted")await J("onTeamTaskEnd",$,f.agentId,"cancelled","[done] aborted",f.result,f.result.messages);else await J("onTeamTaskEnd",$,f.agentId,"completed",`[done] ${f.result?.finishReason??"completed"}`,f.result,f.result?.messages);break}default:break}}function xW($,f,J,W){if(!$.runtime.teamRuntime)return;let Z=$.runtime.teamRuntime.getTeamName();W({type:"team_progress",payload:{sessionId:f,teamName:Z,lifecycle:mJ({teamName:Z,sessionId:f,event:J}),summary:xJ(Z,$.runtime.teamRuntime.exportState())}})}function w2($){return $.activeTeamRunIds.size>0||$.pendingTeamRunUpdates.length>0}function mW($,f){if($.aborting)return!1;if(!(f==="completed"||f==="max_iterations"))return!1;return $.config.enableAgentTeams===!0&&w2($)}function gJ($){let f=$.teamRunWaiters.splice(0);for(let J of f)J()}async function gW($){while(!0){if($.aborting)return[];if($.pendingTeamRunUpdates.length>0){let f=[...$.pendingTeamRunUpdates];return $.pendingTeamRunUpdates.length=0,f}if($.activeTeamRunIds.size===0)return[];await new Promise((f)=>{$.teamRunWaiters.push(f)})}}function vW($,f){let J=f.map((Q)=>{let j=[`- ${Q.runId} (${Q.agentId}) -> ${Q.status}`];if(Q.taskId)j.push(` task=${Q.taskId}`);if(typeof Q.iterations==="number")j.push(` iterations=${Q.iterations}`);if(Q.error)j.push(` error=${Q.error}`);return j.join("")}),W=$.activeTeamRunIds.size,Z=W>0?`There are still ${W} teammate run(s) in progress. Continue coordination and decide whether to wait for more updates.`:"No teammate runs are currently in progress. Continue coordination using these updates.";return S2(`System-delivered teammate async run updates:
|
|
463
463
|
${J.join(`
|
|
464
464
|
`)}
|
|
465
465
|
|
|
466
|
-
${Z}`,$.config.mode)}function
|
|
467
|
-
`,"utf8"),
|
|
466
|
+
${Z}`,$.config.mode)}function S2($,f){return W_($,f==="plan"?"plan":f==="yolo"?"yolo":"act")}var uW=4;class K${adapter;manifestStore;teamChildren;static STALE_REASON="failed_external_process_exit";static STALE_SOURCE="stale_session_reconciler";static TEAM_HEARTBEAT_LOG_INTERVAL_MS=30000;constructor($,f={}){this.adapter=$;this.manifestStore=new hW($,f.messagesArtifactUploader,f.logger),this.teamChildren=new IJ($,this.manifestStore,(J,W,Z)=>this.toPersistedMessages(J,W,Z),K$.TEAM_HEARTBEAT_LOG_INTERVAL_MS)}toPersistedMessages($,f,J){if(!$)return;return f?NJ(f.messages,f,J):TJ($)}ensureSessionsDir(){return this.manifestStore.ensureSessionsDir()}writeSessionManifest($,f){this.manifestStore.writeSessionManifest($,f)}readSessionManifest($){return this.manifestStore.readSessionManifest($)}async createRootSessionWithArtifacts($){let f=$.startedAt??n(),J=$.sessionId.trim(),W=J.length>0?J:`${Date.now()}_${Q_(5)}`,Z=this.manifestStore.artifacts.sessionMessagesPath(W),Q=this.manifestStore.artifacts.sessionManifestPath(W),j=U2({metadata:$.metadata,prompt:$.prompt}),H={version:1,session_id:W,source:$.source,pid:$.pid,started_at:f,status:"running",interactive:$.interactive,provider:$.provider,model:$.model,cwd:$.cwd,workspace_root:$.workspaceRoot,team_name:$.teamName,enable_tools:$.enableTools,enable_spawn:$.enableSpawn,enable_teams:$.enableTeams,prompt:$.prompt?.trim()||void 0,metadata:j,messages_path:Z};return await this.adapter.upsertSession({sessionId:W,source:$.source,pid:$.pid,startedAt:f,endedAt:null,exitCode:null,status:"running",statusLock:0,interactive:$.interactive,provider:$.provider,model:$.model,cwd:$.cwd,workspaceRoot:$.workspaceRoot,teamName:$.teamName??null,enableTools:$.enableTools,enableSpawn:$.enableSpawn,enableTeams:$.enableTeams,parentSessionId:null,parentAgentId:null,agentId:null,conversationId:null,isSubagent:!1,prompt:H.prompt??null,metadata:b$(H.metadata),hookPath:"",messagesPath:Z,updatedAt:n()}),this.manifestStore.initializeMessagesFile(W,Z,f),this.manifestStore.writeSessionManifest(Q,H),{manifestPath:Q,messagesPath:Z,manifest:H}}async updateSessionStatus($,f,J){let W;if((await hj(()=>this.adapter.getSession($),async(Q)=>{return W=$0(f)?void 0:n(),this.adapter.updateSession({sessionId:$,status:f,endedAt:W??null,exitCode:$0(f)?null:typeof J==="number"?J:null,expectedStatusLock:Q.statusLock})},uW)).updated){if(f==="cancelled")await this.teamChildren.applyStatusToRunningChildSessions($,"cancelled");return{updated:!0,endedAt:W}}return{updated:!1}}async updateSession($){for(let f=0;f<uW;f++){let J=await this.adapter.getSession($.sessionId);if(!J)return{updated:!1};let W=J.metadata??void 0,Z=$.metadata!==void 0?b$($.metadata)??{}:b$(W)??{},Q=_1(typeof W?.title==="string"?W.title:void 0),j=$.title!==void 0?_1($.title):Q??XW($.prompt);if(j)Z.title=j;else delete Z.title;let H=$.metadata!==void 0||$.prompt!==void 0||$.title!==void 0;if(!(await this.adapter.updateSession({sessionId:$.sessionId,prompt:$.prompt,metadata:H?Object.keys(Z).length>0?Z:null:void 0,title:j,expectedStatusLock:J.statusLock})).updated)continue;let{path:Y,manifest:A}=this.manifestStore.readManifestFile($.sessionId);if(A){if($.prompt!==void 0)A.prompt=$.prompt??void 0;let V=$.metadata!==void 0?b$($.metadata)??{}:b$(A.metadata)??{};if(j)V.title=j;A.metadata=Object.keys(V).length>0?V:void 0,this.manifestStore.writeSessionManifest(Y,A)}return{updated:!0}}return{updated:!1}}queueSpawnRequest($){return this.teamChildren.queueSpawnRequest($)}upsertSubagentSession($){return this.teamChildren.upsertSubagentSession($)}upsertSubagentSessionFromHook($){return this.teamChildren.upsertSubagentSessionFromHook($)}appendSubagentHookAudit($,f){return this.teamChildren.appendSubagentHookAudit(f),Promise.resolve()}persistSessionMessages($,f,J){let W=TJ(f);return this.manifestStore.persistSessionMessages($,W,J)}applySubagentStatus($,f){return this.teamChildren.applySubagentStatus($,f)}applySubagentStatusBySessionId($,f){return this.teamChildren.applySubagentStatusBySessionId($,f)}applyStatusToRunningChildSessions($,f){return this.teamChildren.applyStatusToRunningChildSessions($,f)}onTeamTaskStart($,f,J){return this.teamChildren.onTeamTaskStart($,f,J)}onTeamTaskEnd($,f,J,W,Z,Q){return this.teamChildren.onTeamTaskEnd($,f,J,W,Z,Q)}onTeamTaskProgress($,f,J,W){return this.teamChildren.onTeamTaskProgress($,f,J,W)}handleSubAgentStart($,f){return this.teamChildren.handleSubAgentStart($,f)}handleSubAgentEnd($,f){return this.teamChildren.handleSubAgentEnd($,f)}isPidAlive($){if(!Number.isFinite($)||$<=0)return!1;try{return process.kill(Math.floor($),0),!0}catch(f){return typeof f==="object"&&f!==null&&"code"in f&&f.code==="EPERM"}}async reconcileDeadRunningSession($){if($0($.status)===!1||this.isPidAlive($.pid))return $;let f=n(),J=K$.STALE_REASON;for(let W=0;W<uW;W++){let Z=await this.adapter.getSession($.sessionId);if(!Z)return;if($0(Z.status)===!1)return Z;let Q={...Z.metadata??{},terminal_marker:J,terminal_marker_at:f,terminal_marker_pid:Z.pid,terminal_marker_source:K$.STALE_SOURCE},j=await this.adapter.updateSession({sessionId:Z.sessionId,status:"failed",endedAt:f,exitCode:1,metadata:Q,expectedStatusLock:Z.statusLock});if(!j.updated)continue;await this.teamChildren.applyStatusToRunningChildSessions(Z.sessionId,"failed");let H=Sj(Z,{status:"failed",endedAt:f,exitCode:1,metadata:Q}),{path:X}=this.manifestStore.readManifestFile(Z.sessionId);return this.manifestStore.writeSessionManifest(X,H),this.manifestStore.appendStaleSessionHookLog(f,Z.sessionId,Z.pid,J,K$.STALE_SOURCE),{...Z,status:"failed",endedAt:f,exitCode:1,metadata:Q,statusLock:j.statusLock,updatedAt:f}}return await this.adapter.getSession($.sessionId)}async listSessions($=200){let f=Math.max(1,Math.floor($)),J=Math.min(f*5,2000);return await this.reconcileDeadSessions(J),(await this.adapter.listSessions({limit:J})).slice(0,f).map((Z)=>{let Q=b$(Z.metadata??void 0),j=this.manifestStore.readSessionManifest(Z.sessionId),H=_1(typeof j?.metadata?.title==="string"?j.metadata.title:void 0),X=H?{...Q??{},title:H}:Q;return{...Z,metadata:X}})}async reconcileDeadSessions($=2000){let f=Math.max(1,Math.floor($)),J=(await Promise.all(["idle","running","pending"].map((Z)=>this.adapter.listSessions({limit:f,status:Z})))).flat(),W=0;for(let Z of J){let Q=await this.reconcileDeadRunningSession(Z);if(Q&&Q.status!==Z.status)W++}return W}async deleteSession($){let f=$.trim();if(!f)throw Error("session id is required");let J=await this.adapter.getSession(f);if(!J)return{deleted:!1};if(await this.adapter.deleteSession(f,!1),!J.isSubagent){let W=await this.adapter.listSessions({limit:2000,parentSessionId:f});await this.adapter.deleteSession(f,!0),await Promise.allSettled(W.map(async(Z)=>{await wW(Z.cwd,Z.sessionId),y2(Z.messagesPath),y2(this.manifestStore.artifacts.sessionManifestPath(Z.sessionId,!1)),this.manifestStore.artifacts.removeSessionDirIfEmpty(Z.sessionId)}))}if(await wW(J.cwd,f),y2(J.messagesPath),y2(this.manifestStore.artifacts.sessionManifestPath(f,!1)),J.isSubagent)this.manifestStore.artifacts.removeSessionDirIfEmpty(f);else{let W=new Set([this.manifestStore.artifacts.sessionArtifactsDir(f)]);for(let Z of[J.messagesPath])if(typeof Z==="string"&&Z.trim().length>0)W.add(Z_(Z));for(let Z of W)this.manifestStore.artifacts.removeDir(Z)}return{deleted:!0}}}function dW(){return new Date().toISOString()}function CH($,f){let J=`${$}.tmp`;X_(J,`${JSON.stringify(f,null,2)}
|
|
467
|
+
`,"utf8"),H_(J,$)}class EH{sessionsDirPath;constructor($=Y_()){this.sessionsDirPath=$}ensureSessionsDir(){if(!cW(this.sessionsDirPath))j_(this.sessionsDirPath,{recursive:!0});return this.sessionsDirPath}indexPath(){return hH(this.ensureSessionsDir(),"sessions.index.json")}spawnQueuePath(){return hH(this.ensureSessionsDir(),"subagent-spawn-queue.json")}readIndex(){let $=this.indexPath();if(!cW($))return{version:1,sessions:{}};try{let f=JSON.parse(SH($,"utf8"));if(f?.version===1&&f.sessions)return f}catch{}return{version:1,sessions:{}}}writeIndex($){CH(this.indexPath(),$)}readQueue(){let $=this.spawnQueuePath();if(!cW($))return{version:1,nextId:1,requests:[]};try{let f=JSON.parse(SH($,"utf8"));if(f?.version===1&&typeof f.nextId==="number"&&Array.isArray(f.requests))return f}catch{}return{version:1,nextId:1,requests:[]}}writeQueue($){CH(this.spawnQueuePath(),$)}async upsertSession($){let f=this.readIndex();f.sessions[$.sessionId]=$,this.writeIndex(f)}async getSession($){return this.readIndex().sessions[$]}async listSessions($){return Object.values(this.readIndex().sessions).filter((f)=>$.parentSessionId!==void 0?f.parentSessionId===$.parentSessionId:!0).filter((f)=>$.status!==void 0?f.status===$.status:!0).sort((f,J)=>J.startedAt.localeCompare(f.startedAt)).slice(0,$.limit)}async updateSession($){let f=this.readIndex(),J=f.sessions[$.sessionId];if(!J)return{updated:!1,statusLock:0};if($.expectedStatusLock!==void 0&&J.statusLock!==$.expectedStatusLock)return{updated:!1,statusLock:J.statusLock};let W=$.expectedStatusLock!==void 0?$.expectedStatusLock+1:J.statusLock,Z={...J,status:$.status??J.status,endedAt:$.endedAt!==void 0?$.endedAt:J.endedAt??null,exitCode:$.exitCode!==void 0?$.exitCode:J.exitCode??null,prompt:$.prompt!==void 0?$.prompt:J.prompt??null,metadata:$.metadata!==void 0?$.metadata??null:J.metadata??null,parentSessionId:$.parentSessionId!==void 0?$.parentSessionId??null:J.parentSessionId??null,parentAgentId:$.parentAgentId!==void 0?$.parentAgentId??null:J.parentAgentId??null,agentId:$.agentId!==void 0?$.agentId??null:J.agentId??null,conversationId:$.conversationId!==void 0?$.conversationId??null:J.conversationId??null,statusLock:W,isSubagent:$.setRunning||$.parentSessionId!==void 0?!0:J.isSubagent,updatedAt:dW()};if($.setRunning)Z.status="running",Z.endedAt=null,Z.exitCode=null;return f.sessions[$.sessionId]=Z,this.writeIndex(f),{updated:!0,statusLock:Z.statusLock}}async deleteSession($,f){let J=this.readIndex();if(!J.sessions[$])return!1;if(delete J.sessions[$],f){for(let Z of Object.values(J.sessions))if(Z.parentSessionId===$)delete J.sessions[Z.sessionId]}return this.writeIndex(J),!0}async enqueueSpawnRequest($){let f=this.readQueue();f.requests.push({id:f.nextId,rootSessionId:$.rootSessionId,parentAgentId:$.parentAgentId,task:$.task,systemPrompt:$.systemPrompt,createdAt:dW()}),f.nextId+=1,this.writeQueue(f)}async claimSpawnRequest($,f){let J=this.readQueue(),W=J.requests.find((Z)=>Z.rootSessionId===$&&Z.parentAgentId===f&&!Z.consumedAt);if(!W)return;return W.consumedAt=dW(),this.writeQueue(J),W.task}}class lW extends K${constructor($,f={}){super(new EH($),f)}ensureSessionsDir(){return super.ensureSessionsDir()}}import{existsSync as A_,mkdirSync as V_}from"node:fs";import{resolveSessionDataDir as B_}from"@cline/shared/storage";var pW=`
|
|
468
468
|
session_id AS sessionId,
|
|
469
469
|
source,
|
|
470
470
|
pid,
|
|
@@ -491,43 +491,43 @@ ${Z}`,$.config.mode)}function B8($,f){return uL($,f==="plan"?"plan":f==="yolo"?"
|
|
|
491
491
|
metadata_json AS metadata,
|
|
492
492
|
hook_path AS hookPath,
|
|
493
493
|
messages_path AS messagesPath,
|
|
494
|
-
updated_at AS updatedAt`;function
|
|
494
|
+
updated_at AS updatedAt`;function rW($){$.interactive=$.interactive===1,$.enableTools=$.enableTools===1,$.enableSpawn=$.enableSpawn===1,$.enableTeams=$.enableTeams===1,$.isSubagent=$.isSubagent===1;let f=$.metadata;if(typeof f==="string"&&f.trim())try{let J=JSON.parse(f);$.metadata=J&&typeof J==="object"&&!Array.isArray(J)?J:null}catch{$.metadata=null}else $.metadata=null;return $}function iW($){if(!$||Object.keys($).length===0)return null;return JSON.stringify($)}function bH($){return{...$,tasks:$.tasks.map((f)=>({...f,createdAt:new Date(f.createdAt),updatedAt:new Date(f.updatedAt)})),mailbox:$.mailbox.map((f)=>({...f,sentAt:new Date(f.sentAt),readAt:f.readAt?new Date(f.readAt):void 0})),missionLog:$.missionLog.map((f)=>({...f,ts:new Date(f.ts)})),runs:($.runs??[]).map((f)=>({...f,startedAt:new Date(f.startedAt),endedAt:f.endedAt?new Date(f.endedAt):void 0,nextAttemptAt:f.nextAttemptAt?new Date(f.nextAttemptAt):void 0,heartbeatAt:f.heartbeatAt?new Date(f.heartbeatAt):void 0})),outcomes:($.outcomes??[]).map((f)=>({...f,createdAt:new Date(f.createdAt),finalizedAt:f.finalizedAt?new Date(f.finalizedAt):void 0})),outcomeFragments:($.outcomeFragments??[]).map((f)=>({...f,createdAt:new Date(f.createdAt),reviewedAt:f.reviewedAt?new Date(f.reviewedAt):void 0}))}}class kH{store;sessionsDirPath;constructor($,f=B_()){this.store=$;this.sessionsDirPath=f}ensureSessionsDir(){if(!A_(this.sessionsDirPath))V_(this.sessionsDirPath,{recursive:!0});return this.sessionsDirPath}async upsertSession($){this.store.run(`INSERT OR REPLACE INTO sessions (
|
|
495
495
|
session_id, source, pid, started_at, ended_at, exit_code, status, status_lock, interactive,
|
|
496
496
|
provider, model, cwd, workspace_root, team_name, enable_tools, enable_spawn, enable_teams,
|
|
497
497
|
parent_session_id, parent_agent_id, agent_id, conversation_id, is_subagent, prompt,
|
|
498
498
|
metadata_json, transcript_path, hook_path, messages_path, updated_at
|
|
499
|
-
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,[$.sessionId,$.source,$.pid,$.startedAt,$.endedAt??null,$.exitCode??null,$.status,$.statusLock,$.interactive?1:0,$.provider,$.model,$.cwd,$.workspaceRoot,$.teamName??null,$.enableTools?1:0,$.enableSpawn?1:0,$.enableTeams?1:0,$.parentSessionId??null,$.parentAgentId??null,$.agentId??null,$.conversationId??null,$.isSubagent?1:0,$.prompt??null,
|
|
499
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,[$.sessionId,$.source,$.pid,$.startedAt,$.endedAt??null,$.exitCode??null,$.status,$.statusLock,$.interactive?1:0,$.provider,$.model,$.cwd,$.workspaceRoot,$.teamName??null,$.enableTools?1:0,$.enableSpawn?1:0,$.enableTeams?1:0,$.parentSessionId??null,$.parentAgentId??null,$.agentId??null,$.conversationId??null,$.isSubagent?1:0,$.prompt??null,iW($.metadata),"",$.hookPath??"",$.messagesPath??null,$.updatedAt])}async getSession($){let f=this.store.queryOne(`SELECT ${pW} FROM sessions WHERE session_id = ?`,[$]);return f?rW(f):void 0}async listSessions($){let f=[],J=[];if($.parentSessionId)f.push("parent_session_id = ?"),J.push($.parentSessionId);if($.status)f.push("status = ?"),J.push($.status);let W=f.length>0?`WHERE ${f.join(" AND ")}`:"";return this.store.queryAll(`SELECT ${pW}
|
|
500
500
|
FROM sessions
|
|
501
|
-
${
|
|
501
|
+
${W}
|
|
502
502
|
ORDER BY started_at DESC
|
|
503
|
-
LIMIT ?`,[...J,$.limit]).map(
|
|
503
|
+
LIMIT ?`,[...J,$.limit]).map(rW)}async updateSession($){if($.setRunning){if($.expectedStatusLock===void 0)return{updated:!1,statusLock:0};return{updated:(this.store.run(`UPDATE sessions
|
|
504
504
|
SET status = 'running', ended_at = NULL, exit_code = NULL, updated_at = ?, status_lock = ?,
|
|
505
505
|
parent_session_id = ?, parent_agent_id = ?, agent_id = ?, conversation_id = ?, is_subagent = 1,
|
|
506
506
|
prompt = COALESCE(prompt, ?)
|
|
507
|
-
WHERE session_id = ? AND status_lock = ?`,[n(),$.expectedStatusLock+1,$.parentSessionId??null,$.parentAgentId??null,$.agentId??null,$.conversationId??null,$.prompt??null,$.sessionId,$.expectedStatusLock]).changes??0)>0,statusLock:$.expectedStatusLock+1}}let f=[],J=[];if($.status!==void 0)f.push("status = ?"),J.push($.status);if($.endedAt!==void 0)f.push("ended_at = ?"),J.push($.endedAt);if($.exitCode!==void 0)f.push("exit_code = ?"),J.push($.exitCode);if($.prompt!==void 0)f.push("prompt = ?"),J.push($.prompt??null);if($.metadata!==void 0)f.push("metadata_json = ?"),J.push(
|
|
507
|
+
WHERE session_id = ? AND status_lock = ?`,[n(),$.expectedStatusLock+1,$.parentSessionId??null,$.parentAgentId??null,$.agentId??null,$.conversationId??null,$.prompt??null,$.sessionId,$.expectedStatusLock]).changes??0)>0,statusLock:$.expectedStatusLock+1}}let f=[],J=[];if($.status!==void 0)f.push("status = ?"),J.push($.status);if($.endedAt!==void 0)f.push("ended_at = ?"),J.push($.endedAt);if($.exitCode!==void 0)f.push("exit_code = ?"),J.push($.exitCode);if($.prompt!==void 0)f.push("prompt = ?"),J.push($.prompt??null);if($.metadata!==void 0)f.push("metadata_json = ?"),J.push(iW($.metadata));if($.parentSessionId!==void 0)f.push("parent_session_id = ?"),J.push($.parentSessionId??null);if($.parentAgentId!==void 0)f.push("parent_agent_id = ?"),J.push($.parentAgentId??null);if($.agentId!==void 0)f.push("agent_id = ?"),J.push($.agentId??null);if($.conversationId!==void 0)f.push("conversation_id = ?"),J.push($.conversationId??null);if(f.length===0){let j=await this.getSession($.sessionId);return{updated:!!j,statusLock:j?.statusLock??0}}let W=0;if($.expectedStatusLock!==void 0)W=$.expectedStatusLock+1,f.push("status_lock = ?"),J.push(W);f.push("updated_at = ?"),J.push(n());let Z=`UPDATE sessions SET ${f.join(", ")} WHERE session_id = ?`;if(J.push($.sessionId),$.expectedStatusLock!==void 0)Z+=" AND status_lock = ?",J.push($.expectedStatusLock);if((this.store.run(Z,J).changes??0)===0)return{updated:!1,statusLock:0};if($.expectedStatusLock===void 0)W=(await this.getSession($.sessionId))?.statusLock??0;return{updated:!0,statusLock:W}}async deleteSession($,f){let J=this.store.run("DELETE FROM sessions WHERE session_id = ?",[$]).changes??0;if(f)this.store.run("DELETE FROM sessions WHERE parent_session_id = ?",[$]);return J>0}async enqueueSpawnRequest($){this.store.run(`INSERT INTO subagent_spawn_queue (root_session_id, parent_agent_id, task, system_prompt, created_at, consumed_at)
|
|
508
508
|
VALUES (?, ?, ?, ?, ?, NULL)`,[$.rootSessionId,$.parentAgentId,$.task??null,$.systemPrompt??null,n()])}async claimSpawnRequest($,f){let J=this.store.queryOne(`SELECT id, task FROM subagent_spawn_queue
|
|
509
509
|
WHERE root_session_id = ? AND parent_agent_id = ? AND consumed_at IS NULL
|
|
510
|
-
ORDER BY id ASC LIMIT 1`,[$,f]);if(!J||typeof J.id!=="number")return;return this.store.run("UPDATE subagent_spawn_queue SET consumed_at = ? WHERE id = ?",[n(),J.id]),J.task??void 0}}class
|
|
510
|
+
ORDER BY id ASC LIMIT 1`,[$,f]);if(!J||typeof J.id!=="number")return;return this.store.run("UPDATE subagent_spawn_queue SET consumed_at = ? WHERE id = ?",[n(),J.id]),J.task??void 0}}class d$ extends K${store;constructor($,f={}){super(new kH($,f.sessionArtifactsDir),f);this.store=$}createRootSession($){this.store.run(`INSERT OR REPLACE INTO sessions (
|
|
511
511
|
session_id, source, pid, started_at, ended_at, exit_code, status, status_lock, interactive,
|
|
512
512
|
provider, model, cwd, workspace_root, team_name, enable_tools, enable_spawn, enable_teams,
|
|
513
513
|
parent_session_id, parent_agent_id, agent_id, conversation_id, is_subagent, prompt,
|
|
514
514
|
metadata_json, transcript_path, hook_path, messages_path, updated_at
|
|
515
|
-
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,[$.sessionId,$.source,$.pid,$.startedAt,null,null,"running",0,$.interactive?1:0,$.provider,$.model,$.cwd,$.workspaceRoot,$.teamName??null,$.enableTools?1:0,$.enableSpawn?1:0,$.enableTeams?1:0,null,null,null,null,0,$.prompt??null,$.metadata?JSON.stringify($.metadata):null,"","",$.messagesPath,n()])}}import{readdirSync as
|
|
516
|
-
...[truncated ${$.length-f} chars]`}function
|
|
515
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,[$.sessionId,$.source,$.pid,$.startedAt,null,null,"running",0,$.interactive?1:0,$.provider,$.model,$.cwd,$.workspaceRoot,$.teamName??null,$.enableTools?1:0,$.enableSpawn?1:0,$.enableTeams?1:0,null,null,null,null,0,$.prompt??null,$.metadata?JSON.stringify($.metadata):null,"","",$.messagesPath,n()])}}import{readdirSync as pT}from"node:fs";import{homedir as rT}from"node:os";import{isAbsolute as iT,join as SZ,resolve as hZ}from"node:path";import{captureSdkError as C1,createSessionId as nT,isLikelyAuthError as aT,normalizeUserInput as tT}from"@cline/shared";import{setHomeDirIfUnset as sT}from"@cline/shared/storage";B0();import{createHandlerAsync as U_}from"@cline/llms";import{estimateTokens as nW}from"@cline/shared";var mH=200000,aW=0.9,gH=16384,tW=20000,IH=1024,xH=2000,vH=2000,uH=8;function l$($,f){if($.length<=f)return $;return`${$.slice(0,f)}
|
|
516
|
+
...[truncated ${$.length-f} chars]`}function K_($){let f=sW($);if(typeof f==="string")return f;return f.map((J)=>{switch(J.type){case"text":return J.text;case"file":return`<file path="${J.path}">
|
|
517
517
|
${J.content}
|
|
518
518
|
</file>`;case"image":return`[image:${J.mediaType}]`;default:return""}}).join(`
|
|
519
|
-
`)}function
|
|
520
|
-
`)}function
|
|
519
|
+
`)}function sW($){if(typeof $==="string")return l$($,xH);return $.map((f)=>{switch(f.type){case"text":return{...f,text:l$(f.text,xH)};case"file":return{...f,content:l$(f.content,vH)};case"image":return f;default:return f}})}function G_($){return Object.entries($).map(([f,J])=>`${f}=${JSON.stringify(J)}`).join(", ")}function cH($){if(typeof $.content==="string")return`[${$.role==="user"?"User":"Bot"}]: ${$.content}`;let f=[];for(let J of $.content)switch(J.type){case"text":f.push(`[${$.role==="user"?"User":"Bot"}]: ${J.text}`);break;case"thinking":f.push(`[Bot thinking]: ${l$(J.thinking,2000)}`);break;case"redacted_thinking":f.push("[Bot thinking]: [redacted]");break;case"tool_use":f.push(`[Bot tool calls]: ${J.name}(${G_(J.input)})`);break;case"tool_result":f.push(`[Tool result]: ${K_(J.content)}`);break;case"file":f.push(`[${$.role==="user"?"User":"Bot"} file ${J.path}]: ${l$(J.content,vH)}`);break;case"image":f.push(`[${$.role==="user"?"User":"Bot"} image]: ${J.mediaType}`);break}return f.join(`
|
|
520
|
+
`)}function dH($){return $.map(cH).join(`
|
|
521
521
|
|
|
522
|
-
`).trim()}function
|
|
523
|
-
`):"- none",J=$.modifiedFiles.length>0?$.modifiedFiles.map((
|
|
522
|
+
`).trim()}function lH(){let $=new WeakMap;return(f)=>{let J=f,W=$.get(J);if(typeof W==="number")return W;let Z;try{Z=JSON.stringify(f)}catch{Z=cH(f)}let Q=nW(Z.length);return $.set(J,Q),Q}}function E2($){return $.metadata?.kind==="compaction_summary"}function oW($){if(!E2($))return;let f=$.metadata;if(!f)return;let J=f.details;return{kind:"compaction_summary",summary:String(f.summary??""),details:{readFiles:Array.isArray(J?.readFiles)?J.readFiles.filter((W)=>typeof W==="string").map((W)=>W.trim()).filter((W)=>W.length>0):[],modifiedFiles:Array.isArray(J?.modifiedFiles)?J.modifiedFiles.filter((W)=>typeof W==="string").map((W)=>W.trim()).filter((W)=>W.length>0):[]},tokensBefore:Number(f.tokensBefore??0),generatedAt:Number(f.generatedAt??0)}}function P_($){if($.role!=="user"||!Array.isArray($.content))return!1;return $.content.length>0&&$.content.every((f)=>f.type==="tool_result")}function b2($){return $.role==="user"&&!P_($)&&!E2($)}function pH($){for(let f=0;f<$.length;f+=1)if(b2($[f]))return f;return-1}function vJ($){for(let f=$.length-1;f>=0;f-=1)if(b2($[f]))return f;return 0}function rH($){for(let f=$.length-1;f>=0;f-=1)if($[f].role==="assistant")return f;return-1}function iH($){for(let f=$.length-1;f>=0;f-=1)if(E2($[f]))return f;return-1}function nH($,f,J){let W=vJ($);if(W<=0)return 0;let Z=0,Q=$.length;for(let H=$.length-1;H>=0;H-=1)if(Z+=J($[H]),Q=H,Z>=f)break;if(Q<=0)return 0;let j=Math.min(Q,W);while(j>0&&!b2($[j]))j-=1;return j}function C2($){if(typeof $==="string"&&$.trim().length>0)return[$];if(Array.isArray($))return $.flatMap((f)=>C2(f));if($&&typeof $==="object"){let f=$,J=[];for(let W of["path","file_path","target_file","new_file_path","old_file_path"])J.push(...C2(f[W]));if(Array.isArray(f.files)){for(let W of f.files)if(W&&typeof W==="object")J.push(...C2(W.path))}if(Array.isArray(f.file_paths))J.push(...C2(f.file_paths));return J}return[]}function h2($,f){let J=new Set($);for(let W of f){let Z=W.trim();if(!Z)continue;J.add(Z)}return[...J].sort((W,Z)=>W.localeCompare(Z))}function aH($){let f=[],J=[];for(let W of $){let Z=oW(W);if(Z){f=h2(f,Z.details.readFiles),J=h2(J,Z.details.modifiedFiles);continue}if(!Array.isArray(W.content))continue;for(let Q of W.content){if(Q.type==="file"){f=h2(f,[Q.path]);continue}if(Q.type!=="tool_use")continue;let j=C2(Q.input);if(Q.name==="read_files"){f=h2(f,j);continue}if(Q.name==="editor"||Q.name==="apply_patch")J=h2(J,j)}}return{readFiles:f,modifiedFiles:J}}function F_($){let f=$.readFiles.length>0?$.readFiles.map((W)=>`- ${W}`).join(`
|
|
523
|
+
`):"- none",J=$.modifiedFiles.length>0?$.modifiedFiles.map((W)=>`- ${W}`).join(`
|
|
524
524
|
`):"- none";return`## Files
|
|
525
525
|
Read:
|
|
526
526
|
${f}
|
|
527
527
|
Modified:
|
|
528
|
-
${J}`}function
|
|
528
|
+
${J}`}function tH($,f){if(/^## Files$/im.test($))return $.trim();return`${$.trim()}
|
|
529
529
|
|
|
530
|
-
${
|
|
530
|
+
${F_(f)}`.trim()}function sH($){let f=[`Summarize this session for continuation. Be concise and factual.
|
|
531
531
|
|
|
532
532
|
## Goal
|
|
533
533
|
One sentence: what is being built or fixed.
|
|
@@ -549,18 +549,18 @@ Edited: ${$.fileOps.modifiedFiles.join(", ")||"none"}`];if($.previousSummary?.tr
|
|
|
549
549
|
${$.previousSummary.trim()}`);return f.push(`Conversation:
|
|
550
550
|
${$.conversationText||"(empty)"}`),f.join(`
|
|
551
551
|
|
|
552
|
-
`)}function
|
|
553
|
-
|
|
554
|
-
${$.summary}`,metadata:{kind:"compaction_summary",summary:$.summary,details:$.fileOps,tokensBefore:$.tokensBefore,generatedAt:Date.now()}}}async function JO($){let f=await fO($.providerConfig),J="";for await(let Q of f.createMessage("Summarize the provided coding session into a concise continuation note with detailed next steps.",[{role:"user",content:$.request}])){if(Q.type==="text"){J+=Q.text;continue}if(Q.type==="done"&&!Q.success&&Q.error)throw Error(Q.error)}return $.logger?.debug("Generated compaction summary",{outputChars:J.length,modelId:$.providerConfig.modelId,providerId:$.providerConfig.providerId}),J.trim()}function QO($){try{return JSON.stringify($).length}catch{return String($).length}}async function AX($){let f=$.context.messages;if(f.length<2)return;let J=WX(f,$.preserveRecentTokens,$.estimateMessageTokens);if(J<=0||J>=f.length)return;let Q=f.slice(0,J),Z=ZX(Q),W=Z>=0?N9(Q[Z])?.summary:void 0,j=Z>=0?Q.slice(Z+1):Q;if(j.length===0)return;let X=jX(Q),H=$X(j),Y=HX({previousSummary:W,conversationText:H,fileOps:X});$.logger?.debug("Agentic compaction summarizer diagnostics",{messagesToSummarize:Q.length,newMessagesToFold:j.length,preservedMessages:f.length-J,previousSummaryChars:W?.length??0,conversationTextChars:H.length,summaryRequestChars:Y.length,summaryRequestEstimatedTokens:L9(Y.length),newMessagesJsonChars:QO(j),maxInputTokens:$.context.maxInputTokens,triggerTokens:$.context.triggerTokens});let V=await JO({providerConfig:YX({activeProviderConfig:$.providerConfig,summarizer:$.summarizer}),request:Y,logger:$.logger});if(!V.trim())return;let A=XX(V,X),B=f.reduce((D,F)=>D+$.estimateMessageTokens(F),0),G=[VX({summary:A,fileOps:X,tokensBefore:B}),...f.slice(J)],K=G.reduce((D,F)=>D+$.estimateMessageTokens(F),0);return $.logger?.debug("Performed agentic compaction",{messagesBefore:f.length,messagesAfter:G.length,messagesSummarized:J,messagesPreserved:f.length-J,tokensBefore:B,tokensAfter:K,maxInputTokens:$.context.maxInputTokens}),{messages:G}}function KX($){if(F8($))return;if(typeof $.content==="string"){let J=$.content.trim();return J?{...$,content:J}:void 0}let f=$.content.filter((J)=>J.type!=="text"||J.text.trim());if(f.length===0)return;return{...$,content:f.map((J)=>J.type==="text"?{...J,text:J.text.trim()}:J.type==="tool_result"?{...J,content:_9(J.content)}:J)}}function U8($,f){return $.reduce((J,Q)=>J+f(Q),0)}function BX($,f){let J=Math.max(1,f),Q=Math.max(16,J*4);if(typeof $.content==="string"){let j=g$($.content,Q).trim();return{...$,content:j||"..."}}let Z=Q,W=$.content.map((j)=>{if(j.type!=="text"||Z<=0)return j;let X=g$(j.text,Z).trim();return Z-=X.length,{...j,text:X||"..."}});return{...$,content:W}}function ZO($,f){let J=JX($),Q=U6($),Z=QX($),W=[];for(let j=0;j<$.length;j+=1){let X=KX($[j]);if(!X)continue;W.push({index:j,message:X,estimatedTokens:f(X),isFirstUser:j===J,isLastUser:j===Q,isLastAssistant:j===Z})}return W}function GX($,f,J,Q){let Z=$[f];Z.message=J,Z.estimatedTokens=Q(J)}function WO($){let f=new Set;if(!Array.isArray($.content))return f;for(let J of $.content)if(J.type==="tool_use")f.add(J.id);return f}function jO($){let f=new Set;if(!Array.isArray($.content))return f;for(let J of $.content)if(J.type==="tool_result")f.add(J.tool_use_id);return f}function FX($){return new Set([...WO($.message),...jO($.message)])}function XO($){let f=new Map;for(let J=0;J<$.length;J+=1)for(let Q of FX($[J])){let Z=f.get(Q);if(Z)Z.add(J);else f.set(Q,new Set([J]))}return f}function HO($,f){let J=XO($),Q=new Set,Z=[f];while(Z.length>0){let W=Z.shift();if(W===void 0||Q.has(W))continue;Q.add(W);for(let j of FX($[W]))for(let X of J.get(j)??[])if(!Q.has(X))Z.push(X)}return Q}function D6($,f,J,Q){let Z=U8($.map((W)=>W.message),Q);for(let W=0;W<$.length&&Z>J;){if(!f($[W])){W+=1;continue}let j=HO($,W);Z-=Array.from(j).reduce((X,H)=>X+$[H].estimatedTokens,0);for(let X of Array.from(j).sort((H,Y)=>Y-H))$.splice(X,1)}}function YO($,f,J){let Q=U8($.map((W)=>W.message),J);if(Q<=f)return;for(let W=$.length-1;W>=0&&Q>f;W-=1){let j=$[W];if(j.isFirstUser)continue;let X=Math.max(oj,j.estimatedTokens-(Q-f));if(X>=j.estimatedTokens)continue;GX($,W,BX(j.message,X),J),Q=U8($.map((H)=>H.message),J)}if(Q<=f)return;let Z=$.findIndex((W)=>W.isFirstUser);if(Z>=0){let W=Math.max(1,$[Z].estimatedTokens-(Q-f));GX($,Z,BX($[Z].message,W),J)}}function VO($,f){return JSON.stringify($)!==JSON.stringify(f)}function AO($){let f=U6($);if(f<0||f===0&&!P8($[0]))return{compactable:$,protectedTail:[]};return{compactable:$.slice(0,f),protectedTail:$.slice(f)}}function PX($){let f=Math.max(1,Math.min($.context.triggerTokens,$.context.maxInputTokens)),{compactable:J,protectedTail:Q}=AO($.context.messages);if(J.length===0)return;let Z=ZO(J,$.estimateMessageTokens);if(Z.length===0)return;D6(Z,(H)=>H.message.role==="assistant"&&!H.isLastAssistant,f,$.estimateMessageTokens),D6(Z,(H)=>H.message.role==="user"&&!H.isFirstUser&&!H.isLastUser,f,$.estimateMessageTokens),D6(Z,(H)=>H.message.role==="assistant"&&H.isLastAssistant,f,$.estimateMessageTokens),D6(Z,(H)=>H.message.role==="user"&&H.isLastUser&&!H.isFirstUser,f,$.estimateMessageTokens),YO(Z,f,$.estimateMessageTokens);let W=[...Z.map((H)=>H.message),...Q];if(!VO($.context.messages,W))return;let j=U8([...J.map((H)=>KX(H)??H),...Q],$.estimateMessageTokens),X=U8(W,$.estimateMessageTokens);return $.logger?.debug("Performed basic compaction",{messagesBefore:$.context.messages.length,messagesAfter:W.length,messagesRemoved:$.context.messages.length-W.length,tokensBefore:j,tokensAfter:X,targetTokens:f,maxInputTokens:$.context.maxInputTokens}),{messages:W}}function UX($){try{return JSON.stringify($).length}catch{return String($).length}}function BO($){let f=0,J=0,Q=0;for(let Z of $){if(!Array.isArray(Z.content))continue;for(let W of Z.content){if(W.type!=="tool_result")continue;let j=UX(W.content);f+=1,J+=j,Q=Math.max(Q,j)}}return{toolResultCount:f,toolResultSerializedChars:J,maxToolResultSerializedChars:Q}}var GO={basic:({context:$,estimateMessageTokens:f,logger:J})=>PX({context:$,estimateMessageTokens:f,logger:J}),agentic:({context:$,providerConfig:f,compaction:J,mode:Q,estimateMessageTokens:Z,logger:W})=>AX({context:$,providerConfig:f,summarizer:J?.summarizer,preserveRecentTokens:Q==="manual"?Math.min(J?.preserveRecentTokens??z9,$.triggerTokens):J?.preserveRecentTokens??z9,estimateMessageTokens:Z,logger:W})};function KO($){if(typeof $.config.reserveTokens==="number"){let Q=Math.max(0,$.config.reserveTokens),Z=Math.max(0,$.maxInputTokens-Q);return{shouldCompact:$.inputTokens>Z,triggerTokens:Z,thresholdRatio:$.maxInputTokens>0?Z/$.maxInputTokens:0}}if(typeof $.config.thresholdRatio!=="number"){let Q=Math.max(0,Math.min($.maxInputTokens-tj,$.maxInputTokens*O9));return{shouldCompact:$.inputTokens>Q,triggerTokens:Q,thresholdRatio:$.maxInputTokens>0?Q/$.maxInputTokens:0}}let f=$.config.thresholdRatio??O9,J=$.maxInputTokens*f;return{shouldCompact:$.inputTokens>J,triggerTokens:J,thresholdRatio:f}}function FO($){let f=typeof $.manualTargetRatio==="number"&&Number.isFinite($.manualTargetRatio)?$.manualTargetRatio:0.5,J=Math.min(0.95,Math.max(0.05,f)),Q=Math.max(1,Math.floor(Math.min($.autoTriggerTokens,$.inputTokens*J)));return{triggerTokens:Q,thresholdRatio:$.maxInputTokens>0?Q/$.maxInputTokens:0}}function T9($,f={}){let J=$.compaction;if(J?.enabled!==!0)return;let Q=$.providerConfig??{providerId:$.providerId,modelId:$.modelId},Z=fX(),W=J?.strategy??"basic",j=GO[W],X=f.mode??"auto",H=J?.compact?"custom":W;return async(Y)=>{let V=Y.apiMessages.reduce((L,N)=>L+Z(N),0),A=J?.maxInputTokens??Y.model.info?.maxInputTokens??Y.model.info?.contextWindow??aj;if(typeof A!=="number"||!Number.isFinite(A)||A<=0)return;let B=KO({inputTokens:V,maxInputTokens:A,config:{reserveTokens:J?.reserveTokens,thresholdRatio:J?.thresholdRatio}});if($.logger?.debug("Context compaction diagnostics",{mode:X,strategy:W,iteration:Y.iteration,providerId:$.providerId,modelId:$.modelId,inputTokens:V,maxInputTokens:A,triggerTokens:B.triggerTokens,thresholdRatio:B.thresholdRatio,shouldCompact:B.shouldCompact,messageCount:Y.messages.length,apiMessageCount:Y.apiMessages.length,apiMessagesJsonChars:UX(Y.apiMessages),...BO(Y.apiMessages)}),X==="auto"&&!B.shouldCompact)return;let G=X==="manual"?FO({inputTokens:V,maxInputTokens:A,autoTriggerTokens:B.triggerTokens,manualTargetRatio:f.manualTargetRatio}):B,K={agentId:Y.agentId,conversationId:Y.conversationId,parentAgentId:Y.parentAgentId,iteration:Y.iteration,messages:Y.messages,model:Y.model,maxInputTokens:A,triggerTokens:G.triggerTokens,thresholdRatio:G.thresholdRatio,utilizationRatio:A>0?V/A:0},D=X==="manual"?"manual_compaction":"auto_compaction";Y.emitStatusNotice?.(X==="manual"?"compacting":"auto-compacting",{kind:D,reason:D,iteration:Y.iteration,triggerTokens:G.triggerTokens,maxInputTokens:A});let F=Y.messages.length,P=Date.now(),U=J?.compact?await J.compact(K):await j({context:K,providerConfig:{...Q,abortSignal:Y.abortSignal},compaction:J,mode:X,estimateMessageTokens:Z,logger:$.logger}),z=Date.now()-P,_=$.sessionId??Y.conversationId,R={agentId:Y.agentId,conversationId:Y.conversationId,parentAgentId:Y.parentAgentId??void 0};if(U?.messages){let L=U.messages.reduce((N,M)=>N+Z(M),0);$.logger?.log("Context compaction completed",{severity:"info",strategy:W,maxInputTokens:A,inputTokens:V,afterTokens:L,tokensSaved:V-L,utilizationBefore:`${(V/A*100).toFixed(1)}%`,utilizationAfter:`${(L/A*100).toFixed(1)}%`,thresholdTrigger:`${(G.thresholdRatio*100).toFixed(1)}%`,messagesBefore:F,messagesAfter:U.messages.length,messagesRemoved:F-U.messages.length}),Tf($.telemetry,{ulid:_,strategy:H,mode:X,messagesBefore:F,messagesAfter:U.messages.length,messagesRemoved:F-U.messages.length,tokensBefore:V,tokensAfter:L,tokensSaved:V-L,triggerTokens:G.triggerTokens,maxInputTokens:A,thresholdRatio:G.thresholdRatio,durationMs:z,provider:$.providerId,modelId:$.modelId,...R})}else Mf($.telemetry,{ulid:_,strategy:H,mode:X,reason:"no_result",tokensBefore:V,triggerTokens:G.triggerTokens,maxInputTokens:A,thresholdRatio:G.thresholdRatio,durationMs:z,provider:$.providerId,modelId:$.modelId,...R});return U}}G0();function B0(){return{inputTokens:0,outputTokens:0,cacheReadTokens:0,cacheWriteTokens:0,totalCost:0}}function H0($,f){return{inputTokens:$.inputTokens+Math.max(0,f.inputTokens??0),outputTokens:$.outputTokens+Math.max(0,f.outputTokens??0),cacheReadTokens:$.cacheReadTokens+Math.max(0,f.cacheReadTokens??0),cacheWriteTokens:$.cacheWriteTokens+Math.max(0,f.cacheWriteTokens??0),totalCost:$.totalCost+Math.max(0,f.totalCost??0)}}function R6($){let f=B0();for(let J of $)f=H0(f,J);return f}function f2($){return typeof $==="number"&&Number.isFinite($)?$:0}function L6($){let f=B0();for(let J of $){let Q=J.metrics;if(!Q)continue;f=H0(f,{inputTokens:f2(Q.inputTokens),outputTokens:f2(Q.outputTokens),cacheReadTokens:f2(Q.cacheReadTokens),cacheWriteTokens:f2(Q.cacheWriteTokens),totalCost:f2(Q.cost)})}return f}function PO($){for(let f=$.length-1;f>=0;f-=1){let J=$[f];if(J?.role!=="assistant")continue;let Q=f2(J.metrics?.inputTokens);return Q>0?Q:void 0}return}function UO($){if(!$||typeof $!=="object")return;let f=$,J=f.skill??f.skill_name??f.skillName;if(typeof J!=="string")return;let Q=J.trim();return Q.length>0?Q:void 0}function M9($){if(!$||typeof $!=="object")return{};let f=$;return{agentId:typeof f.agentId==="string"?f.agentId:void 0,conversationId:typeof f.conversationId==="string"?f.conversationId:void 0,parentAgentId:typeof f.parentAgentId==="string"?f.parentAgentId:void 0}}function V$($){let f=$.agentId?.trim();if(!f)return;let J=$.parentAgentId?.trim()||void 0,Q=$.teamRole,Z="root";if(Q==="teammate")Z="team_teammate";else if(Q==="lead")Z="team_lead";else if(J)Z="subagent";return{agentId:f,agentKind:Z,conversationId:$.conversationId?.trim()||void 0,parentAgentId:J,createdByAgentId:$.createdByAgentId?.trim()||J||void 0,isSubagent:Boolean(J),teamId:$.teamId?.trim()||void 0,teamName:$.teamName?.trim()||void 0,teamRole:Q,teamAgentId:$.teamAgentId?.trim()||void 0}}function DO($){return{inputTokens:$.inputTokens,outputTokens:$.outputTokens,cacheWriteTokens:$.cacheWriteTokens,cacheReadTokens:$.cacheReadTokens,totalCost:$.cost}}function RO($){let f=$.isPrimaryAgentEvent?[$.overrides?.agentId,$.eventMetadata.agentId,$.overrides?.teamAgentId]:[$.overrides?.teamAgentId,$.overrides?.agentId,$.eventMetadata.agentId,$.eventMetadata.conversationId];for(let J of f){let Q=J?.trim();if(Q)return Q}return $.isPrimaryAgentEvent?"root":"unknown"}function q9($,f,J){let{sessionId:Q,config:Z,liveSession:W,emit:j}=$,X=Z.telemetry,H=W?.runtime.teamRuntime,Y=J?.isPrimaryAgentEvent??!0,V=M9(f),A=V$({agentId:J?.agentId??V.agentId,conversationId:J?.conversationId??V.conversationId,parentAgentId:J?.parentAgentId??V.parentAgentId,createdByAgentId:J?.createdByAgentId,teamId:J?.teamId??H?.getTeamId(),teamName:J?.teamName??H?.getTeamName(),teamRole:J?.teamRole,teamAgentId:J?.teamAgentId});if(f.type==="content_start"&&f.contentType==="tool"&&f.toolName==="skills"){let B=UO(f.input);if(B)Df(X,{ulid:Q,skillName:B,skillSource:"project",skillsAvailableGlobal:0,skillsAvailableProject:0,provider:Z.providerId,modelId:Z.modelId,...A})}if(f.type==="content_end"&&f.contentType==="tool"){let B=f.toolName??"unknown",G=!f.error;if(Uf(X,{ulid:Q,tool:B,autoApproved:void 0,success:G,modelId:Z.modelId,provider:Z.providerId,...A}),!G&&(B==="editor"||B==="apply_patch"))Rf(X,{ulid:Q,modelId:Z.modelId,provider:Z.providerId,errorType:f.error,...A})}if(f.type==="notice"&&f.reason==="api_error")C8(X,{ulid:Q,model:Z.modelId,provider:Z.providerId,errorMessage:f.message,...A});if(f.type==="error")C8(X,{ulid:Q,model:Z.modelId,provider:Z.providerId,errorMessage:f.error?.message??"unknown error",...A});if(f.type==="usage"&&W?.turnUsageBaseline){let B=DO(f);if(Y){W.turnPrimaryUsage=H0(W.turnPrimaryUsage??B0(),B);let K=H0(W.turnUsageBaseline,W.turnPrimaryUsage);$.usageBySession.set(Q,K),A2(X,{ulid:Q,provider:Z.providerId,model:Z.modelId,source:"assistant",mode:Z.mode,...A}),Ff(X,{ulid:Q,tokensIn:f.inputTokens,tokensOut:f.outputTokens,cacheWriteTokens:f.cacheWriteTokens,cacheReadTokens:f.cacheReadTokens,totalCost:f.cost,model:Z.modelId,...A})}else{let K=RO({isPrimaryAgentEvent:Y,overrides:J,eventMetadata:V}),D=W.turnUsageByAgent??new Map;W.turnUsageByAgent=D,D.set(K,H0(D.get(K)??B0(),B))}let G=H0(W.turnPrimaryUsage??B0(),R6(W.turnUsageByAgent?.values()??[]));$.aggregateUsageBySession.set(Q,H0(W.turnAggregateUsageBaseline??W.turnUsageBaseline,G))}if(f.type==="iteration_end"&&Y)$.persistMessages(Q,W?.agent.getMessages()??[],W?.config.systemPrompt);j({type:"agent_event",payload:{sessionId:Q,event:f,teamAgentId:J?.teamAgentId,teamRole:J!==void 0?J.teamRole??(Y?"lead":void 0):void 0}}),j({type:"chunk",payload:{sessionId:Q,stream:"agent",chunk:mW(f),ts:Date.now()}})}function v$($){return $.workspaceRoot??$.cwd}import{hasRuntimeConfigExtension as iO}from"@cline/shared";import{spawn as yO}from"node:child_process";import{appendFileSync as wO,readFileSync as SO}from"node:fs";import{join as hO}from"node:path";import{augmentNodeCommandForDebug as OX,withResolvedClineBuildEnv as E9}from"@cline/shared";import{ensureHookLogDir as RX}from"@cline/shared/storage";function O6($,f){if(!f)return;return{name:$,manifest:{capabilities:["hooks"]},hooks:f}}import{existsSync as LO,readdirSync as OO}from"node:fs";import{basename as zO,extname as _O,join as NO}from"node:path";import{HOOKS_CONFIG_DIRECTORY_NAME as DX,resolveHooksConfigSearchPaths as TO}from"@cline/shared/storage";function y9($){return TO($)}var z6;((V)=>{V.TaskStart="TaskStart";V.TaskResume="TaskResume";V.TaskCancel="TaskCancel";V.TaskComplete="TaskComplete";V.TaskError="TaskError";V.PreToolUse="PreToolUse";V.PostToolUse="PostToolUse";V.UserPromptSubmit="UserPromptSubmit";V.PreCompact="PreCompact";V.SessionShutdown="SessionShutdown"})(z6||={});var w9={["TaskStart"]:"agent_start",["TaskResume"]:"agent_resume",["TaskCancel"]:"agent_abort",["TaskComplete"]:"agent_end",["TaskError"]:"agent_error",["PreToolUse"]:"tool_call",["PostToolUse"]:"tool_result",["UserPromptSubmit"]:"prompt_submit",["PreCompact"]:void 0,["SessionShutdown"]:"session_shutdown"},MO=new Map(Object.values(z6).map(($)=>[$.toLowerCase(),$])),qO=new Set(["",".sh",".bash",".zsh",".js",".mjs",".cjs",".ts",".mts",".cts",".py",".ps1"]);function S9($){let f=_O($).toLowerCase();if(!qO.has(f))return;let J=zO($,f).trim().toLowerCase();return MO.get(J)}function J2($){let f=[],J=new Set,Q=y9($).filter((Z)=>LO(Z));for(let Z of Q)try{for(let W of OO(Z,{withFileTypes:!0})){if(!W.isFile())continue;let j=S9(W.name);if(!j)continue;let X=NO(Z,W.name);if(J.has(X))continue;J.add(X),f.push({fileName:j,hookEventName:w9[j],path:X})}}catch{}return f.sort((Z,W)=>Z.path.localeCompare(W.path))}function N6($){if(!$||typeof $!=="object")return{};let f={};for(let[J,Q]of Object.entries($))f[J]=typeof Q==="string"?Q:JSON.stringify(Q);return f}function _6($,f,J){let Q=J instanceof Error?`: ${J.message}`:"",Z=`${f}${Q}`;if($){try{$.log(Z,{severity:"warn",...J!==void 0?{error:J}:{}})}catch{}return}console.warn(Z)}function CO($,f){if(!f)return $;if(!$)return{...f};let J=[$.context,f.context].filter((Z)=>typeof Z==="string"&&Z.length>0).join(`
|
|
555
|
-
`),
|
|
556
|
-
`).map((
|
|
557
|
-
`,j=(process.env.CLINE_HOOKS_LOG_PATH?.trim()||void 0)??hO(RX(),"hooks.jsonl");RX(j),wO(j,Z,"utf8")};return{beforeRun:async(Q)=>{let Z=C9(Q,"");J({...Y0(Z,f),hookName:"agent_start",taskStart:{taskMetadata:{}}});return},beforeTool:async(Q)=>{let Z=NX(Q);J({...Y0(Z,f),hookName:"tool_call",iteration:Z.iteration,tool_call:{id:Z.call.id,name:Z.call.name,input:Z.call.input},preToolUse:{toolName:Z.call.name,parameters:N6(Z.call.input)}});return},afterTool:async(Q)=>{let Z=TX(Q);J({...Y0(Z,f),hookName:"tool_result",iteration:Z.iteration,tool_result:Z.record,postToolUse:{toolName:Z.record.name,parameters:N6(Z.record.input),result:typeof Z.record.output==="string"?Z.record.output:JSON.stringify(Z.record.output),success:!Z.record.error,executionTimeMs:Z.record.durationMs}});return},afterRun:async({snapshot:Q,result:Z})=>{let W=u$(Q);if(Z.status==="completed"){J({...Y0(W,f),hookName:"agent_end",iteration:Z.iterations,turn:{outputText:Z.outputText,status:Z.status},taskComplete:{taskMetadata:{}}});return}if(Z.status==="aborted"||h9(Z.error?.message)){J({...Y0(W,f),hookName:"agent_abort",reason:Z.error?.message,taskCancel:{taskMetadata:{}}});return}if(Z.error)J({...Y0(W,f),hookName:"agent_error",iteration:Z.iterations,error:{name:Z.error.name,message:Z.error.message,stack:Z.error.stack}})},onEvent:async(Q)=>{if(Q.type!=="message-added"||Q.message.role!=="user")return;let Z=C9({snapshot:Q.snapshot},MX(Q.message.content));J({...Y0(Z,f),hookName:"prompt_submit",userPromptSubmit:{prompt:Z.userMessage,attachments:[]}})}}}function b9($){let f=vO($.workspacePath);if(!Object.values(f).some((A)=>A.length>0))return;let Q=async(A,B)=>{let G=f[B]??[];if(G.length===0)return;R1({commands:G,cwd:$.cwd,logger:$.logger,payload:B==="agent_resume"?{...Y0(A,$),hookName:B,taskResume:{taskMetadata:{},previousState:{}}}:{...Y0(A,$),hookName:B,taskStart:{taskMetadata:{}}}})},Z=async(A)=>{let B=f.prompt_submit??[];if(B.length>0)R1({commands:B,cwd:$.cwd,logger:$.logger,payload:{...Y0(A,$),hookName:"prompt_submit",userPromptSubmit:{prompt:A.userMessage,attachments:[]}}})},W=async(A)=>{let B=f.tool_call??[];if(B.length===0)return;return uO({commands:B,cwd:$.cwd,logger:$.logger,timeoutMs:$.toolCallTimeoutMs??120000,payload:{...Y0(A,$),hookName:"tool_call",iteration:A.iteration,tool_call:{id:A.call.id,name:A.call.name,input:A.call.input},preToolUse:{toolName:A.call.name,parameters:N6(A.call.input)}}})},j=async(A)=>{let B=f.tool_result??[];if(B.length===0)return;R1({commands:B,cwd:$.cwd,logger:$.logger,payload:{...Y0(A,$),hookName:"tool_result",iteration:A.iteration,tool_result:A.record,postToolUse:{toolName:A.record.name,parameters:N6(A.record.input),result:typeof A.record.output==="string"?A.record.output:JSON.stringify(A.record.output),success:!A.record.error,executionTimeMs:A.record.durationMs}}})},X=async(A)=>{let B=f.agent_end??[];if(B.length===0)return;R1({commands:B,cwd:$.cwd,logger:$.logger,payload:{...Y0(A,$),hookName:"agent_end",iteration:A.iteration,turn:A.turn,taskComplete:{taskMetadata:{}}}})},H=async(A)=>{let B=f.agent_error??[];if(B.length===0)return;R1({commands:B,cwd:$.cwd,logger:$.logger,payload:{...Y0(A,$),hookName:"agent_error",iteration:A.iteration,error:{name:A.error.name,message:A.error.message,stack:A.error.stack}}})},Y=async(A)=>{if(h9(A.reason)){let G=f.agent_abort??[];if(G.length>0)R1({commands:G,cwd:$.cwd,logger:$.logger,payload:{...Y0(A,$),hookName:"agent_abort",reason:A.reason,taskCancel:{taskMetadata:{}}}})}let B=f.session_shutdown??[];if(B.length===0)return;R1({commands:B,cwd:$.cwd,logger:$.logger,payload:{...Y0(A,$),hookName:"session_shutdown",reason:A.reason}})},V={};if((f.agent_start?.length??0)>0||(f.agent_resume?.length??0)>0||(f.prompt_submit?.length??0)>0){if((f.agent_start?.length??0)>0||(f.agent_resume?.length??0)>0)V.beforeRun=async(A)=>{let B=process.env.CLINE_HOOK_AGENT_RESUME==="1"?"agent_resume":"agent_start";await Q(u$(A.snapshot),B);return};if((f.prompt_submit?.length??0)>0)V.onEvent=async(A)=>{if(A.type!=="message-added"||A.message.role!=="user")return;await Z(C9({snapshot:A.snapshot},MX(A.message.content)))}}if((f.tool_call?.length??0)>0)V.beforeTool=async(A)=>{let B=await W(NX(A));return cO(B)};if((f.tool_result?.length??0)>0)V.afterTool=async(A)=>{await j(TX(A));return};if((f.agent_end?.length??0)>0)V.afterRun=async({snapshot:A,result:B})=>{if(B.status!=="completed")return;await X({...u$(A),iteration:B.iterations,turn:{outputText:B.outputText,status:B.status}})};if((f.agent_error?.length??0)>0||(f.agent_abort?.length??0)>0||(f.session_shutdown?.length??0)>0){let A=V.afterRun;V.afterRun=async(B)=>{await A?.(B);let{snapshot:G,result:K}=B;if(K.status==="aborted"||h9(K.error?.message)){await Y({...u$(G),reason:K.error?.message});return}if(K.error)await H({...u$(G),iteration:K.iterations,error:K.error})}}return V}function M6($){return O6("core.hook_config_files",b9($))}function L1($,f){let J=$.map((Q)=>Q[f]).filter((Q)=>typeof Q==="function");if(J.length===0)return;return async(Q)=>{let Z;for(let W of J){let j=await W(Q);if(!j||typeof j!=="object")continue;let X=j;Z={...Z??{},...X,stop:Z?.stop===!0||X.stop===!0?!0:X.stop,options:Z?.options||X.options?{...Z?.options??{},...X.options??{}}:void 0}}return Z}}function D8($){let f=$.filter((J)=>J!==void 0);if(f.length===0)return;return{beforeRun:L1(f,"beforeRun"),afterRun:L1(f,"afterRun"),beforeModel:L1(f,"beforeModel"),afterModel:L1(f,"afterModel"),beforeTool:L1(f,"beforeTool"),afterTool:L1(f,"afterTool"),onEvent:L1(f,"onEvent")}}import{z as c$}from"zod";var q6=b1;var qX=c$.object({settings:b1,updatedAt:c$.string().datetime(),tokenSource:c$.enum(["manual","oauth","migration"]).default("manual")}),y6=c$.object({version:c$.literal(1),lastUsedProvider:c$.string().min(1).optional(),providers:c$.record(c$.string(),qX)});function Q2(){return{version:1,providers:{}}}Z$();import{upsertWorkspaceInfo as dO,WorkspaceManifestSchema as k9}from"@cline/shared";class w6{manifest;listeners=new Set;constructor($){this.manifest=k9.parse($??{workspaces:{}})}async addWorkspacePath($){let f=await s4($);return this.manifest=dO(this.manifest,f),this.emit({type:"workspace_added",workspace:f}),f}async switchWorkspace($){let f=Y1($),J=this.manifest.workspaces[f];if(J)return this.manifest=k9.parse({...this.manifest,currentWorkspacePath:f}),this.emit({type:"workspace_switched",workspace:J}),J;let Q=await this.addWorkspacePath(f);return this.manifest=k9.parse({...this.manifest,currentWorkspacePath:Q.rootPath}),this.emit({type:"workspace_switched",workspace:Q}),Q}subscribe($){return this.listeners.add($),()=>{this.listeners.delete($)}}getCurrentWorkspace(){let $=this.manifest.currentWorkspacePath;if(!$)return;return this.manifest.workspaces[$]}getWorkspace($){let f=Y1($);return this.manifest.workspaces[f]}listWorkspaces(){return Object.values(this.manifest.workspaces)}getManifest(){return this.manifest}emit($){for(let f of this.listeners)f($)}}G0();import{createHash as lO}from"node:crypto";var yX=new Set,wX=new Set;function pO($){return lO("sha256").update($).digest("hex")}function rO($){if($.vcsTypes&&$.vcsTypes.length>0)return $.vcsTypes;return[$.vcsType==="git"?"git":"none"]}function SX($){if(!$.telemetry)return;let f=pO($.rootPath),J=$.rootCount??1;if(!yX.has(f))yX.add(f),Af($.telemetry,{root_count:J,vcs_types:rO($),init_duration_ms:$.durationMs,feature_flag_enabled:$.featureFlagEnabled??!0,is_remote_workspace:$.isRemoteWorkspace});if($.initError&&!wX.has(f)){wX.add(f);let Q=Error($.initError.message);Q.name=$.initError.errorType||"Error",Bf($.telemetry,Q,{fallback_to_single_root:!0,workspace_count:J})}}function nO($){return`${$.pluginName??$.pluginPath}: ${$.message}`}function aO($,f,J){if(f.length>0)for(let W of f)J?.log(W.message,{severity:"warn"});if($.length===0)return;let Q=$.slice(0,3).map(nO).join("; "),Z=$.length>3?`; and ${$.length-3} more`:"";J?.log(`Some plugins failed to initialize. ${Q}${Z}. Use --verbose for more details.`,{severity:"warn"});for(let W of $)J?.log(`Plugin initialization failed (${W.phase}) for ${W.pluginPath}`,{severity:"warn",stack:W.stack,pluginPath:W.pluginPath,pluginName:W.pluginName})}function tO($,f){let J=typeof $.thinking==="boolean",Q=typeof $.reasoningEffort==="string";if(!J&&!Q)return f;return{...f??{},...J?{enabled:$.thinking}:{},...Q?{effort:$.reasoningEffort}:{}}}function sO($,f){return iO($,f)}function oO($){let f=0;for(let J of $??[]){if(J.role!=="user")continue;if(("metadata"in J&&J.metadata&&typeof J.metadata==="object"&&!Array.isArray(J.metadata)?J.metadata:void 0)?.kind==="recovery_notice")continue;f+=1}return f}function eO($){let f={...$.storedHeaders??{},...$.configHeaders??{}},J=$.accountId?.trim()||$z($.accessToken);if(f.originator="cline",f.session_id=$.sessionId,f["User-Agent"]=`Cline/${process.env.npm_package_version||"1.0.0"}`,J)f["ChatGPT-Account-Id"]=J;return f}function $z($){let f=$?.trim();if(!f)return;let J=K0(f),Q=J?.["https://api.openai.com/auth"]?.chatgpt_account_id;if(typeof Q==="string"&&Q.length>0)return Q;let Z=J?.organizations?.[0]?.id;if(typeof Z==="string"&&Z.length>0)return Z;let W=J?.chatgpt_account_id;if(typeof W==="string"&&W.length>0)return W;return}function fz($,f,J,Q,Z){let W=J.getProviderSettings($.providerId),j=Q||W?.modelCatalog?{...Q??{},...W?.modelCatalog??{}}:void 0,X={...W??{},provider:$.providerId,model:$.modelId,apiKey:$.apiKey??W?.apiKey,baseUrl:$.baseUrl??W?.baseUrl,headers:$.providerId==="openai-codex"?eO({sessionId:f,configHeaders:$.headers,storedHeaders:W?.headers,accountId:W?.auth?.accountId,accessToken:$.apiKey??W?.auth?.accessToken??W?.apiKey}):$.headers??W?.headers,reasoning:tO($,W?.reasoning),modelCatalog:j},H=$$(X);if($.knownModels)H.knownModels=$.knownModels;if($.extensionContext)H.extensionContext=$.extensionContext;let V=$.fetch??H.fetch??Z;if(V)H.fetch=V;return H}async function hX($){let{input:f,sessionId:J,providerSettingsManager:Q,defaultTelemetry:Z,defaultCapabilities:W,defaultToolPolicies:j,defaultFetch:X,onPluginEvent:H,onTeamEvent:Y,createSpawnTool:V,localRuntime:A,readSessionMetadata:B,writeSessionMetadata:G}=$,K=v$(f.config),{modelCatalogDefaults:D,userInstructionService:F,configExtensions:P,onTeamRestored:U,...z}=A??{},_=Object.keys(z).length>0?z:void 0,{workspaceInfo:R,workspaceMetadata:L,durationMs:N,vcsType:M,initError:o}=await LW(K),e=_?.extensionContext,a={...e??{},workspace:{...R,...e?.workspace??{}},session:{...e?.session??{},sessionId:J},logger:e?.logger??_?.logger,telemetry:e?.telemetry??_?.telemetry??Z};SX({telemetry:a.telemetry,rootPath:R.rootPath,workspaceInfo:R,rootCount:1,vcsType:M,durationMs:N,initError:o,featureFlagEnabled:!0});let v=M6({cwd:f.config.cwd,workspacePath:K,rootSessionId:J,logger:_?.logger,workspaceInfo:R}),V0=xW(_?.hooks)?void 0:T6({rootSessionId:J,workspacePath:K,workspaceInfo:R}),B$=D8([_?.hooks,V0]),u;if(sO(P,"plugins"))try{u=await r4({pluginPaths:_?.pluginPaths,workspacePath:K,cwd:f.config.cwd,onEvent:H,providerId:f.config.providerId,modelId:f.config.modelId,workspaceInfo:R,session:a.session,client:a.client,user:a.user,logger:a.logger,telemetry:a.telemetry,automation:a.automation}),aO(u.failures,u.warnings,_?.logger)}catch(V2){let p=V2 instanceof Error?V2.message:String(V2);_?.logger?.log?.(`plugin loading failed; continuing without plugins (${p})`)}let h=E5(v?[v]:void 0,E5(_?.extensions,iJ(u?.extensions))),l={...f.config,..._??{},sessionId:J,hooks:B$,extensions:h,extensionContext:a,telemetry:a.telemetry},M0=fz(l,J,Q,D,X),L0=D8([l.hooks,l.checkpoint?.enabled===!0?hj({cwd:l.cwd,sessionId:J,logger:l.logger,createCheckpoint:l.checkpoint?.createCheckpoint,initialRunCount:oO(f.initialMessages),readSessionMetadata:B,writeSessionMetadata:G}):void 0]),r$={...l,providerConfig:M0,workspaceMetadata:L,hooks:L0},y1=f.toolPolicies??l.toolPolicies??j,Y2=P0(W,f.capabilities),w8=Y2?.requestToolApproval,Wf=Y2?.toolExecutors,w1=new w6({currentWorkspacePath:R.rootPath,workspaces:{[R.rootPath]:R}});return{effectiveInput:f,config:r$,providerConfig:M0,workspaceMetadata:L,workspaceInfo:R,extensions:h,hooks:L0,toolPolicies:y1,requestToolApproval:w8,pluginSandboxShutdown:u?.shutdown,runtimeBuilderInput:{config:r$,hooks:L0,extensions:h,onTeamEvent:Y,createSpawnTool:V,onTeamRestored:U,userInstructionService:F,configExtensions:P,toolExecutors:Wf,workspaceManager:w1,logger:r$.logger,telemetry:r$.telemetry}}}import{resolveDocumentsExtensionPath as Jz}from"@cline/shared/storage";G0();function CX($,f,J,Q,Z){if(J)Kf($.telemetry,{ulid:f,apiProvider:$.providerId,...Z});else Gf($.telemetry,{ulid:f,apiProvider:$.providerId,...Z});Qz($.telemetry,{workspacePath:Q})}function Qz($,f){let J=Jz("Hooks"),Q=J2(f.workspacePath),Z=new Map;for(let W of Q){let j=W.hookEventName??"unknown",X=Z.get(j)??{global:0,workspace:0};if(W.path===J||W.path.startsWith(`${J}/`))X.global+=1;else X.workspace+=1;Z.set(j,X)}for(let[W,j]of Z.entries())Nf($,W,j.global,j.workspace)}function EX($,f){for(let J of f.mentions)zf($,J,f.matchedFiles.includes(J)?1:0,"file",!f.matchedFiles.includes(J));for(let J of f.matchedFiles)Lf($,"file",J.length);for(let J of f.ignoredMentions)Of($,"file","not_found",J)}import{chmodSync as tX,existsSync as u9,mkdirSync as xz,readFileSync as mz,writeFileSync as gz}from"node:fs";import{basename as sX,dirname as c9}from"node:path";import{resolveProviderSettingsPath as vz}from"@cline/shared/storage";import{existsSync as Zz,mkdirSync as Wz,readFileSync as jz,writeFileSync as Xz}from"node:fs";import{mkdir as Hz,readFile as Yz,writeFile as Vz}from"node:fs/promises";import{dirname as I9,join as Az}from"node:path";import*as N0 from"@cline/llms";import{ModelCapabilitySchema as Bz,ProviderCapabilitySchema as Gz,ProviderClientSchema as Kz,ProviderProtocolSchema as Fz}from"@cline/shared";import{z as d}from"zod";var Pz=d.object({id:d.string().optional(),name:d.string().optional(),maxTokens:d.number().optional(),contextWindow:d.number().optional(),maxInputTokens:d.number().optional(),capabilities:d.array(Bz).optional(),supportsVision:d.boolean().optional(),supportsAttachments:d.boolean().optional(),supportsReasoning:d.boolean().optional()}).passthrough(),Uz=d.object({name:d.string(),baseUrl:d.string(),defaultModelId:d.string().optional(),protocol:Fz.optional(),client:Kz.optional(),capabilities:d.array(Gz).optional(),modelsSourceUrl:d.string().optional()}).passthrough(),bX=d.object({provider:Uz.optional(),models:d.record(d.string(),Pz).optional()}).passthrough(),kX=d.object({version:d.literal(1),providers:d.record(d.string(),bX)}),Dz=d.object({version:d.literal(1),providers:d.record(d.string(),d.unknown())}),S6=new Set;function IX($){return $.split(/[-_]/).filter(Boolean).map((f)=>f.charAt(0).toUpperCase()+f.slice(1)).join(" ")}function O1($){return Az(I9($.getFilePath()),"models.json")}function h6(){return{version:1,providers:{}}}function xX($){let f=Dz.safeParse($);if(!f.success)return h6();let J={};for(let[Q,Z]of Object.entries(f.data.providers)){let W=bX.safeParse(Z);if(W.success)J[Q]=W.data}return{version:1,providers:J}}function x9($){if(!Zz($))return h6();try{let f=jz($,"utf8");return xX(JSON.parse(f))}catch{}return h6()}async function Z2($){try{let f=await Yz($,"utf8");return xX(JSON.parse(f))}catch{}return h6()}function mX($,f){Wz(I9($),{recursive:!0});let J=kX.parse(f);Xz($,`${JSON.stringify(J,null,2)}
|
|
558
|
-
`,"utf8")}async function
|
|
559
|
-
`,"utf8")}function gX($,f){return{id:$,name:f.name??$,supportsAttachments:f.capabilities?.includes("files"),supportsVision:f.capabilities?.includes("images"),supportsReasoning:f.capabilities?.includes("reasoning")||f.thinkingConfig!=null}}function vX($){if(!$||$.length===0)return;let f=new Set;if($.includes("reasoning"))f.add("reasoning");if($.includes("prompt-cache"))f.add("prompt-cache");if($.includes("tools"))f.add("tools");return f.size>0?[...f]:void 0}function uX($){let f=new Set;if(!$||$.length===0)return[...f];if($.includes("streaming"))f.add("streaming");if($.includes("tools"))f.add("tools");if($.includes("reasoning"))f.add("reasoning");if($.includes("prompt-cache"))f.add("prompt-cache");if($.includes("vision"))f.add("images"),f.add("files");return[...f]}function Rz($){return $!=null&&typeof $.name==="string"&&typeof $.baseUrl==="string"}function cX($,f){return $??f??"openai-chat"}function dX($,f,J){return $??J??(f==="openai-responses"?"openai":"openai-compatible")}function lX($,f,J){let Q=new Set(f?.capabilities??J??[]);if(f?.supportsVision)Q.add("images");if(f?.supportsAttachments)Q.add("files");if(f?.supportsReasoning)Q.add("reasoning");return{id:$,name:f?.name??$,maxTokens:f?.maxTokens,contextWindow:f?.contextWindow,maxInputTokens:f?.maxInputTokens,capabilities:Q.size>0?[...Q]:void 0}}function Lz($,f){for(let[J,Q]of Object.entries(f??{})){let Z=Q.id?.trim()||J.trim();if(!Z)continue;N0.registerModel($,Z,lX(Z,Q))}}function Oz($,f,J){return{...f??{},id:$,name:f?.name??$,capabilities:f?.capabilities??J}}function zz($){return Object.assign({},...N0.resolveProviderModelCatalogKeys($).map((J)=>N0.getGeneratedModelsForProvider(J)))}function _z($){let f=$.provider.trim();if(!f||N0.isBuiltInProviderId(f))return;let J=$.baseUrl?.trim();if(!J)return;let Q=N0.MODEL_COLLECTIONS_BY_PROVIDER_ID[f],Z=zz(f),W=uX($.capabilities),j=W.length>0?W:void 0,X=$.model?.trim(),H={...Z,...Q?.models??{}};if(X)H[X]=Oz(X,H[X],j);let Y=Object.keys(H).filter(Boolean),V=X||Y[0];if(!V)return;let A=cX($.protocol,Q?.provider.protocol),B=dX($.client,A,Q?.provider.client);N0.registerProvider({provider:{id:f,name:Q?.provider.name??IX(f),description:Q?.provider.description,protocol:A,client:B,baseUrl:J,modelsSourceUrl:Q?.provider.modelsSourceUrl,defaultModelId:V,capabilities:vX($.capabilities)??Q?.provider.capabilities,source:"file"},models:H})}function E6($){for(let f of Object.values($.providers))_z(f.settings)}function R8($,f){let J=f.models??{};if(!Rz(f.provider)){Lz($,J);return}let Q=uX(f.provider.capabilities),Z=Object.entries(J).map(([Y,V])=>({id:V.id?.trim()||Y.trim(),model:V})).filter(({id:Y})=>Y.length>0),W=f.provider.defaultModelId?.trim()||Z[0]?.id||"default",j=cX(f.provider.protocol,void 0),X=dX(f.provider.client,j,void 0),H=Object.fromEntries(Z.map(({id:Y,model:V})=>[Y,{...lX(Y,V,Q.length>0?Q:void 0),status:"active"}]));N0.registerProvider({provider:{id:$,name:f.provider.name.trim()||IX($),protocol:j,client:X,baseUrl:f.provider.baseUrl,modelsSourceUrl:f.provider.modelsSourceUrl,defaultModelId:W,capabilities:vX(f.provider.capabilities),source:"file"},models:H})}function pX($){let f=O1($);if(S6.has(f))return;let J=x9(f);for(let[Q,Z]of Object.entries(J.providers))R8(Q,Z);S6.add(f)}async function rX($){let f=O1($);if(S6.has(f))return;let J=await Z2(f);for(let[Q,Z]of Object.entries(J.providers))R8(Q,Z);S6.add(f)}import{existsSync as Nz,readFileSync as Tz}from"node:fs";import{dirname as Mz,join as m9}from"node:path";import*as k6 from"@cline/llms";import{resolveClineDataDir as qz}from"@cline/shared/storage";var b6="openai",aX=k6.BUILT_IN_PROVIDER.OPENAI_COMPATIBLE,iX=128000;function yz($){let f=$?.trim();if(!f)return;try{let J=JSON.parse(f);if(!J)return;return{accessToken:J.idToken,refreshToken:J.refreshToken,expiresAt:J.expiresAt,accountId:J.userInfo?.id}}catch{return}}function C($){let f=$?.trim();return f?f:void 0}function nX($){if(!Nz($))return;try{let f=Tz($,"utf8"),J=JSON.parse(f);if(J&&typeof J==="object"&&!Array.isArray(J))return J}catch{}return}function wz($){let f=$.dataDir??qz(),J=$.globalStatePath??m9(f,"globalState.json"),Q=$.secretsPath??m9(f,"secrets.json"),Z=nX(J),W=nX(Q);if(!Z&&!W)return;return{globalState:Z??{},secrets:W??{}}}function g9($){if($===b6)return aX;return $}function Sz($,f,J,Q){let Z=J==="plan"?"planMode":"actMode",W=f===Q?C(J==="plan"?$.planModeApiModelId:$.actModeApiModelId):void 0,X={openrouter:`${Z}OpenRouterModelId`,cline:`${Z}ClineModelId`,openai:`${Z}OpenAiModelId`,ollama:`${Z}OllamaModelId`,lmstudio:`${Z}LmStudioModelId`,litellm:`${Z}LiteLlmModelId`,requesty:`${Z}RequestyModelId`,together:`${Z}TogetherModelId`,fireworks:`${Z}FireworksModelId`,sapaicore:`${Z}SapAiCoreModelId`,groq:`${Z}GroqModelId`,baseten:`${Z}BasetenModelId`,huggingface:`${Z}HuggingFaceModelId`,"huawei-cloud-maas":`${Z}HuaweiCloudMaasModelId`,oca:`${Z}OcaModelId`,aihubmix:`${Z}AihubmixModelId`,hicap:`${Z}HicapModelId`,nousResearch:`${Z}NousResearchModelId`,"vercel-ai-gateway":`${Z}VercelAiGatewayModelId`}[f];return(X?C(typeof $[X]==="string"?$[X]:void 0):void 0)??W}function hz($,f,J){let Q=J==="plan"?$.planModeReasoningEffort:$.actModeReasoningEffort,Z=J==="plan"?$.geminiPlanModeThinkingLevel:$.geminiActModeThinkingLevel,W=J==="plan"?$.planModeThinkingBudgetTokens:$.actModeThinkingBudgetTokens,j=(f==="gemini"?Z:void 0)??Q,X=j==="none"||j==="low"||j==="medium"||j==="high"?j:void 0,H=typeof W==="number"&&Number.isInteger(W)&&W>0?W:void 0;if(!X&&H===void 0)return;return{...X?{effort:X}:{},...H!==void 0?{budgetTokens:H}:{}}}function Cz($){let f=$["openai-codex-oauth-credentials"];if(!f)return;try{let J=JSON.parse(f),Q=C(J.access_token),Z=C(J.refresh_token),W=C(J.accountId);if(!Q&&!Z&&!W)return;return{...Q?{apiKey:Q}:{},auth:{...Q?{accessToken:Q}:{},...Z?{refreshToken:Z}:{},...W?{accountId:W}:{}}}}catch{return}}function Ez($){let f=k6.getGeneratedModelsForProvider($);return Object.keys(f)[0]??void 0}function bz($,f,J,Q){let Z=g9($),W=C(Q==="plan"?f.planModeApiProvider:f.actModeApiProvider),j=Sz(f,$,Q,W)??Ez(Z),X=hz(f,Z,Q),H=typeof f.requestTimeoutMs==="number"&&Number.isInteger(f.requestTimeoutMs)&&f.requestTimeoutMs>0?f.requestTimeoutMs:void 0,Y={anthropic:J.apiKey,cline:J.clineApiKey,openai:J.openAiApiKey,"openai-native":J.openAiNativeApiKey,openrouter:J.openRouterApiKey,bedrock:J.awsBedrockApiKey,gemini:J.geminiApiKey,ollama:J.ollamaApiKey,deepseek:J.deepSeekApiKey,requesty:J.requestyApiKey,together:J.togetherApiKey,fireworks:J.fireworksApiKey,qwen:J.qwenApiKey,doubao:J.doubaoApiKey,mistral:J.mistralApiKey,litellm:J.liteLlmApiKey,asksage:J.asksageApiKey,xai:J.xaiApiKey,moonshot:J.moonshotApiKey,zai:J.zaiApiKey,huggingface:J.huggingFaceApiKey,nebius:J.nebiusApiKey,sambanova:J.sambanovaApiKey,cerebras:J.cerebrasApiKey,groq:J.groqApiKey,"huawei-cloud-maas":J.huaweiCloudMaasApiKey,baseten:J.basetenApiKey,"vercel-ai-gateway":J.vercelAiGatewayApiKey,dify:J.difyApiKey,minimax:J.minimaxApiKey,hicap:J.hicapApiKey,aihubmix:J.aihubmixApiKey,nousResearch:J.nousResearchApiKey,oca:J.ocaApiKey,sapaicore:J.sapAiCoreClientId},V={};if($==="openai-codex")Object.assign(V,Cz(J));if($==="cline")try{let P=C(J["cline:clineAccountId"]);if(P)V.auth={...V.auth??{},...yz(P)}}catch{}if($===b6&&f.openAiHeaders)V.headers=f.openAiHeaders;if($==="bedrock"){let P=f.awsAuthentication==="profile"||f.awsUseProfile===!0;V.aws={accessKey:C(J.awsAccessKey),secretKey:C(J.awsSecretKey),sessionToken:C(J.awsSessionToken),region:C(f.awsRegion),authentication:f.awsAuthentication,profile:P?C(f.awsProfile):void 0,usePromptCache:f.awsBedrockUsePromptCache,useCrossRegionInference:f.awsUseCrossRegionInference,useGlobalInference:f.awsUseGlobalInference,endpoint:C(f.awsBedrockEndpoint),customModelBaseId:C(Q==="plan"?f.planModeAwsBedrockCustomModelBaseId:f.actModeAwsBedrockCustomModelBaseId)}}if($==="vertex")V.gcp={projectId:C(f.vertexProjectId),region:C(f.vertexRegion)};if($===b6&&(f.azureApiVersion||f.azureIdentity!==void 0))V.azure={apiVersion:C(f.azureApiVersion),useIdentity:f.azureIdentity};if($==="sapaicore")V.sap={clientId:C(J.sapAiCoreClientId),clientSecret:C(J.sapAiCoreClientSecret),tokenUrl:C(f.sapAiCoreTokenUrl),resourceGroup:C(f.sapAiResourceGroup),deploymentId:C(Q==="plan"?f.planModeSapAiCoreDeploymentId:f.actModeSapAiCoreDeploymentId),useOrchestrationMode:f.sapAiCoreUseOrchestrationMode};if($==="oca"){V.oca={mode:f.ocaMode};let P=C(J.ocaRefreshToken);if(P)V.auth={...V.auth??{},refreshToken:P}}if($==="qwen")V.apiLine=f.qwenApiLine;if($==="moonshot")V.apiLine=f.moonshotApiLine;if($==="zai")V.apiLine=f.zaiApiLine;if($==="minimax")V.apiLine=f.minimaxApiLine;let A={anthropic:f.anthropicBaseUrl,openai:f.openAiBaseUrl,ollama:f.ollamaBaseUrl,lmstudio:f.lmStudioBaseUrl,litellm:f.liteLlmBaseUrl,gemini:f.geminiBaseUrl,requesty:f.requestyBaseUrl,asksage:f.asksageApiUrl,dify:f.difyBaseUrl,oca:f.ocaBaseUrl,aihubmix:f.aihubmixBaseUrl,sapaicore:f.sapAiCoreBaseUrl},B=C(Y[$]),G=C(A[$]),K={provider:Z,...B?{apiKey:B}:{},...j?{model:j}:{},...G?{baseUrl:G}:{},...X?{reasoning:X}:{},...H?{timeout:H}:{},...V},D=q6.safeParse(K);if(!D.success)return;return Object.keys(K).filter((P)=>P!=="provider").length>0?D.data:void 0}function kz($,f){if($!==aX)return;if(!f.baseUrl||!f.model)return;return{provider:{name:"OpenAI Compatible",baseUrl:f.baseUrl,defaultModelId:f.model},models:{[f.model]:{id:f.model,name:f.model,contextWindow:iX,maxInputTokens:iX,capabilities:["streaming","tools","images"]}}}}function Iz($,f){let J=new Set;for(let Q of[$.actModeApiProvider,$.planModeApiProvider]){let Z=C(Q);if(Z)J.add(Z)}if(C(f.apiKey))J.add("anthropic");if(C(f.openRouterApiKey))J.add("openrouter");if(C(f.openAiApiKey))J.add(b6);if(C(f.openAiNativeApiKey))J.add("openai-native");if(C(f["openai-codex-oauth-credentials"]))J.add("openai-codex");if(C(f.geminiApiKey))J.add("gemini");if(C(f.ollamaApiKey))J.add("ollama");if(C(f.awsAccessKey)||C(f.awsBedrockApiKey)||$.awsAuthentication!==void 0||$.awsUseProfile===!0||C($.awsProfile))J.add("bedrock");if(C($.vertexProjectId)||C($.vertexRegion))J.add("vertex");if(C(f.clineApiKey))J.add("cline");if(C(f.ocaApiKey))J.add("oca");return J}function v9($){let f=$.providerSettingsManager.read(),J=wz($);if(!J)return{migrated:!1,providerCount:Object.keys(f.providers).length,lastUsedProvider:f.lastUsedProvider};let{globalState:Q,secrets:Z}=J,W=Q.mode==="plan"?"plan":"act",j=Iz(Q,Z),X=Q2();X.providers={...f.providers},X.lastUsedProvider=f.lastUsedProvider;let H=new Date().toISOString(),Y=0,V=m9(Mz($.providerSettingsManager.getFilePath()),"models.json"),A=x9(V),B=0;for(let D of j){let F=g9(D);if(X.providers[F])continue;let P=bz(D,Q,Z,W);if(!P)continue;X.providers[F]={settings:P,updatedAt:H,tokenSource:"migration"},Y+=1;let U=kz(F,P);if(U&&!A.providers[F])A.providers[F]=U,B+=1}if(Y===0&&B===0)return{migrated:!1,providerCount:Object.keys(f.providers).length,lastUsedProvider:f.lastUsedProvider};let G=C(W==="plan"?Q.planModeApiProvider:Q.actModeApiProvider),K=G?g9(G):void 0;if(X.lastUsedProvider=f.lastUsedProvider??(K&&X.providers[K]?K:Object.keys(X.providers)[0]),$.providerSettingsManager.write(X),B>0)mX(V,A);return{migrated:Y>0||B>0,providerCount:Object.keys(X.providers).length,lastUsedProvider:X.lastUsedProvider}}function uz(){return new Date().toISOString()}function cz($){if(sX($)!=="providers.json")return;let f=c9($);if(sX(f)!=="settings")return;return c9(f)}class d${filePath;dataDir;constructor($={}){if(this.filePath=$.filePath??vz(),this.dataDir=$.dataDir??cz(this.filePath),this.dataDir||!$.filePath)v9({providerSettingsManager:this,dataDir:this.dataDir});if(pX(this),E6(this.read()),u9(this.filePath))try{tX(this.filePath,384)}catch{}}getFilePath(){return this.filePath}read(){if(!u9(this.filePath))return Q2();try{let $=mz(this.filePath,"utf8"),f=JSON.parse($),J=y6.safeParse(f);if(J.success)return E6(J.data),J.data}catch{}return Q2()}write($){let f=y6.parse($),J=c9(this.filePath);if(!u9(J))xz(J,{recursive:!0,mode:448});gz(this.filePath,`${JSON.stringify(f,null,2)}
|
|
560
|
-
`,"utf8");try{
|
|
561
|
-
`).map((
|
|
562
|
-
`,"utf8")}persistRuntime($,f,J){this.ensureTeamSubdir($);let
|
|
563
|
-
`,"utf8"),
|
|
552
|
+
`)}function oH($){let f=$.summarizer,J=(Z)=>{if(Z.providerId==="openai-codex"){let{maxOutputTokens:Q,...j}=Z;return{...j,thinking:!1}}return{...Z,maxOutputTokens:Z.maxOutputTokens??IH,thinking:!1}};if(!f)return J($.activeProviderConfig);let W=f.providerConfig?.providerId===f.providerId?f.providerConfig:void 0;return J({...W??{},providerId:f.providerId,modelId:f.modelId,apiKey:f.apiKey??W?.apiKey,baseUrl:f.baseUrl??W?.baseUrl,headers:f.headers??W?.headers,knownModels:f.knownModels??W?.knownModels,maxOutputTokens:f.maxOutputTokens??IH})}function eH($){return{role:"user",content:`Context summary:
|
|
553
|
+
|
|
554
|
+
${$.summary}`,metadata:{kind:"compaction_summary",summary:$.summary,details:$.fileOps,tokensBefore:$.tokensBefore,generatedAt:Date.now()}}}async function R_($){let f=await U_($.providerConfig),J="";for await(let W of f.createMessage("Summarize the provided coding session into a concise continuation note with detailed next steps.",[{role:"user",content:$.request}])){if(W.type==="text"){J+=W.text;continue}if(W.type==="done"&&!W.success&&W.error)throw Error(W.error)}return $.logger?.debug("Generated compaction summary",{outputChars:J.length,modelId:$.providerConfig.modelId,providerId:$.providerConfig.providerId}),J.trim()}function D_($){try{return JSON.stringify($).length}catch{return String($).length}}async function $X($){let f=$.context.messages;if(f.length<2)return;let J=nH(f,$.preserveRecentTokens,$.estimateMessageTokens);if(J<=0||J>=f.length)return;let W=f.slice(0,J),Z=iH(W),Q=Z>=0?oW(W[Z])?.summary:void 0,j=Z>=0?W.slice(Z+1):W;if(j.length===0)return;let H=aH(W),X=dH(j),Y=sH({previousSummary:Q,conversationText:X,fileOps:H});$.logger?.debug("Agentic compaction summarizer diagnostics",{messagesToSummarize:W.length,newMessagesToFold:j.length,preservedMessages:f.length-J,previousSummaryChars:Q?.length??0,conversationTextChars:X.length,summaryRequestChars:Y.length,summaryRequestEstimatedTokens:nW(Y.length),newMessagesJsonChars:D_(j),maxInputTokens:$.context.maxInputTokens,triggerTokens:$.context.triggerTokens});let A=await R_({providerConfig:oH({activeProviderConfig:$.providerConfig,summarizer:$.summarizer}),request:Y,logger:$.logger});if(!A.trim())return;let V=tH(A,H),B=f.reduce((R,P)=>R+$.estimateMessageTokens(P),0),K=[eH({summary:V,fileOps:H,tokensBefore:B}),...f.slice(J)],G=K.reduce((R,P)=>R+$.estimateMessageTokens(P),0);return $.logger?.debug("Performed agentic compaction",{messagesBefore:f.length,messagesAfter:K.length,messagesSummarized:J,messagesPreserved:f.length-J,tokensBefore:B,tokensAfter:G,maxInputTokens:$.context.maxInputTokens}),{messages:K}}function WX($){if(E2($))return;if(typeof $.content==="string"){let J=$.content.trim();return J?{...$,content:J}:void 0}let f=$.content.filter((J)=>J.type!=="text"||J.text.trim());if(f.length===0)return;return{...$,content:f.map((J)=>J.type==="text"?{...J,text:J.text.trim()}:J.type==="tool_result"?{...J,content:sW(J.content)}:J)}}function k2($,f){return $.reduce((J,W)=>J+f(W),0)}function fX($,f){let J=Math.max(1,f),W=Math.max(16,J*4);if(typeof $.content==="string"){let j=l$($.content,W).trim();return{...$,content:j||"..."}}let Z=W,Q=$.content.map((j)=>{if(j.type!=="text"||Z<=0)return j;let H=l$(j.text,Z).trim();return Z-=H.length,{...j,text:H||"..."}});return{...$,content:Q}}function L_($,f){let J=pH($),W=vJ($),Z=rH($),Q=[];for(let j=0;j<$.length;j+=1){let H=WX($[j]);if(!H)continue;Q.push({index:j,message:H,estimatedTokens:f(H),isFirstUser:j===J,isLastUser:j===W,isLastAssistant:j===Z})}return Q}function JX($,f,J,W){let Z=$[f];Z.message=J,Z.estimatedTokens=W(J)}function O_($){let f=new Set;if(!Array.isArray($.content))return f;for(let J of $.content)if(J.type==="tool_use")f.add(J.id);return f}function __($){let f=new Set;if(!Array.isArray($.content))return f;for(let J of $.content)if(J.type==="tool_result")f.add(J.tool_use_id);return f}function ZX($){return new Set([...O_($.message),...__($.message)])}function z_($){let f=new Map;for(let J=0;J<$.length;J+=1)for(let W of ZX($[J])){let Z=f.get(W);if(Z)Z.add(J);else f.set(W,new Set([J]))}return f}function T_($,f){let J=z_($),W=new Set,Z=[f];while(Z.length>0){let Q=Z.shift();if(Q===void 0||W.has(Q))continue;W.add(Q);for(let j of ZX($[Q]))for(let H of J.get(j)??[])if(!W.has(H))Z.push(H)}return W}function uJ($,f,J,W){let Z=k2($.map((Q)=>Q.message),W);for(let Q=0;Q<$.length&&Z>J;){if(!f($[Q])){Q+=1;continue}let j=T_($,Q);Z-=Array.from(j).reduce((H,X)=>H+$[X].estimatedTokens,0);for(let H of Array.from(j).sort((X,Y)=>Y-X))$.splice(H,1)}}function N_($,f,J){let W=k2($.map((Q)=>Q.message),J);if(W<=f)return;for(let Q=$.length-1;Q>=0&&W>f;Q-=1){let j=$[Q];if(j.isFirstUser)continue;let H=Math.max(uH,j.estimatedTokens-(W-f));if(H>=j.estimatedTokens)continue;JX($,Q,fX(j.message,H),J),W=k2($.map((X)=>X.message),J)}if(W<=f)return;let Z=$.findIndex((Q)=>Q.isFirstUser);if(Z>=0){let Q=Math.max(1,$[Z].estimatedTokens-(W-f));JX($,Z,fX($[Z].message,Q),J)}}function M_($,f){return JSON.stringify($)!==JSON.stringify(f)}function y_($){let f=vJ($);if(f<0||f===0&&!b2($[0]))return{compactable:$,protectedTail:[]};return{compactable:$.slice(0,f),protectedTail:$.slice(f)}}function QX($){let f=Math.max(1,Math.min($.context.triggerTokens,$.context.maxInputTokens)),{compactable:J,protectedTail:W}=y_($.context.messages);if(J.length===0)return;let Z=L_(J,$.estimateMessageTokens);if(Z.length===0)return;uJ(Z,(X)=>X.message.role==="assistant"&&!X.isLastAssistant,f,$.estimateMessageTokens),uJ(Z,(X)=>X.message.role==="user"&&!X.isFirstUser&&!X.isLastUser,f,$.estimateMessageTokens),uJ(Z,(X)=>X.message.role==="assistant"&&X.isLastAssistant,f,$.estimateMessageTokens),uJ(Z,(X)=>X.message.role==="user"&&X.isLastUser&&!X.isFirstUser,f,$.estimateMessageTokens),N_(Z,f,$.estimateMessageTokens);let Q=[...Z.map((X)=>X.message),...W];if(!M_($.context.messages,Q))return;let j=k2([...J.map((X)=>WX(X)??X),...W],$.estimateMessageTokens),H=k2(Q,$.estimateMessageTokens);return $.logger?.debug("Performed basic compaction",{messagesBefore:$.context.messages.length,messagesAfter:Q.length,messagesRemoved:$.context.messages.length-Q.length,tokensBefore:j,tokensAfter:H,targetTokens:f,maxInputTokens:$.context.maxInputTokens}),{messages:Q}}function jX($){try{return JSON.stringify($).length}catch{return String($).length}}function q_($){let f=0,J=0,W=0;for(let Z of $){if(!Array.isArray(Z.content))continue;for(let Q of Z.content){if(Q.type!=="tool_result")continue;let j=jX(Q.content);f+=1,J+=j,W=Math.max(W,j)}}return{toolResultCount:f,toolResultSerializedChars:J,maxToolResultSerializedChars:W}}var w_={basic:({context:$,estimateMessageTokens:f,logger:J})=>QX({context:$,estimateMessageTokens:f,logger:J}),agentic:({context:$,providerConfig:f,compaction:J,mode:W,estimateMessageTokens:Z,logger:Q})=>$X({context:$,providerConfig:f,summarizer:J?.summarizer,preserveRecentTokens:W==="manual"?Math.min(J?.preserveRecentTokens??tW,$.triggerTokens):J?.preserveRecentTokens??tW,estimateMessageTokens:Z,logger:Q})};function S_($){if(typeof $.config.reserveTokens==="number"){let W=Math.max(0,$.config.reserveTokens),Z=Math.max(0,$.maxInputTokens-W);return{shouldCompact:$.inputTokens>Z,triggerTokens:Z,thresholdRatio:$.maxInputTokens>0?Z/$.maxInputTokens:0}}if(typeof $.config.thresholdRatio!=="number"){let W=Math.max(0,Math.min($.maxInputTokens-gH,$.maxInputTokens*aW));return{shouldCompact:$.inputTokens>W,triggerTokens:W,thresholdRatio:$.maxInputTokens>0?W/$.maxInputTokens:0}}let f=$.config.thresholdRatio??aW,J=$.maxInputTokens*f;return{shouldCompact:$.inputTokens>J,triggerTokens:J,thresholdRatio:f}}function h_($){let f=typeof $.manualTargetRatio==="number"&&Number.isFinite($.manualTargetRatio)?$.manualTargetRatio:0.5,J=Math.min(0.95,Math.max(0.05,f)),W=Math.max(1,Math.floor(Math.min($.autoTriggerTokens,$.inputTokens*J)));return{triggerTokens:W,thresholdRatio:$.maxInputTokens>0?W/$.maxInputTokens:0}}function eW($,f={}){let J=$.compaction;if(J?.enabled!==!0)return;let W=$.providerConfig??{providerId:$.providerId,modelId:$.modelId},Z=lH(),Q=J?.strategy??"basic",j=w_[Q],H=f.mode??"auto",X=J?.compact?"custom":Q;return async(Y)=>{let A=Y.apiMessages.reduce((O,T)=>O+Z(T),0),V=J?.maxInputTokens??Y.model.info?.maxInputTokens??Y.model.info?.contextWindow??mH;if(typeof V!=="number"||!Number.isFinite(V)||V<=0)return;let B=S_({inputTokens:A,maxInputTokens:V,config:{reserveTokens:J?.reserveTokens,thresholdRatio:J?.thresholdRatio}});if($.logger?.debug("Context compaction diagnostics",{mode:H,strategy:Q,iteration:Y.iteration,providerId:$.providerId,modelId:$.modelId,inputTokens:A,maxInputTokens:V,triggerTokens:B.triggerTokens,thresholdRatio:B.thresholdRatio,shouldCompact:B.shouldCompact,messageCount:Y.messages.length,apiMessageCount:Y.apiMessages.length,apiMessagesJsonChars:jX(Y.apiMessages),...q_(Y.apiMessages)}),H==="auto"&&!B.shouldCompact)return;let K=H==="manual"?h_({inputTokens:A,maxInputTokens:V,autoTriggerTokens:B.triggerTokens,manualTargetRatio:f.manualTargetRatio}):B,G={agentId:Y.agentId,conversationId:Y.conversationId,parentAgentId:Y.parentAgentId,iteration:Y.iteration,messages:Y.messages,model:Y.model,maxInputTokens:V,triggerTokens:K.triggerTokens,thresholdRatio:K.thresholdRatio,utilizationRatio:V>0?A/V:0},R=H==="manual"?"manual_compaction":"auto_compaction";Y.emitStatusNotice?.(H==="manual"?"compacting":"auto-compacting",{kind:R,reason:R,iteration:Y.iteration,triggerTokens:K.triggerTokens,maxInputTokens:V});let P=Y.messages.length,F=Date.now(),U=J?.compact?await J.compact(G):await j({context:G,providerConfig:{...W,abortSignal:Y.abortSignal},compaction:J,mode:H,estimateMessageTokens:Z,logger:$.logger}),_=Date.now()-F,z=$.sessionId??Y.conversationId,D={agentId:Y.agentId,conversationId:Y.conversationId,parentAgentId:Y.parentAgentId??void 0};if(U?.messages){let O=U.messages.reduce((T,M)=>T+Z(M),0);$.logger?.log("Context compaction completed",{severity:"info",strategy:Q,maxInputTokens:V,inputTokens:A,afterTokens:O,tokensSaved:A-O,utilizationBefore:`${(A/V*100).toFixed(1)}%`,utilizationAfter:`${(O/V*100).toFixed(1)}%`,thresholdTrigger:`${(K.thresholdRatio*100).toFixed(1)}%`,messagesBefore:P,messagesAfter:U.messages.length,messagesRemoved:P-U.messages.length}),o4($.telemetry,{ulid:z,strategy:X,mode:H,messagesBefore:P,messagesAfter:U.messages.length,messagesRemoved:P-U.messages.length,tokensBefore:A,tokensAfter:O,tokensSaved:A-O,triggerTokens:K.triggerTokens,maxInputTokens:V,thresholdRatio:K.thresholdRatio,durationMs:_,provider:$.providerId,modelId:$.modelId,...D})}else e4($.telemetry,{ulid:z,strategy:X,mode:H,reason:"no_result",tokensBefore:A,triggerTokens:K.triggerTokens,maxInputTokens:V,thresholdRatio:K.thresholdRatio,durationMs:_,provider:$.providerId,modelId:$.modelId,...D});return U}}B0();function G0(){return{inputTokens:0,outputTokens:0,cacheReadTokens:0,cacheWriteTokens:0,totalCost:0}}function Y0($,f){return{inputTokens:$.inputTokens+Math.max(0,f.inputTokens??0),outputTokens:$.outputTokens+Math.max(0,f.outputTokens??0),cacheReadTokens:$.cacheReadTokens+Math.max(0,f.cacheReadTokens??0),cacheWriteTokens:$.cacheWriteTokens+Math.max(0,f.cacheWriteTokens??0),totalCost:$.totalCost+Math.max(0,f.totalCost??0)}}function cJ($){let f=G0();for(let J of $)f=Y0(f,J);return f}function Bf($){return typeof $==="number"&&Number.isFinite($)?$:0}function dJ($){let f=G0();for(let J of $){let W=J.metrics;if(!W)continue;f=Y0(f,{inputTokens:Bf(W.inputTokens),outputTokens:Bf(W.outputTokens),cacheReadTokens:Bf(W.cacheReadTokens),cacheWriteTokens:Bf(W.cacheWriteTokens),totalCost:Bf(W.cost)})}return f}function C_($){for(let f=$.length-1;f>=0;f-=1){let J=$[f];if(J?.role!=="assistant")continue;let W=Bf(J.metrics?.inputTokens);return W>0?W:void 0}return}function E_($){if(!$||typeof $!=="object")return;let f=$,J=f.skill??f.skill_name??f.skillName;if(typeof J!=="string")return;let W=J.trim();return W.length>0?W:void 0}function $Z($){if(!$||typeof $!=="object")return{};let f=$;return{agentId:typeof f.agentId==="string"?f.agentId:void 0,conversationId:typeof f.conversationId==="string"?f.conversationId:void 0,parentAgentId:typeof f.parentAgentId==="string"?f.parentAgentId:void 0}}function G$($){let f=$.agentId?.trim();if(!f)return;let J=$.parentAgentId?.trim()||void 0,W=$.teamRole,Z="root";if(W==="teammate")Z="team_teammate";else if(W==="lead")Z="team_lead";else if(J)Z="subagent";return{agentId:f,agentKind:Z,conversationId:$.conversationId?.trim()||void 0,parentAgentId:J,createdByAgentId:$.createdByAgentId?.trim()||J||void 0,isSubagent:Boolean(J),teamId:$.teamId?.trim()||void 0,teamName:$.teamName?.trim()||void 0,teamRole:W,teamAgentId:$.teamAgentId?.trim()||void 0}}function b_($){return{inputTokens:$.inputTokens,outputTokens:$.outputTokens,cacheWriteTokens:$.cacheWriteTokens,cacheReadTokens:$.cacheReadTokens,totalCost:$.cost}}function k_($){let f=$.isPrimaryAgentEvent?[$.overrides?.agentId,$.eventMetadata.agentId,$.overrides?.teamAgentId]:[$.overrides?.teamAgentId,$.overrides?.agentId,$.eventMetadata.agentId,$.eventMetadata.conversationId];for(let J of f){let W=J?.trim();if(W)return W}return $.isPrimaryAgentEvent?"root":"unknown"}function fZ($,f,J){let{sessionId:W,config:Z,liveSession:Q,emit:j}=$,H=Z.telemetry,X=Q?.runtime.teamRuntime,Y=J?.isPrimaryAgentEvent??!0,A=$Z(f),V=G$({agentId:J?.agentId??A.agentId,conversationId:J?.conversationId??A.conversationId,parentAgentId:J?.parentAgentId??A.parentAgentId,createdByAgentId:J?.createdByAgentId,teamId:J?.teamId??X?.getTeamId(),teamName:J?.teamName??X?.getTeamName(),teamRole:J?.teamRole,teamAgentId:J?.teamAgentId});if(f.type==="content_start"&&f.contentType==="tool"&&f.toolName==="skills"){let B=E_(f.input);if(B)p4(H,{ulid:W,skillName:B,skillSource:"project",skillsAvailableGlobal:0,skillsAvailableProject:0,provider:Z.providerId,modelId:Z.modelId,...V})}if(f.type==="content_end"&&f.contentType==="tool"){let B=f.toolName??"unknown",K=!f.error;if(l4(H,{ulid:W,tool:B,autoApproved:void 0,success:K,modelId:Z.modelId,provider:Z.providerId,...V}),!K&&(B==="editor"||B==="apply_patch"))r4(H,{ulid:W,modelId:Z.modelId,provider:Z.providerId,errorType:f.error,...V})}if(f.type==="notice"&&f.reason==="api_error")t2(H,{ulid:W,model:Z.modelId,provider:Z.providerId,errorMessage:f.message,...V});if(f.type==="error")t2(H,{ulid:W,model:Z.modelId,provider:Z.providerId,errorMessage:f.error?.message??"unknown error",...V});if(f.type==="usage"&&Q?.turnUsageBaseline){let B=b_(f);if(Y){Q.turnPrimaryUsage=Y0(Q.turnPrimaryUsage??G0(),B);let G=Y0(Q.turnUsageBaseline,Q.turnPrimaryUsage);$.usageBySession.set(W,G),Tf(H,{ulid:W,provider:Z.providerId,model:Z.modelId,source:"assistant",mode:Z.mode,...V}),c4(H,{ulid:W,tokensIn:f.inputTokens,tokensOut:f.outputTokens,cacheWriteTokens:f.cacheWriteTokens,cacheReadTokens:f.cacheReadTokens,totalCost:f.cost,model:Z.modelId,...V})}else{let G=k_({isPrimaryAgentEvent:Y,overrides:J,eventMetadata:A}),R=Q.turnUsageByAgent??new Map;Q.turnUsageByAgent=R,R.set(G,Y0(R.get(G)??G0(),B))}let K=Y0(Q.turnPrimaryUsage??G0(),cJ(Q.turnUsageByAgent?.values()??[]));$.aggregateUsageBySession.set(W,Y0(Q.turnAggregateUsageBaseline??Q.turnUsageBaseline,K))}if(f.type==="iteration_end"&&Y)$.persistMessages(W,Q?.agent.getMessages()??[],Q?.config.systemPrompt);j({type:"agent_event",payload:{sessionId:W,event:f,teamAgentId:J?.teamAgentId,teamRole:J!==void 0?J.teamRole??(Y?"lead":void 0):void 0}}),j({type:"chunk",payload:{sessionId:W,stream:"agent",chunk:qj(f),ts:Date.now()}})}function p$($){return $.workspaceRoot??$.cwd}import{hasRuntimeConfigExtension as Yz}from"@cline/shared";import{spawn as l_}from"node:child_process";import{appendFileSync as p_,readFileSync as r_}from"node:fs";import{join as i_}from"node:path";import{augmentNodeCommandForDebug as AX,withResolvedClineBuildEnv as HZ}from"@cline/shared";import{ensureHookLogDir as XX}from"@cline/shared/storage";function lJ($,f){if(!f)return;return{name:$,manifest:{capabilities:["hooks"]},hooks:f}}import{existsSync as I_,readdirSync as x_}from"node:fs";import{basename as m_,extname as g_,join as v_}from"node:path";import{HOOKS_CONFIG_DIRECTORY_NAME as HX,resolveHooksConfigSearchPaths as u_}from"@cline/shared/storage";function JZ($){return u_($)}var pJ;((A)=>{A.TaskStart="TaskStart";A.TaskResume="TaskResume";A.TaskCancel="TaskCancel";A.TaskComplete="TaskComplete";A.TaskError="TaskError";A.PreToolUse="PreToolUse";A.PostToolUse="PostToolUse";A.UserPromptSubmit="UserPromptSubmit";A.PreCompact="PreCompact";A.SessionShutdown="SessionShutdown"})(pJ||={});var WZ={["TaskStart"]:"agent_start",["TaskResume"]:"agent_resume",["TaskCancel"]:"agent_abort",["TaskComplete"]:"agent_end",["TaskError"]:"agent_error",["PreToolUse"]:"tool_call",["PostToolUse"]:"tool_result",["UserPromptSubmit"]:"prompt_submit",["PreCompact"]:void 0,["SessionShutdown"]:"session_shutdown"},c_=new Map(Object.values(pJ).map(($)=>[$.toLowerCase(),$])),d_=new Set(["",".sh",".bash",".zsh",".js",".mjs",".cjs",".ts",".mts",".cts",".py",".ps1"]);function ZZ($){let f=g_($).toLowerCase();if(!d_.has(f))return;let J=m_($,f).trim().toLowerCase();return c_.get(J)}function Kf($){let f=[],J=new Set,W=JZ($).filter((Z)=>I_(Z));for(let Z of W)try{for(let Q of x_(Z,{withFileTypes:!0})){if(!Q.isFile())continue;let j=ZZ(Q.name);if(!j)continue;let H=v_(Z,Q.name);if(J.has(H))continue;J.add(H),f.push({fileName:j,hookEventName:WZ[j],path:H})}}catch{}return f.sort((Z,Q)=>Z.path.localeCompare(Q.path))}function iJ($){if(!$||typeof $!=="object")return{};let f={};for(let[J,W]of Object.entries($))f[J]=typeof W==="string"?W:JSON.stringify(W);return f}function rJ($,f,J){let W=J instanceof Error?`: ${J.message}`:"",Z=`${f}${W}`;if($){try{$.log(Z,{severity:"warn",...J!==void 0?{error:J}:{}})}catch{}return}console.warn(Z)}function n_($,f){if(!f)return $;if(!$)return{...f};let J=[$.context,f.context].filter((Z)=>typeof Z==="string"&&Z.length>0).join(`
|
|
555
|
+
`),W=[...$.appendMessages??[],...f.appendMessages??[]];return{cancel:$.cancel===!0||f.cancel===!0?!0:void 0,review:$.review===!0||f.review===!0?!0:void 0,context:J||void 0,overrideInput:f.overrideInput!==void 0?f.overrideInput:$.overrideInput,systemPrompt:f.systemPrompt!==void 0?f.systemPrompt:$.systemPrompt,appendMessages:W.length>0?W:void 0}}function a_($){if(!$||typeof $!=="object")return;let f=$,J=typeof f.context==="string"?f.context:typeof f.contextModification==="string"?f.contextModification:typeof f.errorMessage==="string"?f.errorMessage:void 0;return{cancel:typeof f.cancel==="boolean"?f.cancel:void 0,review:typeof f.review==="boolean"?f.review:void 0,context:J,overrideInput:Object.hasOwn(f,"overrideInput")?f.overrideInput:void 0}}function QZ($){let f=String($??"").toLowerCase();return f.includes("cancel")||f.includes("abort")||f.includes("interrupt")}function A0($,f){let J=process.env.CLINE_USER_ID?.trim()||process.env.USER?.trim()||"unknown",W={rootSessionId:f.rootSessionId||$.conversationId};return{clineVersion:process.env.CLINE_VERSION?.trim()||"",timestamp:new Date().toISOString(),taskId:$.conversationId,sessionContext:W,workspaceRoots:f.workspacePath?[f.workspacePath]:[],workspaceInfo:f.workspaceInfo,userId:J,agent_id:$.agentId,parent_agent_id:$.parentAgentId}}function t_($){let f=$.trim();if(!f)return{};let W=f.split(`
|
|
556
|
+
`).map((Q)=>Q.trim()).filter(Boolean).filter((Q)=>Q.startsWith("HOOK_CONTROL\t")).map((Q)=>Q.slice(13)),Z=W.length>0?W[W.length-1]:f;try{return{parsedJson:JSON.parse(Z)}}catch(Q){return{parseError:Q instanceof Error?Q.message:"Failed to parse hook stdout JSON"}}}async function s_($,f){let J=$.stdin;if(!J)throw Error("hook command failed to create stdin");await new Promise((W,Z)=>{let Q=!1,j=()=>{J.off("error",X),J.off("finish",Y),$.off("close",A)},H=(V)=>{if(Q)return;if(Q=!0,j(),V){let B=V.code;if(B==="EPIPE"||B==="ERR_STREAM_DESTROYED"){W();return}Z(V);return}W()},X=(V)=>H(V),Y=()=>H(),A=()=>H();J.on("error",X),J.once("finish",Y),$.once("close",A);try{J.end(f)}catch(V){H(V)}})}async function VX($,f){if(f.command.length===0)throw Error("runHookCommand requires non-empty command");try{return await YX($,f)}catch(J){let W=$z(f.command,process.platform,J);if(!W)throw J;return await YX($,{...f,command:W})}}async function YX($,f){let J=AX(f.command,{env:f.env,debugRole:"hook"}),W=l_(J[0],J.slice(1),{cwd:f.cwd,env:HZ(f.env),stdio:f.detached?["pipe","ignore","ignore"]:["pipe","pipe","pipe"],detached:f.detached}),Z=new Promise((B)=>{W.once("spawn",()=>B())}),Q=new Promise((B,K)=>{W.once("error",(G)=>K(G))}),j=JSON.stringify($);if(await Promise.race([Z,Q]),await s_(W,j),f.detached){W.unref();return}if(!W.stdout||!W.stderr)throw Error("hook command failed to create stdout/stderr");let H="",X="",Y=!1,A;W.stdout.on("data",(B)=>{H+=B.toString()}),W.stderr.on("data",(B)=>{X+=B.toString()});let V=new Promise((B)=>{if((f.timeoutMs??0)>0)A=setTimeout(()=>{Y=!0,W.kill("SIGKILL")},f.timeoutMs);W.once("close",(K)=>{if(A)clearTimeout(A);let{parsedJson:G,parseError:R}=t_(H);B({exitCode:K,stdout:H,stderr:X,parsedJson:G,parseError:R,timedOut:Y})})});return await Promise.race([V,Q])}function o_($){try{let J=r_($,"utf8").split(/\r?\n/,1)[0]?.trim();if(!J?.startsWith("#!"))return;let W=J.slice(2).trim();if(!W)return;let Z=W.split(/\s+/).filter(Boolean);return Z.length>0?Z:void 0}catch{return}}function e_($){return!!($&&typeof $==="object"&&("code"in $)&&$.code==="ENOENT")}function $z($,f=process.platform,J){if(f!=="win32"||!e_(J))return;if($[0]!=="py"||$[1]!=="-3")return;return["python",...$.slice(2)]}function BX($){if($.length===0)return;let[f,...J]=$,W=f.replace(/\\/g,"/").toLowerCase(),Z=W.split("/").at(-1)??W;if(Z==="env")return BX(J);if(Z==="bash"||Z==="sh"||Z==="zsh")return[Z,...J];if(Z==="python3"||Z==="python")return process.platform==="win32"?["py","-3",...J]:[Z,...J];return $}function fz($){let f=o_($);if(f&&f.length>0)return[...BX(f)??f,$];let J=$.toLowerCase();if(J.endsWith(".sh")||J.endsWith(".bash")||J.endsWith(".zsh"))return["bash",$];if(J.endsWith(".js")||J.endsWith(".mjs")||J.endsWith(".cjs"))return AX(["node",$],{debugRole:"hook"});if(J.endsWith(".ts")||J.endsWith(".mts")||J.endsWith(".cts"))return["bun","run",$];if(J.endsWith(".py"))return process.platform==="win32"?["py","-3",$]:["python3",$];if(J.endsWith(".ps1"))return[process.platform==="win32"?"powershell":"pwsh","-File",$];return["bash",$]}function Jz($){let f={};for(let J of Kf($)){if(!J.hookEventName)continue;let W=J.hookEventName,Z=f[W]??[];Z.push(fz(J.path)),f[W]=Z}return f}async function Wz($){let f;for(let J of $.commands){let W=J.join(" ");try{let Z=await VX($.payload,{command:J,cwd:$.cwd,env:HZ(process.env),detached:!1,timeoutMs:$.timeoutMs});if(Z?.timedOut){rJ($.logger,`hook command timed out: ${W}`);continue}if(Z?.parseError){rJ($.logger,`hook command returned invalid JSON control output: ${W} (${Z.parseError})`);continue}f=n_(f,a_(Z?.parsedJson))}catch(Z){rJ($.logger,`hook command failed: ${W}`,Z)}}return f}function w1($){for(let f of $.commands){let J=f.join(" ");VX($.payload,{command:f,cwd:$.cwd,env:HZ(process.env),detached:!0}).catch((W)=>{rJ($.logger,`hook command failed: ${J}`,W)})}}function r$($){return{agentId:$.agentId,conversationId:$.conversationId??$.runId??$.agentId,parentAgentId:$.parentAgentId??null}}function jZ($,f){return{...r$($.snapshot),userMessage:f}}function KX($){return{...r$($.snapshot),iteration:$.snapshot.iteration,call:{id:$.toolCall.toolCallId,name:$.toolCall.toolName,input:$.input}}}function GX($){return{...r$($.snapshot),iteration:$.snapshot.iteration,record:{id:$.toolCall.toolCallId,name:$.toolCall.toolName,input:$.input,output:$.result.output,error:$.result.isError?String($.result.output):void 0,durationMs:$.durationMs,startedAt:$.startedAt,endedAt:$.endedAt}}}function PX($){return $.filter((f)=>f.type==="text"&&typeof f.text==="string").map((f)=>f.text).join("")}function Zz($){if(!$)return;let f={};if($.cancel===!0)f.stop=!0;if($.overrideInput!==void 0)f.input=$.overrideInput;return Object.keys(f).length>0?f:void 0}function nJ($){let f={cwd:$.workspacePath,workspacePath:$.workspacePath,rootSessionId:$.rootSessionId,workspaceInfo:$.workspaceInfo},J=(W)=>{let Z=`${JSON.stringify({ts:new Date().toISOString(),...W})}
|
|
557
|
+
`,j=(process.env.CLINE_HOOKS_LOG_PATH?.trim()||void 0)??i_(XX(),"hooks.jsonl");XX(j),p_(j,Z,"utf8")};return{beforeRun:async(W)=>{let Z=jZ(W,"");J({...A0(Z,f),hookName:"agent_start",taskStart:{taskMetadata:{}}});return},beforeTool:async(W)=>{let Z=KX(W);J({...A0(Z,f),hookName:"tool_call",iteration:Z.iteration,tool_call:{id:Z.call.id,name:Z.call.name,input:Z.call.input},preToolUse:{toolName:Z.call.name,parameters:iJ(Z.call.input)}});return},afterTool:async(W)=>{let Z=GX(W);J({...A0(Z,f),hookName:"tool_result",iteration:Z.iteration,tool_result:Z.record,postToolUse:{toolName:Z.record.name,parameters:iJ(Z.record.input),result:typeof Z.record.output==="string"?Z.record.output:JSON.stringify(Z.record.output),success:!Z.record.error,executionTimeMs:Z.record.durationMs}});return},afterRun:async({snapshot:W,result:Z})=>{let Q=r$(W);if(Z.status==="completed"){J({...A0(Q,f),hookName:"agent_end",iteration:Z.iterations,turn:{outputText:Z.outputText,status:Z.status},taskComplete:{taskMetadata:{}}});return}if(Z.status==="aborted"||QZ(Z.error?.message)){J({...A0(Q,f),hookName:"agent_abort",reason:Z.error?.message,taskCancel:{taskMetadata:{}}});return}if(Z.error)J({...A0(Q,f),hookName:"agent_error",iteration:Z.iterations,error:{name:Z.error.name,message:Z.error.message,stack:Z.error.stack}})},onEvent:async(W)=>{if(W.type!=="message-added"||W.message.role!=="user")return;let Z=jZ({snapshot:W.snapshot},PX(W.message.content));J({...A0(Z,f),hookName:"prompt_submit",userPromptSubmit:{prompt:Z.userMessage,attachments:[]}})}}}function XZ($){let f=Jz($.workspacePath);if(!Object.values(f).some((V)=>V.length>0))return;let W=async(V,B)=>{let K=f[B]??[];if(K.length===0)return;w1({commands:K,cwd:$.cwd,logger:$.logger,payload:B==="agent_resume"?{...A0(V,$),hookName:B,taskResume:{taskMetadata:{},previousState:{}}}:{...A0(V,$),hookName:B,taskStart:{taskMetadata:{}}}})},Z=async(V)=>{let B=f.prompt_submit??[];if(B.length>0)w1({commands:B,cwd:$.cwd,logger:$.logger,payload:{...A0(V,$),hookName:"prompt_submit",userPromptSubmit:{prompt:V.userMessage,attachments:[]}}})},Q=async(V)=>{let B=f.tool_call??[];if(B.length===0)return;return Wz({commands:B,cwd:$.cwd,logger:$.logger,timeoutMs:$.toolCallTimeoutMs??120000,payload:{...A0(V,$),hookName:"tool_call",iteration:V.iteration,tool_call:{id:V.call.id,name:V.call.name,input:V.call.input},preToolUse:{toolName:V.call.name,parameters:iJ(V.call.input)}}})},j=async(V)=>{let B=f.tool_result??[];if(B.length===0)return;w1({commands:B,cwd:$.cwd,logger:$.logger,payload:{...A0(V,$),hookName:"tool_result",iteration:V.iteration,tool_result:V.record,postToolUse:{toolName:V.record.name,parameters:iJ(V.record.input),result:typeof V.record.output==="string"?V.record.output:JSON.stringify(V.record.output),success:!V.record.error,executionTimeMs:V.record.durationMs}}})},H=async(V)=>{let B=f.agent_end??[];if(B.length===0)return;w1({commands:B,cwd:$.cwd,logger:$.logger,payload:{...A0(V,$),hookName:"agent_end",iteration:V.iteration,turn:V.turn,taskComplete:{taskMetadata:{}}}})},X=async(V)=>{let B=f.agent_error??[];if(B.length===0)return;w1({commands:B,cwd:$.cwd,logger:$.logger,payload:{...A0(V,$),hookName:"agent_error",iteration:V.iteration,error:{name:V.error.name,message:V.error.message,stack:V.error.stack}}})},Y=async(V)=>{if(QZ(V.reason)){let K=f.agent_abort??[];if(K.length>0)w1({commands:K,cwd:$.cwd,logger:$.logger,payload:{...A0(V,$),hookName:"agent_abort",reason:V.reason,taskCancel:{taskMetadata:{}}}})}let B=f.session_shutdown??[];if(B.length===0)return;w1({commands:B,cwd:$.cwd,logger:$.logger,payload:{...A0(V,$),hookName:"session_shutdown",reason:V.reason}})},A={};if((f.agent_start?.length??0)>0||(f.agent_resume?.length??0)>0||(f.prompt_submit?.length??0)>0){if((f.agent_start?.length??0)>0||(f.agent_resume?.length??0)>0)A.beforeRun=async(V)=>{let B=process.env.CLINE_HOOK_AGENT_RESUME==="1"?"agent_resume":"agent_start";await W(r$(V.snapshot),B);return};if((f.prompt_submit?.length??0)>0)A.onEvent=async(V)=>{if(V.type!=="message-added"||V.message.role!=="user")return;await Z(jZ({snapshot:V.snapshot},PX(V.message.content)))}}if((f.tool_call?.length??0)>0)A.beforeTool=async(V)=>{let B=await Q(KX(V));return Zz(B)};if((f.tool_result?.length??0)>0)A.afterTool=async(V)=>{await j(GX(V));return};if((f.agent_end?.length??0)>0)A.afterRun=async({snapshot:V,result:B})=>{if(B.status!=="completed")return;await H({...r$(V),iteration:B.iterations,turn:{outputText:B.outputText,status:B.status}})};if((f.agent_error?.length??0)>0||(f.agent_abort?.length??0)>0||(f.session_shutdown?.length??0)>0){let V=A.afterRun;A.afterRun=async(B)=>{await V?.(B);let{snapshot:K,result:G}=B;if(G.status==="aborted"||QZ(G.error?.message)){await Y({...r$(K),reason:G.error?.message});return}if(G.error)await X({...r$(K),iteration:G.iterations,error:G.error})}}return A}function aJ($){return lJ("core.hook_config_files",XZ($))}function S1($,f){let J=$.map((W)=>W[f]).filter((W)=>typeof W==="function");if(J.length===0)return;return async(W)=>{let Z;for(let Q of J){let j=await Q(W);if(!j||typeof j!=="object")continue;let H=j;Z={...Z??{},...H,stop:Z?.stop===!0||H.stop===!0?!0:H.stop,options:Z?.options||H.options?{...Z?.options??{},...H.options??{}}:void 0}}return Z}}function I2($){let f=$.filter((J)=>J!==void 0);if(f.length===0)return;return{beforeRun:S1(f,"beforeRun"),afterRun:S1(f,"afterRun"),beforeModel:S1(f,"beforeModel"),afterModel:S1(f,"afterModel"),beforeTool:S1(f,"beforeTool"),afterTool:S1(f,"afterTool"),onEvent:S1(f,"onEvent")}}import{z as i$}from"zod";var tJ=l1;var FX=i$.object({settings:l1,updatedAt:i$.string().datetime(),tokenSource:i$.enum(["manual","oauth","migration"]).default("manual")}),sJ=i$.object({version:i$.literal(1),lastUsedProvider:i$.string().min(1).optional(),providers:i$.record(i$.string(),FX)});function Gf(){return{version:1,providers:{}}}n0();import{upsertWorkspaceInfo as Qz,WorkspaceManifestSchema as YZ}from"@cline/shared";class oJ{manifest;listeners=new Set;constructor($){this.manifest=YZ.parse($??{workspaces:{}})}async addWorkspacePath($){let f=await LJ($);return this.manifest=Qz(this.manifest,f),this.emit({type:"workspace_added",workspace:f}),f}async switchWorkspace($){let f=R1($),J=this.manifest.workspaces[f];if(J)return this.manifest=YZ.parse({...this.manifest,currentWorkspacePath:f}),this.emit({type:"workspace_switched",workspace:J}),J;let W=await this.addWorkspacePath(f);return this.manifest=YZ.parse({...this.manifest,currentWorkspacePath:W.rootPath}),this.emit({type:"workspace_switched",workspace:W}),W}subscribe($){return this.listeners.add($),()=>{this.listeners.delete($)}}getCurrentWorkspace(){let $=this.manifest.currentWorkspacePath;if(!$)return;return this.manifest.workspaces[$]}getWorkspace($){let f=R1($);return this.manifest.workspaces[f]}listWorkspaces(){return Object.values(this.manifest.workspaces)}getManifest(){return this.manifest}emit($){for(let f of this.listeners)f($)}}B0();import{createHash as jz}from"node:crypto";var UX=new Set,RX=new Set;function Hz($){return jz("sha256").update($).digest("hex")}function Xz($){if($.vcsTypes&&$.vcsTypes.length>0)return $.vcsTypes;return[$.vcsType==="git"?"git":"none"]}function DX($){if(!$.telemetry)return;let f=Hz($.rootPath),J=$.rootCount??1;if(!UX.has(f))UX.add(f),m4($.telemetry,{root_count:J,vcs_types:Xz($),init_duration_ms:$.durationMs,feature_flag_enabled:$.featureFlagEnabled??!0,is_remote_workspace:$.isRemoteWorkspace});if($.initError&&!RX.has(f)){RX.add(f);let W=Error($.initError.message);W.name=$.initError.errorType||"Error",g4($.telemetry,W,{fallback_to_single_root:!0,workspace_count:J})}}function Az($){return`${$.pluginName??$.pluginPath}: ${$.message}`}function Vz($,f,J){if(f.length>0)for(let Q of f)J?.log(Q.message,{severity:"warn"});if($.length===0)return;let W=$.slice(0,3).map(Az).join("; "),Z=$.length>3?`; and ${$.length-3} more`:"";J?.log(`Some plugins failed to initialize. ${W}${Z}. Use --verbose for more details.`,{severity:"warn"});for(let Q of $)J?.log(`Plugin initialization failed (${Q.phase}) for ${Q.pluginPath}`,{severity:"warn",stack:Q.stack,pluginPath:Q.pluginPath,pluginName:Q.pluginName})}function Bz($,f){let J=typeof $.thinking==="boolean",W=typeof $.reasoningEffort==="string";if(!J&&!W)return f;return{...f??{},...J?{enabled:$.thinking}:{},...W?{effort:$.reasoningEffort}:{}}}function LX($,f){return Yz($,f)}function Kz($){let f=0;for(let J of $??[]){if(J.role!=="user")continue;if(("metadata"in J&&J.metadata&&typeof J.metadata==="object"&&!Array.isArray(J.metadata)?J.metadata:void 0)?.kind==="recovery_notice")continue;f+=1}return f}function Gz($){let f={...$.storedHeaders??{},...$.configHeaders??{}},J=$.accountId?.trim()||Pz($.accessToken);if(f.originator="cline",f.session_id=$.sessionId,f["User-Agent"]=`Cline/${process.env.npm_package_version||"1.0.0"}`,J)f["ChatGPT-Account-Id"]=J;return f}function Pz($){let f=$?.trim();if(!f)return;let J=P0(f),W=J?.["https://api.openai.com/auth"]?.chatgpt_account_id;if(typeof W==="string"&&W.length>0)return W;let Z=J?.organizations?.[0]?.id;if(typeof Z==="string"&&Z.length>0)return Z;let Q=J?.chatgpt_account_id;if(typeof Q==="string"&&Q.length>0)return Q;return}function Fz($,f,J,W,Z){let Q=J.getProviderSettings($.providerId),j=W||Q?.modelCatalog?{...W??{},...Q?.modelCatalog??{}}:void 0,H={...Q??{},provider:$.providerId,model:$.modelId,apiKey:$.apiKey??Q?.apiKey,baseUrl:$.baseUrl??Q?.baseUrl,headers:$.providerId==="openai-codex"?Gz({sessionId:f,configHeaders:$.headers,storedHeaders:Q?.headers,accountId:Q?.auth?.accountId,accessToken:$.apiKey??Q?.auth?.accessToken??Q?.apiKey}):$.headers??Q?.headers,reasoning:Bz($,Q?.reasoning),modelCatalog:j},X=Z$(H);if($.knownModels)X.knownModels=$.knownModels;if($.extensionContext)X.extensionContext=$.extensionContext;let A=$.fetch??X.fetch??Z;if(A)X.fetch=A;return X}async function OX($){let{input:f,sessionId:J,providerSettingsManager:W,defaultTelemetry:Z,defaultCapabilities:Q,defaultToolPolicies:j,defaultFetch:H,onPluginEvent:X,onTeamEvent:Y,createSpawnTool:A,localRuntime:V,readSessionMetadata:B,writeSessionMetadata:K}=$,G=p$(f.config),{modelCatalogDefaults:R,userInstructionService:P,configExtensions:F,onTeamRestored:U,..._}=V??{},z=Object.keys(_).length>0?_:void 0,{workspaceInfo:D,workspaceMetadata:O,durationMs:T,vcsType:M,initError:s}=await Aj(G),Z0=z?.extensionContext,a={...Z0??{},workspace:{...D,...Z0?.workspace??{}},session:{...Z0?.session??{},sessionId:J},logger:Z0?.logger??z?.logger,telemetry:Z0?.telemetry??z?.telemetry??Z};DX({telemetry:a.telemetry,rootPath:D.rootPath,workspaceInfo:D,rootCount:1,vcsType:M,durationMs:T,initError:s,featureFlagEnabled:!0});let Q0=aJ({cwd:f.config.cwd,workspacePath:G,rootSessionId:J,logger:z?.logger,workspaceInfo:D}),l=yj(z?.hooks)?void 0:nJ({rootSessionId:J,workspacePath:G,workspaceInfo:D}),i0=I2([z?.hooks,l]),c;if(LX(F,"plugins"))try{c=await q8({pluginPaths:z?.pluginPaths,workspacePath:G,cwd:f.config.cwd,onEvent:X,providerId:f.config.providerId,modelId:f.config.modelId,workspaceInfo:D,session:a.session,client:a.client,user:a.user,logger:a.logger,telemetry:a.telemetry,automation:a.automation}),Vz(c.failures,c.warnings,z?.logger)}catch(zf){let d=zf instanceof Error?zf.message:String(zf);z?.logger?.log?.(`plugin loading failed; continuing without plugins (${d})`)}let C=HW(Q0?[Q0]:void 0,HW(z?.extensions,q6(c?.extensions))),V0=LX(F,"plugins")?bf(c?.pluginPaths??[]):void 0,p={...f.config,...z??{},sessionId:J,hooks:i0,extensions:C,extensionContext:a,telemetry:a.telemetry},u0=Fz(p,J,W,R,H),o$=I2([p.hooks,p.checkpoint?.enabled===!0?LH({cwd:p.cwd,sessionId:J,logger:p.logger,createCheckpoint:p.checkpoint?.createCheckpoint,initialRunCount:Kz(f.initialMessages),readSessionMetadata:B,writeSessionMetadata:K}):void 0]),e$={...p,providerConfig:u0,workspaceMetadata:O,hooks:o$},m1=f.toolPolicies??p.toolPolicies??j,_f=U0(Q,f.capabilities),i2=_f?.requestToolApproval,C4=_f?.toolExecutors,g1=new oJ({currentWorkspacePath:D.rootPath,workspaces:{[D.rootPath]:D}});return{effectiveInput:f,config:e$,providerConfig:u0,workspaceMetadata:O,workspaceInfo:D,extensions:C,hooks:o$,toolPolicies:m1,requestToolApproval:i2,pluginSandboxShutdown:c?.shutdown,runtimeBuilderInput:{config:e$,hooks:o$,extensions:C,onTeamEvent:Y,createSpawnTool:A,onTeamRestored:U,userInstructionService:P,pluginSkillDirectories:V0,configExtensions:F,toolExecutors:C4,workspaceManager:g1,logger:e$.logger,telemetry:e$.telemetry}}}import{resolveDocumentsExtensionPath as Uz}from"@cline/shared/storage";B0();function _X($,f,J,W,Z){if(J)u4($.telemetry,{ulid:f,apiProvider:$.providerId,...Z});else v4($.telemetry,{ulid:f,apiProvider:$.providerId,...Z});Rz($.telemetry,{workspacePath:W})}function Rz($,f){let J=Uz("Hooks"),W=Kf(f.workspacePath),Z=new Map;for(let Q of W){let j=Q.hookEventName??"unknown",H=Z.get(j)??{global:0,workspace:0};if(Q.path===J||Q.path.startsWith(`${J}/`))H.global+=1;else H.workspace+=1;Z.set(j,H)}for(let[Q,j]of Z.entries())s4($,Q,j.global,j.workspace)}function zX($,f){for(let J of f.mentions)a4($,J,f.matchedFiles.includes(J)?1:0,"file",!f.matchedFiles.includes(J));for(let J of f.matchedFiles)i4($,"file",J.length);for(let J of f.ignoredMentions)n4($,"file","not_found",J)}import{chmodSync as uX,existsSync as PZ,mkdirSync as sz,readFileSync as oz,writeFileSync as ez}from"node:fs";import{basename as cX,dirname as FZ}from"node:path";import{resolveProviderSettingsPath as $T}from"@cline/shared/storage";import{existsSync as Dz,mkdirSync as Lz,readFileSync as Oz,writeFileSync as _z}from"node:fs";import{mkdir as zz,readFile as Tz,writeFile as Nz}from"node:fs/promises";import{dirname as AZ,join as Mz}from"node:path";import*as z0 from"@cline/llms";import{ModelCapabilitySchema as yz,ProviderCapabilitySchema as qz,ProviderClientSchema as wz,ProviderProtocolSchema as Sz}from"@cline/shared";import{z as u}from"zod";var hz=u.object({id:u.string().optional(),name:u.string().optional(),maxTokens:u.number().optional(),contextWindow:u.number().optional(),maxInputTokens:u.number().optional(),capabilities:u.array(yz).optional(),supportsVision:u.boolean().optional(),supportsAttachments:u.boolean().optional(),supportsReasoning:u.boolean().optional()}).passthrough(),Cz=u.object({name:u.string(),baseUrl:u.string(),defaultModelId:u.string().optional(),protocol:Sz.optional(),client:wz.optional(),capabilities:u.array(qz).optional(),modelsSourceUrl:u.string().optional()}).passthrough(),TX=u.object({provider:Cz.optional(),models:u.record(u.string(),hz).optional()}).passthrough(),NX=u.object({version:u.literal(1),providers:u.record(u.string(),TX)}),Ez=u.object({version:u.literal(1),providers:u.record(u.string(),u.unknown())}),eJ=new Set;function MX($){return $.split(/[-_]/).filter(Boolean).map((f)=>f.charAt(0).toUpperCase()+f.slice(1)).join(" ")}function h1($){return Mz(AZ($.getFilePath()),"models.json")}function $4(){return{version:1,providers:{}}}function yX($){let f=Ez.safeParse($);if(!f.success)return $4();let J={};for(let[W,Z]of Object.entries(f.data.providers)){let Q=TX.safeParse(Z);if(Q.success)J[W]=Q.data}return{version:1,providers:J}}function VZ($){if(!Dz($))return $4();try{let f=Oz($,"utf8");return yX(JSON.parse(f))}catch{}return $4()}async function Pf($){try{let f=await Tz($,"utf8");return yX(JSON.parse(f))}catch{}return $4()}function qX($,f){Lz(AZ($),{recursive:!0});let J=NX.parse(f);_z($,`${JSON.stringify(J,null,2)}
|
|
558
|
+
`,"utf8")}async function f4($,f){await zz(AZ($),{recursive:!0});let J=NX.parse(f);await Nz($,`${JSON.stringify(J,null,2)}
|
|
559
|
+
`,"utf8")}function wX($,f){return{id:$,name:f.name??$,supportsAttachments:f.capabilities?.includes("files"),supportsVision:f.capabilities?.includes("images"),supportsReasoning:f.capabilities?.includes("reasoning")||f.thinkingConfig!=null}}function SX($){if(!$||$.length===0)return;let f=new Set;if($.includes("reasoning"))f.add("reasoning");if($.includes("prompt-cache"))f.add("prompt-cache");if($.includes("tools"))f.add("tools");return f.size>0?[...f]:void 0}function hX($){let f=new Set;if(!$||$.length===0)return[...f];if($.includes("streaming"))f.add("streaming");if($.includes("tools"))f.add("tools");if($.includes("reasoning"))f.add("reasoning");if($.includes("prompt-cache"))f.add("prompt-cache");if($.includes("vision"))f.add("images"),f.add("files");return[...f]}function bz($){return $!=null&&typeof $.name==="string"&&typeof $.baseUrl==="string"}function CX($,f){return $??f??"openai-chat"}function EX($,f,J){return $??J??(f==="openai-responses"?"openai":"openai-compatible")}function bX($,f,J){let W=new Set(f?.capabilities??J??[]);if(f?.supportsVision)W.add("images");if(f?.supportsAttachments)W.add("files");if(f?.supportsReasoning)W.add("reasoning");return{id:$,name:f?.name??$,maxTokens:f?.maxTokens,contextWindow:f?.contextWindow,maxInputTokens:f?.maxInputTokens,capabilities:W.size>0?[...W]:void 0}}function kz($,f){for(let[J,W]of Object.entries(f??{})){let Z=W.id?.trim()||J.trim();if(!Z)continue;z0.registerModel($,Z,bX(Z,W))}}function Iz($,f,J){return{...f??{},id:$,name:f?.name??$,capabilities:f?.capabilities??J}}function xz($){return Object.assign({},...z0.resolveProviderModelCatalogKeys($).map((J)=>z0.getGeneratedModelsForProvider(J)))}function mz($){let f=$.provider.trim();if(!f||z0.isBuiltInProviderId(f))return;let J=$.baseUrl?.trim();if(!J)return;let W=z0.MODEL_COLLECTIONS_BY_PROVIDER_ID[f],Z=xz(f),Q=hX($.capabilities),j=Q.length>0?Q:void 0,H=$.model?.trim(),X={...Z,...W?.models??{}};if(H)X[H]=Iz(H,X[H],j);let Y=Object.keys(X).filter(Boolean),A=H||Y[0];if(!A)return;let V=CX($.protocol,W?.provider.protocol),B=EX($.client,V,W?.provider.client);z0.registerProvider({provider:{id:f,name:W?.provider.name??MX(f),description:W?.provider.description,protocol:V,client:B,baseUrl:J,modelsSourceUrl:W?.provider.modelsSourceUrl,defaultModelId:A,capabilities:SX($.capabilities)??W?.provider.capabilities,source:"file"},models:X})}function J4($){for(let f of Object.values($.providers))mz(f.settings)}function x2($,f){let J=f.models??{};if(!bz(f.provider)){kz($,J);return}let W=hX(f.provider.capabilities),Z=Object.entries(J).map(([Y,A])=>({id:A.id?.trim()||Y.trim(),model:A})).filter(({id:Y})=>Y.length>0),Q=f.provider.defaultModelId?.trim()||Z[0]?.id||"default",j=CX(f.provider.protocol,void 0),H=EX(f.provider.client,j,void 0),X=Object.fromEntries(Z.map(({id:Y,model:A})=>[Y,{...bX(Y,A,W.length>0?W:void 0),status:"active"}]));z0.registerProvider({provider:{id:$,name:f.provider.name.trim()||MX($),protocol:j,client:H,baseUrl:f.provider.baseUrl,modelsSourceUrl:f.provider.modelsSourceUrl,defaultModelId:Q,capabilities:SX(f.provider.capabilities),source:"file"},models:X})}function kX($){let f=h1($);if(eJ.has(f))return;let J=VZ(f);for(let[W,Z]of Object.entries(J.providers))x2(W,Z);eJ.add(f)}async function IX($){let f=h1($);if(eJ.has(f))return;let J=await Pf(f);for(let[W,Z]of Object.entries(J.providers))x2(W,Z);eJ.add(f)}import{existsSync as gz,readFileSync as vz}from"node:fs";import{dirname as uz,join as BZ}from"node:path";import*as Z4 from"@cline/llms";import{resolveClineDataDir as cz}from"@cline/shared/storage";var W4="openai",gX=Z4.BUILT_IN_PROVIDER.OPENAI_COMPATIBLE,xX=128000;function vX($){let f=$?.trim();if(!f)return;try{let J=JSON.parse(f);if(!J)return;let W=typeof J.expiresAt==="number"&&Number.isFinite(J.expiresAt)?J.expiresAt<10000000000?J.expiresAt*1000:J.expiresAt:void 0;return{accessToken:J.idToken,refreshToken:J.refreshToken,expiresAt:W,accountId:J.userInfo?.id}}catch{return}}function q($){let f=$?.trim();return f?f:void 0}function mX($){if(!gz($))return;try{let f=vz($,"utf8"),J=JSON.parse(f);if(J&&typeof J==="object"&&!Array.isArray(J))return J}catch{}return}function dz($){let f=$.dataDir??cz(),J=$.globalStatePath??BZ(f,"globalState.json"),W=$.secretsPath??BZ(f,"secrets.json"),Z=mX(J),Q=mX(W);if(!Z&&!Q)return;return{globalState:Z??{},secrets:Q??{}}}function KZ($){if($===W4)return gX;return $}function lz($,f,J,W){let Z=J==="plan"?"planMode":"actMode",Q=f===W?q(J==="plan"?$.planModeApiModelId:$.actModeApiModelId):void 0,H={openrouter:`${Z}OpenRouterModelId`,cline:`${Z}ClineModelId`,openai:`${Z}OpenAiModelId`,ollama:`${Z}OllamaModelId`,lmstudio:`${Z}LmStudioModelId`,litellm:`${Z}LiteLlmModelId`,requesty:`${Z}RequestyModelId`,together:`${Z}TogetherModelId`,fireworks:`${Z}FireworksModelId`,sapaicore:`${Z}SapAiCoreModelId`,groq:`${Z}GroqModelId`,baseten:`${Z}BasetenModelId`,huggingface:`${Z}HuggingFaceModelId`,"huawei-cloud-maas":`${Z}HuaweiCloudMaasModelId`,oca:`${Z}OcaModelId`,aihubmix:`${Z}AihubmixModelId`,hicap:`${Z}HicapModelId`,nousResearch:`${Z}NousResearchModelId`,"vercel-ai-gateway":`${Z}VercelAiGatewayModelId`}[f];return(H?q(typeof $[H]==="string"?$[H]:void 0):void 0)??Q}function pz($,f,J){let W=J==="plan"?$.planModeReasoningEffort:$.actModeReasoningEffort,Z=J==="plan"?$.geminiPlanModeThinkingLevel:$.geminiActModeThinkingLevel,Q=J==="plan"?$.planModeThinkingBudgetTokens:$.actModeThinkingBudgetTokens,j=(f==="gemini"?Z:void 0)??W,H=j==="none"||j==="low"||j==="medium"||j==="high"?j:void 0,X=typeof Q==="number"&&Number.isInteger(Q)&&Q>0?Q:void 0;if(!H&&X===void 0)return;return{...H?{effort:H}:{},...X!==void 0?{budgetTokens:X}:{}}}function rz($){let f=$["openai-codex-oauth-credentials"];if(!f)return;try{let J=JSON.parse(f),W=q(J.access_token),Z=q(J.refresh_token),Q=q(J.accountId);if(!W&&!Z&&!Q)return;return{...W?{apiKey:W}:{},auth:{...W?{accessToken:W}:{},...Z?{refreshToken:Z}:{},...Q?{accountId:Q}:{}}}}catch{return}}function iz($){let f=Z4.getGeneratedModelsForProvider($);return Object.keys(f)[0]??void 0}function nz($,f,J,W){let Z=KZ($),Q=q(W==="plan"?f.planModeApiProvider:f.actModeApiProvider),j=lz(f,$,W,Q)??iz(Z),H=pz(f,Z,W),X=typeof f.requestTimeoutMs==="number"&&Number.isInteger(f.requestTimeoutMs)&&f.requestTimeoutMs>0?f.requestTimeoutMs:void 0,Y={anthropic:J.apiKey,cline:J.clineApiKey,openai:J.openAiApiKey,"openai-native":J.openAiNativeApiKey,openrouter:J.openRouterApiKey,bedrock:J.awsBedrockApiKey,gemini:J.geminiApiKey,ollama:J.ollamaApiKey,deepseek:J.deepSeekApiKey,requesty:J.requestyApiKey,together:J.togetherApiKey,fireworks:J.fireworksApiKey,qwen:J.qwenApiKey,doubao:J.doubaoApiKey,mistral:J.mistralApiKey,litellm:J.liteLlmApiKey,asksage:J.asksageApiKey,xai:J.xaiApiKey,moonshot:J.moonshotApiKey,zai:J.zaiApiKey,huggingface:J.huggingFaceApiKey,nebius:J.nebiusApiKey,sambanova:J.sambanovaApiKey,cerebras:J.cerebrasApiKey,groq:J.groqApiKey,"huawei-cloud-maas":J.huaweiCloudMaasApiKey,baseten:J.basetenApiKey,"vercel-ai-gateway":J.vercelAiGatewayApiKey,dify:J.difyApiKey,minimax:J.minimaxApiKey,hicap:J.hicapApiKey,aihubmix:J.aihubmixApiKey,nousResearch:J.nousResearchApiKey,oca:J.ocaApiKey},A={};if($==="openai-codex")Object.assign(A,rz(J));if($==="cline")try{let F=q(J["cline:clineAccountId"]);if(F)A.auth={...A.auth??{},...vX(F)}}catch{}if($===W4&&f.openAiHeaders)A.headers=f.openAiHeaders;if($==="bedrock"){let F=f.awsAuthentication==="profile"||f.awsUseProfile===!0;A.aws={accessKey:q(J.awsAccessKey),secretKey:q(J.awsSecretKey),sessionToken:q(J.awsSessionToken),region:q(f.awsRegion),authentication:f.awsAuthentication,profile:F?q(f.awsProfile):void 0,usePromptCache:f.awsBedrockUsePromptCache,useCrossRegionInference:f.awsUseCrossRegionInference,useGlobalInference:f.awsUseGlobalInference,endpoint:q(f.awsBedrockEndpoint),customModelBaseId:q(W==="plan"?f.planModeAwsBedrockCustomModelBaseId:f.actModeAwsBedrockCustomModelBaseId)}}if($==="vertex")A.gcp={projectId:q(f.vertexProjectId),region:q(f.vertexRegion)};if($===W4&&(f.azureApiVersion||f.azureIdentity!==void 0))A.azure={apiVersion:q(f.azureApiVersion),useIdentity:f.azureIdentity};if($==="sapaicore")A.sap={clientId:q(J.sapAiCoreClientId),clientSecret:q(J.sapAiCoreClientSecret),tokenUrl:q(f.sapAiCoreTokenUrl),resourceGroup:q(f.sapAiResourceGroup),deploymentId:q(W==="plan"?f.planModeSapAiCoreDeploymentId:f.actModeSapAiCoreDeploymentId),useOrchestrationMode:f.sapAiCoreUseOrchestrationMode};if($==="oca"){A.oca={mode:f.ocaMode};let F=q(J.ocaRefreshToken);if(F)A.auth={...A.auth??{},refreshToken:F}}if($==="qwen")A.apiLine=f.qwenApiLine;if($==="moonshot")A.apiLine=f.moonshotApiLine;if($==="zai")A.apiLine=f.zaiApiLine;if($==="minimax")A.apiLine=f.minimaxApiLine;let V={anthropic:f.anthropicBaseUrl,openai:f.openAiBaseUrl,ollama:f.ollamaBaseUrl,lmstudio:f.lmStudioBaseUrl,litellm:f.liteLlmBaseUrl,gemini:f.geminiBaseUrl,requesty:f.requestyBaseUrl,asksage:f.asksageApiUrl,dify:f.difyBaseUrl,oca:f.ocaBaseUrl,aihubmix:f.aihubmixBaseUrl,sapaicore:f.sapAiCoreBaseUrl},B=q(Y[$]),K=q(V[$]),G={provider:Z,...B?{apiKey:B}:{},...j?{model:j}:{},...K?{baseUrl:K}:{},...H?{reasoning:H}:{},...X?{timeout:X}:{},...A},R=tJ.safeParse(G);if(!R.success)return;return Object.keys(G).filter((F)=>F!=="provider").length>0?R.data:void 0}function az($,f){if($!==gX)return;if(!f.baseUrl||!f.model)return;return{provider:{name:"OpenAI Compatible",baseUrl:f.baseUrl,defaultModelId:f.model},models:{[f.model]:{id:f.model,name:f.model,contextWindow:xX,maxInputTokens:xX,capabilities:["streaming","tools","images"]}}}}function tz($,f){let J=new Set;for(let Z of[$.actModeApiProvider,$.planModeApiProvider]){let Q=q(Z);if(Q)J.add(Q)}if(q(f.apiKey))J.add("anthropic");if(q(f.openRouterApiKey))J.add("openrouter");if(q(f.openAiApiKey))J.add(W4);if(q(f.openAiNativeApiKey))J.add("openai-native");if(q(f["openai-codex-oauth-credentials"]))J.add("openai-codex");if(q(f.geminiApiKey))J.add("gemini");if(q(f.ollamaApiKey))J.add("ollama");if(q(f.awsAccessKey)||q(f.awsBedrockApiKey)||$.awsAuthentication!==void 0||$.awsUseProfile===!0||q($.awsProfile))J.add("bedrock");if(q($.vertexProjectId)||q($.vertexRegion))J.add("vertex");if(q(f.clineApiKey))J.add("cline");let W=vX(q(f["cline:clineAccountId"]));if(W?.accessToken||W?.refreshToken||W?.accountId)J.add("cline");if(q(f.ocaApiKey))J.add("oca");if(q(f.sapAiCoreClientId)||q(f.sapAiCoreClientSecret)||q($.sapAiCoreTokenUrl)||q($.sapAiCoreBaseUrl)||q($.sapAiResourceGroup)||$.sapAiCoreUseOrchestrationMode!==void 0)J.add("sapaicore");return J}function GZ($){let f=$.providerSettingsManager.read(),J=dz($);if(!J)return{migrated:!1,providerCount:Object.keys(f.providers).length,lastUsedProvider:f.lastUsedProvider};let{globalState:W,secrets:Z}=J,Q=W.mode==="plan"?"plan":"act",j=tz(W,Z),H=Gf();H.providers={...f.providers},H.lastUsedProvider=f.lastUsedProvider;let X=new Date().toISOString(),Y=0,A=BZ(uz($.providerSettingsManager.getFilePath()),"models.json"),V=VZ(A),B=0;for(let R of j){let P=KZ(R);if(H.providers[P])continue;let F=nz(R,W,Z,Q);if(!F)continue;H.providers[P]={settings:F,updatedAt:X,tokenSource:"migration"},Y+=1;let U=az(P,F);if(U&&!V.providers[P])V.providers[P]=U,B+=1}if(Y===0&&B===0)return{migrated:!1,providerCount:Object.keys(f.providers).length,lastUsedProvider:f.lastUsedProvider};let K=q(Q==="plan"?W.planModeApiProvider:W.actModeApiProvider),G=K?KZ(K):void 0;if(H.lastUsedProvider=f.lastUsedProvider??(G&&H.providers[G]?G:Object.keys(H.providers)[0]),$.providerSettingsManager.write(H),B>0)qX(A,V);return{migrated:Y>0||B>0,providerCount:Object.keys(H.providers).length,lastUsedProvider:H.lastUsedProvider}}function fT(){return new Date().toISOString()}function JT($){if(cX($)!=="providers.json")return;let f=FZ($);if(cX(f)!=="settings")return;return FZ(f)}class n${filePath;dataDir;constructor($={}){if(this.filePath=$.filePath??$T(),this.dataDir=$.dataDir??JT(this.filePath),this.dataDir||!$.filePath)GZ({providerSettingsManager:this,dataDir:this.dataDir});if(kX(this),J4(this.read()),PZ(this.filePath))try{uX(this.filePath,384)}catch{}}getFilePath(){return this.filePath}read(){if(!PZ(this.filePath))return Gf();try{let $=oz(this.filePath,"utf8"),f=JSON.parse($),J=sJ.safeParse(f);if(J.success)return J4(J.data),J.data}catch{}return Gf()}write($){let f=sJ.parse($),J=FZ(this.filePath);if(!PZ(J))sz(J,{recursive:!0,mode:448});ez(this.filePath,`${JSON.stringify(f,null,2)}
|
|
560
|
+
`,"utf8");try{uX(this.filePath,384)}catch{}J4(f)}saveProviderSettings($,f={}){let J=tJ.parse($),W=this.read(),Z=J.provider,Q=f.setLastUsed!==!1,j=W.providers[Z],H=f.tokenSource??j?.tokenSource??"manual",X={...W,providers:{...W.providers,[Z]:{settings:J,updatedAt:fT(),tokenSource:H}},lastUsedProvider:Q?Z:W.lastUsedProvider};return this.write(X),X}getProviderSettings($){return this.read().providers[$]?.settings}getLastUsedProviderSettings(){let $=this.read(),f=$.lastUsedProvider;if(!f)return;return $.providers[f]?.settings}getProviderConfig($,f){let J=this.getProviderSettings($);if(!J)return;return Z$(J,f)}getLastUsedProviderConfig($){let f=this.getLastUsedProviderSettings();if(!f)return;return Z$(f,$)}async refreshCatalog(){try{await K8({})}catch{}}}B0();EJ();import{execFile as WT}from"node:child_process";import{promisify as ZT}from"node:util";var Ff=ZT(WT);function UZ($){let f=$?.metadata?.checkpoint&&typeof $.metadata.checkpoint==="object"&&!Array.isArray($.metadata.checkpoint)?$.metadata.checkpoint:void 0;return(Array.isArray(f?.history)?f.history:[]).filter((W)=>!!W&&typeof W==="object"&&!Array.isArray(W)).flatMap((W)=>{let Z=String(W.ref??"").trim(),Q=Number(W.createdAt??0),j=Number(W.runCount??0);if(Z.length===0||!Number.isFinite(Q)||!Number.isInteger(j)||j<1)return[];let H=W.kind==="stash"||W.kind==="commit"?W.kind:void 0;return[{ref:Z,createdAt:Q,runCount:j,...H?{kind:H}:{}}]})}function dX($,f){let J=UZ($).filter((Z)=>Z.runCount<=f),W=J.at(-1);return W?{latest:W,history:J}:void 0}function QT($,f){return $.reduce((J,W)=>{if(W.runCount>f)return J;if(!J||W.runCount>J.runCount)return W;return J},void 0)}function lX($,f){let J=0;for(let W=0;W<$.length;W+=1){let Z=$[W];if(Z?.role!=="user")continue;if(("metadata"in Z&&Z.metadata&&typeof Z.metadata==="object"?Z.metadata:void 0)?.kind==="recovery_notice")continue;if(J+=1,J===f)return W}throw Error(`Could not find user message for checkpoint run ${f}`)}function jT($,f){let J=lX($,f);return $.slice(0,J+1)}function pX($,f){let J=lX($,f);return $.slice(0,J)}function rX($){let f=$.checkpointRunCount;if(!Number.isInteger(f)||f<1)throw Error("checkpointRunCount must be a positive integer");let J=QT(UZ($.session),f);if(!J)throw Error(`No checkpoint found at or before run ${f} in session ${$.session.sessionId}`);let W=($.cwd?.trim()||$.session.cwd||$.session.workspaceRoot).trim();if(!W)throw Error("cwd or workspaceRoot is required to restore a checkpoint");return{checkpoint:J,cwd:W,...$.restoreMessages!==!1?{messages:jT($.messages??[],f)}:{}}}async function iX($,f){if((await Ff("git",["-C",$,"rev-parse","--is-inside-work-tree"],{windowsHide:!0})).stdout.trim()!=="true")throw Error(`${$} is not a git repository`);if(await Ff("git",["-C",$,"cat-file","-e",`${f.ref}^{commit}`],{windowsHide:!0}),await Ff("git",["-C",$,"reset","--hard"],{windowsHide:!0}),await Ff("git",["-C",$,"clean","-fd"],{windowsHide:!0}),f.kind==="commit"){await Ff("git",["-C",$,"reset","--hard",f.ref],{windowsHide:!0});return}await Ff("git",["-C",$,"stash","apply",f.ref],{windowsHide:!0})}class p0 extends Error{code;constructor($,f){super(f);this.code=$;this.name="SessionVersioningError"}}function HT($){let f=$.sessionId.trim();if(!f)throw new p0("invalid_restore","sessionId is required");if(!$.restoreMessages&&!$.restoreWorkspace)throw new p0("invalid_restore","restore.messages or restore.workspace must be true");if($.restoreMessages&&$.requiresStart)throw new p0("invalid_restore","start is required when restore.messages is true");if(!Number.isInteger($.checkpointRunCount)||$.checkpointRunCount<1)throw new p0("invalid_restore","checkpointRunCount must be a positive integer");return f}class Uf{async restoreCheckpoint($){let f=$.restore?.messages!==!1,J=$.restore?.workspace!==!1,W=HT({sessionId:$.sessionId,restoreMessages:f,restoreWorkspace:J,requiresStart:$.start===void 0,checkpointRunCount:$.checkpointRunCount}),Z=await $.getSession(W);if(!Z)throw new p0("session_not_found",`Session ${W} not found`);let Q=f?await $.readMessages(W):void 0;if(f&&Q?.length===0)throw new p0("session_messages_not_found",`No messages found for session ${W}`);let j=rX({session:Z,messages:Q,checkpointRunCount:$.checkpointRunCount,cwd:$.cwd,restoreMessages:f});if(J)await($.applyWorkspaceCheckpoint??iX)(j.cwd,j.checkpoint);let H=g$({session:Z,messages:Q});if(!f)return{checkpoint:j.checkpoint,sourceSnapshot:H};let X=dX(Z,$.checkpointRunCount),Y=$.restore?.omitCheckpointMessageFromSession?pX(Q??[],$.checkpointRunCount):j.messages??[],A={sourceSession:Z,sourceMessages:Q,sourceSnapshot:H,plan:j,restoredCheckpointMetadata:X,initialMessages:Y,restoreMessages:f,restoreWorkspace:J,checkpointRunCount:$.checkpointRunCount};if(!$.start||!$.startSession)throw new p0("invalid_restore","start is required when restore.messages is true");let V=$.buildStartInput?await $.buildStartInput(A,$.start):$.start,B=await $.startSession(V),K=$.getStartedSessionId?.(B);if(K)await($.retainCheckpointRefs??DH)(j.cwd,K,X?.history??[]);let G=K&&$.readRestoredSession?await $.readRestoredSession(K):void 0;return{sessionId:K,startResult:B,messages:j.messages,checkpoint:j.checkpoint,sourceSnapshot:H,...G?{restoredSnapshot:g$({session:G,messages:Y})}:{}}}}import{hasRuntimeConfigExtension as OT}from"@cline/shared";import{nanoid as _T}from"nanoid";n0();import{appendFileSync as XT,existsSync as Rf,mkdirSync as nX,readdirSync as YT,readFileSync as aX,renameSync as AT,writeFileSync as VT}from"node:fs";import{join as RZ}from"node:path";import{resolveTeamDataDir as BT}from"@cline/shared/storage";function tX(){return new Date().toISOString()}function DZ($){return $.toLowerCase().replace(/[^a-z0-9._-]+/g,"-").replace(/^-+|-+$/g,"")}function sX($){return{...$,tasks:$.tasks.map((f)=>({...f,createdAt:new Date(f.createdAt),updatedAt:new Date(f.updatedAt)})),mailbox:$.mailbox.map((f)=>({...f,sentAt:new Date(f.sentAt),readAt:f.readAt?new Date(f.readAt):void 0})),missionLog:$.missionLog.map((f)=>({...f,ts:new Date(f.ts)})),runs:($.runs??[]).map((f)=>({...f,startedAt:new Date(f.startedAt),endedAt:f.endedAt?new Date(f.endedAt):void 0,nextAttemptAt:f.nextAttemptAt?new Date(f.nextAttemptAt):void 0,heartbeatAt:f.heartbeatAt?new Date(f.heartbeatAt):void 0})),outcomes:($.outcomes??[]).map((f)=>({...f,createdAt:new Date(f.createdAt),finalizedAt:f.finalizedAt?new Date(f.finalizedAt):void 0})),outcomeFragments:($.outcomeFragments??[]).map((f)=>({...f,createdAt:new Date(f.createdAt),reviewedAt:f.reviewedAt?new Date(f.reviewedAt):void 0}))}}class Q4{teamDirPath;constructor($={}){this.teamDirPath=$.teamDir??BT()}init(){this.ensureTeamDir()}listTeamNames(){if(!Rf(this.teamDirPath))return[];return YT(this.teamDirPath,{withFileTypes:!0}).filter(($)=>$.isDirectory()).filter(($)=>Rf(this.statePath($.name))).map(($)=>$.name).sort()}readState($){let f=this.readEnvelope($);return f?.teamState?sX(f.teamState):void 0}readHistory($,f=200){let J=this.historyPath($);if(!Rf(J))return[];return aX(J,"utf8").split(`
|
|
561
|
+
`).map((W)=>W.trim()).filter(Boolean).map((W)=>{try{return JSON.parse(W)}catch{return}}).filter((W)=>W!==void 0).reverse().slice(0,f)}loadRuntime($){let f=this.readEnvelope($);return{state:f?.teamState?sX(f.teamState):void 0,teammates:f?.teammates??[],interruptedRunIds:[]}}handleTeamEvent($,f){this.ensureTeamSubdir($),XT(this.historyPath($),`${JSON.stringify({ts:tX(),eventType:f.type,payload:f})}
|
|
562
|
+
`,"utf8")}persistRuntime($,f,J){this.ensureTeamSubdir($);let W={version:1,updatedAt:tX(),teamState:f,teammates:J},Z=this.statePath($),Q=`${Z}.tmp`;VT(Q,`${JSON.stringify(W,null,2)}
|
|
563
|
+
`,"utf8"),AT(Q,Z)}markInProgressRunsInterrupted($,f){let J=this.readEnvelope($);if(!J?.teamState?.runs?.length)return[];let W=J.teamState.runs.filter((Q)=>Q.status==="queued"||Q.status==="running").map((Q)=>Q.id);if(W.length===0)return[];let Z=new Date;return J.teamState={...J.teamState,runs:J.teamState.runs.map((Q)=>Q.status==="queued"||Q.status==="running"?{...Q,status:"interrupted",error:f,endedAt:Z}:Q)},this.persistRuntime($,J.teamState,J.teammates),W}ensureTeamDir(){if(!Rf(this.teamDirPath))nX(this.teamDirPath,{recursive:!0});return this.teamDirPath}ensureTeamSubdir($){let f=RZ(this.ensureTeamDir(),DZ($));if(!Rf(f))nX(f,{recursive:!0});return f}statePath($){return RZ(this.ensureTeamDir(),DZ($),"state.json")}historyPath($){return RZ(this.ensureTeamDir(),DZ($),"task-history.jsonl")}readEnvelope($){let f=this.statePath($);if(!Rf(f))return;try{let J=JSON.parse(aX(f,"utf8"));if(J?.version===1&&J.teamState)return J}catch{}return}}import{existsSync as KT,mkdirSync as GT}from"node:fs";import{join as PT}from"node:path";import{safeJsonParse as oX}from"@cline/shared";import{loadSqliteDb as FT,nowIso as LZ}from"@cline/shared/db";import{resolveDbDataDir as UT}from"@cline/shared/storage";function RT(){return UT()}function Df($){return $.toLowerCase().replace(/[^a-z0-9._-]+/g,"-").replace(/^-+|-+$/g,"")}function DT($){let f=oX($);if(!Array.isArray(f))return[];let J=[];for(let W of f){if(!W||typeof W!=="object")continue;let Z=W,Q=Z.agentId,j=Z.rolePrompt;if(typeof Q!=="string"||!Q.trim())continue;if(typeof j!=="string"||!j.trim())continue;let H={agentId:Q.trim(),rolePrompt:j};if(typeof Z.modelId==="string"&&Z.modelId.trim())H.modelId=Z.modelId.trim();if(typeof Z.maxIterations==="number"&&Number.isFinite(Z.maxIterations))H.maxIterations=Math.max(1,Math.floor(Z.maxIterations));J.push(H)}return J}function LT($){return{...$,tasks:$.tasks.map((f)=>({...f,createdAt:new Date(f.createdAt),updatedAt:new Date(f.updatedAt)})),mailbox:$.mailbox.map((f)=>({...f,sentAt:new Date(f.sentAt),readAt:f.readAt?new Date(f.readAt):void 0})),missionLog:$.missionLog.map((f)=>({...f,ts:new Date(f.ts)})),runs:($.runs??[]).map((f)=>({...f,startedAt:new Date(f.startedAt),endedAt:f.endedAt?new Date(f.endedAt):void 0,nextAttemptAt:f.nextAttemptAt?new Date(f.nextAttemptAt):void 0,heartbeatAt:f.heartbeatAt?new Date(f.heartbeatAt):void 0})),outcomes:($.outcomes??[]).map((f)=>({...f,createdAt:new Date(f.createdAt),finalizedAt:f.finalizedAt?new Date(f.finalizedAt):void 0})),outcomeFragments:($.outcomeFragments??[]).map((f)=>({...f,createdAt:new Date(f.createdAt),reviewedAt:f.reviewedAt?new Date(f.reviewedAt):void 0}))}}class m2{teamDirPath;db;constructor($={}){this.teamDirPath=$.teamDir??RT()}init(){this.getRawDb()}ensureTeamDir(){if(!KT(this.teamDirPath))GT(this.teamDirPath,{recursive:!0});return this.teamDirPath}dbPath(){return PT(this.ensureTeamDir(),"teams.db")}getRawDb(){if(this.db)return this.db;let $=FT(this.dbPath());return this.ensureSchema($),this.db=$,$}ensureSchema($){if($.exec("PRAGMA journal_mode = WAL;"),$.exec("PRAGMA busy_timeout = 5000;"),$.exec(`
|
|
564
564
|
CREATE TABLE IF NOT EXISTS team_store_schema_version (
|
|
565
565
|
lock INTEGER PRIMARY KEY CHECK (lock = 1),
|
|
566
566
|
version INTEGER NOT NULL
|
|
@@ -644,13 +644,13 @@ ${$.summary}`,metadata:{kind:"compaction_summary",summary:$.summary,details:$.fi
|
|
|
644
644
|
version INTEGER NOT NULL DEFAULT 1,
|
|
645
645
|
PRIMARY KEY(team_name, fragment_id)
|
|
646
646
|
);
|
|
647
|
-
`)}run($,f=[]){return this.getRawDb().prepare($).run(...f)}queryOne($,f=[]){return this.getRawDb().prepare($).get(...f)??void 0}queryAll($,f=[]){return this.getRawDb().prepare($).all(...f)}withTransaction($){let f=this.getRawDb();f.exec("BEGIN IMMEDIATE;");try{$(),f.exec("COMMIT;")}catch(J){try{f.exec("ROLLBACK;")}catch{}throw J}}listTeamNames(){return this.queryAll("SELECT team_name FROM team_runtime_snapshot ORDER BY team_name ASC").map(($)=>$.team_name)}readState($){let f=this.queryOne("SELECT team_name, state_json, teammates_json, updated_at FROM team_runtime_snapshot WHERE team_name = ?",[
|
|
648
|
-
VALUES (?, ?, ?, ?, NULL, ?)`,[
|
|
647
|
+
`)}run($,f=[]){return this.getRawDb().prepare($).run(...f)}queryOne($,f=[]){return this.getRawDb().prepare($).get(...f)??void 0}queryAll($,f=[]){return this.getRawDb().prepare($).all(...f)}withTransaction($){let f=this.getRawDb();f.exec("BEGIN IMMEDIATE;");try{$(),f.exec("COMMIT;")}catch(J){try{f.exec("ROLLBACK;")}catch{}throw J}}listTeamNames(){return this.queryAll("SELECT team_name FROM team_runtime_snapshot ORDER BY team_name ASC").map(($)=>$.team_name)}readState($){let f=this.queryOne("SELECT team_name, state_json, teammates_json, updated_at FROM team_runtime_snapshot WHERE team_name = ?",[Df($)]);if(!f)return;let J=oX(f.state_json);if(!J)return;try{return LT(J)}catch{return}}readHistory($,f=200){return this.queryAll("SELECT event_type, payload_json, ts FROM team_events WHERE team_name = ? ORDER BY id DESC LIMIT ?",[Df($),f]).flatMap((J)=>{try{return[{eventType:J.event_type,payload:JSON.parse(J.payload_json),ts:J.ts}]}catch{return[]}})}loadRuntime($){let f=Df($),J=this.readState(f),W=this.queryOne("SELECT team_name, state_json, teammates_json, updated_at FROM team_runtime_snapshot WHERE team_name = ?",[f]),Z=W?DT(W.teammates_json):[];return{state:J,teammates:Z,interruptedRunIds:[]}}appendTeamEvent($,f,J,W){this.run(`INSERT INTO team_events (team_name, ts, event_type, payload_json, causation_id, correlation_id)
|
|
648
|
+
VALUES (?, ?, ?, ?, NULL, ?)`,[Df($),LZ(),f,JSON.stringify(J),W??null])}persistRuntime($,f,J){let W=Df($),Z=LZ();this.withTransaction(()=>{this.run(`INSERT INTO team_runtime_snapshot (team_name, state_json, teammates_json, updated_at)
|
|
649
649
|
VALUES (?, ?, ?, ?)
|
|
650
650
|
ON CONFLICT(team_name) DO UPDATE SET
|
|
651
651
|
state_json = excluded.state_json,
|
|
652
652
|
teammates_json = excluded.teammates_json,
|
|
653
|
-
updated_at = excluded.updated_at`,[
|
|
653
|
+
updated_at = excluded.updated_at`,[W,JSON.stringify(f),JSON.stringify(J),Z]);for(let Q of f.tasks)this.run(`INSERT INTO team_tasks (team_name, task_id, title, description, status, assignee, depends_on_json, summary, version, updated_at)
|
|
654
654
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, 1, ?)
|
|
655
655
|
ON CONFLICT(team_name, task_id) DO UPDATE SET
|
|
656
656
|
title = excluded.title,
|
|
@@ -660,7 +660,7 @@ ${$.summary}`,metadata:{kind:"compaction_summary",summary:$.summary,details:$.fi
|
|
|
660
660
|
depends_on_json = excluded.depends_on_json,
|
|
661
661
|
summary = excluded.summary,
|
|
662
662
|
version = team_tasks.version + 1,
|
|
663
|
-
updated_at = excluded.updated_at`,[Q
|
|
663
|
+
updated_at = excluded.updated_at`,[W,Q.id,Q.title,Q.description,Q.status,Q.assignee??null,JSON.stringify(Q.dependsOn??[]),Q.summary??null,Q.updatedAt.toISOString()]);for(let Q of f.runs??[])this.run(`INSERT INTO team_runs (team_name, run_id, agent_id, task_id, status, message, started_at, ended_at, error, lease_owner, heartbeat_at, version)
|
|
664
664
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, 1)
|
|
665
665
|
ON CONFLICT(team_name, run_id) DO UPDATE SET
|
|
666
666
|
agent_id = excluded.agent_id,
|
|
@@ -672,14 +672,14 @@ ${$.summary}`,metadata:{kind:"compaction_summary",summary:$.summary,details:$.fi
|
|
|
672
672
|
error = excluded.error,
|
|
673
673
|
lease_owner = excluded.lease_owner,
|
|
674
674
|
heartbeat_at = excluded.heartbeat_at,
|
|
675
|
-
version = team_runs.version + 1`,[Q
|
|
675
|
+
version = team_runs.version + 1`,[W,Q.id,Q.agentId,Q.taskId??null,Q.status,Q.message,Q.startedAt?Q.startedAt.toISOString():null,Q.endedAt?Q.endedAt.toISOString():null,Q.error??null,Q.leaseOwner??null,Q.heartbeatAt?Q.heartbeatAt.toISOString():null]);for(let Q of f.outcomes??[])this.run(`INSERT INTO team_outcomes (team_name, outcome_id, title, status, schema_json, finalized_at, version)
|
|
676
676
|
VALUES (?, ?, ?, ?, ?, ?, 1)
|
|
677
677
|
ON CONFLICT(team_name, outcome_id) DO UPDATE SET
|
|
678
678
|
title = excluded.title,
|
|
679
679
|
status = excluded.status,
|
|
680
680
|
schema_json = excluded.schema_json,
|
|
681
681
|
finalized_at = excluded.finalized_at,
|
|
682
|
-
version = team_outcomes.version + 1`,[Q
|
|
682
|
+
version = team_outcomes.version + 1`,[W,Q.id,Q.title,Q.status,JSON.stringify({requiredSections:Q.requiredSections}),Q.finalizedAt?Q.finalizedAt.toISOString():null]);for(let Q of f.outcomeFragments??[])this.run(`INSERT INTO team_outcome_fragments (team_name, outcome_id, fragment_id, section, source_agent_id, source_run_id, content, status, reviewed_by, reviewed_at, version)
|
|
683
683
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, 1)
|
|
684
684
|
ON CONFLICT(team_name, fragment_id) DO UPDATE SET
|
|
685
685
|
outcome_id = excluded.outcome_id,
|
|
@@ -690,28 +690,28 @@ ${$.summary}`,metadata:{kind:"compaction_summary",summary:$.summary,details:$.fi
|
|
|
690
690
|
status = excluded.status,
|
|
691
691
|
reviewed_by = excluded.reviewed_by,
|
|
692
692
|
reviewed_at = excluded.reviewed_at,
|
|
693
|
-
version = team_outcome_fragments.version + 1`,[Q
|
|
694
|
-
WHERE team_name = ? AND status IN ('queued', 'running')`,[f,Z,J]),Q.map((W)=>W.run_id)}handleTeamEvent($,f){this.appendTeamEvent($,f.type,f)}}function HH($={}){try{let f=new L8($);return f.init(),f}catch{let f=new I6({teamDir:$.teamDir});return f.init(),f}}function i9($,f){return X_($,f)}function Y_($,f){let J=f?.["*"]??{},Q=f?.[$]??{};return{...J,...Q}.enabled!==!1}function V_($,f){return $.filter((J)=>Y_(J.name,f))}function YH($,f){return l1(V_($,f))}function VH(){return`team-${H_(5)}`}function n9($,f,J,Q,Z,W,j,X){let H=r0[N$({mode:J})],Y=L2(f,Q,J,Z??R2);return YH(M2({cwd:$,...H,enableSkills:!!j,...Y,executors:{...j?{skills:j}:{},...X??{}}}),W)}function A_($){return n9($.cwd,$.providerId,$.mode,$.modelId,$.toolRoutingRules,$.toolPolicies,B_,$.toolExecutors).some((f)=>f.name==="skills")}var B_=async()=>"";async function G_($){let f=C0();if(!X1({filePath:f}))return{tools:[]};let J=new b2({clientFactory:b4({settingsPath:f})}),Q;try{Q=await E2(J,{filePath:f})}catch(X){await J.dispose().catch(()=>{});let H=X instanceof Error?X.message:String(X);return $?.log(`[mcp] Failed to load MCP settings, skipping MCP tools: ${H}`),{tools:[]}}let Z=Q.filter((X)=>X.disabled!==!0),W=await Promise.allSettled(Z.map((X)=>I4({serverName:X.name,provider:J}))),j=[];for(let[X,H]of W.entries())if(H.status==="fulfilled")j.push(...H.value);else{let Y=H.reason instanceof Error?H.reason.message:String(H.reason);$?.log(`[mcp] Failed to load tools from MCP server "${Z[X].name}", skipping: ${Y}`)}return{tools:j,shutdown:async()=>{await J.dispose()}}}function K_($,f){if(!$)return;for(let J of $.getTeammateIds())try{$.shutdownTeammate(J,f)}catch{}}function F_($){if($===void 0)return!0;switch($){case"session_stop":case"session_complete":case"session_error":case"session_manager_dispose":case"cli_run_shutdown":case"cli_interactive_shutdown":case"cli_interactive_startup_cancelled":case"provider_change":case"acp_shutdown":case"hub_server_stop":case"vscode_webview_dispose":return!0;default:return!1}}function P_($){let f=r0[N$({mode:$.mode})];return{sessionId:$.sessionId||"",mode:$.mode==="plan"?"plan":$.mode==="yolo"?"yolo":"act",enableTools:$.enableTools!==!1,enableSpawnAgent:$.enableSpawnAgent??f.enableSpawnAgent??!0,enableAgentTeams:$.enableAgentTeams??f.enableAgentTeams??!0,disableMcpSettingsTools:$.disableMcpSettingsTools===!0,yolo:$.yolo===!0,missionLogIntervalSteps:typeof $.missionLogIntervalSteps==="number"&&Number.isFinite($.missionLogIntervalSteps)?$.missionLogIntervalSteps:3,missionLogIntervalMs:typeof $.missionLogIntervalMs==="number"&&Number.isFinite($.missionLogIntervalMs)?$.missionLogIntervalMs:120000}}class x6{teamRuntimeEntries=new Map;async build($){let{config:f,hooks:J,extensions:Q,logger:Z,telemetry:W,createSpawnTool:j,onTeamRestored:X,userInstructionService:H,configExtensions:Y,toolExecutors:V}=$,A=$.onTeamEvent??(()=>{}),B=P_(f),G=Q$(),K=[],D=f.teamName?.trim()||VH(),F=f.sessionId?.trim()||D,P=i9(Y,"rules"),U=i9(Y,"skills"),z=i9(Y,"workflows"),_=P||U||z,R=!1,L=Boolean(H),N=H,M;if(!N&&_)N=c1({skills:{workspacePath:f.cwd},rules:{workspacePath:f.cwd},workflows:{workspacePath:f.cwd}});if(N)await N.start().catch(()=>{});let o=B.enableTools&&U&&Boolean(N)&&N?.hasConfiguredSkills(f.skills)===!0&&A_({cwd:f.cwd,providerId:f.providerId,mode:B.mode,modelId:f.modelId,toolRoutingRules:f.toolRoutingRules,toolPolicies:f.toolPolicies,toolExecutors:V}),e=N&&_?N.createExtension({includeRules:P,includeSkills:U,includeWorkflows:z,registerSkillsTool:o,allowedSkillNames:f.skills}):void 0,a=e?[...Q??f.extensions??[],e]:Q??f.extensions;if(B.enableTools){if(K.push(...n9(f.cwd,f.providerId,B.mode,f.modelId,f.toolRoutingRules,f.toolPolicies,void 0,V)),!B.disableMcpSettingsTools){let p=await G_(f.logger);K.push(...p.tools),M=p.shutdown}}let v,V0=B.enableAgentTeams?HH():void 0,B$=V0?.loadRuntime(F),u=B$?.state,s0=B$?.teammates??[],h=new Map(s0.map((p)=>[p.agentId,p])),l=f.sessionId||D,M0,L0=[],r$=!1,y1=N4({providerId:f.providerId,modelId:f.modelId,cwd:f.cwd,apiKey:f.apiKey??"",baseUrl:f.baseUrl,headers:f.headers,providerConfig:f.providerConfig,knownModels:f.knownModels,thinking:f.thinking,maxIterations:f.maxIterations,hooks:J,extensions:a,logger:Z??f.logger,telemetry:$.telemetry??f.telemetry,workspaceMetadata:f.workspaceMetadata});if(!this.teamRuntimeEntries.has(l))this.teamRuntimeEntries.set(l,{delegatedAgentConfigProvider:y1});let Y2=()=>{if(!B.enableAgentTeams)return;let p=this.teamRuntimeEntries.get(l)??{delegatedAgentConfigProvider:y1};if(this.teamRuntimeEntries.set(l,p),v=p.runtime,!v){if(v=new V8({teamName:D,leadAgentId:f.sessionId||"lead",missionLogIntervalSteps:B.missionLogIntervalSteps,missionLogIntervalMs:B.missionLogIntervalMs,onTeamEvent:(s)=>{if(A(s),v&&V0){if(s.type==="teammate_spawned"&&s.teammate?.rolePrompt){let o0={agentId:s.agentId,rolePrompt:s.teammate.rolePrompt,modelId:s.teammate.modelId,maxIterations:s.teammate.maxIterations};h.set(o0.agentId,o0)}if(s.type==="teammate_shutdown"&&!F_(s.reason))h.delete(s.agentId);V0.handleTeamEvent(F,s),V0.persistRuntime(F,v.exportState(),Array.from(h.values()))}}}),u)v.hydrateState(u),r$=!0;p.runtime=v}if(!R){if(!v)return;R=!0;let s=y4({runtime:v,leadAgentId:f.sessionId||"lead",restoredFromPersistence:Boolean(u),restoredTeammates:s0,includeLeadSpawnTool:!0,includeLeadManagementTools:!0,onLeadToolsUnlocked:(o0)=>{L0=o0,M0?.addTools(o0)},createBaseTools:B.enableTools?()=>n9(f.cwd,f.providerId,B.mode,f.modelId,f.toolRoutingRules,f.toolPolicies,void 0,V):void 0,teammateConfigProvider:y1});if(r$)v.recoverActiveRuns("runtime_recovered");if(s.restoredFromPersistence)X?.();K.push(...s.tools)}return v};if(B.enableSpawnAgent&&j){let p=j();K.push({...p,execute:async(s,o0)=>{return Y2(),p.execute(s,o0)}})}if(B.enableAgentTeams)Y2();let w8=YH(K,f.toolPolicies),Wf=w8.some((p)=>p.name===W0.SUBMIT_AND_EXIT&&p.lifecycle?.completesRun===!0),w1=B.enableAgentTeams?()=>{let p=this.teamRuntimeEntries.get(l)?.runtime;if(!p)return;let s=p.listTasks(),o0=s.some((G$)=>G$.status==="in_progress"||G$.status==="pending"),E7=p.listRuns({}),rY=E7.some((G$)=>G$.status==="running"||G$.status==="queued");if(o0||rY){let G$=s.filter((q0)=>q0.status==="in_progress"||q0.status==="pending").map((q0)=>`${q0.id} (${q0.status}): ${q0.title}`).join(", "),b7=E7.filter((q0)=>q0.status==="running"||q0.status==="queued").map((q0)=>`${q0.id} (${q0.status})`).join(", "),jf=[];if(G$)jf.push(`Unfinished tasks: ${G$}`);if(b7)jf.push(`Active runs: ${b7}`);return`[SYSTEM] You still have team obligations. ${jf.join(". ")}. Use team_run_task to delegate work, or team_task with action=complete to mark tasks done, or team_await_runs to wait for active runs. Do NOT stop until all tasks are completed.`}return}:void 0,V2=Wf?{requireCompletionTool:!0,...w1?{completionGuard:w1}:{}}:w1?{completionGuard:w1}:void 0;return{tools:w8,logger:Z??f.logger,telemetry:W??f.telemetry,teamRuntime:v,teamRestoredFromPersistence:Boolean(u),delegatedAgentConfigProvider:this.teamRuntimeEntries.get(l)?.delegatedAgentConfigProvider??y1,extensions:a,completionPolicy:V2,registerLeadAgent:(p)=>{if(M0=p,L0.length>0)p.addTools(l1(L0,[...G]))},shutdown:async(p)=>{if(K_(v,p),this.teamRuntimeEntries.delete(l),await M?.(),!L)N?.stop()}}}}import{getClineEnvironmentConfig as U_,isOAuthProviderId as D_}from"@cline/shared";var a9="workos:";function R_($,f){if($==="cline")return`${a9}${f}`;return f}function L_($,f){if($==="cline"&&f.toLowerCase().startsWith(a9))return f.slice(a9.length);return f}function O_($){let J=K0($)?.exp;if(typeof J==="number"&&J>0)return J*1000;return null}function z_($,f){let J=$.auth?.expiresAt;if(typeof J==="number"&&Number.isFinite(J)&&J>0)return J;let Q=O_(f);if(Q)return Q;return Date.now()-1}function __($,f){let J=f.auth?.accessToken?.trim(),Q=f.auth?.refreshToken?.trim();if(!J||!Q)return null;let Z=L_($,J);if(!Z)return null;return{access:Z,refresh:Q,expires:z_(f,Z),accountId:f.auth?.accountId}}function N_($,f){let J=$?.expiresAt,Q=f?.expiresAt;return $?.accessToken===f?.accessToken&&$?.refreshToken===f?.refreshToken&&$?.accountId===f?.accountId&&J===Q}class m6 extends Error{providerId;constructor($){super(`OAuth credentials for provider "${$}" are no longer valid. Re-run authentication for this provider.`);this.name="OAuthReauthRequiredError",this.providerId=$}}class t9{providerSettingsManager;telemetry;refreshInFlight=new Map;constructor($){this.providerSettingsManager=$?.providerSettingsManager??new d$,this.telemetry=$?.telemetry}async resolveProviderApiKey($){if(!D_($.providerId))return null;return this.resolveWithSingleFlight($.providerId,$.forceRefresh)}async resolveWithSingleFlight($,f=!1){let J=this.refreshInFlight.get($);if(J)return J;let Q=this.resolveProviderApiKeyInternal($,f).catch((Z)=>{throw Z}).finally(()=>{this.refreshInFlight.delete($)});return this.refreshInFlight.set($,Q),Q}async resolveProviderApiKeyInternal($,f){let J=this.providerSettingsManager.getProviderSettings($);if(!J)return null;let Q=__($,J);if(!Q)return null;let Z=await this.resolveCredentials($,J,Q,f);if(!Z)throw new m6($);let W=R_($,Z.access),j={...J.auth??{},accessToken:W,refreshToken:Z.refresh,accountId:Z.accountId};j.expiresAt=Z.expires;let X={...J,auth:j},H=!N_(J.auth,X.auth);if(H)this.providerSettingsManager.saveProviderSettings(X,{setLastUsed:!1,tokenSource:"oauth"});return{providerId:$,apiKey:W,accountId:Z.accountId,refreshed:H}}async resolveCredentials($,f,J,Q){if($==="cline")return Ef(J,{apiBaseUrl:f.baseUrl?.trim()||U_().apiBaseUrl,telemetry:this.telemetry},{forceRefresh:Q});if($==="oca")return uf(J,{forceRefresh:Q,telemetry:this.telemetry},{mode:f.oca?.mode,telemetry:this.telemetry});return kf(J,{forceRefresh:Q,telemetry:this.telemetry})}}import{normalizeUserInput as T_}from"@cline/shared";import{nanoid as M_}from"nanoid";class AH{list($){return $?x0($):[]}update($,f){if(!$)return{sessionId:f.sessionId,prompts:[],updated:!1};let J=f.promptId.trim(),Q=$.pendingPrompts.findIndex((H)=>H.id===J);if(Q<0)return{sessionId:f.sessionId,prompts:x0($),updated:!1};let Z=$.pendingPrompts[Q];if(!Z)return{sessionId:f.sessionId,prompts:x0($),updated:!1};let W=f.prompt===void 0?Z.prompt:T_(f.prompt).trim();if(!W)throw Error("prompt cannot be empty");let j=f.delivery??Z.delivery,X={...Z,prompt:W,mode:f.mode??Z.mode,delivery:j};return $.pendingPrompts.splice(Q,1),q_($,X,Q,Z.delivery),{sessionId:f.sessionId,prompts:x0($),prompt:g6(X),updated:!0}}delete($,f){if(!$)return{sessionId:f.sessionId,prompts:[],removed:!1};let J=f.promptId.trim(),Q=$.pendingPrompts.findIndex((W)=>W.id===J);if(Q<0)return{sessionId:f.sessionId,prompts:x0($),removed:!1};let[Z]=$.pendingPrompts.splice(Q,1);return{sessionId:f.sessionId,prompts:x0($),prompt:Z?g6(Z):void 0,removed:!0}}enqueue($,f){let{prompt:J,mode:Q,delivery:Z,userImages:W,userFiles:j}=f,X=$.pendingPrompts.findIndex((H)=>H.prompt===J);if(X>=0){let[H]=$.pendingPrompts.splice(X,1),Y={...H,prompt:J,mode:Q??H.mode,userImages:W??H.userImages,userFiles:j??H.userFiles};if(Z==="steer"||H.delivery==="steer")$.pendingPrompts.unshift({...Y,delivery:"steer"});else $.pendingPrompts.push(Y)}else{let H={id:`pending_${Date.now()}_${M_(5)}`,prompt:J,mode:Q,delivery:Z,userImages:W,userFiles:j};if(Z==="steer")$.pendingPrompts.unshift(H);else $.pendingPrompts.push(H)}return x0($)}consumeSteer($){let f=$.pendingPrompts.findIndex((Q)=>Q.delivery==="steer");if(f<0)return{prompts:x0($)};let[J]=$.pendingPrompts.splice(f,1);return{entry:J,prompts:x0($)}}shiftNext($){return{entry:$.pendingPrompts.shift(),prompts:x0($)}}requeueFront($,f){return $.pendingPrompts.unshift(f),x0($)}clear($){return $.pendingPrompts.length=0,[]}}class s9{deps;service=new AH;constructor($){this.deps=$}list($){return this.service.list(this.deps.getSession($))}update($){let f=this.deps.getSession($.sessionId);if(!f||f.aborting)return{sessionId:$.sessionId,prompts:[],updated:!1};let J=this.service.update(f,$);return this.emitPrompts(f),this.scheduleDrain($.sessionId,f),J}delete($){let f=this.deps.getSession($.sessionId);if(!f||f.aborting)return{sessionId:$.sessionId,prompts:[],removed:!1};let J=this.service.delete(f,$);return this.emitPrompts(f),this.scheduleDrain($.sessionId,f),J}enqueue($,f){let J=this.deps.getSession($);if(!J||J.aborting)return;this.service.enqueue(J,f),this.emitPrompts(J),this.scheduleDrain($,J)}consumeSteer($){let f=this.deps.getSession($);if(!f)return;let{entry:J}=this.service.consumeSteer(f);if(!J)return;return this.emitPrompts(f),this.emitSubmitted(f,J),J}clearAborted($){if($.pendingPrompts.length===0)return;this.service.clear($),this.emitPrompts($)}emitPrompts($){this.deps.emit({type:"pending_prompts",payload:{sessionId:$.sessionId,prompts:x0($)}})}scheduleDrain($,f){if(f.pendingPrompts.length===0||f.aborting||f.drainingPendingPrompts||!f.agent.canStartRun())return;queueMicrotask(()=>{this.drain($)})}async drain($){let f=this.deps.getSession($);if(!f)return;if(f.aborting||f.drainingPendingPrompts)return;if(!f.agent.canStartRun())return;let{entry:J}=this.service.shiftNext(f);if(!J)return;this.emitPrompts(f),this.emitSubmitted(f,J),f.drainingPendingPrompts=!0;let Q=!0;try{await this.deps.send({sessionId:$,prompt:J.prompt,...J.mode?{mode:J.mode}:{},userImages:J.userImages,userFiles:J.userFiles})}catch{Q=!1,this.service.requeueFront(f,J),this.emitPrompts(f)}finally{if(f.drainingPendingPrompts=!1,Q&&f.pendingPrompts.length>0&&f.status!=="failed"&&f.status!=="cancelled")queueMicrotask(()=>{this.drain($)})}}emitSubmitted($,f){let J=g6(f);this.deps.emit({type:"pending_prompt_submitted",payload:{sessionId:$.sessionId,id:J.id,prompt:J.prompt,delivery:J.delivery,attachmentCount:J.attachmentCount}})}}function g6($){return{id:$.id,prompt:$.prompt,delivery:$.delivery,attachmentCount:($.userImages?.length??0)+($.userFiles?.length??0)}}function x0($){return $.pendingPrompts.map(g6)}function q_($,f,J,Q){if(f.delivery==="steer")$.pendingPrompts.unshift(f);else if(Q==="steer")$.pendingPrompts.push(f);else $.pendingPrompts.splice(J,0,f)}G0();class e9{deps;constructor($){this.deps=$}dispatchAgentEvent($,f,J){let Q=this.deps.getSession($),Z={sessionId:$,config:f,liveSession:Q,usageBySession:this.deps.usageBySession,aggregateUsageBySession:this.deps.aggregateUsageBySession,persistMessages:this.deps.persistMessages,emit:this.deps.emit},W=M9(J),j=!!Q&&(!W.agentId||W.agentId===o9(Q.agent));q9(Z,J,j?{isPrimaryAgentEvent:!0,agentId:o9(Q.agent),conversationId:Q.agent.getConversationId(),...Q?.runtime.teamRuntime?{teamRole:"lead"}:{}}:{isPrimaryAgentEvent:!1})}async handleTeamEvent($,f){let J=this.deps.getSession($);if(J){if(X9(J,f),f.type==="agent_event"){let Q={sessionId:$,config:J.config,liveSession:J,usageBySession:this.deps.usageBySession,aggregateUsageBySession:this.deps.aggregateUsageBySession,persistMessages:this.deps.persistMessages,emit:this.deps.emit};q9(Q,f.event,{agentId:f.agentId,teamRole:"teammate",teamAgentId:f.agentId,isPrimaryAgentEvent:!1})}if(f.type==="teammate_spawned"){let Q=V$({agentId:f.teammate.runtimeAgentId??f.agentId,conversationId:f.teammate.conversationId,parentAgentId:f.teammate.parentAgentId,createdByAgentId:o9(J.agent),teamId:J.runtime.teamRuntime?.getTeamId(),teamName:J.runtime.teamRuntime?.getTeamName(),teamRole:"teammate",teamAgentId:f.agentId});if(Q)a$(J.config.telemetry,{ulid:$,modelId:f.teammate.modelId??J.config.modelId,provider:J.config.providerId,...Q})}}if(await H9($,f,this.deps.invokeBackendOptional),J)Y9(J,$,f,this.deps.emit)}async handlePluginEvent($,f,J){if(f.name==="plugin_log"){this.handlePluginLog($,f.payload);return}if(f.name==="automation_event"){let H=this.deps.getSession($)?.config.extensionContext?.automation??J;if(!H)return;let Y=f.payload&&typeof f.payload==="object"?f.payload:void 0;if(!Y)return;await H.ingestEvent(Y);return}if(f.name!=="steer_message"&&f.name!=="queue_message"&&f.name!=="pending_prompt")return;let Q=f.payload&&typeof f.payload==="object"?f.payload:void 0,Z=typeof Q?.sessionId==="string"&&Q.sessionId.trim().length>0?Q.sessionId.trim():$,W=typeof Q?.prompt==="string"?Q.prompt.trim():"";if(!W)return;let j=f.name==="steer_message"?"steer":f.name==="queue_message"?"queue":Q?.delivery==="steer"?"steer":"queue";this.deps.enqueuePendingPrompt(Z,{prompt:W,delivery:j})}handlePluginLog($,f,J){let Q=this.deps.getSession($),Z=J??Q?.config.extensionContext?.logger??Q?.config.logger;if(!Z||!f||typeof f!=="object")return;let W=f,j=typeof W.message==="string"?W.message:"";if(!j)return;let X=W.metadata&&typeof W.metadata==="object"?{...W.metadata}:{};if(X.sessionId??=$,typeof W.pluginName==="string"&&W.pluginName)X.pluginName=W.pluginName;if(W.level==="debug"){Z.debug(j,X);return}if(W.level==="error"){if(Z.error)Z.error(j,X);else Z.log(j,{...X,severity:"error"});return}Z.log(j,X)}}function o9($){return $.getAgentId()}function $7($){return{sessionId:$.sessionId,source:$.source,pid:process.pid,startedAt:$.startedAt,endedAt:$.endedAt??null,exitCode:$.exitCode??null,status:$.status,interactive:$.interactive,provider:$.config.providerId,model:$.config.modelId,cwd:$.config.cwd,workspaceRoot:v$($.config),teamName:$.config.teamName?.trim()||void 0,enableTools:$.config.enableTools,enableSpawn:$.config.enableSpawnAgent,enableTeams:$.config.enableAgentTeams,parentSessionId:typeof $.sessionMetadata?.parentSessionId==="string"?$.sessionMetadata.parentSessionId:void 0,parentAgentId:typeof $.sessionMetadata?.parentAgentId==="string"?$.sessionMetadata.parentAgentId:void 0,agentId:typeof $.sessionMetadata?.agentId==="string"?$.sessionMetadata.agentId:void 0,conversationId:typeof $.sessionMetadata?.conversationId==="string"?$.sessionMetadata.conversationId:void 0,isSubagent:typeof $.sessionMetadata?.isSubagent==="boolean"?$.sessionMetadata.isSubagent:!1,prompt:$.pendingPrompt,metadata:$.sessionMetadata,messagesPath:$.artifacts?.messagesPath,updatedAt:$.updatedAt??$.endedAt??$.startedAt}}function f7($,f){let J=$[f];return typeof J==="function"?J:null}async function BH($,f,...J){let Q=f7($,f);if(!Q)throw Error(`session service method not available: ${f}`);return Promise.resolve(Q.apply($,J))}async function GH($,f,...J){let Q=f7($,f);if(!Q)return;await Promise.resolve(Q.apply($,J))}async function KH($,f,...J){let Q=f7($,f);if(!Q)return;return await Promise.resolve(Q.apply($,J))}Z$();G0();function J7($,f,J,Q){return u1({configProvider:{getRuntimeConfig:()=>$.getSession(J)?.runtime.delegatedAgentConfigProvider?.getRuntimeConfig()??{providerId:f.providerId,modelId:f.modelId,cwd:f.cwd,apiKey:f.apiKey,baseUrl:f.baseUrl,headers:f.headers,providerConfig:f.providerConfig,knownModels:f.knownModels,thinking:f.thinking,maxIterations:f.maxIterations,hooks:f.hooks,extensions:f.extensions,logger:f.logger,telemetry:f.telemetry},getConnectionConfig:()=>$.getSession(J)?.runtime.delegatedAgentConfigProvider?.getConnectionConfig()??{providerId:f.providerId,modelId:f.modelId,apiKey:f.apiKey,baseUrl:f.baseUrl,headers:f.headers,providerConfig:f.providerConfig,knownModels:f.knownModels,thinking:f.thinking},updateConnectionDefaults:()=>{}},createSubAgentTools:()=>{let W=f.enableTools?M2({cwd:f.cwd,...r0[N$({mode:f.mode})],executors:Q}):[];if(f.enableSpawnAgent)W.push(J7($,f,J,Q));return l1(W)},onSubAgentEvent:(W)=>$.onAgentEvent(J,f,W),onSubAgentStart:(W)=>{let j=$.getSession(J)?.runtime.teamRuntime;$.subAgentStarts.set(W.subAgentId,{startedAt:Date.now(),rootSessionId:J});let X=V$({agentId:W.subAgentId,conversationId:W.conversationId,parentAgentId:W.parentAgentId,teamId:j?.getTeamId(),teamName:j?.getTeamName(),createdByAgentId:W.parentAgentId});if(X)a$(f.telemetry,{ulid:J,modelId:f.modelId,provider:f.providerId,...X});E8(f.telemetry,{event:"started",ulid:J,durationMs:0,parentId:W.parentAgentId,agentId:W.subAgentId,...X}),$.invokeBackendOptional("handleSubAgentStart",J,W)},onSubAgentEnd:(W)=>{let j=$.getSession(J)?.runtime.teamRuntime,X=$.subAgentStarts.get(W.subAgentId),H=X?Date.now()-X.startedAt:0,Y=W.result?.text?W.result.text.split(`
|
|
695
|
-
`).length:0;E8(f.telemetry,{event:"ended",ulid:J,durationMs:H,outputLines:Y,errorMessage:W.error?String(W.error):void 0,agentId:W.subAgentId,parentId:W.parentAgentId,...V$({agentId:W.subAgentId,conversationId:W.conversationId,parentAgentId:W.parentAgentId,teamId:j?.getTeamId(),teamName:j?.getTeamName(),createdByAgentId:W.parentAgentId})}),$.subAgentStarts.delete(W.subAgentId),$.invokeBackendOptional("handleSubAgentEnd",J,W)}})}import{readFile as y_,stat as w_}from"node:fs/promises";var S_=20480000;async function FH($){let f=await w_($);if(!f.isFile())throw Error("Path is not a file");if(f.size>S_)throw Error("File is too large to read into context.");let J=await y_($,"utf8");if(J.includes("\x00"))throw Error("Cannot read binary file into context.");return J}var PH=5000;function O8($){return typeof $==="number"&&Number.isFinite($)?$:void 0}function m_($){if(!$||typeof $!=="object"||Array.isArray($))return;let f=$,J=O8(f.inputTokens),Q=O8(f.outputTokens),Z=O8(f.cacheReadTokens),W=O8(f.cacheWriteTokens),j=O8(f.totalCost);if(J===void 0||Q===void 0||Z===void 0||W===void 0||j===void 0)return;return{inputTokens:J,outputTokens:Q,cacheReadTokens:Z,cacheWriteTokens:W,totalCost:j}}function g_($,f){return{inputTokens:Math.max($.inputTokens,f.inputTokens),outputTokens:Math.max($.outputTokens,f.outputTokens),cacheReadTokens:Math.max($.cacheReadTokens,f.cacheReadTokens),cacheWriteTokens:Math.max($.cacheWriteTokens,f.cacheWriteTokens),totalCost:Math.max($.totalCost,f.totalCost)}}class l${runtimeAddress=void 0;pendingPrompts;sessionService;runtimeBuilder;createAgentInstance;toolExecutors;defaultCapabilities;defaultToolPolicies;providerSettingsManager;oauthTokenManager;defaultTelemetry;defaultFetch;events=new f8;sessions=new Map;usageBySession=new Map;aggregateUsageBySession=new Map;subAgentStarts=new Map;pendingPromptsController;eventBridge;sessionVersioning=new j2;constructor($){let f=C_();if(f)x_(f);let J=U1($.distinctId);this.sessionService=$.sessionService,this.runtimeBuilder=$.runtimeBuilder??new x6,this.createAgentInstance=$.createAgent??((Q)=>new T$(Q)),this.defaultCapabilities=P0($.capabilities),this.toolExecutors=this.defaultCapabilities?.toolExecutors,this.defaultToolPolicies=$.toolPolicies,this.providerSettingsManager=$.providerSettingsManager??new d$,this.oauthTokenManager=$.oauthTokenManager??new t9({providerSettingsManager:this.providerSettingsManager,telemetry:$.telemetry}),this.defaultTelemetry=$.telemetry,this.defaultTelemetry?.setDistinctId(J),this.defaultFetch=$.fetch,this.pendingPromptsController=new s9({getSession:(Q)=>this.sessions.get(Q),emit:(Q)=>this.emit(Q),send:(Q)=>this.runTurn(Q)}),this.pendingPrompts={list:async(Q)=>this.pendingPromptsController.list(Q.sessionId),update:async(Q)=>this.pendingPromptsController.update(Q),delete:async(Q)=>this.pendingPromptsController.delete(Q)},this.eventBridge=new e9({getSession:(Q)=>this.sessions.get(Q),usageBySession:this.usageBySession,aggregateUsageBySession:this.aggregateUsageBySession,emit:(Q)=>this.emit(Q),persistMessages:(Q,Z,W)=>{this.invoke("persistSessionMessages",Q,Z,W)},enqueuePendingPrompt:(Q,Z)=>this.pendingPromptsController.enqueue(Q,Z),invokeBackendOptional:(Q,...Z)=>this.invokeOptional(Q,...Z)})}async startSession($){let f=$.source??F0.CLI,J=n(),Q=$.config.sessionId?.trim()??"",Z=Q||b_(),W=$,j=W.initialMessages??[],X=j.length>0?L6(j):B0(),H=await this.invokeOptionalValue("ensureSessionsDir")??"";if(!H)throw Error("session service method not available: ensureSessionsDir");let Y=Q7(H,Z),V=Q7(Y,`${Z}.messages.json`),A=Q7(Y,`${Z}.json`),B=v$($.config),G=_0.parse({version:1,session_id:Z,source:f,pid:process.pid,started_at:J,status:"running",interactive:$.interactive===!0,provider:W.config.providerId,model:W.config.modelId,cwd:W.config.cwd,workspace_root:B,team_name:W.config.teamName,enable_tools:W.config.enableTools,enable_spawn:W.config.enableSpawnAgent,enable_teams:W.config.enableAgentTeams,prompt:W.prompt?.trim()||void 0,messages_path:V}),K;if(Q.length>0&&j.length>0&&!W.prompt?.trim()){let h=await this.invokeOptionalValue("readSessionManifest",Z);if(h)G=h,K={manifestPath:A,messagesPath:h.messages_path||V,manifest:h}}let F=await this.seedAggregateUsageFromArtifacts({initialUsage:X,sessionDir:Y,rootMessagesPath:K?.messagesPath??V,manifest:G});this.usageBySession.set(Z,X),this.aggregateUsageBySession.set(Z,F);let P=P0(this.defaultCapabilities,$.capabilities),U=P?.toolExecutors??this.toolExecutors,z=$.localRuntime,_=z?.extensionContext?.logger??z?.logger,R=z?.extensionContext?.automation,L;L=await hX({input:W,localRuntime:$.localRuntime,sessionId:Z,providerSettingsManager:this.providerSettingsManager,defaultTelemetry:this.defaultTelemetry,defaultCapabilities:P,defaultToolPolicies:this.defaultToolPolicies,defaultFetch:this.defaultFetch,onPluginEvent:(h)=>{if(h.name==="plugin_log"){this.eventBridge.handlePluginLog(Z,h.payload,_);return}this.eventBridge.handlePluginEvent(Z,h,R)},onTeamEvent:(h)=>{this.eventBridge.handleTeamEvent(Z,h),L.config.onTeamEvent?.(h)},createSpawnTool:()=>J7({getSession:(h)=>this.sessions.get(h),subAgentStarts:this.subAgentStarts,onAgentEvent:(h,l,M0)=>this.eventBridge.dispatchAgentEvent(h,l,M0),invokeBackendOptional:(h,...l)=>this.invokeOptional(h,...l)},L.config,Z,U),readSessionMetadata:async()=>(await this.getSession(Z))?.metadata,writeSessionMetadata:async(h)=>{await this.persistSessionMetadata(Z,()=>h)}});let N=await this.runtimeBuilder.build(L.runtimeBuilderInput),M=L.config,o=L.providerConfig;if(N.teamRuntime&&!M.teamName?.trim())M.teamName=N.teamRuntime.getTeamName();let e=[...N.tools,...M.extraTools??[]],a=N.extensions??L.extensions,v={sessionId:Z,providerId:o.providerId,modelId:o.modelId,apiKey:o.apiKey,baseUrl:o.baseUrl,headers:o.headers,knownModels:o.knownModels,providerConfig:o,thinking:M.thinking,reasoningEffort:M.reasoningEffort??o.reasoningEffort,systemPrompt:M.systemPrompt,maxIterations:M.maxIterations,execution:M.execution,prepareTurn:T9(M),tools:e,hooks:L.hooks,extensions:a,hookErrorMode:M.hookErrorMode,initialMessages:L.effectiveInput.initialMessages,userFileContentLoader:FH,toolPolicies:L.toolPolicies,requestToolApproval:L.requestToolApproval?async(h)=>{let l=L.requestToolApproval,M0=this.sessions.get(Z);if(M0)await this.markTurnPending(M0);try{if(!l)return{approved:!1,reason:"Tool approval callback is not configured."};return await l(h)}finally{let L0=this.sessions.get(Z);if(L0?.status==="pending")await this.markTurnRunning(L0)}}:void 0,telemetry:M.telemetry,onConsecutiveMistakeLimitReached:M.onConsecutiveMistakeLimitReached,completionPolicy:N.completionPolicy,consumePendingUserMessage:()=>{let h=this.pendingPromptsController.consumeSteer(Z);return h?B8(h.prompt,h.mode??M.mode):void 0},logger:N.logger??M.logger,extensionContext:M.extensionContext,onEvent:(h)=>this.eventBridge.dispatchAgentEvent(Z,M,h)};v.hooks={...v.hooks,onEvent:async(h)=>{if(await L.hooks?.onEvent?.(h),h.type!=="assistant-message")return;let l=this.sessions.get(Z);if(!l)return;let M0=l.agent.getMessages();try{await this.invoke("persistSessionMessages",Z,M0,M.systemPrompt)}catch(L0){M.logger?.error?.("Failed to persist session messages after assistant response",{sessionId:Z,error:L0}),z1(M.telemetry,{component:"core",operation:"session.persist_messages_after_assistant_response",error:L0,severity:"warn",handled:!0,context:{sessionId:Z,providerId:M.providerId,modelId:M.modelId}})}}};let V0=this.createAgentInstance(v);if(v.onEvent)V0.subscribeEvents(v.onEvent);N.registerLeadAgent?.(V0);let B$=V$({agentId:V0.getAgentId(),conversationId:V0.getConversationId(),teamId:N.teamRuntime?.getTeamId(),teamName:N.teamRuntime?.getTeamName(),teamRole:N.teamRuntime?"lead":void 0});if(CX(M,Z,Q.length>0,B,B$),B$)a$(M.telemetry,{ulid:Z,modelId:M.modelId,provider:M.providerId,...B$});if(N.teamRuntime)_f(M.telemetry,{ulid:Z,teamId:N.teamRuntime.getTeamId(),teamName:N.teamRuntime.getTeamName(),leadAgentId:V0.getAgentId(),restoredFromPersistence:N.teamRestoredFromPersistence===!0});let u={sessionId:Z,config:M,sessionMetadata:W.sessionMetadata,...K?{artifacts:K}:{},source:f,startedAt:K?.manifest.started_at??J,updatedAt:K?.manifest.ended_at??K?.manifest.started_at??J,pendingPrompt:G.prompt,runtime:N,agent:V0,started:!1,status:K?.manifest.status??"running",aborting:!1,interactive:$.interactive===!0,persistedMessages:j,activeTeamRunIds:new Set,pendingTeamRunUpdates:[],teamRunWaiters:[],pendingPrompts:[],drainingPendingPrompts:!1,pluginSandboxShutdown:L.pluginSandboxShutdown,submitAndExitObserved:!1,lastInteractiveTurnFinishReason:void 0};if(this.sessions.set(Z,u),this.emitStatus(Z,"running"),j.length>0&&!K){if(await this.ensureSessionPersisted(u),await this.invoke("persistSessionMessages",u.sessionId,j,u.config.systemPrompt),!W.prompt?.trim())await this.updateStatus(u,"completed",0)}let s0;try{if(W.prompt?.trim())if(s0=await this.executeTurn(u,{prompt:W.prompt,userImages:W.userImages,userFiles:W.userFiles}),!u.interactive)await this.finalizeSingleRun(u,s0.finishReason);else await this.completeInteractiveTurn(u,s0.finishReason)}catch(h){if(u.interactive&&u.aborting)s0=await this.completeAbortedInteractiveTurn(u);else throw z1(u.config.telemetry,{component:"core",operation:"session.start",error:h,severity:"error",handled:!1,context:{sessionId:u.sessionId,providerId:u.config.providerId,modelId:u.config.modelId}}),await this.failSession(u),h}return{sessionId:Z,manifest:G,manifestPath:A,messagesPath:V,result:s0}}async restoreSession($){return this.sessionVersioning.restoreCheckpoint({...$,getSession:(f)=>this.getSession(f),readMessages:(f)=>this.readSessionMessages(f),buildStartInput:(f,J)=>{let Q=f.restoredCheckpointMetadata?{...J.sessionMetadata??{},checkpoint:f.restoredCheckpointMetadata}:J.sessionMetadata;return{...J,...Q?{sessionMetadata:Q}:{},initialMessages:f.initialMessages}},startSession:(f)=>this.startSession(f),getStartedSessionId:(f)=>f.sessionId,readRestoredSession:(f)=>this.getSession(f)})}async runTurn($){let f=this.getSessionOrThrow($.sessionId),J=f.agent.canStartRun(),Q=$.delivery??(f.interactive&&!J?"queue":void 0);if(f.config.telemetry?.capture({event:"session.input_sent",properties:{sessionId:$.sessionId,promptLength:$.prompt.length,userImageCount:$.userImages?.length??0,userFileCount:$.userFiles?.length??0,delivery:Q??"immediate"}}),Q==="queue"||Q==="steer"){this.pendingPromptsController.enqueue($.sessionId,{prompt:$.prompt,mode:$.mode,delivery:Q,userImages:$.userImages,userFiles:$.userFiles});return}try{let Z=await this.executeTurn(f,{prompt:$.prompt,mode:$.mode,userImages:$.userImages,userFiles:$.userFiles});if(!f.interactive)await this.finalizeSingleRun(f,Z.finishReason);else await this.completeInteractiveTurn(f,Z.finishReason);if(Z.finishReason==="error"||Z.finishReason==="aborted")return Z;return queueMicrotask(()=>{this.pendingPromptsController.drain($.sessionId)}),Z}catch(Z){if(f.interactive&&f.aborting)return await this.completeAbortedInteractiveTurn(f);throw z1(f.config.telemetry,{component:"core",operation:"session.submit",error:Z,severity:"error",handled:!1,context:{sessionId:f.sessionId,providerId:f.config.providerId,modelId:f.config.modelId}}),await this.failSession(f),Z}}async getAccumulatedUsage($){let f=x5(this.usageBySession.get($)),J=x5(this.aggregateUsageBySession.get($));return f||J?{usage:f,aggregateUsage:J}:void 0}async abort($,f){let J=this.sessions.get($);if(!J)return;J.config.telemetry?.capture({event:"session.aborted",properties:{sessionId:$}}),J.aborting=!0,this.pendingPromptsController.clearAborted(J),J.agent.abort(f)}async stopSession($){let f=this.sessions.get($);if(!f)return;if(f.config.telemetry?.capture({event:"session.stopped",properties:{sessionId:$}}),f.interactive&&!f0(f.status)){await this.releaseSessionRuntime(f,"session_stop");return}if(f.interactive&&f.agent.canStartRun()){await this.shutdownSession(f,{status:this.resolveInteractiveStopStatus(f),exitCode:this.resolveInteractiveStopExitCode(f),shutdownReason:"session_stop",endReason:"stopped"});return}f.aborting=!0,f.agent.abort(Error("session_stop")),await this.shutdownSession(f,{status:"cancelled",exitCode:0,shutdownReason:"session_stop",endReason:"stopped"})}async dispose($="session_manager_dispose"){let f=[...this.sessions.values()];if(f.length===0)return;await Promise.allSettled(f.map((J)=>J.interactive&&!f0(J.status)?this.releaseSessionRuntime(J,$):J.interactive&&J.agent.canStartRun()?this.shutdownSession(J,{status:this.resolveInteractiveStopStatus(J),exitCode:this.resolveInteractiveStopExitCode(J),shutdownReason:$,endReason:"disposed"}):this.shutdownSession(J,{status:"cancelled",exitCode:0,shutdownReason:$,endReason:"disposed"}))),this.usageBySession.clear(),this.aggregateUsageBySession.clear()}async getSession($){let f=this.sessions.get($);if(f)return $7(f);let J=$.trim();if(!J)return;let Q=await this.getRow(J);if(Q)return e2(Q);let Z=await this.readManifest(J);return Z?v5(Z):void 0}async listSessions($=200){let J=(await this.listRows($)).map(e2),Q=new Set(J.map((Z)=>Z.sessionId));for(let Z of this.sessions.values()){if(Q.has(Z.sessionId))continue;J.unshift($7(Z))}return J.slice(0,$)}async deleteSession($){if(this.sessions.has($))await this.stopSession($);let f=await this.invoke("deleteSession",$);if(f.deleted)this.usageBySession.delete($),this.aggregateUsageBySession.delete($);return f.deleted}async updateSession($,f){return{updated:(await this.invokeOptionalValue("updateSession",{sessionId:$,prompt:f.prompt,metadata:f.metadata,title:f.title}))?.updated===!0}}async readSessionMessages($){let f=$.trim();if(!f)return[];let J=await this.getRow(f);if(J?.messagesPath)return h$(J.messagesPath);let Q=await this.readManifest(f);return h$(Q?.messages_path)}async dispatchHookEvent($){await lW($,{queueSpawnRequest:(f)=>this.invokeOptional("queueSpawnRequest",f),upsertSubagentSessionFromHook:(f)=>this.invokeOptionalValue("upsertSubagentSessionFromHook",f),appendSubagentHookAudit:(f,J)=>this.invokeOptional("appendSubagentHookAudit",f,J),applySubagentStatus:(f,J)=>this.invokeOptional("applySubagentStatus",f,J)})}subscribe($,f){return this.events.subscribe($,f)}async updateSessionModel($,f){let J=this.getSessionOrThrow($);J.config.modelId=f,J.runtime.delegatedAgentConfigProvider?.updateConnectionDefaults({modelId:f}),J.agent.updateConnection({modelId:f})}handlePluginEvent($,f,J){return this.eventBridge.handlePluginEvent($,f,J)}async executeTurn($,f){let J=await this.prepareTurnInput($,f),Q=J.prompt.trim();if(!Q)throw Error("prompt cannot be empty");if(!$.artifacts&&!$.pendingPrompt)$.pendingPrompt=Q;await this.ensureSessionPersisted($),await this.syncOAuthCredentials($),await this.markTurnRunning($);let Z=await this.executeAgentTurn($,Q,J.userImages,J.userFiles);while(V9($,Z.finishReason)){let W=await A9($);if(W.length===0)break;let j=B9($,W);Z=await this.executeAgentTurn($,j)}return Z}async completeInteractiveTurn($,f){if(A8($))return;$.lastInteractiveTurnFinishReason=f,await this.markTurnIdle($),$.aborting=!1}resolveInteractiveStopStatus($){let f=$.lastInteractiveTurnFinishReason;if(!f)return"cancelled";switch(f){case"completed":return"completed";case"error":return"failed";case"aborted":case"max_iterations":case"mistake_limit":return"cancelled"}return f}resolveInteractiveStopExitCode($){return $.lastInteractiveTurnFinishReason==="error"?1:0}async completeAbortedInteractiveTurn($){let f=new Date,J=$.agent.getMessages(),Q=B0();return $.persistedMessages=J,$.started=$.started||J.length>0,this.eventBridge.dispatchAgentEvent($.sessionId,$.config,{type:"done",reason:"aborted",text:"",iterations:0,usage:Q}),await this.completeInteractiveTurn($,"aborted"),{text:"",usage:Q,messages:J,toolCalls:[],iterations:0,finishReason:"aborted",model:{id:$.config.modelId,provider:$.config.providerId},startedAt:f,endedAt:f,durationMs:0}}async executeAgentTurn($,f,J,Q){let Z=$.started||$.agent.getMessages().length>0,W=$.persistedMessages??$.agent.getMessages(),j=this.usageBySession.get($.sessionId)??B0(),X=this.aggregateUsageBySession.get($.sessionId)??j;$.turnUsageBaseline=j,$.turnAggregateUsageBaseline=X,$.turnPrimaryUsage=B0(),$.turnUsageByAgent=new Map,Pf($.config.telemetry,$.sessionId,$.config.mode),A2($.config.telemetry,{ulid:$.sessionId,provider:$.config.providerId,model:$.config.modelId,source:"user",mode:$.config.mode,...this.getSessionAgentTelemetryIdentity($)});try{let H=Z?()=>$.agent.continue(f,J,Q):()=>$.agent.run(f,J,Q),Y=await this.runWithAuthRetry($,H,W);$.started=!0;let V=J6(Y.messages,Y,W);$.persistedMessages=V;let A=R6($.turnUsageByAgent?.values()??[]),B=H0(j,Y.usage),G=H0(H0(B0(),Y.usage),A),K=H0(X,G);return this.usageBySession.set($.sessionId,B),this.aggregateUsageBySession.set($.sessionId,K),await this.persistSessionMetadata($.sessionId,(D)=>({...D??{},totalCost:B.totalCost,aggregatedAgentsCost:K.totalCost,usage:B,aggregateUsage:K})),await this.invoke("persistSessionMessages",$.sessionId,V,$.config.systemPrompt),this.observeTaskCompletionTool($,Y),Y}catch(H){throw z1($.config.telemetry,{component:"core",operation:"session.turn",error:H,severity:"error",handled:!1,context:{sessionId:$.sessionId,providerId:$.config.providerId,modelId:$.config.modelId}}),await this.invoke("persistSessionMessages",$.sessionId,$.agent.getMessages(),$.config.systemPrompt),H}finally{$.turnUsageBaseline=void 0,$.turnAggregateUsageBaseline=void 0,$.turnPrimaryUsage=void 0,$.turnUsageByAgent=void 0}}observeTaskCompletionTool($,f){if($.submitAndExitObserved)return;if(!f.toolCalls.some((Q)=>Q.name===W0.SUBMIT_AND_EXIT&&Q.error===void 0))return;$.submitAndExitObserved=!0,h8($.config.telemetry,{ulid:$.sessionId,provider:$.config.providerId,modelId:$.config.modelId,mode:$.config.mode,durationMs:Date.now()-Date.parse($.startedAt),source:"submit_and_exit",...this.getSessionAgentTelemetryIdentity($)})}async prepareTurnInput($,f){let J=v$($.config),Q=I_(f.prompt).trim();if(!Q)return{prompt:"",userImages:f.userImages,userFiles:this.resolveAbsoluteFilePaths($.config.cwd,f.userFiles)};let Z=await D4(Q,J);EX($.config.telemetry,Z);let W=B8(Z.prompt,f.mode??$.config.mode),j=this.resolveAbsoluteFilePaths($.config.cwd,f.userFiles),X=this.resolveAbsoluteFilePaths(J,Z.matchedFiles),H=Array.from(new Set([...j,...X]));return{prompt:W,userImages:f.userImages,userFiles:H.length>0?H:void 0}}async ensureSessionPersisted($){if($.artifacts)return;let f=v$($.config);$.artifacts=await this.invoke("createRootSessionWithArtifacts",{sessionId:$.sessionId,source:$.source,pid:process.pid,interactive:$.interactive,provider:$.config.providerId,model:$.config.modelId,cwd:$.config.cwd,workspaceRoot:f,teamName:$.config.teamName,enableTools:$.config.enableTools,enableSpawn:$.config.enableSpawnAgent,enableTeams:$.config.enableAgentTeams,prompt:$.pendingPrompt,metadata:$.sessionMetadata,startedAt:$.startedAt})}async markTurnRunning($){if($.status==="running")return;await this.updateStatus($,"running",null)}async markTurnPending($){if($.status==="pending")return;await this.updateStatus($,"pending",null)}async markTurnIdle($){if($.status==="idle")return;await this.updateStatus($,"idle",null)}async persistSessionMetadata($,f){let J=this.sessions.get($),Q=await this.invokeOptionalValue("readSessionManifest",$)??J?.artifacts?.manifest,Z=f(Q?.metadata);if(!J?.artifacts)return;if((await this.invokeOptionalValue("updateSession",{sessionId:$,metadata:Z}))?.updated===!1)return;J.sessionMetadata=Z,J.artifacts.manifest.metadata=Z}async finalizeSingleRun($,f){if(A8($))return;let J=f==="aborted"||$.aborting,Q=f==="error";await this.shutdownSession($,{status:J?"cancelled":Q?"failed":"completed",exitCode:Q?1:0,shutdownReason:Q?"session_error":"session_complete",endReason:f})}async failSession($){await this.shutdownSession($,{status:"failed",exitCode:1,shutdownReason:"session_error",endReason:"error"})}async shutdownSession($,f){if(f.status==="completed"&&!$.submitAndExitObserved)h8($.config.telemetry,{ulid:$.sessionId,provider:$.config.providerId,modelId:$.config.modelId,mode:$.config.mode,durationMs:Date.now()-Date.parse($.startedAt),source:"shutdown",...this.getSessionAgentTelemetryIdentity($)});P6($);let J=[],Q=(Z,W)=>{J.push(W),$.config.logger?.log("Session shutdown cleanup failed",{sessionId:$.sessionId,stage:Z,error:W,severity:"warn"}),z1($.config.telemetry,{component:"core",operation:"session.shutdown_cleanup",error:W,severity:"warn",handled:!0,context:{sessionId:$.sessionId,stage:Z,status:f.status,shutdownReason:f.shutdownReason,providerId:$.config.providerId,modelId:$.config.modelId}})};if($.artifacts){try{await this.updateStatus($,f.status,f.exitCode)}catch(Z){Q("update_status",Z)}try{await $.agent.shutdown(f.shutdownReason)}catch(Z){Q("agent_shutdown",Z)}}try{await Promise.resolve($.runtime.shutdown(f.shutdownReason))}catch(Z){Q("runtime_shutdown",Z)}try{await $.pluginSandboxShutdown?.()}catch(Z){Q("plugin_sandbox_shutdown",Z)}if(this.sessions.delete($.sessionId),this.emit({type:"ended",payload:{sessionId:$.sessionId,reason:f.endReason,ts:Date.now()}}),J.length>0&&f.status==="failed")throw J[0]}async releaseSessionRuntime($,f){let J=[],Q=(Z,W)=>{J.push(W),$.config.logger?.log("Session runtime cleanup failed",{sessionId:$.sessionId,stage:Z,error:W,severity:"warn"}),z1($.config.telemetry,{component:"core",operation:"session.runtime_cleanup",error:W,severity:"warn",handled:!0,context:{sessionId:$.sessionId,stage:Z,reason:f,providerId:$.config.providerId,modelId:$.config.modelId}})};try{await $.agent.shutdown(f)}catch(Z){Q("agent_shutdown",Z)}try{await Promise.resolve($.runtime.shutdown(f))}catch(Z){Q("runtime_shutdown",Z)}try{await $.pluginSandboxShutdown?.()}catch(Z){Q("plugin_sandbox_shutdown",Z)}if(this.sessions.delete($.sessionId),J.length>0)throw J[0]}async updateStatus($,f,J){if(!$.artifacts)return;let Q=await this.invoke("updateSessionStatus",$.sessionId,f,J);if(!Q.updated)return;let Z=await this.invokeOptionalValue("readSessionManifest",$.sessionId)??$.artifacts.manifest;if(Z.status=f,f0(f))delete Z.ended_at,Z.exit_code=null;else Z.ended_at=Q.endedAt??n(),Z.exit_code=typeof J==="number"?J:null;$.artifacts.manifest=Z,$.status=f,$.updatedAt=Q.endedAt??n(),$.endedAt=f0(f)?null:Z.ended_at,$.exitCode=Z.exit_code,await this.invoke("writeSessionManifest",$.artifacts.manifestPath,Z),this.emitStatus($.sessionId,f)}async runWithAuthRetry($,f,J){try{return await f()}catch(Q){if(!k_(Q,$.config.providerId))throw Q;return await this.syncOAuthCredentials($,{forceRefresh:!0}),$.agent.restore(J),f()}}async syncOAuthCredentials($,f){let J=null;try{J=await this.oauthTokenManager.resolveProviderApiKey({providerId:$.config.providerId,forceRefresh:f?.forceRefresh})}catch(Q){if(Q instanceof m6)throw Error(`${Q.providerId} requires re-authentication.`);throw Q}if(!J?.apiKey||$.config.apiKey===J.apiKey)return;$.config.apiKey=J.apiKey,$.agent.updateConnection({apiKey:J.apiKey}),$.runtime.delegatedAgentConfigProvider?.updateConnectionDefaults({apiKey:J.apiKey}),$.runtime.teamRuntime?.updateTeammateConnections({apiKey:J.apiKey})}getSessionOrThrow($){let f=this.sessions.get($);if(!f){let J=Error(`session not found: ${$}`);throw z1(this.defaultTelemetry,{component:"core",operation:"session.active_lookup",error:J,severity:"warn",handled:!0,context:{sessionId:$,activeSessionCount:this.sessions.size}}),J}return f}resolveAbsoluteFilePaths($,f){if(!f||f.length===0)return[];let J=f.map((Q)=>Q.trim()).filter((Q)=>Q.length>0).map((Q)=>E_(Q)?Q:Z7($,Q));return Array.from(new Set(J))}getSessionAgentTelemetryIdentity($){return V$({agentId:$.agent.getAgentId(),conversationId:$.agent.getConversationId(),teamId:$.runtime.teamRuntime?.getTeamId(),teamName:$.runtime.teamRuntime?.getTeamName(),teamRole:$.runtime.teamRuntime?"lead":void 0})}async seedAggregateUsageFromArtifacts($){let f=await this.summarizePersistedTeammateUsage($.sessionDir,$.rootMessagesPath,$.manifest.session_id),J=H0($.initialUsage,f);return this.withPersistedAggregateUsageFloor(J,$.manifest)}async summarizePersistedTeammateUsage($,f,J){let Q=Z7(f),Z=`${J}.messages.json`,W;try{W=h_($)}catch{return B0()}let j=B0();for(let X of W){if(!X.endsWith(".messages.json"))continue;if(X===Z)continue;let H=Z7($,X);if(H===Q)continue;let Y=await h$(H);if(Y.length===0)continue;j=H0(j,L6(Y))}return j}withPersistedAggregateUsageFloor($,f){let J=m_(f.metadata?.aggregateUsage);if(J)return g_($,J);let Q=f.metadata?.aggregatedAgentsCost;if(typeof Q!=="number"||!Number.isFinite(Q)||Q<=$.totalCost)return $;return{...$,totalCost:Q}}emitStatus($,f){this.emitSessionSnapshot($),this.emit({type:"status",payload:{sessionId:$,status:f}})}async emitSessionSnapshot($){let f=await this.getSession($);if(!f)return;this.emit({type:"session_snapshot",payload:{sessionId:$,snapshot:b$({session:f,messages:await this.readSessionMessages($),usage:this.usageBySession.get($),aggregateUsage:this.aggregateUsageBySession.get($)})}})}emit($){this.events.emit($)}async listRows($){return this.invoke("listSessions",Math.min(Math.max(1,Math.floor($)),PH))}async getRow($){let f=$.trim();if(!f)return;return(await this.listRows(PH)).find((Q)=>Q.sessionId===f)}async readManifest($){let f=$.trim();if(!f)return;return await this.invokeOptionalValue("readSessionManifest",f)}invoke($,...f){return BH(this.sessionService,$,...f)}invokeOptional($,...f){return GH(this.sessionService,$,...f)}invokeOptionalValue($,...f){return KH(this.sessionService,$,...f)}}function v_($){if($.backendMode)return $.backendMode;if(process.env.CLINE_VCR?.trim())return"local";let f=process.env.CLINE_SESSION_BACKEND_MODE?.trim().toLowerCase();if(f==="local"||f==="hub"||f==="remote")return f;return"auto"}var z8,_8;function u_($,f){if($!=="auto"&&$!=="hub")return;if(f.hub?.endpoint?.trim())return;Hj(f.hub?.workspaceRoot?.trim()||f.hub?.cwd?.trim()||process.cwd())}async function c_($){await $.reconcileDeadSessions?.().catch(()=>{})}function RH($){try{let f=new x$;return f.init(),new m$(f,{messagesArtifactUploader:$.messagesArtifactUploader,logger:$.logger})}catch(f){return $.telemetry?.capture({event:"session_backend_fallback",properties:{requestedBackend:"sqlite",fallbackBackend:"file"}}),DH($.telemetry,{component:"core",operation:"session_backend.sqlite_init",error:f,severity:"warn",handled:!0,context:{requestedBackend:"sqlite",fallbackBackend:"file"}}),new P9(void 0,{messagesArtifactUploader:$.messagesArtifactUploader,logger:$.logger})}}function UH($,f,J){return new l$({sessionService:J??$.sessionService??RH($),capabilities:$.capabilities,telemetry:$.telemetry,toolPolicies:$.toolPolicies,distinctId:f,fetch:$.fetch})}async function d_($){if(z8)return z8;if(_8)return await _8;return _8=(async()=>{return z8=RH($),await c_(z8),z8})().finally(()=>{_8=void 0}),await _8}async function v6($){let f=U1($.distinctId);$.telemetry?.setDistinctId(f);let J=v_($);if(u_(J,$),J==="remote"){let Q=$.remote?.endpoint?.trim();if(!Q)throw Error("Remote runtime mode requires `remote.endpoint` to be configured.");return $.logger?.log("Using remote runtime host",{endpoint:Q}),new H6({endpoint:Q,authToken:$.remote?.authToken,clientType:$.remote?.clientType,displayName:$.remote?.displayName,workspaceRoot:$.remote?.workspaceRoot,cwd:$.remote?.cwd,capabilities:$.capabilities})}if(J==="hub"){let Q=$.hub?.endpoint?.trim(),Z=Q||await W8({strategy:$.hub?.strategy??"require-hub",workspaceRoot:$.hub?.workspaceRoot,cwd:$.hub?.cwd});if(!Z)throw Error("No compatible hub runtime is available.");return $.logger?.log("Using hub runtime host",{url:Z,explicitEndpoint:Q||void 0}),new P1({url:Z,authToken:$.hub?.authToken,clientType:$.hub?.clientType,displayName:$.hub?.displayName,capabilities:$.capabilities,telemetry:$.telemetry},{workspaceRoot:$.hub?.workspaceRoot,cwd:$.hub?.cwd})}if(J==="auto"){let Q=await s5({endpoint:$.hub?.endpoint,strategy:$.hub?.strategy??"prefer-hub",workspaceRoot:$.hub?.workspaceRoot,cwd:$.hub?.cwd});if(Q){$.logger?.log("Using discovered local hub runtime host",{url:Q});let Z=new P1({url:Q,authToken:$.hub?.authToken,clientType:$.hub?.clientType,displayName:$.hub?.displayName,capabilities:$.capabilities,telemetry:$.telemetry},{workspaceRoot:$.hub?.workspaceRoot,cwd:$.hub?.cwd});try{return await Z.connect(),Z}catch(W){$.logger?.log("Falling back to local runtime host",{reason:"hub_connect_failed",severity:"warn",error:W}),DH($.telemetry,{component:"core",operation:"runtime_host.hub_connect",error:W,severity:"warn",handled:!0,context:{backendMode:"auto",fallbackBackend:"local"}})}}return $.logger?.log("Falling back to local runtime host",{reason:"compatible_hub_unavailable",severity:"warn"}),UH($,f)}return UH($,f)}class W7{clientName;runtimeAddress;automation;settings;pendingPrompts;host;prepare;capabilities;logger;telemetry;distinctId;automationService;activeSessionBootstraps=new Map;unsubscribeBootstrapCleanup;constructor($,f,J,Q,Z,W,j,X,H){this.clientName=f,this.runtimeAddress=J,this.host=$,this.prepare=Q,this.capabilities=Z,this.logger=W,this.telemetry=j,this.distinctId=X,this.settings=BW($),this.pendingPrompts=GW($),this.automation=new of(()=>{if(!this.automationService)throw Error("ClineCore automation is not enabled. Pass `automation: true` or automation options to ClineCore.create().");return this.automationService}),this.automationService=H?new t2({workspaceRoot:H.workspaceRoot??process.cwd(),specs:{cronSpecsDir:H.cronSpecsDir??H.cronDir,scope:qQ(H.cronScope),workspaceRoot:H.workspaceRoot},runtimeHandlers:yQ({host:$,getExtensionContext:()=>s8({automationService:this.automationService,automation:this.automation,clientName:this.clientName,distinctId:this.distinctId,logger:this.logger,telemetry:this.telemetry})}),dbPath:H.dbPath,logger:H.logger,pollIntervalMs:H.pollIntervalMs,claimLeaseSeconds:H.claimLeaseSeconds,globalMaxConcurrency:H.globalMaxConcurrency,watcherDebounceMs:H.watcherDebounceMs}):void 0,this.unsubscribeBootstrapCleanup=this.host.subscribe((Y)=>{if(Y.type!=="ended")return;this.disposeSessionBootstrap(Y.payload.sessionId)})}static async create($={}){let f=P0($.capabilities),J=await v6({...$,capabilities:f}),Q=MQ($.automation),Z=new W7(J,$.clientName,J.runtimeAddress,$.prepare,f,$.logger,$.telemetry,$.distinctId,Q?{...Q,logger:$.logger}:void 0);if(Q&&Q.autoStart!==!1)await Z.automation.start();return Z}async disposeSessionBootstrap($){let f=this.activeSessionBootstraps.get($);if(!f)return;this.activeSessionBootstraps.delete($),await Promise.resolve(f.dispose?.())}async start($){let f=KW($),J=await this.prepare?.(f);try{let Q=J?await J.applyToStartSessionInput(f):f,Z=await this.host.startSession(Y5(Q,{defaultCapabilities:this.capabilities,withExtensionContext:(W)=>s8({automationService:this.automationService,automation:this.automation,context:W,clientName:this.clientName,distinctId:this.distinctId,logger:this.logger,telemetry:this.telemetry})}));if(J)if(await this.host.getSession(Z.sessionId))this.activeSessionBootstraps.set(Z.sessionId,J);else await Promise.resolve(J.dispose?.());return FW({input:Q,sessionId:Z.sessionId,telemetry:this.telemetry,clientName:this.clientName,runtimeAddress:this.runtimeAddress}),Z}catch(Q){throw await Promise.resolve(J?.dispose?.()),Q}}send=(...$)=>this.host.runTurn(...$);getAccumulatedUsage=(...$)=>{return this.host.getAccumulatedUsage?.(...$)??Promise.resolve(void 0)};abort=(...$)=>this.host.abort(...$);stop=async($)=>{await this.host.stopSession($),await this.disposeSessionBootstrap($)};dispose=async(...$)=>{try{await this.automationService?.dispose(),await this.host.dispose(...$)}finally{this.unsubscribeBootstrapCleanup();let f=[...this.activeSessionBootstraps.keys()];await Promise.allSettled(f.map((J)=>this.disposeSessionBootstrap(J)))}};get=(...$)=>this.host.getSession(...$);listHistory=async($={})=>await u5(this.host,$);list=async($=200,f={})=>await this.listHistory({...f,limit:$});delete=async($)=>{let f=await this.host.deleteSession($);if(f)await this.disposeSessionBootstrap($);return f};update=(...$)=>this.host.updateSession(...$);readMessages=(...$)=>this.host.readSessionMessages(...$);async restore($){let f=$.start?Y5($.start,{defaultCapabilities:this.capabilities,withExtensionContext:(J)=>s8({automationService:this.automationService,automation:this.automation,context:J,clientName:this.clientName,distinctId:this.distinctId,logger:this.logger,telemetry:this.telemetry})}):void 0;return this.host.restoreSession({sessionId:$.sessionId,checkpointRunCount:$.checkpointRunCount,cwd:$.cwd,restore:$.restore,start:f})}ingestHookEvent=(...$)=>this.host.dispatchHookEvent(...$);subscribe($,f){return this.host.subscribe($,f)}updateSessionModel=(...$)=>{return this.host.updateSessionModel?.(...$)??Promise.resolve()}}import{HookEventNameSchema as OH,HookEventPayloadSchema as zH,parseHookEventPayload as c6,resolveHookSessionContext as t_}from"@cline/shared";import{z as _1}from"zod";import{spawn as l_}from"node:child_process";import{augmentNodeCommandForDebug as p_,withResolvedClineBuildEnv as r_}from"@cline/shared";function i_($){let f=$.trim();if(!f)return{};let Q=f.split(`
|
|
696
|
-
`).map((W)=>W.trim()).filter(Boolean).filter((W)=>W.startsWith("HOOK_CONTROL\t")).map((W)=>W.slice(13)),Z=Q.length>0?Q[Q.length-1]:f;try{return{parsedJson:JSON.parse(Z)}}catch(W){return{parseError:W instanceof Error?W.message:"Failed to parse subprocess stdout JSON"}}}function n_($,f){let J=$ instanceof Error?$:Error(String($)),Q=J,Z=f.join(" ");if(Q.code==="EACCES")return Error(`Failed to execute hook command "${Z}" (EACCES). Configure hooks with an explicit interpreter/command array (for example: ["bash", "/path/to/script"]) or make the script executable with a valid shebang.`);return Error(`Failed to execute hook command "${Z}": ${J.message}`)}async function a_($,f){let J=$.stdin;if(!J)throw Error("runSubprocessEvent failed to create stdin pipe");await new Promise((Q,Z)=>{let W=(j)=>{J.off("error",W);let X=j.code;if(X==="EPIPE"||X==="ERR_STREAM_DESTROYED"){Q();return}Z(j)};J.once("error",W),J.end(f,(j)=>{if(J.off("error",W),j){let X=j.code;if(X==="EPIPE"||X==="ERR_STREAM_DESTROYED"){Q();return}Z(j);return}Q()})})}async function u6($,f){let J=p_(f.command,{env:f.env,debugRole:"hook"});if(!Array.isArray(J)||J.length===0)throw Error("runSubprocessEvent requires a non-empty command");let Q=!!f.detached,Z=l_(J[0],J.slice(1),{cwd:f.cwd,env:r_(f.env),stdio:Q?["pipe","ignore","ignore"]:["pipe","pipe","pipe"],detached:Q}),W=new Promise((B)=>{Z.once("spawn",()=>{try{f.onSpawn?.({command:J,pid:Z.pid??void 0,detached:Q})}catch{}B()})}),j=new Promise((B,G)=>{Z.once("error",(K)=>{G(n_(K,J))})});if(await a_(Z,JSON.stringify($)),Q){await Promise.race([W,j]),Z.unref();return}if(!Z.stdout||!Z.stderr)throw Error("runSubprocessEvent failed to create stdout/stderr pipes");let X="",H="",Y=!1,V;Z.stdout.on("data",(B)=>{X+=B.toString()}),Z.stderr.on("data",(B)=>{H+=B.toString()});let A=new Promise((B)=>{if((f.timeoutMs??0)>0)V=setTimeout(()=>{Y=!0,Z.kill("SIGKILL")},f.timeoutMs);Z.once("close",(G)=>{if(V)clearTimeout(V);let{parsedJson:K,parseError:D}=i_(X);B({exitCode:G,stdout:X,stderr:H,parsedJson:K,parseError:D,timedOut:Y})})});return await Promise.race([A,j])}var s_=_1.object({contextModification:_1.string().optional(),cancel:_1.boolean().optional(),review:_1.boolean().optional(),errorMessage:_1.string().optional(),context:_1.string().optional(),overrideInput:_1.unknown().optional()}).passthrough();var o_=["agent","hook"];async function d6($,f={}){let J=f.command??o_;return await u6($,{command:J,cwd:f.cwd,env:f.env,detached:f.detached,timeoutMs:f.timeoutMs,onSpawn:f.onSpawn})}function _H($){return $ instanceof Error?$:Error(String($))}function e_($){if(!$||typeof $!=="object")return;let f=s_.safeParse($);if(!f.success)return;let J=f.data;if(!(("cancel"in J)||("review"in J)||("context"in J)||("contextModification"in J)||("overrideInput"in J)||("errorMessage"in J)))return;let Z=typeof J.context==="string"?J.context:typeof J.contextModification==="string"?J.contextModification:typeof J.errorMessage==="string"&&J.errorMessage.length>0?J.errorMessage:void 0;return{cancel:typeof J.cancel==="boolean"?J.cancel:void 0,review:typeof J.review==="boolean"?J.review:void 0,context:Z,overrideInput:Object.hasOwn(J,"overrideInput")?J.overrideInput:void 0}}function LH($){if(!$||typeof $!=="object")return{};let f={};for(let[J,Q]of Object.entries($))if(typeof Q==="string")f[J]=Q;else f[J]=JSON.stringify(Q);return f}function A$($,f,J){let Q=J.env??process.env,Z=Q.CLINE_USER_ID?.trim()||Q.USER?.trim()||"unknown",W=J.cwd||process.cwd();return{clineVersion:Q.CLINE_VERSION?.trim()||"",hookName:$,timestamp:new Date().toISOString(),taskId:f.conversationId,sessionContext:t_(J.sessionContext,{hookName:$,conversationId:f.conversationId,agentId:f.agentId,parentAgentId:f.parentAgentId}),workspaceRoots:W?[W]:[],workspaceInfo:J.workspaceInfo,userId:Z,agent_id:f.agentId,parent_agent_id:f.parentAgentId}}function $N($){return{name:$.name,message:$.message,stack:$.stack}}function fN($){let f=String($??"").toLowerCase();return f.includes("cancel")||f.includes("abort")||f.includes("interrupt")}function JN($){return{agentId:$.snapshot.agentId,conversationId:$.snapshot.conversationId??$.snapshot.runId??$.snapshot.agentId,parentAgentId:$.snapshot.parentAgentId??null}}function QN($){return $.filter((f)=>f.type==="text"&&typeof f.text==="string").map((f)=>f.text).join("")}function ZN($){return{id:$.toolCall.toolCallId,name:$.toolCall.toolName,input:$.input,output:$.result.output,error:$.result.isError?String($.result.output):void 0,durationMs:$.durationMs,startedAt:$.startedAt,endedAt:$.endedAt}}function WN($){if(!$)return;let f={};if($.cancel===!0)f.stop=!0;if($.overrideInput!==void 0)f.input=$.overrideInput;return Object.keys(f).length>0?f:void 0}async function N1($,f){try{let J=await d6($,{command:f.command,cwd:f.cwd,env:f.env,detached:!0,onSpawn:f.onSpawn});f.onDispatch?.({payload:$,result:J,detached:!0})}catch(J){f.onDispatchError?.(_H(J),$)}}function NH($={}){return{hooks:{beforeRun:async(X)=>{let H=JN(X);if(($.env??process.env).CLINE_HOOK_AGENT_RESUME==="1"){let V={...A$("agent_resume",H,$),hookName:"agent_resume",taskResume:{taskMetadata:{},previousState:{}}};await N1(V,$)}else{let V={...A$("agent_start",H,$),hookName:"agent_start",taskStart:{taskMetadata:{}}};await N1(V,$)}return},beforeTool:async(X)=>{let H={agentId:X.snapshot.agentId,conversationId:X.snapshot.conversationId??X.snapshot.runId??X.snapshot.agentId,parentAgentId:X.snapshot.parentAgentId??null},Y={...A$("tool_call",H,$),hookName:"tool_call",iteration:X.snapshot.iteration,tool_call:{id:X.toolCall.toolCallId,name:X.toolCall.toolName,input:X.input},preToolUse:{toolName:X.toolCall.toolName,parameters:LH(X.input)}};try{let V=await d6(Y,{command:$.command,cwd:$.cwd,env:$.env,detached:!1,timeoutMs:$.timeoutMs,onSpawn:$.onSpawn});if($.onDispatch?.({payload:Y,result:V,detached:!1}),V?.timedOut)throw Error("tool_call hook command timed out");if(V?.parseError)throw Error(`tool_call hook produced invalid control JSON: ${V.parseError}`);return WN(e_(V?.parsedJson))}catch(V){$.onDispatchError?.(_H(V),Y);return}},afterTool:async(X)=>{let H=ZN(X),Y={agentId:X.snapshot.agentId,conversationId:X.snapshot.conversationId??X.snapshot.runId??X.snapshot.agentId,parentAgentId:X.snapshot.parentAgentId??null},V={...A$("tool_result",Y,$),hookName:"tool_result",iteration:X.snapshot.iteration,tool_result:H,postToolUse:{toolName:H.name,parameters:LH(H.input),result:typeof H.output==="string"?H.output:JSON.stringify(H.output),success:!H.error,executionTimeMs:H.durationMs}};await N1(V,$);return},afterRun:async({snapshot:X,result:H})=>{let Y={agentId:X.agentId,conversationId:X.conversationId??X.runId??X.agentId,parentAgentId:X.parentAgentId??null};if(H.status==="completed"){let B={...A$("agent_end",Y,$),hookName:"agent_end",iteration:H.iterations,turn:{outputText:H.outputText,status:H.status},taskComplete:{taskMetadata:{}}};await N1(B,$);return}let V=H.status==="aborted"||fN(H.error?.message)?"agent_abort":"agent_error",A=V==="agent_error"?{...A$(V,Y,$),hookName:V,iteration:H.iterations,error:$N(H.error??Error("Agent run failed")),taskCancel:{taskMetadata:{}}}:{...A$(V,Y,$),hookName:V,reason:H.error?.message,taskCancel:{taskMetadata:{}}};await N1(A,$)},onEvent:async(X)=>{if(X.type!=="message-added"||X.message.role!=="user")return;let H={agentId:X.snapshot.agentId,conversationId:X.snapshot.conversationId??X.snapshot.runId??X.snapshot.agentId,parentAgentId:X.snapshot.parentAgentId??null},Y={...A$("prompt_submit",H,$),hookName:"prompt_submit",userPromptSubmit:{prompt:QN(X.message.content),attachments:[]}};await N1(Y,$)}},shutdown:async({agentId:X,conversationId:H,parentAgentId:Y,reason:V})=>{let A={...A$("session_shutdown",{agentId:X,conversationId:H,parentAgentId:Y},$),hookName:"session_shutdown",reason:V};await N1(A,$)}}}import{createSessionId as jN}from"@cline/shared";function m0($,f){return{version:$.version,requestId:$.requestId,ok:!0,payload:f}}function TH($,f,J){return{version:$.version,requestId:$.requestId??jN("hubreq_"),ok:!1,error:{code:f,message:J}}}class l6{schedules;constructor($){this.schedules=$}async handleCommand($){try{switch($.command){case"schedule.create":return m0($,{schedule:this.schedules.createSchedule(this.toCreateInput($.payload??{}))});case"schedule.list":return m0($,{schedules:this.schedules.listSchedules({enabled:typeof $.payload?.enabled==="boolean"?$.payload.enabled:void 0,limit:typeof $.payload?.limit==="number"?$.payload.limit:void 0,tags:Array.isArray($.payload?.tags)?$.payload?.tags:void 0})});case"schedule.get":return m0($,{schedule:this.schedules.getSchedule(String($.payload?.scheduleId??""))});case"schedule.update":return m0($,{schedule:this.schedules.updateSchedule(String($.payload?.scheduleId??""),this.toUpdateInput($.payload??{}))});case"schedule.delete":return m0($,{deleted:this.schedules.deleteSchedule(String($.payload?.scheduleId??""))});case"schedule.enable":return m0($,{schedule:this.schedules.resumeSchedule(String($.payload?.scheduleId??""))});case"schedule.disable":return m0($,{schedule:this.schedules.pauseSchedule(String($.payload?.scheduleId??""))});case"schedule.trigger":return m0($,{execution:await this.schedules.triggerScheduleNow(String($.payload?.scheduleId??""))});case"schedule.list_executions":return m0($,{executions:this.schedules.listScheduleExecutions({scheduleId:typeof $.payload?.scheduleId==="string"?$.payload.scheduleId:void 0,status:typeof $.payload?.status==="string"?$.payload.status:void 0,limit:typeof $.payload?.limit==="number"?$.payload.limit:void 0})});case"schedule.stats":return m0($,{stats:this.schedules.getScheduleStats(String($.payload?.scheduleId??""))});case"schedule.active":return m0($,{executions:this.schedules.getActiveExecutions()});case"schedule.upcoming":return m0($,{runs:this.schedules.getUpcomingRuns(typeof $.payload?.limit==="number"?$.payload.limit:void 0)});default:return TH($,"unsupported_command",`Unsupported hub schedule command: ${$.command}`)}}catch(f){return TH($,"schedule_command_failed",f instanceof Error?f.message:String(f))}}toCreateInput($){let f=$.modelSelection&&typeof $.modelSelection==="object"&&!Array.isArray($.modelSelection)?$.modelSelection:$.provider&&$.model?{providerId:String($.provider),modelId:String($.model)}:void 0;return{...$,modelSelection:f}}toUpdateInput($){let f=$.modelSelection&&typeof $.modelSelection==="object"&&!Array.isArray($.modelSelection)?$.modelSelection:$.provider||$.model?{providerId:typeof $.provider==="string"?$.provider:"",modelId:typeof $.model==="string"?$.model:""}:void 0;return{...$,modelSelection:f}}}function r6($){return $?new Date($).getTime():void 0}function XN($){let f=$.metadata?{...$.metadata}:void 0;if(f)delete f.__hubScheduleCreatedBy,delete f.__hubScheduleCwd,delete f.__hubRuntimeOptions;return f}function p6($){let f=$.metadata;return{scheduleId:$.externalId,name:$.title,cronPattern:$.scheduleExpr??"",prompt:$.prompt??"",workspaceRoot:$.workspaceRoot??"",cwd:typeof f?.__hubScheduleCwd==="string"?f.__hubScheduleCwd:void 0,modelSelection:$.providerId||$.modelId?{providerId:$.providerId??"",modelId:$.modelId??""}:void 0,enabled:$.enabled&&!$.removed&&$.parseStatus==="valid",mode:$.mode==="plan"?"plan":$.mode==="yolo"?"yolo":"act",systemPrompt:$.systemPrompt,maxIterations:$.maxIterations,timeoutSeconds:$.timeoutSeconds,maxParallel:$.maxParallel??1,createdAt:new Date($.createdAt).getTime(),updatedAt:new Date($.updatedAt).getTime(),nextRunAt:r6($.nextRunAt),lastRunAt:r6($.lastRunAt),createdBy:typeof f?.__hubScheduleCreatedBy==="string"?f.__hubScheduleCreatedBy:void 0,tags:$.tags,runtimeOptions:f?.__hubRuntimeOptions&&typeof f.__hubRuntimeOptions==="object"&&!Array.isArray(f.__hubRuntimeOptions)?f.__hubRuntimeOptions:void 0,metadata:XN($)}}function HN($){switch($){case"done":return"success";case"cancelled":return"aborted";case"running":return"running";case"queued":return"pending";default:return"failed"}}function MH($,f){return{executionId:$.runId,scheduleId:f,sessionId:$.sessionId,triggeredAt:new Date($.scheduledFor??$.createdAt).getTime(),startedAt:r6($.startedAt),endedAt:r6($.completedAt),status:HN($.status),errorMessage:$.error}}class i6{store;materializer;runner;started=!1;disposed=!1;constructor($){this.store=new a2({dbPath:$.dbPath}),this.materializer=new l2({store:this.store}),this.runner=new p2({store:this.store,materializer:this.materializer,runtimeHandlers:$.runtimeHandlers,eventPublisher:$.eventPublisher,workspaceRoot:"",logger:$.logger,pollIntervalMs:$.pollIntervalMs,claimLeaseSeconds:$.claimLeaseSeconds,globalMaxConcurrency:$.globalMaxConcurrency})}async start(){if(this.disposed)throw Error("HubScheduleService has been disposed");if(this.started)return;this.started=!0,await this.runner.start()}async stop(){await this.runner.stop(),this.started=!1}async dispose(){if(this.disposed)return;this.disposed=!0,await this.runner.dispose(),this.store.close()}createSchedule($){if(L5($.cronPattern),!$.workspaceRoot?.trim())throw Error("workspaceRoot is required for schedules");return p6(this.store.createHubSchedule($))}getSchedule($){let f=this.store.getHubSchedule($);return f?p6(f):void 0}listSchedules($={}){return this.store.listHubSchedules($).map((f)=>p6(f))}updateSchedule($,f){if(f.cronPattern!==void 0)L5(f.cronPattern);let J=this.store.getHubSchedule($);if(!J)return;let Q=f.workspaceRoot!==void 0?f.workspaceRoot.trim():J.workspaceRoot;if((f.enabled??J.enabled)&&!Q)throw Error("workspaceRoot is required for enabled schedules");let W=this.store.updateHubSchedule($,{...f,scheduleId:$});return W?p6(W):void 0}deleteSchedule($){return this.store.deleteHubSchedule($)}pauseSchedule($){return this.updateSchedule($,{scheduleId:$,enabled:!1})}resumeSchedule($){return this.updateSchedule($,{scheduleId:$,enabled:!0})}async triggerScheduleNow($){let f=this.store.enqueueHubScheduleRun($,"manual");if(!f)return;await this.runner.tick();let J=this.store.getRun(f.runId)??f;return MH(J,$)}listScheduleExecutions($){let f=$.scheduleId?this.store.getHubSchedule($.scheduleId):void 0,J={specId:f?.specId,limit:$.limit};return this.store.listRuns(J).map((Z)=>{let W=f??this.store.getSpec(Z.specId);if(!W||W.source!=="hub-schedule")return;return MH(Z,W.externalId)}).filter((Z)=>{if(!Z)return!1;return!$.status||Z.status===$.status})}getScheduleStats($){let f=this.listScheduleExecutions({scheduleId:$,limit:1e4});if(f.length===0)return{totalRuns:0,successRate:0,avgDurationSeconds:0};let J=0,Q=0,Z=0,W;for(let j of f){if(j.status==="success"||j.status==="completed")J+=1;if(!W&&j.status!=="success"&&j.status!=="completed")W=j;if(j.startedAt&&j.endedAt)Z+=j.endedAt-j.startedAt,Q+=1}return{totalRuns:f.length,successRate:J/f.length,avgDurationSeconds:Q>0?Z/Q/1000:0,lastFailure:W}}getActiveExecutions(){return this.runner.getActiveRuns().flatMap(($)=>{let f=this.store.getSpec($.specId);if(!f||f.source!=="hub-schedule"||!$.sessionId)return[];return[{executionId:$.runId,scheduleId:f.externalId,sessionId:$.sessionId,startedAt:$.startedAt??new Date().toISOString(),timeoutAt:f.timeoutSeconds&&$.startedAt?new Date(new Date($.startedAt).getTime()+f.timeoutSeconds*1000).toISOString():void 0}]})}getUpcomingRuns($=20){let f={triggerKind:"schedule",enabled:!0,limit:$};return this.store.listSpecs(f).flatMap((J)=>J.source==="hub-schedule"&&J.nextRunAt?[{spec:J,nextRunAt:J.nextRunAt}]:[]).sort((J,Q)=>String(J.nextRunAt).localeCompare(String(Q.nextRunAt))).slice(0,$).map(({spec:J,nextRunAt:Q})=>({scheduleId:J.externalId,name:J.title,nextRunAt:Q}))}}s6();function hN($,f){if($ instanceof Error)return $;if($&&typeof $==="object"&&"message"in $&&typeof $.message==="string"&&$.message.trim())return Error($.message.trim());let J=$&&typeof $==="object"&&"type"in $&&typeof $.type==="string"?$.type.trim():"";return Error(J?`Failed to connect to hub at ${f} (${J} event before socket open).`:`Failed to connect to hub at ${f}.`)}var CN="cline-hub-auth.";function EN($){return $.host!==void 0||$.port!==void 0||$.pathname!==void 0}function bN($,f){let J=new URL($),Q=new URL(f);return J.search="",J.hash="",Q.search="",Q.hash="",J.toString()===Q.toString()}async function kN($){let f=$.searchParams.get("authToken")?.trim();if($.searchParams.delete("authToken"),f)return f;let J=D0(),Q=await A0(J.discoveryPath);if(Q?.url&&bN($.toString(),Q.url))return Q.authToken;return}async function IN($={}){let f=C$($);if(!EN($)){let J=D0(),Q=await A0(J.discoveryPath);if(Q?.url)return Q.url}return j$(f.host,f.port,f.pathname)}async function wH($){return await new Promise((f,J)=>{(async()=>{let Q=new URL($),Z=await kN(Q);Q.hash="";let W=new WebSocket(Q.toString(),Z?[`${CN}${Z}`]:void 0),j=new Map,X=0;W.addEventListener("open",()=>{f({send(H){let Y=H.requestId??`hub-client-${++X}`;return new Promise((V,A)=>{j.set(Y,{resolve:V,reject:A});let B={kind:"command",envelope:{...H,requestId:Y}};W.send(JSON.stringify(B))})},close(){W.close()}})}),W.addEventListener("message",(H)=>{let Y=JSON.parse(String(H.data));if(Y.kind==="reply"&&Y.envelope.requestId){let V=j.get(Y.envelope.requestId);if(V)j.delete(Y.envelope.requestId),V.resolve(Y.envelope)}}),W.addEventListener("close",()=>{for(let H of j.values())H.reject(Error("Hub connection closed"));j.clear()}),W.addEventListener("error",(H)=>{J(hN(H,$))})})().catch(J)})}async function Yv($){try{return(await wH($)).close(),!0}catch{return!1}}async function Vv($,f){let J=await IN($),Q=await wH(J);try{return await Q.send({version:f.version??"v1",clientId:f.clientId??"hub-client",...f})}finally{Q.close()}}function Y7($){return $?JSON.parse(JSON.stringify($)):{}}function o6($){let f=$?.session&&typeof $.session==="object"?$.session:void 0;if(!f)return;let J=f.metadata&&typeof f.metadata==="object"?Y7(f.metadata):void 0;return{sessionId:typeof f.sessionId==="string"?f.sessionId:"",parentSessionId:typeof J?.parentSessionId==="string"?J.parentSessionId:void 0,messagesPath:typeof J?.messagesPath==="string"?J.messagesPath:void 0,metadata:J}}function SH($,f){return $.error?.message??`hub command failed: ${f}`}function xN($){let f=Y7($);if(typeof f.error==="string"&&f.error.trim())return{...f,error:f.error.trim()};let J=f.result&&typeof f.result==="object"?f.result:void 0;if(typeof J?.text==="string"&&J.text.trim())return{...f,error:J.text.trim()};let Q=J?.error&&typeof J.error==="object"?J.error:void 0;if(typeof Q?.message==="string"&&Q.message.trim())return{...f,error:Q.message.trim()};return f}function hH($){let f=$?.sessionId;return typeof f==="string"&&f.trim()?f.trim():void 0}function mN($){let f=$?.checkpoint;if(!f||typeof f!=="object"||Array.isArray(f))throw Error("hub checkpoint restore returned no checkpoint");let J=f;if(typeof J.ref!=="string"||typeof J.createdAt!=="number"||typeof J.runCount!=="number")throw Error("hub checkpoint restore returned an invalid checkpoint");return J}function gN($){let f=Y7($.payload);if($.event==="schedule.execution_completed")return{sessionId:$.sessionId?.trim()||hH(f)||"",eventType:"schedule.execution.completed",payload:f};if($.event==="schedule.execution_failed")return{sessionId:$.sessionId?.trim()||hH(f)||"",eventType:"schedule.execution.failed",payload:f};let J=$.sessionId?.trim();if(!J)return;switch($.event){case"iteration.started":return{sessionId:J,eventType:"runtime.chat.iteration_start",payload:f};case"iteration.finished":return{sessionId:J,eventType:"runtime.chat.iteration_end",payload:f};case"assistant.delta":return{sessionId:J,eventType:"runtime.chat.text_delta",payload:f};case"usage.updated":return{sessionId:J,eventType:"runtime.chat.usage",payload:f};case"tool.started":return{sessionId:J,eventType:"runtime.chat.tool_call_start",payload:f};case"tool.finished":return{sessionId:J,eventType:"runtime.chat.tool_call_end",payload:f};case"approval.requested":return{sessionId:J,eventType:"approval.requested",payload:f};case"run.aborted":return{sessionId:J,eventType:"runtime.chat.aborted",payload:f};case"run.failed":return{sessionId:J,eventType:"runtime.chat.failed",payload:xN($.payload)};case"run.completed":return{sessionId:J,eventType:"runtime.chat.completed",payload:f};default:return}}class vN{options;client;metadataApplied=!1;constructor($){this.options=$;this.client=new X$({url:$.address,authToken:$.authToken,clientId:$.clientId,clientType:$.clientType??"hub-session-client",displayName:$.displayName??"hub session client",workspaceRoot:$.workspaceRoot,cwd:$.cwd})}async ensureMetadataApplied(){if(this.metadataApplied||!this.options.metadata){if(!this.options.metadata)await this.client.connect();return}await this.client.connect(),await this.client.command("client.update",{metadata:this.options.metadata}),this.metadataApplied=!0}async connect(){await this.ensureMetadataApplied()}close(){this.client.close()}async dispose(){await this.client.dispose()}async startRuntimeSession($){await this.ensureMetadataApplied();let f=await this.client.command("session.create",{workspaceRoot:$.workspaceRoot,cwd:$.cwd,sessionConfig:{providerId:$.provider,modelId:$.model,apiKey:$.apiKey,cwd:$.cwd??$.workspaceRoot,workspaceRoot:$.workspaceRoot,systemPrompt:$.systemPrompt??"",mode:$.mode??"act",rules:$.rules,maxIterations:$.maxIterations,timeoutSeconds:$.timeoutSeconds,enableTools:$.enableTools,enableSpawnAgent:$.enableSpawn!==!1,enableAgentTeams:$.enableTeams!==!1,disableMcpSettingsTools:$.disableMcpSettingsTools,missionLogIntervalSteps:$.missionStepInterval,missionLogIntervalMs:$.missionTimeIntervalMs},metadata:{source:$.source??"cli",provider:$.provider,model:$.model,enableTools:$.enableTools,enableSpawn:$.enableSpawn,enableTeams:$.enableTeams,prompt:void 0,interactive:$.interactive!==!1},runtimeOptions:{mode:$.mode,systemPrompt:$.systemPrompt,maxIterations:$.maxIterations,timeoutSeconds:$.timeoutSeconds,enableTools:$.enableTools,enableSpawn:$.enableSpawn,enableTeams:$.enableTeams,autoApproveTools:$.autoApproveTools,toolExecutors:$.toolExecutors,configExtensions:$.configExtensions},modelSelection:{provider:$.provider,model:$.model,apiKey:$.apiKey},toolPolicies:$.toolPolicies}),J=o6(f.payload);if(!J?.sessionId)throw Error("hub session create returned no session id");return{sessionId:J.sessionId,startResult:{sessionId:J.sessionId,manifestPath:"",messagesPath:J.messagesPath??""}}}async sendRuntimeSession($,f,J){return await this.ensureMetadataApplied(),{result:(await this.client.command("session.send_input",{prompt:f.prompt,mode:f.config.mode,attachments:f.attachments,delivery:f.delivery,timeoutSeconds:f.config.timeoutSeconds},$,J)).payload?.result}}async stopRuntimeSession($){return await this.ensureMetadataApplied(),await this.client.command("session.detach",{sessionId:$},$),{applied:!0}}async abortRuntimeSession($){return await this.ensureMetadataApplied(),await this.client.command("run.abort",{sessionId:$},$),{applied:!0}}async updateSession($){return await this.ensureMetadataApplied(),await this.client.command("session.update",{sessionId:$.sessionId,metadata:$.metadata},$.sessionId),{updated:!0}}async getSession($){await this.ensureMetadataApplied();let f=await this.client.command("session.get",void 0,$);return o6(f.payload)}async readMessages($){let f=$.trim();if(!f)return[];await this.ensureMetadataApplied();let J=await this.client.command("session.messages",{sessionId:f},f);if(!J.ok)throw Error(SH(J,"session.messages"));let Q=J.payload?.messages;return Array.isArray(Q)?Q:[]}async restore($){let f=$.sessionId.trim();if(!f)throw Error("sessionId is required");let J=$.restore?.messages!==!1;if(J&&!$.config)throw Error("config is required when restore.messages is true");await this.ensureMetadataApplied();let Q=$.config,Z=await this.client.command("session.restore",{sessionId:f,checkpointRunCount:$.checkpointRunCount,restore:$.restore,...Q?{workspaceRoot:Q.workspaceRoot,cwd:Q.cwd,sessionConfig:{providerId:Q.provider,modelId:Q.model,apiKey:Q.apiKey,cwd:Q.cwd??Q.workspaceRoot,workspaceRoot:Q.workspaceRoot,systemPrompt:Q.systemPrompt??"",mode:Q.mode??"act",rules:Q.rules,maxIterations:Q.maxIterations,enableTools:Q.enableTools,enableSpawnAgent:Q.enableSpawn!==!1,enableAgentTeams:Q.enableTeams!==!1,disableMcpSettingsTools:Q.disableMcpSettingsTools,missionLogIntervalSteps:Q.missionStepInterval,missionLogIntervalMs:Q.missionTimeIntervalMs},metadata:{source:Q.source??"cli",provider:Q.provider,model:Q.model,enableTools:Q.enableTools,enableSpawn:Q.enableSpawn,enableTeams:Q.enableTeams,prompt:void 0,interactive:Q.interactive!==!1},runtimeOptions:{mode:Q.mode,systemPrompt:Q.systemPrompt,maxIterations:Q.maxIterations,enableTools:Q.enableTools,enableSpawn:Q.enableSpawn,enableTeams:Q.enableTeams,autoApproveTools:Q.autoApproveTools,configExtensions:Q.configExtensions},modelSelection:{provider:Q.provider,model:Q.model,apiKey:Q.apiKey},toolPolicies:Q.toolPolicies}:{}},f);if(!Z.ok)throw Error(SH(Z,"session.restore"));let W=o6(Z.payload);if(J&&!W?.sessionId)throw Error("hub checkpoint restore returned no session id");let j=Array.isArray(Z.payload?.messages)?Z.payload.messages:void 0,X=mN(Z.payload);return{sessionId:W?.sessionId,startResult:W?.sessionId?{sessionId:W.sessionId,manifestPath:"",messagesPath:W.messagesPath??""}:void 0,...j?{messages:j}:{},checkpoint:X}}async listSessions($){await this.ensureMetadataApplied();let f=await this.client.command("session.list",{limit:$?.limit??200});return(Array.isArray(f.payload?.sessions)?f.payload?.sessions:[]).map((Q)=>o6({session:Q})).filter((Q)=>Boolean(Q?.sessionId))}async deleteSession($,f=!0){return await this.ensureMetadataApplied(),(await this.client.command("session.delete",{sessionId:$,deleteCheckpointRefs:f})).payload?.deleted===!0}async respondToolApproval($){await this.ensureMetadataApplied(),await this.client.command("approval.respond",{approvalId:$.approvalId,approved:$.approved,payload:$.reason?{reason:$.reason}:void 0,responderClientId:$.responderClientId})}streamEvents($,f){let J=new Set(($.sessionIds??[]).map((Z)=>Z.trim()).filter(Boolean)),Q=this.client.subscribe((Z)=>{let W=gN(Z);if(!W)return;if(J.size>0&&!J.has(W.sessionId))return;f.onEvent?.(W)});return this.ensureMetadataApplied().catch((Z)=>{f.onError?.(Z instanceof Error?Z:Error(String(Z)))}),Q}streamTeamProgress($,f){let J=this.client.subscribe((Q)=>{if(Q.event!=="team.progress"||!Q.payload)return;f.onProjection?.(Q.payload)});return this.ensureMetadataApplied().catch((Q)=>{f.onError?.(Q instanceof Error?Q:Error(String(Q)))}),J}async createSchedule($){return await this.ensureMetadataApplied(),(await this.client.command("schedule.create",$)).payload?.schedule}async listSchedules($){await this.ensureMetadataApplied();let f=await this.client.command("schedule.list");return Array.isArray(f.payload?.schedules)?f.payload?.schedules:[]}async getSchedule($){return await this.ensureMetadataApplied(),(await this.client.command("schedule.get",{scheduleId:$})).payload?.schedule}async updateSchedule($,f){return await this.ensureMetadataApplied(),(await this.client.command("schedule.update",{scheduleId:$,...f})).payload?.schedule}async pauseSchedule($){return await this.ensureMetadataApplied(),(await this.client.command("schedule.disable",{scheduleId:$})).payload?.schedule}async resumeSchedule($){return await this.ensureMetadataApplied(),(await this.client.command("schedule.enable",{scheduleId:$})).payload?.schedule}async deleteSchedule($){return await this.ensureMetadataApplied(),(await this.client.command("schedule.delete",{scheduleId:$})).payload?.deleted===!0}async triggerScheduleNow($){return await this.ensureMetadataApplied(),(await this.client.command("schedule.trigger",{scheduleId:$})).payload?.execution}async listScheduleExecutions($,f){await this.ensureMetadataApplied();let J=await this.client.command("schedule.list_executions",{scheduleId:$,limit:f});return Array.isArray(J.payload?.executions)?J.payload?.executions:[]}async getScheduleStats(){return await this.ensureMetadataApplied(),(await this.client.command("schedule.stats")).payload?.stats}async getActiveScheduledExecutions(){await this.ensureMetadataApplied();let $=await this.client.command("schedule.active");return Array.isArray($.payload?.executions)?$.payload?.executions:[]}async getUpcomingScheduledRuns($){await this.ensureMetadataApplied();let f=await this.client.command("schedule.upcoming",{limit:$});return Array.isArray(f.payload?.upcoming)?f.payload?.upcoming:[]}}class uN{client;constructor($){this.client=new X$({url:$.address,authToken:$.authToken,clientId:$.clientId,clientType:$.clientType??"hub-ui-client",displayName:$.displayName??"hub ui client"})}async connect(){await this.client.connect()}close(){this.client.close()}async dispose(){await this.client.dispose()}getClientId(){return this.client.getClientId()}async sendNotify($){await this.client.command("ui.notify",$)}async sendShowWindow($){await this.client.command("ui.show_window",$??{})}async listClients(){let $=await this.client.command("client.list");return Array.isArray($.payload?.clients)?$.payload.clients:[]}async listSessions($=200){let f=await this.client.command("session.list",{limit:$});return Array.isArray(f.payload?.sessions)?f.payload.sessions:[]}subscribeUI($){return this.client.subscribe((f)=>{switch(f.event){case"ui.notify":$.onNotify?.(f.payload);break;case"ui.show_window":$.onShowWindow?.(f.payload);break;case"hub.client.registered":$.onClientRegistered?.(f.payload??{});break;case"hub.client.disconnected":$.onClientDisconnected?.(f.payload??{});break;case"session.created":$.onSessionCreated?.(f.payload??{});break;case"session.updated":$.onSessionUpdated?.(f.payload??{});break;case"session.detached":$.onSessionDetached?.(f.payload??{});break}})}}import{normalizeProviderId as cN}from"@cline/llms";function dN($){return{text:$.text,usage:$.usage,inputTokens:$.usage.inputTokens,outputTokens:$.usage.outputTokens,iterations:$.iterations,finishReason:$.finishReason,toolCalls:$.toolCalls.map((f)=>({name:f.name,input:f.input,output:f.output,error:f.error,durationMs:f.durationMs}))}}function lN($){return $.mode==="plan"?"plan":$.mode==="yolo"?"yolo":"act"}function Ov($={}){let f=new l$({sessionService:new m$(new x$),fetch:$.fetch,telemetry:$.telemetry});return{async startSession(J){let Q=(J.cwd?.trim()||J.workspaceRoot).trim(),Z=await f.startSession({source:J.source?.trim()||F0.CLI,interactive:!1,config:{providerId:cN(J.provider),modelId:J.model,apiKey:J.apiKey?.trim()||void 0,cwd:Q,workspaceRoot:J.workspaceRoot,systemPrompt:J.systemPrompt??"",mode:lN(J),maxIterations:J.maxIterations,enableTools:J.enableTools!==!1,enableSpawnAgent:J.enableSpawn!==!1,enableAgentTeams:J.enableTeams!==!1,disableMcpSettingsTools:J.disableMcpSettingsTools,missionLogIntervalSteps:J.missionStepInterval,missionLogIntervalMs:J.missionTimeIntervalMs},toolPolicies:J.toolPolicies??{"*":{autoApprove:J.autoApproveTools!==!1}},localRuntime:{configExtensions:J.configExtensions}});return{sessionId:Z.sessionId,startResult:{sessionId:Z.sessionId,manifestPath:Z.manifestPath,messagesPath:Z.messagesPath}}},async sendSession(J,Q){let Z=await f.runTurn({sessionId:J,prompt:Q.prompt,userImages:Q.attachments?.userImages,userFiles:Q.attachments?.userFiles?.map((W)=>W.content)});if(!Z)throw Error("local hub schedule runtime returned no turn result");return{result:dN(Z)}},async abortSession(J){return await f.abort(J,Error("hub schedule abort")),{applied:!0}},async stopSession(J){return await f.stopSession(J),{applied:!0}}}}function pN($){if(typeof $==="string")return $.trim()||void 0;if(!Array.isArray($))return;return $.map((J)=>{if(J&&typeof J==="object"&&"type"in J&&J.type==="text"&&"text"in J&&typeof J.text==="string")return J.text.trim();return""}).filter(Boolean).join(`
|
|
697
|
-
`).trim()||void 0}var CH=120,V7="...";function A7($){let f=$.trim();if(!f)return"";if(Buffer.byteLength(f,"utf8")<=CH)return f;let J=CH-Buffer.byteLength(V7,"utf8");if(J<=0)return V7;let Q="";for(let Z of f){if(Buffer.byteLength(Q+Z,"utf8")>J)break;Q+=Z}return`${Q}${V7}`}async function EH($){let f=$?.sessionId?.trim()||"unknown",J=typeof $?.metadata?.messagesPath==="string"?$.metadata.messagesPath:void 0,Z=[...await h$(J)].reverse().find((H)=>H.role==="assistant"),W=Z?pN(Z.content):void 0,j=$?.workspaceRoot?.trim()||"workspace",X=typeof $?.metadata?.prompt==="string"?$.metadata.prompt.trim():j;return{title:`Task completed (${f})`,body:A7(W&&W.length>0?W:X.length>0?X:j),severity:"info"}}import{captureSdkError as Jf,createSessionId as LT}from"@cline/shared";import{createSessionId as aN}from"@cline/shared";import{createSessionId as nN}from"@cline/shared";function rN($){switch($){case"idle":return"idle";case"pending":return"pending";case"completed":return"completed";case"failed":return"failed";case"cancelled":return"aborted";default:return"running"}}function iN($){let f=$.metadata&&typeof $.metadata==="object"?JSON.parse(JSON.stringify($.metadata)):{};if($.parentSessionId?.trim())f.parentSessionId=$.parentSessionId;if($.parentAgentId?.trim())f.parentAgentId=$.parentAgentId;if($.agentId?.trim())f.agentId=$.agentId;if($.conversationId?.trim())f.conversationId=$.conversationId;if($.messagesPath?.trim())f.messagesPath=$.messagesPath;if($.prompt?.trim())f.prompt=$.prompt;if($.provider?.trim())f.provider=$.provider;if($.model?.trim())f.model=$.model;if($.source?.trim())f.source=$.source;if(typeof $.pid==="number")f.pid=$.pid;return Object.keys(f).length>0?f:void 0}function e6($,f,J,Q){return{sessionId:$.sessionId,workspaceRoot:$.workspaceRoot,cwd:$.cwd,createdAt:Date.parse($.startedAt),updatedAt:Date.parse($.updatedAt),createdByClientId:f?.createdByClientId??"hub",status:rN($.status),participants:f?[...f.participants.values()]:[],metadata:iN($),runtimeOptions:{enableTools:$.enableTools,enableSpawn:$.enableSpawn,enableTeams:$.enableTeams,mode:typeof $.metadata?.mode==="string"?$.metadata.mode:void 0,systemPrompt:typeof $.metadata?.systemPrompt==="string"?$.metadata.systemPrompt:void 0},runtimeSession:$.agentId?{agentId:$.agentId,team:$.teamName?{teamId:$.teamName}:void 0}:void 0,...J?{usage:{...J}}:{},...Q?{aggregateUsage:{...Q}}:{}}}function m($,f){return{version:$.version,requestId:$.requestId,ok:!0,...f!==void 0?{payload:f}:{}}}function b($,f,J){return{version:$.version,requestId:$.requestId,ok:!1,error:{code:f,message:J}}}function $f($){return $&&typeof $==="object"&&!Array.isArray($)?$:void 0}function T0($){if(typeof $.payload?.sessionId==="string")return $.payload.sessionId.trim();return $.sessionId?.trim()??""}function M1($,f,J){return{version:"v1",event:$,eventId:nN("hevt_"),sessionId:J,timestamp:Date.now(),payload:f}}async function g0($,f){let J=await $.sessionHost.getSession(f);if(!J)return;let Q=await $.sessionHost.getAccumulatedUsage?.(f);return e6(J,$.sessionState.get(f),Q?.usage,Q?.aggregateUsage)}async function v0($,f){let J=await $.sessionHost.getSession(f);if(!J)return;let[Q,Z]=await Promise.all([typeof $.sessionHost.readSessionMessages==="function"?$.sessionHost.readSessionMessages(f):[],$.sessionHost.getAccumulatedUsage?.(f)]);return b$({session:J,messages:Q,usage:Z?.usage,aggregateUsage:Z?.aggregateUsage})}function ff($,f,J,Q,Z={}){let W=$.sessionState.get(f);if(W){if(Z.interactive!==void 0)W.interactive=Z.interactive;if(!W.participants.has(J))W.participants.set(J,{clientId:J,attachedAt:Date.now(),role:Q});return W}let j={createdByClientId:J,interactive:Z.interactive??!0,participants:new Map([[J,{clientId:J,attachedAt:Date.now(),role:Q}]])};return $.sessionState.set(f,j),j}async function B7($,f){let J=aN("approval_"),Q=f.sessionId;if($.sessionState.get(Q)?.interactive===!1)return{approved:!1,reason:"Tool approval requires an interactive session, but this session is non-interactive."};return await new Promise((W)=>{$.pendingApprovals.set(J,{sessionId:Q,resolve:W}),$.publish($.buildEvent("approval.requested",{approvalId:J,sessionId:f.sessionId,agentId:f.agentId,conversationId:f.conversationId,iteration:f.iteration,toolCallId:f.toolCallId,toolName:f.toolName,inputJson:JSON.stringify(f.input??null),policy:f.policy},Q))})}function G7($,f,J){let Q=$.pendingApprovals.get(f);if(!Q)return;return $.pendingApprovals.delete(f),Q.resolve(J),{sessionId:Q.sessionId}}function K7($,f,J){let Q=0;for(let[Z,W]of[...$.pendingApprovals.entries()]){if(!f({approvalId:Z,sessionId:W.sessionId}))continue;$.pendingApprovals.delete(Z),W.resolve({approved:!1,reason:J}),$.publish($.buildEvent("approval.resolved",{approvalId:Z,approved:!1,cancelled:!0,reason:J},W.sessionId)),Q+=1}return Q}async function bH($,f){let J=typeof f.payload?.approvalId==="string"?f.payload.approvalId.trim():"";if(!$.pendingApprovals.get(J))return b(f,"approval_not_found",`Unknown approval: ${J}`);let Z=typeof f.payload?.reason==="string"?f.payload.reason:f.payload?.payload&&typeof f.payload.payload==="object"&&!Array.isArray(f.payload.payload)&&typeof f.payload.payload.reason==="string"?f.payload.payload.reason:void 0,W=f.payload?.approved===!0,j=G7($,J,{approved:W,reason:Z});if(!j)return b(f,"approval_not_found",`Unknown approval: ${J}`);return $.publish($.buildEvent("approval.resolved",{approvalId:J,approved:W,reason:Z},j.sessionId)),m(f,{approvalId:J,approved:W})}import{createSessionId as oN}from"@cline/shared";function tN($){if($ instanceof Error)return{name:$.name,message:$.message,stack:$.stack};if($===void 0)return;return $}var kH={debug:10,info:20,warn:30,error:40,silent:50};function sN(){let $=process.env.CLINE_HUB_LOG_LEVEL?.trim().toLowerCase();if($==="debug"||$==="info"||$==="warn"||$==="error"||$==="silent")return $;return process.env.VITEST?"error":"info"}function I($,f,J={}){if(kH[$]<kH[sN()])return;let Q=JSON.stringify({ts:new Date().toISOString(),level:$,component:"hub",message:f,...Object.fromEntries(Object.entries(J).map(([Z,W])=>[Z,tN(W)]).filter(([,Z])=>Z!==void 0))});if($==="error"||$==="warn"){console.error(`[hub] ${Q}`);return}console.log(`[hub] ${Q}`)}function F7($,f){let J=f instanceof Error?f.stack||f.message:String(f);I("error",$,{error:J})}async function IH($,f,J,Q,Z,W){let j=oN("capreq_"),X=performance.now();return I("info","capability.request.start",{requestId:j,sessionId:f,capabilityName:J,targetClientId:Z}),await new Promise((H,Y)=>{$.pendingCapabilityRequests.set(j,{sessionId:f,targetClientId:Z,capabilityName:J,onProgress:W,resolve:(V)=>{if(I(V.ok?"info":"warn","capability.request.end",{requestId:j,sessionId:f,capabilityName:J,targetClientId:Z,ok:V.ok,error:V.error,durationMs:Math.round(performance.now()-X)}),!V.ok){Y(Error(V.error||`Capability ${J} was rejected by ${Z}.`));return}H(V.payload)}}),$.publish($.buildEvent("capability.requested",{requestId:j,targetClientId:Z,capabilityName:J,payload:Q},f)),I("info","capability.request.published",{requestId:j,sessionId:f,capabilityName:J,targetClientId:Z})})}function xH($,f){let J=typeof f.payload?.requestId==="string"?f.payload.requestId.trim():"",Q=$.pendingCapabilityRequests.get(J);if(!Q)return b(f,"capability_not_found",`Unknown capability request: ${J}`);if((f.clientId?.trim()||"")!==Q.targetClientId)return b(f,"capability_wrong_client",`Capability request ${J} is owned by ${Q.targetClientId}`);if(f.sessionId?.trim()&&f.sessionId.trim()!==Q.sessionId)return b(f,"capability_wrong_session",`Capability request ${J} belongs to session ${Q.sessionId}`);let W=f.payload?.payload&&typeof f.payload.payload==="object"&&!Array.isArray(f.payload.payload)?f.payload.payload:{};return Q.onProgress?.(W),m(f,{requestId:J})}function p$($,f,J){let Q=0;for(let[Z,W]of[...$.pendingCapabilityRequests.entries()]){if(!f({requestId:Z,...W}))continue;$.pendingCapabilityRequests.delete(Z),I("warn","capability.request.cancelled",{requestId:Z,sessionId:W.sessionId,capabilityName:W.capabilityName,targetClientId:W.targetClientId,reason:J}),W.resolve({ok:!1,error:J}),$.publish($.buildEvent("capability.resolved",{requestId:Z,capabilityName:W.capabilityName,targetClientId:W.targetClientId,ok:!1,cancelled:!0,error:J},W.sessionId)),Q+=1}return Q}async function mH($,f){let J=typeof f.payload?.sessionId==="string"?f.payload.sessionId.trim():f.sessionId?.trim()||"",Q=typeof f.payload?.capabilityName==="string"?f.payload.capabilityName.trim():"",Z=typeof f.payload?.targetClientId==="string"?f.payload.targetClientId.trim():"";if(!J||!Q||!Z)return b(f,"invalid_capability_request","capability.request requires sessionId, capabilityName, and targetClientId");try{let W=f.payload?.payload&&typeof f.payload.payload==="object"&&!Array.isArray(f.payload.payload)?f.payload.payload:{},j=await $.requestCapability(J,Q,W,Z);return m(f,j)}catch(W){return b(f,"capability_request_failed",W instanceof Error?W.message:String(W))}}function gH($,f){let J=typeof f.payload?.requestId==="string"?f.payload.requestId.trim():"",Q=$.pendingCapabilityRequests.get(J);if(!Q)return b(f,"capability_not_found",`Unknown capability request: ${J}`);let Z=f.clientId?.trim()||"";if(Z!==Q.targetClientId)return b(f,"capability_wrong_client",`Capability request ${J} is owned by ${Q.targetClientId}`);if(f.sessionId?.trim()&&f.sessionId.trim()!==Q.sessionId)return b(f,"capability_wrong_session",`Capability request ${J} belongs to session ${Q.sessionId}`);$.pendingCapabilityRequests.delete(J);let W=f.payload?.payload&&typeof f.payload.payload==="object"&&!Array.isArray(f.payload.payload)?f.payload.payload:void 0,j=typeof f.payload?.error==="string"?f.payload.error:void 0,X=f.payload?.ok===!0;return I(X?"info":"warn","capability.respond",{requestId:J,sessionId:Q.sessionId,capabilityName:Q.capabilityName,targetClientId:Q.targetClientId,respondedByClientId:Z,ok:X,error:j}),Q.resolve({ok:X,payload:W,error:j}),$.publish($.buildEvent("capability.resolved",{requestId:J,capabilityName:Q.capabilityName,targetClientId:Q.targetClientId,respondedByClientId:Z,ok:X,payload:W,error:j},Q.sessionId)),m(f,{requestId:J,ok:X})}import{createSessionId as eN}from"@cline/shared";function vH($,f){let J=f.payload,Q=J?.clientId?.trim()||f.clientId?.trim()||eN("client_");return $.clients.set(Q,{clientId:Q,clientType:J?.clientType??"unknown",displayName:J?.displayName,actorKind:J?.actorKind??"client",connectedAt:Date.now(),lastSeenAt:Date.now(),transport:J?.transport??"native",capabilities:J?.capabilities??[],metadata:J?.metadata,workspaceContext:J?.workspaceContext}),$.publish($.buildEvent("hub.client.registered",{clientId:Q,clientType:J?.clientType??"unknown",displayName:J?.displayName,connectedAt:Date.now()})),m(f,{clientId:Q})}function uH($,f){let J=f.clientId?.trim(),Q=J?$.clients.get(J):void 0;if(!J||!Q)return b(f,"client_not_found","Client is not registered with this hub.");let Z=$f(f.payload?.metadata);if(Q.lastSeenAt=Date.now(),Z)Q.metadata=JSON.parse(JSON.stringify(Z));return m(f)}function cH($,f,J){let Q=f.clientId?.trim();if(Q)$.clients.delete(Q),J(Q),$.publish($.buildEvent("hub.client.disconnected",{clientId:Q}));return m(f)}function dH($,f){return m(f,{clients:[...$.clients.values()]})}var $T=30000;function fT($){if($==="aborted")return"run.aborted";if($==="error"||$==="failed")return"run.failed";return"run.completed"}function JT($){if($.finishReason!=="error")return;return $.text.trim()||void 0}function QT($){return $?$:void 0}function ZT($){let f=typeof $.timeoutMs==="number"?$.timeoutMs:typeof $.timeout_ms==="number"?$.timeout_ms:void 0;if(f&&Number.isFinite(f)&&f>0)return Math.floor(f);let J=typeof $.timeoutSeconds==="number"?$.timeoutSeconds:typeof $.timeout_seconds==="number"?$.timeout_seconds:void 0;if(J&&Number.isFinite(J)&&J>0)return Math.floor(J*1000);return}async function WT($,f,J,Q){let Z=performance.now(),W=!1,j={command:f.command,requestId:f.requestId,clientId:f.clientId,sessionId:J.sessionId,timeoutMs:Q},X=setInterval(()=>{if(W)return;let V=Math.round(performance.now()-Z);I("warn","run.heartbeat",{...j,elapsedMs:V}),$.publish($.buildEvent("run.heartbeat",{requestId:f.requestId,elapsedMs:V,...Q?{timeoutMs:Q}:{}},J.sessionId))},$T),H=$.sessionHost.runTurn(J);H.then((V)=>{if(!W)return;I("warn","run.late_end",{...j,elapsedMs:Math.round(performance.now()-Z),finishReason:V?.finishReason})},(V)=>{if(!W)return;I("error","run.late_error",{...j,elapsedMs:Math.round(performance.now()-Z),error:V})});let Y;try{if(!Q)return await H;return await Promise.race([H,new Promise((V,A)=>{Y=setTimeout(()=>{let B=`Hub run ${f.command} timed out after ${Q}ms.`;W=!0,clearInterval(X),A(Error(B)),I("error","run.timeout",{...j,elapsedMs:Math.round(performance.now()-Z)}),K7($,(G)=>G.sessionId===J.sessionId,B),p$($,(G)=>G.sessionId===J.sessionId,B),$.sessionHost.abort(J.sessionId,B).catch((G)=>{I("error","run.timeout_abort_failed",{...j,error:G})})},Q)})])}finally{if(W=!0,clearInterval(X),Y)clearTimeout(Y)}}async function lH($,f){let J=T0(f),Q=f.payload&&typeof f.payload==="object"?f.payload:{},Z=typeof Q.prompt==="string"?Q.prompt:typeof Q.input==="string"?Q.input:"";if(!Z.trim())return b(f,"invalid_session_input","session input requires a prompt string");$.publish($.buildEvent("run.started",void 0,J));let W=Q.attachments&&typeof Q.attachments==="object"&&!Array.isArray(Q.attachments)?Q.attachments:void 0,j=Array.isArray(W?.userFiles)?W.userFiles.filter((V)=>typeof V==="string"):void 0,X=ZT(Q);$.suppressNextTerminalEventBySession.set(J,"run.start.reply");let H;try{H=await WT($,f,{sessionId:J,prompt:Z,mode:QT(Q.mode),delivery:Q.delivery==="queue"||Q.delivery==="steer"?Q.delivery:void 0,userImages:Array.isArray(W?.userImages)?W.userImages:void 0,userFiles:j,timeoutMs:X},X)}catch(V){if($.suppressNextTerminalEventBySession.get(J)==="run.start.reply")$.suppressNextTerminalEventBySession.delete(J);throw $.publish($.buildEvent("run.failed",{reason:"error",error:V instanceof Error?V.message:String(V)},J)),V}if(H){let V=await v0($,J),A=JT(H);if($.publish($.buildEvent(fT(H.finishReason),{reason:H.finishReason,...A?{error:A}:{},result:H,...V?{snapshot:V}:{}},J)),$.suppressNextTerminalEventBySession.get(J)==="run.start.reply")$.suppressNextTerminalEventBySession.delete(J)}else $.suppressNextTerminalEventBySession.delete(J);let Y=await v0($,J);return m(f,H||Y?{...H?{result:H}:{},...Y?{snapshot:Y}:{}}:void 0)}async function pH($,f){let J=T0(f),Q=typeof f.payload?.reason==="string"?f.payload.reason:"Run was aborted before pending approval or capability request was resolved.";K7($,(Z)=>Z.sessionId===J,Q);try{await $.sessionHost.abort(J,f.payload?.reason)}catch(Z){I("warn","run.abort_failed",{command:f.command,requestId:f.requestId,clientId:f.clientId,sessionId:J,error:Z})}finally{p$($,(Z)=>Z.sessionId===J,Q)}return m(f,{applied:!0})}async function rH($,f){let J=c6(f.payload?.payload);if(!J)return b(f,"invalid_hook_payload","session.hook requires a valid hook event payload");return await $.sessionHost.dispatchHookEvent(J),m(f,{applied:!0})}async function iH($,f){switch(f.type){case"chunk":return;case"agent_event":await jT($,f);return;case"hook":if(f.payload.hookEventName==="tool_call")$.publish($.buildEvent("tool.started",{toolName:f.payload.toolName},f.payload.sessionId));else if(f.payload.hookEventName==="tool_result")$.publish($.buildEvent("tool.finished",{toolName:f.payload.toolName},f.payload.sessionId));return;case"team_progress":{let J={type:"team_progress_projection",version:1,sessionId:f.payload.sessionId,summary:f.payload.summary,lastEvent:f.payload.lifecycle};$.publish($.buildEvent("team.progress",J,f.payload.sessionId));return}case"pending_prompts":$.publish($.buildEvent("session.pending_prompts",{sessionId:f.payload.sessionId,prompts:f.payload.prompts},f.payload.sessionId));return;case"pending_prompt_submitted":{let J={id:f.payload.id,prompt:f.payload.prompt,delivery:f.payload.delivery,attachmentCount:f.payload.attachmentCount};$.publish($.buildEvent("session.pending_prompt_submitted",{sessionId:f.payload.sessionId,prompt:J},f.payload.sessionId));return}case"session_snapshot":$.publish($.buildEvent("session.updated",{sessionId:f.payload.sessionId,snapshot:f.payload.snapshot},f.payload.sessionId));return;case"status":{let[J,Q]=await Promise.all([g0($,f.payload.sessionId),v0($,f.payload.sessionId)]);if(J)$.publish($.buildEvent("session.updated",{session:J,...Q?{snapshot:Q}:{}},f.payload.sessionId));return}case"ended":await XT($,f);return;default:return}}async function jT($,f){let{sessionId:J,event:Q}=f.payload;if(Q.type==="iteration_start"){$.publish($.buildEvent("iteration.started",{iteration:Q.iteration},J));return}if(Q.type==="iteration_end"){$.publish($.buildEvent("iteration.finished",{iteration:Q.iteration,hadToolCalls:Q.hadToolCalls,toolCallCount:Q.toolCallCount},J));return}if(Q.type==="content_start"){if(Q.contentType==="text"&&typeof Q.text==="string"&&Q.text.length>0){$.publish($.buildEvent("assistant.delta",{text:Q.text},J));return}if(Q.contentType==="reasoning"){if(Q.redacted&&!Q.reasoning){$.publish($.buildEvent("reasoning.delta",{text:"",redacted:!0},J));return}if(typeof Q.reasoning==="string"&&Q.reasoning.length>0)$.publish($.buildEvent("reasoning.delta",{text:Q.reasoning,redacted:Q.redacted===!0},J));return}if(Q.contentType==="tool"){$.publish($.buildEvent("tool.started",{toolCallId:Q.toolCallId,toolName:Q.toolName,input:Q.input},J));return}}if(Q.type==="content_end"){switch(Q.contentType){case"text":$.publish($.buildEvent("assistant.finished",{text:Q.text},J));break;case"reasoning":$.publish($.buildEvent("reasoning.finished",{reasoning:Q.reasoning},J));break;case"tool":$.publish($.buildEvent("tool.finished",{toolCallId:Q.toolCallId,toolName:Q.toolName,output:Q.output,error:Q.error},J));break}return}if(Q.type==="usage"){let Z;try{Z=await $.sessionHost.getAccumulatedUsage?.(J)}catch{Z=void 0}$.publish($.buildEvent("usage.updated",{sessionId:J,delta:{inputTokens:Q.inputTokens,outputTokens:Q.outputTokens,cacheReadTokens:Q.cacheReadTokens??0,cacheWriteTokens:Q.cacheWriteTokens??0,totalCost:Q.cost??0},totals:{inputTokens:Q.totalInputTokens,outputTokens:Q.totalOutputTokens,cacheReadTokens:Q.totalCacheReadTokens??0,cacheWriteTokens:Q.totalCacheWriteTokens??0,totalCost:Q.totalCost??0},usage:Z?.usage,aggregateUsage:Z?.aggregateUsage,agent:{kind:f.payload.teamRole==="teammate"?"teammate":Q.parentAgentId?"subagent":"lead",agentId:Q.agentId,conversationId:Q.conversationId,parentAgentId:Q.parentAgentId,teamAgentId:f.payload.teamAgentId,teamRole:f.payload.teamRole}},J));return}if(Q.type==="done")$.publish($.buildEvent("agent.done",{reason:Q.reason,text:Q.text,iterations:Q.iterations,usage:Q.usage},J))}async function XT($,f){let J=$.suppressNextTerminalEventBySession.get(f.payload.sessionId),Q=J===f.payload.reason||J==="run.start.reply";if(Q)$.suppressNextTerminalEventBySession.delete(f.payload.sessionId);let[Z,W]=await Promise.all([g0($,f.payload.sessionId),v0($,f.payload.sessionId)]);if(f.payload.reason==="completed"){let j=await EH(Z);$.publish($.buildEvent("ui.notify",j,f.payload.sessionId))}if(Q)return;$.publish($.buildEvent(f.payload.reason==="aborted"?"run.aborted":f.payload.reason==="error"||f.payload.reason==="failed"?"run.failed":"run.completed",{reason:f.payload.reason,...W?{snapshot:W}:{}},f.payload.sessionId))}import{createSessionId as aH,parseRuntimeConfigExtensions as tH}from"@cline/shared";import{HUB_CHECKPOINT_CAPABILITY as sv,HUB_COMPACTION_CAPABILITY as ov,HUB_CUSTOM_TOOL_CAPABILITY_PREFIX as ev,HUB_HOOK_CAPABILITY_PREFIX as $u,HUB_MISTAKE_LIMIT_CAPABILITY as fu,HUB_TOOL_EXECUTOR_CAPABILITY_PREFIX as Ju,HUB_USER_INSTRUCTIONS_SNAPSHOT_CAPABILITY as Qu,isHubToolExecutorName as HT}from"@cline/shared";import{HUB_CHECKPOINT_CAPABILITY as Hu,HUB_COMPACTION_CAPABILITY as Yu,HUB_CUSTOM_TOOL_CAPABILITY_PREFIX as Vu,HUB_HOOK_CAPABILITY_PREFIX as Au,HUB_MISTAKE_LIMIT_CAPABILITY as Bu,HUB_TOOL_EXECUTOR_CAPABILITY_PREFIX as Gu,HUB_USER_INSTRUCTIONS_SNAPSHOT_CAPABILITY as Ku}from"@cline/shared";var YT=["beforeRun","afterRun","beforeModel","afterModel","beforeTool","afterTool","onEvent"];function q1($){return $&&typeof $==="object"&&!Array.isArray($)?JSON.parse(JSON.stringify($)):void 0}function VT($,f){let J=typeof $.name==="string"?$.name.trim():"",Q=typeof $.description==="string"?$.description:"",Z=typeof $.capabilityName==="string"?$.capabilityName.trim():"",W=q1($.inputSchema);if(!J||!Q||!W||!Z||f.has(Z))return;return f.add(Z),{kind:"tool",capabilityName:Z,name:J,description:Q,inputSchema:W,...q1($.lifecycle)?{lifecycle:q1($.lifecycle)}:{}}}function U7($){if(!Array.isArray($))return[];let f=[],J=new Set;for(let Q of $){if(!Q||typeof Q!=="object"||Array.isArray(Q))continue;let Z=Q,W=Z.kind,j=typeof Z.capabilityName==="string"?Z.capabilityName.trim():"";if(!j||J.has(j))continue;if(W==="tool"){let X=VT(Z,J);if(X)f.push(X);continue}if(W==="toolExecutor"){let X=Z.executor;if(!HT(X))continue;J.add(j),f.push({kind:"toolExecutor",capabilityName:j,executor:X});continue}if(W==="hook"){let X=typeof Z.name==="string"?Z.name.trim():"";if(!X)continue;J.add(j),f.push({kind:"hook",capabilityName:j,name:X});continue}if(W==="compaction"){J.add(j),f.push({kind:"compaction",capabilityName:j,...q1(Z.config)?{config:q1(Z.config)}:{}});continue}if(W==="checkpoint"){J.add(j),f.push({kind:"checkpoint",capabilityName:j,...q1(Z.config)?{config:q1(Z.config)}:{}});continue}if(W==="mistakeLimit"){J.add(j),f.push({kind:"mistakeLimit",capabilityName:j});continue}if(W==="userInstructionService")J.add(j),f.push({kind:"userInstructionService",capabilityName:j})}return f}function nH($){return{agentId:$.agentId,conversationId:$.conversationId,iteration:$.iteration,metadata:$.metadata}}function AT($){return Object.hasOwn($,"update")?$.update:$}function q8($){return $.trim().replace(/^\/+/,"").toLowerCase()}function BT($){let f=($??[]).map(q8).filter(Boolean);return f.length>0?new Set(f):void 0}function GT($,f,J){if(!J)return!0;let Q=q8($),Z=q8(f),W=Q.includes(":")?Q.split(":").at(-1)??Q:Q,j=Z.includes(":")?Z.split(":").at(-1)??Z:Z;return J.has(Q)||J.has(Z)||J.has(W)||J.has(j)}function P7($,f){let J=BT(f);return $.records.skill.map((Q)=>({id:Q.id,name:Q.item.name,description:"description"in Q.item&&typeof Q.item.description==="string"?Q.item.description:void 0,disabled:Q.item.disabled===!0,skill:Q.item})).filter((Q)=>GT(Q.id,Q.name,J))}function KT($,f){let J=async(Q,Z)=>{let W=q8(Q),X=P7($,f).filter((B)=>B.id===W||q8(B.name)===W||B.id.endsWith(`:${W}`)).filter((B)=>!B.disabled);if(X.length!==1)return X.length>1?`Skill "${Q}" is ambiguous. Use one of: ${X.map((B)=>B.id).join(", ")}`:`Skill "${Q}" not found.`;let H=X[0].skill,Y=Z?.trim(),V=Y?`
|
|
698
|
-
<command-args>${Y}</command-args>`:"",
|
|
699
|
-
|
|
700
|
-
`:"";return`<command-name>${
|
|
693
|
+
version = team_outcome_fragments.version + 1`,[W,Q.outcomeId,Q.id,Q.section,Q.sourceAgentId,Q.sourceRunId??null,Q.content,Q.status,Q.reviewedBy??null,Q.reviewedAt?Q.reviewedAt.toISOString():null])})}markInProgressRunsInterrupted($,f){let J=Df($),W=this.queryAll("SELECT run_id FROM team_runs WHERE team_name = ? AND status IN ('queued', 'running')",[J]);if(W.length===0)return[];let Z=LZ();return this.run(`UPDATE team_runs SET status = 'interrupted', error = ?, ended_at = ?, version = version + 1
|
|
694
|
+
WHERE team_name = ? AND status IN ('queued', 'running')`,[f,Z,J]),W.map((Q)=>Q.run_id)}handleTeamEvent($,f){this.appendTeamEvent($,f.type,f)}}function eX($={}){try{let f=new m2($);return f.init(),f}catch{let f=new Q4({teamDir:$.teamDir});return f.init(),f}}function j4($,f){return OT($,f)}function zT($,f){let J=f?.["*"]??{},W=f?.[$]??{};return{...J,...W}.enabled!==!1}function TT($,f){return $.filter((J)=>zT(J.name,f))}function $Y($,f){return p1(TT($,f))}function fY(){return`team-${_T(5)}`}function OZ($,f,J,W,Z,Q,j,H){let X=s0[w$({mode:J})],Y=uf(f,W,J,Z??vf);return $Y(nf({cwd:$,...X,enableSkills:!!j,...Y,executors:{...j?{skills:j}:{},...H??{}}}),Q)}function NT($){return OZ($.cwd,$.providerId,$.mode,$.modelId,$.toolRoutingRules,$.toolPolicies,MT,$.toolExecutors).some((f)=>f.name==="skills")}var MT=async()=>"";async function yT($){let f=S0();if(!P1({filePath:f}))return{tools:[]};let J=new J2({clientFactory:KJ({settingsPath:f})}),W;try{W=await f2(J,{filePath:f})}catch(H){await J.dispose().catch(()=>{});let X=H instanceof Error?H.message:String(H);return $?.log(`[mcp] Failed to load MCP settings, skipping MCP tools: ${X}`),{tools:[]}}let Z=W.filter((H)=>H.disabled!==!0),Q=await Promise.allSettled(Z.map((H)=>PJ({serverName:H.name,provider:J}))),j=[];for(let[H,X]of Q.entries())if(X.status==="fulfilled")j.push(...X.value);else{let Y=X.reason instanceof Error?X.reason.message:String(X.reason);$?.log(`[mcp] Failed to load tools from MCP server "${Z[H].name}", skipping: ${Y}`)}return{tools:j,shutdown:async()=>{await J.dispose()}}}function qT($,f){if(!$)return;for(let J of $.getTeammateIds())try{$.shutdownTeammate(J,f)}catch{}}function wT($){if($===void 0)return!0;switch($){case"session_stop":case"session_complete":case"session_error":case"session_manager_dispose":case"cli_run_shutdown":case"cli_interactive_shutdown":case"cli_interactive_startup_cancelled":case"provider_change":case"acp_shutdown":case"hub_server_stop":case"vscode_webview_dispose":return!0;default:return!1}}function ST($){let f=s0[w$({mode:$.mode})];return{sessionId:$.sessionId||"",mode:$.mode==="plan"?"plan":$.mode==="yolo"?"yolo":"act",enableTools:$.enableTools!==!1,enableSpawnAgent:$.enableSpawnAgent??f.enableSpawnAgent??!0,enableAgentTeams:$.enableAgentTeams??f.enableAgentTeams??!0,disableMcpSettingsTools:$.disableMcpSettingsTools===!0,yolo:$.yolo===!0,missionLogIntervalSteps:typeof $.missionLogIntervalSteps==="number"&&Number.isFinite($.missionLogIntervalSteps)?$.missionLogIntervalSteps:3,missionLogIntervalMs:typeof $.missionLogIntervalMs==="number"&&Number.isFinite($.missionLogIntervalMs)?$.missionLogIntervalMs:120000}}class H4{teamRuntimeEntries=new Map;async build($){let{config:f,hooks:J,extensions:W,logger:Z,telemetry:Q,createSpawnTool:j,onTeamRestored:H,userInstructionService:X,configExtensions:Y,toolExecutors:A}=$,V=$.onTeamEvent??(()=>{}),B=ST(f),K=Q$(),G=[],R=f.teamName?.trim()||fY(),P=f.sessionId?.trim()||R,F=j4(Y,"rules"),U=j4(Y,"skills"),_=j4(Y,"workflows"),z=j4(Y,"plugins"),D=F||U||_,O=!1,T=Boolean(X),M=X,s;if(!M&&D)M=Wf({skills:U?{workspacePath:f.cwd,includePluginSkills:z,pluginSkillDirectories:z?$.pluginSkillDirectories:void 0,pluginPaths:f.pluginPaths,cwd:f.cwd}:{workspacePath:f.cwd},rules:{workspacePath:f.cwd},workflows:{workspacePath:f.cwd}});if(M)await M.start().catch(()=>{});let Z0=B.enableTools&&U&&Boolean(M)&&M?.hasConfiguredSkills(f.skills)===!0&&NT({cwd:f.cwd,providerId:f.providerId,mode:B.mode,modelId:f.modelId,toolRoutingRules:f.toolRoutingRules,toolPolicies:f.toolPolicies,toolExecutors:A}),a=M&&D?M.createExtension({includeRules:F,includeSkills:U,includeWorkflows:_,registerSkillsTool:Z0,allowedSkillNames:f.skills}):void 0,Q0=a?[...W??f.extensions??[],a]:W??f.extensions;if(B.enableTools){if(G.push(...OZ(f.cwd,f.providerId,B.mode,f.modelId,f.toolRoutingRules,f.toolPolicies,void 0,A)),!B.disableMcpSettingsTools){let d=await yT(f.logger);G.push(...d.tools),s=d.shutdown}}let l,i0=B.enableAgentTeams?eX():void 0,c=i0?.loadRuntime(P),v0=c?.state,C=c?.teammates??[],V0=new Map(C.map((d)=>[d.agentId,d])),p=f.sessionId||R,u0,o$=[],e$=!1,m1=WJ({providerId:f.providerId,modelId:f.modelId,cwd:f.cwd,apiKey:f.apiKey??"",baseUrl:f.baseUrl,headers:f.headers,providerConfig:f.providerConfig,knownModels:f.knownModels,thinking:f.thinking,maxIterations:f.maxIterations,hooks:J,extensions:Q0,logger:Z??f.logger,telemetry:$.telemetry??f.telemetry,workspaceMetadata:f.workspaceMetadata});if(!this.teamRuntimeEntries.has(p))this.teamRuntimeEntries.set(p,{delegatedAgentConfigProvider:m1});let _f=()=>{if(!B.enableAgentTeams)return;let d=this.teamRuntimeEntries.get(p)??{delegatedAgentConfigProvider:m1};if(this.teamRuntimeEntries.set(p,d),l=d.runtime,!l){if(l=new q2({teamName:R,leadAgentId:f.sessionId||"lead",missionLogIntervalSteps:B.missionLogIntervalSteps,missionLogIntervalMs:B.missionLogIntervalMs,onTeamEvent:(o)=>{if(V(o),l&&i0){if(o.type==="teammate_spawned"&&o.teammate?.rolePrompt){let J$={agentId:o.agentId,rolePrompt:o.teammate.rolePrompt,modelId:o.teammate.modelId,maxIterations:o.teammate.maxIterations};V0.set(J$.agentId,J$)}if(o.type==="teammate_shutdown"&&!wT(o.reason))V0.delete(o.agentId);i0.handleTeamEvent(P,o),i0.persistRuntime(P,l.exportState(),Array.from(V0.values()))}}}),v0)l.hydrateState(v0),e$=!0;d.runtime=l}if(!O){if(!l)return;O=!0;let o=HJ({runtime:l,leadAgentId:f.sessionId||"lead",restoredFromPersistence:Boolean(v0),restoredTeammates:C,includeLeadSpawnTool:!0,includeLeadManagementTools:!0,onLeadToolsUnlocked:(J$)=>{o$=J$,u0?.addTools(J$)},createBaseTools:B.enableTools?()=>OZ(f.cwd,f.providerId,B.mode,f.modelId,f.toolRoutingRules,f.toolPolicies,void 0,A):void 0,teammateConfigProvider:m1});if(e$)l.recoverActiveRuns("runtime_recovered");if(o.restoredFromPersistence)H?.();G.push(...o.tools)}return l};if(B.enableSpawnAgent&&j){let d=j();G.push({...d,execute:async(o,J$)=>{return _f(),d.execute(o,J$)}})}if(B.enableAgentTeams)_f();let i2=$Y(G,f.toolPolicies),C4=i2.some((d)=>d.name===j0.SUBMIT_AND_EXIT&&d.lifecycle?.completesRun===!0),g1=B.enableAgentTeams?()=>{let d=this.teamRuntimeEntries.get(p)?.runtime;if(!d)return;let o=d.listTasks(),J$=o.some((U$)=>U$.status==="in_progress"||U$.status==="pending"),G9=d.listRuns({}),uA=G9.some((U$)=>U$.status==="running"||U$.status==="queued");if(J$||uA){let U$=o.filter((N0)=>N0.status==="in_progress"||N0.status==="pending").map((N0)=>`${N0.id} (${N0.status}): ${N0.title}`).join(", "),P9=G9.filter((N0)=>N0.status==="running"||N0.status==="queued").map((N0)=>`${N0.id} (${N0.status})`).join(", "),E4=[];if(U$)E4.push(`Unfinished tasks: ${U$}`);if(P9)E4.push(`Active runs: ${P9}`);return`[SYSTEM] You still have team obligations. ${E4.join(". ")}. Use team_run_task to delegate work, or team_task with action=complete to mark tasks done, or team_await_runs to wait for active runs. Do NOT stop until all tasks are completed.`}return}:void 0,zf=C4?{requireCompletionTool:!0,...g1?{completionGuard:g1}:{}}:g1?{completionGuard:g1}:void 0;return{tools:i2,logger:Z??f.logger,telemetry:Q??f.telemetry,teamRuntime:l,teamRestoredFromPersistence:Boolean(v0),delegatedAgentConfigProvider:this.teamRuntimeEntries.get(p)?.delegatedAgentConfigProvider??m1,extensions:Q0,completionPolicy:zf,registerLeadAgent:(d)=>{if(u0=d,o$.length>0)d.addTools(p1(o$,[...K]))},shutdown:async(d)=>{if(qT(l,d),this.teamRuntimeEntries.delete(p),await s?.(),!T)M?.stop()}}}}import{getClineEnvironmentConfig as hT,isOAuthProviderId as CT}from"@cline/shared";var _Z="workos:";function ET($,f){if($==="cline")return`${_Z}${f}`;return f}function bT($,f){if($==="cline"&&f.toLowerCase().startsWith(_Z))return f.slice(_Z.length);return f}function kT($){let J=P0($)?.exp;if(typeof J==="number"&&J>0)return J*1000;return null}function IT($,f){let J=$.auth?.expiresAt;if(typeof J==="number"&&Number.isFinite(J)&&J>0)return J;let W=kT(f);if(W)return W;return Date.now()-1}function xT($,f){let J=f.auth?.accessToken?.trim(),W=f.auth?.refreshToken?.trim();if(!J||!W)return null;let Z=bT($,J);if(!Z)return null;return{access:Z,refresh:W,expires:IT(f,Z),accountId:f.auth?.accountId}}function mT($,f){let J=$?.expiresAt,W=f?.expiresAt;return $?.accessToken===f?.accessToken&&$?.refreshToken===f?.refreshToken&&$?.accountId===f?.accountId&&J===W}class X4 extends Error{providerId;constructor($){super(`OAuth credentials for provider "${$}" are no longer valid. Re-run authentication for this provider.`);this.name="OAuthReauthRequiredError",this.providerId=$}}class zZ{providerSettingsManager;telemetry;refreshInFlight=new Map;constructor($){this.providerSettingsManager=$?.providerSettingsManager??new n$,this.telemetry=$?.telemetry}async resolveProviderApiKey($){if(!CT($.providerId))return null;return this.resolveWithSingleFlight($.providerId,$.forceRefresh)}async resolveWithSingleFlight($,f=!1){let J=this.refreshInFlight.get($);if(J)return J;let W=this.resolveProviderApiKeyInternal($,f).catch((Z)=>{throw Z}).finally(()=>{this.refreshInFlight.delete($)});return this.refreshInFlight.set($,W),W}async resolveProviderApiKeyInternal($,f){let J=this.providerSettingsManager.getProviderSettings($);if(!J)return null;let W=xT($,J);if(!W)return null;let Z=await this.resolveCredentials($,J,W,f);if(!Z)throw new X4($);let Q=ET($,Z.access),j={...J.auth??{},accessToken:Q,refreshToken:Z.refresh,accountId:Z.accountId};j.expiresAt=Z.expires;let H={...J,auth:j},X=!mT(J.auth,H.auth);if(X)this.providerSettingsManager.saveProviderSettings(H,{setLastUsed:!1,tokenSource:"oauth"});return{providerId:$,apiKey:Q,accountId:Z.accountId,refreshed:X}}async resolveCredentials($,f,J,W){if($==="cline")return j6(J,{apiBaseUrl:f.baseUrl?.trim()||hT().apiBaseUrl,telemetry:this.telemetry},{forceRefresh:W});if($==="oca")return G6(J,{forceRefresh:W,telemetry:this.telemetry},{mode:f.oca?.mode,telemetry:this.telemetry});return X6(J,{forceRefresh:W,telemetry:this.telemetry})}}import{normalizeUserInput as gT}from"@cline/shared";import{nanoid as vT}from"nanoid";class JY{list($){return $?k0($):[]}update($,f){if(!$)return{sessionId:f.sessionId,prompts:[],updated:!1};let J=f.promptId.trim(),W=$.pendingPrompts.findIndex((X)=>X.id===J);if(W<0)return{sessionId:f.sessionId,prompts:k0($),updated:!1};let Z=$.pendingPrompts[W];if(!Z)return{sessionId:f.sessionId,prompts:k0($),updated:!1};let Q=f.prompt===void 0?Z.prompt:gT(f.prompt).trim();if(!Q)throw Error("prompt cannot be empty");let j=f.delivery??Z.delivery,H={...Z,prompt:Q,mode:f.mode??Z.mode,delivery:j};return $.pendingPrompts.splice(W,1),uT($,H,W,Z.delivery),{sessionId:f.sessionId,prompts:k0($),prompt:Y4(H),updated:!0}}delete($,f){if(!$)return{sessionId:f.sessionId,prompts:[],removed:!1};let J=f.promptId.trim(),W=$.pendingPrompts.findIndex((Q)=>Q.id===J);if(W<0)return{sessionId:f.sessionId,prompts:k0($),removed:!1};let[Z]=$.pendingPrompts.splice(W,1);return{sessionId:f.sessionId,prompts:k0($),prompt:Z?Y4(Z):void 0,removed:!0}}enqueue($,f){let{prompt:J,mode:W,delivery:Z,userImages:Q,userFiles:j}=f,H=$.pendingPrompts.findIndex((X)=>X.prompt===J);if(H>=0){let[X]=$.pendingPrompts.splice(H,1),Y={...X,prompt:J,mode:W??X.mode,userImages:Q??X.userImages,userFiles:j??X.userFiles};if(Z==="steer"||X.delivery==="steer")$.pendingPrompts.unshift({...Y,delivery:"steer"});else $.pendingPrompts.push(Y)}else{let X={id:`pending_${Date.now()}_${vT(5)}`,prompt:J,mode:W,delivery:Z,userImages:Q,userFiles:j};if(Z==="steer")$.pendingPrompts.unshift(X);else $.pendingPrompts.push(X)}return k0($)}consumeSteer($){let f=$.pendingPrompts.findIndex((W)=>W.delivery==="steer");if(f<0)return{prompts:k0($)};let[J]=$.pendingPrompts.splice(f,1);return{entry:J,prompts:k0($)}}shiftNext($){return{entry:$.pendingPrompts.shift(),prompts:k0($)}}requeueFront($,f){return $.pendingPrompts.unshift(f),k0($)}clear($){return $.pendingPrompts.length=0,[]}}class TZ{deps;service=new JY;constructor($){this.deps=$}list($){return this.service.list(this.deps.getSession($))}update($){let f=this.deps.getSession($.sessionId);if(!f||f.aborting)return{sessionId:$.sessionId,prompts:[],updated:!1};let J=this.service.update(f,$);return this.emitPrompts(f),this.scheduleDrain($.sessionId,f),J}delete($){let f=this.deps.getSession($.sessionId);if(!f||f.aborting)return{sessionId:$.sessionId,prompts:[],removed:!1};let J=this.service.delete(f,$);return this.emitPrompts(f),this.scheduleDrain($.sessionId,f),J}enqueue($,f){let J=this.deps.getSession($);if(!J||J.aborting)return;this.service.enqueue(J,f),this.emitPrompts(J),this.scheduleDrain($,J)}consumeSteer($){let f=this.deps.getSession($);if(!f)return;let{entry:J}=this.service.consumeSteer(f);if(!J)return;return this.emitPrompts(f),this.emitSubmitted(f,J),J}clearAborted($){if($.pendingPrompts.length===0)return;this.service.clear($),this.emitPrompts($)}emitPrompts($){this.deps.emit({type:"pending_prompts",payload:{sessionId:$.sessionId,prompts:k0($)}})}scheduleDrain($,f){if(f.pendingPrompts.length===0||f.aborting||f.drainingPendingPrompts||!f.agent.canStartRun())return;queueMicrotask(()=>{this.drain($)})}async drain($){let f=this.deps.getSession($);if(!f)return;if(f.aborting||f.drainingPendingPrompts)return;if(!f.agent.canStartRun())return;let{entry:J}=this.service.shiftNext(f);if(!J)return;this.emitPrompts(f),this.emitSubmitted(f,J),f.drainingPendingPrompts=!0;let W=!0;try{await this.deps.send({sessionId:$,prompt:J.prompt,...J.mode?{mode:J.mode}:{},userImages:J.userImages,userFiles:J.userFiles})}catch{W=!1,this.service.requeueFront(f,J),this.emitPrompts(f)}finally{if(f.drainingPendingPrompts=!1,W&&f.pendingPrompts.length>0&&f.status!=="failed"&&f.status!=="cancelled")queueMicrotask(()=>{this.drain($)})}}emitSubmitted($,f){let J=Y4(f);this.deps.emit({type:"pending_prompt_submitted",payload:{sessionId:$.sessionId,id:J.id,prompt:J.prompt,delivery:J.delivery,attachmentCount:J.attachmentCount}})}}function Y4($){return{id:$.id,prompt:$.prompt,delivery:$.delivery,attachmentCount:($.userImages?.length??0)+($.userFiles?.length??0)}}function k0($){return $.pendingPrompts.map(Y4)}function uT($,f,J,W){if(f.delivery==="steer")$.pendingPrompts.unshift(f);else if(W==="steer")$.pendingPrompts.push(f);else $.pendingPrompts.splice(J,0,f)}B0();class MZ{deps;constructor($){this.deps=$}dispatchAgentEvent($,f,J){let W=this.deps.getSession($),Z={sessionId:$,config:f,liveSession:W,usageBySession:this.deps.usageBySession,aggregateUsageBySession:this.deps.aggregateUsageBySession,persistMessages:this.deps.persistMessages,emit:this.deps.emit},Q=$Z(J),j=!!W&&(!Q.agentId||Q.agentId===NZ(W.agent));fZ(Z,J,j?{isPrimaryAgentEvent:!0,agentId:NZ(W.agent),conversationId:W.agent.getConversationId(),...W?.runtime.teamRuntime?{teamRole:"lead"}:{}}:{isPrimaryAgentEvent:!1})}async handleTeamEvent($,f){let J=this.deps.getSession($);if(J){if(kW(J,f),f.type==="agent_event"){let W={sessionId:$,config:J.config,liveSession:J,usageBySession:this.deps.usageBySession,aggregateUsageBySession:this.deps.aggregateUsageBySession,persistMessages:this.deps.persistMessages,emit:this.deps.emit};fZ(W,f.event,{agentId:f.agentId,teamRole:"teammate",teamAgentId:f.agentId,isPrimaryAgentEvent:!1})}if(f.type==="teammate_spawned"){let W=G$({agentId:f.teammate.runtimeAgentId??f.agentId,conversationId:f.teammate.conversationId,parentAgentId:f.teammate.parentAgentId,createdByAgentId:NZ(J.agent),teamId:J.runtime.teamRuntime?.getTeamId(),teamName:J.runtime.teamRuntime?.getTeamName(),teamRole:"teammate",teamAgentId:f.agentId});if(W)J1(J.config.telemetry,{ulid:$,modelId:f.teammate.modelId??J.config.modelId,provider:J.config.providerId,...W})}}if(await IW($,f,this.deps.invokeBackendOptional),J)xW(J,$,f,this.deps.emit)}async handlePluginEvent($,f,J){if(f.name==="plugin_log"){this.handlePluginLog($,f.payload);return}if(f.name==="automation_event"){let X=this.deps.getSession($)?.config.extensionContext?.automation??J;if(!X)return;let Y=f.payload&&typeof f.payload==="object"?f.payload:void 0;if(!Y)return;await X.ingestEvent(Y);return}if(f.name!=="steer_message"&&f.name!=="queue_message"&&f.name!=="pending_prompt")return;let W=f.payload&&typeof f.payload==="object"?f.payload:void 0,Z=typeof W?.sessionId==="string"&&W.sessionId.trim().length>0?W.sessionId.trim():$,Q=typeof W?.prompt==="string"?W.prompt.trim():"";if(!Q)return;let j=f.name==="steer_message"?"steer":f.name==="queue_message"?"queue":W?.delivery==="steer"?"steer":"queue";this.deps.enqueuePendingPrompt(Z,{prompt:Q,delivery:j})}handlePluginLog($,f,J){let W=this.deps.getSession($),Z=J??W?.config.extensionContext?.logger??W?.config.logger;if(!Z||!f||typeof f!=="object")return;let Q=f,j=typeof Q.message==="string"?Q.message:"";if(!j)return;let H=Q.metadata&&typeof Q.metadata==="object"?{...Q.metadata}:{};if(H.sessionId??=$,typeof Q.pluginName==="string"&&Q.pluginName)H.pluginName=Q.pluginName;if(Q.level==="debug"){Z.debug(j,H);return}if(Q.level==="error"){if(Z.error)Z.error(j,H);else Z.log(j,{...H,severity:"error"});return}Z.log(j,H)}}function NZ($){return $.getAgentId()}function yZ($){return{sessionId:$.sessionId,source:$.source,pid:process.pid,startedAt:$.startedAt,endedAt:$.endedAt??null,exitCode:$.exitCode??null,status:$.status,interactive:$.interactive,provider:$.config.providerId,model:$.config.modelId,cwd:$.config.cwd,workspaceRoot:p$($.config),teamName:$.config.teamName?.trim()||void 0,enableTools:$.config.enableTools,enableSpawn:$.config.enableSpawnAgent,enableTeams:$.config.enableAgentTeams,parentSessionId:typeof $.sessionMetadata?.parentSessionId==="string"?$.sessionMetadata.parentSessionId:void 0,parentAgentId:typeof $.sessionMetadata?.parentAgentId==="string"?$.sessionMetadata.parentAgentId:void 0,agentId:typeof $.sessionMetadata?.agentId==="string"?$.sessionMetadata.agentId:void 0,conversationId:typeof $.sessionMetadata?.conversationId==="string"?$.sessionMetadata.conversationId:void 0,isSubagent:typeof $.sessionMetadata?.isSubagent==="boolean"?$.sessionMetadata.isSubagent:!1,prompt:$.pendingPrompt,metadata:$.sessionMetadata,messagesPath:$.artifacts?.messagesPath,updatedAt:$.updatedAt??$.endedAt??$.startedAt}}function qZ($,f){let J=$[f];return typeof J==="function"?J:null}async function WY($,f,...J){let W=qZ($,f);if(!W)throw Error(`session service method not available: ${f}`);return Promise.resolve(W.apply($,J))}async function ZY($,f,...J){let W=qZ($,f);if(!W)return;await Promise.resolve(W.apply($,J))}async function QY($,f,...J){let W=qZ($,f);if(!W)return;return await Promise.resolve(W.apply($,J))}n0();B0();function wZ($,f,J,W){return Jf({configProvider:{getRuntimeConfig:()=>$.getSession(J)?.runtime.delegatedAgentConfigProvider?.getRuntimeConfig()??{providerId:f.providerId,modelId:f.modelId,cwd:f.cwd,apiKey:f.apiKey,baseUrl:f.baseUrl,headers:f.headers,providerConfig:f.providerConfig,knownModels:f.knownModels,thinking:f.thinking,maxIterations:f.maxIterations,hooks:f.hooks,extensions:f.extensions,logger:f.logger,telemetry:f.telemetry},getConnectionConfig:()=>$.getSession(J)?.runtime.delegatedAgentConfigProvider?.getConnectionConfig()??{providerId:f.providerId,modelId:f.modelId,apiKey:f.apiKey,baseUrl:f.baseUrl,headers:f.headers,providerConfig:f.providerConfig,knownModels:f.knownModels,thinking:f.thinking},updateConnectionDefaults:()=>{}},createSubAgentTools:()=>{let Q=f.enableTools?nf({cwd:f.cwd,...s0[w$({mode:f.mode})],executors:W}):[];if(f.enableSpawnAgent)Q.push(wZ($,f,J,W));return p1(Q)},onSubAgentEvent:(Q)=>$.onAgentEvent(J,f,Q),onSubAgentStart:(Q)=>{let j=$.getSession(J)?.runtime.teamRuntime;$.subAgentStarts.set(Q.subAgentId,{startedAt:Date.now(),rootSessionId:J});let H=G$({agentId:Q.subAgentId,conversationId:Q.conversationId,parentAgentId:Q.parentAgentId,teamId:j?.getTeamId(),teamName:j?.getTeamName(),createdByAgentId:Q.parentAgentId});if(H)J1(f.telemetry,{ulid:J,modelId:f.modelId,provider:f.providerId,...H});s2(f.telemetry,{event:"started",ulid:J,durationMs:0,parentId:Q.parentAgentId,agentId:Q.subAgentId,...H}),$.invokeBackendOptional("handleSubAgentStart",J,Q)},onSubAgentEnd:(Q)=>{let j=$.getSession(J)?.runtime.teamRuntime,H=$.subAgentStarts.get(Q.subAgentId),X=H?Date.now()-H.startedAt:0,Y=Q.result?.text?Q.result.text.split(`
|
|
695
|
+
`).length:0;s2(f.telemetry,{event:"ended",ulid:J,durationMs:X,outputLines:Y,errorMessage:Q.error?String(Q.error):void 0,agentId:Q.subAgentId,parentId:Q.parentAgentId,...G$({agentId:Q.subAgentId,conversationId:Q.conversationId,parentAgentId:Q.parentAgentId,teamId:j?.getTeamId(),teamName:j?.getTeamName(),createdByAgentId:Q.parentAgentId})}),$.subAgentStarts.delete(Q.subAgentId),$.invokeBackendOptional("handleSubAgentEnd",J,Q)}})}import{readFile as cT,stat as dT}from"node:fs/promises";var lT=20480000;async function jY($){let f=await dT($);if(!f.isFile())throw Error("Path is not a file");if(f.size>lT)throw Error("File is too large to read into context.");let J=await cT($,"utf8");if(J.includes("\x00"))throw Error("Cannot read binary file into context.");return J}var HY=5000;function g2($){return typeof $==="number"&&Number.isFinite($)?$:void 0}function oT($){if(!$||typeof $!=="object"||Array.isArray($))return;let f=$,J=g2(f.inputTokens),W=g2(f.outputTokens),Z=g2(f.cacheReadTokens),Q=g2(f.cacheWriteTokens),j=g2(f.totalCost);if(J===void 0||W===void 0||Z===void 0||Q===void 0||j===void 0)return;return{inputTokens:J,outputTokens:W,cacheReadTokens:Z,cacheWriteTokens:Q,totalCost:j}}function eT($,f){return{inputTokens:Math.max($.inputTokens,f.inputTokens),outputTokens:Math.max($.outputTokens,f.outputTokens),cacheReadTokens:Math.max($.cacheReadTokens,f.cacheReadTokens),cacheWriteTokens:Math.max($.cacheWriteTokens,f.cacheWriteTokens),totalCost:Math.max($.totalCost,f.totalCost)}}class a${runtimeAddress=void 0;pendingPrompts;sessionService;runtimeBuilder;createAgentInstance;toolExecutors;defaultCapabilities;defaultToolPolicies;providerSettingsManager;oauthTokenManager;defaultTelemetry;defaultFetch;events=new R2;sessions=new Map;usageBySession=new Map;aggregateUsageBySession=new Map;subAgentStarts=new Map;pendingPromptsController;eventBridge;sessionVersioning=new Uf;constructor($){let f=rT();if(f)sT(f);let J=y1($.distinctId);this.sessionService=$.sessionService,this.runtimeBuilder=$.runtimeBuilder??new H4,this.createAgentInstance=$.createAgent??((W)=>new S$(W)),this.defaultCapabilities=U0($.capabilities),this.toolExecutors=this.defaultCapabilities?.toolExecutors,this.defaultToolPolicies=$.toolPolicies,this.providerSettingsManager=$.providerSettingsManager??new n$,this.oauthTokenManager=$.oauthTokenManager??new zZ({providerSettingsManager:this.providerSettingsManager,telemetry:$.telemetry}),this.defaultTelemetry=$.telemetry,this.defaultTelemetry?.setDistinctId(J),this.defaultFetch=$.fetch,this.pendingPromptsController=new TZ({getSession:(W)=>this.sessions.get(W),emit:(W)=>this.emit(W),send:(W)=>this.runTurn(W)}),this.pendingPrompts={list:async(W)=>this.pendingPromptsController.list(W.sessionId),update:async(W)=>this.pendingPromptsController.update(W),delete:async(W)=>this.pendingPromptsController.delete(W)},this.eventBridge=new MZ({getSession:(W)=>this.sessions.get(W),usageBySession:this.usageBySession,aggregateUsageBySession:this.aggregateUsageBySession,emit:(W)=>this.emit(W),persistMessages:(W,Z,Q)=>{this.invoke("persistSessionMessages",W,Z,Q)},enqueuePendingPrompt:(W,Z)=>this.pendingPromptsController.enqueue(W,Z),invokeBackendOptional:(W,...Z)=>this.invokeOptional(W,...Z)})}async startSession($){let f=$.source??F0.CLI,J=n(),W=$.config.sessionId?.trim()??"",Z=W||nT(),Q=$,j=Q.initialMessages??[],H=j.length>0?dJ(j):G0(),X=await this.invokeOptionalValue("ensureSessionsDir")??"";if(!X)throw Error("session service method not available: ensureSessionsDir");let Y=SZ(X,Z),A=SZ(Y,`${Z}.messages.json`),V=SZ(Y,`${Z}.json`),B=p$($.config),K=_0.parse({version:1,session_id:Z,source:f,pid:process.pid,started_at:J,status:"running",interactive:$.interactive===!0,provider:Q.config.providerId,model:Q.config.modelId,cwd:Q.config.cwd,workspace_root:B,team_name:Q.config.teamName,enable_tools:Q.config.enableTools,enable_spawn:Q.config.enableSpawnAgent,enable_teams:Q.config.enableAgentTeams,prompt:Q.prompt?.trim()||void 0,messages_path:A}),G;if(W.length>0&&j.length>0&&!Q.prompt?.trim()){let C=await this.invokeOptionalValue("readSessionManifest",Z);if(C)K=C,G={manifestPath:V,messagesPath:C.messages_path||A,manifest:C}}let P=await this.seedAggregateUsageFromArtifacts({initialUsage:H,sessionDir:Y,rootMessagesPath:G?.messagesPath??A,manifest:K});this.usageBySession.set(Z,H),this.aggregateUsageBySession.set(Z,P);let F=U0(this.defaultCapabilities,$.capabilities),U=F?.toolExecutors??this.toolExecutors,_=$.localRuntime,z=_?.extensionContext?.logger??_?.logger,D=_?.extensionContext?.automation,O;O=await OX({input:Q,localRuntime:$.localRuntime,sessionId:Z,providerSettingsManager:this.providerSettingsManager,defaultTelemetry:this.defaultTelemetry,defaultCapabilities:F,defaultToolPolicies:this.defaultToolPolicies,defaultFetch:this.defaultFetch,onPluginEvent:(C)=>{if(C.name==="plugin_log"){this.eventBridge.handlePluginLog(Z,C.payload,z);return}this.eventBridge.handlePluginEvent(Z,C,D)},onTeamEvent:(C)=>{this.eventBridge.handleTeamEvent(Z,C),O.config.onTeamEvent?.(C)},createSpawnTool:()=>wZ({getSession:(C)=>this.sessions.get(C),subAgentStarts:this.subAgentStarts,onAgentEvent:(C,V0,p)=>this.eventBridge.dispatchAgentEvent(C,V0,p),invokeBackendOptional:(C,...V0)=>this.invokeOptional(C,...V0)},O.config,Z,U),readSessionMetadata:async()=>(await this.getSession(Z))?.metadata,writeSessionMetadata:async(C)=>{await this.persistSessionMetadata(Z,()=>C)}});let T=await this.runtimeBuilder.build(O.runtimeBuilderInput),M=O.config,s=O.providerConfig;if(T.teamRuntime&&!M.teamName?.trim())M.teamName=T.teamRuntime.getTeamName();let Z0=[...T.tools,...M.extraTools??[]],a=T.extensions??O.extensions,Q0={sessionId:Z,providerId:s.providerId,modelId:s.modelId,apiKey:s.apiKey,baseUrl:s.baseUrl,headers:s.headers,knownModels:s.knownModels,providerConfig:s,thinking:M.thinking,reasoningEffort:M.reasoningEffort??s.reasoningEffort,systemPrompt:M.systemPrompt,maxIterations:M.maxIterations,execution:M.execution,prepareTurn:eW(M),tools:Z0,hooks:O.hooks,extensions:a,hookErrorMode:M.hookErrorMode,initialMessages:O.effectiveInput.initialMessages,userFileContentLoader:jY,toolPolicies:O.toolPolicies,requestToolApproval:O.requestToolApproval?async(C)=>{let V0=O.requestToolApproval,p=this.sessions.get(Z);if(p)await this.markTurnPending(p);try{if(!V0)return{approved:!1,reason:"Tool approval callback is not configured."};return await V0(C)}finally{let u0=this.sessions.get(Z);if(u0?.status==="pending")await this.markTurnRunning(u0)}}:void 0,telemetry:M.telemetry,onConsecutiveMistakeLimitReached:M.onConsecutiveMistakeLimitReached,completionPolicy:T.completionPolicy,consumePendingUserMessage:()=>{let C=this.pendingPromptsController.consumeSteer(Z);return C?S2(C.prompt,C.mode??M.mode):void 0},logger:T.logger??M.logger,extensionContext:M.extensionContext,onEvent:(C)=>this.eventBridge.dispatchAgentEvent(Z,M,C)};Q0.hooks={...Q0.hooks,onEvent:async(C)=>{if(await O.hooks?.onEvent?.(C),C.type!=="assistant-message")return;let V0=this.sessions.get(Z);if(!V0)return;let p=V0.agent.getMessages();try{await this.invoke("persistSessionMessages",Z,p,M.systemPrompt)}catch(u0){M.logger?.error?.("Failed to persist session messages after assistant response",{sessionId:Z,error:u0}),C1(M.telemetry,{component:"core",operation:"session.persist_messages_after_assistant_response",error:u0,severity:"warn",handled:!0,context:{sessionId:Z,providerId:M.providerId,modelId:M.modelId}})}}};let l=this.createAgentInstance(Q0);if(Q0.onEvent)l.subscribeEvents(Q0.onEvent);T.registerLeadAgent?.(l);let i0=G$({agentId:l.getAgentId(),conversationId:l.getConversationId(),teamId:T.teamRuntime?.getTeamId(),teamName:T.teamRuntime?.getTeamName(),teamRole:T.teamRuntime?"lead":void 0});if(_X(M,Z,W.length>0,B,i0),i0)J1(M.telemetry,{ulid:Z,modelId:M.modelId,provider:M.providerId,...i0});if(T.teamRuntime)t4(M.telemetry,{ulid:Z,teamId:T.teamRuntime.getTeamId(),teamName:T.teamRuntime.getTeamName(),leadAgentId:l.getAgentId(),restoredFromPersistence:T.teamRestoredFromPersistence===!0});let c={sessionId:Z,config:M,sessionMetadata:Q.sessionMetadata,...G?{artifacts:G}:{},source:f,startedAt:G?.manifest.started_at??J,updatedAt:G?.manifest.ended_at??G?.manifest.started_at??J,pendingPrompt:K.prompt,runtime:T,agent:l,started:!1,status:G?.manifest.status??"running",aborting:!1,interactive:$.interactive===!0,persistedMessages:j,activeTeamRunIds:new Set,pendingTeamRunUpdates:[],teamRunWaiters:[],pendingPrompts:[],drainingPendingPrompts:!1,pluginSandboxShutdown:O.pluginSandboxShutdown,submitAndExitObserved:!1,lastInteractiveTurnFinishReason:void 0};if(this.sessions.set(Z,c),this.emitStatus(Z,"running"),j.length>0&&!G){if(await this.ensureSessionPersisted(c),await this.invoke("persistSessionMessages",c.sessionId,j,c.config.systemPrompt),!Q.prompt?.trim())await this.updateStatus(c,"completed",0)}let v0;try{if(Q.prompt?.trim())if(v0=await this.executeTurn(c,{prompt:Q.prompt,userImages:Q.userImages,userFiles:Q.userFiles}),!c.interactive)await this.finalizeSingleRun(c,v0.finishReason);else await this.completeInteractiveTurn(c,v0.finishReason)}catch(C){if(c.interactive&&c.aborting)v0=await this.completeAbortedInteractiveTurn(c);else throw C1(c.config.telemetry,{component:"core",operation:"session.start",error:C,severity:"error",handled:!1,context:{sessionId:c.sessionId,providerId:c.config.providerId,modelId:c.config.modelId}}),await this.failSession(c),C}return{sessionId:Z,manifest:K,manifestPath:V,messagesPath:A,result:v0}}async restoreSession($){return this.sessionVersioning.restoreCheckpoint({...$,getSession:(f)=>this.getSession(f),readMessages:(f)=>this.readSessionMessages(f),buildStartInput:(f,J)=>{let W=f.restoredCheckpointMetadata?{...J.sessionMetadata??{},checkpoint:f.restoredCheckpointMetadata}:J.sessionMetadata;return{...J,...W?{sessionMetadata:W}:{},initialMessages:f.initialMessages}},startSession:(f)=>this.startSession(f),getStartedSessionId:(f)=>f.sessionId,readRestoredSession:(f)=>this.getSession(f)})}async runTurn($){let f=this.getSessionOrThrow($.sessionId),J=f.agent.canStartRun(),W=$.delivery??(f.interactive&&!J?"queue":void 0);if(f.config.telemetry?.capture({event:"session.input_sent",properties:{sessionId:$.sessionId,promptLength:$.prompt.length,userImageCount:$.userImages?.length??0,userFileCount:$.userFiles?.length??0,delivery:W??"immediate"}}),W==="queue"||W==="steer"){this.pendingPromptsController.enqueue($.sessionId,{prompt:$.prompt,mode:$.mode,delivery:W,userImages:$.userImages,userFiles:$.userFiles});return}try{let Z=await this.executeTurn(f,{prompt:$.prompt,mode:$.mode,userImages:$.userImages,userFiles:$.userFiles});if(!f.interactive)await this.finalizeSingleRun(f,Z.finishReason);else await this.completeInteractiveTurn(f,Z.finishReason);if(Z.finishReason==="error"||Z.finishReason==="aborted")return Z;return queueMicrotask(()=>{this.pendingPromptsController.drain($.sessionId)}),Z}catch(Z){if(f.interactive&&f.aborting)return await this.completeAbortedInteractiveTurn(f);throw C1(f.config.telemetry,{component:"core",operation:"session.submit",error:Z,severity:"error",handled:!1,context:{sessionId:f.sessionId,providerId:f.config.providerId,modelId:f.config.modelId}}),await this.failSession(f),Z}}async getAccumulatedUsage($){let f=VW(this.usageBySession.get($)),J=VW(this.aggregateUsageBySession.get($));return f||J?{usage:f,aggregateUsage:J}:void 0}async abort($,f){let J=this.sessions.get($);if(!J)return;J.config.telemetry?.capture({event:"session.aborted",properties:{sessionId:$}}),J.aborting=!0,this.pendingPromptsController.clearAborted(J),J.agent.abort(f)}async stopSession($){let f=this.sessions.get($);if(!f)return;if(f.config.telemetry?.capture({event:"session.stopped",properties:{sessionId:$}}),f.interactive&&!$0(f.status)){await this.releaseSessionRuntime(f,"session_stop");return}if(f.interactive&&f.agent.canStartRun()){await this.shutdownSession(f,{status:this.resolveInteractiveStopStatus(f),exitCode:this.resolveInteractiveStopExitCode(f),shutdownReason:"session_stop",endReason:"stopped"});return}f.aborting=!0,f.agent.abort(Error("session_stop")),await this.shutdownSession(f,{status:"cancelled",exitCode:0,shutdownReason:"session_stop",endReason:"stopped"})}async dispose($="session_manager_dispose"){let f=[...this.sessions.values()];if(f.length===0)return;await Promise.allSettled(f.map((J)=>J.interactive&&!$0(J.status)?this.releaseSessionRuntime(J,$):J.interactive&&J.agent.canStartRun()?this.shutdownSession(J,{status:this.resolveInteractiveStopStatus(J),exitCode:this.resolveInteractiveStopExitCode(J),shutdownReason:$,endReason:"disposed"}):this.shutdownSession(J,{status:"cancelled",exitCode:0,shutdownReason:$,endReason:"disposed"}))),this.usageBySession.clear(),this.aggregateUsageBySession.clear()}async getSession($){let f=this.sessions.get($);if(f)return yZ(f);let J=$.trim();if(!J)return;let W=await this.getRow(J);if(W)return F2(W);let Z=await this.readManifest(J);return Z?GW(Z):void 0}async listSessions($=200){let J=(await this.listRows($)).map(F2),W=new Set(J.map((Z)=>Z.sessionId));for(let Z of this.sessions.values()){if(W.has(Z.sessionId))continue;J.unshift(yZ(Z))}return J.slice(0,$)}async deleteSession($){if(this.sessions.has($))await this.stopSession($);let f=await this.invoke("deleteSession",$);if(f.deleted)this.usageBySession.delete($),this.aggregateUsageBySession.delete($);return f.deleted}async updateSession($,f){return{updated:(await this.invokeOptionalValue("updateSession",{sessionId:$,prompt:f.prompt,metadata:f.metadata,title:f.title}))?.updated===!0}}async readSessionMessages($){let f=$.trim();if(!f)return[];let J=await this.getRow(f);if(J?.messagesPath)return k$(J.messagesPath);let W=await this.readManifest(f);return k$(W?.messages_path)}async dispatchHookEvent($){await bj($,{queueSpawnRequest:(f)=>this.invokeOptional("queueSpawnRequest",f),upsertSubagentSessionFromHook:(f)=>this.invokeOptionalValue("upsertSubagentSessionFromHook",f),appendSubagentHookAudit:(f,J)=>this.invokeOptional("appendSubagentHookAudit",f,J),applySubagentStatus:(f,J)=>this.invokeOptional("applySubagentStatus",f,J)})}subscribe($,f){return this.events.subscribe($,f)}async updateSessionModel($,f){let J=this.getSessionOrThrow($);J.config.modelId=f,J.runtime.delegatedAgentConfigProvider?.updateConnectionDefaults({modelId:f}),J.agent.updateConnection({modelId:f})}handlePluginEvent($,f,J){return this.eventBridge.handlePluginEvent($,f,J)}async executeTurn($,f){let J=await this.prepareTurnInput($,f),W=J.prompt.trim();if(!W)throw Error("prompt cannot be empty");if(!$.artifacts&&!$.pendingPrompt)$.pendingPrompt=W;await this.ensureSessionPersisted($),await this.syncOAuthCredentials($),await this.markTurnRunning($);let Z=await this.executeAgentTurn($,W,J.userImages,J.userFiles);while(mW($,Z.finishReason)){let Q=await gW($);if(Q.length===0)break;let j=vW($,Q);Z=await this.executeAgentTurn($,j)}return Z}async completeInteractiveTurn($,f){if(w2($))return;$.lastInteractiveTurnFinishReason=f,await this.markTurnIdle($),$.aborting=!1}resolveInteractiveStopStatus($){let f=$.lastInteractiveTurnFinishReason;if(!f)return"cancelled";switch(f){case"completed":return"completed";case"error":return"failed";case"aborted":case"max_iterations":case"mistake_limit":return"cancelled"}return f}resolveInteractiveStopExitCode($){return $.lastInteractiveTurnFinishReason==="error"?1:0}async completeAbortedInteractiveTurn($){let f=new Date,J=$.agent.getMessages(),W=G0();return $.persistedMessages=J,$.started=$.started||J.length>0,this.eventBridge.dispatchAgentEvent($.sessionId,$.config,{type:"done",reason:"aborted",text:"",iterations:0,usage:W}),await this.completeInteractiveTurn($,"aborted"),{text:"",usage:W,messages:J,toolCalls:[],iterations:0,finishReason:"aborted",model:{id:$.config.modelId,provider:$.config.providerId},startedAt:f,endedAt:f,durationMs:0}}async executeAgentTurn($,f,J,W){let Z=$.started||$.agent.getMessages().length>0,Q=$.persistedMessages??$.agent.getMessages(),j=this.usageBySession.get($.sessionId)??G0(),H=this.aggregateUsageBySession.get($.sessionId)??j;$.turnUsageBaseline=j,$.turnAggregateUsageBaseline=H,$.turnPrimaryUsage=G0(),$.turnUsageByAgent=new Map,d4($.config.telemetry,$.sessionId,$.config.mode),Tf($.config.telemetry,{ulid:$.sessionId,provider:$.config.providerId,model:$.config.modelId,source:"user",mode:$.config.mode,...this.getSessionAgentTelemetryIdentity($)});try{let X=Z?()=>$.agent.continue(f,J,W):()=>$.agent.run(f,J,W),Y=await this.runWithAuthRetry($,X,Q);$.started=!0;let A=NJ(Y.messages,Y,Q);$.persistedMessages=A;let V=cJ($.turnUsageByAgent?.values()??[]),B=Y0(j,Y.usage),K=Y0(Y0(G0(),Y.usage),V),G=Y0(H,K);return this.usageBySession.set($.sessionId,B),this.aggregateUsageBySession.set($.sessionId,G),await this.persistSessionMetadata($.sessionId,(R)=>({...R??{},totalCost:B.totalCost,aggregatedAgentsCost:G.totalCost,usage:B,aggregateUsage:G})),await this.invoke("persistSessionMessages",$.sessionId,A,$.config.systemPrompt),this.observeTaskCompletionTool($,Y),Y}catch(X){throw C1($.config.telemetry,{component:"core",operation:"session.turn",error:X,severity:"error",handled:!1,context:{sessionId:$.sessionId,providerId:$.config.providerId,modelId:$.config.modelId}}),await this.invoke("persistSessionMessages",$.sessionId,$.agent.getMessages(),$.config.systemPrompt),X}finally{$.turnUsageBaseline=void 0,$.turnAggregateUsageBaseline=void 0,$.turnPrimaryUsage=void 0,$.turnUsageByAgent=void 0}}observeTaskCompletionTool($,f){if($.submitAndExitObserved)return;if(!f.toolCalls.some((W)=>W.name===j0.SUBMIT_AND_EXIT&&W.error===void 0))return;$.submitAndExitObserved=!0,a2($.config.telemetry,{ulid:$.sessionId,provider:$.config.providerId,modelId:$.config.modelId,mode:$.config.mode,durationMs:Date.now()-Date.parse($.startedAt),source:"submit_and_exit",...this.getSessionAgentTelemetryIdentity($)})}async prepareTurnInput($,f){let J=p$($.config),W=tT(f.prompt).trim();if(!W)return{prompt:"",userImages:f.userImages,userFiles:this.resolveAbsoluteFilePaths($.config.cwd,f.userFiles)};let Z=await t8(W,J);zX($.config.telemetry,Z);let Q=S2(Z.prompt,f.mode??$.config.mode),j=this.resolveAbsoluteFilePaths($.config.cwd,f.userFiles),H=this.resolveAbsoluteFilePaths(J,Z.matchedFiles),X=Array.from(new Set([...j,...H]));return{prompt:Q,userImages:f.userImages,userFiles:X.length>0?X:void 0}}async ensureSessionPersisted($){if($.artifacts)return;let f=p$($.config);$.artifacts=await this.invoke("createRootSessionWithArtifacts",{sessionId:$.sessionId,source:$.source,pid:process.pid,interactive:$.interactive,provider:$.config.providerId,model:$.config.modelId,cwd:$.config.cwd,workspaceRoot:f,teamName:$.config.teamName,enableTools:$.config.enableTools,enableSpawn:$.config.enableSpawnAgent,enableTeams:$.config.enableAgentTeams,prompt:$.pendingPrompt,metadata:$.sessionMetadata,startedAt:$.startedAt})}async markTurnRunning($){if($.status==="running")return;await this.updateStatus($,"running",null)}async markTurnPending($){if($.status==="pending")return;await this.updateStatus($,"pending",null)}async markTurnIdle($){if($.status==="idle")return;await this.updateStatus($,"idle",null)}async persistSessionMetadata($,f){let J=this.sessions.get($),W=await this.invokeOptionalValue("readSessionManifest",$)??J?.artifacts?.manifest,Z=f(W?.metadata);if(!J?.artifacts)return;if((await this.invokeOptionalValue("updateSession",{sessionId:$,metadata:Z}))?.updated===!1)return;J.sessionMetadata=Z,J.artifacts.manifest.metadata=Z}async finalizeSingleRun($,f){if(w2($))return;let J=f==="aborted"||$.aborting,W=f==="error";await this.shutdownSession($,{status:J?"cancelled":W?"failed":"completed",exitCode:W?1:0,shutdownReason:W?"session_error":"session_complete",endReason:f})}async failSession($){await this.shutdownSession($,{status:"failed",exitCode:1,shutdownReason:"session_error",endReason:"error"})}async shutdownSession($,f){if(f.status==="completed"&&!$.submitAndExitObserved)a2($.config.telemetry,{ulid:$.sessionId,provider:$.config.providerId,modelId:$.config.modelId,mode:$.config.mode,durationMs:Date.now()-Date.parse($.startedAt),source:"shutdown",...this.getSessionAgentTelemetryIdentity($)});gJ($);let J=[],W=(Z,Q)=>{J.push(Q),$.config.logger?.log("Session shutdown cleanup failed",{sessionId:$.sessionId,stage:Z,error:Q,severity:"warn"}),C1($.config.telemetry,{component:"core",operation:"session.shutdown_cleanup",error:Q,severity:"warn",handled:!0,context:{sessionId:$.sessionId,stage:Z,status:f.status,shutdownReason:f.shutdownReason,providerId:$.config.providerId,modelId:$.config.modelId}})};if($.artifacts){try{await this.updateStatus($,f.status,f.exitCode)}catch(Z){W("update_status",Z)}try{await $.agent.shutdown(f.shutdownReason)}catch(Z){W("agent_shutdown",Z)}}try{await Promise.resolve($.runtime.shutdown(f.shutdownReason))}catch(Z){W("runtime_shutdown",Z)}try{await $.pluginSandboxShutdown?.()}catch(Z){W("plugin_sandbox_shutdown",Z)}if(this.sessions.delete($.sessionId),this.emit({type:"ended",payload:{sessionId:$.sessionId,reason:f.endReason,ts:Date.now()}}),J.length>0&&f.status==="failed")throw J[0]}async releaseSessionRuntime($,f){let J=[],W=(Z,Q)=>{J.push(Q),$.config.logger?.log("Session runtime cleanup failed",{sessionId:$.sessionId,stage:Z,error:Q,severity:"warn"}),C1($.config.telemetry,{component:"core",operation:"session.runtime_cleanup",error:Q,severity:"warn",handled:!0,context:{sessionId:$.sessionId,stage:Z,reason:f,providerId:$.config.providerId,modelId:$.config.modelId}})};try{await $.agent.shutdown(f)}catch(Z){W("agent_shutdown",Z)}try{await Promise.resolve($.runtime.shutdown(f))}catch(Z){W("runtime_shutdown",Z)}try{await $.pluginSandboxShutdown?.()}catch(Z){W("plugin_sandbox_shutdown",Z)}if(this.sessions.delete($.sessionId),J.length>0)throw J[0]}async updateStatus($,f,J){if(!$.artifacts)return;let W=await this.invoke("updateSessionStatus",$.sessionId,f,J);if(!W.updated)return;let Z=await this.invokeOptionalValue("readSessionManifest",$.sessionId)??$.artifacts.manifest;if(Z.status=f,$0(f))delete Z.ended_at,Z.exit_code=null;else Z.ended_at=W.endedAt??n(),Z.exit_code=typeof J==="number"?J:null;$.artifacts.manifest=Z,$.status=f,$.updatedAt=W.endedAt??n(),$.endedAt=$0(f)?null:Z.ended_at,$.exitCode=Z.exit_code,await this.invoke("writeSessionManifest",$.artifacts.manifestPath,Z),this.emitStatus($.sessionId,f)}async runWithAuthRetry($,f,J){try{return await f()}catch(W){if(!aT(W,$.config.providerId))throw W;return await this.syncOAuthCredentials($,{forceRefresh:!0}),$.agent.restore(J),f()}}async syncOAuthCredentials($,f){let J=null;try{J=await this.oauthTokenManager.resolveProviderApiKey({providerId:$.config.providerId,forceRefresh:f?.forceRefresh})}catch(W){if(W instanceof X4)throw Error(`${W.providerId} requires re-authentication.`);throw W}if(!J?.apiKey||$.config.apiKey===J.apiKey)return;$.config.apiKey=J.apiKey,$.agent.updateConnection({apiKey:J.apiKey}),$.runtime.delegatedAgentConfigProvider?.updateConnectionDefaults({apiKey:J.apiKey}),$.runtime.teamRuntime?.updateTeammateConnections({apiKey:J.apiKey})}getSessionOrThrow($){let f=this.sessions.get($);if(!f){let J=new F1($);throw C1(this.defaultTelemetry,{component:"core",operation:"session.active_lookup",error:J,severity:"warn",handled:!0,context:{sessionId:$,activeSessionCount:this.sessions.size}}),J}return f}resolveAbsoluteFilePaths($,f){if(!f||f.length===0)return[];let J=f.map((W)=>W.trim()).filter((W)=>W.length>0).map((W)=>iT(W)?W:hZ($,W));return Array.from(new Set(J))}getSessionAgentTelemetryIdentity($){return G$({agentId:$.agent.getAgentId(),conversationId:$.agent.getConversationId(),teamId:$.runtime.teamRuntime?.getTeamId(),teamName:$.runtime.teamRuntime?.getTeamName(),teamRole:$.runtime.teamRuntime?"lead":void 0})}async seedAggregateUsageFromArtifacts($){let f=await this.summarizePersistedTeammateUsage($.sessionDir,$.rootMessagesPath,$.manifest.session_id),J=Y0($.initialUsage,f);return this.withPersistedAggregateUsageFloor(J,$.manifest)}async summarizePersistedTeammateUsage($,f,J){let W=hZ(f),Z=`${J}.messages.json`,Q;try{Q=pT($)}catch{return G0()}let j=G0();for(let H of Q){if(!H.endsWith(".messages.json"))continue;if(H===Z)continue;let X=hZ($,H);if(X===W)continue;let Y=await k$(X);if(Y.length===0)continue;j=Y0(j,dJ(Y))}return j}withPersistedAggregateUsageFloor($,f){let J=oT(f.metadata?.aggregateUsage);if(J)return eT($,J);let W=f.metadata?.aggregatedAgentsCost;if(typeof W!=="number"||!Number.isFinite(W)||W<=$.totalCost)return $;return{...$,totalCost:W}}emitStatus($,f){this.emitSessionSnapshot($),this.emit({type:"status",payload:{sessionId:$,status:f}})}async emitSessionSnapshot($){let f=await this.getSession($);if(!f)return;this.emit({type:"session_snapshot",payload:{sessionId:$,snapshot:g$({session:f,messages:await this.readSessionMessages($),usage:this.usageBySession.get($),aggregateUsage:this.aggregateUsageBySession.get($)})}})}emit($){this.events.emit($)}async listRows($){return this.invoke("listSessions",Math.min(Math.max(1,Math.floor($)),HY))}async getRow($){let f=$.trim();if(!f)return;return(await this.listRows(HY)).find((W)=>W.sessionId===f)}async readManifest($){let f=$.trim();if(!f)return;return await this.invokeOptionalValue("readSessionManifest",f)}invoke($,...f){return WY(this.sessionService,$,...f)}invokeOptional($,...f){return ZY(this.sessionService,$,...f)}invokeOptionalValue($,...f){return QY(this.sessionService,$,...f)}}function $N($){if($.backendMode)return $.backendMode;if(process.env.CLINE_VCR?.trim())return"local";let f=process.env.CLINE_SESSION_BACKEND_MODE?.trim().toLowerCase();if(f==="local"||f==="hub"||f==="remote")return f;return"auto"}var v2,u2;function fN($,f){if($!=="auto"&&$!=="hub")return;if(f.hub?.endpoint?.trim())return;sj(f.hub?.workspaceRoot?.trim()||f.hub?.cwd?.trim()||process.cwd())}async function JN($){await $.reconcileDeadSessions?.().catch(()=>{})}function AY($){try{let f=new c$;return f.init(),new d$(f,{messagesArtifactUploader:$.messagesArtifactUploader,logger:$.logger})}catch(f){return $.telemetry?.capture({event:"session_backend_fallback",properties:{requestedBackend:"sqlite",fallbackBackend:"file"}}),YY($.telemetry,{component:"core",operation:"session_backend.sqlite_init",error:f,severity:"warn",handled:!0,context:{requestedBackend:"sqlite",fallbackBackend:"file"}}),new lW(void 0,{messagesArtifactUploader:$.messagesArtifactUploader,logger:$.logger})}}function XY($,f,J){return new a$({sessionService:J??$.sessionService??AY($),capabilities:$.capabilities,telemetry:$.telemetry,toolPolicies:$.toolPolicies,distinctId:f,fetch:$.fetch})}async function WN($){if(v2)return v2;if(u2)return await u2;return u2=(async()=>{return v2=AY($),await JN(v2),v2})().finally(()=>{u2=void 0}),await u2}async function A4($){let f=y1($.distinctId);$.telemetry?.setDistinctId(f);let J=$N($);if(fN(J,$),J==="remote"){let W=$.remote?.endpoint?.trim();if(!W)throw Error("Remote runtime mode requires `remote.endpoint` to be configured.");return $.logger?.log("Using remote runtime host",{endpoint:W}),new hJ({endpoint:W,authToken:$.remote?.authToken,clientType:$.remote?.clientType,displayName:$.remote?.displayName,workspaceRoot:$.remote?.workspaceRoot,cwd:$.remote?.cwd,capabilities:$.capabilities})}if(J==="hub"){let W=$.hub?.endpoint?.trim(),Z=W||await z2({strategy:$.hub?.strategy??"require-hub",workspaceRoot:$.hub?.workspaceRoot,cwd:$.hub?.cwd});if(!Z)throw Error("No compatible hub runtime is available.");return $.logger?.log("Using hub runtime host",{url:Z,explicitEndpoint:W||void 0}),new M1({url:Z,authToken:$.hub?.authToken,clientType:$.hub?.clientType,displayName:$.hub?.displayName,capabilities:$.capabilities,telemetry:$.telemetry},{workspaceRoot:$.hub?.workspaceRoot,cwd:$.hub?.cwd})}if(J==="auto"){let W=await NW({endpoint:$.hub?.endpoint,strategy:$.hub?.strategy??"prefer-hub",workspaceRoot:$.hub?.workspaceRoot,cwd:$.hub?.cwd});if(W){$.logger?.log("Using discovered local hub runtime host",{url:W});let Z=new M1({url:W,authToken:$.hub?.authToken,clientType:$.hub?.clientType,displayName:$.hub?.displayName,capabilities:$.capabilities,telemetry:$.telemetry},{workspaceRoot:$.hub?.workspaceRoot,cwd:$.hub?.cwd});try{return await Z.connect(),Z}catch(Q){$.logger?.log("Falling back to local runtime host",{reason:"hub_connect_failed",severity:"warn",error:Q}),YY($.telemetry,{component:"core",operation:"runtime_host.hub_connect",error:Q,severity:"warn",handled:!0,context:{backendMode:"auto",fallbackBackend:"local"}})}}return $.logger?.log("Falling back to local runtime host",{reason:"compatible_hub_unavailable",severity:"warn"}),XY($,f)}return XY($,f)}class CZ{clientName;runtimeAddress;automation;settings;pendingPrompts;host;prepare;capabilities;logger;telemetry;distinctId;automationService;activeSessionBootstraps=new Map;unsubscribeBootstrapCleanup;constructor($,f,J,W,Z,Q,j,H,X){this.clientName=f,this.runtimeAddress=J,this.host=$,this.prepare=W,this.capabilities=Z,this.logger=Q,this.telemetry=j,this.distinctId=H,this.settings=Jj($),this.pendingPrompts=Wj($),this.automation=new T6(()=>{if(!this.automationService)throw Error("ClineCore automation is not enabled. Pass `automation: true` or automation options to ClineCore.create().");return this.automationService}),this.automationService=X?new K2({workspaceRoot:X.workspaceRoot??process.cwd(),specs:{cronSpecsDir:X.cronSpecsDir??X.cronDir,scope:YQ(X.cronScope),workspaceRoot:X.workspaceRoot},runtimeHandlers:AQ({host:$,getExtensionContext:()=>P8({automationService:this.automationService,automation:this.automation,clientName:this.clientName,distinctId:this.distinctId,logger:this.logger,telemetry:this.telemetry})}),dbPath:X.dbPath,logger:X.logger,pollIntervalMs:X.pollIntervalMs,claimLeaseSeconds:X.claimLeaseSeconds,globalMaxConcurrency:X.globalMaxConcurrency,watcherDebounceMs:X.watcherDebounceMs}):void 0,this.unsubscribeBootstrapCleanup=this.host.subscribe((Y)=>{if(Y.type!=="ended")return;this.disposeSessionBootstrap(Y.payload.sessionId)})}static async create($={}){let f=U0($.capabilities),J=await A4({...$,capabilities:f}),W=XQ($.automation),Z=new CZ(J,$.clientName,J.runtimeAddress,$.prepare,f,$.logger,$.telemetry,$.distinctId,W?{...W,logger:$.logger}:void 0);if(W&&W.autoStart!==!1)await Z.automation.start();return Z}async disposeSessionBootstrap($){let f=this.activeSessionBootstraps.get($);if(!f)return;this.activeSessionBootstraps.delete($),await Promise.resolve(f.dispose?.())}async start($){let f=Zj($),J=await this.prepare?.(f);try{let W=J?await J.applyToStartSessionInput(f):f,Z=await this.host.startSession(x5(W,{defaultCapabilities:this.capabilities,withExtensionContext:(Q)=>P8({automationService:this.automationService,automation:this.automation,context:Q,clientName:this.clientName,distinctId:this.distinctId,logger:this.logger,telemetry:this.telemetry})}));if(J)if(await this.host.getSession(Z.sessionId))this.activeSessionBootstraps.set(Z.sessionId,J);else await Promise.resolve(J.dispose?.());return Qj({input:W,sessionId:Z.sessionId,telemetry:this.telemetry,clientName:this.clientName,runtimeAddress:this.runtimeAddress}),Z}catch(W){throw await Promise.resolve(J?.dispose?.()),W}}send=(...$)=>this.host.runTurn(...$);getAccumulatedUsage=(...$)=>{return this.host.getAccumulatedUsage?.(...$)??Promise.resolve(void 0)};abort=(...$)=>this.host.abort(...$);stop=async($)=>{await this.host.stopSession($),await this.disposeSessionBootstrap($)};dispose=async(...$)=>{try{await this.automationService?.dispose(),await this.host.dispose(...$)}finally{this.unsubscribeBootstrapCleanup();let f=[...this.activeSessionBootstraps.keys()];await Promise.allSettled(f.map((J)=>this.disposeSessionBootstrap(J)))}};get=(...$)=>this.host.getSession(...$);listHistory=async($={})=>await PW(this.host,$);list=async($=200,f={})=>await this.listHistory({...f,limit:$});delete=async($)=>{let f=await this.host.deleteSession($);if(f)await this.disposeSessionBootstrap($);return f};update=(...$)=>this.host.updateSession(...$);readMessages=(...$)=>this.host.readSessionMessages(...$);async restore($){let f=$.start?x5($.start,{defaultCapabilities:this.capabilities,withExtensionContext:(J)=>P8({automationService:this.automationService,automation:this.automation,context:J,clientName:this.clientName,distinctId:this.distinctId,logger:this.logger,telemetry:this.telemetry})}):void 0;return this.host.restoreSession({sessionId:$.sessionId,checkpointRunCount:$.checkpointRunCount,cwd:$.cwd,restore:$.restore,start:f})}ingestHookEvent=(...$)=>this.host.dispatchHookEvent(...$);subscribe($,f){return this.host.subscribe($,f)}updateSessionModel=(...$)=>{return this.host.updateSessionModel?.(...$)??Promise.resolve()}}import{HookEventNameSchema as BY,HookEventPayloadSchema as KY,parseHookEventPayload as B4,resolveHookSessionContext as AN}from"@cline/shared";import{z as E1}from"zod";import{spawn as ZN}from"node:child_process";import{augmentNodeCommandForDebug as QN,withResolvedClineBuildEnv as jN}from"@cline/shared";function HN($){let f=$.trim();if(!f)return{};let W=f.split(`
|
|
696
|
+
`).map((Q)=>Q.trim()).filter(Boolean).filter((Q)=>Q.startsWith("HOOK_CONTROL\t")).map((Q)=>Q.slice(13)),Z=W.length>0?W[W.length-1]:f;try{return{parsedJson:JSON.parse(Z)}}catch(Q){return{parseError:Q instanceof Error?Q.message:"Failed to parse subprocess stdout JSON"}}}function XN($,f){let J=$ instanceof Error?$:Error(String($)),W=J,Z=f.join(" ");if(W.code==="EACCES")return Error(`Failed to execute hook command "${Z}" (EACCES). Configure hooks with an explicit interpreter/command array (for example: ["bash", "/path/to/script"]) or make the script executable with a valid shebang.`);return Error(`Failed to execute hook command "${Z}": ${J.message}`)}async function YN($,f){let J=$.stdin;if(!J)throw Error("runSubprocessEvent failed to create stdin pipe");await new Promise((W,Z)=>{let Q=(j)=>{J.off("error",Q);let H=j.code;if(H==="EPIPE"||H==="ERR_STREAM_DESTROYED"){W();return}Z(j)};J.once("error",Q),J.end(f,(j)=>{if(J.off("error",Q),j){let H=j.code;if(H==="EPIPE"||H==="ERR_STREAM_DESTROYED"){W();return}Z(j);return}W()})})}async function V4($,f){let J=QN(f.command,{env:f.env,debugRole:"hook"});if(!Array.isArray(J)||J.length===0)throw Error("runSubprocessEvent requires a non-empty command");let W=!!f.detached,Z=ZN(J[0],J.slice(1),{cwd:f.cwd,env:jN(f.env),stdio:W?["pipe","ignore","ignore"]:["pipe","pipe","pipe"],detached:W}),Q=new Promise((B)=>{Z.once("spawn",()=>{try{f.onSpawn?.({command:J,pid:Z.pid??void 0,detached:W})}catch{}B()})}),j=new Promise((B,K)=>{Z.once("error",(G)=>{K(XN(G,J))})});if(await YN(Z,JSON.stringify($)),W){await Promise.race([Q,j]),Z.unref();return}if(!Z.stdout||!Z.stderr)throw Error("runSubprocessEvent failed to create stdout/stderr pipes");let H="",X="",Y=!1,A;Z.stdout.on("data",(B)=>{H+=B.toString()}),Z.stderr.on("data",(B)=>{X+=B.toString()});let V=new Promise((B)=>{if((f.timeoutMs??0)>0)A=setTimeout(()=>{Y=!0,Z.kill("SIGKILL")},f.timeoutMs);Z.once("close",(K)=>{if(A)clearTimeout(A);let{parsedJson:G,parseError:R}=HN(H);B({exitCode:K,stdout:H,stderr:X,parsedJson:G,parseError:R,timedOut:Y})})});return await Promise.race([V,j])}var VN=E1.object({contextModification:E1.string().optional(),cancel:E1.boolean().optional(),review:E1.boolean().optional(),errorMessage:E1.string().optional(),context:E1.string().optional(),overrideInput:E1.unknown().optional()}).passthrough();var BN=["agent","hook"];async function K4($,f={}){let J=f.command??BN;return await V4($,{command:J,cwd:f.cwd,env:f.env,detached:f.detached,timeoutMs:f.timeoutMs,onSpawn:f.onSpawn})}function GY($){return $ instanceof Error?$:Error(String($))}function KN($){if(!$||typeof $!=="object")return;let f=VN.safeParse($);if(!f.success)return;let J=f.data;if(!(("cancel"in J)||("review"in J)||("context"in J)||("contextModification"in J)||("overrideInput"in J)||("errorMessage"in J)))return;let Z=typeof J.context==="string"?J.context:typeof J.contextModification==="string"?J.contextModification:typeof J.errorMessage==="string"&&J.errorMessage.length>0?J.errorMessage:void 0;return{cancel:typeof J.cancel==="boolean"?J.cancel:void 0,review:typeof J.review==="boolean"?J.review:void 0,context:Z,overrideInput:Object.hasOwn(J,"overrideInput")?J.overrideInput:void 0}}function VY($){if(!$||typeof $!=="object")return{};let f={};for(let[J,W]of Object.entries($))if(typeof W==="string")f[J]=W;else f[J]=JSON.stringify(W);return f}function P$($,f,J){let W=J.env??process.env,Z=W.CLINE_USER_ID?.trim()||W.USER?.trim()||"unknown",Q=J.cwd||process.cwd();return{clineVersion:W.CLINE_VERSION?.trim()||"",hookName:$,timestamp:new Date().toISOString(),taskId:f.conversationId,sessionContext:AN(J.sessionContext,{hookName:$,conversationId:f.conversationId,agentId:f.agentId,parentAgentId:f.parentAgentId}),workspaceRoots:Q?[Q]:[],workspaceInfo:J.workspaceInfo,userId:Z,agent_id:f.agentId,parent_agent_id:f.parentAgentId}}function GN($){return{name:$.name,message:$.message,stack:$.stack}}function PN($){let f=String($??"").toLowerCase();return f.includes("cancel")||f.includes("abort")||f.includes("interrupt")}function FN($){return{agentId:$.snapshot.agentId,conversationId:$.snapshot.conversationId??$.snapshot.runId??$.snapshot.agentId,parentAgentId:$.snapshot.parentAgentId??null}}function UN($){return $.filter((f)=>f.type==="text"&&typeof f.text==="string").map((f)=>f.text).join("")}function RN($){return{id:$.toolCall.toolCallId,name:$.toolCall.toolName,input:$.input,output:$.result.output,error:$.result.isError?String($.result.output):void 0,durationMs:$.durationMs,startedAt:$.startedAt,endedAt:$.endedAt}}function DN($){if(!$)return;let f={};if($.cancel===!0)f.stop=!0;if($.overrideInput!==void 0)f.input=$.overrideInput;return Object.keys(f).length>0?f:void 0}async function b1($,f){try{let J=await K4($,{command:f.command,cwd:f.cwd,env:f.env,detached:!0,onSpawn:f.onSpawn});f.onDispatch?.({payload:$,result:J,detached:!0})}catch(J){f.onDispatchError?.(GY(J),$)}}function PY($={}){return{hooks:{beforeRun:async(H)=>{let X=FN(H);if(($.env??process.env).CLINE_HOOK_AGENT_RESUME==="1"){let A={...P$("agent_resume",X,$),hookName:"agent_resume",taskResume:{taskMetadata:{},previousState:{}}};await b1(A,$)}else{let A={...P$("agent_start",X,$),hookName:"agent_start",taskStart:{taskMetadata:{}}};await b1(A,$)}return},beforeTool:async(H)=>{let X={agentId:H.snapshot.agentId,conversationId:H.snapshot.conversationId??H.snapshot.runId??H.snapshot.agentId,parentAgentId:H.snapshot.parentAgentId??null},Y={...P$("tool_call",X,$),hookName:"tool_call",iteration:H.snapshot.iteration,tool_call:{id:H.toolCall.toolCallId,name:H.toolCall.toolName,input:H.input},preToolUse:{toolName:H.toolCall.toolName,parameters:VY(H.input)}};try{let A=await K4(Y,{command:$.command,cwd:$.cwd,env:$.env,detached:!1,timeoutMs:$.timeoutMs,onSpawn:$.onSpawn});if($.onDispatch?.({payload:Y,result:A,detached:!1}),A?.timedOut)throw Error("tool_call hook command timed out");if(A?.parseError)throw Error(`tool_call hook produced invalid control JSON: ${A.parseError}`);return DN(KN(A?.parsedJson))}catch(A){$.onDispatchError?.(GY(A),Y);return}},afterTool:async(H)=>{let X=RN(H),Y={agentId:H.snapshot.agentId,conversationId:H.snapshot.conversationId??H.snapshot.runId??H.snapshot.agentId,parentAgentId:H.snapshot.parentAgentId??null},A={...P$("tool_result",Y,$),hookName:"tool_result",iteration:H.snapshot.iteration,tool_result:X,postToolUse:{toolName:X.name,parameters:VY(X.input),result:typeof X.output==="string"?X.output:JSON.stringify(X.output),success:!X.error,executionTimeMs:X.durationMs}};await b1(A,$);return},afterRun:async({snapshot:H,result:X})=>{let Y={agentId:H.agentId,conversationId:H.conversationId??H.runId??H.agentId,parentAgentId:H.parentAgentId??null};if(X.status==="completed"){let B={...P$("agent_end",Y,$),hookName:"agent_end",iteration:X.iterations,turn:{outputText:X.outputText,status:X.status},taskComplete:{taskMetadata:{}}};await b1(B,$);return}let A=X.status==="aborted"||PN(X.error?.message)?"agent_abort":"agent_error",V=A==="agent_error"?{...P$(A,Y,$),hookName:A,iteration:X.iterations,error:GN(X.error??Error("Agent run failed")),taskCancel:{taskMetadata:{}}}:{...P$(A,Y,$),hookName:A,reason:X.error?.message,taskCancel:{taskMetadata:{}}};await b1(V,$)},onEvent:async(H)=>{if(H.type!=="message-added"||H.message.role!=="user")return;let X={agentId:H.snapshot.agentId,conversationId:H.snapshot.conversationId??H.snapshot.runId??H.snapshot.agentId,parentAgentId:H.snapshot.parentAgentId??null},Y={...P$("prompt_submit",X,$),hookName:"prompt_submit",userPromptSubmit:{prompt:UN(H.message.content),attachments:[]}};await b1(Y,$)}},shutdown:async({agentId:H,conversationId:X,parentAgentId:Y,reason:A})=>{let V={...P$("session_shutdown",{agentId:H,conversationId:X,parentAgentId:Y},$),hookName:"session_shutdown",reason:A};await b1(V,$)}}}import{createSessionId as LN}from"@cline/shared";function I0($,f){return{version:$.version,requestId:$.requestId,ok:!0,payload:f}}function FY($,f,J){return{version:$.version,requestId:$.requestId??LN("hubreq_"),ok:!1,error:{code:f,message:J}}}class G4{schedules;constructor($){this.schedules=$}async handleCommand($){try{switch($.command){case"schedule.create":return I0($,{schedule:this.schedules.createSchedule(this.toCreateInput($.payload??{}))});case"schedule.list":return I0($,{schedules:this.schedules.listSchedules({enabled:typeof $.payload?.enabled==="boolean"?$.payload.enabled:void 0,limit:typeof $.payload?.limit==="number"?$.payload.limit:void 0,tags:Array.isArray($.payload?.tags)?$.payload?.tags:void 0})});case"schedule.get":return I0($,{schedule:this.schedules.getSchedule(String($.payload?.scheduleId??""))});case"schedule.update":return I0($,{schedule:this.schedules.updateSchedule(String($.payload?.scheduleId??""),this.toUpdateInput($.payload??{}))});case"schedule.delete":return I0($,{deleted:this.schedules.deleteSchedule(String($.payload?.scheduleId??""))});case"schedule.enable":return I0($,{schedule:this.schedules.resumeSchedule(String($.payload?.scheduleId??""))});case"schedule.disable":return I0($,{schedule:this.schedules.pauseSchedule(String($.payload?.scheduleId??""))});case"schedule.trigger":return I0($,{execution:$.payload?.wait===!1?this.schedules.triggerScheduleNowDetached(String($.payload?.scheduleId??"")):await this.schedules.triggerScheduleNow(String($.payload?.scheduleId??""))});case"schedule.list_executions":return I0($,{executions:this.schedules.listScheduleExecutions({scheduleId:typeof $.payload?.scheduleId==="string"?$.payload.scheduleId:void 0,status:typeof $.payload?.status==="string"?$.payload.status:void 0,limit:typeof $.payload?.limit==="number"?$.payload.limit:void 0})});case"schedule.stats":return I0($,{stats:this.schedules.getScheduleStats(String($.payload?.scheduleId??""))});case"schedule.active":return I0($,{executions:this.schedules.getActiveExecutions()});case"schedule.upcoming":return I0($,{runs:this.schedules.getUpcomingRuns(typeof $.payload?.limit==="number"?$.payload.limit:void 0)});default:return FY($,"unsupported_command",`Unsupported hub schedule command: ${$.command}`)}}catch(f){return FY($,"schedule_command_failed",f instanceof Error?f.message:String(f))}}toCreateInput($){let f=$.modelSelection&&typeof $.modelSelection==="object"&&!Array.isArray($.modelSelection)?$.modelSelection:$.provider&&$.model?{providerId:String($.provider),modelId:String($.model)}:void 0;return{...$,modelSelection:f}}toUpdateInput($){let f=$.modelSelection&&typeof $.modelSelection==="object"&&!Array.isArray($.modelSelection)?$.modelSelection:$.provider||$.model?{providerId:typeof $.provider==="string"?$.provider:"",modelId:typeof $.model==="string"?$.model:""}:void 0;return{...$,modelSelection:f}}}function F4($){return $?new Date($).getTime():void 0}function ON($){let f=$.metadata?{...$.metadata}:void 0;if(f)delete f.__hubScheduleCreatedBy,delete f.__hubScheduleCwd,delete f.__hubRuntimeOptions;return f}function P4($){let f=$.metadata;return{scheduleId:$.externalId,name:$.title,cronPattern:$.scheduleExpr??"",prompt:$.prompt??"",workspaceRoot:$.workspaceRoot??"",cwd:typeof f?.__hubScheduleCwd==="string"?f.__hubScheduleCwd:void 0,modelSelection:$.providerId||$.modelId?{providerId:$.providerId??"",modelId:$.modelId??""}:void 0,enabled:$.enabled&&!$.removed&&$.parseStatus==="valid",mode:$.mode==="plan"?"plan":$.mode==="yolo"?"yolo":"act",systemPrompt:$.systemPrompt,maxIterations:$.maxIterations,timeoutSeconds:$.timeoutSeconds,maxParallel:$.maxParallel??1,createdAt:new Date($.createdAt).getTime(),updatedAt:new Date($.updatedAt).getTime(),nextRunAt:F4($.nextRunAt),lastRunAt:F4($.lastRunAt),createdBy:typeof f?.__hubScheduleCreatedBy==="string"?f.__hubScheduleCreatedBy:void 0,tags:$.tags,runtimeOptions:f?.__hubRuntimeOptions&&typeof f.__hubRuntimeOptions==="object"&&!Array.isArray(f.__hubRuntimeOptions)?f.__hubRuntimeOptions:void 0,metadata:ON($)}}function _N($){switch($){case"done":return"success";case"cancelled":return"aborted";case"running":return"running";case"queued":return"pending";default:return"failed"}}function EZ($,f){return{executionId:$.runId,scheduleId:f,sessionId:$.sessionId,triggeredAt:new Date($.scheduledFor??$.createdAt).getTime(),startedAt:F4($.startedAt),endedAt:F4($.completedAt),status:_N($.status),errorMessage:$.error}}class U4{store;materializer;runner;started=!1;disposed=!1;constructor($){this.store=new B2({dbPath:$.dbPath}),this.materializer=new H2({store:this.store}),this.runner=new X2({store:this.store,materializer:this.materializer,runtimeHandlers:$.runtimeHandlers,eventPublisher:$.eventPublisher,workspaceRoot:"",logger:$.logger,pollIntervalMs:$.pollIntervalMs,claimLeaseSeconds:$.claimLeaseSeconds,globalMaxConcurrency:$.globalMaxConcurrency})}async start(){if(this.disposed)throw Error("HubScheduleService has been disposed");if(this.started)return;this.started=!0,await this.runner.start()}async stop(){await this.runner.stop(),this.started=!1}async dispose(){if(this.disposed)return;this.disposed=!0,await this.runner.dispose(),this.store.close()}createSchedule($){if(n5($.cronPattern),!$.workspaceRoot?.trim())throw Error("workspaceRoot is required for schedules");return P4(this.store.createHubSchedule($))}getSchedule($){let f=this.store.getHubSchedule($);return f?P4(f):void 0}listSchedules($={}){return this.store.listHubSchedules($).map((f)=>P4(f))}updateSchedule($,f){if(f.cronPattern!==void 0)n5(f.cronPattern);let J=this.store.getHubSchedule($);if(!J)return;let W=f.workspaceRoot!==void 0?f.workspaceRoot.trim():J.workspaceRoot;if((f.enabled??J.enabled)&&!W)throw Error("workspaceRoot is required for enabled schedules");let Q=this.store.updateHubSchedule($,{...f,scheduleId:$});return Q?P4(Q):void 0}deleteSchedule($){return this.store.deleteHubSchedule($)}pauseSchedule($){return this.updateSchedule($,{scheduleId:$,enabled:!1})}resumeSchedule($){return this.updateSchedule($,{scheduleId:$,enabled:!0})}async triggerScheduleNow($){let f=this.store.enqueueHubScheduleRun($,"manual");if(!f)return;await this.runner.tick();let J=this.store.getRun(f.runId)??f;return EZ(J,$)}triggerScheduleNowDetached($){let f=this.store.enqueueHubScheduleRun($,"manual");if(!f)return;return this.runner.tick().catch(()=>{return}),EZ(f,$)}listScheduleExecutions($){let f=$.scheduleId?this.store.getHubSchedule($.scheduleId):void 0,J={specId:f?.specId,limit:$.limit};return this.store.listRuns(J).map((Z)=>{let Q=f??this.store.getSpec(Z.specId);if(!Q||Q.source!=="hub-schedule")return;return EZ(Z,Q.externalId)}).filter((Z)=>{if(!Z)return!1;return!$.status||Z.status===$.status})}getScheduleStats($){let f=this.listScheduleExecutions({scheduleId:$,limit:1e4});if(f.length===0)return{totalRuns:0,successRate:0,avgDurationSeconds:0};let J=0,W=0,Z=0,Q;for(let j of f){if(j.status==="success"||j.status==="completed")J+=1;if(!Q&&j.status!=="success"&&j.status!=="completed")Q=j;if(j.startedAt&&j.endedAt)Z+=j.endedAt-j.startedAt,W+=1}return{totalRuns:f.length,successRate:J/f.length,avgDurationSeconds:W>0?Z/W/1000:0,lastFailure:Q}}getActiveExecutions(){return this.runner.getActiveRuns().flatMap(($)=>{let f=this.store.getSpec($.specId);if(!f||f.source!=="hub-schedule"||!$.sessionId)return[];return[{executionId:$.runId,scheduleId:f.externalId,sessionId:$.sessionId,startedAt:$.startedAt??new Date().toISOString(),timeoutAt:f.timeoutSeconds&&$.startedAt?new Date(new Date($.startedAt).getTime()+f.timeoutSeconds*1000).toISOString():void 0}]})}getUpcomingRuns($=20){let f={triggerKind:"schedule",enabled:!0,limit:$};return this.store.listSpecs(f).flatMap((J)=>J.source==="hub-schedule"&&J.nextRunAt?[{spec:J,nextRunAt:J.nextRunAt}]:[]).sort((J,W)=>String(J.nextRunAt).localeCompare(String(W.nextRunAt))).slice(0,$).map(({spec:J,nextRunAt:W})=>({scheduleId:J.externalId,name:J.title,nextRunAt:W}))}}O4();function pN($,f){if($ instanceof Error)return $;if($&&typeof $==="object"&&"message"in $&&typeof $.message==="string"&&$.message.trim())return Error($.message.trim());let J=$&&typeof $==="object"&&"type"in $&&typeof $.type==="string"?$.type.trim():"";return Error(J?`Failed to connect to hub at ${f} (${J} event before socket open).`:`Failed to connect to hub at ${f}.`)}var rN="cline-hub-auth.";function iN($){return $.host!==void 0||$.port!==void 0||$.pathname!==void 0}function nN($,f){let J=new URL($),W=new URL(f);return J.search="",J.hash="",W.search="",W.hash="",J.toString()===W.toString()}async function aN($){let f=$.searchParams.get("authToken")?.trim();if($.searchParams.delete("authToken"),f)return f;let J=R0(),W=await K0(J.discoveryPath);if(W?.url&&nN($.toString(),W.url))return W.authToken;return}async function tN($={}){let f=x$($);if(!iN($)){let J=R0(),W=await K0(J.discoveryPath);if(W?.url)return W.url}return A$(f.host,f.port,f.pathname)}async function DY($){return await new Promise((f,J)=>{(async()=>{let W=new URL($),Z=await aN(W);W.hash="";let Q=new WebSocket(W.toString(),Z?[`${rN}${Z}`]:void 0),j=new Map,H=0;Q.addEventListener("open",()=>{f({send(X){let Y=X.requestId??`hub-client-${++H}`;return new Promise((A,V)=>{j.set(Y,{resolve:A,reject:V});let B={kind:"command",envelope:{...X,requestId:Y}};Q.send(JSON.stringify(B))})},close(){Q.close()}})}),Q.addEventListener("message",(X)=>{let Y=JSON.parse(String(X.data));if(Y.kind==="reply"&&Y.envelope.requestId){let A=j.get(Y.envelope.requestId);if(A)j.delete(Y.envelope.requestId),A.resolve(Y.envelope)}}),Q.addEventListener("close",()=>{for(let X of j.values())X.reject(Error("Hub connection closed"));j.clear()}),Q.addEventListener("error",(X)=>{J(pN(X,$))})})().catch(J)})}async function Bc($){try{return(await DY($)).close(),!0}catch{return!1}}async function Kc($,f){let J=await tN($),W=await DY(J);try{return await W.send({version:f.version??"v1",clientId:f.clientId??"hub-client",...f})}finally{W.close()}}function xZ($){return $?JSON.parse(JSON.stringify($)):{}}function _4($){let f=$?.session&&typeof $.session==="object"?$.session:void 0;if(!f)return;let J=f.metadata&&typeof f.metadata==="object"?xZ(f.metadata):void 0;return{sessionId:typeof f.sessionId==="string"?f.sessionId:"",parentSessionId:typeof J?.parentSessionId==="string"?J.parentSessionId:void 0,messagesPath:typeof J?.messagesPath==="string"?J.messagesPath:void 0,metadata:J}}function LY($,f){return $.error?.message??`hub command failed: ${f}`}function sN($){let f=xZ($);if(typeof f.error==="string"&&f.error.trim())return{...f,error:f.error.trim()};let J=f.result&&typeof f.result==="object"?f.result:void 0;if(typeof J?.text==="string"&&J.text.trim())return{...f,error:J.text.trim()};let W=J?.error&&typeof J.error==="object"?J.error:void 0;if(typeof W?.message==="string"&&W.message.trim())return{...f,error:W.message.trim()};return f}function OY($){let f=$?.sessionId;return typeof f==="string"&&f.trim()?f.trim():void 0}function oN($){let f=$?.checkpoint;if(!f||typeof f!=="object"||Array.isArray(f))throw Error("hub checkpoint restore returned no checkpoint");let J=f;if(typeof J.ref!=="string"||typeof J.createdAt!=="number"||typeof J.runCount!=="number")throw Error("hub checkpoint restore returned an invalid checkpoint");return J}function eN($){let f=xZ($.payload);if($.event==="schedule.execution_completed")return{sessionId:$.sessionId?.trim()||OY(f)||"",eventType:"schedule.execution.completed",payload:f};if($.event==="schedule.execution_failed")return{sessionId:$.sessionId?.trim()||OY(f)||"",eventType:"schedule.execution.failed",payload:f};let J=$.sessionId?.trim();if(!J)return;switch($.event){case"iteration.started":return{sessionId:J,eventType:"runtime.chat.iteration_start",payload:f};case"iteration.finished":return{sessionId:J,eventType:"runtime.chat.iteration_end",payload:f};case"assistant.delta":return{sessionId:J,eventType:"runtime.chat.text_delta",payload:f};case"usage.updated":return{sessionId:J,eventType:"runtime.chat.usage",payload:f};case"tool.started":return{sessionId:J,eventType:"runtime.chat.tool_call_start",payload:f};case"tool.finished":return{sessionId:J,eventType:"runtime.chat.tool_call_end",payload:f};case"approval.requested":return{sessionId:J,eventType:"approval.requested",payload:f};case"run.aborted":return{sessionId:J,eventType:"runtime.chat.aborted",payload:f};case"run.failed":return{sessionId:J,eventType:"runtime.chat.failed",payload:sN($.payload)};case"run.completed":return{sessionId:J,eventType:"runtime.chat.completed",payload:f};default:return}}class $M{options;client;metadataApplied=!1;constructor($){this.options=$;this.client=new V$({url:$.address,authToken:$.authToken,clientId:$.clientId,clientType:$.clientType??"hub-session-client",displayName:$.displayName??"hub session client",workspaceRoot:$.workspaceRoot,cwd:$.cwd})}async ensureMetadataApplied(){if(this.metadataApplied||!this.options.metadata){if(!this.options.metadata)await this.client.connect();return}await this.client.connect(),await this.client.command("client.update",{metadata:this.options.metadata}),this.metadataApplied=!0}async connect(){await this.ensureMetadataApplied()}close(){this.client.close()}async dispose(){await this.client.dispose()}async startRuntimeSession($){await this.ensureMetadataApplied();let f=await this.client.command("session.create",{workspaceRoot:$.workspaceRoot,cwd:$.cwd,sessionConfig:{providerId:$.provider,modelId:$.model,apiKey:$.apiKey,cwd:$.cwd??$.workspaceRoot,workspaceRoot:$.workspaceRoot,systemPrompt:$.systemPrompt??"",mode:$.mode??"act",rules:$.rules,maxIterations:$.maxIterations,timeoutSeconds:$.timeoutSeconds,enableTools:$.enableTools,enableSpawnAgent:$.enableSpawn!==!1,enableAgentTeams:$.enableTeams!==!1,disableMcpSettingsTools:$.disableMcpSettingsTools,missionLogIntervalSteps:$.missionStepInterval,missionLogIntervalMs:$.missionTimeIntervalMs},metadata:{source:$.source??"cli",provider:$.provider,model:$.model,enableTools:$.enableTools,enableSpawn:$.enableSpawn,enableTeams:$.enableTeams,prompt:void 0,interactive:$.interactive!==!1},runtimeOptions:{mode:$.mode,systemPrompt:$.systemPrompt,maxIterations:$.maxIterations,timeoutSeconds:$.timeoutSeconds,enableTools:$.enableTools,enableSpawn:$.enableSpawn,enableTeams:$.enableTeams,autoApproveTools:$.autoApproveTools,toolExecutors:$.toolExecutors,configExtensions:$.configExtensions},modelSelection:{provider:$.provider,model:$.model,apiKey:$.apiKey},toolPolicies:$.toolPolicies}),J=_4(f.payload);if(!J?.sessionId)throw Error("hub session create returned no session id");return{sessionId:J.sessionId,startResult:{sessionId:J.sessionId,manifestPath:"",messagesPath:J.messagesPath??""}}}async sendRuntimeSession($,f,J){return await this.ensureMetadataApplied(),{result:(await this.client.command("session.send_input",{prompt:f.prompt,mode:f.config.mode,attachments:f.attachments,delivery:f.delivery,timeoutSeconds:f.config.timeoutSeconds},$,J)).payload?.result}}async stopRuntimeSession($){return await this.ensureMetadataApplied(),await this.client.command("session.detach",{sessionId:$},$),{applied:!0}}async abortRuntimeSession($){return await this.ensureMetadataApplied(),await this.client.command("run.abort",{sessionId:$},$),{applied:!0}}async updateSession($){return await this.ensureMetadataApplied(),await this.client.command("session.update",{sessionId:$.sessionId,metadata:$.metadata},$.sessionId),{updated:!0}}async getSession($){await this.ensureMetadataApplied();let f;try{f=await this.client.command("session.get",void 0,$)}catch(J){if(U1(J))return;throw J}return _4(f.payload)}async readMessages($){let f=$.trim();if(!f)return[];await this.ensureMetadataApplied();let J=await this.client.command("session.messages",{sessionId:f},f);if(!J.ok)throw Error(LY(J,"session.messages"));let W=J.payload?.messages;return Array.isArray(W)?W:[]}async restore($){let f=$.sessionId.trim();if(!f)throw Error("sessionId is required");let J=$.restore?.messages!==!1;if(J&&!$.config)throw Error("config is required when restore.messages is true");await this.ensureMetadataApplied();let W=$.config,Z=await this.client.command("session.restore",{sessionId:f,checkpointRunCount:$.checkpointRunCount,restore:$.restore,...W?{workspaceRoot:W.workspaceRoot,cwd:W.cwd,sessionConfig:{providerId:W.provider,modelId:W.model,apiKey:W.apiKey,cwd:W.cwd??W.workspaceRoot,workspaceRoot:W.workspaceRoot,systemPrompt:W.systemPrompt??"",mode:W.mode??"act",rules:W.rules,maxIterations:W.maxIterations,enableTools:W.enableTools,enableSpawnAgent:W.enableSpawn!==!1,enableAgentTeams:W.enableTeams!==!1,disableMcpSettingsTools:W.disableMcpSettingsTools,missionLogIntervalSteps:W.missionStepInterval,missionLogIntervalMs:W.missionTimeIntervalMs},metadata:{source:W.source??"cli",provider:W.provider,model:W.model,enableTools:W.enableTools,enableSpawn:W.enableSpawn,enableTeams:W.enableTeams,prompt:void 0,interactive:W.interactive!==!1},runtimeOptions:{mode:W.mode,systemPrompt:W.systemPrompt,maxIterations:W.maxIterations,enableTools:W.enableTools,enableSpawn:W.enableSpawn,enableTeams:W.enableTeams,autoApproveTools:W.autoApproveTools,configExtensions:W.configExtensions},modelSelection:{provider:W.provider,model:W.model,apiKey:W.apiKey},toolPolicies:W.toolPolicies}:{}},f);if(!Z.ok)throw Error(LY(Z,"session.restore"));let Q=_4(Z.payload);if(J&&!Q?.sessionId)throw Error("hub checkpoint restore returned no session id");let j=Array.isArray(Z.payload?.messages)?Z.payload.messages:void 0,H=oN(Z.payload);return{sessionId:Q?.sessionId,startResult:Q?.sessionId?{sessionId:Q.sessionId,manifestPath:"",messagesPath:Q.messagesPath??""}:void 0,...j?{messages:j}:{},checkpoint:H}}async listSessions($){await this.ensureMetadataApplied();let f=await this.client.command("session.list",{limit:$?.limit??200});return(Array.isArray(f.payload?.sessions)?f.payload?.sessions:[]).map((W)=>_4({session:W})).filter((W)=>Boolean(W?.sessionId))}async deleteSession($,f=!0){return await this.ensureMetadataApplied(),(await this.client.command("session.delete",{sessionId:$,deleteCheckpointRefs:f})).payload?.deleted===!0}async respondToolApproval($){await this.ensureMetadataApplied(),await this.client.command("approval.respond",{approvalId:$.approvalId,approved:$.approved,payload:$.reason?{reason:$.reason}:void 0,responderClientId:$.responderClientId})}streamEvents($,f){let J=new Set(($.sessionIds??[]).map((Z)=>Z.trim()).filter(Boolean)),W=this.client.subscribe((Z)=>{let Q=eN(Z);if(!Q)return;if(J.size>0&&!J.has(Q.sessionId))return;f.onEvent?.(Q)});return this.ensureMetadataApplied().catch((Z)=>{f.onError?.(Z instanceof Error?Z:Error(String(Z)))}),W}streamTeamProgress($,f){let J=this.client.subscribe((W)=>{if(W.event!=="team.progress"||!W.payload)return;f.onProjection?.(W.payload)});return this.ensureMetadataApplied().catch((W)=>{f.onError?.(W instanceof Error?W:Error(String(W)))}),J}async createSchedule($){return await this.ensureMetadataApplied(),(await this.client.command("schedule.create",$)).payload?.schedule}async listSchedules($){await this.ensureMetadataApplied();let f=await this.client.command("schedule.list");return Array.isArray(f.payload?.schedules)?f.payload?.schedules:[]}async getSchedule($){return await this.ensureMetadataApplied(),(await this.client.command("schedule.get",{scheduleId:$})).payload?.schedule}async updateSchedule($,f){return await this.ensureMetadataApplied(),(await this.client.command("schedule.update",{scheduleId:$,...f})).payload?.schedule}async pauseSchedule($){return await this.ensureMetadataApplied(),(await this.client.command("schedule.disable",{scheduleId:$})).payload?.schedule}async resumeSchedule($){return await this.ensureMetadataApplied(),(await this.client.command("schedule.enable",{scheduleId:$})).payload?.schedule}async deleteSchedule($){return await this.ensureMetadataApplied(),(await this.client.command("schedule.delete",{scheduleId:$})).payload?.deleted===!0}async triggerScheduleNow($){return await this.ensureMetadataApplied(),(await this.client.command("schedule.trigger",{scheduleId:$})).payload?.execution}async listScheduleExecutions($,f){await this.ensureMetadataApplied();let J=await this.client.command("schedule.list_executions",{scheduleId:$,limit:f});return Array.isArray(J.payload?.executions)?J.payload?.executions:[]}async getScheduleStats(){return await this.ensureMetadataApplied(),(await this.client.command("schedule.stats")).payload?.stats}async getActiveScheduledExecutions(){await this.ensureMetadataApplied();let $=await this.client.command("schedule.active");return Array.isArray($.payload?.executions)?$.payload?.executions:[]}async getUpcomingScheduledRuns($){await this.ensureMetadataApplied();let f=await this.client.command("schedule.upcoming",{limit:$});return Array.isArray(f.payload?.upcoming)?f.payload?.upcoming:[]}}class fM{client;constructor($){this.client=new V$({url:$.address,authToken:$.authToken,clientId:$.clientId,clientType:$.clientType??"hub-ui-client",displayName:$.displayName??"hub ui client"})}async connect(){await this.client.connect()}close(){this.client.close()}async dispose(){await this.client.dispose()}getClientId(){return this.client.getClientId()}async sendNotify($){await this.client.command("ui.notify",$)}async sendShowWindow($){await this.client.command("ui.show_window",$??{})}async listClients(){let $=await this.client.command("client.list");return Array.isArray($.payload?.clients)?$.payload.clients:[]}async listSessions($=200){let f=await this.client.command("session.list",{limit:$});return Array.isArray(f.payload?.sessions)?f.payload.sessions:[]}subscribeUI($){return this.client.subscribe((f)=>{switch(f.event){case"ui.notify":$.onNotify?.(f.payload);break;case"ui.show_window":$.onShowWindow?.(f.payload);break;case"hub.client.registered":$.onClientRegistered?.(f.payload??{});break;case"hub.client.disconnected":$.onClientDisconnected?.(f.payload??{});break;case"session.created":$.onSessionCreated?.(f.payload??{});break;case"session.updated":$.onSessionUpdated?.(f.payload??{});break;case"session.detached":$.onSessionDetached?.(f.payload??{});break}})}}import{normalizeProviderId as JM}from"@cline/llms";function WM($){return{text:$.text,usage:$.usage,inputTokens:$.usage.inputTokens,outputTokens:$.usage.outputTokens,iterations:$.iterations,finishReason:$.finishReason,toolCalls:$.toolCalls.map((f)=>({name:f.name,input:f.input,output:f.output,error:f.error,durationMs:f.durationMs}))}}function ZM($){return $.mode==="plan"?"plan":$.mode==="yolo"?"yolo":"act"}function Nc($={}){let f=new a$({sessionService:new d$(new c$),fetch:$.fetch,telemetry:$.telemetry});return{async startSession(J){let W=(J.cwd?.trim()||J.workspaceRoot).trim(),Z=await f.startSession({source:J.source?.trim()||F0.CLI,interactive:!1,config:{providerId:JM(J.provider),modelId:J.model,apiKey:J.apiKey?.trim()||void 0,cwd:W,workspaceRoot:J.workspaceRoot,systemPrompt:J.systemPrompt??"",mode:ZM(J),maxIterations:J.maxIterations,enableTools:J.enableTools!==!1,enableSpawnAgent:J.enableSpawn!==!1,enableAgentTeams:J.enableTeams!==!1,disableMcpSettingsTools:J.disableMcpSettingsTools,missionLogIntervalSteps:J.missionStepInterval,missionLogIntervalMs:J.missionTimeIntervalMs},toolPolicies:J.toolPolicies??{"*":{autoApprove:J.autoApproveTools!==!1}},localRuntime:{configExtensions:J.configExtensions}});return{sessionId:Z.sessionId,startResult:{sessionId:Z.sessionId,manifestPath:Z.manifestPath,messagesPath:Z.messagesPath}}},async sendSession(J,W){let Z=await f.runTurn({sessionId:J,prompt:W.prompt,userImages:W.attachments?.userImages,userFiles:W.attachments?.userFiles?.map((Q)=>Q.content)});if(!Z)throw Error("local hub schedule runtime returned no turn result");return{result:WM(Z)}},async abortSession(J){return await f.abort(J,Error("hub schedule abort")),{applied:!0}},async stopSession(J){return await f.stopSession(J),{applied:!0}}}}function QM($){if(typeof $==="string")return $.trim()||void 0;if(!Array.isArray($))return;return $.map((J)=>{if(J&&typeof J==="object"&&"type"in J&&J.type==="text"&&"text"in J&&typeof J.text==="string")return J.text.trim();return""}).filter(Boolean).join(`
|
|
697
|
+
`).trim()||void 0}var _Y=120,mZ="...";function gZ($){let f=$.trim();if(!f)return"";if(Buffer.byteLength(f,"utf8")<=_Y)return f;let J=_Y-Buffer.byteLength(mZ,"utf8");if(J<=0)return mZ;let W="";for(let Z of f){if(Buffer.byteLength(W+Z,"utf8")>J)break;W+=Z}return`${W}${mZ}`}async function zY($){let f=$?.sessionId?.trim()||"unknown",J=typeof $?.metadata?.messagesPath==="string"?$.metadata.messagesPath:void 0,Z=[...await k$(J)].reverse().find((X)=>X.role==="assistant"),Q=Z?QM(Z.content):void 0,j=$?.workspaceRoot?.trim()||"workspace",H=typeof $?.metadata?.prompt==="string"?$.metadata.prompt.trim():j;return{title:`Task completed (${f})`,body:gZ(Q&&Q.length>0?Q:H.length>0?H:j),severity:"info"}}import{captureSdkError as M4,createSessionId as kM}from"@cline/shared";import{createSessionId as YM}from"@cline/shared";import{createSessionId as XM}from"@cline/shared";function jM($){switch($){case"idle":return"idle";case"pending":return"pending";case"completed":return"completed";case"failed":return"failed";case"cancelled":return"aborted";default:return"running"}}function HM($){let f=$.metadata&&typeof $.metadata==="object"?JSON.parse(JSON.stringify($.metadata)):{};if($.parentSessionId?.trim())f.parentSessionId=$.parentSessionId;if($.parentAgentId?.trim())f.parentAgentId=$.parentAgentId;if($.agentId?.trim())f.agentId=$.agentId;if($.conversationId?.trim())f.conversationId=$.conversationId;if($.messagesPath?.trim())f.messagesPath=$.messagesPath;if($.prompt?.trim())f.prompt=$.prompt;if($.provider?.trim())f.provider=$.provider;if($.model?.trim())f.model=$.model;if($.source?.trim())f.source=$.source;if(typeof $.pid==="number")f.pid=$.pid;return Object.keys(f).length>0?f:void 0}function z4($,f,J,W){return{sessionId:$.sessionId,workspaceRoot:$.workspaceRoot,cwd:$.cwd,createdAt:Date.parse($.startedAt),updatedAt:Date.parse($.updatedAt),createdByClientId:f?.createdByClientId??"hub",status:jM($.status),participants:f?[...f.participants.values()]:[],metadata:HM($),runtimeOptions:{enableTools:$.enableTools,enableSpawn:$.enableSpawn,enableTeams:$.enableTeams,mode:typeof $.metadata?.mode==="string"?$.metadata.mode:void 0,systemPrompt:typeof $.metadata?.systemPrompt==="string"?$.metadata.systemPrompt:void 0},runtimeSession:$.agentId?{agentId:$.agentId,team:$.teamName?{teamId:$.teamName}:void 0}:void 0,...J?{usage:{...J}}:{},...W?{aggregateUsage:{...W}}:{}}}function m($,f){return{version:$.version,requestId:$.requestId,ok:!0,...f!==void 0?{payload:f}:{}}}function b($,f,J){return{version:$.version,requestId:$.requestId,ok:!1,error:{code:f,message:J}}}function T4($){return $&&typeof $==="object"&&!Array.isArray($)?$:void 0}function T0($){if(typeof $.payload?.sessionId==="string")return $.payload.sessionId.trim();return $.sessionId?.trim()??""}function I1($,f,J){return{version:"v1",event:$,eventId:XM("hevt_"),sessionId:J,timestamp:Date.now(),payload:f}}async function x0($,f){let J=await $.sessionHost.getSession(f);if(!J)return;let W=await $.sessionHost.getAccumulatedUsage?.(f);return z4(J,$.sessionState.get(f),W?.usage,W?.aggregateUsage)}async function m0($,f){let J=await $.sessionHost.getSession(f);if(!J)return;let[W,Z]=await Promise.all([typeof $.sessionHost.readSessionMessages==="function"?$.sessionHost.readSessionMessages(f):[],$.sessionHost.getAccumulatedUsage?.(f)]);return g$({session:J,messages:W,usage:Z?.usage,aggregateUsage:Z?.aggregateUsage})}function N4($,f,J,W,Z={}){let Q=$.sessionState.get(f);if(Q){if(Z.interactive!==void 0)Q.interactive=Z.interactive;if(!Q.participants.has(J))Q.participants.set(J,{clientId:J,attachedAt:Date.now(),role:W});return Q}let j={createdByClientId:J,interactive:Z.interactive??!0,participants:new Map([[J,{clientId:J,attachedAt:Date.now(),role:W}]])};return $.sessionState.set(f,j),j}async function vZ($,f){let J=YM("approval_"),W=f.sessionId;if($.sessionState.get(W)?.interactive===!1)return{approved:!1,reason:"Tool approval requires an interactive session, but this session is non-interactive."};return await new Promise((Q)=>{$.pendingApprovals.set(J,{sessionId:W,resolve:Q}),$.publish($.buildEvent("approval.requested",{approvalId:J,sessionId:f.sessionId,agentId:f.agentId,conversationId:f.conversationId,iteration:f.iteration,toolCallId:f.toolCallId,toolName:f.toolName,inputJson:JSON.stringify(f.input??null),policy:f.policy},W))})}function uZ($,f,J){let W=$.pendingApprovals.get(f);if(!W)return;return $.pendingApprovals.delete(f),W.resolve(J),{sessionId:W.sessionId}}function cZ($,f,J){let W=0;for(let[Z,Q]of[...$.pendingApprovals.entries()]){if(!f({approvalId:Z,sessionId:Q.sessionId}))continue;$.pendingApprovals.delete(Z),Q.resolve({approved:!1,reason:J}),$.publish($.buildEvent("approval.resolved",{approvalId:Z,approved:!1,cancelled:!0,reason:J},Q.sessionId)),W+=1}return W}async function TY($,f){let J=typeof f.payload?.approvalId==="string"?f.payload.approvalId.trim():"";if(!$.pendingApprovals.get(J))return b(f,"approval_not_found",`Unknown approval: ${J}`);let Z=typeof f.payload?.reason==="string"?f.payload.reason:f.payload?.payload&&typeof f.payload.payload==="object"&&!Array.isArray(f.payload.payload)&&typeof f.payload.payload.reason==="string"?f.payload.payload.reason:void 0,Q=f.payload?.approved===!0,j=uZ($,J,{approved:Q,reason:Z});if(!j)return b(f,"approval_not_found",`Unknown approval: ${J}`);return $.publish($.buildEvent("approval.resolved",{approvalId:J,approved:Q,reason:Z},j.sessionId)),m(f,{approvalId:J,approved:Q})}import{createSessionId as BM}from"@cline/shared";function AM($){if($ instanceof Error)return{name:$.name,message:$.message,stack:$.stack};if($===void 0)return;return $}var NY={debug:10,info:20,warn:30,error:40,silent:50};function VM(){let $=process.env.CLINE_HUB_LOG_LEVEL?.trim().toLowerCase();if($==="debug"||$==="info"||$==="warn"||$==="error"||$==="silent")return $;return process.env.VITEST?"error":"info"}function I($,f,J={}){if(NY[$]<NY[VM()])return;let W=JSON.stringify({ts:new Date().toISOString(),level:$,component:"hub",message:f,...Object.fromEntries(Object.entries(J).map(([Z,Q])=>[Z,AM(Q)]).filter(([,Z])=>Z!==void 0))});if($==="error"||$==="warn"){console.error(`[hub] ${W}`);return}console.log(`[hub] ${W}`)}function dZ($,f){let J=f instanceof Error?f.stack||f.message:String(f);I("error",$,{error:J})}async function MY($,f,J,W,Z,Q){let j=BM("capreq_"),H=performance.now();return I("info","capability.request.start",{requestId:j,sessionId:f,capabilityName:J,targetClientId:Z}),await new Promise((X,Y)=>{$.pendingCapabilityRequests.set(j,{sessionId:f,targetClientId:Z,capabilityName:J,onProgress:Q,resolve:(A)=>{if(I(A.ok?"info":"warn","capability.request.end",{requestId:j,sessionId:f,capabilityName:J,targetClientId:Z,ok:A.ok,error:A.error,durationMs:Math.round(performance.now()-H)}),!A.ok){Y(Error(A.error||`Capability ${J} was rejected by ${Z}.`));return}X(A.payload)}}),$.publish($.buildEvent("capability.requested",{requestId:j,targetClientId:Z,capabilityName:J,payload:W},f)),I("info","capability.request.published",{requestId:j,sessionId:f,capabilityName:J,targetClientId:Z})})}function yY($,f){let J=typeof f.payload?.requestId==="string"?f.payload.requestId.trim():"",W=$.pendingCapabilityRequests.get(J);if(!W)return b(f,"capability_not_found",`Unknown capability request: ${J}`);if((f.clientId?.trim()||"")!==W.targetClientId)return b(f,"capability_wrong_client",`Capability request ${J} is owned by ${W.targetClientId}`);if(f.sessionId?.trim()&&f.sessionId.trim()!==W.sessionId)return b(f,"capability_wrong_session",`Capability request ${J} belongs to session ${W.sessionId}`);let Q=f.payload?.payload&&typeof f.payload.payload==="object"&&!Array.isArray(f.payload.payload)?f.payload.payload:{};return W.onProgress?.(Q),m(f,{requestId:J})}function t$($,f,J){let W=0;for(let[Z,Q]of[...$.pendingCapabilityRequests.entries()]){if(!f({requestId:Z,...Q}))continue;$.pendingCapabilityRequests.delete(Z),I("warn","capability.request.cancelled",{requestId:Z,sessionId:Q.sessionId,capabilityName:Q.capabilityName,targetClientId:Q.targetClientId,reason:J}),Q.resolve({ok:!1,error:J}),$.publish($.buildEvent("capability.resolved",{requestId:Z,capabilityName:Q.capabilityName,targetClientId:Q.targetClientId,ok:!1,cancelled:!0,error:J},Q.sessionId)),W+=1}return W}async function qY($,f){let J=typeof f.payload?.sessionId==="string"?f.payload.sessionId.trim():f.sessionId?.trim()||"",W=typeof f.payload?.capabilityName==="string"?f.payload.capabilityName.trim():"",Z=typeof f.payload?.targetClientId==="string"?f.payload.targetClientId.trim():"";if(!J||!W||!Z)return b(f,"invalid_capability_request","capability.request requires sessionId, capabilityName, and targetClientId");try{let Q=f.payload?.payload&&typeof f.payload.payload==="object"&&!Array.isArray(f.payload.payload)?f.payload.payload:{},j=await $.requestCapability(J,W,Q,Z);return m(f,j)}catch(Q){return b(f,"capability_request_failed",Q instanceof Error?Q.message:String(Q))}}function wY($,f){let J=typeof f.payload?.requestId==="string"?f.payload.requestId.trim():"",W=$.pendingCapabilityRequests.get(J);if(!W)return b(f,"capability_not_found",`Unknown capability request: ${J}`);let Z=f.clientId?.trim()||"";if(Z!==W.targetClientId)return b(f,"capability_wrong_client",`Capability request ${J} is owned by ${W.targetClientId}`);if(f.sessionId?.trim()&&f.sessionId.trim()!==W.sessionId)return b(f,"capability_wrong_session",`Capability request ${J} belongs to session ${W.sessionId}`);$.pendingCapabilityRequests.delete(J);let Q=f.payload?.payload&&typeof f.payload.payload==="object"&&!Array.isArray(f.payload.payload)?f.payload.payload:void 0,j=typeof f.payload?.error==="string"?f.payload.error:void 0,H=f.payload?.ok===!0;return I(H?"info":"warn","capability.respond",{requestId:J,sessionId:W.sessionId,capabilityName:W.capabilityName,targetClientId:W.targetClientId,respondedByClientId:Z,ok:H,error:j}),W.resolve({ok:H,payload:Q,error:j}),$.publish($.buildEvent("capability.resolved",{requestId:J,capabilityName:W.capabilityName,targetClientId:W.targetClientId,respondedByClientId:Z,ok:H,payload:Q,error:j},W.sessionId)),m(f,{requestId:J,ok:H})}import{createSessionId as KM}from"@cline/shared";function SY($,f){let J=f.payload,W=J?.clientId?.trim()||f.clientId?.trim()||KM("client_");return $.clients.set(W,{clientId:W,clientType:J?.clientType??"unknown",displayName:J?.displayName,actorKind:J?.actorKind??"client",connectedAt:Date.now(),lastSeenAt:Date.now(),transport:J?.transport??"native",capabilities:J?.capabilities??[],metadata:J?.metadata,workspaceContext:J?.workspaceContext}),$.publish($.buildEvent("hub.client.registered",{clientId:W,clientType:J?.clientType??"unknown",displayName:J?.displayName,connectedAt:Date.now()})),m(f,{clientId:W})}function hY($,f){let J=f.clientId?.trim(),W=J?$.clients.get(J):void 0;if(!J||!W)return b(f,"client_not_found","Client is not registered with this hub.");let Z=T4(f.payload?.metadata);if(W.lastSeenAt=Date.now(),Z)W.metadata=JSON.parse(JSON.stringify(Z));return m(f)}function CY($,f,J){let W=f.clientId?.trim();if(W)$.clients.delete(W),J(W),$.publish($.buildEvent("hub.client.disconnected",{clientId:W}));return m(f)}function EY($,f){return m(f,{clients:[...$.clients.values()]})}var GM=30000;function PM($){if($==="aborted")return"run.aborted";if($==="error"||$==="failed")return"run.failed";return"run.completed"}function FM($){if($.finishReason!=="error")return;return $.text.trim()||void 0}function UM($,f,J){let W=J instanceof Error&&J.message.trim()?J.message:`Unknown session: ${f}`;return b($,Q2,W)}function RM($){return $?$:void 0}function DM($){let f=typeof $.timeoutMs==="number"?$.timeoutMs:typeof $.timeout_ms==="number"?$.timeout_ms:void 0;if(f&&Number.isFinite(f)&&f>0)return Math.floor(f);let J=typeof $.timeoutSeconds==="number"?$.timeoutSeconds:typeof $.timeout_seconds==="number"?$.timeout_seconds:void 0;if(J&&Number.isFinite(J)&&J>0)return Math.floor(J*1000);return}async function LM($,f,J,W){let Z=performance.now(),Q=!1,j={command:f.command,requestId:f.requestId,clientId:f.clientId,sessionId:J.sessionId,timeoutMs:W},H=setInterval(()=>{if(Q)return;let A=Math.round(performance.now()-Z);I("warn","run.heartbeat",{...j,elapsedMs:A}),$.publish($.buildEvent("run.heartbeat",{requestId:f.requestId,elapsedMs:A,...W?{timeoutMs:W}:{}},J.sessionId))},GM),X=$.sessionHost.runTurn(J);X.then((A)=>{if(!Q)return;I("warn","run.late_end",{...j,elapsedMs:Math.round(performance.now()-Z),finishReason:A?.finishReason})},(A)=>{if(!Q)return;I("error","run.late_error",{...j,elapsedMs:Math.round(performance.now()-Z),error:A})});let Y;try{if(!W)return await X;return await Promise.race([X,new Promise((A,V)=>{Y=setTimeout(()=>{let B=`Hub run ${f.command} timed out after ${W}ms.`;Q=!0,clearInterval(H),V(Error(B)),I("error","run.timeout",{...j,elapsedMs:Math.round(performance.now()-Z)}),cZ($,(K)=>K.sessionId===J.sessionId,B),t$($,(K)=>K.sessionId===J.sessionId,B),$.sessionHost.abort(J.sessionId,B).catch((K)=>{I("error","run.timeout_abort_failed",{...j,error:K})})},W)})])}finally{if(Q=!0,clearInterval(H),Y)clearTimeout(Y)}}async function bY($,f){let J=T0(f),W=f.payload&&typeof f.payload==="object"?f.payload:{},Z=typeof W.prompt==="string"?W.prompt:typeof W.input==="string"?W.input:"";if(!Z.trim())return b(f,"invalid_session_input","session input requires a prompt string");$.publish($.buildEvent("run.started",void 0,J));let Q=W.attachments&&typeof W.attachments==="object"&&!Array.isArray(W.attachments)?W.attachments:void 0,j=Array.isArray(Q?.userFiles)?Q.userFiles.filter((A)=>typeof A==="string"):void 0,H=DM(W);$.suppressNextTerminalEventBySession.set(J,"run.start.reply");let X;try{X=await LM($,f,{sessionId:J,prompt:Z,mode:RM(W.mode),delivery:W.delivery==="queue"||W.delivery==="steer"?W.delivery:void 0,userImages:Array.isArray(Q?.userImages)?Q.userImages:void 0,userFiles:j,timeoutMs:H},H)}catch(A){if($.suppressNextTerminalEventBySession.get(J)==="run.start.reply")$.suppressNextTerminalEventBySession.delete(J);if(U1(A))return UM(f,J,A);throw $.publish($.buildEvent("run.failed",{reason:"error",error:A instanceof Error?A.message:String(A)},J)),A}if(X){let A=await m0($,J),V=FM(X);if($.publish($.buildEvent(PM(X.finishReason),{reason:X.finishReason,...V?{error:V}:{},result:X,...A?{snapshot:A}:{}},J)),$.suppressNextTerminalEventBySession.get(J)==="run.start.reply")$.suppressNextTerminalEventBySession.delete(J)}else $.suppressNextTerminalEventBySession.delete(J);let Y=await m0($,J);return m(f,X||Y?{...X?{result:X}:{},...Y?{snapshot:Y}:{}}:void 0)}async function kY($,f){let J=T0(f),W=typeof f.payload?.reason==="string"?f.payload.reason:"Run was aborted before pending approval or capability request was resolved.";cZ($,(Z)=>Z.sessionId===J,W);try{await $.sessionHost.abort(J,f.payload?.reason)}catch(Z){I("warn","run.abort_failed",{command:f.command,requestId:f.requestId,clientId:f.clientId,sessionId:J,error:Z})}finally{t$($,(Z)=>Z.sessionId===J,W)}return m(f,{applied:!0})}async function IY($,f){let J=B4(f.payload?.payload);if(!J)return b(f,"invalid_hook_payload","session.hook requires a valid hook event payload");return await $.sessionHost.dispatchHookEvent(J),m(f,{applied:!0})}async function xY($,f){switch(f.type){case"chunk":return;case"agent_event":await OM($,f);return;case"hook":if(f.payload.hookEventName==="tool_call")$.publish($.buildEvent("tool.started",{toolName:f.payload.toolName},f.payload.sessionId));else if(f.payload.hookEventName==="tool_result")$.publish($.buildEvent("tool.finished",{toolName:f.payload.toolName},f.payload.sessionId));return;case"team_progress":{let J={type:"team_progress_projection",version:1,sessionId:f.payload.sessionId,summary:f.payload.summary,lastEvent:f.payload.lifecycle};$.publish($.buildEvent("team.progress",J,f.payload.sessionId));return}case"pending_prompts":$.publish($.buildEvent("session.pending_prompts",{sessionId:f.payload.sessionId,prompts:f.payload.prompts},f.payload.sessionId));return;case"pending_prompt_submitted":{let J={id:f.payload.id,prompt:f.payload.prompt,delivery:f.payload.delivery,attachmentCount:f.payload.attachmentCount};$.publish($.buildEvent("session.pending_prompt_submitted",{sessionId:f.payload.sessionId,prompt:J},f.payload.sessionId));return}case"session_snapshot":$.publish($.buildEvent("session.updated",{sessionId:f.payload.sessionId,snapshot:f.payload.snapshot},f.payload.sessionId));return;case"status":{let[J,W]=await Promise.all([x0($,f.payload.sessionId),m0($,f.payload.sessionId)]);if(J)$.publish($.buildEvent("session.updated",{session:J,...W?{snapshot:W}:{}},f.payload.sessionId));return}case"ended":await _M($,f);return;default:return}}async function OM($,f){let{sessionId:J,event:W}=f.payload;if(W.type==="iteration_start"){$.publish($.buildEvent("iteration.started",{iteration:W.iteration},J));return}if(W.type==="iteration_end"){$.publish($.buildEvent("iteration.finished",{iteration:W.iteration,hadToolCalls:W.hadToolCalls,toolCallCount:W.toolCallCount},J));return}if(W.type==="content_start"){if(W.contentType==="text"&&typeof W.text==="string"&&W.text.length>0){$.publish($.buildEvent("assistant.delta",{text:W.text},J));return}if(W.contentType==="reasoning"){if(W.redacted&&!W.reasoning){$.publish($.buildEvent("reasoning.delta",{text:"",redacted:!0},J));return}if(typeof W.reasoning==="string"&&W.reasoning.length>0)$.publish($.buildEvent("reasoning.delta",{text:W.reasoning,redacted:W.redacted===!0},J));return}if(W.contentType==="tool"){$.publish($.buildEvent("tool.started",{toolCallId:W.toolCallId,toolName:W.toolName,input:W.input},J));return}}if(W.type==="content_end"){switch(W.contentType){case"text":$.publish($.buildEvent("assistant.finished",{text:W.text},J));break;case"reasoning":$.publish($.buildEvent("reasoning.finished",{reasoning:W.reasoning},J));break;case"tool":$.publish($.buildEvent("tool.finished",{toolCallId:W.toolCallId,toolName:W.toolName,output:W.output,error:W.error},J));break}return}if(W.type==="usage"){let Z;try{Z=await $.sessionHost.getAccumulatedUsage?.(J)}catch{Z=void 0}$.publish($.buildEvent("usage.updated",{sessionId:J,delta:{inputTokens:W.inputTokens,outputTokens:W.outputTokens,cacheReadTokens:W.cacheReadTokens??0,cacheWriteTokens:W.cacheWriteTokens??0,totalCost:W.cost??0},totals:{inputTokens:W.totalInputTokens,outputTokens:W.totalOutputTokens,cacheReadTokens:W.totalCacheReadTokens??0,cacheWriteTokens:W.totalCacheWriteTokens??0,totalCost:W.totalCost??0},usage:Z?.usage,aggregateUsage:Z?.aggregateUsage,agent:{kind:f.payload.teamRole==="teammate"?"teammate":W.parentAgentId?"subagent":"lead",agentId:W.agentId,conversationId:W.conversationId,parentAgentId:W.parentAgentId,teamAgentId:f.payload.teamAgentId,teamRole:f.payload.teamRole}},J));return}if(W.type==="done")$.publish($.buildEvent("agent.done",{reason:W.reason,text:W.text,iterations:W.iterations,usage:W.usage},J))}async function _M($,f){let J=$.suppressNextTerminalEventBySession.get(f.payload.sessionId),W=J===f.payload.reason||J==="run.start.reply";if(W)$.suppressNextTerminalEventBySession.delete(f.payload.sessionId);let[Z,Q]=await Promise.all([x0($,f.payload.sessionId),m0($,f.payload.sessionId)]);if(f.payload.reason==="completed"){let j=await zY(Z);$.publish($.buildEvent("ui.notify",j,f.payload.sessionId))}if(W)return;$.publish($.buildEvent(f.payload.reason==="aborted"?"run.aborted":f.payload.reason==="error"||f.payload.reason==="failed"?"run.failed":"run.completed",{reason:f.payload.reason,...Q?{snapshot:Q}:{}},f.payload.sessionId))}import{createSessionId as gY,parseRuntimeConfigExtensions as vY}from"@cline/shared";import{HUB_CHECKPOINT_CAPABILITY as Jd,HUB_COMPACTION_CAPABILITY as Wd,HUB_CUSTOM_TOOL_CAPABILITY_PREFIX as Zd,HUB_HOOK_CAPABILITY_PREFIX as Qd,HUB_MISTAKE_LIMIT_CAPABILITY as jd,HUB_TOOL_EXECUTOR_CAPABILITY_PREFIX as Hd,HUB_USER_INSTRUCTIONS_SNAPSHOT_CAPABILITY as Xd,isHubToolExecutorName as zM}from"@cline/shared";import{HUB_CHECKPOINT_CAPABILITY as Kd,HUB_COMPACTION_CAPABILITY as Gd,HUB_CUSTOM_TOOL_CAPABILITY_PREFIX as Pd,HUB_HOOK_CAPABILITY_PREFIX as Fd,HUB_MISTAKE_LIMIT_CAPABILITY as Ud,HUB_TOOL_EXECUTOR_CAPABILITY_PREFIX as Rd,HUB_USER_INSTRUCTIONS_SNAPSHOT_CAPABILITY as Dd}from"@cline/shared";var TM=["beforeRun","afterRun","beforeModel","afterModel","beforeTool","afterTool","onEvent"];function x1($){return $&&typeof $==="object"&&!Array.isArray($)?JSON.parse(JSON.stringify($)):void 0}function NM($,f){let J=typeof $.name==="string"?$.name.trim():"",W=typeof $.description==="string"?$.description:"",Z=typeof $.capabilityName==="string"?$.capabilityName.trim():"",Q=x1($.inputSchema);if(!J||!W||!Q||!Z||f.has(Z))return;return f.add(Z),{kind:"tool",capabilityName:Z,name:J,description:W,inputSchema:Q,...x1($.lifecycle)?{lifecycle:x1($.lifecycle)}:{}}}function pZ($){if(!Array.isArray($))return[];let f=[],J=new Set;for(let W of $){if(!W||typeof W!=="object"||Array.isArray(W))continue;let Z=W,Q=Z.kind,j=typeof Z.capabilityName==="string"?Z.capabilityName.trim():"";if(!j||J.has(j))continue;if(Q==="tool"){let H=NM(Z,J);if(H)f.push(H);continue}if(Q==="toolExecutor"){let H=Z.executor;if(!zM(H))continue;J.add(j),f.push({kind:"toolExecutor",capabilityName:j,executor:H});continue}if(Q==="hook"){let H=typeof Z.name==="string"?Z.name.trim():"";if(!H)continue;J.add(j),f.push({kind:"hook",capabilityName:j,name:H});continue}if(Q==="compaction"){J.add(j),f.push({kind:"compaction",capabilityName:j,...x1(Z.config)?{config:x1(Z.config)}:{}});continue}if(Q==="checkpoint"){J.add(j),f.push({kind:"checkpoint",capabilityName:j,...x1(Z.config)?{config:x1(Z.config)}:{}});continue}if(Q==="mistakeLimit"){J.add(j),f.push({kind:"mistakeLimit",capabilityName:j});continue}if(Q==="userInstructionService")J.add(j),f.push({kind:"userInstructionService",capabilityName:j})}return f}function mY($){return{agentId:$.agentId,conversationId:$.conversationId,iteration:$.iteration,metadata:$.metadata}}function MM($){return Object.hasOwn($,"update")?$.update:$}function p2($){return $.trim().replace(/^\/+/,"").toLowerCase()}function yM($){let f=($??[]).map(p2).filter(Boolean);return f.length>0?new Set(f):void 0}function qM($,f,J){if(!J)return!0;let W=p2($),Z=p2(f),Q=W.includes(":")?W.split(":").at(-1)??W:W,j=Z.includes(":")?Z.split(":").at(-1)??Z:Z;return J.has(W)||J.has(Z)||J.has(Q)||J.has(j)}function lZ($,f){let J=yM(f);return $.records.skill.map((W)=>({id:W.id,name:W.item.name,description:"description"in W.item&&typeof W.item.description==="string"?W.item.description:void 0,disabled:W.item.disabled===!0,skill:W.item})).filter((W)=>qM(W.id,W.name,J))}function wM($,f){let J=async(W,Z)=>{let Q=p2(W),H=lZ($,f).filter((B)=>B.id===Q||p2(B.name)===Q||B.id.endsWith(`:${Q}`)).filter((B)=>!B.disabled);if(H.length!==1)return H.length>1?`Skill "${W}" is ambiguous. Use one of: ${H.map((B)=>B.id).join(", ")}`:`Skill "${W}" not found.`;let X=H[0].skill,Y=Z?.trim(),A=Y?`
|
|
698
|
+
<command-args>${Y}</command-args>`:"",V=X.description?.trim()?`Description: ${X.description.trim()}
|
|
699
|
+
|
|
700
|
+
`:"";return`<command-name>${X.name}</command-name>${A}
|
|
701
701
|
<command-instructions>
|
|
702
|
-
${
|
|
703
|
-
</command-instructions>`};return Object.defineProperty(J,"configuredSkills",{get:()=>
|
|
702
|
+
${V}${X.instructions}
|
|
703
|
+
</command-instructions>`};return Object.defineProperty(J,"configuredSkills",{get:()=>lZ($,f).map(({skill:W,...Z})=>Z),enumerable:!0}),J}function SM($,f,J,W){let Z={records:{skill:[],rule:[],workflow:[]},runtimeCommands:[]},Q=async()=>{let j=await W($,J.capabilityName,{},f);if(j?.snapshot)Z=j.snapshot};return{start:Q,stop:()=>{},refreshType:async()=>{await Q()},listRecords:(j)=>[...Z.records[j]],listRuntimeCommands:()=>[...Z.runtimeCommands],resolveRuntimeSlashCommand:(j)=>{if(!j.startsWith("/")||j.length<2)return j;let X=j.match(/^\/(\S+)/)?.[1];if(!X)return j;let Y=Z.runtimeCommands.find((A)=>A.name===X);return Y?`${Y.instructions}${j.slice(X.length+1)}`:j},hasConfiguredSkills:(j)=>lZ(Z,j).some((H)=>!H.disabled),createExtension:(j)=>({name:"cline-hub-user-instructions",manifest:{capabilities:[j.includeRules?"rules":void 0,j.registerSkillsTool?"tools":void 0,j.includeSkills||j.includeWorkflows?"commands":void 0].filter((H)=>Boolean(H))},setup(H){if(j.includeRules)H.registerRule({id:"cline-hub-user-instructions:rules",source:"hub-user-instructions",content:()=>b8(Z.records.rule.map((X)=>X.item).filter((X)=>X.disabled!==!0))});if(j.registerSkillsTool)H.registerTool(o1(wM(Z,j.allowedSkillNames)));for(let X of Z.runtimeCommands.filter((Y)=>Y.kind==="skill"&&j.includeSkills||Y.kind==="workflow"&&j.includeWorkflows))H.registerCommand({name:X.name,description:X.description,handler:(Y)=>{let A=Y.trim();return A?`${X.instructions}
|
|
704
704
|
|
|
705
|
-
${V}`:H.instructions}})}})}}function PT($,f,J,Q){let Z=J.map((W)=>[W.executor,async(...j)=>{let X=j.at(-1),H=j.slice(0,-1);return(await Q($,W.capabilityName,{executor:W.executor,args:H,context:nH(X)},f))?.result}]);return Z.length>0?Object.fromEntries(Z):void 0}function UT($,f,J,Q){if(J.length===0)return;return J.map((Z)=>({name:Z.name,description:Z.description,inputSchema:Z.inputSchema,lifecycle:Z.lifecycle,async execute(W,j){return(await Q($,Z.capabilityName,{toolName:Z.name,input:W,context:nH(j)},f,j.emitUpdate?(H)=>{j.emitUpdate?.(AT(H))}:void 0))?.result}}))}function DT($,f,J,Q){let Z=new Map(J.map((j)=>[j.name,j])),W={};for(let j of YT){let X=Z.get(j);if(!X)continue;W[j]=async(H)=>{return(await Q($,X.capabilityName,{context:H},f))?.control}}return Object.keys(W).length>0?W:void 0}function D7($){let f=$.contributions.filter((H)=>H.kind==="toolExecutor"),J=$.contributions.filter((H)=>H.kind==="tool"),Q=$.contributions.filter((H)=>H.kind==="hook"),Z=$.contributions.find((H)=>H.kind==="compaction"),W=$.contributions.find((H)=>H.kind==="checkpoint"),j=$.contributions.find((H)=>H.kind==="mistakeLimit"),X=$.contributions.find((H)=>H.kind==="userInstructionService");return{hasClientContributions:$.contributions.length>0,toolExecutors:PT($.sessionId,$.targetClientId,f,$.requestCapability),localRuntime:{...Q.length>0?{hooks:DT($.sessionId,$.targetClientId,Q,$.requestCapability)}:{},...J.length>0?{extraTools:UT($.sessionId,$.targetClientId,J,$.requestCapability)}:{},...Z?{compaction:{...$.sessionConfig?.compaction??{},...Z.config,compact:async(H)=>{return(await $.requestCapability($.sessionId,Z.capabilityName,{context:H},$.targetClientId))?.result}}}:{},...W?{checkpoint:{...$.sessionConfig?.checkpoint??{},...W.config,createCheckpoint:async(H)=>{return(await $.requestCapability($.sessionId,W.capabilityName,{context:H},$.targetClientId))?.result}}}:{},...j?{onConsecutiveMistakeLimitReached:async(H)=>{return(await $.requestCapability($.sessionId,j.capabilityName,{context:H},$.targetClientId))?.result}}:{},...X?{userInstructionService:FT($.sessionId,$.targetClientId,X,$.requestCapability)}:{}}}}var sH="hubCapabilityOwnerClientId";function oH($,f){$[sH]=f}function RT($){let f=$?.[sH];return typeof f==="string"&&f.trim()?f.trim():void 0}async function eH($,f,J){let Q=performance.now(),Z={command:f.command,requestId:f.requestId,clientId:f.clientId,sessionId:f.sessionId};I("info","session.create.begin",Z);let W=f.payload&&typeof f.payload==="object"?f.payload:{},j=W.metadata&&typeof W.metadata==="object"?JSON.parse(JSON.stringify(W.metadata)):{},X=W.sessionConfig&&typeof W.sessionConfig==="object"?JSON.parse(JSON.stringify(W.sessionConfig)):void 0,H=W.runtimeOptions&&typeof W.runtimeOptions==="object"?W.runtimeOptions:{};if(typeof X?.mode==="string")j.mode=X.mode;else if(typeof H.mode==="string")j.mode=H.mode;if(typeof X?.systemPrompt==="string")j.systemPrompt=X.systemPrompt;else if(typeof H.systemPrompt==="string")j.systemPrompt=H.systemPrompt;if(X?.checkpoint?.enabled===!0)j.checkpointEnabled=!0;else if(H.checkpointEnabled===!0)j.checkpointEnabled=!0;let Y=W.modelSelection&&typeof W.modelSelection==="object"?W.modelSelection:{},V=typeof W.workspaceRoot==="string"&&W.workspaceRoot.trim()?W.workspaceRoot.trim():typeof W.cwd==="string"&&W.cwd.trim()?W.cwd.trim():"";if(!V)return I("warn","session.create.invalid",{...Z,reason:"missing_workspace_root"}),b(f,"invalid_session_create","session.create requires workspaceRoot or cwd");let A=f.clientId?.trim()||"hub-client",B=U7(H.clientContributions);if(I("info","session.create.contributions_parsed",{...Z,clientId:A,workspaceRoot:V,cwd:typeof W.cwd==="string"?W.cwd:void 0,contributionCount:B.length}),B.length>0)oH(j,A);let K=(typeof X?.sessionId==="string"?X.sessionId.trim():"")||aH(),D=tH(H.configExtensions);I("info","session.create.runtime_build.begin",{...Z,sessionId:K,configExtensionCount:D?.length??0});let F=D7({sessionId:K,targetClientId:A,contributions:B,sessionConfig:X,requestCapability:$.requestCapability});I("info","session.create.start_session.begin",{...Z,sessionId:K,provider:X?.providerId??(typeof Y.provider==="string"?Y.provider:typeof j.provider==="string"?j.provider:"hub"),model:X?.modelId??(typeof Y.model==="string"?Y.model:typeof j.model==="string"?j.model:"hub")});let P=await $.sessionHost.startSession({source:typeof j.source==="string"?j.source:void 0,interactive:j.interactive!==!1,sessionMetadata:Object.keys(j).length>0?j:void 0,initialMessages:Array.isArray(W.initialMessages)?W.initialMessages:void 0,localRuntime:{modelCatalogDefaults:{loadLatestOnInit:!0,loadPrivateOnAuth:!0},configExtensions:D,...F.localRuntime},capabilities:{toolExecutors:F.toolExecutors,requestToolApproval:J},config:{...X??{},sessionId:K,providerId:X?.providerId??(typeof Y.provider==="string"?Y.provider:typeof j.provider==="string"?j.provider:"hub"),modelId:X?.modelId??(typeof Y.model==="string"?Y.model:typeof j.model==="string"?j.model:"hub"),apiKey:X?.apiKey??(typeof Y.apiKey==="string"?Y.apiKey:void 0),cwd:X?.cwd??(typeof W.cwd==="string"&&W.cwd.trim()?W.cwd.trim():V),workspaceRoot:X?.workspaceRoot??V,systemPrompt:X?.systemPrompt??(typeof H.systemPrompt==="string"?H.systemPrompt:""),mode:X?.mode??(H.mode==="plan"||H.mode==="yolo"?H.mode:"act"),maxIterations:X?.maxIterations??(typeof H.maxIterations==="number"?H.maxIterations:void 0),enableTools:X?.enableTools??H.enableTools!==!1,enableSpawnAgent:X?.enableSpawnAgent??H.enableSpawn!==!1,enableAgentTeams:X?.enableAgentTeams??H.enableTeams!==!1,checkpoint:X?.checkpoint??(H.checkpointEnabled===!0?{enabled:!0}:void 0),teamName:X?.teamName??(typeof j.teamName==="string"?j.teamName:void 0)},toolPolicies:W.toolPolicies&&typeof W.toolPolicies==="object"&&!Array.isArray(W.toolPolicies)?JSON.parse(JSON.stringify(W.toolPolicies)):H.autoApproveTools===!0?{"*":{autoApprove:!0}}:void 0});I("info","session.create.start_session.end",{...Z,sessionId:P.sessionId,elapsedMs:Math.round(performance.now()-Q),hasImmediateResult:!!P.result}),ff($,P.sessionId,A,"creator",{interactive:j.interactive!==!1}),I("info","session.create.read_records.begin",{...Z,sessionId:P.sessionId});let[U,z]=await Promise.all([g0($,P.sessionId),v0($,P.sessionId)]);if(I("info","session.create.read_records.end",{...Z,sessionId:P.sessionId,hasSession:!!U,hasSnapshot:!!z,elapsedMs:Math.round(performance.now()-Q)}),U)$.publish($.buildEvent("session.created",{session:U,...z?{snapshot:z}:{}},P.sessionId));return I("info","session.create.reply",{...Z,sessionId:P.sessionId,elapsedMs:Math.round(performance.now()-Q)}),m(f,{session:U,...z?{snapshot:z}:{}})}async function $Y($,f,J){let Q=f.payload&&typeof f.payload==="object"?f.payload:{},Z=typeof Q.sessionId==="string"?Q.sessionId.trim():f.sessionId?.trim()||"",W=Q.checkpointRunCount;if(!Z)return b(f,"invalid_restore","session.restore requires a session id");let j=Q.restore&&typeof Q.restore==="object"?Q.restore:{},X=j.messages!==!1;if(typeof W!=="number")return b(f,"invalid_restore","checkpointRunCount must be a positive integer");try{let H=Q.sessionConfig&&typeof Q.sessionConfig==="object"?JSON.parse(JSON.stringify(Q.sessionConfig)):void 0;if(X&&!H)return b(f,"invalid_restore","sessionConfig is required when restore.messages is true");let Y=Q.runtimeOptions&&typeof Q.runtimeOptions==="object"?Q.runtimeOptions:{},V=Q.metadata&&typeof Q.metadata==="object"?JSON.parse(JSON.stringify(Q.metadata)):{};if(typeof H?.mode==="string")V.mode=H.mode;else if(typeof Y.mode==="string")V.mode=Y.mode;if(typeof H?.systemPrompt==="string")V.systemPrompt=H.systemPrompt;else if(typeof Y.systemPrompt==="string")V.systemPrompt=Y.systemPrompt;if(H?.checkpoint?.enabled===!0)V.checkpointEnabled=!0;else if(Y.checkpointEnabled===!0)V.checkpointEnabled=!0;let A=Q.modelSelection&&typeof Q.modelSelection==="object"?Q.modelSelection:{},B=f.clientId?.trim()||"hub-client",G=U7(Y.clientContributions);if(G.length>0)oH(V,B);let D=(typeof H?.sessionId==="string"?H.sessionId.trim():"")||aH(),F=tH(Y.configExtensions),P=D7({sessionId:D,targetClientId:B,contributions:G,sessionConfig:H,requestCapability:$.requestCapability}),z=await new j2().restoreCheckpoint({sessionId:Z,checkpointRunCount:W,restore:{messages:j.messages,workspace:j.workspace,omitCheckpointMessageFromSession:j.omitCheckpointMessageFromSession===!0},start:H,cwd:typeof H?.cwd==="string"&&H.cwd.trim()||typeof H?.workspaceRoot==="string"&&H.workspaceRoot.trim()||void 0,getSession:(N)=>$.sessionHost.getSession(N),readMessages:(N)=>$.sessionHost.readSessionMessages(N),buildStartInput:(N)=>{if(N.restoredCheckpointMetadata)V.checkpoint=N.restoredCheckpointMetadata;let M=typeof Q.workspaceRoot==="string"&&Q.workspaceRoot.trim()?Q.workspaceRoot.trim():typeof Q.cwd==="string"&&Q.cwd.trim()?Q.cwd.trim():N.sourceSession.workspaceRoot||N.sourceSession.cwd;return{source:typeof V.source==="string"?V.source:void 0,interactive:V.interactive!==!1,sessionMetadata:{...V,restoredFromSessionId:Z,restoredCheckpointRunCount:W},initialMessages:N.initialMessages,localRuntime:{modelCatalogDefaults:{loadLatestOnInit:!0,loadPrivateOnAuth:!0},configExtensions:F,...P.localRuntime},capabilities:{toolExecutors:P.toolExecutors,requestToolApproval:J},config:{...H??{},sessionId:D,providerId:H?.providerId??(typeof A.provider==="string"?A.provider:N.sourceSession.provider),modelId:H?.modelId??(typeof A.model==="string"?A.model:N.sourceSession.model),apiKey:H?.apiKey??(typeof A.apiKey==="string"?A.apiKey:""),cwd:H?.cwd??N.plan.cwd,workspaceRoot:H?.workspaceRoot??M,systemPrompt:H?.systemPrompt??(typeof Y.systemPrompt==="string"?Y.systemPrompt:""),mode:H?.mode??(Y.mode==="plan"||Y.mode==="yolo"?Y.mode:"act"),maxIterations:H?.maxIterations??(typeof Y.maxIterations==="number"?Y.maxIterations:void 0),enableTools:H?.enableTools??Y.enableTools!==!1,enableSpawnAgent:H?.enableSpawnAgent??Y.enableSpawn!==!1,enableAgentTeams:H?.enableAgentTeams??Y.enableTeams!==!1,checkpoint:H?.checkpoint??(Y.checkpointEnabled===!0?{enabled:!0}:void 0),teamName:H?.teamName??(typeof V.teamName==="string"?V.teamName:void 0)},toolPolicies:Q.toolPolicies&&typeof Q.toolPolicies==="object"&&!Array.isArray(Q.toolPolicies)?JSON.parse(JSON.stringify(Q.toolPolicies)):Y.autoApproveTools===!0?{"*":{autoApprove:!0}}:void 0}},startSession:(N)=>$.sessionHost.startSession(N),getStartedSessionId:(N)=>N.sessionId,readRestoredSession:(N)=>$.sessionHost.getSession(N)});if(!X)return m(f,{checkpoint:z.checkpoint});let _=z.startResult;if(!_)return b(f,"restore_failed","Checkpoint restore did not start a session");ff($,_.sessionId,B,"creator",{interactive:V.interactive!==!1});let[R,L]=await Promise.all([g0($,_.sessionId),v0($,_.sessionId)]);if(R)$.publish($.buildEvent("session.created",{session:R,...L?{snapshot:L}:{}},_.sessionId));return m(f,{session:R,...L?{snapshot:L}:{},messages:z.messages??[],checkpoint:z.checkpoint})}catch(H){if(H instanceof d0)return b(f,H.code,H.code==="session_not_found"?`Unknown session: ${Z}`:H.message);return b(f,"restore_failed",H instanceof Error?H.message:String(H))}}async function fY($,f){let J=T0(f);if(!J)return b(f,"invalid_session_attach","session.attach requires a session id");ff($,J,f.clientId?.trim()||"hub-client","participant");let Q=await g0($,J);if(Q)$.publish($.buildEvent("session.attached",{session:Q},J));return Q?m(f,{session:Q}):b(f,"session_not_found",`Unknown session: ${J}`)}async function JY($,f){let J=T0(f);if(!J)return b(f,"invalid_session_detach","session.detach requires a session id");let Q=f.clientId?.trim()||"hub-client",[Z]=await Promise.all([g0($,J)]),W=RT(Z?.metadata)??Q,j=$.sessionState.get(J);if(j){if(j.participants.delete(Q),j.createdByClientId===Q)j.createdByClientId=W;if(j.participants.size===0)$.sessionState.delete(J)}p$($,(Y)=>Y.sessionId===J&&Y.targetClientId===Q,`Capability owner client ${Q} detached before request was resolved.`);let[X,H]=await Promise.all([g0($,J),v0($,J)]);return $.publish($.buildEvent("session.detached",X?{session:X,...H?{snapshot:H}:{},clientId:Q}:{clientId:Q},J)),m(f)}async function QY($,f){let J=T0(f),Q=f.payload?.includeSnapshot===!0,[Z,W]=await Promise.all([g0($,J),Q?v0($,J):Promise.resolve(void 0)]);return Z?m(f,{session:Z,...W?{snapshot:W}:{}}):b(f,"session_not_found",`Unknown session: ${J}`)}async function ZY($,f){let J=T0(f);if(!J)return b(f,"invalid_session_id","session.messages requires a session id");if(!await g0($,J))return b(f,"session_not_found",`Unknown session: ${J}`);let Z=await $.sessionHost.readSessionMessages(J);return m(f,{sessionId:J,messages:Z})}async function WY($,f){let J=typeof f.payload?.limit==="number"?f.payload.limit:200,Z=(await $.sessionHost.listSessions(J)).map((W)=>e6(W,$.sessionState.get(W.sessionId)));return m(f,{sessions:Z})}async function jY($,f){let J=T0(f),Q=$f(f.payload?.metadata),Z=await $.sessionHost.updateSession(J,{metadata:Q}),[W,j]=await Promise.all([g0($,J),v0($,J)]);if(W)$.publish($.buildEvent("session.updated",{session:W,...j?{snapshot:j}:{}},J));return{version:f.version,requestId:f.requestId,ok:Z.updated,payload:{updated:Z.updated,session:W,...j?{snapshot:j}:{}}}}async function XY($,f){let J=T0(f),Q=await $.sessionHost.deleteSession(J);return $.sessionState.delete(J),m(f,{deleted:Q})}async function HY($,f){let J=T0(f),Q=$.sessionHost.pendingPrompts;if(!Q)return b(f,"pending_prompts_unavailable","Pending prompt service is not available.");let Z=await Q.list({sessionId:J});return m(f,{sessionId:J,prompts:Z})}async function YY($,f){let J=T0(f),Q=typeof f.payload?.promptId==="string"?f.payload.promptId.trim():"",Z=typeof f.payload?.prompt==="string"?f.payload.prompt:void 0,W=f.payload?.delivery==="queue"||f.payload?.delivery==="steer"?f.payload.delivery:void 0,j=$.sessionHost.pendingPrompts;if(!j)return b(f,"pending_prompts_unavailable","Pending prompt service is not available.");let X=await j.update({sessionId:J,promptId:Q,prompt:Z,delivery:W});return m(f,X)}async function VY($,f){let J=T0(f),Q=typeof f.payload?.promptId==="string"?f.payload.promptId.trim():"",Z=$.sessionHost.pendingPrompts;if(!Z)return b(f,"pending_prompts_unavailable","Pending prompt service is not available.");let W=await Z.delete({sessionId:J,promptId:Q});return m(f,W)}function AY($){switch($){case"schedule.create":return"schedule.created";case"schedule.update":case"schedule.enable":case"schedule.disable":return"schedule.updated";case"schedule.delete":return"schedule.deleted";case"schedule.trigger":return"schedule.triggered";default:return}}var OT=new Set(["skills","workflows","rules","tools","mcp"]);function R7($){return typeof $==="object"&&$!==null&&!Array.isArray($)}function y8($,f){let J=$[f];if(J===void 0)return;if(typeof J!=="string")throw Error(`settings payload '${f}' must be a string.`);return J}function zT($,f){let J=$[f];if(J===void 0)return;if(typeof J!=="boolean")throw Error(`settings payload '${f}' must be a boolean.`);return J}function BY($){if($===void 0)return{};if(!R7($))throw Error("settings.list payload must be an object.");return{cwd:y8($,"cwd"),workspaceRoot:y8($,"workspaceRoot"),availabilityContext:R7($.availabilityContext)?$.availabilityContext:void 0}}function _T($){if(!R7($))throw Error("settings.toggle payload must be an object.");let{type:f}=$;if(typeof f!=="string"||!OT.has(f))throw Error("settings.toggle payload 'type' must be one of: skills, workflows, rules, tools, mcp.");return{...BY($),type:f,id:y8($,"id"),path:y8($,"path"),name:y8($,"name"),enabled:zT($,"enabled")}}class Qf{options;clients=new Map;listeners=new Map;sessionState=new Map;pendingApprovals=new Map;pendingCapabilityRequests=new Map;suppressNextTerminalEventBySession=new Map;schedules;scheduleCommands;settings;cronService;sessionHost;hubId=LT("hub_");ctx;constructor($){this.options=$;if(this.sessionHost=$.sessionHost??new l$({sessionService:new m$(new x$),fetch:$.fetch,telemetry:$.telemetry}),this.ctx={clients:this.clients,sessionState:this.sessionState,pendingApprovals:this.pendingApprovals,pendingCapabilityRequests:this.pendingCapabilityRequests,suppressNextTerminalEventBySession:this.suppressNextTerminalEventBySession,telemetry:$.telemetry,sessionHost:this.sessionHost,publish:(f)=>this.publish(f),buildEvent:M1,requestCapability:(f,J,Q,Z,W)=>IH(this.ctx,f,J,Q,Z,W)},this.schedules=new i6({...$.scheduleOptions,runtimeHandlers:$.runtimeHandlers,eventPublisher:(f,J)=>{let Q=f==="schedule.execution.completed"?"schedule.execution_completed":f==="schedule.execution.failed"?"schedule.execution_failed":void 0;if(!Q)return;this.publish(M1(Q,J&&typeof J==="object"?J:void 0))}}),this.scheduleCommands=new l6(this.schedules),this.settings=$.settingsService??new a1,$.cronOptions)this.cronService=new t2({runtimeHandlers:$.runtimeHandlers,...$.cronOptions});this.sessionHost.subscribe((f)=>{iH(this.ctx,f).catch((J)=>{F7("session event handling failed",J),Jf(this.options.telemetry,{component:"core",operation:"hub.session_event_project",error:J,severity:"error",handled:!0,context:{eventType:f.type,sessionId:f.payload.sessionId}})})})}getCronService(){return this.cronService}getHubId(){return this.hubId}async start(){if(await this.schedules.start(),this.cronService)try{await this.cronService.start()}catch($){console.error("[hub] cron service start failed",$)}}async stop(){for(let $ of this.pendingApprovals.keys())G7(this.ctx,$,{approved:!1,reason:"Hub shutting down before approval was resolved."});if(p$(this.ctx,()=>!0,"Hub shutting down before capability request was resolved."),await this.sessionHost.dispose("hub_server_stop"),await this.schedules.dispose(),this.cronService)try{await this.cronService.dispose()}catch($){console.error("[hub] cron service stop failed",$)}}async handleCommand($){try{let f=await this.dispatchCommand($);return this.captureFailedReply($,f),f}catch(f){throw Jf(this.options.telemetry,{component:"core",operation:"hub.command",error:f,severity:"error",handled:!1,context:this.commandTelemetryContext($)}),f}}async dispatchCommand($){switch($.command){case"client.register":return vH(this.ctx,$);case"client.update":return uH(this.ctx,$);case"client.unregister":return cH(this.ctx,$,(f)=>{this.listeners.delete(f),this.detachClientFromSessions(f)});case"client.list":return dH(this.ctx,$);case"session.create":return await eH(this.ctx,$,(f)=>B7(this.ctx,f));case"session.restore":return await $Y(this.ctx,$,(f)=>B7(this.ctx,f));case"session.attach":return await fY(this.ctx,$);case"session.detach":return await JY(this.ctx,$);case"session.get":return await QY(this.ctx,$);case"session.messages":return await ZY(this.ctx,$);case"session.list":return await WY(this.ctx,$);case"session.update":return await jY(this.ctx,$);case"session.pending_prompts":return await HY(this.ctx,$);case"session.update_pending_prompt":return await YY(this.ctx,$);case"session.remove_pending_prompt":return await VY(this.ctx,$);case"session.delete":return await XY(this.ctx,$);case"session.hook":return await rH(this.ctx,$);case"run.start":case"session.send_input":return await lH(this.ctx,$);case"run.abort":return await pH(this.ctx,$);case"capability.request":return await mH(this.ctx,$);case"approval.respond":return await bH(this.ctx,$);case"capability.respond":return gH(this.ctx,$);case"capability.progress":return xH(this.ctx,$);case"ui.notify":return this.publish(M1("ui.notify",$.payload??{})),m($);case"ui.show_window":return this.publish(M1("ui.show_window",$.payload??{})),m($);case"settings.list":return await this.handleSettingsList($);case"settings.toggle":return await this.handleSettingsToggle($);case"settings.get":case"settings.patch":return{version:$.version,requestId:$.requestId,ok:!1,error:{code:"not_implemented",message:`${$.command} is not implemented yet.`}};default:{let f=await this.scheduleCommands.handleCommand($);if(f.ok){let J=AY($.command);if(J)this.publish(M1(J,f.payload))}return f}}}captureFailedReply($,f){if(f.ok||!f.error||!NT(f.error.code))return;Jf(this.options.telemetry,{component:"core",operation:"hub.command_reply",error:Error(f.error.message),severity:f.error.code==="session_not_found"?"warn":"error",handled:!0,context:{...this.commandTelemetryContext($),errorCode:f.error.code}})}commandTelemetryContext($){return{command:$.command,requestId:$.requestId,clientId:$.clientId,sessionId:typeof $.payload?.sessionId==="string"?$.payload.sessionId:$.sessionId}}async handleSettingsList($){try{let f=await this.settings.list(BY($.payload));return{version:$.version,requestId:$.requestId,ok:!0,payload:{snapshot:f}}}catch(f){return{version:$.version,requestId:$.requestId,ok:!1,error:{code:"settings_list_failed",message:f instanceof Error?f.message:String(f)}}}}async handleSettingsToggle($){try{let f=await this.settings.toggle(_T($.payload));return this.publish(M1("settings.changed",{types:f.changedTypes,snapshot:f.snapshot})),{version:$.version,requestId:$.requestId,ok:!0,payload:{snapshot:f.snapshot,changedTypes:f.changedTypes}}}catch(f){return{version:$.version,requestId:$.requestId,ok:!1,error:{code:"settings_toggle_failed",message:f instanceof Error?f.message:String(f)}}}}subscribe($,f,J){let Q=this.listeners.get($)??new Set,Z={sessionId:J?.sessionId,listener:f};return Q.add(Z),this.listeners.set($,Q),()=>{let W=this.listeners.get($);if(!W)return;if(W.delete(Z),W.size===0)this.listeners.delete($)}}detachClientFromSessions($){for(let[f,J]of this.sessionState.entries())if(J.participants.delete($),J.participants.size===0)this.sessionState.delete(f);p$(this.ctx,(f)=>f.targetClientId===$,`Capability owner client ${$} disconnected before request was resolved.`)}publish($){for(let f of this.listeners.values())for(let J of f){if(J.sessionId&&J.sessionId!==$.sessionId)continue;try{J.listener($)}catch(Q){F7(`listener threw while publishing ${$.event}`,Q),Jf(this.options.telemetry,{component:"core",operation:"hub.publish",error:Q,severity:"warn",handled:!0,context:{event:$.event,sessionId:$.sessionId}})}}}}function NT($){return $==="session_not_found"||$==="session_messages_not_found"||$==="hub_command_timeout"||$.endsWith("_failed")}import{timingSafeEqual as yT}from"node:crypto";import wT from"node:http";import ST from"node:net";import{URL as FY}from"node:url";import{WebSocketServer as hT}from"ws";import{captureSdkError as GY,HUB_COMMAND_SLOW_LOG_MS as TT,resolveHubCommandTimeoutMs as MT,safeJsonParse as qT}from"@cline/shared";function L7($){return{command:$.envelope.command,requestId:$.envelope.requestId,clientId:$.envelope.clientId,sessionId:$.envelope.sessionId}}function KY($,f,J){return{version:$.envelope.version,requestId:$.envelope.requestId,ok:!1,error:{code:f,message:J}}}class O7{transport;telemetry;constructor($,f){this.transport=$;this.telemetry=f}attach($){let f=new Map,J=new Set,Q=!1,Z=(H)=>{try{$.send(JSON.stringify(H))}catch(Y){console.error(`[hub] failed to send websocket frame: ${Y instanceof Error?Y.stack||Y.message:String(Y)}`)}},W=(H)=>{Z({kind:"event",envelope:H})},j=async(H)=>{try{let Y=JSON.parse(H.data);switch(Y.kind){case"command":{let V=performance.now(),A=!1,B=L7(Y);I("info","command.start",B);let G=setTimeout(()=>{if(A)return;I("warn","command.slow",{...B,elapsedMs:Math.round(performance.now()-V)})},TT),K=this.transport.command(Y.envelope);K.then((_)=>{if(!A)return;I(_.ok?"warn":"error","command.late_end",{...B,elapsedMs:Math.round(performance.now()-V),ok:_.ok,errorCode:_.error?.code,errorMessage:_.error?.message})},(_)=>{if(!A)return;I("error","command.late_error",{...B,elapsedMs:Math.round(performance.now()-V),error:_})});let D=!1,F,P,U=MT(Y.envelope.command,Y.envelope.timeoutMs);try{P=U===null?await K:await Promise.race([K,new Promise((_)=>{F=setTimeout(()=>{D=!0,GY(this.telemetry,{component:"core",operation:"hub.command_timeout",error:Error(`Hub command ${Y.envelope.command} did not complete within ${U}ms.`),severity:"error",handled:!0,context:{...B,timeoutMs:U}}),_(KY(Y,"hub_command_timeout",`Hub command ${Y.envelope.command} did not complete within ${U}ms. Check hub-daemon.log for command.start/command.slow logs with requestId ${Y.envelope.requestId}.`))},U)})])}catch(_){if(clearTimeout(G),F)clearTimeout(F);throw _}if(A=D,clearTimeout(G),F)clearTimeout(F);let z=Math.round(performance.now()-V);if(D)I("error","command.timeout",{...B,durationMs:z,timeoutMs:U});else I(P.ok?"info":"warn","command.end",{...B,durationMs:z,ok:P.ok,errorCode:P.error?.code,errorMessage:P.error?.message});if(Y.envelope.command==="client.register"&&P.ok){let R=(Y.envelope.payload??{}).clientId?.trim()||Y.envelope.clientId?.trim();if(R)J.add(R)}else if(Y.envelope.command==="client.unregister"&&P.ok){let _=Y.envelope.clientId?.trim();if(_)J.delete(_)}Z({kind:"reply",envelope:P});break}case"stream.subscribe":{let V=`${Y.clientId}:${Y.sessionId??"*"}`;if(f.has(V))break;let A=await this.transport.subscribe(Y.clientId,W,{sessionId:Y.sessionId});f.set(V,A);break}case"stream.unsubscribe":{let V=`${Y.clientId}:${Y.sessionId??"*"}`;f.get(V)?.(),f.delete(V);break}case"reply":case"event":break}}catch(Y){let V=typeof H.data==="string"?qT(H.data):void 0;if(!V||V.kind!=="command"){I("error","rejected malformed websocket frame",{error:Y});return}I("error","command.error",{...L7(V),error:Y}),GY(this.telemetry,{component:"core",operation:"hub.websocket_command",error:Y,severity:"error",handled:!0,context:L7(V)}),Z({kind:"reply",envelope:KY(V,"command_failed",Y instanceof Error?Y.message:"Unknown hub error")})}},X=()=>{if(Q)return;Q=!0;for(let H of f.values())H();f.clear();for(let H of J)this.transport.command({version:"v1",command:"client.unregister",clientId:H});J.clear(),$.removeEventListener("message",j),$.removeEventListener("close",X)};return $.addEventListener("message",j),$.addEventListener("close",X),X}}class z7{transport;constructor($){this.transport=$}command($){return this.transport.handleCommand($)}subscribe($,f,J){return this.transport.subscribe($,f,J)}}function CT($){if(typeof $==="string")return $;if($ instanceof Uint8Array)return Buffer.from($).toString();if($ instanceof ArrayBuffer)return Buffer.from($).toString();if(Array.isArray($))return Buffer.concat($.map((f)=>Buffer.from(f))).toString();return String($)}function ET($){return{send(f){$.send(f)},addEventListener(f,J){if(f==="message"){$.on("message",(Q)=>{J({data:CT(Q)})});return}$.on("close",J)},removeEventListener(){}}}function bT($){try{$.write(`HTTP/1.1 400 Bad Request\r
|
|
705
|
+
${A}`:X.instructions}})}})}}function hM($,f,J,W){let Z=J.map((Q)=>[Q.executor,async(...j)=>{let H=j.at(-1),X=j.slice(0,-1);return(await W($,Q.capabilityName,{executor:Q.executor,args:X,context:mY(H)},f))?.result}]);return Z.length>0?Object.fromEntries(Z):void 0}function CM($,f,J,W){if(J.length===0)return;return J.map((Z)=>({name:Z.name,description:Z.description,inputSchema:Z.inputSchema,lifecycle:Z.lifecycle,async execute(Q,j){return(await W($,Z.capabilityName,{toolName:Z.name,input:Q,context:mY(j)},f,j.emitUpdate?(X)=>{j.emitUpdate?.(MM(X))}:void 0))?.result}}))}function EM($,f,J,W){let Z=new Map(J.map((j)=>[j.name,j])),Q={};for(let j of TM){let H=Z.get(j);if(!H)continue;Q[j]=async(X)=>{return(await W($,H.capabilityName,{context:X},f))?.control}}return Object.keys(Q).length>0?Q:void 0}function rZ($){let f=$.contributions.filter((X)=>X.kind==="toolExecutor"),J=$.contributions.filter((X)=>X.kind==="tool"),W=$.contributions.filter((X)=>X.kind==="hook"),Z=$.contributions.find((X)=>X.kind==="compaction"),Q=$.contributions.find((X)=>X.kind==="checkpoint"),j=$.contributions.find((X)=>X.kind==="mistakeLimit"),H=$.contributions.find((X)=>X.kind==="userInstructionService");return{hasClientContributions:$.contributions.length>0,toolExecutors:hM($.sessionId,$.targetClientId,f,$.requestCapability),localRuntime:{...W.length>0?{hooks:EM($.sessionId,$.targetClientId,W,$.requestCapability)}:{},...J.length>0?{extraTools:CM($.sessionId,$.targetClientId,J,$.requestCapability)}:{},...Z?{compaction:{...$.sessionConfig?.compaction??{},...Z.config,compact:async(X)=>{return(await $.requestCapability($.sessionId,Z.capabilityName,{context:X},$.targetClientId))?.result}}}:{},...Q?{checkpoint:{...$.sessionConfig?.checkpoint??{},...Q.config,createCheckpoint:async(X)=>{return(await $.requestCapability($.sessionId,Q.capabilityName,{context:X},$.targetClientId))?.result}}}:{},...j?{onConsecutiveMistakeLimitReached:async(X)=>{return(await $.requestCapability($.sessionId,j.capabilityName,{context:X},$.targetClientId))?.result}}:{},...H?{userInstructionService:SM($.sessionId,$.targetClientId,H,$.requestCapability)}:{}}}}var uY="hubCapabilityOwnerClientId";function cY($,f){$[uY]=f}function bM($){let f=$?.[uY];return typeof f==="string"&&f.trim()?f.trim():void 0}async function dY($,f,J){let W=performance.now(),Z={command:f.command,requestId:f.requestId,clientId:f.clientId,sessionId:f.sessionId};I("info","session.create.begin",Z);let Q=f.payload&&typeof f.payload==="object"?f.payload:{},j=Q.metadata&&typeof Q.metadata==="object"?JSON.parse(JSON.stringify(Q.metadata)):{},H=Q.sessionConfig&&typeof Q.sessionConfig==="object"?JSON.parse(JSON.stringify(Q.sessionConfig)):void 0,X=Q.runtimeOptions&&typeof Q.runtimeOptions==="object"?Q.runtimeOptions:{};if(typeof H?.mode==="string")j.mode=H.mode;else if(typeof X.mode==="string")j.mode=X.mode;if(typeof H?.systemPrompt==="string")j.systemPrompt=H.systemPrompt;else if(typeof X.systemPrompt==="string")j.systemPrompt=X.systemPrompt;if(H?.checkpoint?.enabled===!0)j.checkpointEnabled=!0;else if(X.checkpointEnabled===!0)j.checkpointEnabled=!0;let Y=Q.modelSelection&&typeof Q.modelSelection==="object"?Q.modelSelection:{},A=typeof Q.workspaceRoot==="string"&&Q.workspaceRoot.trim()?Q.workspaceRoot.trim():typeof Q.cwd==="string"&&Q.cwd.trim()?Q.cwd.trim():"";if(!A)return I("warn","session.create.invalid",{...Z,reason:"missing_workspace_root"}),b(f,"invalid_session_create","session.create requires workspaceRoot or cwd");let V=f.clientId?.trim()||"hub-client",B=pZ(X.clientContributions);if(I("info","session.create.contributions_parsed",{...Z,clientId:V,workspaceRoot:A,cwd:typeof Q.cwd==="string"?Q.cwd:void 0,contributionCount:B.length}),B.length>0)cY(j,V);let G=(typeof H?.sessionId==="string"?H.sessionId.trim():"")||gY(),R=vY(X.configExtensions);I("info","session.create.runtime_build.begin",{...Z,sessionId:G,configExtensionCount:R?.length??0});let P=rZ({sessionId:G,targetClientId:V,contributions:B,sessionConfig:H,requestCapability:$.requestCapability});I("info","session.create.start_session.begin",{...Z,sessionId:G,provider:H?.providerId??(typeof Y.provider==="string"?Y.provider:typeof j.provider==="string"?j.provider:"hub"),model:H?.modelId??(typeof Y.model==="string"?Y.model:typeof j.model==="string"?j.model:"hub")});let F=await $.sessionHost.startSession({source:typeof j.source==="string"?j.source:void 0,interactive:j.interactive!==!1,sessionMetadata:Object.keys(j).length>0?j:void 0,initialMessages:Array.isArray(Q.initialMessages)?Q.initialMessages:void 0,localRuntime:{modelCatalogDefaults:{loadLatestOnInit:!0,loadPrivateOnAuth:!0},configExtensions:R,...P.localRuntime},capabilities:{toolExecutors:P.toolExecutors,requestToolApproval:J},config:{...H??{},sessionId:G,providerId:H?.providerId??(typeof Y.provider==="string"?Y.provider:typeof j.provider==="string"?j.provider:"hub"),modelId:H?.modelId??(typeof Y.model==="string"?Y.model:typeof j.model==="string"?j.model:"hub"),apiKey:H?.apiKey??(typeof Y.apiKey==="string"?Y.apiKey:void 0),cwd:H?.cwd??(typeof Q.cwd==="string"&&Q.cwd.trim()?Q.cwd.trim():A),workspaceRoot:H?.workspaceRoot??A,systemPrompt:H?.systemPrompt??(typeof X.systemPrompt==="string"?X.systemPrompt:""),mode:H?.mode??(X.mode==="plan"||X.mode==="yolo"?X.mode:"act"),maxIterations:H?.maxIterations??(typeof X.maxIterations==="number"?X.maxIterations:void 0),enableTools:H?.enableTools??X.enableTools!==!1,enableSpawnAgent:H?.enableSpawnAgent??X.enableSpawn!==!1,enableAgentTeams:H?.enableAgentTeams??X.enableTeams!==!1,checkpoint:H?.checkpoint??(X.checkpointEnabled===!0?{enabled:!0}:void 0),teamName:H?.teamName??(typeof j.teamName==="string"?j.teamName:void 0)},toolPolicies:Q.toolPolicies&&typeof Q.toolPolicies==="object"&&!Array.isArray(Q.toolPolicies)?JSON.parse(JSON.stringify(Q.toolPolicies)):X.autoApproveTools===!0?{"*":{autoApprove:!0}}:void 0});I("info","session.create.start_session.end",{...Z,sessionId:F.sessionId,elapsedMs:Math.round(performance.now()-W),hasImmediateResult:!!F.result}),N4($,F.sessionId,V,"creator",{interactive:j.interactive!==!1}),I("info","session.create.read_records.begin",{...Z,sessionId:F.sessionId});let[U,_]=await Promise.all([x0($,F.sessionId),m0($,F.sessionId)]);if(I("info","session.create.read_records.end",{...Z,sessionId:F.sessionId,hasSession:!!U,hasSnapshot:!!_,elapsedMs:Math.round(performance.now()-W)}),U)$.publish($.buildEvent("session.created",{session:U,..._?{snapshot:_}:{}},F.sessionId));return I("info","session.create.reply",{...Z,sessionId:F.sessionId,elapsedMs:Math.round(performance.now()-W)}),m(f,{session:U,..._?{snapshot:_}:{}})}async function lY($,f,J){let W=f.payload&&typeof f.payload==="object"?f.payload:{},Z=typeof W.sessionId==="string"?W.sessionId.trim():f.sessionId?.trim()||"",Q=W.checkpointRunCount;if(!Z)return b(f,"invalid_restore","session.restore requires a session id");let j=W.restore&&typeof W.restore==="object"?W.restore:{},H=j.messages!==!1;if(typeof Q!=="number")return b(f,"invalid_restore","checkpointRunCount must be a positive integer");try{let X=W.sessionConfig&&typeof W.sessionConfig==="object"?JSON.parse(JSON.stringify(W.sessionConfig)):void 0;if(H&&!X)return b(f,"invalid_restore","sessionConfig is required when restore.messages is true");let Y=W.runtimeOptions&&typeof W.runtimeOptions==="object"?W.runtimeOptions:{},A=W.metadata&&typeof W.metadata==="object"?JSON.parse(JSON.stringify(W.metadata)):{};if(typeof X?.mode==="string")A.mode=X.mode;else if(typeof Y.mode==="string")A.mode=Y.mode;if(typeof X?.systemPrompt==="string")A.systemPrompt=X.systemPrompt;else if(typeof Y.systemPrompt==="string")A.systemPrompt=Y.systemPrompt;if(X?.checkpoint?.enabled===!0)A.checkpointEnabled=!0;else if(Y.checkpointEnabled===!0)A.checkpointEnabled=!0;let V=W.modelSelection&&typeof W.modelSelection==="object"?W.modelSelection:{},B=f.clientId?.trim()||"hub-client",K=pZ(Y.clientContributions);if(K.length>0)cY(A,B);let R=(typeof X?.sessionId==="string"?X.sessionId.trim():"")||gY(),P=vY(Y.configExtensions),F=rZ({sessionId:R,targetClientId:B,contributions:K,sessionConfig:X,requestCapability:$.requestCapability}),_=await new Uf().restoreCheckpoint({sessionId:Z,checkpointRunCount:Q,restore:{messages:j.messages,workspace:j.workspace,omitCheckpointMessageFromSession:j.omitCheckpointMessageFromSession===!0},start:X,cwd:typeof X?.cwd==="string"&&X.cwd.trim()||typeof X?.workspaceRoot==="string"&&X.workspaceRoot.trim()||void 0,getSession:(T)=>$.sessionHost.getSession(T),readMessages:(T)=>$.sessionHost.readSessionMessages(T),buildStartInput:(T)=>{if(T.restoredCheckpointMetadata)A.checkpoint=T.restoredCheckpointMetadata;let M=typeof W.workspaceRoot==="string"&&W.workspaceRoot.trim()?W.workspaceRoot.trim():typeof W.cwd==="string"&&W.cwd.trim()?W.cwd.trim():T.sourceSession.workspaceRoot||T.sourceSession.cwd;return{source:typeof A.source==="string"?A.source:void 0,interactive:A.interactive!==!1,sessionMetadata:{...A,restoredFromSessionId:Z,restoredCheckpointRunCount:Q},initialMessages:T.initialMessages,localRuntime:{modelCatalogDefaults:{loadLatestOnInit:!0,loadPrivateOnAuth:!0},configExtensions:P,...F.localRuntime},capabilities:{toolExecutors:F.toolExecutors,requestToolApproval:J},config:{...X??{},sessionId:R,providerId:X?.providerId??(typeof V.provider==="string"?V.provider:T.sourceSession.provider),modelId:X?.modelId??(typeof V.model==="string"?V.model:T.sourceSession.model),apiKey:X?.apiKey??(typeof V.apiKey==="string"?V.apiKey:""),cwd:X?.cwd??T.plan.cwd,workspaceRoot:X?.workspaceRoot??M,systemPrompt:X?.systemPrompt??(typeof Y.systemPrompt==="string"?Y.systemPrompt:""),mode:X?.mode??(Y.mode==="plan"||Y.mode==="yolo"?Y.mode:"act"),maxIterations:X?.maxIterations??(typeof Y.maxIterations==="number"?Y.maxIterations:void 0),enableTools:X?.enableTools??Y.enableTools!==!1,enableSpawnAgent:X?.enableSpawnAgent??Y.enableSpawn!==!1,enableAgentTeams:X?.enableAgentTeams??Y.enableTeams!==!1,checkpoint:X?.checkpoint??(Y.checkpointEnabled===!0?{enabled:!0}:void 0),teamName:X?.teamName??(typeof A.teamName==="string"?A.teamName:void 0)},toolPolicies:W.toolPolicies&&typeof W.toolPolicies==="object"&&!Array.isArray(W.toolPolicies)?JSON.parse(JSON.stringify(W.toolPolicies)):Y.autoApproveTools===!0?{"*":{autoApprove:!0}}:void 0}},startSession:(T)=>$.sessionHost.startSession(T),getStartedSessionId:(T)=>T.sessionId,readRestoredSession:(T)=>$.sessionHost.getSession(T)});if(!H)return m(f,{checkpoint:_.checkpoint});let z=_.startResult;if(!z)return b(f,"restore_failed","Checkpoint restore did not start a session");N4($,z.sessionId,B,"creator",{interactive:A.interactive!==!1});let[D,O]=await Promise.all([x0($,z.sessionId),m0($,z.sessionId)]);if(D)$.publish($.buildEvent("session.created",{session:D,...O?{snapshot:O}:{}},z.sessionId));return m(f,{session:D,...O?{snapshot:O}:{},messages:_.messages??[],checkpoint:_.checkpoint})}catch(X){if(X instanceof p0)return b(f,X.code,X.code==="session_not_found"?`Unknown session: ${Z}`:X.message);return b(f,"restore_failed",X instanceof Error?X.message:String(X))}}async function pY($,f){let J=T0(f);if(!J)return b(f,"invalid_session_attach","session.attach requires a session id");N4($,J,f.clientId?.trim()||"hub-client","participant");let W=await x0($,J);if(W)$.publish($.buildEvent("session.attached",{session:W},J));return W?m(f,{session:W}):b(f,"session_not_found",`Unknown session: ${J}`)}async function rY($,f){let J=T0(f);if(!J)return b(f,"invalid_session_detach","session.detach requires a session id");let W=f.clientId?.trim()||"hub-client",[Z]=await Promise.all([x0($,J)]),Q=bM(Z?.metadata)??W,j=$.sessionState.get(J);if(j){if(j.participants.delete(W),j.createdByClientId===W)j.createdByClientId=Q;if(j.participants.size===0)$.sessionState.delete(J)}t$($,(Y)=>Y.sessionId===J&&Y.targetClientId===W,`Capability owner client ${W} detached before request was resolved.`);let[H,X]=await Promise.all([x0($,J),m0($,J)]);return $.publish($.buildEvent("session.detached",H?{session:H,...X?{snapshot:X}:{},clientId:W}:{clientId:W},J)),m(f)}async function iY($,f){let J=T0(f),W=f.payload?.includeSnapshot===!0,[Z,Q]=await Promise.all([x0($,J),W?m0($,J):Promise.resolve(void 0)]);return Z?m(f,{session:Z,...Q?{snapshot:Q}:{}}):b(f,"session_not_found",`Unknown session: ${J}`)}async function nY($,f){let J=T0(f);if(!J)return b(f,"invalid_session_id","session.messages requires a session id");if(!await x0($,J))return b(f,"session_not_found",`Unknown session: ${J}`);let Z=await $.sessionHost.readSessionMessages(J);return m(f,{sessionId:J,messages:Z})}async function aY($,f){let J=typeof f.payload?.limit==="number"?f.payload.limit:200,Z=(await $.sessionHost.listSessions(J)).map((Q)=>z4(Q,$.sessionState.get(Q.sessionId)));return m(f,{sessions:Z})}async function tY($,f){let J=T0(f),W=T4(f.payload?.metadata),Z=await $.sessionHost.updateSession(J,{metadata:W}),[Q,j]=await Promise.all([x0($,J),m0($,J)]);if(Q)$.publish($.buildEvent("session.updated",{session:Q,...j?{snapshot:j}:{}},J));return{version:f.version,requestId:f.requestId,ok:Z.updated,payload:{updated:Z.updated,session:Q,...j?{snapshot:j}:{}}}}async function sY($,f){let J=T0(f),W=await $.sessionHost.deleteSession(J);return $.sessionState.delete(J),m(f,{deleted:W})}async function oY($,f){let J=T0(f),W=$.sessionHost.pendingPrompts;if(!W)return b(f,"pending_prompts_unavailable","Pending prompt service is not available.");let Z=await W.list({sessionId:J});return m(f,{sessionId:J,prompts:Z})}async function eY($,f){let J=T0(f),W=typeof f.payload?.promptId==="string"?f.payload.promptId.trim():"",Z=typeof f.payload?.prompt==="string"?f.payload.prompt:void 0,Q=f.payload?.delivery==="queue"||f.payload?.delivery==="steer"?f.payload.delivery:void 0,j=$.sessionHost.pendingPrompts;if(!j)return b(f,"pending_prompts_unavailable","Pending prompt service is not available.");let H=await j.update({sessionId:J,promptId:W,prompt:Z,delivery:Q});return m(f,H)}async function $A($,f){let J=T0(f),W=typeof f.payload?.promptId==="string"?f.payload.promptId.trim():"",Z=$.sessionHost.pendingPrompts;if(!Z)return b(f,"pending_prompts_unavailable","Pending prompt service is not available.");let Q=await Z.delete({sessionId:J,promptId:W});return m(f,Q)}function fA($){switch($){case"schedule.create":return"schedule.created";case"schedule.update":case"schedule.enable":case"schedule.disable":return"schedule.updated";case"schedule.delete":return"schedule.deleted";case"schedule.trigger":return"schedule.triggered";default:return}}var IM=new Set(["skills","workflows","rules","tools","mcp"]);function iZ($){return typeof $==="object"&&$!==null&&!Array.isArray($)}function r2($,f){let J=$[f];if(J===void 0)return;if(typeof J!=="string")throw Error(`settings payload '${f}' must be a string.`);return J}function xM($,f){let J=$[f];if(J===void 0)return;if(typeof J!=="boolean")throw Error(`settings payload '${f}' must be a boolean.`);return J}function JA($){if($===void 0)return{};if(!iZ($))throw Error("settings.list payload must be an object.");return{cwd:r2($,"cwd"),workspaceRoot:r2($,"workspaceRoot"),availabilityContext:iZ($.availabilityContext)?$.availabilityContext:void 0}}function mM($){if(!iZ($))throw Error("settings.toggle payload must be an object.");let{type:f}=$;if(typeof f!=="string"||!IM.has(f))throw Error("settings.toggle payload 'type' must be one of: skills, workflows, rules, tools, mcp.");return{...JA($),type:f,id:r2($,"id"),path:r2($,"path"),name:r2($,"name"),enabled:xM($,"enabled")}}class y4{options;clients=new Map;listeners=new Map;sessionState=new Map;pendingApprovals=new Map;pendingCapabilityRequests=new Map;suppressNextTerminalEventBySession=new Map;schedules;scheduleCommands;settings;cronService;sessionHost;hubId=kM("hub_");ctx;constructor($){this.options=$;if(this.sessionHost=$.sessionHost??new a$({sessionService:new d$(new c$),fetch:$.fetch,telemetry:$.telemetry}),this.ctx={clients:this.clients,sessionState:this.sessionState,pendingApprovals:this.pendingApprovals,pendingCapabilityRequests:this.pendingCapabilityRequests,suppressNextTerminalEventBySession:this.suppressNextTerminalEventBySession,telemetry:$.telemetry,sessionHost:this.sessionHost,publish:(f)=>this.publish(f),buildEvent:I1,requestCapability:(f,J,W,Z,Q)=>MY(this.ctx,f,J,W,Z,Q)},this.schedules=new U4({...$.scheduleOptions,runtimeHandlers:$.runtimeHandlers,eventPublisher:(f,J)=>{let W=f==="schedule.execution.completed"?"schedule.execution_completed":f==="schedule.execution.failed"?"schedule.execution_failed":void 0;if(!W)return;this.publish(I1(W,J&&typeof J==="object"?J:void 0))}}),this.scheduleCommands=new G4(this.schedules),this.settings=$.settingsService??new jf,$.cronOptions)this.cronService=new K2({runtimeHandlers:$.runtimeHandlers,...$.cronOptions});this.sessionHost.subscribe((f)=>{xY(this.ctx,f).catch((J)=>{dZ("session event handling failed",J),M4(this.options.telemetry,{component:"core",operation:"hub.session_event_project",error:J,severity:"error",handled:!0,context:{eventType:f.type,sessionId:f.payload.sessionId}})})})}getCronService(){return this.cronService}getHubId(){return this.hubId}async start(){if(await this.schedules.start(),this.cronService)try{await this.cronService.start()}catch($){console.error("[hub] cron service start failed",$)}}async stop(){for(let $ of this.pendingApprovals.keys())uZ(this.ctx,$,{approved:!1,reason:"Hub shutting down before approval was resolved."});if(t$(this.ctx,()=>!0,"Hub shutting down before capability request was resolved."),await this.sessionHost.dispose("hub_server_stop"),await this.schedules.dispose(),this.cronService)try{await this.cronService.dispose()}catch($){console.error("[hub] cron service stop failed",$)}}async handleCommand($){try{let f=await this.dispatchCommand($);return this.captureFailedReply($,f),f}catch(f){throw M4(this.options.telemetry,{component:"core",operation:"hub.command",error:f,severity:"error",handled:!1,context:this.commandTelemetryContext($)}),f}}async dispatchCommand($){switch($.command){case"client.register":return SY(this.ctx,$);case"client.update":return hY(this.ctx,$);case"client.unregister":return CY(this.ctx,$,(f)=>{this.listeners.delete(f),this.detachClientFromSessions(f)});case"client.list":return EY(this.ctx,$);case"session.create":return await dY(this.ctx,$,(f)=>vZ(this.ctx,f));case"session.restore":return await lY(this.ctx,$,(f)=>vZ(this.ctx,f));case"session.attach":return await pY(this.ctx,$);case"session.detach":return await rY(this.ctx,$);case"session.get":return await iY(this.ctx,$);case"session.messages":return await nY(this.ctx,$);case"session.list":return await aY(this.ctx,$);case"session.update":return await tY(this.ctx,$);case"session.pending_prompts":return await oY(this.ctx,$);case"session.update_pending_prompt":return await eY(this.ctx,$);case"session.remove_pending_prompt":return await $A(this.ctx,$);case"session.delete":return await sY(this.ctx,$);case"session.hook":return await IY(this.ctx,$);case"run.start":case"session.send_input":return await bY(this.ctx,$);case"run.abort":return await kY(this.ctx,$);case"capability.request":return await qY(this.ctx,$);case"approval.respond":return await TY(this.ctx,$);case"capability.respond":return wY(this.ctx,$);case"capability.progress":return yY(this.ctx,$);case"ui.notify":return this.publish(I1("ui.notify",$.payload??{})),m($);case"ui.show_window":return this.publish(I1("ui.show_window",$.payload??{})),m($);case"settings.list":return await this.handleSettingsList($);case"settings.toggle":return await this.handleSettingsToggle($);case"settings.get":case"settings.patch":return{version:$.version,requestId:$.requestId,ok:!1,error:{code:"not_implemented",message:`${$.command} is not implemented yet.`}};default:{let f=await this.scheduleCommands.handleCommand($);if(f.ok){let J=fA($.command);if(J)this.publish(I1(J,f.payload))}return f}}}captureFailedReply($,f){if(f.ok||!f.error||!gM(f.error.code))return;M4(this.options.telemetry,{component:"core",operation:"hub.command_reply",error:Error(f.error.message),severity:f.error.code==="session_not_found"?"warn":"error",handled:!0,context:{...this.commandTelemetryContext($),errorCode:f.error.code}})}commandTelemetryContext($){return{command:$.command,requestId:$.requestId,clientId:$.clientId,sessionId:typeof $.payload?.sessionId==="string"?$.payload.sessionId:$.sessionId}}async handleSettingsList($){try{let f=await this.settings.list(JA($.payload));return{version:$.version,requestId:$.requestId,ok:!0,payload:{snapshot:f}}}catch(f){return{version:$.version,requestId:$.requestId,ok:!1,error:{code:"settings_list_failed",message:f instanceof Error?f.message:String(f)}}}}async handleSettingsToggle($){try{let f=await this.settings.toggle(mM($.payload));return this.publish(I1("settings.changed",{types:f.changedTypes,snapshot:f.snapshot})),{version:$.version,requestId:$.requestId,ok:!0,payload:{snapshot:f.snapshot,changedTypes:f.changedTypes}}}catch(f){return{version:$.version,requestId:$.requestId,ok:!1,error:{code:"settings_toggle_failed",message:f instanceof Error?f.message:String(f)}}}}subscribe($,f,J){let W=this.listeners.get($)??new Set,Z={sessionId:J?.sessionId,listener:f};return W.add(Z),this.listeners.set($,W),()=>{let Q=this.listeners.get($);if(!Q)return;if(Q.delete(Z),Q.size===0)this.listeners.delete($)}}detachClientFromSessions($){for(let[f,J]of this.sessionState.entries())if(J.participants.delete($),J.participants.size===0)this.sessionState.delete(f);t$(this.ctx,(f)=>f.targetClientId===$,`Capability owner client ${$} disconnected before request was resolved.`)}publish($){for(let f of this.listeners.values())for(let J of f){if(J.sessionId&&J.sessionId!==$.sessionId)continue;try{J.listener($)}catch(W){dZ(`listener threw while publishing ${$.event}`,W),M4(this.options.telemetry,{component:"core",operation:"hub.publish",error:W,severity:"warn",handled:!0,context:{event:$.event,sessionId:$.sessionId}})}}}}function gM($){return $==="session_not_found"||$==="session_messages_not_found"||$==="hub_command_timeout"||$.endsWith("_failed")}import{timingSafeEqual as dM}from"node:crypto";import lM from"node:http";import pM from"node:net";import{URL as QA}from"node:url";import{WebSocketServer as rM}from"ws";import{captureSdkError as WA,HUB_COMMAND_SLOW_LOG_MS as vM,resolveHubCommandTimeoutMs as uM,safeJsonParse as cM}from"@cline/shared";function nZ($){return{command:$.envelope.command,requestId:$.envelope.requestId,clientId:$.envelope.clientId,sessionId:$.envelope.sessionId}}function ZA($,f,J){return{version:$.envelope.version,requestId:$.envelope.requestId,ok:!1,error:{code:f,message:J}}}class aZ{transport;telemetry;constructor($,f){this.transport=$;this.telemetry=f}attach($){let f=new Map,J=new Set,W=!1,Z=(X)=>{try{$.send(JSON.stringify(X))}catch(Y){console.error(`[hub] failed to send websocket frame: ${Y instanceof Error?Y.stack||Y.message:String(Y)}`)}},Q=(X)=>{Z({kind:"event",envelope:X})},j=async(X)=>{try{let Y=JSON.parse(X.data);switch(Y.kind){case"command":{let A=performance.now(),V=!1,B=nZ(Y);I("info","command.start",B);let K=setTimeout(()=>{if(V)return;I("warn","command.slow",{...B,elapsedMs:Math.round(performance.now()-A)})},vM),G=this.transport.command(Y.envelope);G.then((z)=>{if(!V)return;I(z.ok?"warn":"error","command.late_end",{...B,elapsedMs:Math.round(performance.now()-A),ok:z.ok,errorCode:z.error?.code,errorMessage:z.error?.message})},(z)=>{if(!V)return;I("error","command.late_error",{...B,elapsedMs:Math.round(performance.now()-A),error:z})});let R=!1,P,F,U=uM(Y.envelope.command,Y.envelope.timeoutMs);try{F=U===null?await G:await Promise.race([G,new Promise((z)=>{P=setTimeout(()=>{R=!0,WA(this.telemetry,{component:"core",operation:"hub.command_timeout",error:Error(`Hub command ${Y.envelope.command} did not complete within ${U}ms.`),severity:"error",handled:!0,context:{...B,timeoutMs:U}}),z(ZA(Y,"hub_command_timeout",`Hub command ${Y.envelope.command} did not complete within ${U}ms. Check hub-daemon.log for command.start/command.slow logs with requestId ${Y.envelope.requestId}.`))},U)})])}catch(z){if(clearTimeout(K),P)clearTimeout(P);throw z}if(V=R,clearTimeout(K),P)clearTimeout(P);let _=Math.round(performance.now()-A);if(R)I("error","command.timeout",{...B,durationMs:_,timeoutMs:U});else I(F.ok?"info":"warn","command.end",{...B,durationMs:_,ok:F.ok,errorCode:F.error?.code,errorMessage:F.error?.message});if(Y.envelope.command==="client.register"&&F.ok){let D=(Y.envelope.payload??{}).clientId?.trim()||Y.envelope.clientId?.trim();if(D)J.add(D)}else if(Y.envelope.command==="client.unregister"&&F.ok){let z=Y.envelope.clientId?.trim();if(z)J.delete(z)}Z({kind:"reply",envelope:F});break}case"stream.subscribe":{let A=`${Y.clientId}:${Y.sessionId??"*"}`;if(f.has(A))break;let V=await this.transport.subscribe(Y.clientId,Q,{sessionId:Y.sessionId});f.set(A,V);break}case"stream.unsubscribe":{let A=`${Y.clientId}:${Y.sessionId??"*"}`;f.get(A)?.(),f.delete(A);break}case"reply":case"event":break}}catch(Y){let A=typeof X.data==="string"?cM(X.data):void 0;if(!A||A.kind!=="command"){I("error","rejected malformed websocket frame",{error:Y});return}I("error","command.error",{...nZ(A),error:Y}),WA(this.telemetry,{component:"core",operation:"hub.websocket_command",error:Y,severity:"error",handled:!0,context:nZ(A)}),Z({kind:"reply",envelope:ZA(A,"command_failed",Y instanceof Error?Y.message:"Unknown hub error")})}},H=()=>{if(W)return;W=!0;for(let X of f.values())X();f.clear();for(let X of J)this.transport.command({version:"v1",command:"client.unregister",clientId:X});J.clear(),$.removeEventListener("message",j),$.removeEventListener("close",H)};return $.addEventListener("message",j),$.addEventListener("close",H),H}}class tZ{transport;constructor($){this.transport=$}command($){return this.transport.handleCommand($)}subscribe($,f,J){return this.transport.subscribe($,f,J)}}function iM($){if(typeof $==="string")return $;if($ instanceof Uint8Array)return Buffer.from($).toString();if($ instanceof ArrayBuffer)return Buffer.from($).toString();if(Array.isArray($))return Buffer.concat($.map((f)=>Buffer.from(f))).toString();return String($)}function nM($){return{send(f){$.send(f)},addEventListener(f,J){if(f==="message"){$.on("message",(W)=>{J({data:iM(W)})});return}$.on("close",J)},removeEventListener(){}}}function aM($){try{$.write(`HTTP/1.1 400 Bad Request\r
|
|
706
706
|
Connection: close\r
|
|
707
707
|
Content-Length: 0\r
|
|
708
708
|
\r
|
|
709
|
-
`),$.end()}catch{$.destroy()}}function
|
|
709
|
+
`),$.end()}catch{$.destroy()}}function tM($){try{$.write(`HTTP/1.1 401 Unauthorized\r
|
|
710
710
|
Connection: close\r
|
|
711
711
|
Content-Length: 0\r
|
|
712
712
|
\r
|
|
713
|
-
`),$.end()}catch{$.destroy()}}function
|
|
714
|
-
Caused by: ${$.stack}`;return
|
|
715
|
-
`,"utf8");let H=f.timeoutMs??300000,Y=f.pollIntervalMs??200,V=Date.now();while(Date.now()-V<H){try{let A=await sT(j,"utf8"),B=JSON.parse(A),G={approved:B.approved===!0,reason:typeof B.reason==="string"?B.reason:void 0};return await Promise.all([M7(j),M7(W)]),G}catch{}await fM(Y)}return await M7(W),{approved:!1,reason:"Tool approval request timed out"}}Z$();import*as R0 from"@cline/llms";import{getClineEnvironmentConfig as QM}from"@cline/shared";function ZM($){return $.apiKey??$.auth?.apiKey}function WM($){return($.auth?.accessToken?.trim()??"").length>0}function MY($){return $.split(/[-_]/).filter(Boolean).map((f)=>f.charAt(0).toUpperCase()+f.slice(1)).join(" ")}function jM($){let f=$.split(/\s+/).filter(Boolean);if(f.length===0)return"?";if(f.length===1)return f[0].slice(0,2).toUpperCase();return`${f[0][0]}${f[1][0]}`.toUpperCase()}function XM($){let f=["#c4956a","#6b8aad","#e8963a","#5b9bd5","#6bbd7b","#9b7dd4","#d07f68","#57a6a1"],J=0;for(let Q of $)J=J*31+Q.charCodeAt(0)>>>0;return f[J%f.length]}function qY($){return Object.entries($).sort(([f],[J])=>f.localeCompare(J)).map(([f,J])=>gX(f,J))}async function HM($,f){let J=await R0.getModelsForProvider($);if(!f)return J;let Q=await nf($,{loadPrivateOnAuth:!0,failOnError:!1},f);return Q?.knownModels?{...J,...Q.knownModels}:J}function q7($){return[...new Set(($??[]).map((f)=>f.trim()).filter(Boolean))]}function YM($){if(!$?.length)return;return[...new Set($)]}function VM($,f){return YM([...$??[],...f??[]])}function AM($){let f=$?.popularRank;return typeof f==="number"&&Number.isFinite(f)?f:Number.MAX_SAFE_INTEGER}function yY($){let f=Object.entries($??{}).filter(([J])=>J.trim().length>0);return f.length>0?Object.fromEntries(f):void 0}function y7($,f){let J=f?.includes("vision")??!1,Q=f?.includes("reasoning")??!1;return Object.fromEntries($.map((Z)=>[Z,{id:Z,name:Z,supportsVision:J,supportsAttachments:J,supportsReasoning:Q}]))}async function wY($){if(!$.shouldRecompute)return $.fallbackModelIds??[];let f=$.modelsSourceUrl?await c8($.modelsSourceUrl,$.providerId):[];return[...new Set([...$.explicitModels??[],...f])]}function SY($,f){let J=$.read(),Q=!1;if(J.providers[f])delete J.providers[f],Q=!0;if(J.lastUsedProvider===f)delete J.lastUsedProvider,Q=!0;if(Q)$.write(J);R0.unregisterProvider(f)}async function BM($,f){let J=f.providerId.trim().toLowerCase();if(!J)throw Error("providerId is required");let Q=f.baseUrl.trim(),Z=f.apiKey?.trim()??"";if(!Q&&!Z){let K=O1($);if((await Z2(K)).providers[J]){let F=await CY($,{providerId:J});return{providerId:J,settingsPath:F.settingsPath,modelsPath:F.modelsPath,modelsCount:0}}return SY($,J),{providerId:J,settingsPath:$.getFilePath(),modelsPath:K,modelsCount:0}}if(R0.hasProvider(J))throw Error(`provider "${J}" already exists`);let W=f.name.trim();if(!W)throw Error("name is required");if(!Q)throw Error("baseUrl is required");let j=q7(f.models),X=f.modelsSourceUrl?.trim(),H=await wY({providerId:J,explicitModels:j,modelsSourceUrl:X,shouldRecompute:!0});if(H.length===0)throw Error("at least one model is required (manual or via modelsSourceUrl)");let Y=f.defaultModelId?.trim()&&H.includes(f.defaultModelId.trim())?f.defaultModelId.trim():H[0],V=f.capabilities?.length?[...new Set(f.capabilities)]:void 0,A=yY(f.headers);$.saveProviderSettings({provider:J,apiKey:Z||void 0,baseUrl:Q,headers:A,timeout:f.timeoutMs,model:Y,protocol:f.protocol,client:f.client},{setLastUsed:!1});let B=O1($),G=await Z2(B);return G.providers[J]={provider:{name:W,baseUrl:Q,defaultModelId:Y,protocol:f.protocol,client:f.client,capabilities:V,modelsSourceUrl:X},models:y7(H,V)},await C6(B,G),R8(J,G.providers[J]),{providerId:J,settingsPath:$.getFilePath(),modelsPath:B,modelsCount:H.length}}async function hY($,f){let J=f.providerId.trim().toLowerCase();if(!J)throw Error("providerId is required");let Q=O1($),Z=await Z2(Q),W=Z.providers[J];if(!W){let _=$.getProviderSettings(J);if(!_)throw Error(`provider "${J}" does not exist`);let R=f.modelsSourceUrl?.trim(),L=q7(f.models)[0]??_.model?.trim();if(!L&&!R)throw Error(`provider "${J}" cannot be updated because no model is configured`);W={provider:{name:f.name?.trim()||MY(J),baseUrl:f.baseUrl?.trim()??_.baseUrl?.trim()??"",defaultModelId:L,protocol:_.protocol,client:_.client,capabilities:_.capabilities},models:L?y7([L],_.capabilities):{}}}if(!W.provider)throw Error(`provider "${J}" cannot be updated because it is a model overlay (no provider metadata)`);let j=f.name?.trim()??W.provider.name.trim();if(!j)throw Error("name is required");let X=f.baseUrl?.trim()??W.provider.baseUrl.trim();if(!X)throw Error("baseUrl is required");let H=f.capabilities===void 0?W.provider.capabilities:f.capabilities===null?void 0:[...new Set(f.capabilities)],Y=f.protocol===void 0?W.provider.protocol:f.protocol??void 0,V=f.client===void 0?W.provider.client:f.client??void 0,A=q7(f.models),B=f.modelsSourceUrl===void 0?W.provider.modelsSourceUrl:f.modelsSourceUrl?.trim()||void 0,G=f.models!==void 0||f.modelsSourceUrl!==void 0&&!!B,K=Object.keys(W.models??{}).map((_)=>_.trim()).filter(Boolean),D=await wY({providerId:J,explicitModels:A,modelsSourceUrl:B,fallbackModelIds:K,shouldRecompute:G});if(D.length===0)throw Error("at least one model is required (manual or via modelsSourceUrl)");let F=f.defaultModelId===void 0?W.provider.defaultModelId?.trim():f.defaultModelId?.trim(),P=F&&D.includes(F)?F:D[0],z={...$.getProviderSettings(J)??{},provider:J,baseUrl:X,model:P};if(Y)z.protocol=Y;else delete z.protocol;if(V)z.client=V;else delete z.client;if(f.apiKey!==void 0){let _=f.apiKey?.trim()??"";if(_)z.apiKey=_;else delete z.apiKey}if(f.headers!==void 0){let _=yY(f.headers);if(_)z.headers=_;else delete z.headers}if(f.timeoutMs!==void 0)if(typeof f.timeoutMs==="number")z.timeout=f.timeoutMs;else delete z.timeout;return $.saveProviderSettings(z,{setLastUsed:!1}),Z.providers[J]={provider:{name:j,baseUrl:X,defaultModelId:P,protocol:Y,client:V,capabilities:H,modelsSourceUrl:B},models:y7(D,H)},await C6(Q,Z),R8(J,Z.providers[J]),{providerId:J,settingsPath:$.getFilePath(),modelsPath:Q,modelsCount:D.length}}async function CY($,f){let J=f.providerId.trim().toLowerCase();if(!J)throw Error("providerId is required");let Q=O1($),Z=await Z2(Q);if(!Z.providers[J])throw Error(`provider "${J}" does not exist`);return delete Z.providers[J],await C6(Q,Z),R0.unregisterProvider(J),SY($,J),{providerId:J,settingsPath:$.getFilePath(),modelsPath:Q}}async function GM($){let f=$.read(),J=R0.getProviderIds(),Q=await Promise.all(J.map(async(W)=>{let[j,X]=await Promise.all([R0.getProvider(W),R0.getModelsForProvider(W)]),H=qY(X),Y=f.providers[W]?.settings,V=j?.name??MY(W),A=VM(j?.capabilities,Y?.capabilities);return{provider:{id:W,name:V,models:H.length,color:XM(W),letter:jM(V),enabled:Boolean(Y),apiKey:Y?ZM(Y):void 0,oauthAccessTokenPresent:Y?WM(Y):void 0,baseUrl:Y?.baseUrl??j?.baseUrl,defaultModelId:j?.defaultModelId,protocol:Y?.protocol??j?.protocol,client:Y?.client??j?.client,capabilities:A,authDescription:"This provider uses API keys for authentication.",baseUrlDescription:"The base endpoint to use for provider requests.",modelList:H},rank:AM(j?.metadata)}}));return Q.sort((W,j)=>{if(W.rank!==j.rank)return W.rank-j.rank;return W.provider.name.localeCompare(j.provider.name)||W.provider.id.localeCompare(j.provider.id)}),{providers:Q.map((W)=>W.provider),settingsPath:$.getFilePath()}}async function KM($,f){let J=$.trim(),Q=await HM(J,f),Z=qY(Q);return{providerId:J,models:Z}}function FM($,f){let J=f.providerId.trim();if(f.enabled===!1){let W=$.read();if(delete W.providers[J],W.lastUsedProvider===J)delete W.lastUsedProvider;return $.write(W),{providerId:J,enabled:!1,settingsPath:$.getFilePath()}}let Z={...$.getProviderSettings(J)??{},provider:J};for(let W of["apiKey","baseUrl","model","region"])if(Object.hasOwn(f,W)&&typeof f[W]==="string")if(f[W].trim().length===0)delete Z[W];else Z[W]=f[W];for(let W of["maxTokens","contextWindow","timeout","apiLine","protocol","client","routingProviderId","capabilities"])if(Object.hasOwn(f,W))Z[W]=f[W];for(let W of["auth","headers","reasoning","aws","gcp","azure","sap","oca"])if(Object.hasOwn(f,W)&&f[W]!=null)Z[W]={...typeof Z[W]==="object"&&Z[W]!=null?Z[W]:{},...f[W]};return $.saveProviderSettings(Z,{setLastUsed:!1}),{providerId:J,enabled:!0,settingsPath:$.getFilePath()}}async function PM($,f){let J=f.trim(),Q=$.getProviderSettings(J),W=R0.MODEL_COLLECTIONS_BY_PROVIDER_ID[J]?.provider,j=Q?.baseUrl?.trim()||W?.baseUrl?.trim(),X=d8(j,W?.baseUrl,W?.modelsSourceUrl);if(!Q||!W||!j||!X)return{providerId:J,refreshed:!1};let H=await hY($,{providerId:J,name:W.name,baseUrl:j,apiKey:Q.apiKey,headers:Q.headers??null,timeoutMs:Q.timeout??null,modelsSourceUrl:X,protocol:Q.protocol??W.protocol??null,client:Q.client??W.client??null,capabilities:Q.capabilities??null});return{providerId:J,refreshed:!0,modelsCount:H.modelsCount}}function UM($){let f=$.trim().toLowerCase();if(f==="codex"||f==="openai-codex")return"openai-codex";if(f==="cline"||f==="oca")return f;throw Error(`provider "${$}" does not support OAuth login (supported: cline, oca, openai-codex)`)}function DM($,f){if($==="cline")return f.access.startsWith("workos:")?f.access:`workos:${f.access}`;return f.access}async function RM($,f,J,Q){let Z=Vf({onPrompt:async(W)=>W.defaultValue??"",openUrl:J,onOpenUrlError:({error:W})=>{throw W instanceof Error?W:Error(String(W))}});if($==="cline")return x8({apiBaseUrl:f?.baseUrl?.trim()||QM().apiBaseUrl,useWorkOSDeviceAuth:!0,callbacks:Z,telemetry:Q});if($==="oca")return u8({mode:f?.oca?.mode,callbacks:Z,telemetry:Q});return g8({onAuth:Z.onAuth,onPrompt:Z.onPrompt,onProgress:Z.onProgress,onManualCodeInput:Z.onManualCodeInput,telemetry:Q})}function LM($,f,J,Q){let Z={...J?.auth??{},accessToken:DM(f,Q),refreshToken:Q.refresh,accountId:Q.accountId,expiresAt:Q.expires},W={...J??{provider:f},provider:f,auth:Z};return $.saveProviderSettings(W,{tokenSource:"oauth"}),W}function OM($){let f=$?.auth?.accessToken?.trim()||$?.apiKey?.trim();return f&&f.length>0?f:void 0}import*as Zf from"@cline/llms";import{isOAuthProviderId as zM}from"@cline/shared";var _M=["apiKey","baseUrl","awsRegion","awsProfile"],NM={bedrock:{mode:"replace",description:"AWS region is required for Bedrock. It can be auto-filled from AWS_REGION, AWS_DEFAULT_REGION, or ~/.aws/config.",fields:{awsRegion:{label:"AWS Region",placeholder:"us-east-1"},apiKey:{label:"AWS Bedrock API Key (optional)",placeholder:"Leave blank to use AWS profile/default chain",optional:!0},awsProfile:{label:"AWS Profile Name (optional)",placeholder:"default",optional:!0}}},ollama:{fields:{apiKey:{note:"Keep empty if no API key for local inference."}}}};function TM($,f){let J={};for(let Q of _M){let Z=$[Q],W=f[Q];if(Z||W)J[Q]={...Z,...W}}return J}function MM($){let f=NM[$.providerId];if(!f)return $;return{...$,description:f.description??$.description,fields:f.mode==="replace"?f.fields:TM($.fields,f.fields)}}var qM=new Set(["ollama","lmstudio","litellm","openai-compatible"]);function yM($,f){if(!f?.provider.baseUrl)return!1;if(f.provider.source!=="system")return!0;return qM.has($)}function wM($){let f=Zf.normalizeProviderId($);if(zM(f))return{providerId:f,authMethod:"oauth",fields:{}};let J=Zf.MODEL_COLLECTIONS_BY_PROVIDER_ID[f];if(J?.provider.capabilities?.includes("local-auth"))return{providerId:f,authMethod:"local",fields:{}};let Q=J?.provider.baseUrl,Z={apiKey:{}};if(yM(f,J))Z.baseUrl={defaultValue:Q};return MM({providerId:f,authMethod:"api-key",fields:Z})}G0();s6();import{appendFileSync as SM,existsSync as w7,mkdirSync as hM,readFileSync as CM,renameSync as EM,unlinkSync as bM,writeFileSync as kM}from"node:fs";import{join as S7}from"node:path";import{resolveTeamDataDir as IM}from"@cline/shared/storage";function xM($){return $.toLowerCase().replace(/[^a-z0-9._-]+/g,"-").replace(/^-+|-+$/g,"")}class EY{dirPath;statePath;taskHistoryPath;teammateSpecs=new Map;constructor($){let f=xM($.teamName),J=$.baseDir?.trim()||IM();this.dirPath=S7(J,f),this.statePath=S7(this.dirPath,"state.json"),this.taskHistoryPath=S7(this.dirPath,"task-history.jsonl")}loadState(){if(!w7(this.statePath))return;try{let $=CM(this.statePath,"utf8"),f=JSON.parse($);if(f.version!==1||!f.teamState)return;for(let J of f.teammates??[])this.teammateSpecs.set(J.agentId,J);return pj(f.teamState)}catch{return}}getTeammateSpecs(){return Array.from(this.teammateSpecs.values())}upsertTeammateSpec($){this.teammateSpecs.set($.agentId,$)}removeTeammateSpec($){this.teammateSpecs.delete($)}persist($){if(!this.hasPersistableState($)){this.clearPersistedState();return}this.ensureDir();let f={version:1,updatedAt:new Date().toISOString(),teamState:$.exportState(),teammates:Array.from(this.teammateSpecs.values())},J=`${this.statePath}.tmp`;kM(J,`${JSON.stringify(f,null,2)}
|
|
716
|
-
`,"utf8"),
|
|
717
|
-
`,"utf8")}ensureDir(){if(!w7(this.dirPath))hM(this.dirPath,{recursive:!0})}hasPersistableState($){let f=$.exportState();if(this.teammateSpecs.size>0)return!0;if(f.members.some((J)=>J.role==="teammate"))return!0;return f.tasks.length>0||f.mailbox.length>0||f.missionLog.length>0}clearPersistedState(){if(w7(this.statePath))bM(this.statePath)}}import{z as y}from"zod";var bY=y.object({workspaceRoot:y.string().min(1),cwd:y.string().optional(),provider:y.string().min(1),model:y.string().min(1),mode:y.enum(["act","plan"]).default("act"),apiKey:y.string(),systemPrompt:y.string().optional(),rules:y.string().optional(),maxIterations:y.number().int().positive().optional(),enableTools:y.boolean(),enableSpawn:y.boolean().optional(),enableTeams:y.boolean().optional(),autoApproveTools:y.boolean().optional(),missionStepInterval:y.number().int().positive().optional(),missionTimeIntervalMs:y.number().int().positive().optional()}),kY=y.enum(["idle","starting","running","pending","stopping","completed","cancelled","failed","error"]),IY=y.enum(["user","assistant","tool","system","status","error"]),xY=y.object({id:y.string().min(1),sessionId:y.string().nullable(),role:IY,content:y.string(),createdAt:y.number().int().nonnegative(),meta:y.object({stream:y.enum(["stdout","stderr"]).optional(),toolName:y.string().optional(),iteration:y.number().int().nonnegative().optional(),agentId:y.string().optional(),conversationId:y.string().optional(),hookEventName:y.string().optional(),inputTokens:y.number().int().nonnegative().optional(),outputTokens:y.number().int().nonnegative().optional(),checkpoint:y.object({ref:y.string(),createdAt:y.number().int().nonnegative(),runCount:y.number().int().positive(),kind:y.enum(["stash","commit"]).optional()}).optional()}).optional()}),mY=y.object({toolCalls:y.number().int().nonnegative(),tokensIn:y.number().int().nonnegative(),tokensOut:y.number().int().nonnegative()}),mM=y.object({sessionId:y.string().nullable(),status:kY,config:bY,messages:y.array(xY),rawTranscript:y.string(),error:y.string().nullable(),summary:mY});var gM=tW;import{Agent as xl,createAgentRuntime as ml}from"@cline/agents";import{getClineEnvironmentConfig as vM}from"@cline/shared";var uM=5000,vY={recommended:[{id:"anthropic/claude-opus-4.6",name:"Claude Opus 4.6",description:"Most intelligent model for agents and coding",tags:["BEST"]},{id:"anthropic/claude-sonnet-4.6",name:"Claude Sonnet 4.6",description:"Strong coding and agent performance",tags:["NEW"]},{id:"google/gemini-3.1-pro-preview",name:"Gemini 3.1 Pro Preview",description:"1M context window, strong coding performance",tags:["NEW"]},{id:"openai/gpt-5.3-codex",name:"GPT-5.3 Codex",description:"OpenAI's latest with strong coding abilities",tags:["NEW"]}],free:[{id:"kwaipilot/kat-coder-pro",name:"KwaiKAT Kat Coder Pro",description:"Advanced agentic coding model",tags:["FREE"]},{id:"arcee-ai/trinity-large-preview:free",name:"Arcee AI Trinity Large Preview",description:"Advanced large preview model",tags:["FREE"]}]};function cM($){return{recommended:$.recommended.map((f)=>({...f,tags:[...f.tags]})),free:$.free.map((f)=>({...f,tags:[...f.tags]}))}}function gY($){if(!$||typeof $!=="object")return null;let f=$;if(typeof f.id!=="string"||f.id.length===0)return null;return{id:f.id,name:typeof f.name==="string"&&f.name.length>0?f.name:f.id,description:typeof f.description==="string"?f.description:"",tags:Array.isArray(f.tags)?f.tags.filter((J)=>typeof J==="string"):[]}}function dM($){if(!$||typeof $!=="object")return null;let f=$,J=Array.isArray(f.recommended)?f.recommended:[],Q=Array.isArray(f.free)?f.free:[],Z=J.map(gY).filter((j)=>j!==null),W=Q.map(gY).filter((j)=>j!==null);if(Z.length===0&&W.length===0)return null;return{recommended:Z,free:W}}function lM($){let f=$.baseUrl?.trim();if(f)return f;let J=vM().apiBaseUrl;try{return($.providerSettingsManager??new d$).getProviderSettings("cline")?.baseUrl?.trim()||J}catch{return J}}async function pM($,f,J){let Q=new AbortController,Z=setTimeout(()=>Q.abort(),J);try{return await $(f,{signal:Q.signal})}finally{clearTimeout(Z)}}async function rM($={}){try{let f=lM($),J=$.fetchImpl??fetch,Q=await pM(J,`${f}/api/v1/ai/cline/recommended-models`,$.timeoutMs??uM);if(!Q.ok)throw Error(`HTTP ${Q.status}`);let Z=await Q.json(),W=dM(Z);if(W)return W}catch{}return cM(vY)}import{readFile as iM}from"node:fs/promises";import nM from"node:path";function aM($){return $}async function tM($){let f=nM.resolve($),J=await iM(f,"utf8"),Q;try{Q=JSON.parse(J)}catch(Z){let W=Z instanceof Error?Z.message:String(Z);throw Error(`Failed to parse JSON config at "${f}": ${W}`)}return sM(Q,f)}function sM($,f){if(!$||typeof $!=="object")throw Error(`Invalid llms config in "${f}": expected an object.`);let Q=$.providers;if(!Array.isArray(Q))throw Error(`Invalid llms config in "${f}": "providers" must be an array.`);if(!Q.length)throw Error(`Invalid llms config in "${f}": "providers" cannot be empty.`);return $}import{BUILT_IN_PROVIDER_IDS as dY,createHandler as $q,createHandlerAsync as fq,getProviderCollection as Jq,hasProvider as lY,registerAsyncHandler as Qq,registerHandler as Zq,registerModel as Wq,registerProvider as pY}from"@cline/llms";function uY($){return $?{...$}:{}}function oM($,f){if($)return $;if(!f)return;let J=globalThis.process;if(!J?.env)return;return J.env[f]}function eM($,f){if(!f.length)throw Error(`Provider "${$}" must include at least one model.`)}function cY($){let f=Object.keys($.collection.models);return{id:$.collection.provider.id,name:$.collection.provider.name,description:$.collection.provider.description,protocol:$.collection.provider.protocol,baseUrl:$.collection.provider.baseUrl,capabilities:$.collection.provider.capabilities,env:$.collection.provider.env,models:f,defaultModel:$.collection.provider.defaultModelId,modelCount:f.length}}class h7{providers=new Map;register($){eM($.id,$.models);let f=$.defaultModel??$.models[0];if(!f)throw Error(`Provider "${$.id}" must define a default model.`);if(!$.models.includes(f))throw Error(`Default model "${f}" is not included in configured models for "${$.id}".`);let J=this.providers.get($.id);this.providers.set($.id,{id:$.id,models:new Set([...J?.models??[],...$.models]),defaultModel:f,defaults:{...J?.defaults??{},...uY($.defaults)}})}registerSelectionConfig($){this.register({id:$.id,models:$.models,defaultModel:$.defaultModel,defaults:{apiKey:oM($.apiKey,$.apiKeyEnv),routingProviderId:$.builtinProviderId,baseUrl:$.baseUrl,headers:$.headers,timeoutMs:$.timeoutMs,capabilities:$.capabilities,...uY($.settings)}})}registerModel($,f){let J=this.providers.get($);if(!J){this.providers.set($,{id:$,models:new Set([f]),defaultModel:f,defaults:{}});return}J.models.add(f)}createHandlerConfig($){let f=this.require($.providerId),J=$.modelId??f.defaultModel;if(!f.models.has(J))throw Error(`Model "${J}" is not configured for provider "${$.providerId}".`);return{providerId:$.providerId,modelId:J,...f.defaults,...$.overrides}}list(){return Array.from(this.providers.values()).map(($)=>({id:$.id,models:Array.from($.models),defaultModel:$.defaultModel}))}getModels($){return Array.from(this.require($).models)}hasProvider($){return this.providers.has($)}hasModel($,f){return this.providers.get($)?.models.has(f)??!1}require($){let f=this.providers.get($);if(!f)throw Error(`Provider "${$}" is not configured in this SDK instance.`);return f}}class C7{configuredProviders=new h7;constructor($){this.applyConfig($)}createHandler($){return $q(this.configuredProviders.createHandlerConfig($))}async createHandlerAsync($){return fq(this.configuredProviders.createHandlerConfig($))}registerProvider($){if(pY($.collection),$.handlerFactory&&$.asyncHandlerFactory)throw Error(`Provider "${$.collection.provider.id}" cannot register both sync and async handlers.`);if($.handlerFactory)Zq($.collection.provider.id,$.handlerFactory);if($.asyncHandlerFactory)Qq($.collection.provider.id,$.asyncHandlerFactory);this.configuredProviders.register({id:$.collection.provider.id,models:$.exposeModels??Object.keys($.collection.models),defaultModel:$.defaultModel??$.collection.provider.defaultModelId,defaults:$.defaults})}registerBuiltinProvider($){let f=$.exposeModels??Object.keys($.models),J=$.defaultModel??f[0];if(!J)throw Error(`Provider "${$.id}" must define a default model.`);pY({provider:{id:$.id,name:$.name??$.id,description:$.description,protocol:$.protocol,baseUrl:$.baseUrl,defaultModelId:J,client:$.client??"openai-compatible",capabilities:$.capabilities,env:$.env,source:"system"},models:$.models}),this.configuredProviders.register({id:$.id,models:f,defaultModel:J,defaults:{routingProviderId:$.builtinProviderId,...$.defaults??{}}})}registerModel($){Wq($.providerId,$.modelId,$.info),this.configuredProviders.registerModel($.providerId,$.modelId)}getProviders(){return this.configuredProviders.list()}getBuiltInProviderIds(){return[...dY]}async getBuiltInProviders(){return(await Promise.all(dY.map((f)=>Jq(f)))).filter((f)=>f!==void 0).map((f)=>cY({collection:f}))}getModels($){return this.configuredProviders.getModels($)}isProviderConfigured($){return this.configuredProviders.hasProvider($)}isModelConfigured($,f){return this.configuredProviders.hasModel($,f)}applyConfig($){for(let f of $.providers)this.configuredProviders.registerSelectionConfig(f);for(let f of $.models??[])this.registerModel(f);for(let f of $.customProviders??[])this.registerProvider(f);for(let f of this.configuredProviders.list()){let J=lY(f.id),Q=this.configuredProviders.createHandlerConfig({providerId:f.id,modelId:f.defaultModel}).routingProviderId,Z=typeof Q==="string"&&lY(Q);if(!J&&!Z)throw Error(`Provider "${f.id}" is not known. Register it through customProviders/registerProvider, registerBuiltinProvider, or use a built-in provider ID.`)}}}function jq($){return new C7($)}j7();async function Ld(){return Promise.resolve().then(() => (T7(),OY))}export{Zj as writeHubDiscovery,I2 as writeGlobalSettings,Wj as withHubStartupLock,E$ as verifyHubConnection,C2 as updateMcpServerOAuthState,hY as updateLocalProvider,A7 as truncateNotificationBody,pJ as toggleDisabledTool,F6 as toTeamProgressLifecycleEvent,$$ as toProviderConfig,wD as toHubHealthUrl,S9 as toHookConfigFileName,L6 as summarizeUsageFromMessages,hR as stopLocalHubServerGracefully,e0 as startLocalOAuthServer,N7 as startHubWebSocketServer,Kc as startHubServer,UV as startClineDeviceAuth,H5 as splitCoreSessionConfig,W6 as spawnDetachedHubServerWithRetry,VR as spawnDetachedHubServer,UF as setTelemetryOptOutGlobally,S2 as setMcpServerDisabled,v3 as setDisabledTools,LF as setDisabledPlugin,Vv as sendHubCommand,FM as saveLocalProviderSettings,LM as saveLocalProviderOAuthCredentials,s2 as sanitizeSessionToken,TQ as safeParseSettings,qA as safeCreateProviderConfig,u6 as runSubprocessEvent,d6 as runHook,H3 as reviveTeamStateDates,Dj as restartLocalHubIfIdleAfterStartupTimeout,uE as resolveWorkspaceHubOwnerContext,AJ as resolveWorkflowsConfigSearchPaths,YJ as resolveSkillsConfigSearchPaths,D0 as resolveSharedHubOwnerContext,d_ as resolveSessionBackend,VJ as resolveRulesConfigSearchPaths,nf as resolveProviderConfig,W5 as resolvePluginConfigSearchPaths,M$ as resolveMcpServerRegistrations,OM as resolveLocalClineAuthToken,IN as resolveHubUrl,K1 as resolveHubOwnerContext,C$ as resolveHubEndpointOptions,t1 as resolveHubBuildId,y9 as resolveHooksConfigSearchPaths,Q$ as resolveDisabledToolNames,v4 as resolveDisabledPluginPaths,C0 as resolveDefaultMcpSettingsPath,Z6 as resolveDefaultHubPort,vD as resolveDefaultHubPathname,gD as resolveDefaultHubHost,B3 as resolveCoreSelectedToolIds,s5 as resolveCompatibleLocalHubUrl,CE as resolveClineDir,p5 as resolveClineDataDir,r4 as resolveAndLoadAgentPlugins,v2 as resolveAgentPluginPaths,r5 as requestHubShutdown,JM as requestDesktopToolApproval,s1 as rememberRecoverableLocalHubUrl,NY as registerRemoteConfigSessionBlobUpload,E2 as registerMcpServersFromSettingsFile,md as registerDisposable,PM as refreshProviderModelsFromSource,bf as refreshOpenAICodexToken,vf as refreshOcaToken,Cf as refreshClineToken,d9 as readSessionCheckpointHistory,rT as readRemoteConfigSessionBlobUploadMetadata,A0 as readHubDiscovery,J$ as readGlobalSettings,U0 as probeHubServer,Yv as probeHubConnection,DZ as prewarmFileIndex,Hj as prewarmDetachedHubServer,aT as prepareRemoteConfigCoreIntegration,HJ as parseWorkflowConfigFromMarkdown,xd as parseUserCommandEnvelope,jJ as parseSkillConfigFromMarkdown,NQ as parseSettings,XJ as parseRuleConfigFromMarkdown,c6 as parseHookEventPayload,qV as openaiCodexOAuthProvider,Y1 as normalizeWorkspacePath,Id as normalizeUserInput,kd as normalizeSdkError,P0 as normalizeRuntimeCapabilities,t8 as normalizeProviderId,MV as normalizeOpenAICodexCredentials,UM as normalizeOAuthProvider,o1 as normalizeHubWebSocketUrl,bd as noopBasicLogger,v9 as migrateLegacyProviderSettings,Q4 as mergeRulesForSystemPrompt,D8 as mergeAgentHooks,S5 as makeTeamTaskSubSessionId,e4 as makeSubSessionId,g8 as loginOpenAICodex,u8 as loginOcaOAuth,RM as loginLocalProvider,x8 as loginClineOAuth,Ld as loadOpenTelemetryAdapter,w2 as loadMcpSettingsFile,tM as loadLlmsConfigFromFile,g2 as loadAgentPluginsFromPathsWithDiagnostics,fW as loadAgentPluginsFromPaths,f5 as loadAgentPluginFromPath,KD as listSessionHistoryFromBackend,HW as listPluginToolsWithDiagnostics,X5 as listPluginTools,vJ as listMcpServerOAuthStatuses,GM as listLocalProviders,J2 as listHookConfigFiles,DF as isToolDisabledGlobally,lJ as isTelemetryOptedOutGlobally,gQ as isRuleEnabled,RF as isPluginDisabledGlobally,TV as isOpenAICodexTokenExpired,NR as isHubReconnectableTransportError,Pj as isHubCommandTimeoutError,kE as isDiscoveryFilePresent,x7 as isClineAccountActionRequest,_A as isBuiltInProviderId,U$ as identifyAccount,X1 as hasMcpSettingsFile,kf as getValidOpenAICodexCredentials,uf as getValidOcaCredentials,Ef as getValidClineCredentials,wM as getProviderConfigFields,GQ as getProviderConfig,h2 as getMcpServerOAuthState,KM as getLocalProviderModels,a8 as getLiveModelsCatalog,J1 as getFileIndex,PO as getCurrentContextSize,IJ as getCoreHeadlessToolNames,A3 as getCoreDefaultEnabledToolIds,T2 as getCoreBuiltinToolCatalog,G3 as getCoreAcpToolNames,Nd as getClineDefaultSystemPrompt,G5 as generateWorkspaceInfoWithDiagnostics,s4 as generateWorkspaceInfo,ZQ as generateOcaOpcRequestId,J4 as formatRulesForSystemPrompt,Ed as formatDisplayUserInput,iJ as filterExtensionToolRegistrations,l1 as filterDisabledTools,rJ as filterDisabledPluginPaths,rM as fetchClineRecommendedModels,m7 as executeClineAccountAction,LY as ensureHubWebSocketServer,Fc as ensureHubServer,oE as ensureDetachedHubServer,rX as ensureCustomProvidersLoaded,W8 as ensureCompatibleLocalHubUrl,D4 as enrichPromptWithMentions,Cd as emptyWorkspaceManifest,Q2 as emptyStoredProviderSettings,j5 as discoverPluginModulePaths,h5 as deriveSubsessionStatus,CY as deleteLocalProvider,aM as defineLlmsConfig,KJ as createWorkflowsConfigDefinition,c1 as createUserInstructionConfigService,zZ as createToolPoliciesWithPreset,hd as createTool,VH as createTeamName,NH as createSubprocessHooks,u1 as createSpawnAgentTool,BJ as createSkillsConfigDefinition,v6 as createSessionHost,v6 as createRuntimeHost,GJ as createRulesConfigDefinition,nT as createRemoteConfigSessionMessagesArtifactUploader,MA as createProviderConfig,a6 as createOpenTelemetryTelemetryService,nV as createOcaRequestHeaders,iV as createOcaOAuthProvider,Vf as createOAuthClientCallbacks,I4 as createMcpTools,Ov as createLocalHubScheduleRuntimeHandlers,jq as createLlmsSdk,B0 as createInitialAccumulatedUsage,bE as createInMemoryHubOwnerContext,j$ as createHubServerUrl,Qj as createHubAuthToken,b9 as createHookConfigFileHooks,M6 as createHookConfigFileExtension,T6 as createHookAuditHooks,dJ as createDisabledMcpToolPolicy,x3 as createDisabledMcpToolPolicies,N4 as createDelegatedAgentConfigProvider,T4 as createDelegatedAgent,_Z as createDefaultToolsWithPreset,m1 as createDefaultTools,b4 as createDefaultMcpServerClientFactory,z4 as createDefaultExecutors,c2 as createCoreSettingsService,b$ as createCoreSessionSnapshot,Sd as createContributionRegistry,T9 as createContextCompactionPrepareTurn,T1 as createConfiguredTelemetryService,t6 as createConfiguredTelemetryHandle,wd as createClineTelemetryServiceMetadata,yd as createClineTelemetryServiceConfig,RV as createClineOAuthProvider,M2 as createBuiltinTools,N2 as createAgentTeamsTools,ml as createAgentRuntime,O6 as createAgentHooksExtension,wH as connectToHub,DV as completeClineDeviceAuth,LA as clearPrivateModelsCatalogCache,RA as clearLiveModelsCatalogCache,n0 as clearHubDiscovery,QV as captureWorkspacePathResolved,Af as captureWorkspaceInitialized,Bf as captureWorkspaceInitError,Uf as captureToolUsage,Ff as captureTokenUsage,Kf as captureTaskRestarted,Gf as captureTaskCreated,h8 as captureTaskCompleted,E8 as captureSubagentExecution,Df as captureSkillUsed,qd as captureSdkError,ZV as captureProviderConfigured,C8 as captureProviderApiError,Pf as captureModeSwitch,Lf as captureMentionUsed,zf as captureMentionSearchResults,Of as captureMentionFailed,Nf as captureHookDiscovery,JV as captureExtensionActivated,Rf as captureDiffEditFailure,A2 as captureConversationTurnEvent,Mf as captureCompactionSkipped,Tf as captureCompactionExecuted,F$ as captureAuthSucceeded,K$ as captureAuthStarted,n$ as captureAuthLoggedOut,P$ as captureAuthFailed,_f as captureAgentTeamCreated,a$ as captureAgentCreated,K5 as buildWorkspaceMetadata,K6 as buildTeamProgressSummary,Td as buildSdkErrorProperties,zY as buildRemoteConfigSessionBlobUploadMetadata,z2 as buildDelegatedAgentConfig,y4 as bootstrapAgentTeams,q3 as authorizeMcpServerOAuth,BM as addLocalProvider,H0 as accumulateUsageTotals,JJ as WORKFLOWS_CONFIG_DIRECTORY_NAME,K2 as UnifiedConfigFileWatcher,r0 as ToolPresets,T8 as TelemetryService,n6 as TelemetryLoggerSink,q4 as TEAM_TOOL_NAMES,c4 as SubprocessSandbox,y6 as StoredProviderSettingsSchema,qX as StoredProviderSettingsEntrySchema,L8 as SqliteTeamStore,x$ as SqliteSessionStore,j2 as SessionVersioningService,d0 as SessionVersioningError,F0 as SessionSource,OQ as SapSettingsSchema,fJ as SKILLS_CONFIG_DIRECTORY_NAME,sf as SESSION_STATUSES,gd as SDK_ERROR_TELEMETRY_EVENT,Yf as RpcClineAccountService,H6 as RemoteRuntimeHost,UQ as ReasoningSettingsSchema,EQ as RULES_CONFIG_DIRECTORY_NAME,_Y as REMOTE_CONFIG_SESSION_BLOB_UPLOAD_METADATA_KEY,b1 as ProviderSettingsSchema,d$ as ProviderSettingsManager,KQ as ProviderProtocolSchema,tf as ProviderIdSchema,FQ as ProviderClientSchema,M8 as OpenTelemetryProvider,zQ as OcaSettingsSchema,rf as OPENAI_COMPATIBLE_PROVIDERS,X$ as NodeHubClient,z7 as NativeHubTransportAdapter,_Q as ModelCatalogSettingsSchema,l$ as LocalRuntimeHost,zd as Llms,w6 as InMemoryWorkspaceManager,b2 as InMemoryMcpManager,uN as HubUIClient,I0 as HubTransportError,vN as HubSessionClient,Qf as HubServerTransport,i6 as HubScheduleService,l6 as HubScheduleCommandService,P1 as HubRuntimeHost,j6 as HubCommandError,zH as HookEventPayloadSchema,OH as HookEventNameSchema,z6 as HookConfigFileName,w9 as HOOK_CONFIG_FILE_EVENT_MAP,DX as HOOKS_CONFIG_DIRECTORY_NAME,g4 as GlobalSettingsSchema,RQ as GcpSettingsSchema,EY as FileTeamPersistenceStore,vY as FALLBACK_CLINE_RECOMMENDED_MODELS,W0 as DefaultToolNames,x6 as DefaultRuntimeBuilder,C7 as DefaultLlmsSdk,VQ as DEFAULT_MODELS_CATALOG_URL,xD as DEFAULT_HUB_PORT,mD as DEFAULT_HUB_PATHNAME,ID as DEFAULT_HUB_HOST,a1 as CoreSettingsService,m$ as CoreSessionService,Md as ContributionRegistry,W7 as ClineCore,Hf as ClineAccountService,mM as ChatViewStateSchema,mY as ChatSummarySchema,kY as ChatSessionStatusSchema,bY as ChatSessionConfigSchema,xY as ChatMessageSchema,IY as ChatMessageRoleSchema,k as CORE_TELEMETRY_EVENTS,gM as CORE_BUILD_VERSION,O7 as BrowserWebSocketHubAdapter,zA as BUILT_IN_PROVIDER_IDS,af as BUILT_IN_PROVIDER,LQ as AzureSettingsSchema,DQ as AwsSettingsSchema,PQ as AuthSettingsSchema,V8 as AgentTeamsRuntime,j9 as AgentTeam,xl as Agent,I1 as ALL_DEFAULT_TOOL_NAMES};
|
|
713
|
+
`),$.end()}catch{$.destroy()}}function jA($,f){if(!$||!f)return!1;let J=Buffer.from($,"utf8"),W=Buffer.from(f,"utf8");return J.length===W.length&&dM(J,W)}function HA($,f){let J=$&&typeof $==="object"&&"code"in $&&typeof $.code==="string"?$.code:void 0,W=$ instanceof Error?$.message:typeof $==="string"?$:"Unknown startup error",Z=`Failed to start hub server on ${f.host}:${f.port}${f.pathname}: ${W}`,Q=Error(J?`${Z} (${J})`:Z);if(J)$.code=J,Q.code=J;if($ instanceof Error&&$.stack)Q.stack=`${Q.name}: ${Q.message}
|
|
714
|
+
Caused by: ${$.stack}`;return Q}async function sM($){return await new Promise((f,J)=>{let W=pM.createServer();W.once("error",J),W.listen(0,$,()=>{let Z=W.address();if(!Z||typeof Z==="string"){W.close(()=>J(Error("Failed to resolve free port")));return}let Q=Z.port;W.close((j)=>{if(j){J(j);return}f(Q)})})})}function oM($){return $ instanceof Error&&"code"in $&&$.code==="EADDRINUSE"}var sZ=new Map,XA="cline-hub-auth.",eM=30000;function YA($){return Array.isArray($)?$.join(","):$??""}function $y($){let f=YA($).trim();return/^Bearer\s+(.+)$/i.exec(f)?.[1]?.trim()||null}function fy($){for(let f of YA($).split(",")){let J=f.trim();if(J.startsWith(XA))return J.slice(XA.length).trim()||null}return null}async function oZ($){let f=$.owner??z1(),J=$.host??"127.0.0.1",W=$.pathname??"/hub",Z=$.port??yJ(),Q=Z===0?await sM(J):Z,j=Q,H=A$(J,Q,W),X=Hf(),Y=rj(),A=new y4($);await A.start();let V=new aZ(new tZ(A),$.telemetry),B=new Set,K=new Date().toISOString(),G={protocolVersion:"v1",coreVersion:L2.version,buildId:X,pid:process.pid,startedAt:K},R=new Set,P,F,U=async()=>{if(F)return F;return F=(async()=>{if(P)clearInterval(P),P=void 0;for(let O of R)O.terminate?.();R.clear();for(let O of B)O();if(B.clear(),await new Promise((O,T)=>{z.close((M)=>{if(M){T(M);return}O()})}),await new Promise((O,T)=>{_.close((M)=>{if(M){T(M);return}O()})}),await A.stop(),(await K0(f.discoveryPath))?.url===H)await e0(f.discoveryPath)})(),F},_=lM.createServer((D,O)=>{if((D.url??"/")==="/health"){let M=JSON.stringify({hubId:A.getHubId(),...G,authToken:"",host:J,port:j,url:H,updatedAt:new Date().toISOString()});O.statusCode=200,O.setHeader("content-type","application/json"),O.end(M);return}if((D.url??"/")==="/version"){O.statusCode=200,O.setHeader("content-type","application/json"),O.end(JSON.stringify(G));return}if(new QA(D.url??"/",`http://${J}:${j}`).pathname==="/shutdown"&&D.method==="POST"){if(!jA($y(D.headers.authorization),Y)){O.statusCode=401,O.end("Unauthorized");return}O.statusCode=202,O.setHeader("content-type","application/json"),O.end(JSON.stringify({ok:!0})),queueMicrotask(()=>{U()});return}O.statusCode=404,O.end("Not found")}),z=new rM({noServer:!0});P=setInterval(()=>{for(let D of R){if(D.isAlive===!1){try{D.terminate?.()}catch{}R.delete(D);continue}D.isAlive=!1;try{D.ping?.()}catch{try{D.terminate?.()}catch{}R.delete(D)}}},eM),_.on("upgrade",(D,O,T)=>{if(new QA(D.url??"/",`http://${J}:${j}`).pathname!==W){O.destroy();return}if(!jA(fy(D.headers["sec-websocket-protocol"]),Y)){tM(O);return}try{z.handleUpgrade(D,O,T,(s)=>{let Z0=s;Z0.isAlive=!0,Z0.on("pong",()=>{Z0.isAlive=!0}),R.add(Z0);let a=V.attach(nM(s));B.add(a),s.once("close",()=>{R.delete(Z0),a(),B.delete(a)})})}catch{aM(O)}});try{await new Promise((D,O)=>{_.once("error",(T)=>{O(HA(T,{host:J,port:Q,pathname:W}))}),_.listen(Q,J,()=>{let T=_.address();if(!T||typeof T==="string"){O(HA(Error("Failed to resolve hub port"),{host:J,port:Q,pathname:W}));return}j=T.port,H=A$(J,j,W),D()})})}catch(D){if(P)clearInterval(P),P=void 0;throw await A.stop().catch(()=>{return}),D}return await ij(f.discoveryPath,{hubId:A.getHubId(),protocolVersion:"v1",coreVersion:L2.version,buildId:X,authToken:Y,host:J,port:j,url:H,pid:process.pid,startedAt:K,updatedAt:K}),{host:J,port:j,url:H,authToken:Y,close:U}}async function AA($){let f=$.owner??z1(),J=$.host!==void 0||$.port!==void 0||$.pathname!==void 0||!!process.env.CLINE_HUB_PORT?.trim(),W=$.host??"127.0.0.1",Z=$.port??yJ(),Q=$.pathname??"/hub",j=A$(W,Z,Q),H=f.discoveryPath,X=(A)=>{if(!J)Xf(A.url,A.authToken);return A},Y=sZ.get(H);if(Y){let A=await Y;if(A.url===j)return X({server:A,url:A.url,authToken:A.authToken,action:"reuse"})}return await nj(f.discoveryPath,async()=>{let A=await K0(f.discoveryPath);if(A?.url&&(A.url===j||$.allowPortFallback===!0)){let G=await I$(A.url);if(G?.url&&await m$(G.url,{authToken:A.authToken}))return X({url:G.url,authToken:A.authToken,action:"reuse"})}if((await I$(j))?.url||A?.url)await e0(f.discoveryPath);let K=async(G)=>{let R=oZ({...G,owner:f});sZ.set(H,R);try{let P=await R;return X({server:P,url:P.url,authToken:P.authToken,action:"started"})}catch(P){throw sZ.delete(H),P}};try{return await K($)}catch(G){if(!$.allowPortFallback||!oM(G))throw G;return await K({...$,port:0})}})}async function Ll($){let f=x$({host:$.host,port:$.port,pathname:$.pathname});return await oZ({...$,...f,owner:R0()})}async function Ol($){let f=$.port!==void 0||!!process.env.CLINE_HUB_PORT?.trim(),J=x$({host:$.host,port:$.port,pathname:$.pathname});return await AA({...$,...J,allowPortFallback:$.allowPortFallback??!f,owner:R0()})}eZ();import{buildRemoteConfigSessionBlobUploadMetadata as BA,clearRemoteConfigSessionBlobUpload as Jy,createClineTelemetryServiceConfig as Wy,createSessionId as Zy,createRemoteConfigSessionMessagesArtifactUploader as Qy,prepareRemoteConfigRuntime as jy,REMOTE_CONFIG_SESSION_BLOB_UPLOAD_METADATA_KEY as KA,readRemoteConfigSessionBlobUploadMetadata as Hy,registerRemoteConfigSessionBlobUpload as GA}from"@cline/shared";function Xy($,f){let J=$.telemetry||f.telemetryService?{...f.telemetryService??{},...$.telemetry??{}}:void 0;if(!J)return;return k1(Wy(J)).telemetry}function Yy(){let $=Qy();return{async uploadMessagesFile(f){await $.uploadMessagesFile(f)}}}async function Ay($){let f=await jy($),J=Xy(f,$),W=[f.pluginDefinition],Z=f.claims?.subject,Q=BA(f.bundle?.remoteConfig,Z),j;return{prepared:f,extensions:W,telemetry:J,applyToStartSessionInput(H){let X=H.config.extensions??[],Y=H.config.telemetry,A=Q?H.config.sessionId?.trim()||Zy():H.config.sessionId;if(A&&Q)j=A;let V=A&&Q?GA(A,f.bundle?.remoteConfig,Z):void 0,B=V?{...H.sessionMetadata??{},[KA]:V}:H.sessionMetadata;return{...H,...B?{sessionMetadata:B}:{},config:{...H.config,...A?{sessionId:A}:{},extensions:[...X,...W],telemetry:J??Y}}},async dispose(){if(j)Jy(j)}}}import{mkdir as Vy,readFile as By,unlink as Ky,writeFile as Gy}from"node:fs/promises";import{join as PA}from"node:path";function Py($){return $.replace(/[^a-zA-Z0-9._-]+/g,"_")}function Fy($){return new Promise((f)=>setTimeout(f,$))}async function $9($){try{await Ky($)}catch{}}async function Uy($,f={}){let J=f.approvalDir?.trim(),W=f.sessionId?.trim();if(!J||!W)return{approved:!1,reason:"Desktop tool approval IPC is not configured"};await Vy(J,{recursive:!0});let Z=Py(`${$.toolCallId}`),Q=PA(J,`${W}.request.${Z}.json`),j=PA(J,`${W}.decision.${Z}.json`),H=f.nowIso??(()=>new Date().toISOString());await Gy(Q,`${JSON.stringify({requestId:Z,sessionId:W,createdAt:H(),toolCallId:$.toolCallId,toolName:$.toolName,input:$.input,iteration:$.iteration,agentId:$.agentId,conversationId:$.conversationId},null,2)}
|
|
715
|
+
`,"utf8");let X=f.timeoutMs??300000,Y=f.pollIntervalMs??200,A=Date.now();while(Date.now()-A<X){try{let V=await By(j,"utf8"),B=JSON.parse(V),K={approved:B.approved===!0,reason:typeof B.reason==="string"?B.reason:void 0};return await Promise.all([$9(j),$9(Q)]),K}catch{}await Fy(Y)}return await $9(Q),{approved:!1,reason:"Tool approval request timed out"}}n0();n0();import{existsSync as Of,readdirSync as Ry,readFileSync as Dy,rmdirSync as Ly,rmSync as Oy,statSync as _y}from"node:fs";import{basename as g0,dirname as s$,extname as zy,isAbsolute as Ty,join as F$,relative as Ny,resolve as Lf,sep as f9}from"node:path";import{discoverPluginModulePaths as My,resolvePluginConfigSearchPaths as yy}from"@cline/shared/storage";var j9="_installed",qy="package",wy=new Map([["git",2],["local",1],["npm",1],["official",1],["remote",1]]);function J9($){return $.trim().toLowerCase()}function r0($,f){let J=f?.trim();if(!J)return;$.add(J)}function Sy($){return $.replace(/-[0-9a-f]{12}$/i,"")}function W9($){let f=zy($);return f?$.slice(0,-f.length):$}function Z9($){if(!Of($))return;try{let f=JSON.parse(Dy($,"utf8"));return typeof f.name==="string"?f.name.trim():void 0}catch{return}}function H9($,f){let J=Ny(f,$);return J===""||!J.startsWith("..")&&!Ty(J)}function FA($){let J=Lf($).split(f9),W=J.lastIndexOf(j9);if(W<0)return;let Z=J[W+1];if(!Z)return;let Q=wy.get(Z)??1,j=W+2+Q;if(J.length<j)return;let H=J.slice(0,j).join(f9)||f9;return Of(H)?H:void 0}function q4($){try{return Ry($,{withFileTypes:!0})}catch{return[]}}function hy($){let f=F$($,j9);if(!Of(f))return[];let J=[];for(let W of q4(f)){if(!W.isDirectory())continue;let Z=F$(f,W.name);if(W.name==="git"){for(let Q of q4(Z)){if(!Q.isDirectory())continue;let j=F$(Z,Q.name);for(let H of q4(j))if(H.isDirectory())J.push(F$(j,H.name))}continue}for(let Q of q4(Z))if(Q.isDirectory())J.push(F$(Z,Q.name))}return J.sort((W,Z)=>W.localeCompare(Z))}function UA($){try{return My($)}catch{return[]}}function Q9($){let f=UA($),J=new Set;r0(J,g0($)),r0(J,Sy(g0($))),r0(J,Z9(F$($,"package.json"))),r0(J,Z9(F$($,qy,"package.json")));for(let W of f)r0(J,g0(W)),r0(J,W9(g0(W)));return{installPath:$,entryPaths:f,names:[...J].sort((W,Z)=>W.localeCompare(Z)),installed:!0}}function Cy($,f){let J=Lf($),W=f.find((j)=>H9(J,j));if(!W)return;let Z=s$(J);while(Z!==W&&Z!==s$(Z)){if(Of(F$(Z,"package.json")))return Z;Z=s$(Z)}let Q=g0(J);if((Q==="index.ts"||Q==="index.js")&&s$(J)!==W)return s$(J);return J}function RA($,f){let J=Cy($,f);if(!J)return;let W=new Set;return r0(W,g0($)),r0(W,W9(g0($))),r0(W,g0(J)),r0(W,W9(g0(J))),r0(W,Z9(F$(J,"package.json"))),{installPath:J,entryPaths:[$],names:[...W].sort((Z,Q)=>Z.localeCompare(Q)),installed:!1}}function Ey($){let f=$.workspaceRoot?.trim()||$.cwd?.trim()||process.cwd();return yy(f).filter((J)=>Of(J))}function by($){let f=new Map;for(let J of $){for(let W of hy(J))f.set(W,Q9(W));for(let W of UA(J)){let Z=FA(W);if(Z){if(!f.has(Z))f.set(Z,Q9(Z));continue}let Q=RA(W,$);if(Q)f.set(Q.installPath,Q)}}return[...f.values()].sort((J,W)=>J.installPath.localeCompare(W.installPath))}function ky($,f){let J=J9(f);if(!J)return!1;if(J9($.installPath)===J)return!0;return $.names.some((W)=>J9(W)===J)}function Iy($,f,J){let W=Lf($);for(let Q of f){if(H9(W,Q.installPath))return Q;if(Q.entryPaths.some((j)=>Lf(j)===W))return Q}let Z=FA(W);if(Z)return Q9(Z);if(Of(W))return RA(W,J);return}function xy($){let f=c0(),J=f.disabledPlugins;if(!J?.length)return;let W=J.filter((Z)=>{let Q=Lf(Z);if(H9(Q,$.installPath))return!1;return!$.entryPaths.some((j)=>Lf(j)===Q)});if(W.length===J.length)return;j1({...f,disabledPlugins:W})}function my($){let f=s$($);while(f!==s$(f)&&g0(f)!==j9){try{Ly(f)}catch{return}f=s$(f)}}function gy($){return`${$.names[0]??g0($.installPath)} at ${$.installPath}`}async function vy($){let f=Ey($),J=by(f),W=$.path?.trim(),Z=$.name?.trim(),Q;if(W){if(Q=Iy(W,J,f),!Q)throw Error(`No plugin found at ${W}`)}else{if(!Z)throw Error("plugin uninstall requires a plugin name");let H=J.filter((X)=>ky(X,Z));if(H.length===0)throw Error(`No plugin found matching "${Z}"`);if(H.length>1)throw Error(`Multiple plugins match "${Z}": ${H.map(gy).join(", ")}`);Q=H[0]}let j=_y(Q.installPath,{throwIfNoEntry:!1});if(!j)throw Error(`Plugin install path does not exist: ${Q.installPath}`);if(Oy(Q.installPath,{recursive:j.isDirectory(),force:!0}),xy(Q),Q.installed)my(Q.installPath);return{name:Z||Q.names[0]||g0(Q.installPath),installPath:Q.installPath,removedPaths:[Q.installPath],entryPaths:Q.entryPaths}}import*as D0 from"@cline/llms";import{getClineEnvironmentConfig as uy}from"@cline/shared";function cy($){return $.apiKey??$.auth?.apiKey}function dy($){return($.auth?.accessToken?.trim()??"").length>0}function LA($){return $.split(/[-_]/).filter(Boolean).map((f)=>f.charAt(0).toUpperCase()+f.slice(1)).join(" ")}function ly($){let f=$.split(/\s+/).filter(Boolean);if(f.length===0)return"?";if(f.length===1)return f[0].slice(0,2).toUpperCase();return`${f[0][0]}${f[1][0]}`.toUpperCase()}function py($){let f=["#c4956a","#6b8aad","#e8963a","#5b9bd5","#6bbd7b","#9b7dd4","#d07f68","#57a6a1"],J=0;for(let W of $)J=J*31+W.charCodeAt(0)>>>0;return f[J%f.length]}function OA($){return Object.entries($).sort(([f],[J])=>f.localeCompare(J)).map(([f,J])=>wX(f,J))}async function ry($,f){let J=await D0.getModelsForProvider($);if(!f)return J;let W=await L6($,{loadPrivateOnAuth:!0,failOnError:!1},f);return W?.knownModels?{...J,...W.knownModels}:J}function X9($){return[...new Set(($??[]).map((f)=>f.trim()).filter(Boolean))]}function iy($){if(!$?.length)return;return[...new Set($)]}function ny($,f){return iy([...$??[],...f??[]])}function ay($){let f=$?.popularRank;return typeof f==="number"&&Number.isFinite(f)?f:Number.MAX_SAFE_INTEGER}function ty($){if(!$||typeof $!=="object")return!1;let f=$;return typeof f.path==="string"&&f.path.trim().length>0&&typeof f.label==="string"&&f.label.trim().length>0&&["text","password","url","number","select","boolean"].includes(String(f.type))}function sy($){let f=$?.configFields;if(!Array.isArray(f))return;return f.filter(ty)}var w4={path:"apiKey",label:"API Key",type:"password",placeholder:"Enter API key...",description:"API key issued by the provider.",secret:!0},DA={path:"baseUrl",label:"Base URL",type:"url",placeholder:"https://...",description:"Base endpoint used for provider requests."};function oy($){if(!$)return[w4];if($.source!=="system")return $.baseUrl?[w4,DA]:[w4];let f=[];if($.env?.length)f.push(w4);if($.baseUrl)f.push(DA);return f}function ey($,f){return f.split(".").reduce((J,W)=>{if(!J||typeof J!=="object")return;return J[W]},$)}function $q($){if(typeof $==="string"||typeof $==="number"||typeof $==="boolean"||$===null)return $;return}function fq($,f,J){if(!$?.length)return;let W={};for(let Z of $){let j=$q(Z.path==="baseUrl"&&f?.baseUrl===void 0?J?.baseUrl:ey(f,Z.path))??Z.defaultValue;if(j!==void 0)W[Z.path]=j}return W}function _A($){let f=Object.entries($??{}).filter(([J])=>J.trim().length>0);return f.length>0?Object.fromEntries(f):void 0}function Y9($,f){let J=f?.includes("vision")??!1,W=f?.includes("reasoning")??!1;return Object.fromEntries($.map((Z)=>[Z,{id:Z,name:Z,supportsVision:J,supportsAttachments:J,supportsReasoning:W}]))}async function zA($){if(!$.shouldRecompute)return $.fallbackModelIds??[];let f=$.modelsSourceUrl?await j8($.modelsSourceUrl,$.providerId):[];return[...new Set([...$.explicitModels??[],...f])]}function TA($,f){let J=$.read(),W=!1;if(J.providers[f])delete J.providers[f],W=!0;if(J.lastUsedProvider===f)delete J.lastUsedProvider,W=!0;if(W)$.write(J);D0.unregisterProvider(f)}async function Jq($,f){let J=f.providerId.trim().toLowerCase();if(!J)throw Error("providerId is required");let W=f.baseUrl.trim(),Z=f.apiKey?.trim()??"";if(!W&&!Z){let G=h1($);if((await Pf(G)).providers[J]){let P=await MA($,{providerId:J});return{providerId:J,settingsPath:P.settingsPath,modelsPath:P.modelsPath,modelsCount:0}}return TA($,J),{providerId:J,settingsPath:$.getFilePath(),modelsPath:G,modelsCount:0}}if(D0.hasProvider(J))throw Error(`provider "${J}" already exists`);let Q=f.name.trim();if(!Q)throw Error("name is required");if(!W)throw Error("baseUrl is required");let j=X9(f.models),H=f.modelsSourceUrl?.trim(),X=await zA({providerId:J,explicitModels:j,modelsSourceUrl:H,shouldRecompute:!0});if(X.length===0)throw Error("at least one model is required (manual or via modelsSourceUrl)");let Y=f.defaultModelId?.trim()&&X.includes(f.defaultModelId.trim())?f.defaultModelId.trim():X[0],A=f.capabilities?.length?[...new Set(f.capabilities)]:void 0,V=_A(f.headers);$.saveProviderSettings({provider:J,apiKey:Z||void 0,baseUrl:W,headers:V,timeout:f.timeoutMs,model:Y,protocol:f.protocol,client:f.client},{setLastUsed:!1});let B=h1($),K=await Pf(B);return K.providers[J]={provider:{name:Q,baseUrl:W,defaultModelId:Y,protocol:f.protocol,client:f.client,capabilities:A,modelsSourceUrl:H},models:Y9(X,A)},await f4(B,K),x2(J,K.providers[J]),{providerId:J,settingsPath:$.getFilePath(),modelsPath:B,modelsCount:X.length}}async function NA($,f){let J=f.providerId.trim().toLowerCase();if(!J)throw Error("providerId is required");let W=h1($),Z=await Pf(W),Q=Z.providers[J];if(!Q){let z=$.getProviderSettings(J);if(!z)throw Error(`provider "${J}" does not exist`);let D=f.modelsSourceUrl?.trim(),O=X9(f.models)[0]??z.model?.trim();if(!O&&!D)throw Error(`provider "${J}" cannot be updated because no model is configured`);Q={provider:{name:f.name?.trim()||LA(J),baseUrl:f.baseUrl?.trim()??z.baseUrl?.trim()??"",defaultModelId:O,protocol:z.protocol,client:z.client,capabilities:z.capabilities},models:O?Y9([O],z.capabilities):{}}}if(!Q.provider)throw Error(`provider "${J}" cannot be updated because it is a model overlay (no provider metadata)`);let j=f.name?.trim()??Q.provider.name.trim();if(!j)throw Error("name is required");let H=f.baseUrl?.trim()??Q.provider.baseUrl.trim();if(!H)throw Error("baseUrl is required");let X=f.capabilities===void 0?Q.provider.capabilities:f.capabilities===null?void 0:[...new Set(f.capabilities)],Y=f.protocol===void 0?Q.provider.protocol:f.protocol??void 0,A=f.client===void 0?Q.provider.client:f.client??void 0,V=X9(f.models),B=f.modelsSourceUrl===void 0?Q.provider.modelsSourceUrl:f.modelsSourceUrl?.trim()||void 0,K=f.models!==void 0||f.modelsSourceUrl!==void 0&&!!B,G=Object.keys(Q.models??{}).map((z)=>z.trim()).filter(Boolean),R=await zA({providerId:J,explicitModels:V,modelsSourceUrl:B,fallbackModelIds:G,shouldRecompute:K});if(R.length===0)throw Error("at least one model is required (manual or via modelsSourceUrl)");let P=f.defaultModelId===void 0?Q.provider.defaultModelId?.trim():f.defaultModelId?.trim(),F=P&&R.includes(P)?P:R[0],_={...$.getProviderSettings(J)??{},provider:J,baseUrl:H,model:F};if(Y)_.protocol=Y;else delete _.protocol;if(A)_.client=A;else delete _.client;if(f.apiKey!==void 0){let z=f.apiKey?.trim()??"";if(z)_.apiKey=z;else delete _.apiKey}if(f.headers!==void 0){let z=_A(f.headers);if(z)_.headers=z;else delete _.headers}if(f.timeoutMs!==void 0)if(typeof f.timeoutMs==="number")_.timeout=f.timeoutMs;else delete _.timeout;return $.saveProviderSettings(_,{setLastUsed:!1}),Z.providers[J]={provider:{name:j,baseUrl:H,defaultModelId:F,protocol:Y,client:A,capabilities:X,modelsSourceUrl:B},models:Y9(R,X)},await f4(W,Z),x2(J,Z.providers[J]),{providerId:J,settingsPath:$.getFilePath(),modelsPath:W,modelsCount:R.length}}async function MA($,f){let J=f.providerId.trim().toLowerCase();if(!J)throw Error("providerId is required");let W=h1($),Z=await Pf(W);if(!Z.providers[J])throw Error(`provider "${J}" does not exist`);return delete Z.providers[J],await f4(W,Z),D0.unregisterProvider(J),TA($,J),{providerId:J,settingsPath:$.getFilePath(),modelsPath:W}}async function Wq($){let f=$.read(),J=D0.getProviderIds(),W=await Promise.all(J.map(async(Q)=>{let[j,H]=await Promise.all([D0.getProvider(Q),D0.getModelsForProvider(Q)]),X=OA(H),Y=f.providers[Q]?.settings,A=j?.name??LA(Q),V=ny(j?.capabilities,Y?.capabilities),B=sy(j?.metadata)??oy(j);return{provider:{id:Q,name:A,models:X.length,color:py(Q),letter:ly(A),enabled:Boolean(Y),apiKey:Y?cy(Y):void 0,oauthAccessTokenPresent:Y?dy(Y):void 0,baseUrl:Y?.baseUrl??j?.baseUrl,defaultModelId:j?.defaultModelId,protocol:Y?.protocol??j?.protocol,client:Y?.client??j?.client,capabilities:V,authDescription:"This provider uses API keys for authentication.",baseUrlDescription:"The base endpoint to use for provider requests.",configFields:B,configValues:fq(B,Y,j),modelList:X},rank:ay(j?.metadata)}}));return W.sort((Q,j)=>{if(Q.rank!==j.rank)return Q.rank-j.rank;return Q.provider.name.localeCompare(j.provider.name)||Q.provider.id.localeCompare(j.provider.id)}),{providers:W.map((Q)=>Q.provider),settingsPath:$.getFilePath()}}async function Zq($,f){let J=$.trim(),W=await ry(J,f),Z=OA(W);return{providerId:J,models:Z}}function S4($){return $!=null&&typeof $==="object"&&!Array.isArray($)}function yA($,f){if(!S4(f))return S4($)?{...$}:void 0;let J=S4($)?{...$}:{};for(let[W,Z]of Object.entries(f)){if(Z==null||Z===""){delete J[W];continue}if(S4(Z)){let Q=yA(J[W],Z);if(Q&&Object.keys(Q).length>0)J[W]=Q;else delete J[W];continue}J[W]=Z}return Object.keys(J).length>0?J:void 0}function Qq($,f){let J=f.providerId.trim();if(f.enabled===!1){let Q=$.read();if(delete Q.providers[J],Q.lastUsedProvider===J)delete Q.lastUsedProvider;return $.write(Q),{providerId:J,enabled:!1,settingsPath:$.getFilePath()}}let Z={...$.getProviderSettings(J)??{},provider:J};for(let Q of["apiKey","baseUrl","model","region"])if(Object.hasOwn(f,Q)&&typeof f[Q]==="string")if(f[Q].trim().length===0)delete Z[Q];else Z[Q]=f[Q];for(let Q of["maxTokens","contextWindow","timeout","apiLine","protocol","client","routingProviderId","capabilities"])if(Object.hasOwn(f,Q))Z[Q]=f[Q];for(let Q of["auth","headers","reasoning","aws","gcp","azure","sap","oca"])if(Object.hasOwn(f,Q)&&f[Q]!=null){let j=yA(Z[Q],f[Q]);if(j)Z[Q]=j;else delete Z[Q]}return $.saveProviderSettings(Z,{setLastUsed:!1}),{providerId:J,enabled:!0,settingsPath:$.getFilePath()}}async function jq($,f){let J=f.trim(),W=$.getProviderSettings(J),Q=D0.MODEL_COLLECTIONS_BY_PROVIDER_ID[J]?.provider,j=W?.baseUrl?.trim()||Q?.baseUrl?.trim(),H=H8(j,Q?.baseUrl,Q?.modelsSourceUrl);if(!W||!Q||!j||!H)return{providerId:J,refreshed:!1};let X=await NA($,{providerId:J,name:Q.name,baseUrl:j,apiKey:W.apiKey,headers:W.headers??null,timeoutMs:W.timeout??null,modelsSourceUrl:H,protocol:W.protocol??Q.protocol??null,client:W.client??Q.client??null,capabilities:W.capabilities??null});return{providerId:J,refreshed:!0,modelsCount:X.modelsCount}}function Hq($){let f=$.trim().toLowerCase();if(f==="codex"||f==="openai-codex")return"openai-codex";if(f==="cline"||f==="oca")return f;throw Error(`provider "${$}" does not support OAuth login (supported: cline, oca, openai-codex)`)}function Xq($,f){if($==="cline")return f.access.startsWith("workos:")?f.access:`workos:${f.access}`;return f.access}async function Yq($,f,J,W){let Z=x4({onPrompt:async(Q)=>Q.defaultValue??"",openUrl:J,onOpenUrlError:({error:Q})=>{throw Q instanceof Error?Q:Error(String(Q))}});if($==="cline")return f8({apiBaseUrl:f?.baseUrl?.trim()||uy().apiBaseUrl,useWorkOSDeviceAuth:!0,callbacks:Z,telemetry:W});if($==="oca")return Q8({mode:f?.oca?.mode,callbacks:Z,telemetry:W});return W8({onAuth:Z.onAuth,onPrompt:Z.onPrompt,onProgress:Z.onProgress,onManualCodeInput:Z.onManualCodeInput,telemetry:W})}function Aq($,f,J,W){let Z={...J?.auth??{},accessToken:Xq(f,W),refreshToken:W.refresh,accountId:W.accountId,expiresAt:W.expires},Q={...J??{provider:f},provider:f,auth:Z};return $.saveProviderSettings(Q,{tokenSource:"oauth"}),Q}function Vq($){let f=$?.auth?.accessToken?.trim()||$?.apiKey?.trim();return f&&f.length>0?f:void 0}import*as h4 from"@cline/llms";import{isOAuthProviderId as Bq}from"@cline/shared";var Kq=["apiKey","baseUrl","awsRegion","awsProfile","sapClientId","sapClientSecret","sapTokenUrl","sapResourceGroup","sapDeploymentId"],Gq={bedrock:{mode:"replace",description:"AWS region is required for Bedrock. It can be auto-filled from AWS_REGION, AWS_DEFAULT_REGION, or ~/.aws/config.",fields:{awsRegion:{label:"AWS Region",placeholder:"us-east-1"},apiKey:{label:"AWS Bedrock API Key (optional)",placeholder:"Leave blank to use AWS profile/default chain",optional:!0},awsProfile:{label:"AWS Profile Name (optional)",placeholder:"default",optional:!0}}},ollama:{fields:{apiKey:{note:"Keep empty if no API key for local inference."}}},sapaicore:{mode:"replace",description:"SAP AI Core uses OAuth client credentials and an AI Core API URL, not a generic API key.",fields:{baseUrl:{label:"AI Core Base URL",placeholder:"https://api.ai.<region>.aws.ml.hana.ondemand.com"},sapClientId:{label:"Client ID",placeholder:"sb-...|xsuaa_std!b..."},sapClientSecret:{label:"Client Secret",placeholder:"SAP AI Core client secret"},sapTokenUrl:{label:"Token URL",placeholder:"https://<subdomain>.authentication.sap.hana.ondemand.com"},sapResourceGroup:{label:"Resource Group",placeholder:"default",optional:!0},sapDeploymentId:{label:"Deployment ID",placeholder:"SAP AI Core deployment id",optional:!0}}}};function Pq($,f){let J={};for(let W of Kq){let Z=$[W],Q=f[W];if(Z||Q)J[W]={...Z,...Q}}return J}function Fq($){let f=Gq[$.providerId];if(!f)return $;return{...$,description:f.description??$.description,fields:f.mode==="replace"?f.fields:Pq($.fields,f.fields)}}var Uq=new Set(["ollama","lmstudio","litellm","openai-compatible"]);function Rq($,f){if(!f?.provider.baseUrl)return!1;if(f.provider.source!=="system")return!0;return Uq.has($)}function Dq($){let f=h4.normalizeProviderId($);if(Bq(f))return{providerId:f,authMethod:"oauth",fields:{}};let J=h4.MODEL_COLLECTIONS_BY_PROVIDER_ID[f];if(J?.provider.capabilities?.includes("local-auth"))return{providerId:f,authMethod:"local",fields:{}};let W=J?.provider.baseUrl,Z={apiKey:{}};if(Rq(f,J))Z.baseUrl={defaultValue:W};return Fq({providerId:f,authMethod:"api-key",fields:Z})}B0();O4();import{appendFileSync as Lq,existsSync as A9,mkdirSync as Oq,readFileSync as _q,renameSync as zq,unlinkSync as Tq,writeFileSync as Nq}from"node:fs";import{join as V9}from"node:path";import{resolveTeamDataDir as Mq}from"@cline/shared/storage";function yq($){return $.toLowerCase().replace(/[^a-z0-9._-]+/g,"-").replace(/^-+|-+$/g,"")}class qA{dirPath;statePath;taskHistoryPath;teammateSpecs=new Map;constructor($){let f=yq($.teamName),J=$.baseDir?.trim()||Mq();this.dirPath=V9(J,f),this.statePath=V9(this.dirPath,"state.json"),this.taskHistoryPath=V9(this.dirPath,"task-history.jsonl")}loadState(){if(!A9(this.statePath))return;try{let $=_q(this.statePath,"utf8"),f=JSON.parse($);if(f.version!==1||!f.teamState)return;for(let J of f.teammates??[])this.teammateSpecs.set(J.agentId,J);return bH(f.teamState)}catch{return}}getTeammateSpecs(){return Array.from(this.teammateSpecs.values())}upsertTeammateSpec($){this.teammateSpecs.set($.agentId,$)}removeTeammateSpec($){this.teammateSpecs.delete($)}persist($){if(!this.hasPersistableState($)){this.clearPersistedState();return}this.ensureDir();let f={version:1,updatedAt:new Date().toISOString(),teamState:$.exportState(),teammates:Array.from(this.teammateSpecs.values())},J=`${this.statePath}.tmp`;Nq(J,`${JSON.stringify(f,null,2)}
|
|
716
|
+
`,"utf8"),zq(J,this.statePath)}appendTaskHistory($){let f={};switch($.type){case"team_task_updated":f=$.task;break;case"team_message":f={agentId:$.message.fromAgentId,toAgentId:$.message.toAgentId,subject:$.message.subject,taskId:$.message.taskId};break;case"team_mission_log":f={agentId:$.entry.agentId,kind:$.entry.kind,summary:$.entry.summary,taskId:$.entry.taskId};break;case"teammate_spawned":case"teammate_shutdown":case"task_start":f={agentId:$.agentId,message:"message"in $?$.message:void 0};break;case"task_end":f={agentId:$.agentId,finishReason:$.result?.finishReason,error:$.error?.message};break;case"agent_event":f={agentId:$.agentId,eventType:$.event.type};break}this.ensureDir(),Lq(this.taskHistoryPath,`${JSON.stringify({ts:new Date().toISOString(),type:$.type,task:f})}
|
|
717
|
+
`,"utf8")}ensureDir(){if(!A9(this.dirPath))Oq(this.dirPath,{recursive:!0})}hasPersistableState($){let f=$.exportState();if(this.teammateSpecs.size>0)return!0;if(f.members.some((J)=>J.role==="teammate"))return!0;return f.tasks.length>0||f.mailbox.length>0||f.missionLog.length>0}clearPersistedState(){if(A9(this.statePath))Tq(this.statePath)}}import{z as w}from"zod";var wA=w.object({workspaceRoot:w.string().min(1),cwd:w.string().optional(),provider:w.string().min(1),model:w.string().min(1),mode:w.enum(["act","plan"]).default("act"),apiKey:w.string(),systemPrompt:w.string().optional(),rules:w.string().optional(),maxIterations:w.number().int().positive().optional(),enableTools:w.boolean(),enableSpawn:w.boolean().optional(),enableTeams:w.boolean().optional(),autoApproveTools:w.boolean().optional(),missionStepInterval:w.number().int().positive().optional(),missionTimeIntervalMs:w.number().int().positive().optional()}),SA=w.enum(["idle","starting","running","pending","stopping","completed","cancelled","failed","error"]),hA=w.enum(["user","assistant","tool","system","status","error"]),CA=w.object({id:w.string().min(1),sessionId:w.string().nullable(),role:hA,content:w.string(),createdAt:w.number().int().nonnegative(),meta:w.object({stream:w.enum(["stdout","stderr"]).optional(),toolName:w.string().optional(),iteration:w.number().int().nonnegative().optional(),agentId:w.string().optional(),conversationId:w.string().optional(),hookEventName:w.string().optional(),inputTokens:w.number().int().nonnegative().optional(),outputTokens:w.number().int().nonnegative().optional(),checkpoint:w.object({ref:w.string(),createdAt:w.number().int().nonnegative(),runCount:w.number().int().positive(),kind:w.enum(["stash","commit"]).optional()}).optional()}).optional()}),EA=w.object({toolCalls:w.number().int().nonnegative(),tokensIn:w.number().int().nonnegative(),tokensOut:w.number().int().nonnegative()}),qq=w.object({sessionId:w.string().nullable(),status:SA,config:wA,messages:w.array(CA),rawTranscript:w.string(),error:w.string().nullable(),summary:EA});var wq=vj;import{Agent as ar,createAgentRuntime as tr}from"@cline/agents";import{getClineEnvironmentConfig as Sq}from"@cline/shared";var hq=5000,kA={recommended:[{id:"anthropic/claude-opus-4.6",name:"Claude Opus 4.6",description:"Most intelligent model for agents and coding",tags:["BEST"]},{id:"anthropic/claude-sonnet-4.6",name:"Claude Sonnet 4.6",description:"Strong coding and agent performance",tags:["NEW"]},{id:"google/gemini-3.1-pro-preview",name:"Gemini 3.1 Pro Preview",description:"1M context window, strong coding performance",tags:["NEW"]},{id:"openai/gpt-5.3-codex",name:"GPT-5.3 Codex",description:"OpenAI's latest with strong coding abilities",tags:["NEW"]}],free:[{id:"kwaipilot/kat-coder-pro",name:"KwaiKAT Kat Coder Pro",description:"Advanced agentic coding model",tags:["FREE"]},{id:"arcee-ai/trinity-large-preview:free",name:"Arcee AI Trinity Large Preview",description:"Advanced large preview model",tags:["FREE"]}]};function Cq($){return{recommended:$.recommended.map((f)=>({...f,tags:[...f.tags]})),free:$.free.map((f)=>({...f,tags:[...f.tags]}))}}function bA($){if(!$||typeof $!=="object")return null;let f=$;if(typeof f.id!=="string"||f.id.length===0)return null;return{id:f.id,name:typeof f.name==="string"&&f.name.length>0?f.name:f.id,description:typeof f.description==="string"?f.description:"",tags:Array.isArray(f.tags)?f.tags.filter((J)=>typeof J==="string"):[]}}function Eq($){if(!$||typeof $!=="object")return null;let f=$,J=Array.isArray(f.recommended)?f.recommended:[],W=Array.isArray(f.free)?f.free:[],Z=J.map(bA).filter((j)=>j!==null),Q=W.map(bA).filter((j)=>j!==null);if(Z.length===0&&Q.length===0)return null;return{recommended:Z,free:Q}}function bq($){let f=$.baseUrl?.trim();if(f)return f;let J=Sq().apiBaseUrl;try{return($.providerSettingsManager??new n$).getProviderSettings("cline")?.baseUrl?.trim()||J}catch{return J}}async function kq($,f,J){let W=new AbortController,Z=setTimeout(()=>W.abort(),J);try{return await $(f,{signal:W.signal})}finally{clearTimeout(Z)}}async function Iq($={}){try{let f=bq($),J=$.fetchImpl??fetch,W=await kq(J,`${f}/api/v1/ai/cline/recommended-models`,$.timeoutMs??hq);if(!W.ok)throw Error(`HTTP ${W.status}`);let Z=await W.json(),Q=Eq(Z);if(Q)return Q}catch{}return Cq(kA)}import{readFile as xq}from"node:fs/promises";import mq from"node:path";function gq($){return $}async function vq($){let f=mq.resolve($),J=await xq(f,"utf8"),W;try{W=JSON.parse(J)}catch(Z){let Q=Z instanceof Error?Z.message:String(Z);throw Error(`Failed to parse JSON config at "${f}": ${Q}`)}return uq(W,f)}function uq($,f){if(!$||typeof $!=="object")throw Error(`Invalid llms config in "${f}": expected an object.`);let W=$.providers;if(!Array.isArray(W))throw Error(`Invalid llms config in "${f}": "providers" must be an array.`);if(!W.length)throw Error(`Invalid llms config in "${f}": "providers" cannot be empty.`);return $}import{BUILT_IN_PROVIDER_IDS as mA,createHandler as lq,createHandlerAsync as pq,getProviderCollection as rq,hasProvider as gA,registerAsyncHandler as iq,registerHandler as nq,registerModel as aq,registerProvider as vA}from"@cline/llms";function IA($){return $?{...$}:{}}function cq($,f){if($)return $;if(!f)return;let J=globalThis.process;if(!J?.env)return;return J.env[f]}function dq($,f){if(!f.length)throw Error(`Provider "${$}" must include at least one model.`)}function xA($){let f=Object.keys($.collection.models);return{id:$.collection.provider.id,name:$.collection.provider.name,description:$.collection.provider.description,protocol:$.collection.provider.protocol,baseUrl:$.collection.provider.baseUrl,capabilities:$.collection.provider.capabilities,env:$.collection.provider.env,models:f,defaultModel:$.collection.provider.defaultModelId,modelCount:f.length}}class B9{providers=new Map;register($){dq($.id,$.models);let f=$.defaultModel??$.models[0];if(!f)throw Error(`Provider "${$.id}" must define a default model.`);if(!$.models.includes(f))throw Error(`Default model "${f}" is not included in configured models for "${$.id}".`);let J=this.providers.get($.id);this.providers.set($.id,{id:$.id,models:new Set([...J?.models??[],...$.models]),defaultModel:f,defaults:{...J?.defaults??{},...IA($.defaults)}})}registerSelectionConfig($){this.register({id:$.id,models:$.models,defaultModel:$.defaultModel,defaults:{apiKey:cq($.apiKey,$.apiKeyEnv),routingProviderId:$.builtinProviderId,baseUrl:$.baseUrl,headers:$.headers,timeoutMs:$.timeoutMs,capabilities:$.capabilities,...IA($.settings)}})}registerModel($,f){let J=this.providers.get($);if(!J){this.providers.set($,{id:$,models:new Set([f]),defaultModel:f,defaults:{}});return}J.models.add(f)}createHandlerConfig($){let f=this.require($.providerId),J=$.modelId??f.defaultModel;if(!f.models.has(J))throw Error(`Model "${J}" is not configured for provider "${$.providerId}".`);return{providerId:$.providerId,modelId:J,...f.defaults,...$.overrides}}list(){return Array.from(this.providers.values()).map(($)=>({id:$.id,models:Array.from($.models),defaultModel:$.defaultModel}))}getModels($){return Array.from(this.require($).models)}hasProvider($){return this.providers.has($)}hasModel($,f){return this.providers.get($)?.models.has(f)??!1}require($){let f=this.providers.get($);if(!f)throw Error(`Provider "${$}" is not configured in this SDK instance.`);return f}}class K9{configuredProviders=new B9;constructor($){this.applyConfig($)}createHandler($){return lq(this.configuredProviders.createHandlerConfig($))}async createHandlerAsync($){return pq(this.configuredProviders.createHandlerConfig($))}registerProvider($){if(vA($.collection),$.handlerFactory&&$.asyncHandlerFactory)throw Error(`Provider "${$.collection.provider.id}" cannot register both sync and async handlers.`);if($.handlerFactory)nq($.collection.provider.id,$.handlerFactory);if($.asyncHandlerFactory)iq($.collection.provider.id,$.asyncHandlerFactory);this.configuredProviders.register({id:$.collection.provider.id,models:$.exposeModels??Object.keys($.collection.models),defaultModel:$.defaultModel??$.collection.provider.defaultModelId,defaults:$.defaults})}registerBuiltinProvider($){let f=$.exposeModels??Object.keys($.models),J=$.defaultModel??f[0];if(!J)throw Error(`Provider "${$.id}" must define a default model.`);vA({provider:{id:$.id,name:$.name??$.id,description:$.description,protocol:$.protocol,baseUrl:$.baseUrl,defaultModelId:J,client:$.client??"openai-compatible",capabilities:$.capabilities,env:$.env,source:"system"},models:$.models}),this.configuredProviders.register({id:$.id,models:f,defaultModel:J,defaults:{routingProviderId:$.builtinProviderId,...$.defaults??{}}})}registerModel($){aq($.providerId,$.modelId,$.info),this.configuredProviders.registerModel($.providerId,$.modelId)}getProviders(){return this.configuredProviders.list()}getBuiltInProviderIds(){return[...mA]}async getBuiltInProviders(){return(await Promise.all(mA.map((f)=>rq(f)))).filter((f)=>f!==void 0).map((f)=>xA({collection:f}))}getModels($){return this.configuredProviders.getModels($)}isProviderConfigured($){return this.configuredProviders.hasProvider($)}isModelConfigured($,f){return this.configuredProviders.hasModel($,f)}applyConfig($){for(let f of $.providers)this.configuredProviders.registerSelectionConfig(f);for(let f of $.models??[])this.registerModel(f);for(let f of $.customProviders??[])this.registerProvider(f);for(let f of this.configuredProviders.list()){let J=gA(f.id),W=this.configuredProviders.createHandlerConfig({providerId:f.id,modelId:f.defaultModel}).routingProviderId,Z=typeof W==="string"&&gA(W);if(!J&&!Z)throw Error(`Provider "${f.id}" is not known. Register it through customProviders/registerProvider, registerBuiltinProvider, or use a built-in provider ID.`)}}}function tq($){return new K9($)}bZ();async function hp(){return Promise.resolve().then(() => (eZ(),VA))}export{ij as writeHubDiscovery,j1 as writeGlobalSettings,nj as withHubStartupLock,m$ as verifyHubConnection,$2 as updateMcpServerOAuthState,NA as updateLocalProvider,vy as uninstallPlugin,gZ as truncateNotificationBody,M6 as toggleDisabledTool,mJ as toTeamProgressLifecycleEvent,Z$ as toProviderConfig,pD as toHubHealthUrl,ZZ as toHookConfigFileName,dJ as summarizeUsageFromMessages,iL as stopLocalHubServerGracefully,W$ as startLocalOAuthServer,oZ as startHubWebSocketServer,Ll as startHubServer,KV as startClineDeviceAuth,I5 as splitCoreSessionConfig,qJ as spawnDetachedHubServerWithRetry,ML as spawnDetachedHubServer,pB as setTelemetryOptOutGlobally,of as setMcpServerDisabled,FQ as setDisabledTools,nB as setDisabledPlugin,Kc as sendHubCommand,Qq as saveLocalProviderSettings,Aq as saveLocalProviderOAuthCredentials,G2 as sanitizeSessionToken,HQ as safeParseSettings,zB as safeCreateProviderConfig,V4 as runSubprocessEvent,K4 as runHook,O3 as reviveTeamStateDates,HH as restartLocalHubIfIdleAfterStartupTimeout,uk as resolveWorkspaceHubOwnerContext,W5 as resolveWorkflowsConfigSearchPaths,f5 as resolveSkillsConfigSearchPaths,R0 as resolveSharedHubOwnerContext,WN as resolveSessionBackend,J5 as resolveRulesConfigSearchPaths,L6 as resolveProviderConfig,bf as resolvePluginSkillDirectoriesFromPaths,c6 as resolvePluginConfigSearchPaths,h$ as resolveMcpServerRegistrations,Vq as resolveLocalClineAuthToken,tN as resolveHubUrl,z1 as resolveHubOwnerContext,x$ as resolveHubEndpointOptions,Hf as resolveHubBuildId,JZ as resolveHooksConfigSearchPaths,Q$ as resolveDisabledToolNames,D8 as resolveDisabledPluginPaths,S0 as resolveDefaultMcpSettingsPath,yJ as resolveDefaultHubPort,JL as resolveDefaultHubPathname,fL as resolveDefaultHubHost,N3 as resolveCoreSelectedToolIds,NW as resolveCompatibleLocalHubUrl,Ck as resolveClineDir,DW as resolveClineDataDir,q8 as resolveAndLoadAgentPlugins,Ef as resolveAgentPluginPaths,LW as requestHubShutdown,Uy as requestDesktopToolApproval,Xf as rememberRecoverableLocalHubUrl,GA as registerRemoteConfigSessionBlobUpload,f2 as registerMcpServersFromSettingsFile,ap as registerDisposable,jq as refreshProviderModelsFromSource,H6 as refreshOpenAICodexToken,K6 as refreshOcaToken,Q6 as refreshClineToken,UZ as readSessionCheckpointHistory,Hy as readRemoteConfigSessionBlobUploadMetadata,K0 as readHubDiscovery,c0 as readGlobalSettings,I$ as probeHubServer,Bc as probeHubConnection,h7 as prewarmFileIndex,sj as prewarmDetachedHubServer,Ay as prepareRemoteConfigCoreIntegration,$5 as parseWorkflowConfigFromMarkdown,np as parseUserCommandEnvelope,o6 as parseSkillConfigFromMarkdown,jQ as parseSettings,e6 as parseRuleConfigFromMarkdown,B4 as parseHookEventPayload,zV as openaiCodexOAuthProvider,R1 as normalizeWorkspacePath,ip as normalizeUserInput,rp as normalizeSdkError,U0 as normalizeRuntimeCapabilities,G8 as normalizeProviderId,_V as normalizeOpenAICodexCredentials,Hq as normalizeOAuthProvider,Yf as normalizeHubWebSocketUrl,pp as noopBasicLogger,GZ as migrateLegacyProviderSettings,k8 as mergeRulesForSystemPrompt,I2 as mergeAgentHooks,ZW as makeTeamTaskSubSessionId,_J as makeSubSessionId,W8 as loginOpenAICodex,Q8 as loginOcaOAuth,Yq as loginLocalProvider,f8 as loginClineOAuth,hp as loadOpenTelemetryAdapter,sf as loadMcpSettingsFile,vq as loadLlmsConfigFromFile,hf as loadAgentPluginsFromPathsWithDiagnostics,hQ as loadAgentPluginsFromPaths,I6 as loadAgentPluginFromPath,SD as listSessionHistoryFromBackend,o3 as listPluginToolsWithDiagnostics,k5 as listPluginTools,h5 as listMcpServerOAuthStatuses,Wq as listLocalProviders,Kf as listHookConfigFiles,rB as isToolDisabledGlobally,N6 as isTelemetryOptedOutGlobally,U1 as isSessionNotFoundError,tQ as isRuleEnabled,iB as isPluginDisabledGlobally,OV as isOpenAICodexTokenExpired,vL as isHubReconnectableTransportError,QH as isHubCommandTimeoutError,kk as isDiscoveryFilePresent,R9 as isClineAccountActionRequest,DB as isBuiltInProviderId,O$ as identifyAccount,P1 as hasMcpSettingsFile,X6 as getValidOpenAICodexCredentials,G6 as getValidOcaCredentials,j6 as getValidClineCredentials,Dq as getProviderConfigFields,a9 as getProviderConfig,ef as getMcpServerOAuthState,Zq as getLocalProviderModels,K8 as getLiveModelsCatalog,A1 as getFileIndex,C_ as getCurrentContextSize,y5 as getCoreHeadlessToolNames,T3 as getCoreDefaultEnabledToolIds,rf as getCoreBuiltinToolCatalog,M3 as getCoreAcpToolNames,kp as getClineDefaultSystemPrompt,u5 as generateWorkspaceInfoWithDiagnostics,LJ as generateWorkspaceInfo,v9 as generateOcaOpcRequestId,b8 as formatRulesForSystemPrompt,lp as formatDisplayUserInput,q6 as filterExtensionToolRegistrations,p1 as filterDisabledTools,y6 as filterDisabledPluginPaths,Iq as fetchClineRecommendedModels,D9 as executeClineAccountAction,AA as ensureHubWebSocketServer,Ol as ensureHubServer,ok as ensureDetachedHubServer,IX as ensureCustomProvidersLoaded,z2 as ensureCompatibleLocalHubUrl,t8 as enrichPromptWithMentions,dp as emptyWorkspaceManifest,Gf as emptyStoredProviderSettings,d6 as discoverPluginModulePaths,QW as deriveSubsessionStatus,MA as deleteLocalProvider,gq as defineLlmsConfig,j5 as createWorkflowsConfigDefinition,Wf as createUserInstructionConfigService,k7 as createToolPoliciesWithPreset,cp as createTool,fY as createTeamName,PY as createSubprocessHooks,Jf as createSpawnAgentTool,Z5 as createSkillsConfigDefinition,A4 as createSessionHost,A4 as createRuntimeHost,Q5 as createRulesConfigDefinition,Yy as createRemoteConfigSessionMessagesArtifactUploader,_B as createProviderConfig,D4 as createOpenTelemetryTelemetryService,lV as createOcaRequestHeaders,dV as createOcaOAuthProvider,x4 as createOAuthClientCallbacks,PJ as createMcpTools,Nc as createLocalHubScheduleRuntimeHandlers,tq as createLlmsSdk,G0 as createInitialAccumulatedUsage,bk as createInMemoryHubOwnerContext,A$ as createHubServerUrl,rj as createHubAuthToken,XZ as createHookConfigFileHooks,aJ as createHookConfigFileExtension,nJ as createHookAuditHooks,b5 as createDisabledMcpToolPolicy,t3 as createDisabledMcpToolPolicies,WJ as createDelegatedAgentConfigProvider,ZJ as createDelegatedAgent,I7 as createDefaultToolsWithPreset,e1 as createDefaultTools,KJ as createDefaultMcpServerClientFactory,$J as createDefaultExecutors,Z2 as createCoreSettingsService,g$ as createCoreSessionSnapshot,up as createContributionRegistry,eW as createContextCompactionPrepareTurn,k1 as createConfiguredTelemetryService,L4 as createConfiguredTelemetryHandle,vp as createClineTelemetryServiceMetadata,gp as createClineTelemetryServiceConfig,PV as createClineOAuthProvider,nf as createBuiltinTools,pf as createAgentTeamsTools,tr as createAgentRuntime,lJ as createAgentHooksExtension,DY as connectToHub,GV as completeClineDeviceAuth,FB as clearPrivateModelsCatalogCache,PB as clearLiveModelsCatalogCache,e0 as clearHubDiscovery,oA as captureWorkspacePathResolved,m4 as captureWorkspaceInitialized,g4 as captureWorkspaceInitError,l4 as captureToolUsage,c4 as captureTokenUsage,u4 as captureTaskRestarted,v4 as captureTaskCreated,a2 as captureTaskCompleted,s2 as captureSubagentExecution,p4 as captureSkillUsed,mp as captureSdkError,eA as captureProviderConfigured,t2 as captureProviderApiError,d4 as captureModeSwitch,i4 as captureMentionUsed,a4 as captureMentionSearchResults,n4 as captureMentionFailed,s4 as captureHookDiscovery,sA as captureExtensionActivated,r4 as captureDiffEditFailure,Tf as captureConversationTurnEvent,e4 as captureCompactionSkipped,o4 as captureCompactionExecuted,D$ as captureAuthSucceeded,R$ as captureAuthStarted,f1 as captureAuthLoggedOut,L$ as captureAuthFailed,t4 as captureAgentTeamCreated,J1 as captureAgentCreated,c5 as buildWorkspaceMetadata,xJ as buildTeamProgressSummary,Ip as buildSdkErrorProperties,BA as buildRemoteConfigSessionBlobUploadMetadata,df as buildDelegatedAgentConfig,HJ as bootstrapAgentTeams,v3 as authorizeMcpServerOAuth,Jq as addLocalProvider,Y0 as accumulateUsageTotals,n6 as WORKFLOWS_CONFIG_DIRECTORY_NAME,yf as UnifiedConfigFileWatcher,s0 as ToolPresets,d2 as TelemetryService,R4 as TelemetryLoggerSink,jJ as TEAM_TOOL_NAMES,O8 as SubprocessSandbox,sJ as StoredProviderSettingsSchema,FX as StoredProviderSettingsEntrySchema,m2 as SqliteTeamStore,c$ as SqliteSessionStore,Uf as SessionVersioningService,p0 as SessionVersioningError,F0 as SessionSource,F1 as SessionNotFoundError,WQ as SapSettingsSchema,i6 as SKILLS_CONFIG_DIRECTORY_NAME,z6 as SESSION_STATUSES,Q2 as SESSION_NOT_FOUND_ERROR_CODE,tp as SDK_ERROR_TELEMETRY_EVENT,I4 as RpcClineAccountService,hJ as RemoteRuntimeHost,e9 as ReasoningSettingsSchema,dQ as RULES_CONFIG_DIRECTORY_NAME,KA as REMOTE_CONFIG_SESSION_BLOB_UPLOAD_METADATA_KEY,l1 as ProviderSettingsSchema,n$ as ProviderSettingsManager,t9 as ProviderProtocolSchema,_6 as ProviderIdSchema,s9 as ProviderClientSchema,l2 as OpenTelemetryProvider,ZQ as OcaSettingsSchema,D6 as OPENAI_COMPATIBLE_PROVIDERS,V$ as NodeHubClient,tZ as NativeHubTransportAdapter,QQ as ModelCatalogSettingsSchema,a$ as LocalRuntimeHost,Ep as Llms,oJ as InMemoryWorkspaceManager,J2 as InMemoryMcpManager,fM as HubUIClient,b0 as HubTransportError,$M as HubSessionClient,y4 as HubServerTransport,U4 as HubScheduleService,G4 as HubScheduleCommandService,M1 as HubRuntimeHost,wJ as HubCommandError,KY as HookEventPayloadSchema,BY as HookEventNameSchema,pJ as HookConfigFileName,WZ as HOOK_CONFIG_FILE_EVENT_MAP,HX as HOOKS_CONFIG_DIRECTORY_NAME,R8 as GlobalSettingsSchema,fQ as GcpSettingsSchema,qA as FileTeamPersistenceStore,kA as FALLBACK_CLINE_RECOMMENDED_MODELS,j0 as DefaultToolNames,H4 as DefaultRuntimeBuilder,K9 as DefaultLlmsSdk,r9 as DEFAULT_MODELS_CATALOG_URL,eD as DEFAULT_HUB_PORT,$L as DEFAULT_HUB_PATHNAME,oD as DEFAULT_HUB_HOST,jf as CoreSettingsService,d$ as CoreSessionService,xp as ContributionRegistry,CZ as ClineCore,k4 as ClineAccountService,qq as ChatViewStateSchema,EA as ChatSummarySchema,SA as ChatSessionStatusSchema,wA as ChatSessionConfigSchema,CA as ChatMessageSchema,hA as ChatMessageRoleSchema,k as CORE_TELEMETRY_EVENTS,wq as CORE_BUILD_VERSION,aZ as BrowserWebSocketHubAdapter,RB as BUILT_IN_PROVIDER_IDS,O6 as BUILT_IN_PROVIDER,JQ as AzureSettingsSchema,$Q as AwsSettingsSchema,o9 as AuthSettingsSchema,q2 as AgentTeamsRuntime,bW as AgentTeam,ar as Agent,s1 as ALL_DEFAULT_TOOL_NAMES};
|