sliccy 4.3.0 → 4.4.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.
Files changed (85) hide show
  1. package/dist/node-server/index.js +645 -1550
  2. package/dist/node-server/routes/fetch-proxy.d.ts +12 -0
  3. package/dist/node-server/routes/fetch-proxy.js +316 -0
  4. package/dist/node-server/routes/handoff.d.ts +48 -0
  5. package/dist/node-server/routes/handoff.js +60 -0
  6. package/dist/node-server/routes/lick-api.d.ts +7 -0
  7. package/dist/node-server/routes/lick-api.js +129 -0
  8. package/dist/node-server/routes/lick-bridge.d.ts +16 -0
  9. package/dist/node-server/routes/lick-bridge.js +73 -0
  10. package/dist/node-server/routes/oauth-callback.d.ts +11 -0
  11. package/dist/node-server/routes/oauth-callback.js +62 -0
  12. package/dist/node-server/routes/secrets.d.ts +17 -0
  13. package/dist/node-server/routes/secrets.js +204 -0
  14. package/dist/node-server/ui-serving.d.ts +18 -0
  15. package/dist/node-server/ui-serving.js +91 -0
  16. package/dist/ui/assets/{account-store-B7QAqqi3.js → account-store-DDmdZHbw.js} +2 -2
  17. package/dist/ui/assets/{account-store-C8na8kHM.js → account-store-DYwow2TA.js} +2 -2
  18. package/dist/ui/assets/{adobe-CLAtsbgy.js → adobe-Yy9fISE-.js} +1 -1
  19. package/dist/ui/assets/{adobe-B3FAPCSl.js → adobe-hTPIFNJv.js} +1 -1
  20. package/dist/ui/assets/{agent-message-to-chat-u5bAg3Dv.js → agent-message-to-chat-9I5BpCy9.js} +1 -1
  21. package/dist/ui/assets/{apps-BrQb6D54.js → apps-D8Gdju73.js} +1 -1
  22. package/dist/ui/assets/{azure-openai-DdRohXjQ.js → azure-openai-C2W9g3IJ.js} +1 -1
  23. package/dist/ui/assets/{azure-openai-BfAHTf5F.js → azure-openai-DRB4IDfJ.js} +1 -1
  24. package/dist/ui/assets/{bsh-watchdog-Bc7J2Bk7.js → bsh-watchdog-Bt9CqKVQ.js} +1 -1
  25. package/dist/ui/assets/{connect-surface-FrHkI2dH.js → connect-surface-DQzchqkg.js} +1 -1
  26. package/dist/ui/assets/dip-DFaUkk4F.js +1 -0
  27. package/dist/ui/assets/{dist-eq0qrLpe.js → dist-CO9fGFcy.js} +1 -1
  28. package/dist/ui/assets/{dist-DOo6fKGj.js → dist-Doek6FYy.js} +1 -1
  29. package/dist/ui/assets/{es-CRDAPvPn.js → es-DIdFAR_x.js} +1 -1
  30. package/dist/ui/assets/{fs-Bd1RYTR9.js → fs-B11hxMFT.js} +2 -2
  31. package/dist/ui/assets/{fs-BlUrfzJM.js → fs-Tyk_pbIn.js} +1 -1
  32. package/dist/ui/assets/{github-Dik4gFKy.js → github-B71DA8E3.js} +2 -2
  33. package/dist/ui/assets/{github-CqzS1etP.js → github-CPiFDsp3.js} +1 -1
  34. package/dist/ui/assets/{github-copilot-yPQNbALb.js → github-copilot-BfiOICFw.js} +1 -1
  35. package/dist/ui/assets/{github-copilot-B2O232DQ.js → github-copilot-uEeOT_7K.js} +1 -1
  36. package/dist/ui/assets/{hear-UQAn2f9B.js → hear-CfpqqXo5.js} +1 -1
  37. package/dist/ui/assets/{kernel-worker-BMe--kS1.js → kernel-worker-CJBmf2_H.js} +631 -631
  38. package/dist/ui/assets/{kokoro-engine-Cu1pI-kR.js → kokoro-engine-C6AgVvUa.js} +1 -1
  39. package/dist/ui/assets/{lick-ws-bridge-DAuwCMQO.js → lick-ws-bridge-BMBeGHRK.js} +1 -1
  40. package/dist/ui/assets/{local-llm-l4-XQFY8.js → local-llm-CEaARq5R.js} +1 -1
  41. package/dist/ui/assets/{main-BDx9HQkN.js → main-BHrstcdQ.js} +3 -3
  42. package/dist/ui/assets/{mount-CWCvNUcA.js → mount-BwDyizK9.js} +1 -1
  43. package/dist/ui/assets/{mount-D5vdZ9ZD.js → mount-CyEIOV30.js} +2 -2
  44. package/dist/ui/assets/{new-session-Gr9WMwtw.js → new-session-CfhcCQAp.js} +1 -1
  45. package/dist/ui/assets/{oauth-bootstrap-BsfJ9QeQ.js → oauth-bootstrap-Tcg85q8p.js} +2 -2
  46. package/dist/ui/assets/{openai-codex-kuA3-9C7.js → openai-codex-BDz5Fxit.js} +1 -1
  47. package/dist/ui/assets/{openai-codex-BaNE798j.js → openai-codex-CVcod1ia.js} +1 -1
  48. package/dist/ui/assets/{panel-rpc-handlers-BcpEgTGa.js → panel-rpc-handlers-DPUizpgv.js} +1 -1
  49. package/dist/ui/assets/{provider-CEn9M9_r.js → provider-DcMNUxfM.js} +1 -1
  50. package/dist/ui/assets/{provider-BmbE_rtX.js → provider-DdXgyWQC.js} +2 -2
  51. package/dist/ui/assets/provider-store-access-BwZ-Ogkc.js +1 -0
  52. package/dist/ui/assets/provider-store-access-gZjBUTYS.js +1 -0
  53. package/dist/ui/assets/{providers-MUCDnWww.js → providers-CcWtOmn0.js} +1 -1
  54. package/dist/ui/assets/{quick-llm-DB--outF.js → quick-llm-BKbreZXe.js} +1 -1
  55. package/dist/ui/assets/session-freezer-DMAACMXD.js +1 -0
  56. package/dist/ui/assets/setup-sudo-CsL0Y3UH.js +1 -0
  57. package/dist/ui/assets/{speak-BHHbBLx8.js → speak-Bv-b3EVQ.js} +1 -1
  58. package/dist/ui/assets/{sprinkle-manager-COo-zwx8.js → sprinkle-manager-CBrsHbU3.js} +1 -1
  59. package/dist/ui/assets/{store-CqhogTXq.js → store-BwHhL-tv.js} +1 -1
  60. package/dist/ui/assets/{sudo-IiXNo0Z2.js → sudo-DZ9_0JRP.js} +1 -1
  61. package/dist/ui/assets/{transformers-env-d7AMEyAX.js → transformers-env-XuyWgfSl.js} +1 -1
  62. package/dist/ui/assets/{tray-leave-runtime-CQ20HzV5.js → tray-leave-runtime-Ww3km3lu.js} +1 -1
  63. package/dist/ui/assets/{upgrade-detection-CqAg8yKN.js → upgrade-detection-_YQCwW8c.js} +1 -1
  64. package/dist/ui/assets/{wc-attach-NtXmSLiR.js → wc-attach-BGApOJUg.js} +2 -2
  65. package/dist/ui/assets/{wc-detached-TITxuKki.js → wc-detached-mQvIrRCJ.js} +1 -1
  66. package/dist/ui/assets/{wc-extension-Dy7sBRt4.js → wc-extension-DmWG-O_B.js} +2 -2
  67. package/dist/ui/assets/{wc-live-CKs-VTsl.js → wc-live-CA1EDWiu.js} +5 -5
  68. package/dist/ui/assets/wc-nav-BF5SsYYe.js +2 -0
  69. package/dist/ui/assets/{wc-onboarding-D4j2oDHI.js → wc-onboarding-CVMo_Eqf.js} +2 -2
  70. package/dist/ui/assets/{wc-placeholder-Cg0ggHwo.js → wc-placeholder-BUbREW79.js} +2 -2
  71. package/dist/ui/assets/{wc-settings-BlGVWM4o.js → wc-settings-MQTTeP3O.js} +2 -2
  72. package/dist/ui/assets/{wc-shell-RljPbgFJ.js → wc-shell-CZSwcbtB.js} +9 -5
  73. package/dist/ui/assets/{wc-sprinkles-B791LgwY.js → wc-sprinkles-BUD5Miwy.js} +2 -2
  74. package/dist/ui/assets/{wc-tray-DCscOwKN.js → wc-tray-iifyjNN6.js} +3 -3
  75. package/dist/ui/assets/{xai-grok-Dh1WJ9QS.js → xai-grok-BrM3dm3w.js} +1 -1
  76. package/dist/ui/assets/{xai-grok-Z0dPXLgr.js → xai-grok-CPiFjFiB.js} +1 -1
  77. package/dist/ui/index.html +2 -2
  78. package/dist/ui/packages/webapp/index.html +2 -2
  79. package/package.json +6 -5
  80. package/dist/ui/assets/dip-CBvyzPyQ.js +0 -1
  81. package/dist/ui/assets/provider-store-access-BSVI8UyE.js +0 -1
  82. package/dist/ui/assets/provider-store-access-CWZqsjgW.js +0 -1
  83. package/dist/ui/assets/session-freezer-DUHrs9By.js +0 -1
  84. package/dist/ui/assets/setup-sudo-B5JoDQ4W.js +0 -1
  85. package/dist/ui/assets/wc-nav-BSmxk4Wx.js +0 -2
