@symerian/symi 3.0.18 → 3.0.19

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 (116) hide show
  1. package/dist/build-info.json +3 -3
  2. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  3. package/package.json +1 -1
  4. package/extensions/copilot-proxy/README.md +0 -24
  5. package/extensions/copilot-proxy/index.ts +0 -154
  6. package/extensions/copilot-proxy/node_modules/.bin/symi +0 -21
  7. package/extensions/copilot-proxy/package.json +0 -15
  8. package/extensions/copilot-proxy/symi.plugin.json +0 -9
  9. package/extensions/device-pair/index.ts +0 -642
  10. package/extensions/device-pair/symi.plugin.json +0 -20
  11. package/extensions/diagnostics-otel/index.ts +0 -15
  12. package/extensions/diagnostics-otel/node_modules/.bin/acorn +0 -21
  13. package/extensions/diagnostics-otel/node_modules/.bin/symi +0 -21
  14. package/extensions/diagnostics-otel/package.json +0 -27
  15. package/extensions/diagnostics-otel/src/service.test.ts +0 -290
  16. package/extensions/diagnostics-otel/src/service.ts +0 -666
  17. package/extensions/diagnostics-otel/symi.plugin.json +0 -8
  18. package/extensions/google-antigravity-auth/README.md +0 -24
  19. package/extensions/google-antigravity-auth/index.ts +0 -424
  20. package/extensions/google-antigravity-auth/node_modules/.bin/symi +0 -21
  21. package/extensions/google-antigravity-auth/package.json +0 -15
  22. package/extensions/google-antigravity-auth/symi.plugin.json +0 -9
  23. package/extensions/google-gemini-cli-auth/README.md +0 -35
  24. package/extensions/google-gemini-cli-auth/index.ts +0 -75
  25. package/extensions/google-gemini-cli-auth/node_modules/.bin/symi +0 -21
  26. package/extensions/google-gemini-cli-auth/oauth.test.ts +0 -162
  27. package/extensions/google-gemini-cli-auth/oauth.ts +0 -636
  28. package/extensions/google-gemini-cli-auth/package.json +0 -15
  29. package/extensions/google-gemini-cli-auth/symi.plugin.json +0 -9
  30. package/extensions/learning-loop/index.ts +0 -159
  31. package/extensions/learning-loop/node_modules/.bin/symi +0 -21
  32. package/extensions/learning-loop/package.json +0 -18
  33. package/extensions/learning-loop/src/analytics/gateway-methods.ts +0 -230
  34. package/extensions/learning-loop/src/analytics/metrics-aggregator.ts +0 -153
  35. package/extensions/learning-loop/src/capture/run-tracker.ts +0 -181
  36. package/extensions/learning-loop/src/capture/serializer.ts +0 -74
  37. package/extensions/learning-loop/src/db.ts +0 -583
  38. package/extensions/learning-loop/src/feedback/explicit-feedback.ts +0 -58
  39. package/extensions/learning-loop/src/feedback/implicit-signals.ts +0 -89
  40. package/extensions/learning-loop/src/graph/edge-inference.ts +0 -189
  41. package/extensions/learning-loop/src/graph/graph-retrieval.ts +0 -144
  42. package/extensions/learning-loop/src/graph/graph-store.ts +0 -183
  43. package/extensions/learning-loop/src/hooks.ts +0 -244
  44. package/extensions/learning-loop/src/injection/cache.ts +0 -73
  45. package/extensions/learning-loop/src/injection/context-injector.ts +0 -104
  46. package/extensions/learning-loop/src/injection/prompt-builder.ts +0 -43
  47. package/extensions/learning-loop/src/learning/embedding-bridge.ts +0 -54
  48. package/extensions/learning-loop/src/learning/learning-extractor.ts +0 -217
  49. package/extensions/learning-loop/src/learning/learning-store.ts +0 -158
  50. package/extensions/learning-loop/src/learning/retrieval.ts +0 -87
  51. package/extensions/learning-loop/src/math/confidence-intervals.ts +0 -62
  52. package/extensions/learning-loop/src/math/ewma.ts +0 -51
  53. package/extensions/learning-loop/src/math/weighted-scorer.ts +0 -42
  54. package/extensions/learning-loop/src/schema.ts +0 -176
  55. package/extensions/learning-loop/src/scoring/normalization.ts +0 -32
  56. package/extensions/learning-loop/src/scoring/quality-engine.ts +0 -78
  57. package/extensions/learning-loop/src/scoring/signal-extractors.ts +0 -155
  58. package/extensions/learning-loop/src/test/context-injector.test.ts +0 -142
  59. package/extensions/learning-loop/src/test/fixes.test.ts +0 -1286
  60. package/extensions/learning-loop/src/test/graph.test.ts +0 -711
  61. package/extensions/learning-loop/src/test/integration.test.ts +0 -312
  62. package/extensions/learning-loop/src/test/learning-store.test.ts +0 -191
  63. package/extensions/learning-loop/src/test/math.test.ts +0 -148
  64. package/extensions/learning-loop/src/test/quality-engine.test.ts +0 -231
  65. package/extensions/learning-loop/src/test/run-tracker.test.ts +0 -143
  66. package/extensions/learning-loop/src/types.ts +0 -281
  67. package/extensions/learning-loop/symi.plugin.json +0 -46
  68. package/extensions/llm-task/README.md +0 -97
  69. package/extensions/llm-task/index.ts +0 -6
  70. package/extensions/llm-task/package.json +0 -12
  71. package/extensions/llm-task/src/llm-task-tool.test.ts +0 -138
  72. package/extensions/llm-task/src/llm-task-tool.ts +0 -249
  73. package/extensions/llm-task/symi.plugin.json +0 -21
  74. package/extensions/memory-lancedb/config.ts +0 -161
  75. package/extensions/memory-lancedb/index.test.ts +0 -330
  76. package/extensions/memory-lancedb/index.ts +0 -670
  77. package/extensions/memory-lancedb/node_modules/.bin/arrow2csv +0 -21
  78. package/extensions/memory-lancedb/node_modules/.bin/openai +0 -21
  79. package/extensions/memory-lancedb/node_modules/.bin/symi +0 -21
  80. package/extensions/memory-lancedb/package.json +0 -20
  81. package/extensions/memory-lancedb/symi.plugin.json +0 -71
  82. package/extensions/minimax-portal-auth/README.md +0 -33
  83. package/extensions/minimax-portal-auth/index.ts +0 -161
  84. package/extensions/minimax-portal-auth/node_modules/.bin/symi +0 -21
  85. package/extensions/minimax-portal-auth/oauth.ts +0 -247
  86. package/extensions/minimax-portal-auth/package.json +0 -15
  87. package/extensions/minimax-portal-auth/symi.plugin.json +0 -9
  88. package/extensions/model-equalizer/index.ts +0 -80
  89. package/extensions/model-equalizer/skills/model-equalizer/SKILL.md +0 -58
  90. package/extensions/model-equalizer/src/detection.ts +0 -62
  91. package/extensions/model-equalizer/src/enhancer.ts +0 -63
  92. package/extensions/model-equalizer/src/test/detection.test.ts +0 -218
  93. package/extensions/model-equalizer/src/test/enhancer.test.ts +0 -137
  94. package/extensions/model-equalizer/src/test/integration.test.ts +0 -185
  95. package/extensions/model-equalizer/src/types.ts +0 -24
  96. package/extensions/model-equalizer/symi.plugin.json +0 -12
  97. package/extensions/phone-control/index.ts +0 -421
  98. package/extensions/phone-control/symi.plugin.json +0 -10
  99. package/extensions/pipeline/README.md +0 -75
  100. package/extensions/pipeline/SKILL.md +0 -97
  101. package/extensions/pipeline/index.ts +0 -18
  102. package/extensions/pipeline/package.json +0 -11
  103. package/extensions/pipeline/src/pipeline-tool.test.ts +0 -345
  104. package/extensions/pipeline/src/pipeline-tool.ts +0 -266
  105. package/extensions/pipeline/src/windows-spawn.test.ts +0 -148
  106. package/extensions/pipeline/src/windows-spawn.ts +0 -193
  107. package/extensions/pipeline/symi.plugin.json +0 -10
  108. package/extensions/qwen-portal-auth/README.md +0 -24
  109. package/extensions/qwen-portal-auth/index.ts +0 -134
  110. package/extensions/qwen-portal-auth/oauth.ts +0 -190
  111. package/extensions/qwen-portal-auth/symi.plugin.json +0 -9
  112. package/extensions/talk-voice/index.ts +0 -150
  113. package/extensions/talk-voice/symi.plugin.json +0 -10
  114. package/extensions/thread-ownership/index.test.ts +0 -180
  115. package/extensions/thread-ownership/index.ts +0 -133
  116. package/extensions/thread-ownership/symi.plugin.json +0 -28
