sliccy 4.0.2 → 4.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/ui/assets/__vite-browser-external-C7iut881.js +1 -0
- package/dist/ui/assets/account-store-BcAPWTGv.js +38 -0
- package/dist/ui/assets/account-store-CiB6cAel.js +99 -0
- package/dist/ui/assets/adobe-B-oaNVGg.js +1 -0
- package/dist/ui/assets/adobe-CrAdS9SD.js +2 -0
- package/dist/ui/assets/{agent-message-to-chat-2oatz-4r.js → agent-message-to-chat-BAWaR5C4.js} +1 -1
- package/dist/ui/assets/{anthropic-DdhoKMtR.js → anthropic-DVpFSsKH.js} +2 -2
- package/dist/ui/assets/{apps-BkzP1PLW.js → apps-BHERTKiO.js} +1 -1
- package/dist/ui/assets/azure-openai-C-826Dlw.js +1 -0
- package/dist/ui/assets/azure-openai-DvGwGsI1.js +1 -0
- package/dist/ui/assets/azure-openai-responses-BPLbXfA6.js +1 -0
- package/dist/ui/assets/bedrock-camp-D64i9rke.js +1 -0
- package/dist/ui/assets/{bsh-watchdog-BFmmHSkm.js → bsh-watchdog-ClOjddgN.js} +1 -1
- package/dist/ui/assets/cdn-url-builder-Cq7LLgru.js +1 -0
- package/dist/ui/assets/{cdp-Bx-nkPzL.js → cdp-Cbi5Katl.js} +3 -3
- package/dist/ui/assets/{clipboard-C2cR8flR.js → clipboard-DgFtRQbq.js} +1 -1
- package/dist/ui/assets/composer-speech-BuzPv_Yy.js +1 -0
- package/dist/ui/assets/{connect-surface-Dwz7gSuy.js → connect-surface-D6ECkvh5.js} +1 -1
- package/dist/ui/assets/context-compaction-DJF_qJZJ.js +27 -0
- package/dist/ui/assets/diagnostics-mI-AnKx_.js +1 -0
- package/dist/ui/assets/dip-ilEHW-Zu.js +1 -0
- package/dist/ui/assets/dist-CSwuvPa6.js +4 -0
- package/dist/ui/assets/{dist-DwJ61hEj.js → dist-CvzfEfDj2.js} +1 -1
- package/dist/ui/assets/{dist-DU9Hdb6p.js → dist-Dejj5eGe.js} +2 -2
- package/dist/ui/assets/{dist-DBjE4kB5.js → dist-l3FWXCp1.js} +1 -1
- package/dist/ui/assets/{es-CxV76drH.js → es-BxwKdh2y.js} +1 -1
- package/dist/ui/assets/esp8266-BPLrOmN4.js +1 -0
- package/dist/ui/assets/{esptool-operations-CXqSawtf.js → esptool-operations-CiX8mbpu.js} +2 -2
- package/dist/ui/assets/event-stream-Cs43PhOB.js +1 -0
- package/dist/ui/assets/{fs-Dg90t6PY.js → fs-BDe3kEbh.js} +1 -1
- package/dist/ui/assets/fs-D2X8IzCo.js +2 -0
- package/dist/ui/assets/github-BAqz3bbU.js +1 -0
- package/dist/ui/assets/github-BPoxioKX.js +2 -0
- package/dist/ui/assets/github-copilot-C7kttkXK.js +1 -0
- package/dist/ui/assets/github-copilot-Colai-cF.js +2 -0
- package/dist/ui/assets/google-shared-CVRDRmWo.js +11 -0
- package/dist/ui/assets/google-syj0sMxL.js +1 -0
- package/dist/ui/assets/google-vertex-CzAYHmbM.js +1 -0
- package/dist/ui/assets/hear-W4qlQvtc.js +1 -0
- package/dist/ui/assets/hear-lee28_gN.js +1 -0
- package/dist/ui/assets/hosted-config-apply-uAym2aS5.js +1 -0
- package/dist/ui/assets/json-parse-BUunmmNl.js +3 -0
- package/dist/ui/assets/{kernel-worker-DpRMAeb1.js → kernel-worker-ic1QU0mg.js} +1055 -1032
- package/dist/ui/assets/kokoro-IuvgZkZk.js +4 -0
- package/dist/ui/assets/kokoro-engine-B330eLPz.js +2 -0
- package/dist/ui/assets/kokoro-engine-C5c0LOmY.js +1 -0
- package/dist/ui/assets/kokoro-pZaPWf_-.js +4 -0
- package/dist/ui/assets/legacy-styles-4PP74ISo.js +2 -0
- package/dist/ui/assets/{lick-ws-bridge-CIdCZl2q.js → lick-ws-bridge-C0dPnE8i.js} +1 -1
- package/dist/ui/assets/{local-llm-DgWHei2e.js → local-llm-DzOVooE9.js} +2 -2
- package/dist/ui/assets/logger-DDBAeTLF.js +1 -0
- package/dist/ui/assets/magick-wasm-BvNy9LFP.js +1 -0
- package/dist/ui/assets/main-DqjICHRh.js +22 -0
- package/dist/ui/assets/main-cherry-Bap_NTtV.js +1 -0
- package/dist/ui/assets/mime-types-BqLkKWa7.js +1 -0
- package/dist/ui/assets/mime-types-ugOWOUZ9.js +1 -0
- package/dist/ui/assets/{mistral-C8Uiexjg.js → mistral-pCZ0Zm3T.js} +2 -2
- package/dist/ui/assets/mount-CCmhX5cE.js +2 -0
- package/dist/ui/assets/{mount-CYuBE82h.js → mount-DqjQTDCU.js} +1 -1
- package/dist/ui/assets/mount-id-DtHfwjbZ.js +1 -0
- package/dist/ui/assets/mount-picker-popup-BORxgnGu.js +1 -0
- package/dist/ui/assets/new-session-DeH2bC1U.js +1 -0
- package/dist/ui/assets/oauth-bootstrap-B6wP6zi_.js +2 -0
- package/dist/ui/assets/oauth-service-CTlktxVj.js +1 -0
- package/dist/ui/assets/{oauth-service-CSJo71ct.js → oauth-service-DQVciyk_.js} +1 -1
- package/dist/ui/assets/onboarding-orchestrator-MNoD_6wi.js +1 -0
- package/dist/ui/assets/openai-codex-C_G8kpA8.js +1 -0
- package/dist/ui/assets/openai-codex-DKhn8od8.js +1 -0
- package/dist/ui/assets/{openai-codex-responses-iASEGX_4.js → openai-codex-responses-C8xgMZBo.js} +3 -3
- package/dist/ui/assets/openai-completions-Dry_mhhJ.js +5 -0
- package/dist/ui/assets/openai-responses-Bmov8oh7.js +1 -0
- package/dist/ui/assets/{openai-responses-shared-B1lth5mr.js → openai-responses-shared-Ct3FUe7d.js} +4 -4
- package/dist/ui/assets/panel-rpc-Ck8CVyMh.js +1 -0
- package/dist/ui/assets/panel-rpc-DqT2FG7c.js +1 -0
- package/dist/ui/assets/panel-rpc-handlers-CEpB4s-n.js +2 -0
- package/dist/ui/assets/{picker-approval-EweLNWgE.js → picker-approval-tzbkMw-e.js} +1 -1
- package/dist/ui/assets/preload-helper-zJ_50EbN.js +1 -0
- package/dist/ui/assets/provider-Bu84IJif.js +1 -0
- package/dist/ui/assets/provider-CkWZObGz.js +2 -0
- package/dist/ui/assets/provider-store-access-6diGA3zc.js +1 -0
- package/dist/ui/assets/provider-store-access-KstUmZ39.js +1 -0
- package/dist/ui/assets/{providers-BmSZZhhm.js → providers-Dqi1y25H.js} +1 -1
- package/dist/ui/assets/quick-llm-7TCMcdio.js +1 -0
- package/dist/ui/assets/remote-cdp-transport-Cf0sDZ5N.js +1 -0
- package/dist/ui/assets/{remote-terminal-view-Hlq3HwiU.js → remote-terminal-view-FVcjc7kw.js} +1 -1
- package/dist/ui/assets/secret-env-DcfTe28K.js +1 -0
- package/dist/ui/assets/session-freezer-1L0xsBeg.js +1 -0
- package/dist/ui/assets/setup-sprinkle-exec-BGXT8k4k.js +1 -0
- package/dist/ui/assets/setup-sudo-_cBqLWHH.js +1 -0
- package/dist/ui/assets/slicc-editor-BdfBeQCF.js +12 -0
- package/dist/ui/assets/speak-C8nGyR-z.js +1 -0
- package/dist/ui/assets/speak-lc1xl5Fy.js +1 -0
- package/dist/ui/assets/speech-GZe1rUoJ.js +1 -0
- package/dist/ui/assets/sprinkle-manager-Pfbc1BH8.js +1 -0
- package/dist/ui/assets/{sprinkle-renderer-5HX0pMZZ.js → sprinkle-renderer-GiRRbdBx.js} +3 -3
- package/dist/ui/assets/src-DlEHAkLd.js +1 -0
- package/dist/ui/assets/{store-CQo5JYZe.js → store-B3VfUVG6.js} +1 -1
- package/dist/ui/assets/{sudo-fe6QprlZ.js → sudo-CZTI9OeD.js} +1 -1
- package/dist/ui/assets/sync-dialog-BFKWO6DT.js +1 -0
- package/dist/ui/assets/tool-ui-YOPqzMmL.js +1 -0
- package/dist/ui/assets/transform-messages-DzB_lMo-.js +1 -0
- package/dist/ui/assets/transformers-env-6vj5CcH9.js +1 -0
- package/dist/ui/assets/transformers-env-CCpYiaIa.js +1 -0
- package/dist/ui/assets/transformers.web-C9_H_wuQ.js +37 -0
- package/dist/ui/assets/transformers.web-DJfCkvxA.js +43 -0
- package/dist/ui/assets/{tray-leave-runtime--Ue08Cke.js → tray-leave-runtime-CdAgBa02.js} +1 -1
- package/dist/ui/assets/upgrade-detection--E7KkpNj.js +1 -0
- package/dist/ui/assets/voice-reply-BdYE1gSs.js +1 -0
- package/dist/ui/assets/{wc-attach-xs9Fh-R8.js → wc-attach-DAWHF0q6.js} +3 -3
- package/dist/ui/assets/{wc-detached-ux_E6SNJ.js → wc-detached-DaE992Vl.js} +1 -1
- package/dist/ui/assets/wc-extension-CI60x7Bm.js +2 -0
- package/dist/ui/assets/{wc-live-DHS3FYU1.js → wc-live-C_qPXh6O.js} +11 -11
- package/dist/ui/assets/wc-nav-Fk2p4da7.js +2 -0
- package/dist/ui/assets/wc-onboarding-CKZm1pcF.js +2 -0
- package/dist/ui/assets/wc-placeholder-DcxEXlT1.js +4 -0
- package/dist/ui/assets/{wc-settings-DiYFz75I.js → wc-settings-CrD6Tm6Z.js} +3 -3
- package/dist/ui/assets/{wc-shell-9F74yNEh.js → wc-shell-DPYESGkK.js} +233 -110
- package/dist/ui/assets/wc-sprinkles-DEfLhO36.js +2 -0
- package/dist/ui/assets/wc-tray-CP8sez4_.js +5 -0
- package/dist/ui/assets/wc-voice-erm0EtRv.js +1 -0
- package/dist/ui/assets/welcome-detection-Cr8mNEkt.js +1 -0
- package/dist/ui/assets/whisper-session-DwkDWttW.js +2 -0
- package/dist/ui/assets/xai-grok-BpmkOGg0.js +1 -0
- package/dist/ui/assets/xai-grok-CUqytO26.js +1 -0
- package/dist/ui/index.html +15 -1
- package/dist/ui/packages/webapp/index.html +15 -1
- package/package.json +1 -1
- package/dist/ui/assets/adobe-B4ZijlN3.js +0 -1
- package/dist/ui/assets/adobe-CXtz_LR-.js +0 -2
- package/dist/ui/assets/azure-openai-C-3E46Ld.js +0 -1
- package/dist/ui/assets/azure-openai-DTW6COMC.js +0 -1
- package/dist/ui/assets/azure-openai-responses-CdvI3ZMk.js +0 -1
- package/dist/ui/assets/dip-_QvZN8wj.js +0 -1
- package/dist/ui/assets/esp8266-91jA_HHD.js +0 -1
- package/dist/ui/assets/fs-C3bDUkXJ.js +0 -2
- package/dist/ui/assets/github-CPCc-EUr.js +0 -1
- package/dist/ui/assets/github-DxSzH6PI.js +0 -2
- package/dist/ui/assets/github-copilot-BSdH-X0I.js +0 -1
- package/dist/ui/assets/github-copilot-C0PA1-T1.js +0 -2
- package/dist/ui/assets/google-Cp_gRCg5.js +0 -1
- package/dist/ui/assets/google-shared-BoLRjUxb.js +0 -11
- package/dist/ui/assets/google-vertex-IdSaJxmx.js +0 -1
- package/dist/ui/assets/hosted-config-apply-CizDb9Vw.js +0 -1
- package/dist/ui/assets/legacy-styles-Bt2Mk3g2.js +0 -2
- package/dist/ui/assets/magick-wasm-BCSDiya9.js +0 -1
- package/dist/ui/assets/main-D7K1MTaQ.js +0 -88
- package/dist/ui/assets/main-cherry-CXrrVAC-.js +0 -1
- package/dist/ui/assets/mime-types-BG9Gw1bq.js +0 -1
- package/dist/ui/assets/mount-BYWcec4u.js +0 -2
- package/dist/ui/assets/mount-id-Cy4nG68v.js +0 -1
- package/dist/ui/assets/mount-picker-popup-B4U0fkZK.js +0 -1
- package/dist/ui/assets/new-session-C8X_CG95.js +0 -1
- package/dist/ui/assets/oauth-bootstrap-DIqfOl-7.js +0 -2
- package/dist/ui/assets/oauth-service-CmHwn7zK.js +0 -1
- package/dist/ui/assets/onboarding-orchestrator-DSR8Msku.js +0 -1
- package/dist/ui/assets/openai-codex-Bnd4L2L7.js +0 -1
- package/dist/ui/assets/openai-codex-DkqkFtKq.js +0 -1
- package/dist/ui/assets/openai-completions-CnLJNyQk.js +0 -5
- package/dist/ui/assets/openai-responses-TN943MT8.js +0 -1
- package/dist/ui/assets/panel-rpc-Bcvr75SR.js +0 -1
- package/dist/ui/assets/panel-rpc-handlers-BgzkmaOE.js +0 -2
- package/dist/ui/assets/provider-DQ7BvBZw.js +0 -2
- package/dist/ui/assets/provider-settings-VV6aNiP5.js +0 -99
- package/dist/ui/assets/provider-store-access-BGKXkdbd.js +0 -1
- package/dist/ui/assets/provider-store-access-Vtg1yxDc.js +0 -1
- package/dist/ui/assets/provider-tWBv0sFX.js +0 -1
- package/dist/ui/assets/quick-llm-DdZDN1QH.js +0 -1
- package/dist/ui/assets/remote-cdp-transport-B3-CFmk-.js +0 -1
- package/dist/ui/assets/secret-env-CkbRu-AG.js +0 -1
- package/dist/ui/assets/session-freezer-JMR8P1Lt.js +0 -1
- package/dist/ui/assets/setup-sprinkle-exec-ByJwHfyz.js +0 -1
- package/dist/ui/assets/setup-sudo-DPXnK0Zw.js +0 -1
- package/dist/ui/assets/slicc-editor-BxRqmU98.js +0 -12
- package/dist/ui/assets/sprinkle-manager-CqLTFoc9.js +0 -1
- package/dist/ui/assets/sync-dialog-C1-e9vyv.js +0 -1
- package/dist/ui/assets/tray-runtime-config-BRnpyDNS.js +0 -1
- package/dist/ui/assets/upgrade-detection-CHRBJqBB.js +0 -1
- package/dist/ui/assets/wc-extension-BLxY1h5k.js +0 -2
- package/dist/ui/assets/wc-nav-BZZe3rw8.js +0 -2
- package/dist/ui/assets/wc-onboarding-Cz9h4OE8.js +0 -2
- package/dist/ui/assets/wc-placeholder-CO111fjo.js +0 -4
- package/dist/ui/assets/wc-sprinkles-CUllz5Rn.js +0 -2
- package/dist/ui/assets/wc-tray-DnIxlO0o.js +0 -5
- package/dist/ui/assets/wc-voice-DyAmRENA.js +0 -1
- package/dist/ui/assets/welcome-detection-D-eB9s6-.js +0 -1
- package/dist/ui/assets/xai-grok-BNfjuAeJ.js +0 -1
- package/dist/ui/assets/xai-grok-D8Dda6Qy.js +0 -1
- /package/dist/ui/assets/{dist-C6lFkA1A.js → dist-C6lFkA1A2.js} +0 -0
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{p as e,t}from"./provider-settings-VV6aNiP5.js";import{b as n,f as r,g as i,h as a,m as o,v as s,y as c}from"./bedrock-camp-wxdDcDkR.js";import{l,o as u,u as d}from"./transform-messages-C1X1O3BY.js";const f=`github-copilot`,p=atob(`SXYxLmI1MDdhMDhjODdlY2ZlOTg=`),m={Accept:`application/json`,"Editor-Version":`vscode/1.107.0`,"Editor-Plugin-Version":`copilot-chat/0.35.0`,"Copilot-Integration-Id":`vscode-chat`},h={Accept:`application/json`,"Content-Type":`application/x-www-form-urlencoded`};function g(){return t().find(e=>e.providerId===f)}async function _(){let e=await fetch(`https://github.com/login/device/code`,{method:`POST`,headers:h,body:new URLSearchParams({client_id:p,scope:`read:user`})});if(!e.ok)throw Error(`GitHub device-code request failed: ${e.status} ${e.statusText} — ${await e.text().catch(()=>``)}`);let t=await e.json();if(typeof t.device_code!=`string`||typeof t.user_code!=`string`||typeof t.verification_uri!=`string`||typeof t.expires_in!=`number`||typeof t.interval!=`number`)throw Error(`GitHub device-code response had an unexpected shape`);return t}async function v(e,t){let n=Date.now()+e.expires_in*1e3,r=Math.max(1e3,Math.floor(e.interval*1e3)),i=1.2;for(;Date.now()<n;){if(t.aborted)throw Error(`Copilot login cancelled`);await y(Math.ceil(r*i),t);let n=await fetch(`https://github.com/login/oauth/access_token`,{method:`POST`,headers:h,body:new URLSearchParams({client_id:p,device_code:e.device_code,grant_type:`urn:ietf:params:oauth:grant-type:device_code`})});if(!n.ok)throw Error(`GitHub token poll failed: ${n.status} ${n.statusText} — ${await n.text().catch(()=>``)}`);let a=await n.json();if(typeof a.access_token==`string`&&a.access_token.length>0)return a.access_token;if(a.error!==`authorization_pending`){if(a.error===`slow_down`){r=typeof a.interval==`number`?a.interval*1e3:r+5e3,i=1.4;continue}if(a.error){let e=a.error_description?`: ${a.error_description}`:``;throw Error(`Device flow failed (${a.error})${e}`)}}}throw Error(`Copilot device flow timed out (device code expired)`)}function y(e,t){return new Promise((n,r)=>{if(t.aborted){r(Error(`Copilot login cancelled`));return}let i=setTimeout(n,e);t.addEventListener(`abort`,()=>{clearTimeout(i),r(Error(`Copilot login cancelled`))},{once:!0})})}function b(e){let t=e.match(/proxy-ep=([^;]+)/);return t?`https://${t[1].replace(/^proxy\./,`api.`)}`:null}async function x(e){let t=await fetch(`https://api.github.com/copilot_internal/v2/token`,{headers:{...m,Authorization:`Bearer ${e}`}});if(!t.ok){let e=await t.text().catch(()=>``);throw Error(`Copilot token exchange failed: ${t.status} ${t.statusText} — ${e.slice(0,300)}`)}let n=await t.json();if(typeof n.token!=`string`||typeof n.expires_at!=`number`)throw Error(`Copilot token exchange returned an unexpected payload`);if(n.chat_enabled===!1)throw Error(`GitHub Copilot Chat is disabled for this account (no chat features granted)`);return{copilotToken:n.token,expiresAtMs:n.expires_at*1e3-300*1e3,apiBaseUrl:b(n.token)??`https://api.individual.githubcopilot.com`,githubAccessToken:e}}const S=`github-copilot.models.v1`;function C(e){let t=e.supported_endpoints??[],n=(e.vendor??``).toLowerCase(),r=e.id;return n===`anthropic`&&t.includes(`/v1/messages`)?`anthropic-messages`:n===`openai`&&(/^gpt-5/i.test(r)||/codex/i.test(r)||/^o\d/i.test(r))?`openai-responses`:`openai-completions`}function w(e){if(!e||typeof e!=`object`)return[];let t=e.data;if(!Array.isArray(t))return[];let n=[];for(let e of t)e.capabilities?.type&&e.capabilities.type!==`chat`||e.model_picker_enabled!==!1&&e.id&&n.push({id:e.id,name:e.name??e.id,vendor:e.vendor??``,api:C(e),contextWindow:e.capabilities?.limits?.max_context_window_tokens??e.capabilities?.limits?.max_prompt_tokens??128e3,maxTokens:e.capabilities?.limits?.max_output_tokens??8192,supportsTools:e.capabilities?.supports?.tool_calls===!0,supportsStreaming:e.capabilities?.supports?.streaming!==!1,supportsVision:e.capabilities?.supports?.vision===!0,supportsReasoning:e.capabilities?.supports?.adaptive_thinking===!0||Array.isArray(e.capabilities?.supports?.reasoning_effort),policyState:e.policy?.state??`enabled`});return n}async function T(e){let t=await fetch(`${e.apiBaseUrl}/models`,{headers:{...m,Authorization:`Bearer ${e.copilotToken}`,Accept:`application/json`}});if(!t.ok)throw Error(`Copilot /models returned ${t.status} ${t.statusText}`);return w(await t.json())}function E(){if(typeof localStorage>`u`)return[];try{let e=localStorage.getItem(S);if(!e)return[];let t=JSON.parse(e);return Array.isArray(t)?t:[]}catch{return[]}}function D(e){if(!(typeof localStorage>`u`))try{localStorage.setItem(S,JSON.stringify(e))}catch{}}function O(e){return E().find(t=>t.id===e)??null}async function k(e){let t;try{t=await T(e)}catch(e){console.warn(`[github-copilot] Catalog refresh failed; keeping previous cache.`,e instanceof Error?e.message:String(e));return}D(t),await Promise.all(t.filter(e=>e.policyState===`disabled`).map(async t=>{let n=`${e.apiBaseUrl}/models/${encodeURIComponent(t.id)}/policy`;try{let r=await fetch(n,{method:`POST`,headers:{...m,"Content-Type":`application/json`,Authorization:`Bearer ${e.copilotToken}`,"openai-intent":`chat-policy`,"x-interaction-type":`chat-policy`},body:JSON.stringify({state:`enabled`})});r.ok?t.policyState=`enabled`:r.status!==404&&r.status!==400&&console.warn(`[github-copilot] enable policy for ${t.id} returned ${r.status} ${r.statusText}`)}catch(e){console.warn(`[github-copilot] enable policy for ${t.id} failed:`,e instanceof Error?e.message:String(e))}})),D(t)}async function A(t,n){await e({providerId:f,accessToken:t.copilotToken,refreshToken:t.githubAccessToken,tokenExpiresAt:t.expiresAtMs,baseUrl:t.apiBaseUrl,userName:n})}async function j(){let e=g();if(!e?.accessToken||!e.refreshToken)throw Error(`Not logged in to GitHub Copilot — click "Login" in the provider settings`);let t=e.tokenExpiresAt??0;if(Date.now()<t-6e4)return e.accessToken;let n=await x(e.refreshToken);return await A(n,e.userName),n.copilotToken}const M=[`mini`,`nano`,`flash`,`haiku`,`lite`,`embedding`];function N(e){let t=[e.id,e.name??``].flatMap(e=>{let t=e.toLowerCase();return[t,t.replace(/[\s_.:]+/g,`-`)]});return!M.some(e=>t.some(t=>t.includes(e)))}function P(){if(!g()?.accessToken)return[];let e=E();if(e.length>0)return e.filter(e=>!e.policyState.startsWith(`unavailable:`)).filter(e=>N(e)).map(e=>({id:e.id,name:e.name,api:e.api===`anthropic-messages`?`anthropic`:`openai`,context_window:e.contextWindow,max_tokens:e.maxTokens,reasoning:e.supportsReasoning,input:e.supportsVision?[`text`,`image`]:[`text`]}));let t;try{t=d(`github-copilot`)}catch{return[]}return t.filter(e=>N({id:e.id,name:e.name})).map(e=>({id:e.id,name:e.name??e.id,api:e.api===`anthropic-messages`?`anthropic`:`openai`,context_window:e.contextWindow,max_tokens:e.maxTokens,reasoning:e.reasoning,input:e.input}))}function F(e,t){return{type:`error`,reason:`error`,error:{role:`assistant`,content:[],api:e.api,provider:f,model:e.id,usage:{input:0,output:0,cacheRead:0,cacheWrite:0,totalTokens:0,cost:{input:0,output:0,cacheRead:0,cacheWrite:0,total:0}},stopReason:`error`,errorMessage:t instanceof Error?t.message:String(t),timestamp:Date.now()}}}const I={"User-Agent":`GitHubCopilotChat/0.35.0`,"Editor-Version":`vscode/1.107.0`,"Editor-Plugin-Version":`copilot-chat/0.35.0`,"Copilot-Integration-Id":`vscode-chat`};function L(e){let t=g(),n=t?.baseUrl??`https://api.individual.githubcopilot.com`,r=O(e);if(r)return{api:r.api,baseUrl:n,headers:{...I}};try{let n=l(`github-copilot`,e);return{api:n.api,baseUrl:t?.baseUrl??n.baseUrl,headers:{...n.headers??{},...I}}}catch{return null}}function R(e,t){let n=E(),r=n.findIndex(t=>t.id===e);r<0||(n[r]={...n[r],policyState:`unavailable:${t}`},D(n))}function z(e,t){return`GitHub Copilot rejected "${e}" with model_not_supported. This usually means the model isn't included in your Copilot plan (Opus and other premium models require Copilot Pro / Pro+ / Business / Enterprise). Try Claude Sonnet 4.6 or another model that appears in the picker after a fresh login. Original error: ${t}`}function B(e){if(!e||typeof e!=`object`)return null;let t=e;if(t.type!==`error`)return null;if(t.error&&typeof t.error==`object`){let e=t.error.errorMessage;if(typeof e==`string`)return e}return typeof t.errorMessage==`string`?t.errorMessage:null}function V(e){return(t,n,l={})=>{let d=u();return(async()=>{try{let u=await j(),f=L(t.id);if(!f)throw Error(`GitHub Copilot does not recognize "${t.id}" — open the picker (the model list refreshes on login) and pick a current model.`);let p={...t,api:f.api,baseUrl:f.baseUrl,headers:f.headers,provider:`github-copilot`},m={...l,apiKey:u},h;h=f.api===`anthropic-messages`?(e?i:r)(p,n,m):f.api===`openai-responses`?(e?c:a)(p,n,m):(e?s:o)(p,n,m);for await(let e of h){let n=B(e);if(n&&/model_not_supported/i.test(n)){R(t.id,`model_not_supported`);let e=z(t.id,n);console.error(`[github-copilot] Plan-gated model rejection:`,e),d.push(F(t,Error(e))),d.end();return}d.push(e)}d.end()}catch(e){let n=e instanceof Error?e.message:String(e),r=e;/model_not_supported/i.test(n)&&(R(t.id,`model_not_supported`),r=Error(z(t.id,n))),console.error(`[github-copilot] Stream error:`,r instanceof Error?r.message:String(r)),d.push(F(t,r)),d.end()}})(),d}}const H=V(!1),U=V(!0),W=({userCode:e,verificationUrl:t})=>typeof document>`u`?(console.info(`[github-copilot] Device verification code: ${e} — open ${t} in a browser to authorize.`),Promise.resolve(`continue`)):new Promise(t=>{let n=document.createElement(`div`);n.setAttribute(`data-slicc-overlay`,`github-copilot-device`),n.style.cssText=[`position:fixed`,`top:24px`,`right:24px`,`z-index:2147483647`,`background:#0d1117`,`color:#e6edf3`,`border:1px solid #30363d`,`border-radius:10px`,`padding:16px 18px`,`box-shadow:0 8px 32px rgba(0,0,0,0.45)`,`font:13px/1.4 -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif`,`min-width:260px`,`max-width:340px`].join(`;`);let r=document.createElement(`div`);r.textContent=`GitHub Copilot — verification code`,r.style.cssText=`font-weight:600;margin-bottom:8px;color:#7ee787`;let i=document.createElement(`div`);i.textContent=e,i.style.cssText=[`font:600 22px ui-monospace, SFMono-Regular, Menlo, monospace`,`letter-spacing:2px`,`background:#161b22`,`border:1px solid #30363d`,`border-radius:6px`,`padding:10px 12px`,`text-align:center`,`margin-bottom:10px`,`user-select:all`,`cursor:text`].join(`;`);let a=document.createElement(`div`);a.style.cssText=`color:#8b949e;font-size:12px;line-height:1.5`,a.textContent=`Copy the code, then click Continue to open the GitHub authorization page in a new tab.`;let o=document.createElement(`div`);o.style.cssText=`display:flex;gap:8px;margin-top:12px;justify-content:flex-end`;let s=document.createElement(`button`);s.type=`button`,s.textContent=`Cancel`,s.style.cssText=[`background:transparent`,`color:#e6edf3`,`border:1px solid #30363d`,`border-radius:6px`,`padding:6px 12px`,`font:600 12px inherit`,`cursor:pointer`].join(`;`);let c=document.createElement(`button`);c.type=`button`,c.textContent=`Copy & Continue`,c.style.cssText=[`background:#238636`,`color:#fff`,`border:0`,`border-radius:6px`,`padding:6px 12px`,`font:600 12px inherit`,`cursor:pointer`].join(`;`);let l=()=>{try{n.remove()}catch{}};s.addEventListener(`click`,()=>{l(),t(`cancel`)}),c.addEventListener(`click`,()=>{(async()=>{try{let{copyTextToClipboard:t}=await import(`./clipboard-C2cR8flR.js`).then(e=>e.t);await t(e)}catch{}l(),t(`continue`)})()}),o.appendChild(s),o.appendChild(c),n.appendChild(r),n.appendChild(i),n.appendChild(a),n.appendChild(o),document.body.appendChild(n)}),G={id:f,name:`GitHub Copilot`,description:`Use your GitHub Copilot subscription to access Claude, GPT-5, Codex, Gemini, and Grok models. Sign in with the GitHub device-code flow.`,requiresApiKey:!1,requiresBaseUrl:!1,isOAuth:!0,defaultModelId:`claude-sonnet-4.6`,oauthTokenDomains:[`*.githubcopilot.com`,`api.individual.githubcopilot.com`,`api.business.githubcopilot.com`,`api.enterprise.githubcopilot.com`],getModelIds:P,onOAuthLoginIntercepted:async(e,t,n)=>{let r=await _(),i=new URL(r.verification_uri);if(i.searchParams.set(`user_code`,r.user_code),await(n?.presentDeviceCode??W)({userCode:r.user_code,verificationUrl:i.toString(),expiresInSeconds:r.expires_in})===`cancel`)throw Error(`GitHub Copilot login cancelled`);let a=new AbortController,o=e({authorizeUrl:i.toString(),redirectUriPattern:`https://github.com/login/device/success*`,onCapture:`close`,timeoutMs:r.expires_in*1e3}).catch(e=>(console.warn(`[github-copilot] Launcher failed:`,e instanceof Error?e.message:String(e)),null)),s;try{s=await v(r,a.signal)}catch(e){throw a.abort(),await o,e}await o;let c=await x(s),l;try{let e=await fetch(`https://api.github.com/user`,{headers:{Authorization:`Bearer ${s}`,Accept:`application/json`}});if(e.ok){let t=await e.json();l=t.name||t.login}}catch{}await A(c,l),await k(c),t()},onOAuthLogout:async()=>{await e({providerId:f,accessToken:``})},onSilentRenew:async()=>{let e=g();if(!e?.refreshToken)return null;try{let t=await x(e.refreshToken);return await A(t,e.userName),await k(t),t.copilotToken}catch(e){return console.warn(`[github-copilot] Silent renew failed:`,e instanceof Error?e.message:String(e)),null}}};function K(){n({api:`github-copilot-anthropic`,stream:H,streamSimple:U}),n({api:`github-copilot-openai`,stream:H,streamSimple:U})}export{G as config,N as isCopilotConeCompatible,K as register};
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/main-D7K1MTaQ.js","assets/chunk-aKtaBQYM.js","assets/modulepreload-polyfill-Dezn_h7o.js"])))=>i.map(i=>d[i]);
|
|
2
|
-
import{Dt as e,Ot as t,Tt as n,ft as r,gt as i,ht as a,mt as o,r as s,v as c,vt as l,wt as u,xt as d,yt as f}from"./main-D7K1MTaQ.js";var p=`github-copilot`,m=atob(`SXYxLmI1MDdhMDhjODdlY2ZlOTg=`),h=`https://github.com/login/device/code`,g=`https://github.com/login/oauth/access_token`,_=`https://api.github.com/copilot_internal/v2/token`,v={Accept:`application/json`,"Editor-Version":`vscode/1.107.0`,"Editor-Plugin-Version":`copilot-chat/0.35.0`,"Copilot-Integration-Id":`vscode-chat`},y={Accept:`application/json`,"Content-Type":`application/x-www-form-urlencoded`},b=`https://github.com/login/device/success*`;function x(){return s().find(e=>e.providerId===p)}async function S(){let e=await fetch(h,{method:`POST`,headers:y,body:new URLSearchParams({client_id:m,scope:`read:user`})});if(!e.ok)throw Error(`GitHub device-code request failed: ${e.status} ${e.statusText} — ${await e.text().catch(()=>``)}`);let t=await e.json();if(typeof t.device_code!=`string`||typeof t.user_code!=`string`||typeof t.verification_uri!=`string`||typeof t.expires_in!=`number`||typeof t.interval!=`number`)throw Error(`GitHub device-code response had an unexpected shape`);return t}async function C(e,t){let n=Date.now()+e.expires_in*1e3,r=Math.max(1e3,Math.floor(e.interval*1e3)),i=1.2;for(;Date.now()<n;){if(t.aborted)throw Error(`Copilot login cancelled`);await w(Math.ceil(r*i),t);let n=await fetch(g,{method:`POST`,headers:y,body:new URLSearchParams({client_id:m,device_code:e.device_code,grant_type:`urn:ietf:params:oauth:grant-type:device_code`})});if(!n.ok)throw Error(`GitHub token poll failed: ${n.status} ${n.statusText} — ${await n.text().catch(()=>``)}`);let a=await n.json();if(typeof a.access_token==`string`&&a.access_token.length>0)return a.access_token;if(a.error!==`authorization_pending`){if(a.error===`slow_down`){r=typeof a.interval==`number`?a.interval*1e3:r+5e3,i=1.4;continue}if(a.error){let e=a.error_description?`: ${a.error_description}`:``;throw Error(`Device flow failed (${a.error})${e}`)}}}throw Error(`Copilot device flow timed out (device code expired)`)}function w(e,t){return new Promise((n,r)=>{if(t.aborted){r(Error(`Copilot login cancelled`));return}let i=setTimeout(n,e);t.addEventListener(`abort`,()=>{clearTimeout(i),r(Error(`Copilot login cancelled`))},{once:!0})})}function T(e){let t=e.match(/proxy-ep=([^;]+)/);return t?`https://${t[1].replace(/^proxy\./,`api.`)}`:null}async function E(e){let t=await fetch(_,{headers:{...v,Authorization:`Bearer ${e}`}});if(!t.ok){let e=await t.text().catch(()=>``);throw Error(`Copilot token exchange failed: ${t.status} ${t.statusText} — ${e.slice(0,300)}`)}let n=await t.json();if(typeof n.token!=`string`||typeof n.expires_at!=`number`)throw Error(`Copilot token exchange returned an unexpected payload`);if(n.chat_enabled===!1)throw Error(`GitHub Copilot Chat is disabled for this account (no chat features granted)`);return{copilotToken:n.token,expiresAtMs:n.expires_at*1e3-300*1e3,apiBaseUrl:T(n.token)??`https://api.individual.githubcopilot.com`,githubAccessToken:e}}var D=`github-copilot.models.v1`;function O(e){let t=e.supported_endpoints??[],n=(e.vendor??``).toLowerCase(),r=e.id;return n===`anthropic`&&t.includes(`/v1/messages`)?`anthropic-messages`:n===`openai`&&(/^gpt-5/i.test(r)||/codex/i.test(r)||/^o\d/i.test(r))?`openai-responses`:`openai-completions`}function k(e){if(!e||typeof e!=`object`)return[];let t=e.data;if(!Array.isArray(t))return[];let n=[];for(let e of t)e.capabilities?.type&&e.capabilities.type!==`chat`||e.model_picker_enabled!==!1&&e.id&&n.push({id:e.id,name:e.name??e.id,vendor:e.vendor??``,api:O(e),contextWindow:e.capabilities?.limits?.max_context_window_tokens??e.capabilities?.limits?.max_prompt_tokens??128e3,maxTokens:e.capabilities?.limits?.max_output_tokens??8192,supportsTools:e.capabilities?.supports?.tool_calls===!0,supportsStreaming:e.capabilities?.supports?.streaming!==!1,supportsVision:e.capabilities?.supports?.vision===!0,supportsReasoning:e.capabilities?.supports?.adaptive_thinking===!0||Array.isArray(e.capabilities?.supports?.reasoning_effort),policyState:e.policy?.state??`enabled`});return n}async function A(e){let t=await fetch(`${e.apiBaseUrl}/models`,{headers:{...v,Authorization:`Bearer ${e.copilotToken}`,Accept:`application/json`}});if(!t.ok)throw Error(`Copilot /models returned ${t.status} ${t.statusText}`);return k(await t.json())}function j(){if(typeof localStorage>`u`)return[];try{let e=localStorage.getItem(D);if(!e)return[];let t=JSON.parse(e);return Array.isArray(t)?t:[]}catch{return[]}}function M(e){if(!(typeof localStorage>`u`))try{localStorage.setItem(D,JSON.stringify(e))}catch{}}function N(e){return j().find(t=>t.id===e)??null}async function P(e){let t;try{t=await A(e)}catch(e){console.warn(`[github-copilot] Catalog refresh failed; keeping previous cache.`,e instanceof Error?e.message:String(e));return}M(t),await Promise.all(t.filter(e=>e.policyState===`disabled`).map(async t=>{let n=`${e.apiBaseUrl}/models/${encodeURIComponent(t.id)}/policy`;try{let r=await fetch(n,{method:`POST`,headers:{...v,"Content-Type":`application/json`,Authorization:`Bearer ${e.copilotToken}`,"openai-intent":`chat-policy`,"x-interaction-type":`chat-policy`},body:JSON.stringify({state:`enabled`})});r.ok?t.policyState=`enabled`:r.status!==404&&r.status!==400&&console.warn(`[github-copilot] enable policy for ${t.id} returned ${r.status} ${r.statusText}`)}catch(e){console.warn(`[github-copilot] enable policy for ${t.id} failed:`,e instanceof Error?e.message:String(e))}})),M(t)}async function F(e,t){await c({providerId:p,accessToken:e.copilotToken,refreshToken:e.githubAccessToken,tokenExpiresAt:e.expiresAtMs,baseUrl:e.apiBaseUrl,userName:t})}async function I(){let e=x();if(!e?.accessToken||!e.refreshToken)throw Error(`Not logged in to GitHub Copilot — click "Login" in the provider settings`);let t=e.tokenExpiresAt??0;if(Date.now()<t-6e4)return e.accessToken;let n=await E(e.refreshToken);return await F(n,e.userName),n.copilotToken}var L=[`mini`,`nano`,`flash`,`haiku`,`lite`,`embedding`];function R(e){let t=[e.id,e.name??``].flatMap(e=>{let t=e.toLowerCase();return[t,t.replace(/[\s_.:]+/g,`-`)]});return!L.some(e=>t.some(t=>t.includes(e)))}function z(){if(!x()?.accessToken)return[];let e=j();if(e.length>0)return e.filter(e=>!e.policyState.startsWith(`unavailable:`)).filter(e=>R(e)).map(e=>({id:e.id,name:e.name,api:e.api===`anthropic-messages`?`anthropic`:`openai`,context_window:e.contextWindow,max_tokens:e.maxTokens,reasoning:e.supportsReasoning,input:e.supportsVision?[`text`,`image`]:[`text`]}));let t;try{t=n(`github-copilot`)}catch{return[]}return t.filter(e=>R({id:e.id,name:e.name})).map(e=>({id:e.id,name:e.name??e.id,api:e.api===`anthropic-messages`?`anthropic`:`openai`,context_window:e.contextWindow,max_tokens:e.maxTokens,reasoning:e.reasoning,input:e.input}))}function B(e,t){return{type:`error`,reason:`error`,error:{role:`assistant`,content:[],api:e.api,provider:p,model:e.id,usage:{input:0,output:0,cacheRead:0,cacheWrite:0,totalTokens:0,cost:{input:0,output:0,cacheRead:0,cacheWrite:0,total:0}},stopReason:`error`,errorMessage:t instanceof Error?t.message:String(t),timestamp:Date.now()}}}var V={"User-Agent":`GitHubCopilotChat/0.35.0`,"Editor-Version":`vscode/1.107.0`,"Editor-Plugin-Version":`copilot-chat/0.35.0`,"Copilot-Integration-Id":`vscode-chat`};function H(e){let t=x(),n=t?.baseUrl??`https://api.individual.githubcopilot.com`,r=N(e);if(r)return{api:r.api,baseUrl:n,headers:{...V}};try{let n=u(`github-copilot`,e);return{api:n.api,baseUrl:t?.baseUrl??n.baseUrl,headers:{...n.headers??{},...V}}}catch{return null}}function U(e,t){let n=j(),r=n.findIndex(t=>t.id===e);r<0||(n[r]={...n[r],policyState:`unavailable:${t}`},M(n))}function W(e,t){return`GitHub Copilot rejected "${e}" with model_not_supported. This usually means the model isn't included in your Copilot plan (Opus and other premium models require Copilot Pro / Pro+ / Business / Enterprise). Try Claude Sonnet 4.6 or another model that appears in the picker after a fresh login. Original error: ${t}`}function G(e){if(!e||typeof e!=`object`)return null;let t=e;if(t.type!==`error`)return null;if(t.error&&typeof t.error==`object`){let e=t.error.errorMessage;if(typeof e==`string`)return e}return typeof t.errorMessage==`string`?t.errorMessage:null}function K(e){return(t,n,s={})=>{let c=d();return(async()=>{try{let u=await I(),d=H(t.id);if(!d)throw Error(`GitHub Copilot does not recognize "${t.id}" — open the picker (the model list refreshes on login) and pick a current model.`);let p={...t,api:d.api,baseUrl:d.baseUrl,headers:d.headers,provider:`github-copilot`},m={...s,apiKey:u},h;h=d.api===`anthropic-messages`?(e?i:r)(p,n,m):d.api===`openai-responses`?(e?f:a)(p,n,m):(e?l:o)(p,n,m);for await(let e of h){let n=G(e);if(n&&/model_not_supported/i.test(n)){U(t.id,`model_not_supported`);let e=W(t.id,n);console.error(`[github-copilot] Plan-gated model rejection:`,e),c.push(B(t,Error(e))),c.end();return}c.push(e)}c.end()}catch(e){let n=e instanceof Error?e.message:String(e),r=e;/model_not_supported/i.test(n)&&(U(t.id,`model_not_supported`),r=Error(W(t.id,n))),console.error(`[github-copilot] Stream error:`,r instanceof Error?r.message:String(r)),c.push(B(t,r)),c.end()}})(),c}}var q=K(!1),J=K(!0),Y=({userCode:t,verificationUrl:n})=>typeof document>`u`?(console.info(`[github-copilot] Device verification code: ${t} — open ${n} in a browser to authorize.`),Promise.resolve(`continue`)):new Promise(n=>{let r=document.createElement(`div`);r.setAttribute(`data-slicc-overlay`,`github-copilot-device`),r.style.cssText=[`position:fixed`,`top:24px`,`right:24px`,`z-index:2147483647`,`background:#0d1117`,`color:#e6edf3`,`border:1px solid #30363d`,`border-radius:10px`,`padding:16px 18px`,`box-shadow:0 8px 32px rgba(0,0,0,0.45)`,`font:13px/1.4 -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif`,`min-width:260px`,`max-width:340px`].join(`;`);let i=document.createElement(`div`);i.textContent=`GitHub Copilot — verification code`,i.style.cssText=`font-weight:600;margin-bottom:8px;color:#7ee787`;let a=document.createElement(`div`);a.textContent=t,a.style.cssText=[`font:600 22px ui-monospace, SFMono-Regular, Menlo, monospace`,`letter-spacing:2px`,`background:#161b22`,`border:1px solid #30363d`,`border-radius:6px`,`padding:10px 12px`,`text-align:center`,`margin-bottom:10px`,`user-select:all`,`cursor:text`].join(`;`);let o=document.createElement(`div`);o.style.cssText=`color:#8b949e;font-size:12px;line-height:1.5`,o.textContent=`Copy the code, then click Continue to open the GitHub authorization page in a new tab.`;let s=document.createElement(`div`);s.style.cssText=`display:flex;gap:8px;margin-top:12px;justify-content:flex-end`;let c=document.createElement(`button`);c.type=`button`,c.textContent=`Cancel`,c.style.cssText=[`background:transparent`,`color:#e6edf3`,`border:1px solid #30363d`,`border-radius:6px`,`padding:6px 12px`,`font:600 12px inherit`,`cursor:pointer`].join(`;`);let l=document.createElement(`button`);l.type=`button`,l.textContent=`Copy & Continue`,l.style.cssText=[`background:#238636`,`color:#fff`,`border:0`,`border-radius:6px`,`padding:6px 12px`,`font:600 12px inherit`,`cursor:pointer`].join(`;`);let u=()=>{try{r.remove()}catch{}};c.addEventListener(`click`,()=>{u(),n(`cancel`)}),l.addEventListener(`click`,()=>{(async()=>{try{let{copyTextToClipboard:n}=await e(async()=>{let{copyTextToClipboard:e}=await import(`./main-D7K1MTaQ.js`).then(e=>e.E);return{copyTextToClipboard:e}},__vite__mapDeps([0,1,2]));await n(t)}catch{}u(),n(`continue`)})()}),s.appendChild(c),s.appendChild(l),r.appendChild(i),r.appendChild(a),r.appendChild(o),r.appendChild(s),document.body.appendChild(r)}),X={id:p,name:`GitHub Copilot`,description:`Use your GitHub Copilot subscription to access Claude, GPT-5, Codex, Gemini, and Grok models. Sign in with the GitHub device-code flow.`,requiresApiKey:!1,requiresBaseUrl:!1,isOAuth:!0,defaultModelId:`claude-sonnet-4.6`,oauthTokenDomains:[`*.githubcopilot.com`,`api.individual.githubcopilot.com`,`api.business.githubcopilot.com`,`api.enterprise.githubcopilot.com`],getModelIds:z,onOAuthLoginIntercepted:async(e,t,n)=>{let r=await S(),i=new URL(r.verification_uri);if(i.searchParams.set(`user_code`,r.user_code),await(n?.presentDeviceCode??Y)({userCode:r.user_code,verificationUrl:i.toString(),expiresInSeconds:r.expires_in})===`cancel`)throw Error(`GitHub Copilot login cancelled`);let a=new AbortController,o=e({authorizeUrl:i.toString(),redirectUriPattern:b,onCapture:`close`,timeoutMs:r.expires_in*1e3}).catch(e=>(console.warn(`[github-copilot] Launcher failed:`,e instanceof Error?e.message:String(e)),null)),s;try{s=await C(r,a.signal)}catch(e){throw a.abort(),await o,e}await o;let c=await E(s),l;try{let e=await fetch(`https://api.github.com/user`,{headers:{Authorization:`Bearer ${s}`,Accept:`application/json`}});if(e.ok){let t=await e.json();l=t.name||t.login}}catch{}await F(c,l),await P(c),t()},onOAuthLogout:async()=>{await c({providerId:p,accessToken:``})},onSilentRenew:async()=>{let e=x();if(!e?.refreshToken)return null;try{let t=await E(e.refreshToken);return await F(t,e.userName),await P(t),t.copilotToken}catch(e){return console.warn(`[github-copilot] Silent renew failed:`,e instanceof Error?e.message:String(e)),null}}};function Z(){t({api:`github-copilot-anthropic`,stream:q,streamSimple:J}),t({api:`github-copilot-openai`,stream:q,streamSimple:J})}export{X as config,R as isCopilotConeCompatible,Z as register};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{Ct as e,L as t,St as n,bt as r}from"./main-D7K1MTaQ.js";import{t as i}from"./sanitize-unicode-DmIE6hZJ.js";import{a,i as o,n as s,o as c,r as l,s as u,t as d}from"./google-shared-BoLRjUxb.js";var f=0,p=(e,t,i)=>{let a=new r;return(async()=>{let r={role:`assistant`,content:[],api:`google-generative-ai`,provider:e.provider,model:e.id,usage:{input:0,output:0,cacheRead:0,cacheWrite:0,totalTokens:0,cost:{input:0,output:0,cacheRead:0,cacheWrite:0,total:0}},stopReason:`stop`,timestamp:Date.now()};try{let s=i?.apiKey;if(!s)throw Error(`No API key for provider: ${e.provider}`);let u=h(e,s,i?.headers),d=g(e,t,i),p=await i?.onPayload?.(d,e);p!==void 0&&(d=p);let m=await u.models.generateContentStream(d);a.push({type:`start`,partial:r});let _=null,v=r.content,y=()=>v.length-1;for await(let t of m){r.responseId||=t.responseId;let i=t.candidates?.[0];if(i?.content?.parts)for(let e of i.content.parts){if(e.text!==void 0){let t=l(e);(!_||t&&_.type!==`thinking`||!t&&_.type!==`text`)&&(_&&(_.type===`text`?a.push({type:`text_end`,contentIndex:v.length-1,content:_.text,partial:r}):a.push({type:`thinking_end`,contentIndex:y(),content:_.thinking,partial:r})),t?(_={type:`thinking`,thinking:``,thinkingSignature:void 0},r.content.push(_),a.push({type:`thinking_start`,contentIndex:y(),partial:r})):(_={type:`text`,text:``},r.content.push(_),a.push({type:`text_start`,contentIndex:y(),partial:r}))),_.type===`thinking`?(_.thinking+=e.text,_.thinkingSignature=c(_.thinkingSignature,e.thoughtSignature),a.push({type:`thinking_delta`,contentIndex:y(),delta:e.text,partial:r})):(_.text+=e.text,_.textSignature=c(_.textSignature,e.thoughtSignature),a.push({type:`text_delta`,contentIndex:y(),delta:e.text,partial:r}))}if(e.functionCall){_&&=(_.type===`text`?a.push({type:`text_end`,contentIndex:y(),content:_.text,partial:r}):a.push({type:`thinking_end`,contentIndex:y(),content:_.thinking,partial:r}),null);let t=e.functionCall.id,n={type:`toolCall`,id:!t||r.content.some(e=>e.type===`toolCall`&&e.id===t)?`${e.functionCall.name}_${Date.now()}_${++f}`:t,name:e.functionCall.name||``,arguments:e.functionCall.args??{},...e.thoughtSignature&&{thoughtSignature:e.thoughtSignature}};r.content.push(n),a.push({type:`toolcall_start`,contentIndex:y(),partial:r}),a.push({type:`toolcall_delta`,contentIndex:y(),delta:JSON.stringify(n.arguments),partial:r}),a.push({type:`toolcall_end`,contentIndex:y(),toolCall:n,partial:r})}}i?.finishReason&&(r.stopReason=o(i.finishReason),r.content.some(e=>e.type===`toolCall`)&&(r.stopReason=`toolUse`)),t.usageMetadata&&(r.usage={input:(t.usageMetadata.promptTokenCount||0)-(t.usageMetadata.cachedContentTokenCount||0),output:(t.usageMetadata.candidatesTokenCount||0)+(t.usageMetadata.thoughtsTokenCount||0),cacheRead:t.usageMetadata.cachedContentTokenCount||0,cacheWrite:0,totalTokens:t.usageMetadata.totalTokenCount||0,cost:{input:0,output:0,cacheRead:0,cacheWrite:0,total:0}},n(e,r.usage))}if(_&&(_.type===`text`?a.push({type:`text_end`,contentIndex:y(),content:_.text,partial:r}):a.push({type:`thinking_end`,contentIndex:y(),content:_.thinking,partial:r})),i?.signal?.aborted)throw Error(`Request was aborted`);if(r.stopReason===`aborted`||r.stopReason===`error`)throw Error(`An unknown error occurred`);a.push({type:`done`,reason:r.stopReason,message:r}),a.end()}catch(e){for(let e of r.content)`index`in e&&delete e.index;r.stopReason=i?.signal?.aborted?`aborted`:`error`,r.errorMessage=e instanceof Error?e.message:JSON.stringify(e),a.push({type:`error`,reason:r.stopReason,error:r}),a.end()}})(),a},m=(n,r,i)=>{let a=i?.apiKey;if(!a)throw Error(`No API key for provider: ${n.provider}`);let o=t(n,i,a);if(!i?.reasoning)return p(n,r,{...o,thinking:{enabled:!1}});let s=e(n,i.reasoning),c=s===`off`?`high`:s,l=n;return v(l)||y(l)||_(l)?p(n,r,{...o,thinking:{enabled:!0,level:x(c,l)}}):p(n,r,{...o,thinking:{enabled:!0,budgetTokens:S(l,c,i.thinkingBudgets)}})};function h(e,t,n){let r={};return e.baseUrl&&(r.baseUrl=e.baseUrl,r.apiVersion=``),(e.headers||n)&&(r.headers={...e.headers,...n}),new u({apiKey:t,httpOptions:Object.keys(r).length>0?r:void 0})}function g(e,t,n={}){let r=d(e,t),o={};n.temperature!==void 0&&(o.temperature=n.temperature),n.maxTokens!==void 0&&(o.maxOutputTokens=n.maxTokens);let c={...Object.keys(o).length>0&&o,...t.systemPrompt&&{systemInstruction:i(t.systemPrompt)},...t.tools&&t.tools.length>0&&{tools:s(t.tools)}};if(t.tools&&t.tools.length>0&&n.toolChoice?c.toolConfig={functionCallingConfig:{mode:a(n.toolChoice)}}:c.toolConfig=void 0,n.thinking?.enabled&&e.reasoning){let e={includeThoughts:!0};n.thinking.level===void 0?n.thinking.budgetTokens!==void 0&&(e.thinkingBudget=n.thinking.budgetTokens):e.thinkingLevel=n.thinking.level,c.thinkingConfig=e}else e.reasoning&&n.thinking&&!n.thinking.enabled&&(c.thinkingConfig=b(e));if(n.signal){if(n.signal.aborted)throw Error(`Request aborted`);c.abortSignal=n.signal}return{model:e.id,contents:r,config:c}}function _(e){return/gemma-?4/.test(e.id.toLowerCase())}function v(e){return/gemini-3(?:\.\d+)?-pro/.test(e.id.toLowerCase())}function y(e){return/gemini-3(?:\.\d+)?-flash/.test(e.id.toLowerCase())}function b(e){return v(e)?{thinkingLevel:`LOW`}:y(e)||_(e)?{thinkingLevel:`MINIMAL`}:{thinkingBudget:0}}function x(e,t){if(v(t))switch(e){case`minimal`:case`low`:return`LOW`;case`medium`:case`high`:return`HIGH`}if(_(t))switch(e){case`minimal`:case`low`:return`MINIMAL`;case`medium`:case`high`:return`HIGH`}switch(e){case`minimal`:return`MINIMAL`;case`low`:return`LOW`;case`medium`:return`MEDIUM`;case`high`:return`HIGH`}}function S(e,t,n){return n?.[t]===void 0?e.id.includes(`2.5-pro`)?{minimal:128,low:2048,medium:8192,high:32768}[t]:e.id.includes(`2.5-flash-lite`)?{minimal:512,low:2048,medium:8192,high:24576}[t]:e.id.includes(`2.5-flash`)?{minimal:128,low:2048,medium:8192,high:24576}[t]:-1:n[t]}export{p as streamGoogle,m as streamSimpleGoogle};
|