@@ -0,0 +1,62 @@
1
+ import express from 'express';
2
+ /**
3
+ * Generic OAuth redirect target for OAuth providers (implicit + PKCE).
4
+ *
5
+ * The callback page tries `window.opener.postMessage` first (works in the
6
+ * CLI popup flow). When `window.opener` is null (Electron overlay opens the
7
+ * system browser), it falls back to POSTing the result to
8
+ * `/api/oauth-result`, which the UI polls via the GET counterpart — the
9
+ * server holds the single pending result in memory between the two calls.
10
+ */
11
+ export function registerOAuthCallbackRoutes(app) {
12
+ // Pending OAuth result for server-side relay (Electron overlay can't use window.opener)
13
+ let pendingOAuthResult = null;
14
+ app.get('/auth/callback', (_req, res) => {
15
+ res.send(`<!DOCTYPE html><html><body><script>
16
+ var q = new URLSearchParams(location.search);
17
+ var h = new URLSearchParams(location.hash.replace(/^#/, ''));
18
+ var payload = {
19
+ type: 'oauth-callback',
20
+ redirectUrl: location.href,
21
+ code: q.get('code'),
22
+ state: q.get('state') || h.get('state'),
23
+ error: q.get('error') || h.get('error'),
24
+ access_token: h.get('access_token'),
25
+ expires_in: h.get('expires_in'),
26
+ token_type: h.get('token_type')
27
+ };
28
+ if (window.opener) {
29
+ window.opener.postMessage(payload, '*');
30
+ } else {
31
+ fetch('/api/oauth-result', {
32
+ method: 'POST',
33
+ headers: { 'Content-Type': 'application/json' },
34
+ body: JSON.stringify(payload)
35
+ }).catch(function(err) { console.error('[oauth-callback] Failed to relay result to server:', err); });
36
+ }
37
+ window.close();
38
+ </script><p>Completing login... you can close this window.</p></body></html>`);
39
+ });
40
+ app.post('/api/oauth-result', express.json(), (req, res) => {
41
+ const body = req.body;
42
+ const redirectUrl = typeof body.redirectUrl === 'string' ? body.redirectUrl : '';
43
+ if (!redirectUrl) {
44
+ console.warn('[oauth-result] Received callback with empty redirectUrl');
45
+ }
46
+ pendingOAuthResult = {
47
+ redirectUrl,
48
+ error: typeof body.error === 'string' ? body.error : undefined,
49
+ };
50
+ res.json({ ok: true });
51
+ });
52
+ app.get('/api/oauth-result', (_req, res) => {
53
+ if (pendingOAuthResult) {
54
+ const result = pendingOAuthResult;
55
+ pendingOAuthResult = null;
56
+ res.json(result);
57
+ }
58
+ else {
59
+ res.status(204).end();
60
+ }
61
+ });
62
+ }
@@ -0,0 +1,17 @@
1
+ import { type Express } from 'express';
2
+ import type { EnvSecretStore } from '../secrets/env-secret-store.js';
3
+ import type { OauthSecretStore } from '../secrets/oauth-secret-store.js';
4
+ import type { SecretProxyManager } from '../secrets/proxy-manager.js';
5
+ export interface SecretRoutesDeps {
6
+ secretStore: EnvSecretStore;
7
+ secretProxy: SecretProxyManager;
8
+ oauthStore: OauthSecretStore;
9
+ /** When true, the full sign-and-forward error is logged for the local operator. */
10
+ devMode: boolean;
11
+ }
12
+ /**
13
+ * Secret management API — direct .env file access (no browser needed). The
14
+ * `secretStore` is wired into `secretProxy` so the fetch-proxy and the
15
+ * management API share one source of truth.
16
+ */
17
+ export declare function registerSecretRoutes(app: Express, deps: SecretRoutesDeps): void;
@@ -0,0 +1,204 @@
1
+ import { previewSecret } from '../_shared/index.js';
2
+ import express from 'express';
3
+ import { handleDaSignAndForward, handleS3SignAndForward } from '../secrets/sign-and-forward.js';
4
+ /**
5
+ * Sign-and-forward failure responder. Logs only a generic line + trace id —
6
+ * the err.message can carry profile names, bucket names, or partial URLs we
7
+ * don't want in shared log aggregators. The trace id lets the user correlate
8
+ * the 500 they got with the server log; the detail goes to the file logger
9
+ * (above DEBUG) only when devMode is on.
10
+ */
11
+ function respondSignAndForwardError(res, err, devMode, label) {
12
+ const traceId = (globalThis.crypto?.randomUUID?.() ?? Math.random().toString(36).slice(2, 10)).slice(0, 8);
13
+ console.error(`${label} sign-and-forward error [trace=${traceId}]`);
14
+ if (devMode) {
15
+ console.error(err);
16
+ }
17
+ if (!res.headersSent) {
18
+ res.status(500).json({
19
+ ok: false,
20
+ error: `internal sign-and-forward error [trace=${traceId}]`,
21
+ errorCode: 'internal',
22
+ });
23
+ }
24
+ }
25
+ function isStringArray(value) {
26
+ return Array.isArray(value) && value.every((d) => typeof d === 'string');
27
+ }
28
+ /**
29
+ * Secret management API — direct .env file access (no browser needed). The
30
+ * `secretStore` is wired into `secretProxy` so the fetch-proxy and the
31
+ * management API share one source of truth.
32
+ */
33
+ export function registerSecretRoutes(app, deps) {
34
+ const { secretStore, secretProxy, oauthStore, devMode } = deps;
35
+ app.get('/api/secrets', (_req, res) => {
36
+ try {
37
+ res.json(secretStore.list());
38
+ }
39
+ catch (err) {
40
+ res
41
+ .status(500)
42
+ .json({ error: err instanceof Error ? err.message : 'Failed to list secrets' });
43
+ }
44
+ });
45
+ // Persisted-set — write a secret to ~/.slicc/secrets.env. Gated by the agent's
46
+ // intrinsic sudo prompt before the request is ever sent.
47
+ app.post('/api/secrets', express.json(), async (req, res) => {
48
+ const { name, value, domains } = req.body ?? {};
49
+ if (typeof name !== 'string' || typeof value !== 'string' || !isStringArray(domains)) {
50
+ return res.status(400).json({ error: 'bad-request' });
51
+ }
52
+ try {
53
+ secretStore.set(name, value, domains);
54
+ await secretProxy.reload();
55
+ res.json({ ok: true });
56
+ }
57
+ catch (err) {
58
+ res.status(500).json({ error: err instanceof Error ? err.message : 'Failed to set secret' });
59
+ }
60
+ });
61
+ // Scope edit — update the allowed domains of an existing secret (persisted or
62
+ // session), preserving the value. Gated by the agent before sending.
63
+ app.post('/api/secrets/scope', express.json(), async (req, res) => {
64
+ const { name, domains } = req.body ?? {};
65
+ if (typeof name !== 'string' || !isStringArray(domains)) {
66
+ return res.status(400).json({ error: 'bad-request' });
67
+ }
68
+ try {
69
+ if (secretProxy.sessionStore.has(name)) {
70
+ secretProxy.sessionStore.setDomains(name, domains);
71
+ }
72
+ else {
73
+ const existing = secretStore.get(name);
74
+ if (!existing)
75
+ return res.status(404).json({ error: `no secret named "${name}"` });
76
+ secretStore.set(name, existing.value, domains);
77
+ }
78
+ await secretProxy.reload();
79
+ res.json({ ok: true });
80
+ }
81
+ catch (err) {
82
+ res
83
+ .status(500)
84
+ .json({ error: err instanceof Error ? err.message : 'Failed to update scope' });
85
+ }
86
+ });
87
+ // Session secrets — in-memory only, never written to disk. Free for the agent
88
+ // to create; the masking pipeline picks them up on the reload below.
89
+ app.get('/api/secrets/session', (_req, res) => {
90
+ res.json(secretProxy.sessionStore.list());
91
+ });
92
+ app.post('/api/secrets/session', express.json(), async (req, res) => {
93
+ const { name, value, domains } = req.body ?? {};
94
+ if (typeof name !== 'string' ||
95
+ typeof value !== 'string' ||
96
+ (domains !== undefined && !isStringArray(domains))) {
97
+ return res.status(400).json({ error: 'bad-request' });
98
+ }
99
+ secretProxy.sessionStore.set(name, value, Array.isArray(domains) ? domains : []);
100
+ await secretProxy.reload();
101
+ res.json({ ok: true });
102
+ });
103
+ // Peek — elided preview of the unmasked value (session or persisted). The
104
+ // full value never leaves the server.
105
+ app.get('/api/secrets/peek', (req, res) => {
106
+ const name = typeof req.query.name === 'string' ? req.query.name : '';
107
+ if (!name)
108
+ return res.status(400).json({ error: 'bad-request' });
109
+ const session = secretProxy.sessionStore.getRecord(name);
110
+ if (session) {
111
+ return res.json({ name, preview: previewSecret(session.value), domains: session.domains });
112
+ }
113
+ const persisted = secretStore.get(name);
114
+ if (persisted) {
115
+ return res.json({
116
+ name,
117
+ preview: previewSecret(persisted.value),
118
+ domains: persisted.domains,
119
+ });
120
+ }
121
+ return res.status(404).json({ error: `no secret named "${name}"` });
122
+ });
123
+ // S3 sign-and-forward — browser-side mount backend posts envelopes here;
124
+ // server resolves the s3.<profile>.* secrets, signs SigV4 v4, forwards to
125
+ // the upstream, returns the response as a JSON envelope. The browser
126
+ // never sees access_key_id / secret_access_key.
127
+ app.post('/api/s3-sign-and-forward', async (req, res) => {
128
+ try {
129
+ await handleS3SignAndForward(req, res, secretStore);
130
+ }
131
+ catch (err) {
132
+ respondSignAndForwardError(res, err, devMode, 'S3');
133
+ }
134
+ });
135
+ // DA sign-and-forward — same pattern as S3, but for Adobe da.live. The
136
+ // IMS bearer token is passed transiently in the envelope (browser holds
137
+ // it via the existing Adobe LLM provider). v2 will move OAuth server-side
138
+ // to remove the browser exposure entirely.
139
+ app.post('/api/da-sign-and-forward', async (req, res) => {
140
+ try {
141
+ await handleDaSignAndForward(req, res);
142
+ }
143
+ catch (err) {
144
+ respondSignAndForwardError(res, err, devMode, 'DA');
145
+ }
146
+ });
147
+ // Tool-output real→masked scrub. The browser-side agent realm never holds
148
+ // real secret values, so the defense-in-depth scrub of bash / read_file /
149
+ // other tool results runs here against the node-server-owned
150
+ // SecretProxyManager. Direction is real→masked ONLY (`scrubResponse`), so it
151
+ // is always safe and idempotent for already-masked tokens and secret-free
152
+ // output. The caller treats any non-2xx / malformed response as "return
153
+ // input unchanged" — the scrub is defense-in-depth, not the primary defense.
154
+ app.post('/api/secrets/scrub', express.json({ limit: '32mb' }), (req, res) => {
155
+ const text = req.body?.text;
156
+ if (typeof text !== 'string') {
157
+ return res.status(400).json({ error: 'bad-request' });
158
+ }
159
+ try {
160
+ res.json({ text: secretProxy.scrubResponse(text) });
161
+ }
162
+ catch (err) {
163
+ res.status(500).json({ error: err instanceof Error ? err.message : 'scrub failed', text });
164
+ }
165
+ });
166
+ // Masked secrets endpoint — returns name + maskedValue pairs for shell env
167
+ // population. Real values are never exposed; only deterministic
168
+ // session-scoped masks.
169
+ app.get('/api/secrets/masked', (_req, res) => {
170
+ try {
171
+ res.json(secretProxy.getMaskedEntries());
172
+ }
173
+ catch (err) {
174
+ res
175
+ .status(500)
176
+ .json({ error: err instanceof Error ? err.message : 'Failed to get masked secrets' });
177
+ }
178
+ });
179
+ // OAuth secret update — stores access token from OAuth login flow
180
+ app.post('/api/secrets/oauth-update', express.json(), async (req, res) => {
181
+ const { providerId, accessToken, domains } = req.body ?? {};
182
+ if (typeof providerId !== 'string' ||
183
+ typeof accessToken !== 'string' ||
184
+ !isStringArray(domains) ||
185
+ domains.length === 0) {
186
+ return res.status(400).json({ error: 'bad-request' });
187
+ }
188
+ const name = `oauth.${providerId}.token`;
189
+ oauthStore.set(name, accessToken, domains);
190
+ await secretProxy.reload();
191
+ const masked = secretProxy.getMaskedEntries().find((e) => e.name === name)?.maskedValue;
192
+ res.json({ providerId, name, maskedValue: masked, domains });
193
+ });
194
+ // OAuth secret deletion — removes access token on logout
195
+ app.delete('/api/secrets/oauth/:providerId', async (req, res) => {
196
+ const name = `oauth.${req.params.providerId}.token`;
197
+ if (!oauthStore.list().some((e) => e.name === name)) {
198
+ return res.status(404).json({ error: 'not-found' });
199
+ }
200
+ oauthStore.delete(name);
201
+ await secretProxy.reload();
202
+ res.status(204).end();
203
+ });
204
+ }
@@ -0,0 +1,18 @@
1
+ import type { Server as HttpServer } from 'node:http';
2
+ import { type Express } from 'express';
3
+ export interface UiServingOptions {
4
+ devMode: boolean;
5
+ hosted: boolean;
6
+ /** Origin string used only for the dev-server log line. */
7
+ serveOrigin: string;
8
+ /** Built UI directory served in production mode. */
9
+ uiDir: string;
10
+ /** Repo root used to locate the webapp Vite config in dev mode. */
11
+ webappRoot?: string;
12
+ }
13
+ /**
14
+ * Attach UI serving to the Express app. In dev mode (and not hosted) this wires
15
+ * Vite's dev server as middleware for HMR; otherwise it serves the built static
16
+ * bundle with an SPA fallback.
17
+ */
18
+ export declare function attachUiServing(app: Express, server: HttpServer, opts: UiServingOptions): Promise<void>;
@@ -0,0 +1,91 @@
1
+ import { readFileSync } from 'node:fs';
2
+ import { join, resolve, sep } from 'node:path';
3
+ import express from 'express';
4
+ /**
5
+ * Attach UI serving to the Express app. In dev mode (and not hosted) this wires
6
+ * Vite's dev server as middleware for HMR; otherwise it serves the built static
7
+ * bundle with an SPA fallback.
8
+ */
9
+ export async function attachUiServing(app, server, opts) {
10
+ if (opts.devMode && !opts.hosted) {
11
+ await attachViteDevServer(app, server, opts);
12
+ }
13
+ else {
14
+ attachStaticServing(app, opts.uiDir);
15
+ }
16
+ }
17
+ async function attachViteDevServer(app, server, opts) {
18
+ const root = opts.webappRoot ?? process.cwd();
19
+ const { createServer: createViteServer } = await import('vite');
20
+ const webappIndexHtml = resolve(root, 'packages/webapp/index.html');
21
+ const vite = await createViteServer({
22
+ configFile: resolve(root, 'packages/webapp/vite.config.ts'),
23
+ server: {
24
+ middlewareMode: true,
25
+ hmr: {
26
+ server, // Share the HTTP server — our upgrade handler routes /cdp and /licks-ws separately
27
+ path: '/__vite_hmr', // Dedicated path avoids conflicts with /cdp upgrade handler
28
+ },
29
+ },
30
+ appType: 'custom', // We handle index.html serving ourselves via the handler below
31
+ root,
32
+ });
33
+ app.use(vite.middlewares);
34
+ app.use(async (req, res, next) => {
35
+ if (req.method !== 'GET' ||
36
+ !req.headers.accept?.includes('text/html') ||
37
+ req.path.includes('.')) {
38
+ next();
39
+ return;
40
+ }
41
+ try {
42
+ const template = readFileSync(webappIndexHtml, 'utf-8');
43
+ const html = await vite.transformIndexHtml(req.originalUrl, template);
44
+ res.status(200).setHeader('Content-Type', 'text/html');
45
+ res.end(html);
46
+ }
47
+ catch (err) {
48
+ if (err instanceof Error) {
49
+ vite.ssrFixStacktrace(err);
50
+ }
51
+ next(err);
52
+ }
53
+ });
54
+ console.log(`Vite dev server middleware attached (HMR on ${opts.serveOrigin}/__vite_hmr)`);
55
+ }
56
+ /**
57
+ * Cache-Control policy for the built static bundle. Default `no-cache` forces a
58
+ * cheap conditional revalidation so a stale `index.html` never pins outdated
59
+ * `/assets/<hash>.js` references; service workers are `no-store`; content-hashed
60
+ * `/assets/*` are immutable. Each branch overrides the default by assigning to
61
+ * `cacheControl` — never add a separate setHeader after, or the catch-all wins.
62
+ */
63
+ function setStaticCacheControl(res, path) {
64
+ let cacheControl = 'no-cache';
65
+ if (path.endsWith('llm-proxy-sw.js') || path.endsWith('preview-sw.js')) {
66
+ // Service workers need `Service-Worker-Allowed: /` for the root-scoped
67
+ // registration `llm-proxy-sw.js` does (`preview-sw.js` registers at the
68
+ // narrower `/preview/` scope, so the broader allowance is harmless).
69
+ // `no-store`, not `no-cache`: a stale SW pinned in cache would intercept
70
+ // fetch / dispatch `preview/*` with outdated logic — a worse failure mode
71
+ // than the revalidation cost.
72
+ res.setHeader('Service-Worker-Allowed', '/');
73
+ cacheControl = 'no-store';
74
+ }
75
+ else if (path.includes(`${sep}assets${sep}`)) {
76
+ // Vite emits content-hashed filenames into `/assets/` — immutable per URL.
77
+ // `path` is a filesystem path, hence the platform-aware `sep` match.
78
+ cacheControl = 'public, max-age=31536000, immutable';
79
+ }
80
+ res.setHeader('Cache-Control', cacheControl);
81
+ }
82
+ function attachStaticServing(app, uiDir) {
83
+ app.use(express.static(uiDir, { setHeaders: setStaticCacheControl }));
84
+ // SPA fallback — serve index.html for all non-file routes. The served
85
+ // index.html carries references to the current asset hashes, and stale-cached
86
+ // HTML is the canonical post-update breakage, hence `no-cache`.
87
+ app.get('/{*path}', (_req, res) => {
88
+ res.setHeader('Cache-Control', 'no-cache');
89
+ res.sendFile(join(uiDir, 'index.html'));
90
+ });
91
+ }
@@ -1,4 +1,4 @@
1
- import{r as e,t}from"./chunk-CMxvf4Kt.js";import{t as n}from"./logger-LESFN7Hj.js";import{n as r,r as i}from"./tool-ui-N76-EdVc.js";import{n as a,r as o}from"./src-CpdsjHiA.js";import{n as s,r as c}from"./panel-rpc-Ck8CVyMh.js";import{n as l,o as u,t as d}from"./providers-MUCDnWww.js";import{c as f,d as p,r as m,t as h,u as g}from"./bedrock-camp-wxdDcDkR.js";import{d as _,l as v,u as y}from"./transform-messages-C1X1O3BY.js";async function b(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 S(s,o,n,i,r,a),o}async function x(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 S(o,a,t,r,n,i),a}async function S(e,t,n,r,i,a){let o=e,s=n,c=!0,l=await s.getSteeringMessages?.()||[];for(;;){let e=!0;for(;e||l.length>0;){if(c?c=!1:await i({type:`turn_start`}),l.length>0){for(let e of l)await i({type:`message_start`,message:e}),await i({type:`message_end`,message:e}),o.messages.push(e),t.push(e);l=[]}let n=await ee(o,s,r,i,a);if(t.push(n),n.stopReason===`error`||n.stopReason===`aborted`){await i({type:`turn_end`,message:n,toolResults:[]}),await i({type:`agent_end`,messages:t});return}let u=n.content.filter(e=>e.type===`toolCall`),d=[];if(e=!1,u.length>0){let a=await te(o,n,s,r,i);d.push(...a.messages),e=!a.terminate;for(let e of d)o.messages.push(e),t.push(e)}await i({type:`turn_end`,message:n,toolResults:d});let f={message:n,toolResults:d,context:o,newMessages:t},p=await s.prepareNextTurn?.(f);if(p&&(o=p.context??o,s={...s,model:p.model??s.model,reasoning:p.thinkingLevel===void 0?s.reasoning:p.thinkingLevel===`off`?void 0:p.thinkingLevel}),await s.shouldStopAfterTurn?.({message:n,toolResults:d,context:o,newMessages:t})){await i({type:`agent_end`,messages:t});return}l=await s.getSteeringMessages?.()||[]}let n=await s.getFollowUpMessages?.()||[];if(n.length>0){l=n;continue}break}await i({type:`agent_end`,messages:t})}async function ee(e,t,n,r,i){let a=e.messages;t.transformContext&&(a=await t.transformContext(a,n));let o=await t.convertToLlm(a),s={systemPrompt:e.systemPrompt,messages:o,tools:e.tools},c=i||p,l=(t.getApiKey?await t.getApiKey(t.model.provider):void 0)||t.apiKey,u=await c(t.model,s,{...t,apiKey:l,signal:n}),d=null,f=!1;for await(let t of u)switch(t.type){case`start`:d=t.partial,e.messages.push(d),f=!0,await r({type:`message_start`,message:{...d}});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`:d&&(d=t.partial,e.messages[e.messages.length-1]=d,await r({type:`message_update`,assistantMessageEvent:t,message:{...d}}));break;case`done`:case`error`:{let t=await u.result();return f?e.messages[e.messages.length-1]=t:e.messages.push(t),f||await r({type:`message_start`,message:{...t}}),await r({type:`message_end`,message:t}),t}}let m=await u.result();return f?e.messages[e.messages.length-1]=m:(e.messages.push(m),await r({type:`message_start`,message:{...m}})),await r({type:`message_end`,message:m}),m}async function te(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?ne(e,t,a,n,r,i):re(e,t,a,n,r,i)}async function ne(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 oe(e,t,c,r,i),l;l=n.kind===`immediate`?{toolCall:c,result:n.result,isError:n.isError}:await se(e,t,n,await C(n,i,a),r,i),await T(l,a);let u=ce(l);if(await le(u,a),o.push(l),s.push(u),i?.aborted)break}return{messages:s,terminate:ie(o)}}async function re(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 oe(e,t,s,r,i);if(n.kind===`immediate`){let e={toolCall:s,result:n.result,isError:n.isError};if(await T(e,a),o.push(e),i?.aborted)break;continue}if(o.push(async()=>{let o=await se(e,t,n,await C(n,i,a),r,i);return await T(o,a),o}),i?.aborted)break}let s=await Promise.all(o.map(e=>typeof e==`function`?e():Promise.resolve(e))),c=[];for(let e of s){let t=ce(e);await le(t,a),c.push(t)}return{messages:c,terminate:ie(s)}}function ie(e){return e.length>0&&e.every(e=>e.result.terminate===!0)}function ae(e,t){if(!e.prepareArguments)return t;let n=e.prepareArguments(t.arguments);return n===t.arguments?t:{...t,arguments:n}}async function oe(e,t,n,r,i){let a=e.tools?.find(e=>e.name===n.name);if(!a)return{kind:`immediate`,result:w(`Tool ${n.name} not found`),isError:!0};try{let o=f(a,ae(a,n));if(r.beforeToolCall){let a=await r.beforeToolCall({assistantMessage:t,toolCall:n,args:o,context:e},i);if(i?.aborted)return{kind:`immediate`,result:w(`Operation aborted`),isError:!0};if(a?.block)return{kind:`immediate`,result:w(a.reason||`Tool execution was blocked`),isError:!0}}return i?.aborted?{kind:`immediate`,result:w(`Operation aborted`),isError:!0}:{kind:`prepared`,toolCall:n,tool:a,args:o}}catch(e){return{kind:`immediate`,result:w(e instanceof Error?e.message:String(e)),isError:!0}}}async function C(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:w(e instanceof Error?e.message:String(e)),isError:!0}}}async function se(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=w(e instanceof Error?e.message:String(e)),s=!0}return{toolCall:n.toolCall,result:o,isError:s}}function w(e){return{content:[{type:`text`,text:e}],details:{}}}async function T(e,t){await t({type:`tool_execution_end`,toolCallId:e.toolCall.id,toolName:e.toolCall.name,result:e.result,isError:e.isError})}function ce(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 le(e,t){await t({type:`message_start`,message:e}),await t({type:`message_end`,message:e})}function ue(e){return e.filter(e=>e.role===`user`||e.role===`assistant`||e.role===`toolResult`)}const de={input:0,output:0,cacheRead:0,cacheWrite:0,totalTokens:0,cost:{input:0,output:0,cacheRead:0,cacheWrite:0,total:0}},fe={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 pe(e){let t=e?.tools?.slice()??[],n=e?.messages?.slice()??[];return{systemPrompt:e?.systemPrompt??``,model:e?.model??fe,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 me=class{messages=[];mode;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=[]}},he=class{_state;listeners=new Set;steeringQueue;followUpQueue;convertToLlm;transformContext;streamFn;getApiKey;onPayload;onResponse;beforeToolCall;afterToolCall;prepareNextTurn;activeRun;sessionId;thinkingBudgets;transport;maxRetryDelayMs;toolExecution;constructor(e={}){this._state=pe(e.initialState),this.convertToLlm=e.convertToLlm??ue,this.transformContext=e.transformContext,this.streamFn=e.streamFn??p,this.getApiKey=e.getApiKey,this.onPayload=e.onPayload,this.onResponse=e.onResponse,this.beforeToolCall=e.beforeToolCall,this.afterToolCall=e.afterToolCall,this.prepareNextTurn=e.prepareNextTurn,this.steeringQueue=new me(e.steeringMode??`one-at-a-time`),this.followUpQueue=new me(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 b(e,this.createContextSnapshot(),this.createLoopConfig(t),e=>this.processEvents(e),n,this.streamFn)})}async runContinuation(){await this.runWithLifecycle(async e=>{await x(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,prepareNextTurn:this.prepareNextTurn?async()=>await this.prepareNextTurn?.(this.signal):void 0,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:de,stopReason:t?`aborted`:`error`,errorMessage:e instanceof Error?e.message:String(e),timestamp:Date.now()};await this.processEvents({type:`message_start`,message:n}),await this.processEvents({type:`message_end`,message:n}),await this.processEvents({type:`turn_end`,message:n,toolResults:[]}),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 ge=Symbol.for(`yaml.alias`),_e=Symbol.for(`yaml.document`),E=Symbol.for(`yaml.map`),ve=Symbol.for(`yaml.pair`),ye=Symbol.for(`yaml.scalar`),be=Symbol.for(`yaml.seq`),D=Symbol.for(`yaml.node.type`),O=e=>!!e&&typeof e==`object`&&e[D]===ge,xe=e=>!!e&&typeof e==`object`&&e[D]===_e,Se=e=>!!e&&typeof e==`object`&&e[D]===E,k=e=>!!e&&typeof e==`object`&&e[D]===ve,A=e=>!!e&&typeof e==`object`&&e[D]===ye,Ce=e=>!!e&&typeof e==`object`&&e[D]===be;function j(e){if(e&&typeof e==`object`)switch(e[D]){case E:case be:return!0}return!1}function M(e){if(e&&typeof e==`object`)switch(e[D]){case ge:case E:case ye:case be:return!0}return!1}const we=e=>(A(e)||j(e))&&!!e.anchor,N=Symbol(`break visit`),Te=Symbol(`skip children`),P=Symbol(`remove node`);function Ee(e,t){let n=Oe(t);xe(e)?F(null,e.contents,n,Object.freeze([e]))===P&&(e.contents=null):F(null,e,n,Object.freeze([]))}Ee.BREAK=N,Ee.SKIP=Te,Ee.REMOVE=P;function F(e,t,n,r){let i=ke(e,t,n,r);if(M(i)||k(i))return Ae(e,r,i),F(e,i,n,r);if(typeof i!=`symbol`){if(j(t)){r=Object.freeze(r.concat(t));for(let e=0;e<t.items.length;++e){let i=F(e,t.items[e],n,r);if(typeof i==`number`)e=i-1;else if(i===N)return N;else i===P&&(t.items.splice(e,1),--e)}}else if(k(t)){r=Object.freeze(r.concat(t));let e=F(`key`,t.key,n,r);if(e===N)return N;e===P&&(t.key=null);let i=F(`value`,t.value,n,r);if(i===N)return N;i===P&&(t.value=null)}}return i}async function De(e,t){let n=Oe(t);xe(e)?await I(null,e.contents,n,Object.freeze([e]))===P&&(e.contents=null):await I(null,e,n,Object.freeze([]))}De.BREAK=N,De.SKIP=Te,De.REMOVE=P;async function I(e,t,n,r){let i=await ke(e,t,n,r);if(M(i)||k(i))return Ae(e,r,i),I(e,i,n,r);if(typeof i!=`symbol`){if(j(t)){r=Object.freeze(r.concat(t));for(let e=0;e<t.items.length;++e){let i=await I(e,t.items[e],n,r);if(typeof i==`number`)e=i-1;else if(i===N)return N;else i===P&&(t.items.splice(e,1),--e)}}else if(k(t)){r=Object.freeze(r.concat(t));let e=await I(`key`,t.key,n,r);if(e===N)return N;e===P&&(t.key=null);let i=await I(`value`,t.value,n,r);if(i===N)return N;i===P&&(t.value=null)}}return i}function Oe(e){return typeof e==`object`&&(e.Collection||e.Node||e.Value)?Object.assign({Alias:e.Node,Map:e.Node,Scalar:e.Node,Seq:e.Node},e.Value&&{Map:e.Value,Scalar:e.Value,Seq:e.Value},e.Collection&&{Map:e.Collection,Seq:e.Collection},e):e}function ke(e,t,n,r){if(typeof n==`function`)return n(e,t,r);if(Se(t))return n.Map?.(e,t,r);if(Ce(t))return n.Seq?.(e,t,r);if(k(t))return n.Pair?.(e,t,r);if(A(t))return n.Scalar?.(e,t,r);if(O(t))return n.Alias?.(e,t,r)}function Ae(e,t,n){let r=t[t.length-1];if(j(r))r.items[e]=n;else if(k(r))e===`key`?r.key=n:r.value=n;else if(xe(r))r.contents=n;else{let e=O(r)?`alias`:`scalar`;throw Error(`Cannot replace node with ${e} parent`)}}const je={"!":`%21`,",":`%2C`,"[":`%5B`,"]":`%5D`,"{":`%7B`,"}":`%7D`},Me=e=>e.replace(/[!,[\]{}]/g,e=>je[e]);var Ne=class e{constructor(t,n){this.docStart=null,this.docEnd=!1,this.yaml=Object.assign({},e.defaultYaml,t),this.tags=Object.assign({},e.defaultTags,n)}clone(){let t=new e(this.yaml,this.tags);return t.docStart=this.docStart,t}atDocument(){let t=new e(this.yaml,this.tags);switch(this.yaml.version){case`1.1`:this.atNextDocument=!0;break;case`1.2`:this.atNextDocument=!1,this.yaml={explicit:e.defaultYaml.explicit,version:`1.2`},this.tags=Object.assign({},e.defaultTags);break}return t}add(t,n){this.atNextDocument&&=(this.yaml={explicit:e.defaultYaml.explicit,version:`1.1`},this.tags=Object.assign({},e.defaultTags),!1);let r=t.trim().split(/[ \t]+/),i=r.shift();switch(i){case`%TAG`:{if(r.length!==2&&(n(0,`%TAG directive should contain exactly two parts`),r.length<2))return!1;let[e,t]=r;return this.tags[e]=t,!0}case`%YAML`:{if(this.yaml.explicit=!0,r.length!==1)return n(0,`%YAML directive should contain exactly one part`),!1;let[e]=r;if(e===`1.1`||e===`1.2`)return this.yaml.version=e,!0;{let t=/^\d+\.\d+$/.test(e);return n(6,`Unsupported YAML version ${e}`,t),!1}}default:return n(0,`Unknown directive ${i}`,!0),!1}}tagName(e,t){if(e===`!`)return`!`;if(e[0]!==`!`)return t(`Not a valid tag: ${e}`),null;if(e[1]===`<`){let n=e.slice(2,-1);return n===`!`||n===`!!`?(t(`Verbatim tags aren't resolved, so ${e} is invalid.`),null):(e[e.length-1]!==`>`&&t(`Verbatim tags must end with a >`),n)}let[,n,r]=e.match(/^(.*!)([^!]*)$/s);r||t(`The ${e} tag has no suffix`);let i=this.tags[n];if(i)try{return i+decodeURIComponent(r)}catch(e){return t(String(e)),null}return n===`!`?e:(t(`Could not resolve tag: ${e}`),null)}tagString(e){for(let[t,n]of Object.entries(this.tags))if(e.startsWith(n))return t+Me(e.substring(n.length));return e[0]===`!`?e:`!<${e}>`}toString(e){let t=this.yaml.explicit?[`%YAML ${this.yaml.version||`1.2`}`]:[],n=Object.entries(this.tags),r;if(e&&n.length>0&&M(e.contents)){let t={};Ee(e.contents,(e,n)=>{M(n)&&n.tag&&(t[n.tag]=!0)}),r=Object.keys(t)}else r=[];for(let[i,a]of n)i===`!!`&&a===`tag:yaml.org,2002:`||(!e||r.some(e=>e.startsWith(a)))&&t.push(`%TAG ${i} ${a}`);return t.join(`
1
+ import{r as e,t}from"./chunk-CMxvf4Kt.js";import{t as n}from"./logger-LESFN7Hj.js";import{n as r,r as i}from"./tool-ui-N76-EdVc.js";import{n as a,r as o}from"./src-CpdsjHiA.js";import{n as s,r as c}from"./panel-rpc-Ck8CVyMh.js";import{n as l,o as u,t as d}from"./providers-CcWtOmn0.js";import{c as f,d as p,r as m,t as h,u as g}from"./bedrock-camp-wxdDcDkR.js";import{d as _,l as v,u as y}from"./transform-messages-C1X1O3BY.js";async function b(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 S(s,o,n,i,r,a),o}async function x(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 S(o,a,t,r,n,i),a}async function S(e,t,n,r,i,a){let o=e,s=n,c=!0,l=await s.getSteeringMessages?.()||[];for(;;){let e=!0;for(;e||l.length>0;){if(c?c=!1:await i({type:`turn_start`}),l.length>0){for(let e of l)await i({type:`message_start`,message:e}),await i({type:`message_end`,message:e}),o.messages.push(e),t.push(e);l=[]}let n=await ee(o,s,r,i,a);if(t.push(n),n.stopReason===`error`||n.stopReason===`aborted`){await i({type:`turn_end`,message:n,toolResults:[]}),await i({type:`agent_end`,messages:t});return}let u=n.content.filter(e=>e.type===`toolCall`),d=[];if(e=!1,u.length>0){let a=await te(o,n,s,r,i);d.push(...a.messages),e=!a.terminate;for(let e of d)o.messages.push(e),t.push(e)}await i({type:`turn_end`,message:n,toolResults:d});let f={message:n,toolResults:d,context:o,newMessages:t},p=await s.prepareNextTurn?.(f);if(p&&(o=p.context??o,s={...s,model:p.model??s.model,reasoning:p.thinkingLevel===void 0?s.reasoning:p.thinkingLevel===`off`?void 0:p.thinkingLevel}),await s.shouldStopAfterTurn?.({message:n,toolResults:d,context:o,newMessages:t})){await i({type:`agent_end`,messages:t});return}l=await s.getSteeringMessages?.()||[]}let n=await s.getFollowUpMessages?.()||[];if(n.length>0){l=n;continue}break}await i({type:`agent_end`,messages:t})}async function ee(e,t,n,r,i){let a=e.messages;t.transformContext&&(a=await t.transformContext(a,n));let o=await t.convertToLlm(a),s={systemPrompt:e.systemPrompt,messages:o,tools:e.tools},c=i||p,l=(t.getApiKey?await t.getApiKey(t.model.provider):void 0)||t.apiKey,u=await c(t.model,s,{...t,apiKey:l,signal:n}),d=null,f=!1;for await(let t of u)switch(t.type){case`start`:d=t.partial,e.messages.push(d),f=!0,await r({type:`message_start`,message:{...d}});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`:d&&(d=t.partial,e.messages[e.messages.length-1]=d,await r({type:`message_update`,assistantMessageEvent:t,message:{...d}}));break;case`done`:case`error`:{let t=await u.result();return f?e.messages[e.messages.length-1]=t:e.messages.push(t),f||await r({type:`message_start`,message:{...t}}),await r({type:`message_end`,message:t}),t}}let m=await u.result();return f?e.messages[e.messages.length-1]=m:(e.messages.push(m),await r({type:`message_start`,message:{...m}})),await r({type:`message_end`,message:m}),m}async function te(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?ne(e,t,a,n,r,i):re(e,t,a,n,r,i)}async function ne(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 oe(e,t,c,r,i),l;l=n.kind===`immediate`?{toolCall:c,result:n.result,isError:n.isError}:await se(e,t,n,await C(n,i,a),r,i),await T(l,a);let u=ce(l);if(await le(u,a),o.push(l),s.push(u),i?.aborted)break}return{messages:s,terminate:ie(o)}}async function re(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 oe(e,t,s,r,i);if(n.kind===`immediate`){let e={toolCall:s,result:n.result,isError:n.isError};if(await T(e,a),o.push(e),i?.aborted)break;continue}if(o.push(async()=>{let o=await se(e,t,n,await C(n,i,a),r,i);return await T(o,a),o}),i?.aborted)break}let s=await Promise.all(o.map(e=>typeof e==`function`?e():Promise.resolve(e))),c=[];for(let e of s){let t=ce(e);await le(t,a),c.push(t)}return{messages:c,terminate:ie(s)}}function ie(e){return e.length>0&&e.every(e=>e.result.terminate===!0)}function ae(e,t){if(!e.prepareArguments)return t;let n=e.prepareArguments(t.arguments);return n===t.arguments?t:{...t,arguments:n}}async function oe(e,t,n,r,i){let a=e.tools?.find(e=>e.name===n.name);if(!a)return{kind:`immediate`,result:w(`Tool ${n.name} not found`),isError:!0};try{let o=f(a,ae(a,n));if(r.beforeToolCall){let a=await r.beforeToolCall({assistantMessage:t,toolCall:n,args:o,context:e},i);if(i?.aborted)return{kind:`immediate`,result:w(`Operation aborted`),isError:!0};if(a?.block)return{kind:`immediate`,result:w(a.reason||`Tool execution was blocked`),isError:!0}}return i?.aborted?{kind:`immediate`,result:w(`Operation aborted`),isError:!0}:{kind:`prepared`,toolCall:n,tool:a,args:o}}catch(e){return{kind:`immediate`,result:w(e instanceof Error?e.message:String(e)),isError:!0}}}async function C(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:w(e instanceof Error?e.message:String(e)),isError:!0}}}async function se(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=w(e instanceof Error?e.message:String(e)),s=!0}return{toolCall:n.toolCall,result:o,isError:s}}function w(e){return{content:[{type:`text`,text:e}],details:{}}}async function T(e,t){await t({type:`tool_execution_end`,toolCallId:e.toolCall.id,toolName:e.toolCall.name,result:e.result,isError:e.isError})}function ce(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 le(e,t){await t({type:`message_start`,message:e}),await t({type:`message_end`,message:e})}function ue(e){return e.filter(e=>e.role===`user`||e.role===`assistant`||e.role===`toolResult`)}const de={input:0,output:0,cacheRead:0,cacheWrite:0,totalTokens:0,cost:{input:0,output:0,cacheRead:0,cacheWrite:0,total:0}},fe={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 pe(e){let t=e?.tools?.slice()??[],n=e?.messages?.slice()??[];return{systemPrompt:e?.systemPrompt??``,model:e?.model??fe,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 me=class{messages=[];mode;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=[]}},he=class{_state;listeners=new Set;steeringQueue;followUpQueue;convertToLlm;transformContext;streamFn;getApiKey;onPayload;onResponse;beforeToolCall;afterToolCall;prepareNextTurn;activeRun;sessionId;thinkingBudgets;transport;maxRetryDelayMs;toolExecution;constructor(e={}){this._state=pe(e.initialState),this.convertToLlm=e.convertToLlm??ue,this.transformContext=e.transformContext,this.streamFn=e.streamFn??p,this.getApiKey=e.getApiKey,this.onPayload=e.onPayload,this.onResponse=e.onResponse,this.beforeToolCall=e.beforeToolCall,this.afterToolCall=e.afterToolCall,this.prepareNextTurn=e.prepareNextTurn,this.steeringQueue=new me(e.steeringMode??`one-at-a-time`),this.followUpQueue=new me(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 b(e,this.createContextSnapshot(),this.createLoopConfig(t),e=>this.processEvents(e),n,this.streamFn)})}async runContinuation(){await this.runWithLifecycle(async e=>{await x(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,prepareNextTurn:this.prepareNextTurn?async()=>await this.prepareNextTurn?.(this.signal):void 0,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:de,stopReason:t?`aborted`:`error`,errorMessage:e instanceof Error?e.message:String(e),timestamp:Date.now()};await this.processEvents({type:`message_start`,message:n}),await this.processEvents({type:`message_end`,message:n}),await this.processEvents({type:`turn_end`,message:n,toolResults:[]}),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 ge=Symbol.for(`yaml.alias`),_e=Symbol.for(`yaml.document`),E=Symbol.for(`yaml.map`),ve=Symbol.for(`yaml.pair`),ye=Symbol.for(`yaml.scalar`),be=Symbol.for(`yaml.seq`),D=Symbol.for(`yaml.node.type`),O=e=>!!e&&typeof e==`object`&&e[D]===ge,xe=e=>!!e&&typeof e==`object`&&e[D]===_e,Se=e=>!!e&&typeof e==`object`&&e[D]===E,k=e=>!!e&&typeof e==`object`&&e[D]===ve,A=e=>!!e&&typeof e==`object`&&e[D]===ye,Ce=e=>!!e&&typeof e==`object`&&e[D]===be;function j(e){if(e&&typeof e==`object`)switch(e[D]){case E:case be:return!0}return!1}function M(e){if(e&&typeof e==`object`)switch(e[D]){case ge:case E:case ye:case be:return!0}return!1}const we=e=>(A(e)||j(e))&&!!e.anchor,N=Symbol(`break visit`),Te=Symbol(`skip children`),P=Symbol(`remove node`);function Ee(e,t){let n=Oe(t);xe(e)?F(null,e.contents,n,Object.freeze([e]))===P&&(e.contents=null):F(null,e,n,Object.freeze([]))}Ee.BREAK=N,Ee.SKIP=Te,Ee.REMOVE=P;function F(e,t,n,r){let i=ke(e,t,n,r);if(M(i)||k(i))return Ae(e,r,i),F(e,i,n,r);if(typeof i!=`symbol`){if(j(t)){r=Object.freeze(r.concat(t));for(let e=0;e<t.items.length;++e){let i=F(e,t.items[e],n,r);if(typeof i==`number`)e=i-1;else if(i===N)return N;else i===P&&(t.items.splice(e,1),--e)}}else if(k(t)){r=Object.freeze(r.concat(t));let e=F(`key`,t.key,n,r);if(e===N)return N;e===P&&(t.key=null);let i=F(`value`,t.value,n,r);if(i===N)return N;i===P&&(t.value=null)}}return i}async function De(e,t){let n=Oe(t);xe(e)?await I(null,e.contents,n,Object.freeze([e]))===P&&(e.contents=null):await I(null,e,n,Object.freeze([]))}De.BREAK=N,De.SKIP=Te,De.REMOVE=P;async function I(e,t,n,r){let i=await ke(e,t,n,r);if(M(i)||k(i))return Ae(e,r,i),I(e,i,n,r);if(typeof i!=`symbol`){if(j(t)){r=Object.freeze(r.concat(t));for(let e=0;e<t.items.length;++e){let i=await I(e,t.items[e],n,r);if(typeof i==`number`)e=i-1;else if(i===N)return N;else i===P&&(t.items.splice(e,1),--e)}}else if(k(t)){r=Object.freeze(r.concat(t));let e=await I(`key`,t.key,n,r);if(e===N)return N;e===P&&(t.key=null);let i=await I(`value`,t.value,n,r);if(i===N)return N;i===P&&(t.value=null)}}return i}function Oe(e){return typeof e==`object`&&(e.Collection||e.Node||e.Value)?Object.assign({Alias:e.Node,Map:e.Node,Scalar:e.Node,Seq:e.Node},e.Value&&{Map:e.Value,Scalar:e.Value,Seq:e.Value},e.Collection&&{Map:e.Collection,Seq:e.Collection},e):e}function ke(e,t,n,r){if(typeof n==`function`)return n(e,t,r);if(Se(t))return n.Map?.(e,t,r);if(Ce(t))return n.Seq?.(e,t,r);if(k(t))return n.Pair?.(e,t,r);if(A(t))return n.Scalar?.(e,t,r);if(O(t))return n.Alias?.(e,t,r)}function Ae(e,t,n){let r=t[t.length-1];if(j(r))r.items[e]=n;else if(k(r))e===`key`?r.key=n:r.value=n;else if(xe(r))r.contents=n;else{let e=O(r)?`alias`:`scalar`;throw Error(`Cannot replace node with ${e} parent`)}}const je={"!":`%21`,",":`%2C`,"[":`%5B`,"]":`%5D`,"{":`%7B`,"}":`%7D`},Me=e=>e.replace(/[!,[\]{}]/g,e=>je[e]);var Ne=class e{constructor(t,n){this.docStart=null,this.docEnd=!1,this.yaml=Object.assign({},e.defaultYaml,t),this.tags=Object.assign({},e.defaultTags,n)}clone(){let t=new e(this.yaml,this.tags);return t.docStart=this.docStart,t}atDocument(){let t=new e(this.yaml,this.tags);switch(this.yaml.version){case`1.1`:this.atNextDocument=!0;break;case`1.2`:this.atNextDocument=!1,this.yaml={explicit:e.defaultYaml.explicit,version:`1.2`},this.tags=Object.assign({},e.defaultTags);break}return t}add(t,n){this.atNextDocument&&=(this.yaml={explicit:e.defaultYaml.explicit,version:`1.1`},this.tags=Object.assign({},e.defaultTags),!1);let r=t.trim().split(/[ \t]+/),i=r.shift();switch(i){case`%TAG`:{if(r.length!==2&&(n(0,`%TAG directive should contain exactly two parts`),r.length<2))return!1;let[e,t]=r;return this.tags[e]=t,!0}case`%YAML`:{if(this.yaml.explicit=!0,r.length!==1)return n(0,`%YAML directive should contain exactly one part`),!1;let[e]=r;if(e===`1.1`||e===`1.2`)return this.yaml.version=e,!0;{let t=/^\d+\.\d+$/.test(e);return n(6,`Unsupported YAML version ${e}`,t),!1}}default:return n(0,`Unknown directive ${i}`,!0),!1}}tagName(e,t){if(e===`!`)return`!`;if(e[0]!==`!`)return t(`Not a valid tag: ${e}`),null;if(e[1]===`<`){let n=e.slice(2,-1);return n===`!`||n===`!!`?(t(`Verbatim tags aren't resolved, so ${e} is invalid.`),null):(e[e.length-1]!==`>`&&t(`Verbatim tags must end with a >`),n)}let[,n,r]=e.match(/^(.*!)([^!]*)$/s);r||t(`The ${e} tag has no suffix`);let i=this.tags[n];if(i)try{return i+decodeURIComponent(r)}catch(e){return t(String(e)),null}return n===`!`?e:(t(`Could not resolve tag: ${e}`),null)}tagString(e){for(let[t,n]of Object.entries(this.tags))if(e.startsWith(n))return t+Me(e.substring(n.length));return e[0]===`!`?e:`!<${e}>`}toString(e){let t=this.yaml.explicit?[`%YAML ${this.yaml.version||`1.2`}`]:[],n=Object.entries(this.tags),r;if(e&&n.length>0&&M(e.contents)){let t={};Ee(e.contents,(e,n)=>{M(n)&&n.tag&&(t[n.tag]=!0)}),r=Object.keys(t)}else r=[];for(let[i,a]of n)i===`!!`&&a===`tag:yaml.org,2002:`||(!e||r.some(e=>e.startsWith(a)))&&t.push(`%TAG ${i} ${a}`);return t.join(`
2
2
  `)}};Ne.defaultYaml={explicit:!1,version:`1.2`},Ne.defaultTags={"!!":`tag:yaml.org,2002:`};function Pe(e){if(/[\x00-\x19\s,[\]{}]/.test(e)){let t=`Anchor must not contain whitespace or control characters: ${JSON.stringify(e)}`;throw Error(t)}return!0}function Fe(e,t,n,r){if(r&&typeof r==`object`)if(Array.isArray(r))for(let t=0,n=r.length;t<n;++t){let n=r[t],i=Fe(e,r,String(t),n);i===void 0?delete r[t]:i!==n&&(r[t]=i)}else if(r instanceof Map)for(let t of Array.from(r.keys())){let n=r.get(t),i=Fe(e,r,t,n);i===void 0?r.delete(t):i!==n&&r.set(t,i)}else if(r instanceof Set)for(let t of Array.from(r)){let n=Fe(e,r,t,t);n===void 0?r.delete(t):n!==t&&(r.delete(t),r.add(n))}else for(let[t,n]of Object.entries(r)){let i=Fe(e,r,t,n);i===void 0?delete r[t]:i!==n&&(r[t]=i)}return e.call(t,n,r)}function L(e,t,n){if(Array.isArray(e))return e.map((e,t)=>L(e,String(t),n));if(e&&typeof e.toJSON==`function`){if(!n||!we(e))return e.toJSON(t,n);let r={aliasCount:0,count:1,res:void 0};n.anchors.set(e,r),n.onCreate=e=>{r.res=e,delete n.onCreate};let i=e.toJSON(t,n);return n.onCreate&&n.onCreate(i),i}return typeof e==`bigint`&&!n?.keep?Number(e):e}var Ie=class{constructor(e){Object.defineProperty(this,D,{value:e})}clone(){let e=Object.create(Object.getPrototypeOf(this),Object.getOwnPropertyDescriptors(this));return this.range&&(e.range=this.range.slice()),e}toJS(e,{mapAsMap:t,maxAliasCount:n,onAnchor:r,reviver:i}={}){if(!xe(e))throw TypeError(`A document argument is required`);let a={anchors:new Map,doc:e,keep:!0,mapAsMap:t===!0,mapKeyWarned:!1,maxAliasCount:typeof n==`number`?n:100},o=L(this,``,a);if(typeof r==`function`)for(let{count:e,res:t}of a.anchors.values())r(t,e);return typeof i==`function`?Fe(i,{"":o},``,o):o}},Le=class extends Ie{constructor(e){super(ge),this.source=e,Object.defineProperty(this,"tag",{set(){throw Error(`Alias nodes cannot have tags`)}})}resolve(e,t){if(t?.maxAliasCount===0)throw ReferenceError(`Alias resolution is disabled`);let n;t?.aliasResolveCache?n=t.aliasResolveCache:(n=[],Ee(e,{Node:(e,t)=>{(O(t)||we(t))&&n.push(t)}}),t&&(t.aliasResolveCache=n));let r;for(let e of n){if(e===this)break;e.anchor===this.source&&(r=e)}return r}toJSON(e,t){if(!t)return{source:this.source};let{anchors:n,doc:r,maxAliasCount:i}=t,a=this.resolve(r,t);if(!a){let e=`Unresolved alias (the anchor must be set before the alias): ${this.source}`;throw ReferenceError(e)}let o=n.get(a);if(o||=(L(a,null,t),n.get(a)),o?.res===void 0)throw ReferenceError(`This should not happen: Alias anchor was not resolved?`);if(i>=0&&(o.count+=1,o.aliasCount===0&&(o.aliasCount=Re(r,a,n)),o.count*o.aliasCount>i))throw ReferenceError(`Excessive alias count indicates a resource exhaustion attack`);return o.res}toString(e,t,n){let r=`*${this.source}`;if(e){if(Pe(this.source),e.options.verifyAliasOrder&&!e.anchors.has(this.source)){let e=`Unresolved alias (the anchor must be set before the alias): ${this.source}`;throw Error(e)}if(e.implicitKey)return`${r} `}return r}};function Re(e,t,n){if(O(t)){let r=t.resolve(e),i=n&&r&&n.get(r);return i?i.count*i.aliasCount:0}else if(j(t)){let r=0;for(let i of t.items){let t=Re(e,i,n);t>r&&(r=t)}return r}else if(k(t)){let r=Re(e,t.key,n),i=Re(e,t.value,n);return Math.max(r,i)}return 1}const ze=e=>!e||typeof e!=`function`&&typeof e!=`object`;var R=class extends Ie{constructor(e){super(ye),this.value=e}toJSON(e,t){return t?.keep?this.value:L(this.value,e,t)}toString(){return String(this.value)}};R.BLOCK_FOLDED=`BLOCK_FOLDED`,R.BLOCK_LITERAL=`BLOCK_LITERAL`,R.PLAIN=`PLAIN`,R.QUOTE_DOUBLE=`QUOTE_DOUBLE`,R.QUOTE_SINGLE=`QUOTE_SINGLE`;function Be(e,t,n){if(t){let e=n.filter(e=>e.tag===t),r=e.find(e=>!e.format)??e[0];if(!r)throw Error(`Tag ${t} not found`);return r}return n.find(t=>t.identify?.(e)&&!t.format)}function Ve(e,t,n){if(xe(e)&&(e=e.contents),M(e))return e;if(k(e)){let t=n.schema[E].createNode?.(n.schema,null,n);return t.items.push(e),t}(e instanceof String||e instanceof Number||e instanceof Boolean||typeof BigInt<`u`&&e instanceof BigInt)&&(e=e.valueOf());let{aliasDuplicateObjects:r,onAnchor:i,onTagObj:a,schema:o,sourceObjects:s}=n,c;if(r&&e&&typeof e==`object`){if(c=s.get(e),c)return c.anchor??=i(e),new Le(c.anchor);c={anchor:null,node:null},s.set(e,c)}t?.startsWith(`!!`)&&(t=`tag:yaml.org,2002:`+t.slice(2));let l=Be(e,t,o.tags);if(!l){if(e&&typeof e.toJSON==`function`&&(e=e.toJSON()),!e||typeof e!=`object`){let t=new R(e);return c&&(c.node=t),t}l=e instanceof Map?o[E]:Symbol.iterator in Object(e)?o[be]:o[E]}a&&(a(l),delete n.onTagObj);let u=l?.createNode?l.createNode(n.schema,e,n):typeof l?.nodeClass?.from==`function`?l.nodeClass.from(n.schema,e,n):new R(e);return t?u.tag=t:l.default||(u.tag=l.tag),c&&(c.node=u),u}function He(e,t,n){let r=n;for(let e=t.length-1;e>=0;--e){let n=t[e];if(typeof n==`number`&&Number.isInteger(n)&&n>=0){let e=[];e[n]=r,r=e}else r=new Map([[n,r]])}return Ve(r,void 0,{aliasDuplicateObjects:!1,keepUndefined:!1,onAnchor:()=>{throw Error(`This should not happen, please report a bug.`)},schema:e,sourceObjects:new Map})}const Ue=e=>e==null||typeof e==`object`&&!!e[Symbol.iterator]().next().done;var We=class extends Ie{constructor(e,t){super(e),Object.defineProperty(this,"schema",{value:t,configurable:!0,enumerable:!1,writable:!0})}clone(e){let t=Object.create(Object.getPrototypeOf(this),Object.getOwnPropertyDescriptors(this));return e&&(t.schema=e),t.items=t.items.map(t=>M(t)||k(t)?t.clone(e):t),this.range&&(t.range=this.range.slice()),t}addIn(e,t){if(Ue(e))this.add(t);else{let[n,...r]=e,i=this.get(n,!0);if(j(i))i.addIn(r,t);else if(i===void 0&&this.schema)this.set(n,He(this.schema,r,t));else throw Error(`Expected YAML collection at ${n}. Remaining path: ${r}`)}}deleteIn(e){let[t,...n]=e;if(n.length===0)return this.delete(t);let r=this.get(t,!0);if(j(r))return r.deleteIn(n);throw Error(`Expected YAML collection at ${t}. Remaining path: ${n}`)}getIn(e,t){let[n,...r]=e,i=this.get(n,!0);return r.length===0?!t&&A(i)?i.value:i:j(i)?i.getIn(r,t):void 0}hasAllNullValues(e){return this.items.every(t=>{if(!k(t))return!1;let n=t.value;return n==null||e&&A(n)&&n.value==null&&!n.commentBefore&&!n.comment&&!n.tag})}hasIn(e){let[t,...n]=e;if(n.length===0)return this.has(t);let r=this.get(t,!0);return j(r)?r.hasIn(n):!1}setIn(e,t){let[n,...r]=e;if(r.length===0)this.set(n,t);else{let e=this.get(n,!0);if(j(e))e.setIn(r,t);else if(e===void 0&&this.schema)this.set(n,He(this.schema,r,t));else throw Error(`Expected YAML collection at ${n}. Remaining path: ${r}`)}}};const Ge=e=>e.replace(/^(?!$)(?: $)?/gm,`#`);function Ke(e,t){return/^\n+$/.test(e)?e.substring(1):t?e.replace(/^(?! *$)/gm,t):e}const z=(e,t,n)=>e.endsWith(`
3
3
  `)?Ke(n,t):n.includes(`
4
4
  `)?`
@@ -96,4 +96,4 @@ DO NOT include:
96
96
  If nothing in the conversation is worth persisting, return exactly the single line:
97
97
  NONE
98
98
 
99
- Otherwise, output ONLY a markdown bullet list (one bullet per memory), no headers, no preamble, no follow-up. Each bullet is one line. Be specific. Prefer one fact per bullet over multi-clause sentences.`,2048,e.headers,s);if(n?.trim()&&n.trim()!==`NONE`)try{await e.onMemoryUpdates(n.trim()),G.info(`Memory extraction applied`,{bulletsLength:n.length})}catch(e){G.warn(`onMemoryUpdates callback threw`,{error:e instanceof Error?e.message:String(e)})}else G.info(`Memory extraction returned no durable memories`)}catch(e){G.warn(`Memory extraction call failed (compaction still applied)`,{error:e instanceof Error?e.message:String(e)})}return h(`idle`),[a,...m]}catch(e){G.warn(`LLM summarization failed, falling back to naive drop`,{error:e instanceof Error?e.message:String(e)})}else u||G.warn(`No API key available for LLM summarization, falling back to naive drop`);h(`idle`);let _={role:`user`,content:[{type:`text`,text:`[Earlier conversation messages were compacted to save context space]`}],timestamp:Date.now()};return G.info(`Naive compaction applied`,{originalMessages:o.length,compactedMessages:1+m.length}),[_,...m]}}const nn=n(`secret-scrub`);function rn(){return typeof chrome<`u`&&chrome?.runtime?.id?async e=>{if(!e)return e;try{let t=await new Promise(t=>{chrome.runtime.sendMessage({type:`secrets.scrub-tool-result`,text:e},e=>t(e??{}))});return t.error?(nn.debug(`SW scrub-tool-result returned error`,{error:t.error}),e):typeof t.text==`string`?t.text:e}catch(t){return nn.debug(`SW scrub-tool-result failed`,{error:t instanceof Error?t.message:String(t)}),e}}:async e=>{if(!e)return e;try{let t=await fetch(`/api/secrets/scrub`,{method:`POST`,headers:{"content-type":`application/json`},body:JSON.stringify({text:e})});if(!t.ok)return nn.debug(`Server scrub-tool-result returned non-ok`,{status:t.status}),e;let n=await t.json();return typeof n.text==`string`?n.text:e}catch(t){return nn.debug(`Server scrub-tool-result failed`,{error:t instanceof Error?t.message:String(t)}),e}}}const K=`sessions`;function an(){return new Promise((e,t)=>{let n=indexedDB.open(`agent-sessions`,1);n.onupgradeneeded=()=>{let e=n.result;e.objectStoreNames.contains(K)||e.createObjectStore(K,{keyPath:`id`})},n.onsuccess=()=>e(n.result),n.onerror=()=>t(n.error)})}var on=class{dbPromise=null;getDB(){return this.dbPromise||=an(),this.dbPromise}async save(e){let t=await this.getDB();return new Promise((n,r)=>{let i=t.transaction(K,`readwrite`).objectStore(K).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(K,`readonly`).objectStore(K).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(K,`readwrite`).objectStore(K).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(K,`readonly`).objectStore(K).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(K,`readwrite`).objectStore(K).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 q=n(`image-processor`),sn=3932160,cn=new Set([`image/jpeg`,`image/png`,`image/gif`,`image/webp`]);function ln(e){return cn.has(e)}function un(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 dn(e){if(!ln(e.mimeType))return q.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=un(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;q.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(`./kernel-worker-BMe--kS1.js`).then(e=>e.a);r=e.getMagick,i=e.MIME_TO_MAGICK_FORMAT}catch(e){return q.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 q.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),q.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>sn&&s!==`JPEG`?(q.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>sn&&(q.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 q.warn(`ImageMagick produced no output`),{type:`text`,text:`[Image removed: could not be processed (empty output from resize)]`};if(o.data.length>sn)return q.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 q.info(`Image processed successfully`,{originalBase64:t,newBase64:c.length,mimeType:o.mime}),{type:`image`,data:c,mimeType:o.mime}}catch(n){return q.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 fn=n(`tool-adapter`),pn=/<img:(data:(image\/[^;]+);base64,([^>]+))>/g;function mn(e){let t=[],n=0;for(let r of e.matchAll(pn)){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 hn(e){let t=mn(e),n=[];for(let e of t)e.type===`image`?n.push(await dn(e)):n.push(e);return n}function gn(e,t,n){return{name:e.name,label:e.name,description:e.description,parameters:e.inputSchema,async execute(a,o,s,c){let l;c&&(l=i({onUpdate:c,toolName:e.name,toolCallId:a}));let u=t?t.processManager.spawn({kind:`tool`,argv:[e.name,...vn(o)],owner:t.owner,ppid:t.getParentPid?.()}):null,d=null;u&&t&&s&&(s.aborted?t.processManager.signal(u.pid,`SIGINT`):s.addEventListener(`abort`,()=>t.processManager.signal(u.pid,`SIGINT`),{once:!0})),u&&t&&(d=t.processManager.onSignal((e,n)=>{e.pid!==u.pid||n!==`SIGKILL`||t.processManager.exit(u.pid,null)}));let f=u?u.abort.signal:s;try{let r=await e.execute(o??{},f),i=r.content;if(n&&typeof i==`string`&&i.length>0)try{i=await n.scrubToolResult(i)}catch(t){fn.warn(`Tool-result scrub failed, falling back to unscrubbed content`,{tool:e.name,error:t instanceof Error?t.message:String(t)}),i=r.content}let a;try{a=await hn(i)}catch(t){fn.warn(`Image processing failed, falling back to raw content`,{tool:e.name,error:t instanceof Error?t.message:String(t)}),a=mn(i)}return u&&t&&t.processManager.exit(u.pid,+!!r.isError),{content:a,details:{isError:r.isError}}}catch(e){throw u&&t&&t.processManager.exit(u.pid,u.abort.signal.aborted?null:1),e}finally{l&&r(l),d?.()}}}}function _n(e,t,n){return e.map(e=>gn(e,t,n))}function vn(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[]}var yn=e({ACCOUNTS_KEY:()=>J,addAccount:()=>Rn,getAccounts:()=>Q,getAllExtraOAuthDomains:()=>Fn,getApiKey:()=>Qn,getApiKeyForProvider:()=>Kn,getApiVersionForProvider:()=>Yn,getAvailableProviders:()=>On,getBaseUrlForProvider:()=>qn,getDeploymentForProvider:()=>Jn,getExtraOAuthDomains:()=>Mn,getOAuthAccountInfo:()=>jn,getProviderConfig:()=>X,getProviderModels:()=>An,getRawApiKeyForProvider:()=>Gn,getSelectedModelId:()=>Xn,getSelectedProvider:()=>$,logoutOAuthAccount:()=>Vn,maskOAuthTokenWithRetry:()=>Hn,migrateLegacyAuthOnlySelection:()=>Dn,persistOAuthMaskViaServiceWorker:()=>Un,removeAccount:()=>Bn,resolveCurrentModel:()=>rr,resolveModelById:()=>nr,saveOAuthAccount:()=>Wn,setExtraOAuthDomains:()=>Nn,setExtraOAuthDomainsAsync:()=>Pn});const bn=v,xn=y,J=`slicc_accounts`,Y=`selected-model`,Sn=[`slicc_provider`,`slicc_api_key`,`slicc_base_url`,`anthropic_api_key`,`api_provider`,`azure_resource`,`bedrock_region`],Cn=new Set([`github`]);function wn(e){let t;try{t=_()}catch{return!1}return t.includes(e)&&!u(e)}let Tn=!1;function En(){if(!Tn){Tn=!0;for(let e of Sn)try{localStorage.removeItem(e)}catch{}Dn()}}function Dn(){try{let e=localStorage.getItem(Y);if(e){let t=e.indexOf(`:`);if(t>0){let n=e.slice(0,t);(Cn.has(n)||wn(n))&&localStorage.removeItem(Y)}}}catch{}try{let e=localStorage.getItem(J);if(!e)return;let t=JSON.parse(e);if(!Array.isArray(t))return;let n=t.filter(e=>!(typeof e==`object`&&e&&typeof e.providerId==`string`&&wn(e.providerId)));n.length!==t.length&&localStorage.setItem(J,JSON.stringify(n))}catch{}}function On(){let e=_().filter(u),t=l();return[...new Set([...e,...t])].filter(e=>!d(e)?.hidden)}function X(e){return d(e)||{id:e,name:e.split(`-`).map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join(` `),description:`${e} provider`,requiresApiKey:!0,requiresBaseUrl:!1}}function kn(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}),t.thinkingLevelMap!==void 0&&(e.thinkingLevelMap={...e.thinkingLevelMap??{},...t.thinkingLevelMap})}function An(e){try{if(e===`bedrock-camp`){let e=h(qn(`bedrock-camp`));return xn(`amazon-bedrock`).filter(t=>m(t,e)).map(e=>({...e,api:`bedrock-camp-converse`,provider:`bedrock-camp`}))}let t=X(e);if(t.getModelIds){let n;try{n=t.getModelIds()}catch(t){return Z.error(`Provider getModelIds callback failed`,{providerId:e,error:t instanceof Error?t.message:String(t)}),[]}let r=new Map;for(let e of _())try{for(let t of xn(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?o={...a,api:i,provider:e}:(o=er(e,n.id,``,i),n.name&&(o.name=n.name));let s=t.modelOverrides?.[n.id];return s&&kn(o,s),kn(o,n),o})}if(t.isOAuth){let n=xn(`anthropic`),r=`${e}-anthropic`;return n.map(n=>{let i={...n,api:r,provider:e},a=t.modelOverrides?.[n.id];return a&&kn(i,a),i})}return xn(e===`azure-ai-foundry`?`anthropic`:e)}catch(t){return Z.error(`Failed to load models`,{providerId:e,error:t instanceof Error?t.message:String(t)}),[]}}function jn(e){let t=Q().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 Z=n(`provider-settings`);function Q(){En();let e=localStorage.getItem(J);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 Mn(e){return a(localStorage)[e]??[]}function Nn(e,t){let n=a(localStorage),r=t.map(e=>e.trim()).filter(e=>e.length>0);r.length===0?delete n[e]:n[e]=r,o(localStorage,n)}async function Pn(e,t){if(c()){Nn(e,t);return}let n=s();if(!n)throw Error(`setExtraOAuthDomainsAsync: no DOM and no panel-rpc client — cannot persist to page localStorage`);let{storeAfter:r}=await n.call(`oauth-extras-set`,{providerId:e,domains:t});try{o(localStorage,r)}catch(t){Z.warn(`worker-shim mirror failed after successful page write — reload to refresh`,{providerId:e,error:t instanceof Error?t.message:String(t)})}}function Fn(){return a(localStorage)}function In(e){localStorage.setItem(J,JSON.stringify(e))}async function Ln(e){if(c()){In(e);return}let t=s();if(!t)throw Error(`saveAccountsAsync: no DOM and no panel-rpc client — cannot persist to page localStorage`);let n=JSON.stringify(e),{storedJson:r}=await t.call(`save-oauth-accounts`,{accountsJson:n});try{localStorage.setItem(J,r)}catch(e){Z.warn(`worker-shim mirror failed after successful page write — reload to refresh`,{error:e instanceof Error?e.message:String(e)})}}function Rn(e,t,n,r,i){let a=Q().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),In(a)}async function zn(e){let t=typeof chrome<`u`&&!!chrome?.runtime?.id;try{if(t){let t=await new Promise(t=>{chrome.runtime.sendMessage({type:`secrets.delete`,name:`oauth.${e}.token`},n=>{chrome.runtime.lastError&&Z.error(`SW secrets.delete transport failed`,{providerId:e,error:chrome.runtime.lastError.message}),t(n??{})})});t.error&&Z.error(`SW secrets.delete returned error`,{providerId:e,error:t.error})}else{let t=await fetch(`/api/secrets/oauth/${e}`,{method:`DELETE`});!t.ok&&t.status!==404&&Z.warn(`OAuth replica DELETE non-ok`,{providerId:e,status:t.status})}}catch(n){Z.error(`OAuth replica removal failed`,{providerId:e,isExtension:t,error:n instanceof Error?n.message:String(n)})}}async function Bn(e){let t=Q().find(t=>t.providerId===e),n=X(e);t&&n?.isOAuth&&await Vn(e),await zn(e),await Ln(Q().filter(t=>t.providerId!==e));let r=localStorage.getItem(Y)??``,i=r.indexOf(`:`);i>0&&r.slice(0,i)===e&&localStorage.removeItem(Y)}async function Vn(e){let t=Q().find(t=>t.providerId===e);if(!t)return;let n=X(e);if(n?.isOAuth){if(n.onOAuthLogout)try{await n.onOAuthLogout()}catch(t){Z.warn(`onOAuthLogout failed`,{providerId:e,error:t instanceof Error?t.message:String(t)})}if(n.getOAuthLogoutUrl){let r=n.getOAuthLogoutUrl(t);if(r){let{openIdpLogoutUrl:t}=await import(`./oauth-service-DQVciyk_.js`);await t(r).catch(t=>{Z.warn(`IdP logout popup failed`,{providerId:e,error:t instanceof Error?t.message:String(t)})})}}await Ln(Q().map(t=>t.providerId===e?{providerId:t.providerId,apiKey:``,baseUrl:t.baseUrl,userName:t.userName,userAvatar:t.userAvatar,loggedOut:!0}:t)),await zn(e)}}async function Hn(e,t={}){let n=Math.max(1,t.attempts??3),r=t.delayMs??150,i=t.sleep??(e=>new Promise(t=>setTimeout(t,e))),a;for(let t=0;t<n;t++){let o=await e();if(o.maskedValue)return{maskedValue:o.maskedValue};o.error&&(a=o.error),t<n-1&&await i(r)}return{lastError:a}}async function Un(e,t,n){let r={providerId:e.providerId,accessToken:e.accessToken,domains:e.domains.join(`,`)},{maskedValue:i,lastError:a}=await Hn(()=>t.sendMaskRequest(r),n);if(!i){Z.error(`OAuth mask give-up: no masked value after retries`,{providerId:e.providerId,reason:a??`no error reported (cold SW or empty reply)`});return}let o=t.getAccounts(),s=o.find(t=>t.providerId===e.providerId);s&&(s.maskedValue=i,await t.saveAccounts(o))}async function Wn(e){let t=Q().find(t=>t.providerId===e.providerId),n=Q().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}),await Ln(n);let r=X(e.providerId)?.oauthTokenDomains??[],i=Mn(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 Un({providerId:e.providerId,accessToken:e.accessToken,domains:o},{sendMaskRequest:t=>new Promise(n=>{chrome.runtime.sendMessage({type:`secrets.mask-oauth-token`,...t},t=>{chrome.runtime.lastError&&Z.error(`SW mask-oauth-token transport failed`,{providerId:e.providerId,error:chrome.runtime.lastError.message}),t?.error&&Z.warn(`SW mask-oauth-token returned error`,{providerId:e.providerId,error:t.error}),n(t??{})})}),getAccounts:Q,saveAccounts:Ln});else if(!globalThis.__slicc_connect_mode){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=Q(),i=r.find(t=>t.providerId===e.providerId);i&&typeof n.maskedValue==`string`&&(i.maskedValue=n.maskedValue,await Ln(r))}else Z.warn(`OAuth replica POST non-ok`,{providerId:e.providerId,status:t.status})}}catch(t){Z.error(`OAuth replica sync failed`,{providerId:e.providerId,isExtension:s,error:t instanceof Error?t.message:String(t)})}}function Gn(e){let t=Q().find(t=>t.providerId===e);return t&&(t.accessToken||t.apiKey)||null}function Kn(e){let t=Q().find(t=>t.providerId===e);return t?t.accessToken||t.apiKey||(X(e).optionalApiKey?`local`:null):null}function qn(e){return Q().find(t=>t.providerId===e)?.baseUrl??null}function Jn(e){return Q().find(t=>t.providerId===e)?.deployment??null}function Yn(e){return Q().find(t=>t.providerId===e)?.apiVersion??null}function Xn(){let e=localStorage.getItem(Y)||``,t=e.indexOf(`:`);return t>=0?e.slice(t+1):e}function Zn(){return localStorage.getItem(Y)||``}function $(){let e=Zn(),t=e.indexOf(`:`);if(t>0)return e.slice(0,t);let n=Q();return n.length>0?n[0].providerId:`anthropic`}function Qn(){return Kn($())}function $n(e){return/^(?:gpt[-.]?|o[0-9]|chatgpt)/i.test(e)?`openai`:`anthropic`}function er(e,t,n,r){return{id:t,name:t,provider:e,api:r??`${e}-${$n(t)}`,baseUrl:n??``,contextWindow:2e5,maxTokens:16384,input:[`text`,`image`],cost:{input:0,output:0,cacheRead:0,cacheWrite:0},reasoning:!0}}function tr(e,t){return t.isOAuth||e===`azure-ai-foundry`?`anthropic`:e===`bedrock-camp`?`amazon-bedrock`:e}function nr(e){if(!e)return rr();let t=$(),n=qn(t),r=X(t);try{let i=bn(tr(t,r),e);if(!i?.id)throw Error(`Model ${e} not found`);let a=i;return r.isOAuth?a=An(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(i){if(Z.debug(`resolveModelById: pi-ai lookup miss, using provider fallback`,{providerId:t,modelId:e,error:i instanceof Error?i.message:String(i)}),r.isOAuth){let r=An(t).find(t=>t.id===e);return r?n?{...r,baseUrl:n}:r:er(t,e,n)}return rr()}}function rr(){let e=$(),t=Xn(),n=qn(e),r=An(e),i=X(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=tr(e,i),a=bn(t,o);if(!a?.id)throw Error(`Model ${o} not found in ${t} registry`);let s=a;return i.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(t){Z.debug(`resolveCurrentModel: pi-ai lookup miss, using provider fallback`,{providerId:e,effectiveModelId:o,error:t instanceof Error?t.message:String(t)});let a=r.find(e=>e.id===o);return a?n?{...a,baseUrl:n}:a:i.isOAuth?er(e,o,n):bn(`anthropic`,`claude-sonnet-4-0`)}}export{on as A,Bn as C,Nn as D,Wn as E,Vt as F,he as I,tn as M,qt as N,Pn as O,Bt as P,Un as S,nr as T,Xn as _,Fn as a,Hn as b,Yn as c,Jn as d,Mn as f,Gn as g,An as h,Q as i,rn as j,_n as k,On as l,X as m,yn as n,Qn as o,jn as p,Rn as r,Kn as s,J as t,qn as u,$ as v,rr as w,Dn as x,Vn as y};
99
+ Otherwise, output ONLY a markdown bullet list (one bullet per memory), no headers, no preamble, no follow-up. Each bullet is one line. Be specific. Prefer one fact per bullet over multi-clause sentences.`,2048,e.headers,s);if(n?.trim()&&n.trim()!==`NONE`)try{await e.onMemoryUpdates(n.trim()),G.info(`Memory extraction applied`,{bulletsLength:n.length})}catch(e){G.warn(`onMemoryUpdates callback threw`,{error:e instanceof Error?e.message:String(e)})}else G.info(`Memory extraction returned no durable memories`)}catch(e){G.warn(`Memory extraction call failed (compaction still applied)`,{error:e instanceof Error?e.message:String(e)})}return h(`idle`),[a,...m]}catch(e){G.warn(`LLM summarization failed, falling back to naive drop`,{error:e instanceof Error?e.message:String(e)})}else u||G.warn(`No API key available for LLM summarization, falling back to naive drop`);h(`idle`);let _={role:`user`,content:[{type:`text`,text:`[Earlier conversation messages were compacted to save context space]`}],timestamp:Date.now()};return G.info(`Naive compaction applied`,{originalMessages:o.length,compactedMessages:1+m.length}),[_,...m]}}const nn=n(`secret-scrub`);function rn(){return typeof chrome<`u`&&chrome?.runtime?.id?async e=>{if(!e)return e;try{let t=await new Promise(t=>{chrome.runtime.sendMessage({type:`secrets.scrub-tool-result`,text:e},e=>t(e??{}))});return t.error?(nn.debug(`SW scrub-tool-result returned error`,{error:t.error}),e):typeof t.text==`string`?t.text:e}catch(t){return nn.debug(`SW scrub-tool-result failed`,{error:t instanceof Error?t.message:String(t)}),e}}:async e=>{if(!e)return e;try{let t=await fetch(`/api/secrets/scrub`,{method:`POST`,headers:{"content-type":`application/json`},body:JSON.stringify({text:e})});if(!t.ok)return nn.debug(`Server scrub-tool-result returned non-ok`,{status:t.status}),e;let n=await t.json();return typeof n.text==`string`?n.text:e}catch(t){return nn.debug(`Server scrub-tool-result failed`,{error:t instanceof Error?t.message:String(t)}),e}}}const K=`sessions`;function an(){return new Promise((e,t)=>{let n=indexedDB.open(`agent-sessions`,1);n.onupgradeneeded=()=>{let e=n.result;e.objectStoreNames.contains(K)||e.createObjectStore(K,{keyPath:`id`})},n.onsuccess=()=>e(n.result),n.onerror=()=>t(n.error)})}var on=class{dbPromise=null;getDB(){return this.dbPromise||=an(),this.dbPromise}async save(e){let t=await this.getDB();return new Promise((n,r)=>{let i=t.transaction(K,`readwrite`).objectStore(K).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(K,`readonly`).objectStore(K).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(K,`readwrite`).objectStore(K).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(K,`readonly`).objectStore(K).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(K,`readwrite`).objectStore(K).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 q=n(`image-processor`),sn=3932160,cn=new Set([`image/jpeg`,`image/png`,`image/gif`,`image/webp`]);function ln(e){return cn.has(e)}function un(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 dn(e){if(!ln(e.mimeType))return q.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=un(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;q.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(`./kernel-worker-CJBmf2_H.js`).then(e=>e.a);r=e.getMagick,i=e.MIME_TO_MAGICK_FORMAT}catch(e){return q.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 q.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),q.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>sn&&s!==`JPEG`?(q.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>sn&&(q.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 q.warn(`ImageMagick produced no output`),{type:`text`,text:`[Image removed: could not be processed (empty output from resize)]`};if(o.data.length>sn)return q.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 q.info(`Image processed successfully`,{originalBase64:t,newBase64:c.length,mimeType:o.mime}),{type:`image`,data:c,mimeType:o.mime}}catch(n){return q.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 fn=n(`tool-adapter`),pn=/<img:(data:(image\/[^;]+);base64,([^>]+))>/g;function mn(e){let t=[],n=0;for(let r of e.matchAll(pn)){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 hn(e){let t=mn(e),n=[];for(let e of t)e.type===`image`?n.push(await dn(e)):n.push(e);return n}function gn(e,t,n){return{name:e.name,label:e.name,description:e.description,parameters:e.inputSchema,async execute(a,o,s,c){let l;c&&(l=i({onUpdate:c,toolName:e.name,toolCallId:a}));let u=t?t.processManager.spawn({kind:`tool`,argv:[e.name,...vn(o)],owner:t.owner,ppid:t.getParentPid?.()}):null,d=null;u&&t&&s&&(s.aborted?t.processManager.signal(u.pid,`SIGINT`):s.addEventListener(`abort`,()=>t.processManager.signal(u.pid,`SIGINT`),{once:!0})),u&&t&&(d=t.processManager.onSignal((e,n)=>{e.pid!==u.pid||n!==`SIGKILL`||t.processManager.exit(u.pid,null)}));let f=u?u.abort.signal:s;try{let r=await e.execute(o??{},f),i=r.content;if(n&&typeof i==`string`&&i.length>0)try{i=await n.scrubToolResult(i)}catch(t){fn.warn(`Tool-result scrub failed, falling back to unscrubbed content`,{tool:e.name,error:t instanceof Error?t.message:String(t)}),i=r.content}let a;try{a=await hn(i)}catch(t){fn.warn(`Image processing failed, falling back to raw content`,{tool:e.name,error:t instanceof Error?t.message:String(t)}),a=mn(i)}return u&&t&&t.processManager.exit(u.pid,+!!r.isError),{content:a,details:{isError:r.isError}}}catch(e){throw u&&t&&t.processManager.exit(u.pid,u.abort.signal.aborted?null:1),e}finally{l&&r(l),d?.()}}}}function _n(e,t,n){return e.map(e=>gn(e,t,n))}function vn(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[]}var yn=e({ACCOUNTS_KEY:()=>J,addAccount:()=>zn,getAccounts:()=>$,getAllExtraOAuthDomains:()=>In,getApiKey:()=>er,getApiKeyForProvider:()=>qn,getApiVersionForProvider:()=>Xn,getAvailableProviders:()=>On,getBaseUrlForProvider:()=>Jn,getDeploymentForProvider:()=>Yn,getExtraOAuthDomains:()=>Nn,getOAuthAccountInfo:()=>Mn,getProviderConfig:()=>X,getProviderModels:()=>Z,getRawApiKeyForProvider:()=>Kn,getSelectedModelId:()=>Zn,getSelectedProvider:()=>$n,logoutOAuthAccount:()=>Hn,maskOAuthTokenWithRetry:()=>Un,migrateLegacyAuthOnlySelection:()=>Dn,persistOAuthMaskViaServiceWorker:()=>Wn,providerOffersLlmModels:()=>kn,removeAccount:()=>Vn,resolveCurrentModel:()=>ar,resolveModelById:()=>ir,saveOAuthAccount:()=>Gn,setExtraOAuthDomains:()=>Pn,setExtraOAuthDomainsAsync:()=>Fn});const bn=v,xn=y,J=`slicc_accounts`,Y=`selected-model`,Sn=[`slicc_provider`,`slicc_api_key`,`slicc_base_url`,`anthropic_api_key`,`api_provider`,`azure_resource`,`bedrock_region`],Cn=new Set([`github`]);function wn(e){let t;try{t=_()}catch{return!1}return t.includes(e)&&!u(e)}let Tn=!1;function En(){if(!Tn){Tn=!0;for(let e of Sn)try{localStorage.removeItem(e)}catch{}Dn()}}function Dn(){try{let e=localStorage.getItem(Y);if(e){let t=e.indexOf(`:`);if(t>0){let n=e.slice(0,t);(Cn.has(n)||wn(n))&&localStorage.removeItem(Y)}}}catch{}try{let e=localStorage.getItem(J);if(!e)return;let t=JSON.parse(e);if(!Array.isArray(t))return;let n=t.filter(e=>!(typeof e==`object`&&e&&typeof e.providerId==`string`&&wn(e.providerId)));n.length!==t.length&&localStorage.setItem(J,JSON.stringify(n))}catch{}}function On(){let e=_().filter(u),t=l();return[...new Set([...e,...t])].filter(e=>!d(e)?.hidden)}function kn(e){try{if(Z(e).length>0)return!0}catch{}try{if(y(e).length>0)return!0}catch{}let t=d(e);return!!(t?.modelOverrides&&Object.keys(t.modelOverrides).length>0)}function An(e,t){try{if(Z(e).some(e=>e.id===t))return!0}catch{}try{if(y(e).some(e=>e.id===t))return!0}catch{}let n=d(e);return!!(n?.modelOverrides&&Object.hasOwn(n.modelOverrides,t))}function X(e){return d(e)||{id:e,name:e.split(`-`).map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join(` `),description:`${e} provider`,requiresApiKey:!0,requiresBaseUrl:!1}}function jn(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}),t.thinkingLevelMap!==void 0&&(e.thinkingLevelMap={...e.thinkingLevelMap??{},...t.thinkingLevelMap})}function Z(e){try{if(e===`bedrock-camp`){let e=h(Jn(`bedrock-camp`));return xn(`amazon-bedrock`).filter(t=>m(t,e)).map(e=>({...e,api:`bedrock-camp-converse`,provider:`bedrock-camp`}))}let t=X(e);if(t.getModelIds){let n;try{n=t.getModelIds()}catch(t){return Q.error(`Provider getModelIds callback failed`,{providerId:e,error:t instanceof Error?t.message:String(t)}),[]}let r=new Map;for(let e of _())try{for(let t of xn(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?o={...a,api:i,provider:e}:(o=nr(e,n.id,``,i),n.name&&(o.name=n.name));let s=t.modelOverrides?.[n.id];return s&&jn(o,s),jn(o,n),o})}if(t.isOAuth){let n=xn(`anthropic`),r=`${e}-anthropic`;return n.map(n=>{let i={...n,api:r,provider:e},a=t.modelOverrides?.[n.id];return a&&jn(i,a),i})}return xn(e===`azure-ai-foundry`?`anthropic`:e)}catch(t){return Q.error(`Failed to load models`,{providerId:e,error:t instanceof Error?t.message:String(t)}),[]}}function Mn(e){let t=$().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 Q=n(`provider-settings`);function $(){En();let e=localStorage.getItem(J);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 Nn(e){return a(localStorage)[e]??[]}function Pn(e,t){let n=a(localStorage),r=t.map(e=>e.trim()).filter(e=>e.length>0);r.length===0?delete n[e]:n[e]=r,o(localStorage,n)}async function Fn(e,t){if(c()){Pn(e,t);return}let n=s();if(!n)throw Error(`setExtraOAuthDomainsAsync: no DOM and no panel-rpc client — cannot persist to page localStorage`);let{storeAfter:r}=await n.call(`oauth-extras-set`,{providerId:e,domains:t});try{o(localStorage,r)}catch(t){Q.warn(`worker-shim mirror failed after successful page write — reload to refresh`,{providerId:e,error:t instanceof Error?t.message:String(t)})}}function In(){return a(localStorage)}function Ln(e){localStorage.setItem(J,JSON.stringify(e))}async function Rn(e){if(c()){Ln(e);return}let t=s();if(!t)throw Error(`saveAccountsAsync: no DOM and no panel-rpc client — cannot persist to page localStorage`);let n=JSON.stringify(e),{storedJson:r}=await t.call(`save-oauth-accounts`,{accountsJson:n});try{localStorage.setItem(J,r)}catch(e){Q.warn(`worker-shim mirror failed after successful page write — reload to refresh`,{error:e instanceof Error?e.message:String(e)})}}function zn(e,t,n,r,i){let a=$().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),Ln(a)}async function Bn(e){let t=typeof chrome<`u`&&!!chrome?.runtime?.id;try{if(t){let t=await new Promise(t=>{chrome.runtime.sendMessage({type:`secrets.delete`,name:`oauth.${e}.token`},n=>{chrome.runtime.lastError&&Q.error(`SW secrets.delete transport failed`,{providerId:e,error:chrome.runtime.lastError.message}),t(n??{})})});t.error&&Q.error(`SW secrets.delete returned error`,{providerId:e,error:t.error})}else{let t=await fetch(`/api/secrets/oauth/${e}`,{method:`DELETE`});!t.ok&&t.status!==404&&Q.warn(`OAuth replica DELETE non-ok`,{providerId:e,status:t.status})}}catch(n){Q.error(`OAuth replica removal failed`,{providerId:e,isExtension:t,error:n instanceof Error?n.message:String(n)})}}async function Vn(e){let t=$().find(t=>t.providerId===e),n=X(e);t&&n?.isOAuth&&await Hn(e),await Bn(e),await Rn($().filter(t=>t.providerId!==e));let r=localStorage.getItem(Y)??``,i=r.indexOf(`:`);i>0&&r.slice(0,i)===e&&localStorage.removeItem(Y)}async function Hn(e){let t=$().find(t=>t.providerId===e);if(!t)return;let n=X(e);if(n?.isOAuth){if(n.onOAuthLogout)try{await n.onOAuthLogout()}catch(t){Q.warn(`onOAuthLogout failed`,{providerId:e,error:t instanceof Error?t.message:String(t)})}if(n.getOAuthLogoutUrl){let r=n.getOAuthLogoutUrl(t);if(r){let{openIdpLogoutUrl:t}=await import(`./oauth-service-DQVciyk_.js`);await t(r).catch(t=>{Q.warn(`IdP logout popup failed`,{providerId:e,error:t instanceof Error?t.message:String(t)})})}}await Rn($().map(t=>t.providerId===e?{providerId:t.providerId,apiKey:``,baseUrl:t.baseUrl,userName:t.userName,userAvatar:t.userAvatar,loggedOut:!0}:t)),await Bn(e)}}async function Un(e,t={}){let n=Math.max(1,t.attempts??3),r=t.delayMs??150,i=t.sleep??(e=>new Promise(t=>setTimeout(t,e))),a;for(let t=0;t<n;t++){let o=await e();if(o.maskedValue)return{maskedValue:o.maskedValue};o.error&&(a=o.error),t<n-1&&await i(r)}return{lastError:a}}async function Wn(e,t,n){let r={providerId:e.providerId,accessToken:e.accessToken,domains:e.domains.join(`,`)},{maskedValue:i,lastError:a}=await Un(()=>t.sendMaskRequest(r),n);if(!i){Q.error(`OAuth mask give-up: no masked value after retries`,{providerId:e.providerId,reason:a??`no error reported (cold SW or empty reply)`});return}let o=t.getAccounts(),s=o.find(t=>t.providerId===e.providerId);s&&(s.maskedValue=i,await t.saveAccounts(o))}async function Gn(e){let t=$().find(t=>t.providerId===e.providerId),n=$().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}),await Rn(n);let r=X(e.providerId)?.oauthTokenDomains??[],i=Nn(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 Wn({providerId:e.providerId,accessToken:e.accessToken,domains:o},{sendMaskRequest:t=>new Promise(n=>{chrome.runtime.sendMessage({type:`secrets.mask-oauth-token`,...t},t=>{chrome.runtime.lastError&&Q.error(`SW mask-oauth-token transport failed`,{providerId:e.providerId,error:chrome.runtime.lastError.message}),t?.error&&Q.warn(`SW mask-oauth-token returned error`,{providerId:e.providerId,error:t.error}),n(t??{})})}),getAccounts:$,saveAccounts:Rn});else if(!globalThis.__slicc_connect_mode){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=$(),i=r.find(t=>t.providerId===e.providerId);i&&typeof n.maskedValue==`string`&&(i.maskedValue=n.maskedValue,await Rn(r))}else Q.warn(`OAuth replica POST non-ok`,{providerId:e.providerId,status:t.status})}}catch(t){Q.error(`OAuth replica sync failed`,{providerId:e.providerId,isExtension:s,error:t instanceof Error?t.message:String(t)})}}function Kn(e){let t=$().find(t=>t.providerId===e);return t&&(t.accessToken||t.apiKey)||null}function qn(e){let t=$().find(t=>t.providerId===e);return t?t.accessToken||t.apiKey||(X(e).optionalApiKey?`local`:null):null}function Jn(e){return $().find(t=>t.providerId===e)?.baseUrl??null}function Yn(e){return $().find(t=>t.providerId===e)?.deployment??null}function Xn(e){return $().find(t=>t.providerId===e)?.apiVersion??null}function Zn(){let e=localStorage.getItem(Y)||``,t=e.indexOf(`:`);return t>=0?e.slice(t+1):e}function Qn(){return localStorage.getItem(Y)||``}function $n(){let e=Qn(),t=e.indexOf(`:`);if(t>0)return e.slice(0,t);let n=$(),r=Zn();if(r){let e=n.find(e=>kn(e.providerId)&&An(e.providerId,r));if(e)return e.providerId}let i=n.find(e=>kn(e.providerId));return i?i.providerId:n.length>0?n[0].providerId:`anthropic`}function er(){return qn($n())}function tr(e){return/^(?:gpt[-.]?|o[0-9]|chatgpt)/i.test(e)?`openai`:`anthropic`}function nr(e,t,n,r){return{id:t,name:t,provider:e,api:r??`${e}-${tr(t)}`,baseUrl:n??``,contextWindow:2e5,maxTokens:16384,input:[`text`,`image`],cost:{input:0,output:0,cacheRead:0,cacheWrite:0},reasoning:!0}}function rr(e,t){return t.isOAuth||e===`azure-ai-foundry`?`anthropic`:e===`bedrock-camp`?`amazon-bedrock`:e}function ir(e){if(!e)return ar();let t=$n(),n=Jn(t),r=X(t);try{let i=bn(rr(t,r),e);if(!i?.id)throw Error(`Model ${e} not found`);let a=i;return r.isOAuth?a=Z(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(i){if(Q.debug(`resolveModelById: pi-ai lookup miss, using provider fallback`,{providerId:t,modelId:e,error:i instanceof Error?i.message:String(i)}),r.isOAuth){let r=Z(t).find(t=>t.id===e);return r?n?{...r,baseUrl:n}:r:nr(t,e,n)}return ar()}}function ar(){let e=$n(),t=Zn(),n=Jn(e),r=Z(e),i=X(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=rr(e,i),a=bn(t,o);if(!a?.id)throw Error(`Model ${o} not found in ${t} registry`);let s=a;return i.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(t){Q.debug(`resolveCurrentModel: pi-ai lookup miss, using provider fallback`,{providerId:e,effectiveModelId:o,error:t instanceof Error?t.message:String(t)});let a=r.find(e=>e.id===o);return a?n?{...a,baseUrl:n}:a:i.isOAuth?nr(e,o,n):bn(`anthropic`,`claude-sonnet-4-0`)}}export{_n as A,kn as C,Gn as D,ir as E,Bt as F,Vt as I,he as L,rn as M,tn as N,Pn as O,qt as P,Wn as S,ar as T,Zn as _,In as a,Un as b,Xn as c,Yn as d,Nn as f,Kn as g,Z as h,$ as i,on as j,Fn as k,On as l,X as m,yn as n,er as o,Mn as p,zn as r,qn as s,J as t,Jn as u,$n as v,Vn as w,Dn as x,Hn as y};