@@ -1,424 +0,0 @@
1
- import { createHash, randomBytes } from "node:crypto";
2
- import { createServer } from "node:http";
3
- import {
4
- buildOauthProviderAuthResult,
5
- emptyPluginConfigSchema,
6
- isWSL2Sync,
7
- type SymiPluginApi,
8
- type ProviderAuthContext,
9
- } from "symi/plugin-sdk";
10
-
11
- // OAuth constants - decoded from pi-ai's base64 encoded values to stay in sync
12
- const decode = (s: string) => Buffer.from(s, "base64").toString();
13
- const CLIENT_ID = decode(
14
- "MTA3MTAwNjA2MDU5MS10bWhzc2luMmgyMWxjcmUyMzV2dG9sb2poNGc0MDNlcC5hcHBzLmdvb2dsZXVzZXJjb250ZW50LmNvbQ==",
15
- );
16
- const CLIENT_SECRET = decode("R09DU1BYLUs1OEZXUjQ4NkxkTEoxbUxCOHNYQzR6NnFEQWY=");
17
- const REDIRECT_URI = "http://localhost:51121/oauth-callback";
18
- const AUTH_URL = "https://accounts.google.com/o/oauth2/v2/auth";
19
- const TOKEN_URL = "https://oauth2.googleapis.com/token";
20
- const DEFAULT_PROJECT_ID = "rising-fact-p41fc";
21
- const DEFAULT_MODEL = "google-antigravity/claude-opus-4-6-thinking";
22
-
23
- const SCOPES = [
24
- "https://www.googleapis.com/auth/cloud-platform",
25
- "https://www.googleapis.com/auth/userinfo.email",
26
- "https://www.googleapis.com/auth/userinfo.profile",
27
- "https://www.googleapis.com/auth/cclog",
28
- "https://www.googleapis.com/auth/experimentsandconfigs",
29
- ];
30
-
31
- const CODE_ASSIST_ENDPOINTS = [
32
- "https://cloudcode-pa.googleapis.com",
33
- "https://daily-cloudcode-pa.sandbox.googleapis.com",
34
- ];
35
-
36
- const RESPONSE_PAGE = `<!DOCTYPE html>
37
- <html lang="en">
38
- <head>
39
- <meta charset="utf-8" />
40
- <title>Symi Antigravity OAuth</title>
41
- </head>
42
- <body>
43
- <main>
44
- <h1>Authentication complete</h1>
45
- <p>You can return to the terminal.</p>
46
- </main>
47
- </body>
48
- </html>`;
49
-
50
- function generatePkce(): { verifier: string; challenge: string } {
51
- const verifier = randomBytes(32).toString("hex");
52
- const challenge = createHash("sha256").update(verifier).digest("base64url");
53
- return { verifier, challenge };
54
- }
55
-
56
- function shouldUseManualOAuthFlow(isRemote: boolean): boolean {
57
- return isRemote || isWSL2Sync();
58
- }
59
-
60
- function buildAuthUrl(params: { challenge: string; state: string }): string {
61
- const url = new URL(AUTH_URL);
62
- url.searchParams.set("client_id", CLIENT_ID);
63
- url.searchParams.set("response_type", "code");
64
- url.searchParams.set("redirect_uri", REDIRECT_URI);
65
- url.searchParams.set("scope", SCOPES.join(" "));
66
- url.searchParams.set("code_challenge", params.challenge);
67
- url.searchParams.set("code_challenge_method", "S256");
68
- url.searchParams.set("state", params.state);
69
- url.searchParams.set("access_type", "offline");
70
- url.searchParams.set("prompt", "consent");
71
- return url.toString();
72
- }
73
-
74
- function parseCallbackInput(input: string): { code: string; state: string } | { error: string } {
75
- const trimmed = input.trim();
76
- if (!trimmed) {
77
- return { error: "No input provided" };
78
- }
79
-
80
- try {
81
- const url = new URL(trimmed);
82
- const code = url.searchParams.get("code");
83
- const state = url.searchParams.get("state");
84
- if (!code) {
85
- return { error: "Missing 'code' parameter in URL" };
86
- }
87
- if (!state) {
88
- return { error: "Missing 'state' parameter in URL" };
89
- }
90
- return { code, state };
91
- } catch {
92
- return { error: "Paste the full redirect URL (not just the code)." };
93
- }
94
- }
95
-
96
- async function startCallbackServer(params: { timeoutMs: number }) {
97
- const redirect = new URL(REDIRECT_URI);
98
- const port = redirect.port ? Number(redirect.port) : 51121;
99
-
100
- let settled = false;
101
- let resolveCallback: (url: URL) => void;
102
- let rejectCallback: (err: Error) => void;
103
-
104
- const callbackPromise = new Promise<URL>((resolve, reject) => {
105
- resolveCallback = (url) => {
106
- if (settled) {
107
- return;
108
- }
109
- settled = true;
110
- resolve(url);
111
- };
112
- rejectCallback = (err) => {
113
- if (settled) {
114
- return;
115
- }
116
- settled = true;
117
- reject(err);
118
- };
119
- });
120
-
121
- const timeout = setTimeout(() => {
122
- rejectCallback(new Error("Timed out waiting for OAuth callback"));
123
- }, params.timeoutMs);
124
- timeout.unref?.();
125
-
126
- const server = createServer((request, response) => {
127
- if (!request.url) {
128
- response.writeHead(400, { "Content-Type": "text/plain" });
129
- response.end("Missing URL");
130
- return;
131
- }
132
-
133
- const url = new URL(request.url, `${redirect.protocol}//${redirect.host}`);
134
- if (url.pathname !== redirect.pathname) {
135
- response.writeHead(404, { "Content-Type": "text/plain" });
136
- response.end("Not found");
137
- return;
138
- }
139
-
140
- response.writeHead(200, { "Content-Type": "text/html; charset=utf-8" });
141
- response.end(RESPONSE_PAGE);
142
- resolveCallback(url);
143
-
144
- setImmediate(() => {
145
- server.close();
146
- });
147
- });
148
-
149
- await new Promise<void>((resolve, reject) => {
150
- const onError = (err: Error) => {
151
- server.off("error", onError);
152
- reject(err);
153
- };
154
- server.once("error", onError);
155
- server.listen(port, "127.0.0.1", () => {
156
- server.off("error", onError);
157
- resolve();
158
- });
159
- });
160
-
161
- return {
162
- waitForCallback: () => callbackPromise,
163
- close: () =>
164
- new Promise<void>((resolve) => {
165
- server.close(() => resolve());
166
- }),
167
- };
168
- }
169
-
170
- async function exchangeCode(params: {
171
- code: string;
172
- verifier: string;
173
- }): Promise<{ access: string; refresh: string; expires: number }> {
174
- const response = await fetch(TOKEN_URL, {
175
- method: "POST",
176
- headers: { "Content-Type": "application/x-www-form-urlencoded" },
177
- body: new URLSearchParams({
178
- client_id: CLIENT_ID,
179
- client_secret: CLIENT_SECRET,
180
- code: params.code,
181
- grant_type: "authorization_code",
182
- redirect_uri: REDIRECT_URI,
183
- code_verifier: params.verifier,
184
- }),
185
- });
186
-
187
- if (!response.ok) {
188
- const text = await response.text();
189
- throw new Error(`Token exchange failed: ${text}`);
190
- }
191
-
192
- const data = (await response.json()) as {
193
- access_token?: string;
194
- refresh_token?: string;
195
- expires_in?: number;
196
- };
197
-
198
- const access = data.access_token?.trim();
199
- const refresh = data.refresh_token?.trim();
200
- const expiresIn = data.expires_in ?? 0;
201
-
202
- if (!access) {
203
- throw new Error("Token exchange returned no access_token");
204
- }
205
- if (!refresh) {
206
- throw new Error("Token exchange returned no refresh_token");
207
- }
208
-
209
- const expires = Date.now() + expiresIn * 1000 - 5 * 60 * 1000;
210
- return { access, refresh, expires };
211
- }
212
-
213
- async function fetchUserEmail(accessToken: string): Promise<string | undefined> {
214
- try {
215
- const response = await fetch("https://www.googleapis.com/oauth2/v1/userinfo?alt=json", {
216
- headers: { Authorization: `Bearer ${accessToken}` },
217
- });
218
- if (!response.ok) {
219
- return undefined;
220
- }
221
- const data = (await response.json()) as { email?: string };
222
- return data.email;
223
- } catch {
224
- return undefined;
225
- }
226
- }
227
-
228
- async function fetchProjectId(accessToken: string): Promise<string> {
229
- const headers = {
230
- Authorization: `Bearer ${accessToken}`,
231
- "Content-Type": "application/json",
232
- "User-Agent": "google-api-nodejs-client/9.15.1",
233
- "X-Goog-Api-Client": "google-cloud-sdk vscode_cloudshelleditor/0.1",
234
- "Client-Metadata": JSON.stringify({
235
- ideType: "IDE_UNSPECIFIED",
236
- platform: "PLATFORM_UNSPECIFIED",
237
- pluginType: "GEMINI",
238
- }),
239
- };
240
-
241
- for (const endpoint of CODE_ASSIST_ENDPOINTS) {
242
- try {
243
- const response = await fetch(`${endpoint}/v1internal:loadCodeAssist`, {
244
- method: "POST",
245
- headers,
246
- body: JSON.stringify({
247
- metadata: {
248
- ideType: "IDE_UNSPECIFIED",
249
- platform: "PLATFORM_UNSPECIFIED",
250
- pluginType: "GEMINI",
251
- },
252
- }),
253
- });
254
-
255
- if (!response.ok) {
256
- continue;
257
- }
258
- const data = (await response.json()) as {
259
- cloudaicompanionProject?: string | { id?: string };
260
- };
261
-
262
- if (typeof data.cloudaicompanionProject === "string") {
263
- return data.cloudaicompanionProject;
264
- }
265
- if (
266
- data.cloudaicompanionProject &&
267
- typeof data.cloudaicompanionProject === "object" &&
268
- data.cloudaicompanionProject.id
269
- ) {
270
- return data.cloudaicompanionProject.id;
271
- }
272
- } catch {
273
- // ignore
274
- }
275
- }
276
-
277
- return DEFAULT_PROJECT_ID;
278
- }
279
-
280
- async function loginAntigravity(params: {
281
- isRemote: boolean;
282
- openUrl: (url: string) => Promise<void>;
283
- prompt: (message: string) => Promise<string>;
284
- note: (message: string, title?: string) => Promise<void>;
285
- log: (message: string) => void;
286
- progress: { update: (msg: string) => void; stop: (msg?: string) => void };
287
- }): Promise<{
288
- access: string;
289
- refresh: string;
290
- expires: number;
291
- email?: string;
292
- projectId: string;
293
- }> {
294
- const { verifier, challenge } = generatePkce();
295
- const state = randomBytes(16).toString("hex");
296
- const authUrl = buildAuthUrl({ challenge, state });
297
-
298
- let callbackServer: Awaited<ReturnType<typeof startCallbackServer>> | null = null;
299
- const needsManual = shouldUseManualOAuthFlow(params.isRemote);
300
- if (!needsManual) {
301
- try {
302
- callbackServer = await startCallbackServer({ timeoutMs: 5 * 60 * 1000 });
303
- } catch {
304
- callbackServer = null;
305
- }
306
- }
307
-
308
- if (!callbackServer) {
309
- await params.note(
310
- [
311
- "Open the URL in your local browser.",
312
- "After signing in, copy the full redirect URL and paste it back here.",
313
- "",
314
- `Auth URL: ${authUrl}`,
315
- `Redirect URI: ${REDIRECT_URI}`,
316
- ].join("\n"),
317
- "Google Antigravity OAuth",
318
- );
319
- // Output raw URL below the box for easy copying (fixes #1772)
320
- params.log("");
321
- params.log("Copy this URL:");
322
- params.log(authUrl);
323
- params.log("");
324
- }
325
-
326
- if (!needsManual) {
327
- params.progress.update("Opening Google sign-in…");
328
- try {
329
- await params.openUrl(authUrl);
330
- } catch {
331
- // ignore
332
- }
333
- }
334
-
335
- let code = "";
336
- let returnedState = "";
337
-
338
- if (callbackServer) {
339
- params.progress.update("Waiting for OAuth callback…");
340
- const callback = await callbackServer.waitForCallback();
341
- code = callback.searchParams.get("code") ?? "";
342
- returnedState = callback.searchParams.get("state") ?? "";
343
- await callbackServer.close();
344
- } else {
345
- params.progress.update("Waiting for redirect URL…");
346
- const input = await params.prompt("Paste the redirect URL: ");
347
- const parsed = parseCallbackInput(input);
348
- if ("error" in parsed) {
349
- throw new Error(parsed.error);
350
- }
351
- code = parsed.code;
352
- returnedState = parsed.state;
353
- }
354
-
355
- if (!code) {
356
- throw new Error("Missing OAuth code");
357
- }
358
- if (returnedState !== state) {
359
- throw new Error("OAuth state mismatch. Please try again.");
360
- }
361
-
362
- params.progress.update("Exchanging code for tokens…");
363
- const tokens = await exchangeCode({ code, verifier });
364
- const email = await fetchUserEmail(tokens.access);
365
- const projectId = await fetchProjectId(tokens.access);
366
-
367
- params.progress.stop("Antigravity OAuth complete");
368
- return { ...tokens, email, projectId };
369
- }
370
-
371
- const antigravityPlugin = {
372
- id: "google-antigravity-auth",
373
- name: "Google Antigravity Auth",
374
- description: "OAuth flow for Google Antigravity (Cloud Code Assist)",
375
- configSchema: emptyPluginConfigSchema(),
376
- register(api: SymiPluginApi) {
377
- api.registerProvider({
378
- id: "google-antigravity",
379
- label: "Google Antigravity",
380
- docsPath: "/providers/models",
381
- aliases: ["antigravity"],
382
- auth: [
383
- {
384
- id: "oauth",
385
- label: "Google OAuth",
386
- hint: "PKCE + localhost callback",
387
- kind: "oauth",
388
- run: async (ctx: ProviderAuthContext) => {
389
- const spin = ctx.prompter.progress("Starting Antigravity OAuth…");
390
- try {
391
- const result = await loginAntigravity({
392
- isRemote: ctx.isRemote,
393
- openUrl: ctx.openUrl,
394
- prompt: async (message) => String(await ctx.prompter.text({ message })),
395
- note: ctx.prompter.note,
396
- log: (message) => ctx.runtime.log(message),
397
- progress: spin,
398
- });
399
-
400
- return buildOauthProviderAuthResult({
401
- providerId: "google-antigravity",
402
- defaultModel: DEFAULT_MODEL,
403
- access: result.access,
404
- refresh: result.refresh,
405
- expires: result.expires,
406
- email: result.email,
407
- credentialExtra: { projectId: result.projectId },
408
- notes: [
409
- "Antigravity uses Google Cloud project quotas.",
410
- "Enable Gemini for Google Cloud on your project if requests fail.",
411
- ],
412
- });
413
- } catch (err) {
414
- spin.stop("Antigravity OAuth failed");
415
- throw err;
416
- }
417
- },
418
- },
419
- ],
420
- });
421
- },
422
- };
423
-
424
- export default antigravityPlugin;
@@ -1,21 +0,0 @@
1
- #!/bin/sh
2
- basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
3
-
4
- case `uname` in
5
- *CYGWIN*|*MINGW*|*MSYS*)
6
- if command -v cygpath > /dev/null 2>&1; then
7
- basedir=`cygpath -w "$basedir"`
8
- fi
9
- ;;
10
- esac
11
-
12
- if [ -z "$NODE_PATH" ]; then
13
- export NODE_PATH="/home/symi/projects/symi/node_modules:/home/symi/projects/node_modules:/home/symi/node_modules:/home/node_modules:/node_modules:/home/symi/projects/symi/node_modules/.pnpm/node_modules"
14
- else
15
- export NODE_PATH="/home/symi/projects/symi/node_modules:/home/symi/projects/node_modules:/home/symi/node_modules:/home/node_modules:/node_modules:/home/symi/projects/symi/node_modules/.pnpm/node_modules:$NODE_PATH"
16
- fi
17
- if [ -x "$basedir/node" ]; then
18
- exec "$basedir/node" "$basedir/../@symerian/symi/symi.mjs" "$@"
19
- else
20
- exec node "$basedir/../@symerian/symi/symi.mjs" "$@"
21
- fi
@@ -1,15 +0,0 @@
1
- {
2
- "name": "@symi/google-antigravity-auth",
3
- "version": "3.0.9",
4
- "private": true,
5
- "description": "Symi Google Antigravity OAuth provider plugin",
6
- "type": "module",
7
- "devDependencies": {
8
- "@symerian/symi": "workspace:*"
9
- },
10
- "symi": {
11
- "extensions": [
12
- "./index.ts"
13
- ]
14
- }
15
- }
@@ -1,9 +0,0 @@
1
- {
2
- "id": "google-antigravity-auth",
3
- "providers": ["google-antigravity"],
4
- "configSchema": {
5
- "type": "object",
6
- "additionalProperties": false,
7
- "properties": {}
8
- }
9
- }
@@ -1,35 +0,0 @@
1
- # Google Gemini CLI Auth (Symi plugin)
2
-
3
- OAuth provider plugin for **Gemini CLI** (Google Code Assist).
4
-
5
- ## Enable
6
-
7
- Bundled plugins are disabled by default. Enable this one:
8
-
9
- ```bash
10
- symi plugins enable google-gemini-cli-auth
11
- ```
12
-
13
- Restart the Gateway after enabling.
14
-
15
- ## Authenticate
16
-
17
- ```bash
18
- symi models auth login --provider google-gemini-cli --set-default
19
- ```
20
-
21
- ## Requirements
22
-
23
- Requires the Gemini CLI to be installed (credentials are extracted automatically):
24
-
25
- ```bash
26
- brew install gemini-cli
27
- # or: npm install -g @google/gemini-cli
28
- ```
29
-
30
- ## Env vars (optional)
31
-
32
- Override auto-detected credentials with:
33
-
34
- - `SYMI_GEMINI_OAUTH_CLIENT_ID` / `GEMINI_CLI_OAUTH_CLIENT_ID`
35
- - `SYMI_GEMINI_OAUTH_CLIENT_SECRET` / `GEMINI_CLI_OAUTH_CLIENT_SECRET`
@@ -1,75 +0,0 @@
1
- import {
2
- buildOauthProviderAuthResult,
3
- emptyPluginConfigSchema,
4
- type SymiPluginApi,
5
- type ProviderAuthContext,
6
- } from "symi/plugin-sdk";
7
- import { loginGeminiCliOAuth } from "./oauth.js";
8
-
9
- const PROVIDER_ID = "google-gemini-cli";
10
- const PROVIDER_LABEL = "Gemini CLI OAuth";
11
- const DEFAULT_MODEL = "google-gemini-cli/gemini-3-pro-preview";
12
- const ENV_VARS = [
13
- "SYMI_GEMINI_OAUTH_CLIENT_ID",
14
- "SYMI_GEMINI_OAUTH_CLIENT_SECRET",
15
- "GEMINI_CLI_OAUTH_CLIENT_ID",
16
- "GEMINI_CLI_OAUTH_CLIENT_SECRET",
17
- ];
18
-
19
- const geminiCliPlugin = {
20
- id: "google-gemini-cli-auth",
21
- name: "Google Gemini CLI Auth",
22
- description: "OAuth flow for Gemini CLI (Google Code Assist)",
23
- configSchema: emptyPluginConfigSchema(),
24
- register(api: SymiPluginApi) {
25
- api.registerProvider({
26
- id: PROVIDER_ID,
27
- label: PROVIDER_LABEL,
28
- docsPath: "/providers/models",
29
- aliases: ["gemini-cli"],
30
- envVars: ENV_VARS,
31
- auth: [
32
- {
33
- id: "oauth",
34
- label: "Google OAuth",
35
- hint: "PKCE + localhost callback",
36
- kind: "oauth",
37
- run: async (ctx: ProviderAuthContext) => {
38
- const spin = ctx.prompter.progress("Starting Gemini CLI OAuth…");
39
- try {
40
- const result = await loginGeminiCliOAuth({
41
- isRemote: ctx.isRemote,
42
- openUrl: ctx.openUrl,
43
- log: (msg) => ctx.runtime.log(msg),
44
- note: ctx.prompter.note,
45
- prompt: async (message) => String(await ctx.prompter.text({ message })),
46
- progress: spin,
47
- });
48
-
49
- spin.stop("Gemini CLI OAuth complete");
50
- return buildOauthProviderAuthResult({
51
- providerId: PROVIDER_ID,
52
- defaultModel: DEFAULT_MODEL,
53
- access: result.access,
54
- refresh: result.refresh,
55
- expires: result.expires,
56
- email: result.email,
57
- credentialExtra: { projectId: result.projectId },
58
- notes: ["If requests fail, set GOOGLE_CLOUD_PROJECT or GOOGLE_CLOUD_PROJECT_ID."],
59
- });
60
- } catch (err) {
61
- spin.stop("Gemini CLI OAuth failed");
62
- await ctx.prompter.note(
63
- "Trouble with OAuth? Ensure your Google account has Gemini CLI access.",
64
- "OAuth help",
65
- );
66
- throw err;
67
- }
68
- },
69
- },
70
- ],
71
- });
72
- },
73
- };
74
-
75
- export default geminiCliPlugin;
@@ -1,21 +0,0 @@
1
- #!/bin/sh
2
- basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
3
-
4
- case `uname` in
5
- *CYGWIN*|*MINGW*|*MSYS*)
6
- if command -v cygpath > /dev/null 2>&1; then
7
- basedir=`cygpath -w "$basedir"`
8
- fi
9
- ;;
10
- esac
11
-
12
- if [ -z "$NODE_PATH" ]; then
13
- export NODE_PATH="/home/symi/projects/symi/node_modules:/home/symi/projects/node_modules:/home/symi/node_modules:/home/node_modules:/node_modules:/home/symi/projects/symi/node_modules/.pnpm/node_modules"
14
- else
15
- export NODE_PATH="/home/symi/projects/symi/node_modules:/home/symi/projects/node_modules:/home/symi/node_modules:/home/node_modules:/node_modules:/home/symi/projects/symi/node_modules/.pnpm/node_modules:$NODE_PATH"
16
- fi
17
- if [ -x "$basedir/node" ]; then
18
- exec "$basedir/node" "$basedir/../@symerian/symi/symi.mjs" "$@"
19
- else
20
- exec node "$basedir/../@symerian/symi/symi.mjs" "$@"
21
- fi