sliccy 2.45.3 → 2.45.4
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/ui/assets/{adobe-B6wBtBjn.js → adobe-avKwr7Dm.js} +1 -1
- package/dist/ui/assets/{adobe-B4g7AOSY.js → adobe-tvf67GRq.js} +1 -1
- package/dist/ui/assets/{agent-bridge-BIqfSVu2.js → agent-bridge-DiVkgwz-.js} +1 -1
- package/dist/ui/assets/{agent-message-to-chat-Dnnrujom.js → agent-message-to-chat-Cbt_9_fN.js} +1 -1
- package/dist/ui/assets/{anthropic-BoDcD0xs.js → anthropic-CJwUhBlX.js} +1 -1
- package/dist/ui/assets/{anthropic-vh-aBoE_.js → anthropic-CWEVurmr.js} +1 -1
- package/dist/ui/assets/{azure-openai-CMUTac7w.js → azure-openai-BdX0RC5r.js} +1 -1
- package/dist/ui/assets/{azure-openai-responses-Crk9DqJp.js → azure-openai-responses-BDfegDRI.js} +1 -1
- package/dist/ui/assets/{azure-openai-responses-Bx6yBVfU.js → azure-openai-responses-DJ9LbDv9.js} +1 -1
- package/dist/ui/assets/{azure-openai-DpX78gmt.js → azure-openai-tDQwCw_S.js} +1 -1
- package/dist/ui/assets/{bedrock-camp-CkuZf5jK.js → bedrock-camp-BTPbdI5P.js} +2 -2
- package/dist/ui/assets/{bedrock-camp-tuaApwJn.js → bedrock-camp-DZoSTfJa.js} +3 -3
- package/dist/ui/assets/{cdp-ClOGGuy0.js → cdp-B-G1EOxs.js} +2 -2
- package/dist/ui/assets/cost-command-BtV9Fq05.js +1 -0
- package/dist/ui/assets/{es-Cjr2MR0R.js → es-a26K4k4j.js} +1 -1
- package/dist/ui/assets/{fs-Bnfvl1-T.js → fs-BxaZxvu8.js} +2 -2
- package/dist/ui/assets/{fs-BKcSjdXB.js → fs-C5Bh6SAK.js} +3 -3
- package/dist/ui/assets/{github-Ctpw7yW7.js → github-BdUQG7nB.js} +1 -1
- package/dist/ui/assets/{github-B97_s3v4.js → github-CXH07t6L.js} +2 -2
- package/dist/ui/assets/{google-DMNlmX9j.js → google-BAax5yWz.js} +1 -1
- package/dist/ui/assets/{google-B0fvtsLh.js → google-DtE60DkT.js} +1 -1
- package/dist/ui/assets/index-BPKmYW7p.css +1 -0
- package/dist/ui/assets/{index-BepIlMll.js → index-C59z0nlR.js} +6 -6
- package/dist/ui/assets/{kernel-worker-BulN1Taf.js → kernel-worker-Cpe3B5AZ.js} +599 -599
- package/dist/ui/assets/{local-llm-B4JQAghf.js → local-llm-Cz-Egtek.js} +1 -1
- package/dist/ui/assets/{local-llm-DAt3aDPa.js → local-llm-D6PNDXul.js} +1 -1
- package/dist/ui/assets/{magick-wasm-CQC5E0LF.js → magick-wasm-C0UYrNr8.js} +1 -1
- package/dist/ui/assets/{mistral-CkD2H9Iq.js → mistral-B5chjbWN.js} +1 -1
- package/dist/ui/assets/{mistral-BUFp9pi9.js → mistral-Bm7Flw3U.js} +1 -1
- package/dist/ui/assets/{mount-BeFMKlu0.js → mount-BtuRh1GY.js} +1 -1
- package/dist/ui/assets/{mount-D6dUvorm.js → mount-CeV8nQDH.js} +2 -2
- package/dist/ui/assets/{nuke-command-Dbhl4q0W.js → nuke-command-Kwh9fpJ-.js} +1 -1
- package/dist/ui/assets/{oauth-bootstrap-CGg3ArUs.js → oauth-bootstrap-CJU0rioR.js} +1 -1
- package/dist/ui/assets/{oauth-service-BhR9BE2g.js → oauth-service-OzjrJhvT.js} +1 -1
- package/dist/ui/assets/{offscreen-client-wEL_xW9X.js → offscreen-client-BU_msuje.js} +1 -1
- package/dist/ui/assets/{onboarding-orchestrator-DwHIw7_r.js → onboarding-orchestrator-BK2UqVst.js} +1 -1
- package/dist/ui/assets/{openai-codex-responses-D3Gu9VHn.js → openai-codex-responses-C7dp_KxL.js} +1 -1
- package/dist/ui/assets/{openai-codex-responses-To0VPNpK.js → openai-codex-responses-CZWGyVjG.js} +1 -1
- package/dist/ui/assets/{openai-completions-BLDUKEsm.js → openai-completions-COqqEP8O.js} +1 -1
- package/dist/ui/assets/{openai-completions-BTYtmF5L.js → openai-completions-D9Ykqp6l.js} +1 -1
- package/dist/ui/assets/{openai-responses-Dd1wYcsg.js → openai-responses-rs7x-URy.js} +1 -1
- package/dist/ui/assets/{openai-responses-shared-B2L8aVu0.js → openai-responses-shared-B_MOgAN_.js} +1 -1
- package/dist/ui/assets/{openai-responses-shared-bjmGUfjZ.js → openai-responses-shared-BbssLGOF.js} +1 -1
- package/dist/ui/assets/{openai-responses-rbeRR8Tu.js → openai-responses-trulc-Fw.js} +1 -1
- package/dist/ui/assets/provider-settings-BdZH5Wj1.js +90 -0
- package/dist/ui/assets/{provider-settings-BMhQrltn.js → provider-settings-BzJrOSG3.js} +2 -2
- package/dist/ui/assets/{providers-DOkzveyM.js → providers-BEE1lB4a.js} +1 -1
- package/dist/ui/assets/{spawn-CyLKP0QP.js → spawn-DCVh5mXD.js} +1 -1
- package/dist/ui/assets/{upgrade-detection-5S6RyXlk.js → upgrade-detection-Ce7X_CBC.js} +1 -1
- package/dist/ui/index.html +7 -7
- package/dist/ui/packages/webapp/index.html +7 -7
- package/package.json +1 -1
- package/dist/ui/assets/cost-command-BAD6Qx8Q.js +0 -1
- package/dist/ui/assets/index-RVLUy-Qx.css +0 -1
- package/dist/ui/assets/provider-settings-DoJZgrI1.js +0 -90
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
import{r as e}from"./chunk-jRWAZmH_.js";import{t}from"./logger-BHrAkMIS.js";import{a as n,c as r,i,r as a,s as o,t as s}from"./bedrock-camp-CkuZf5jK.js";import{d as c,l,u}from"./transform-messages-DlZklr1h.js";import{a as d,n as f,t as p}from"./providers-DOkzveyM.js";import{m,p as h}from"./kernel-worker-BulN1Taf.js";const ee=`slicc.trayWorkerBaseUrl`,te=`https://www.sliccy.ai`;let ne={state:`inactive`,joinUrl:null,trayId:null,error:null,lastPingTime:null,reconnectAttempts:0,attachAttempts:0,lastAttachCode:null,connectingSince:null,lastError:null};function re(){return{...ne}}const ie=new Set;function ae(e){return ie.add(e),()=>{ie.delete(e)}}async function oe(e,t,n,r,i,a){let o=[...e],s={...t,messages:[...t.messages,...e]};await r({type:`agent_start`}),await r({type:`turn_start`});for(let t of e)await r({type:`message_start`,message:t}),await r({type:`message_end`,message:t});return await g(s,o,n,i,r,a),o}async function se(e,t,n,r,i){if(e.messages.length===0)throw Error(`Cannot continue: no messages in context`);if(e.messages[e.messages.length-1].role===`assistant`)throw Error(`Cannot continue from message role: assistant`);let a=[],o={...e};return await n({type:`agent_start`}),await n({type:`turn_start`}),await g(o,a,t,r,n,i),a}async function g(e,t,n,r,i,a){let o=!0,s=await n.getSteeringMessages?.()||[];for(;;){let c=!0;for(;c||s.length>0;){if(o?o=!1:await i({type:`turn_start`}),s.length>0){for(let n of s)await i({type:`message_start`,message:n}),await i({type:`message_end`,message:n}),e.messages.push(n),t.push(n);s=[]}let l=await ce(e,n,r,i,a);if(t.push(l),l.stopReason===`error`||l.stopReason===`aborted`){await i({type:`turn_end`,message:l,toolResults:[]}),await i({type:`agent_end`,messages:t});return}let u=l.content.filter(e=>e.type===`toolCall`),d=[];if(c=!1,u.length>0){let a=await le(e,l,n,r,i);d.push(...a.messages),c=!a.terminate;for(let n of d)e.messages.push(n),t.push(n)}if(await i({type:`turn_end`,message:l,toolResults:d}),await n.shouldStopAfterTurn?.({message:l,toolResults:d,context:e,newMessages:t})){await i({type:`agent_end`,messages:t});return}s=await n.getSteeringMessages?.()||[]}let l=await n.getFollowUpMessages?.()||[];if(l.length>0){s=l;continue}break}await i({type:`agent_end`,messages:t})}async function ce(e,t,n,i,a){let o=e.messages;t.transformContext&&(o=await t.transformContext(o,n));let s=await t.convertToLlm(o),c={systemPrompt:e.systemPrompt,messages:s,tools:e.tools},l=a||r,u=(t.getApiKey?await t.getApiKey(t.model.provider):void 0)||t.apiKey,d=await l(t.model,c,{...t,apiKey:u,signal:n}),f=null,p=!1;for await(let t of d)switch(t.type){case`start`:f=t.partial,e.messages.push(f),p=!0,await i({type:`message_start`,message:{...f}});break;case`text_start`:case`text_delta`:case`text_end`:case`thinking_start`:case`thinking_delta`:case`thinking_end`:case`toolcall_start`:case`toolcall_delta`:case`toolcall_end`:f&&(f=t.partial,e.messages[e.messages.length-1]=f,await i({type:`message_update`,assistantMessageEvent:t,message:{...f}}));break;case`done`:case`error`:{let t=await d.result();return p?e.messages[e.messages.length-1]=t:e.messages.push(t),p||await i({type:`message_start`,message:{...t}}),await i({type:`message_end`,message:t}),t}}let m=await d.result();return p?e.messages[e.messages.length-1]=m:(e.messages.push(m),await i({type:`message_start`,message:{...m}})),await i({type:`message_end`,message:m}),m}async function le(e,t,n,r,i){let a=t.content.filter(e=>e.type===`toolCall`),o=a.some(t=>e.tools?.find(e=>e.name===t.name)?.executionMode===`sequential`);return n.toolExecution===`sequential`||o?ue(e,t,a,n,r,i):de(e,t,a,n,r,i)}async function ue(e,t,n,r,i,a){let o=[],s=[];for(let c of n){await a({type:`tool_execution_start`,toolCallId:c.id,toolName:c.name,args:c.arguments});let n=await v(e,t,c,r,i),l;l=n.kind===`immediate`?{toolCall:c,result:n.result,isError:n.isError}:await b(e,t,n,await y(n,i,a),r,i),await S(l,a);let u=C(l);await w(u,a),o.push(l),s.push(u)}return{messages:s,terminate:_(o)}}async function de(e,t,n,r,i,a){let o=[];for(let s of n){await a({type:`tool_execution_start`,toolCallId:s.id,toolName:s.name,args:s.arguments});let n=await v(e,t,s,r,i);if(n.kind===`immediate`){let e={toolCall:s,result:n.result,isError:n.isError};await S(e,a),o.push(e);continue}o.push(async()=>{let o=await b(e,t,n,await y(n,i,a),r,i);return await S(o,a),o})}let s=await Promise.all(o.map(e=>typeof e==`function`?e():Promise.resolve(e))),c=[];for(let e of s){let t=C(e);await w(t,a),c.push(t)}return{messages:c,terminate:_(s)}}function _(e){return e.length>0&&e.every(e=>e.result.terminate===!0)}function fe(e,t){if(!e.prepareArguments)return t;let n=e.prepareArguments(t.arguments);return n===t.arguments?t:{...t,arguments:n}}async function v(e,t,r,i,a){let o=e.tools?.find(e=>e.name===r.name);if(!o)return{kind:`immediate`,result:x(`Tool ${r.name} not found`),isError:!0};try{let s=n(o,fe(o,r));if(i.beforeToolCall){let n=await i.beforeToolCall({assistantMessage:t,toolCall:r,args:s,context:e},a);if(n?.block)return{kind:`immediate`,result:x(n.reason||`Tool execution was blocked`),isError:!0}}return{kind:`prepared`,toolCall:r,tool:o,args:s}}catch(e){return{kind:`immediate`,result:x(e instanceof Error?e.message:String(e)),isError:!0}}}async function y(e,t,n){let r=[];try{let i=await e.tool.execute(e.toolCall.id,e.args,t,t=>{r.push(Promise.resolve(n({type:`tool_execution_update`,toolCallId:e.toolCall.id,toolName:e.toolCall.name,args:e.toolCall.arguments,partialResult:t})))});return await Promise.all(r),{result:i,isError:!1}}catch(e){return await Promise.all(r),{result:x(e instanceof Error?e.message:String(e)),isError:!0}}}async function b(e,t,n,r,i,a){let o=r.result,s=r.isError;if(i.afterToolCall)try{let r=await i.afterToolCall({assistantMessage:t,toolCall:n.toolCall,args:n.args,result:o,isError:s,context:e},a);r&&(o={content:r.content??o.content,details:r.details??o.details,terminate:r.terminate??o.terminate},s=r.isError??s)}catch(e){o=x(e instanceof Error?e.message:String(e)),s=!0}return{toolCall:n.toolCall,result:o,isError:s}}function x(e){return{content:[{type:`text`,text:e}],details:{}}}async function S(e,t){await t({type:`tool_execution_end`,toolCallId:e.toolCall.id,toolName:e.toolCall.name,result:e.result,isError:e.isError})}function C(e){return{role:`toolResult`,toolCallId:e.toolCall.id,toolName:e.toolCall.name,content:e.result.content,details:e.result.details,isError:e.isError,timestamp:Date.now()}}async function w(e,t){await t({type:`message_start`,message:e}),await t({type:`message_end`,message:e})}function pe(e){return e.filter(e=>e.role===`user`||e.role===`assistant`||e.role===`toolResult`)}const me={input:0,output:0,cacheRead:0,cacheWrite:0,totalTokens:0,cost:{input:0,output:0,cacheRead:0,cacheWrite:0,total:0}},he={id:`unknown`,name:`unknown`,api:`unknown`,provider:`unknown`,baseUrl:``,reasoning:!1,input:[],cost:{input:0,output:0,cacheRead:0,cacheWrite:0},contextWindow:0,maxTokens:0};function ge(e){let t=e?.tools?.slice()??[],n=e?.messages?.slice()??[];return{systemPrompt:e?.systemPrompt??``,model:e?.model??he,thinkingLevel:e?.thinkingLevel??`off`,get tools(){return t},set tools(e){t=e.slice()},get messages(){return n},set messages(e){n=e.slice()},isStreaming:!1,streamingMessage:void 0,pendingToolCalls:new Set,errorMessage:void 0}}var T=class{mode;messages=[];constructor(e){this.mode=e}enqueue(e){this.messages.push(e)}hasItems(){return this.messages.length>0}drain(){if(this.mode===`all`){let e=this.messages.slice();return this.messages=[],e}let e=this.messages[0];return e?(this.messages=this.messages.slice(1),[e]):[]}clear(){this.messages=[]}},_e=class{_state;listeners=new Set;steeringQueue;followUpQueue;convertToLlm;transformContext;streamFn;getApiKey;onPayload;onResponse;beforeToolCall;afterToolCall;activeRun;sessionId;thinkingBudgets;transport;maxRetryDelayMs;toolExecution;constructor(e={}){this._state=ge(e.initialState),this.convertToLlm=e.convertToLlm??pe,this.transformContext=e.transformContext,this.streamFn=e.streamFn??r,this.getApiKey=e.getApiKey,this.onPayload=e.onPayload,this.onResponse=e.onResponse,this.beforeToolCall=e.beforeToolCall,this.afterToolCall=e.afterToolCall,this.steeringQueue=new T(e.steeringMode??`one-at-a-time`),this.followUpQueue=new T(e.followUpMode??`one-at-a-time`),this.sessionId=e.sessionId,this.thinkingBudgets=e.thinkingBudgets,this.transport=e.transport??`auto`,this.maxRetryDelayMs=e.maxRetryDelayMs,this.toolExecution=e.toolExecution??`parallel`}subscribe(e){return this.listeners.add(e),()=>this.listeners.delete(e)}get state(){return this._state}set steeringMode(e){this.steeringQueue.mode=e}get steeringMode(){return this.steeringQueue.mode}set followUpMode(e){this.followUpQueue.mode=e}get followUpMode(){return this.followUpQueue.mode}steer(e){this.steeringQueue.enqueue(e)}followUp(e){this.followUpQueue.enqueue(e)}clearSteeringQueue(){this.steeringQueue.clear()}clearFollowUpQueue(){this.followUpQueue.clear()}clearAllQueues(){this.clearSteeringQueue(),this.clearFollowUpQueue()}hasQueuedMessages(){return this.steeringQueue.hasItems()||this.followUpQueue.hasItems()}get signal(){return this.activeRun?.abortController.signal}abort(){this.activeRun?.abortController.abort()}waitForIdle(){return this.activeRun?.promise??Promise.resolve()}reset(){this._state.messages=[],this._state.isStreaming=!1,this._state.streamingMessage=void 0,this._state.pendingToolCalls=new Set,this._state.errorMessage=void 0,this.clearFollowUpQueue(),this.clearSteeringQueue()}async prompt(e,t){if(this.activeRun)throw Error(`Agent is already processing a prompt. Use steer() or followUp() to queue messages, or wait for completion.`);let n=this.normalizePromptInput(e,t);await this.runPromptMessages(n)}async continue(){if(this.activeRun)throw Error(`Agent is already processing. Wait for completion before continuing.`);let e=this._state.messages[this._state.messages.length-1];if(!e)throw Error(`No messages to continue from`);if(e.role===`assistant`){let e=this.steeringQueue.drain();if(e.length>0){await this.runPromptMessages(e,{skipInitialSteeringPoll:!0});return}let t=this.followUpQueue.drain();if(t.length>0){await this.runPromptMessages(t);return}throw Error(`Cannot continue from message role: assistant`)}await this.runContinuation()}normalizePromptInput(e,t){if(Array.isArray(e))return e;if(typeof e!=`string`)return[e];let n=[{type:`text`,text:e}];return t&&t.length>0&&n.push(...t),[{role:`user`,content:n,timestamp:Date.now()}]}async runPromptMessages(e,t={}){await this.runWithLifecycle(async n=>{await oe(e,this.createContextSnapshot(),this.createLoopConfig(t),e=>this.processEvents(e),n,this.streamFn)})}async runContinuation(){await this.runWithLifecycle(async e=>{await se(this.createContextSnapshot(),this.createLoopConfig(),e=>this.processEvents(e),e,this.streamFn)})}createContextSnapshot(){return{systemPrompt:this._state.systemPrompt,messages:this._state.messages.slice(),tools:this._state.tools.slice()}}createLoopConfig(e={}){let t=e.skipInitialSteeringPoll===!0;return{model:this._state.model,reasoning:this._state.thinkingLevel===`off`?void 0:this._state.thinkingLevel,sessionId:this.sessionId,onPayload:this.onPayload,onResponse:this.onResponse,transport:this.transport,thinkingBudgets:this.thinkingBudgets,maxRetryDelayMs:this.maxRetryDelayMs,toolExecution:this.toolExecution,beforeToolCall:this.beforeToolCall,afterToolCall:this.afterToolCall,convertToLlm:this.convertToLlm,transformContext:this.transformContext,getApiKey:this.getApiKey,getSteeringMessages:async()=>t?(t=!1,[]):this.steeringQueue.drain(),getFollowUpMessages:async()=>this.followUpQueue.drain()}}async runWithLifecycle(e){if(this.activeRun)throw Error(`Agent is already processing.`);let t=new AbortController,n=()=>{},r=new Promise(e=>{n=e});this.activeRun={promise:r,resolve:n,abortController:t},this._state.isStreaming=!0,this._state.streamingMessage=void 0,this._state.errorMessage=void 0;try{await e(t.signal)}catch(e){await this.handleRunFailure(e,t.signal.aborted)}finally{this.finishRun()}}async handleRunFailure(e,t){let n={role:`assistant`,content:[{type:`text`,text:``}],api:this._state.model.api,provider:this._state.model.provider,model:this._state.model.id,usage:me,stopReason:t?`aborted`:`error`,errorMessage:e instanceof Error?e.message:String(e),timestamp:Date.now()};this._state.messages.push(n),this._state.errorMessage=n.errorMessage,await this.processEvents({type:`agent_end`,messages:[n]})}finishRun(){this._state.isStreaming=!1,this._state.streamingMessage=void 0,this._state.pendingToolCalls=new Set,this.activeRun?.resolve(),this.activeRun=void 0}async processEvents(e){switch(e.type){case`message_start`:this._state.streamingMessage=e.message;break;case`message_update`:this._state.streamingMessage=e.message;break;case`message_end`:this._state.streamingMessage=void 0,this._state.messages.push(e.message);break;case`tool_execution_start`:{let t=new Set(this._state.pendingToolCalls);t.add(e.toolCallId),this._state.pendingToolCalls=t;break}case`tool_execution_end`:{let t=new Set(this._state.pendingToolCalls);t.delete(e.toolCallId),this._state.pendingToolCalls=t;break}case`turn_end`:e.message.role===`assistant`&&e.message.errorMessage&&(this._state.errorMessage=e.message.errorMessage);break;case`agent_end`:this._state.streamingMessage=void 0;break}let t=this.activeRun?.abortController.signal;if(!t)throw Error(`Agent listener invoked outside active run`);for(let n of this.listeners)await n(e,t)}};const E=`sessions`;function ve(){return new Promise((e,t)=>{let n=indexedDB.open(`agent-sessions`,1);n.onupgradeneeded=()=>{let e=n.result;e.objectStoreNames.contains(E)||e.createObjectStore(E,{keyPath:`id`})},n.onsuccess=()=>e(n.result),n.onerror=()=>t(n.error)})}var ye=class{dbPromise=null;getDB(){return this.dbPromise||=ve(),this.dbPromise}async save(e){let t=await this.getDB();return new Promise((n,r)=>{let i=t.transaction(E,`readwrite`).objectStore(E).put(e);i.onsuccess=()=>n(),i.onerror=()=>r(i.error)})}async load(e){let t=await this.getDB();return new Promise((n,r)=>{let i=t.transaction(E,`readonly`).objectStore(E).get(e);i.onsuccess=()=>n(i.result??null),i.onerror=()=>r(i.error)})}async delete(e){let t=await this.getDB();return new Promise((n,r)=>{let i=t.transaction(E,`readwrite`).objectStore(E).delete(e);i.onsuccess=()=>n(),i.onerror=()=>r(i.error)})}async list(){let e=await this.getDB();return new Promise((t,n)=>{let r=e.transaction(E,`readonly`).objectStore(E).getAll();r.onsuccess=()=>{t((r.result??[]).map(e=>({id:e.id,updatedAt:e.updatedAt})))},r.onerror=()=>n(r.error)})}async clearAll(){let e=await this.getDB();return new Promise((t,n)=>{let r=e.transaction(E,`readwrite`).objectStore(E).clear();r.onsuccess=()=>t(),r.onerror=()=>n(r.error)})}static newId(){return`session-${Date.now()}-${Math.random().toString(36).slice(2,8)}`}static createSession(e,t){let n=Date.now();return{id:e,messages:[],config:t,createdAt:n,updatedAt:n}}static updateMessages(e,t){return{...e,messages:t,updatedAt:Date.now()}}};const D=t(`image-processor`),O=3932160,be=new Set([`image/jpeg`,`image/png`,`image/gif`,`image/webp`]);function xe(e){return be.has(e)}function Se(e,t){try{if(t===`image/png`){if(e.length<32)return null;let t=atob(e.slice(0,32)),n=t.charCodeAt(16)<<24|t.charCodeAt(17)<<16|t.charCodeAt(18)<<8|t.charCodeAt(19),r=t.charCodeAt(20)<<24|t.charCodeAt(21)<<16|t.charCodeAt(22)<<8|t.charCodeAt(23);return n>0&&r>0?{width:n,height:r}:null}if(t===`image/gif`){if(e.length<16)return null;let t=atob(e.slice(0,16)),n=t.charCodeAt(6)|t.charCodeAt(7)<<8,r=t.charCodeAt(8)|t.charCodeAt(9)<<8;return n>0&&r>0?{width:n,height:r}:null}if(t===`image/jpeg`){let t=Math.min(21846*4,e.length),n=atob(e.slice(0,t));for(let e=0;e<n.length-8;e++)if(n.charCodeAt(e)===255){let t=n.charCodeAt(e+1);if(t===192||t===194){let t=n.charCodeAt(e+5)<<8|n.charCodeAt(e+6),r=n.charCodeAt(e+7)<<8|n.charCodeAt(e+8);return r>0&&t>0?{width:r,height:t}:null}}}}catch{}return null}async function Ce(e){if(!xe(e.mimeType))return D.warn(`Unsupported image format`,{mimeType:e.mimeType}),{type:`text`,text:`[Image removed: unsupported format "${e.mimeType}". Supported: JPEG, PNG, GIF, WebP]`};let t=e.data.length,n=Se(e.data,e.mimeType);if(!(t>5242880||n!==null&&(n.width>8e3||n.height>8e3)||n!==null&&Math.max(n.width,n.height)>1568))return e;D.info(`Image needs processing`,{base64Size:t,dimensions:n?`${n.width}x${n.height}`:`unknown`,reason:t>5242880?`size`:`dimensions`});let r,i;try{let e=await import(`./magick-wasm-DwA3cs4T.js`).then(e=>e.n);r=e.getMagick,i=e.MIME_TO_MAGICK_FORMAT}catch(e){return D.error(`ImageMagick WASM module unavailable`,{error:e instanceof Error?e.message:String(e)}),{type:`text`,text:`[Image removed: resize service unavailable (ImageMagick WASM could not be loaded)]`}}let a;try{a=await r()}catch(e){return D.error(`ImageMagick WASM initialization failed`,{error:e instanceof Error?e.message:String(e)}),{type:`text`,text:`[Image removed: resize service unavailable (WASM init failed)]`}}try{let n=atob(e.data),r=new Uint8Array(n.length);for(let e=0;e<n.length;e++)r[e]=n.charCodeAt(e);let o={data:null,mime:e.mimeType};if(await a.ImageMagick.read(r,async t=>{let n=t.width,r=t.height,a=Math.max(n,r);if(a>1568){let e=1568/a,i=Math.round(n*e),o=Math.round(r*e);t.resize(i,o),D.info(`Resized image`,{from:`${n}x${r}`,to:`${i}x${o}`})}let s=i[e.mimeType]||`JPEG`;t.write(s,e=>{o.data=new Uint8Array(e)}),o.data&&o.data.length>O&&s!==`JPEG`?(D.info(`Still over 5MB, compressing to JPEG q80`),t.quality=80,t.write(`JPEG`,e=>{o.data=new Uint8Array(e)}),o.mime=`image/jpeg`):o.data&&o.data.length>O&&(D.info(`Still over 5MB as JPEG, reducing quality to 60`),t.quality=60,t.write(`JPEG`,e=>{o.data=new Uint8Array(e)}))}),!o.data)return D.warn(`ImageMagick produced no output`),{type:`text`,text:`[Image removed: could not be processed (empty output from resize)]`};if(o.data.length>O)return D.warn(`Image still over 5MB after resize+compress`,{size:o.data.length}),{type:`text`,text:`[Image removed: still ${Math.round(o.data.length/1024/1024*10)/10}MB after resize and compression, exceeds 5MB API limit]`};let s=``;for(let e=0;e<o.data.length;e++)s+=String.fromCharCode(o.data[e]);let c=btoa(s);return D.info(`Image processed successfully`,{originalBase64:t,newBase64:c.length,mimeType:o.mime}),{type:`image`,data:c,mimeType:o.mime}}catch(n){return D.error(`Image data processing failed (corrupt or unreadable)`,{mimeType:e.mimeType,estimatedBytes:t,error:n instanceof Error?n.message:String(n)}),{type:`text`,text:`[Image removed: image data could not be processed (${n instanceof Error?n.message:`corrupt or unreadable`})]`}}}const we=t(`tool-adapter`),Te=/<img:(data:(image\/[^;]+);base64,([^>]+))>/g;function k(e){let t=[],n=0;for(let r of e.matchAll(Te)){let i=e.slice(n,r.index);i.trim()&&t.push({type:`text`,text:i.trimEnd()}),t.push({type:`image`,mimeType:r[2],data:r[3]}),n=r.index+r[0].length}let r=e.slice(n);return(r.trim()||t.length===0)&&t.push({type:`text`,text:r||e}),t}async function Ee(e){let t=k(e),n=[];for(let e of t)e.type===`image`?n.push(await Ce(e)):n.push(e);return n}function De(e,t){return{name:e.name,label:e.name,description:e.description,parameters:e.inputSchema,async execute(n,r,i,a){let o;a&&(o=m({onUpdate:a,toolName:e.name,toolCallId:n}));let s=t?t.processManager.spawn({kind:`tool`,argv:[e.name,...ke(r)],owner:t.owner,ppid:t.getParentPid?.()}):null,c=null;s&&t&&i&&(i.aborted?t.processManager.signal(s.pid,`SIGINT`):i.addEventListener(`abort`,()=>t.processManager.signal(s.pid,`SIGINT`),{once:!0})),s&&t&&(c=t.processManager.onSignal((e,n)=>{e.pid!==s.pid||n!==`SIGKILL`||t.processManager.exit(s.pid,null)}));let l=s?s.abort.signal:i;try{let n=await e.execute(r??{},l),i;try{i=await Ee(n.content)}catch(t){we.warn(`Image processing failed, falling back to raw content`,{tool:e.name,error:t instanceof Error?t.message:String(t)}),i=k(n.content)}return s&&t&&t.processManager.exit(s.pid,+!!n.isError),{content:i,details:{isError:n.isError}}}catch(e){throw s&&t&&t.processManager.exit(s.pid,s.abort.signal.aborted?null:1),e}finally{o&&h(o),c?.()}}}}function Oe(e,t){return e.map(e=>De(e,t))}function ke(e){if(typeof e!=`object`||!e)return[];let t=e;for(let e of[`command`,`file_path`,`path`,`pattern`,`url`,`key`,`name`,`query`,`message`]){let n=t[e];if(typeof n==`string`&&n.length>0)return[n]}for(let e of Object.values(t))if(typeof e==`string`&&e.length>0)return[e];return[]}function Ae(e){let t=`Ran \`${e.command}\`\n`;return e.output?t+=`\`\`\`\n${e.output}\n\`\`\``:t+=`(no output)`,e.cancelled?t+=`
|
|
2
|
-
|
|
3
|
-
(command cancelled)`:e.exitCode!==null&&e.exitCode!==void 0&&e.exitCode!==0&&(t+=`\n\nCommand exited with code ${e.exitCode}`),e.truncated&&e.fullOutputPath&&(t+=`\n\n[Output truncated. Full output: ${e.fullOutputPath}]`),t}function je(e){return e.map(e=>{switch(e.role){case`bashExecution`:return e.excludeFromContext?void 0:{role:`user`,content:[{type:`text`,text:Ae(e)}],timestamp:e.timestamp};case`custom`:return{role:`user`,content:typeof e.content==`string`?[{type:`text`,text:e.content}]:e.content,timestamp:e.timestamp};case`branchSummary`:return{role:`user`,content:[{type:`text`,text:`The following is a summary of a branch that this conversation came back from:
|
|
4
|
-
|
|
5
|
-
<summary>
|
|
6
|
-
`+e.summary+`</summary>`}],timestamp:e.timestamp};case`compactionSummary`:return{role:`user`,content:[{type:`text`,text:`The conversation history before this point was compacted into the following summary:
|
|
7
|
-
|
|
8
|
-
<summary>
|
|
9
|
-
`+e.summary+`
|
|
10
|
-
</summary>`}],timestamp:e.timestamp};case`user`:case`assistant`:case`toolResult`:return e;default:return}}).filter(e=>e!==void 0)}function Me(e,t){if(e.length<=t)return e;let n=e.length-t;return`${e.slice(0,t)}\n\n[... ${n} more characters truncated]`}function Ne(e){let t=[];for(let n of e)if(n.role===`user`){let e=typeof n.content==`string`?n.content:n.content.filter(e=>e.type===`text`).map(e=>e.text).join(``);e&&t.push(`[User]: ${e}`)}else if(n.role===`assistant`){let e=[],r=[],i=[];for(let t of n.content)if(t.type===`text`)e.push(t.text);else if(t.type===`thinking`)r.push(t.thinking);else if(t.type===`toolCall`){let e=t.arguments,n=Object.entries(e).map(([e,t])=>`${e}=${JSON.stringify(t)}`).join(`, `);i.push(`${t.name}(${n})`)}r.length>0&&t.push(`[Assistant thinking]: ${r.join(`
|
|
11
|
-
`)}`),e.length>0&&t.push(`[Assistant]: ${e.join(`
|
|
12
|
-
`)}`),i.length>0&&t.push(`[Assistant tool calls]: ${i.join(`; `)}`)}else if(n.role===`toolResult`){let e=n.content.filter(e=>e.type===`text`).map(e=>e.text).join(``);e&&t.push(`[Tool result]: ${Me(e,2e3)}`)}return t.join(`
|
|
13
|
-
|
|
14
|
-
`)}const A={enabled:!0,reserveTokens:16384,keepRecentTokens:2e4};function Pe(e,t,n){return n.enabled?e>t-n.reserveTokens:!1}function j(e){let t=0;switch(e.role){case`user`:{let n=e.content;if(typeof n==`string`)t=n.length;else if(Array.isArray(n))for(let e of n)e.type===`text`&&e.text&&(t+=e.text.length);return Math.ceil(t/4)}case`assistant`:{let n=e;for(let e of n.content)e.type===`text`?t+=e.text.length:e.type===`thinking`?t+=e.thinking.length:e.type===`toolCall`&&(t+=e.name.length+JSON.stringify(e.arguments).length);return Math.ceil(t/4)}case`custom`:case`toolResult`:if(typeof e.content==`string`)t=e.content.length;else for(let n of e.content)n.type===`text`&&n.text&&(t+=n.text.length),n.type===`image`&&(t+=4800);return Math.ceil(t/4);case`bashExecution`:return t=e.command.length+e.output.length,Math.ceil(t/4);case`branchSummary`:case`compactionSummary`:return t=e.summary.length,Math.ceil(t/4)}return 0}async function Fe(e,t,n,r,i,a,s,c,l){let u=Math.floor(.8*n),d=c?`The messages above are NEW conversation messages to incorporate into the existing summary provided in <previous-summary> tags.
|
|
15
|
-
|
|
16
|
-
Update the existing structured summary with new information. RULES:
|
|
17
|
-
- PRESERVE all existing information from the previous summary
|
|
18
|
-
- ADD new progress, decisions, and context from the new messages
|
|
19
|
-
- UPDATE the Progress section: move items from "In Progress" to "Done" when completed
|
|
20
|
-
- UPDATE "Next Steps" based on what was accomplished
|
|
21
|
-
- PRESERVE exact file paths, function names, and error messages
|
|
22
|
-
- If something is no longer relevant, you may remove it
|
|
23
|
-
|
|
24
|
-
Use this EXACT format:
|
|
25
|
-
|
|
26
|
-
## Goal
|
|
27
|
-
[Preserve existing goals, add new ones if the task expanded]
|
|
28
|
-
|
|
29
|
-
## Constraints & Preferences
|
|
30
|
-
- [Preserve existing, add new ones discovered]
|
|
31
|
-
|
|
32
|
-
## Progress
|
|
33
|
-
### Done
|
|
34
|
-
- [x] [Include previously done items AND newly completed items]
|
|
35
|
-
|
|
36
|
-
### In Progress
|
|
37
|
-
- [ ] [Current work - update based on progress]
|
|
38
|
-
|
|
39
|
-
### Blocked
|
|
40
|
-
- [Current blockers - remove if resolved]
|
|
41
|
-
|
|
42
|
-
## Key Decisions
|
|
43
|
-
- **[Decision]**: [Brief rationale] (preserve all previous, add new)
|
|
44
|
-
|
|
45
|
-
## Next Steps
|
|
46
|
-
1. [Update based on current state]
|
|
47
|
-
|
|
48
|
-
## Critical Context
|
|
49
|
-
- [Preserve important context, add new if needed]
|
|
50
|
-
|
|
51
|
-
Keep each section concise. Preserve exact file paths, function names, and error messages.`:`The messages above are a conversation to summarize. Create a structured context checkpoint summary that another LLM will use to continue the work.
|
|
52
|
-
|
|
53
|
-
Use this EXACT format:
|
|
54
|
-
|
|
55
|
-
## Goal
|
|
56
|
-
[What is the user trying to accomplish? Can be multiple items if the session covers different tasks.]
|
|
57
|
-
|
|
58
|
-
## Constraints & Preferences
|
|
59
|
-
- [Any constraints, preferences, or requirements mentioned by user]
|
|
60
|
-
- [Or "(none)" if none were mentioned]
|
|
61
|
-
|
|
62
|
-
## Progress
|
|
63
|
-
### Done
|
|
64
|
-
- [x] [Completed tasks/changes]
|
|
65
|
-
|
|
66
|
-
### In Progress
|
|
67
|
-
- [ ] [Current work]
|
|
68
|
-
|
|
69
|
-
### Blocked
|
|
70
|
-
- [Issues preventing progress, if any]
|
|
71
|
-
|
|
72
|
-
## Key Decisions
|
|
73
|
-
- **[Decision]**: [Brief rationale]
|
|
74
|
-
|
|
75
|
-
## Next Steps
|
|
76
|
-
1. [Ordered list of what should happen next]
|
|
77
|
-
|
|
78
|
-
## Critical Context
|
|
79
|
-
- [Any data, examples, or references needed to continue]
|
|
80
|
-
- [Or "(none)" if not applicable]
|
|
81
|
-
|
|
82
|
-
Keep each section concise. Preserve exact file paths, function names, and error messages.`;s&&(d=`${d}\n\nAdditional focus: ${s}`);let f=`<conversation>\n${Ne(je(e))}\n</conversation>\n\n`;c&&(f+=`<previous-summary>\n${c}\n</previous-summary>\n\n`),f+=d;let p=[{role:`user`,content:[{type:`text`,text:f}],timestamp:Date.now()}],m=t.reasoning&&l&&l!==`off`?{maxTokens:u,signal:a,apiKey:r,headers:i,reasoning:l}:{maxTokens:u,signal:a,apiKey:r,headers:i},h=await o(t,{systemPrompt:`You are a context summarization assistant. Your task is to read a conversation between a user and an AI coding assistant, then produce a structured summary following the exact format specified.
|
|
83
|
-
|
|
84
|
-
Do NOT continue the conversation. Do NOT respond to any questions in the conversation. ONLY output the structured summary.`,messages:p},m);if(h.stopReason===`error`)throw Error(`Summarization failed: ${h.errorMessage||`Unknown error`}`);return h.content.filter(e=>e.type===`text`).map(e=>e.text).join(`
|
|
85
|
-
`)}const M=t(`context-compaction`);function Ie(e,t){return e.role===t}function Le(e){let t=e.contextWindow??2e5,n=e.reserveTokens??A.reserveTokens,r=e.keepRecentTokens??A.keepRecentTokens,i={enabled:!0,reserveTokens:n,keepRecentTokens:r};return async(a,o)=>{if(a.length===0)return a;let s=0;for(let e of a)s+=j(e);if(!Pe(s,t,i))return a;M.info(`Context compaction triggered`,{totalTokens:s,contextWindow:t,threshold:t-n,messageCount:a.length});let c=0,l=a.length;for(let e=a.length-1;e>=0;e--){let t=j(a[e]);if(c+t>r&&l<a.length)break;c+=t,l=e}for(;l>0&&Ie(a[l],`toolResult`);)l--;if(l<=0||l>=a.length)return M.warn(`Cannot find valid cut point for compaction`),a;let u=a.slice(0,l),d=a.slice(l);M.info(`Compaction cut point`,{summarizing:u.length,keeping:d.length});let f=e.getApiKey();if(f)try{let t=await Fe(u,e.model,n,f,e.headers,o),r={role:`user`,content:[{type:`text`,text:`<context-summary>\n${t}\n</context-summary>`}],timestamp:Date.now()};return M.info(`LLM summarization successful`,{originalMessages:a.length,compactedMessages:1+d.length,summaryLength:t.length}),[r,...d]}catch(e){M.warn(`LLM summarization failed, falling back to naive drop`,{error:e instanceof Error?e.message:String(e)})}else M.warn(`No API key available for LLM summarization, falling back to naive drop`);let p={role:`user`,content:[{type:`text`,text:`[Earlier conversation messages were compacted to save context space]`}],timestamp:Date.now()};return M.info(`Naive compaction applied`,{originalMessages:a.length,compactedMessages:1+d.length}),[p,...d]}}function Re(e){if(!Number.isFinite(e)||e<=0)return`0 B`;let t=[`B`,`KB`,`MB`,`GB`],n=e,r=0;for(;n>=1024&&r<t.length-1;)n/=1024,r++;return`${n>=10||r===0?Math.round(n):Math.round(n*10)/10} ${t[r]}`}function ze(e){let t=e.mimeType||`application/octet-stream`;return`${e.name} (${t}, ${Re(e.size)})`}function Be(e){let t=ze(e);return e.kind===`image`&&e.data?`[Attached image: ${t}]`:e.kind===`text`&&e.text!==void 0?[`----- BEGIN ATTACHMENT ${t} -----`,e.text,`----- END ATTACHMENT ${e.name} -----`].join(`
|
|
86
|
-
`):e.path?`[Attached ${e.kind===`image`?`image`:e.kind===`text`?`text file`:`file`} saved to ${e.path} — ${t}. Read it from the virtual filesystem when you need its contents.]`:e.error?`[Attachment not included: ${t}. ${e.error}]`:`[Attachment not included: ${t}. Unsupported binary attachment.]`}function Ve(e,t){if(!t?.length)return e;let n=t.map(Be),r=e.trim();return r?`${r}\n\n${n.join(`
|
|
87
|
-
|
|
88
|
-
`)}`:n.join(`
|
|
89
|
-
|
|
90
|
-
`)}function He(e){return e?.length?e.filter(e=>e.kind===`image`&&e.data).map(e=>({type:`image`,data:e.data,mimeType:e.mimeType})):[]}function Ue(e){}[...[`ghp_`,`gho_`,`ghu_`,`ghs_`,`ghr_`,`github_pat_`,`sk-`,`pk-`,`xoxb-`,`xoxp-`,`xoxa-`,`xoxs-`,`AKIA`,`ABIA`,`ACCA`,`ASIA`,`sk-ant-`,`Bearer `]].sort((e,t)=>t.length-e.length);function We(e,t){let n=e.toLowerCase(),r=t.toLowerCase();if(n===`*`)return!0;if(!n.startsWith(`*.`))return n===r;let i=n.slice(1);return r.length>i.length&&r.endsWith(i)}function Ge(e,t){return e.some(e=>We(e,t))}const Ke=`slicc_oauth_extra_domains`;function N(e){try{let t=e.getItem(Ke);if(!t)return{};let n=JSON.parse(t);if(typeof n!=`object`||!n||Array.isArray(n))return{};let r={};for(let[e,t]of Object.entries(n)){if(typeof e!=`string`||!Array.isArray(t))continue;let n=t.filter(e=>typeof e==`string`&&e.length>0);n.length>0&&(r[e]=n)}return r}catch{return{}}}function qe(e,t){try{e.setItem(Ke,JSON.stringify(t))}catch(e){throw Error(`Failed to persist OAuth extras (localStorage quota exceeded?): ${e instanceof Error?e.message:String(e)}`)}}var Je=e({addAccount:()=>nt,getAccounts:()=>K,getAllAvailableModels:()=>G,getAllExtraOAuthDomains:()=>tt,getApiKey:()=>ct,getApiKeyForProvider:()=>X,getApiVersionForProvider:()=>at,getAvailableProviders:()=>Ze,getBaseUrlForProvider:()=>Z,getDeploymentForProvider:()=>it,getExtraOAuthDomains:()=>q,getOAuthAccountInfo:()=>H,getProviderConfig:()=>z,getProviderModels:()=>V,getRawApiKeyForProvider:()=>rt,getSelectedModelId:()=>ot,getSelectedProvider:()=>Q,isModelHiddenFromPicker:()=>W,resolveCurrentModel:()=>$,resolveModelById:()=>lt,saveOAuthAccount:()=>Y,setExtraOAuthDomains:()=>et});const P=l,F=u,I=`slicc_accounts`,L=`selected-model`,Ye=[`slicc_provider`,`slicc_api_key`,`slicc_base_url`,`anthropic_api_key`,`api_provider`,`azure_resource`,`bedrock_region`];let R=!1;function Xe(){if(!R){R=!0;for(let e of Ye)try{localStorage.removeItem(e)}catch{}}}function Ze(){let e=c().filter(d),t=f();return[...new Set([...e,...t])]}function z(e){return p(e)||{id:e,name:e.split(`-`).map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join(` `),description:`${e} provider`,requiresApiKey:!0,requiresBaseUrl:!1}}function B(e,t){t.context_window!==void 0&&(e.contextWindow=t.context_window),t.max_tokens!==void 0&&(e.maxTokens=t.max_tokens),t.reasoning!==void 0&&(e.reasoning=t.reasoning),t.input!==void 0&&(e.input=t.input),t.compat!==void 0&&(e.compat={...e.compat??{},...t.compat})}function V(e){try{if(e===`bedrock-camp`){let e=s(Z(`bedrock-camp`)),t=F(`amazon-bedrock`).filter(t=>i(t,e)),n=new Set(t.map(e=>e.id)),r=a().filter(t=>i(t,e)&&!n.has(t.id));return[...t,...r].map(e=>({...e,api:`bedrock-camp-converse`,provider:`bedrock-camp`}))}let t=z(e);if(t.getModelIds){let n;try{n=t.getModelIds()}catch(t){return U.error(`Provider getModelIds callback failed`,{providerId:e,error:t instanceof Error?t.message:String(t)}),[]}let r=new Map;for(let e of c())try{for(let t of F(e))r.set(t.id,t)}catch{}return n.map(n=>{let i=`${e}-${n.api===`openai`?`openai`:`anthropic`}`,a=r.get(n.id),o=a?{...a,api:i,provider:e}:{id:n.id,name:n.name??n.id,provider:e,api:i,baseUrl:``,contextWindow:2e5,maxTokens:16384,input:[`text`,`image`],cost:{input:0,output:0,cacheRead:0,cacheWrite:0},inputCost:0,outputCost:0,cacheReadCost:0,cacheWriteCost:0,reasoning:!0},s=t.modelOverrides?.[n.id];return s&&B(o,s),B(o,n),o})}if(t.isOAuth){let n=F(`anthropic`),r=`${e}-anthropic`;return n.map(n=>{let i={...n,api:r,provider:e},a=t.modelOverrides?.[n.id];return a&&B(i,a),i})}return F(e===`azure-ai-foundry`?`anthropic`:e)}catch(t){return U.error(`Failed to load models`,{providerId:e,error:t instanceof Error?t.message:String(t)}),[]}}function H(e){let t=K().find(t=>t.providerId===e);if(!t?.accessToken)return null;let n=!!t.tokenExpiresAt&&Date.now()>t.tokenExpiresAt-6e4;return{token:t.accessToken,maskedValue:t.maskedValue,expiresAt:t.tokenExpiresAt,userName:t.userName,userAvatar:t.userAvatar,expired:n}}Object.assign({})[`/packages/webapp/providers.json`];const U=t(`provider-settings`),Qe=[/haiku/i];function W(e){return Qe.some(t=>t.test(e))}function $e(e){return e.filter(e=>!W(e.id))}function G(){let e=K();if(e.length===0)return[];let t=new Map;for(let n of e){if(t.has(n.providerId))continue;let e=$e(V(n.providerId));if(e.length===0)continue;let r=z(n.providerId),i={providerId:n.providerId,providerName:r.name,models:e};t.set(n.providerId,i)}return[...t.values()]}function K(){Xe();let e=localStorage.getItem(I);if(!e)return[];try{let t=JSON.parse(e);return Array.isArray(t)?t.filter(e=>typeof e==`object`&&!!e&&typeof e.providerId==`string`&&typeof e.apiKey==`string`):[]}catch{return[]}}function q(e){return N(localStorage)[e]??[]}function et(e,t){let n=N(localStorage),r=t.map(e=>e.trim()).filter(e=>e.length>0);r.length===0?delete n[e]:n[e]=r,qe(localStorage,n)}function tt(){return N(localStorage)}function J(e){localStorage.setItem(I,JSON.stringify(e))}function nt(e,t,n,r,i){let a=K().filter(t=>t.providerId!==e),o={providerId:e,apiKey:t};n&&(o.baseUrl=n),r&&(o.deployment=r),i&&(o.apiVersion=i),a.push(o),J(a)}async function Y(e){let t=K().find(t=>t.providerId===e.providerId),n=K().filter(t=>t.providerId!==e.providerId);n.push({providerId:e.providerId,apiKey:``,accessToken:e.accessToken,refreshToken:e.refreshToken,tokenExpiresAt:e.tokenExpiresAt,userName:e.userName,userAvatar:e.userAvatar,baseUrl:e.baseUrl??t?.baseUrl}),J(n);let r=z(e.providerId)?.oauthTokenDomains??[],i=q(e.providerId),a=new Set,o=[];for(let e of[...r,...i]){let t=e.toLowerCase();a.has(t)||(a.add(t),o.push(e))}if(o.length===0)return;let s=typeof chrome<`u`&&!!chrome?.runtime?.id;try{if(s){await chrome.storage.local.set({[`oauth.${e.providerId}.token`]:e.accessToken,[`oauth.${e.providerId}.token_DOMAINS`]:o.join(`,`)});let t=await new Promise(t=>{chrome.runtime.sendMessage({type:`secrets.mask-oauth-token`,providerId:e.providerId},n=>{chrome.runtime.lastError&&U.error(`SW mask-oauth-token transport failed`,{providerId:e.providerId,error:chrome.runtime.lastError.message}),t(n??{})})});if(t.error&&U.warn(`SW mask-oauth-token returned error`,{providerId:e.providerId,error:t.error}),t.maskedValue){let n=K(),r=n.find(t=>t.providerId===e.providerId);r&&(r.maskedValue=t.maskedValue,J(n))}}else{let t=await fetch(`/api/secrets/oauth-update`,{method:`POST`,headers:{"Content-Type":`application/json`},body:JSON.stringify({providerId:e.providerId,accessToken:e.accessToken,domains:o})});if(t.ok){let n=await t.json(),r=K(),i=r.find(t=>t.providerId===e.providerId);i&&typeof n.maskedValue==`string`&&(i.maskedValue=n.maskedValue,J(r))}else U.warn(`OAuth replica POST non-ok`,{providerId:e.providerId,status:t.status})}}catch(t){U.error(`OAuth replica sync failed`,{providerId:e.providerId,isExtension:s,error:t instanceof Error?t.message:String(t)})}}function rt(e){let t=K().find(t=>t.providerId===e);return t&&(t.accessToken||t.apiKey)||null}function X(e){let t=K().find(t=>t.providerId===e);return t?t.accessToken||t.apiKey||(z(e).optionalApiKey?`local`:null):null}function Z(e){return K().find(t=>t.providerId===e)?.baseUrl??null}function it(e){return K().find(t=>t.providerId===e)?.deployment??null}function at(e){return K().find(t=>t.providerId===e)?.apiVersion??null}function ot(){let e=localStorage.getItem(L)||``,t=e.indexOf(`:`);return t>=0?e.slice(t+1):e}function st(){return localStorage.getItem(L)||``}function Q(){let e=st(),t=e.indexOf(`:`);if(t>0)return e.slice(0,t);let n=K();return n.length>0?n[0].providerId:`anthropic`}function ct(){return X(Q())}function lt(e){if(!e)return $();let t=Q(),n=Z(t);try{let r=z(t),i=P(r.isOAuth||t===`azure-ai-foundry`?`anthropic`:t===`bedrock-camp`?`amazon-bedrock`:t,e);if(!i?.id)throw Error(`Model ${e} not found`);let a=i;return r.isOAuth?a=V(t).find(t=>t.id===e)||{...a,api:`${t}-anthropic`,provider:t}:t===`bedrock-camp`&&(a={...a,api:`bedrock-camp-converse`,provider:`bedrock-camp`}),n&&(a={...a,baseUrl:n}),a}catch{return $()}}function $(){let e=Q(),t=ot(),n=Z(e),r=V(e),i=z(e),a=i.defaultModelId?r.find(e=>e.id.toLowerCase().includes(i.defaultModelId.toLowerCase()))?.id:void 0,o=t||a||r[0]?.id||`claude-sonnet-4-6`;try{let t=z(e),i=t.isOAuth||e===`azure-ai-foundry`?`anthropic`:e===`bedrock-camp`?`amazon-bedrock`:e,a=P(i,o);if(!a?.id)throw Error(`Model ${o} not found in ${i} registry`);let s=a;return t.isOAuth?s=r.find(e=>e.id===o)||{...s,api:`${e}-anthropic`,provider:e}:e===`bedrock-camp`&&(s={...s,api:`bedrock-camp-converse`,provider:`bedrock-camp`}),n&&(s={...s,baseUrl:n}),s}catch{let e=r.find(e=>e.id===o);return e?n?{...e,baseUrl:n}:e:P(`anthropic`,`claude-sonnet-4-0`)}}export{te as C,ae as S,Le as _,Z as a,_e as b,Q as c,lt as d,Y as f,He as g,Ve as h,at as i,Je as l,Ue as m,G as n,it as o,Ge as p,ct as r,H as s,K as t,$ as u,Oe as v,ee as w,re as x,ye as y};
|