pi-ui-extend 0.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +307 -0
- package/bin/pix.mjs +219 -0
- package/dist/app/app.d.ts +96 -0
- package/dist/app/app.js +871 -0
- package/dist/app/blink-controller.d.ts +23 -0
- package/dist/app/blink-controller.js +82 -0
- package/dist/app/cli.d.ts +8 -0
- package/dist/app/cli.js +83 -0
- package/dist/app/clipboard.d.ts +1 -0
- package/dist/app/clipboard.js +24 -0
- package/dist/app/command-controller.d.ts +18 -0
- package/dist/app/command-controller.js +58 -0
- package/dist/app/command-host.d.ts +44 -0
- package/dist/app/command-host.js +1 -0
- package/dist/app/command-model-actions.d.ts +12 -0
- package/dist/app/command-model-actions.js +176 -0
- package/dist/app/command-navigation-actions.d.ts +19 -0
- package/dist/app/command-navigation-actions.js +267 -0
- package/dist/app/command-registry.d.ts +32 -0
- package/dist/app/command-registry.js +225 -0
- package/dist/app/command-runtime.d.ts +5 -0
- package/dist/app/command-runtime.js +32 -0
- package/dist/app/command-session-actions.d.ts +20 -0
- package/dist/app/command-session-actions.js +295 -0
- package/dist/app/constants.d.ts +52 -0
- package/dist/app/constants.js +103 -0
- package/dist/app/conversation-entry-renderer.d.ts +21 -0
- package/dist/app/conversation-entry-renderer.js +81 -0
- package/dist/app/conversation-shell-renderer.d.ts +5 -0
- package/dist/app/conversation-shell-renderer.js +43 -0
- package/dist/app/conversation-tool-renderer.d.ts +16 -0
- package/dist/app/conversation-tool-renderer.js +216 -0
- package/dist/app/conversation-viewport.d.ts +55 -0
- package/dist/app/conversation-viewport.js +252 -0
- package/dist/app/dcp-stats.d.ts +2 -0
- package/dist/app/dcp-stats.js +116 -0
- package/dist/app/editor-layout-renderer.d.ts +31 -0
- package/dist/app/editor-layout-renderer.js +211 -0
- package/dist/app/editor-panels.d.ts +4 -0
- package/dist/app/editor-panels.js +130 -0
- package/dist/app/extension-actions-controller.d.ts +22 -0
- package/dist/app/extension-actions-controller.js +60 -0
- package/dist/app/extension-event-bus.d.ts +3 -0
- package/dist/app/extension-event-bus.js +23 -0
- package/dist/app/extension-ui-controller.d.ts +57 -0
- package/dist/app/extension-ui-controller.js +532 -0
- package/dist/app/file-link-opener.d.ts +2 -0
- package/dist/app/file-link-opener.js +66 -0
- package/dist/app/file-links.d.ts +10 -0
- package/dist/app/file-links.js +117 -0
- package/dist/app/guards.d.ts +3 -0
- package/dist/app/guards.js +9 -0
- package/dist/app/icons.d.ts +37 -0
- package/dist/app/icons.js +97 -0
- package/dist/app/id.d.ts +1 -0
- package/dist/app/id.js +4 -0
- package/dist/app/image-click-targets.d.ts +5 -0
- package/dist/app/image-click-targets.js +32 -0
- package/dist/app/image-opener.d.ts +2 -0
- package/dist/app/image-opener.js +64 -0
- package/dist/app/input-action-controller.d.ts +47 -0
- package/dist/app/input-action-controller.js +209 -0
- package/dist/app/input-controller.d.ts +60 -0
- package/dist/app/input-controller.js +425 -0
- package/dist/app/input-paste-handler.d.ts +27 -0
- package/dist/app/input-paste-handler.js +146 -0
- package/dist/app/menu-items-controller.d.ts +32 -0
- package/dist/app/menu-items-controller.js +182 -0
- package/dist/app/message-content.d.ts +8 -0
- package/dist/app/message-content.js +115 -0
- package/dist/app/model-ref.d.ts +13 -0
- package/dist/app/model-ref.js +50 -0
- package/dist/app/model-usage-controller.d.ts +35 -0
- package/dist/app/model-usage-controller.js +99 -0
- package/dist/app/model-usage-status.d.ts +125 -0
- package/dist/app/model-usage-status.js +749 -0
- package/dist/app/mouse-controller.d.ts +182 -0
- package/dist/app/mouse-controller.js +968 -0
- package/dist/app/native-modifiers.d.ts +3 -0
- package/dist/app/native-modifiers.js +60 -0
- package/dist/app/nerd-font-controller.d.ts +11 -0
- package/dist/app/nerd-font-controller.js +90 -0
- package/dist/app/popup-action-controller.d.ts +44 -0
- package/dist/app/popup-action-controller.js +278 -0
- package/dist/app/popup-menu-controller.d.ts +183 -0
- package/dist/app/popup-menu-controller.js +1070 -0
- package/dist/app/prompt-enhancer-controller.d.ts +40 -0
- package/dist/app/prompt-enhancer-controller.js +215 -0
- package/dist/app/queued-message-controller.d.ts +62 -0
- package/dist/app/queued-message-controller.js +377 -0
- package/dist/app/render-controller.d.ts +41 -0
- package/dist/app/render-controller.js +378 -0
- package/dist/app/render-text.d.ts +19 -0
- package/dist/app/render-text.js +67 -0
- package/dist/app/request-history.d.ts +23 -0
- package/dist/app/request-history.js +131 -0
- package/dist/app/runtime.d.ts +39 -0
- package/dist/app/runtime.js +195 -0
- package/dist/app/screen-selection.d.ts +6 -0
- package/dist/app/screen-selection.js +9 -0
- package/dist/app/screen-styler.d.ts +34 -0
- package/dist/app/screen-styler.js +168 -0
- package/dist/app/scroll-controller.d.ts +51 -0
- package/dist/app/scroll-controller.js +207 -0
- package/dist/app/session-event-controller.d.ts +69 -0
- package/dist/app/session-event-controller.js +338 -0
- package/dist/app/session-history.d.ts +23 -0
- package/dist/app/session-history.js +164 -0
- package/dist/app/session-lifecycle-controller.d.ts +55 -0
- package/dist/app/session-lifecycle-controller.js +116 -0
- package/dist/app/session-search.d.ts +24 -0
- package/dist/app/session-search.js +215 -0
- package/dist/app/shell-command.d.ts +27 -0
- package/dist/app/shell-command.js +176 -0
- package/dist/app/shell-controller.d.ts +28 -0
- package/dist/app/shell-controller.js +124 -0
- package/dist/app/slash-commands.d.ts +6 -0
- package/dist/app/slash-commands.js +75 -0
- package/dist/app/startup-checks.d.ts +8 -0
- package/dist/app/startup-checks.js +59 -0
- package/dist/app/startup-info.d.ts +3 -0
- package/dist/app/startup-info.js +176 -0
- package/dist/app/status-controller.d.ts +35 -0
- package/dist/app/status-controller.js +105 -0
- package/dist/app/status-line-renderer.d.ts +68 -0
- package/dist/app/status-line-renderer.js +453 -0
- package/dist/app/subagents-files.d.ts +10 -0
- package/dist/app/subagents-files.js +193 -0
- package/dist/app/subagents-model.d.ts +23 -0
- package/dist/app/subagents-model.js +224 -0
- package/dist/app/subagents-widget-controller.d.ts +43 -0
- package/dist/app/subagents-widget-controller.js +311 -0
- package/dist/app/tab-line-renderer.d.ts +26 -0
- package/dist/app/tab-line-renderer.js +222 -0
- package/dist/app/tabs-controller.d.ts +100 -0
- package/dist/app/tabs-controller.js +885 -0
- package/dist/app/terminal-controller.d.ts +40 -0
- package/dist/app/terminal-controller.js +135 -0
- package/dist/app/terminal-edit-shortcuts.d.ts +23 -0
- package/dist/app/terminal-edit-shortcuts.js +138 -0
- package/dist/app/terminal-output-buffer.d.ts +20 -0
- package/dist/app/terminal-output-buffer.js +52 -0
- package/dist/app/toast-controller.d.ts +13 -0
- package/dist/app/toast-controller.js +40 -0
- package/dist/app/toast-renderer.d.ts +9 -0
- package/dist/app/toast-renderer.js +79 -0
- package/dist/app/todo-model.d.ts +22 -0
- package/dist/app/todo-model.js +179 -0
- package/dist/app/todo-widget-controller.d.ts +21 -0
- package/dist/app/todo-widget-controller.js +59 -0
- package/dist/app/tool-block-renderer.d.ts +26 -0
- package/dist/app/tool-block-renderer.js +439 -0
- package/dist/app/types.d.ts +550 -0
- package/dist/app/types.js +1 -0
- package/dist/app/update.d.ts +36 -0
- package/dist/app/update.js +315 -0
- package/dist/app/voice-controller.d.ts +52 -0
- package/dist/app/voice-controller.js +600 -0
- package/dist/app/workspace-actions-controller.d.ts +40 -0
- package/dist/app/workspace-actions-controller.js +215 -0
- package/dist/app/workspace-undo.d.ts +44 -0
- package/dist/app/workspace-undo.js +215 -0
- package/dist/config.d.ts +62 -0
- package/dist/config.js +527 -0
- package/dist/context-progress-bar.d.ts +17 -0
- package/dist/context-progress-bar.js +48 -0
- package/dist/default-pix-config.d.ts +1 -0
- package/dist/default-pix-config.js +375 -0
- package/dist/fuzzy.d.ts +23 -0
- package/dist/fuzzy.js +165 -0
- package/dist/input-editor-files.d.ts +15 -0
- package/dist/input-editor-files.js +62 -0
- package/dist/input-editor.d.ts +186 -0
- package/dist/input-editor.js +835 -0
- package/dist/main.d.ts +1 -0
- package/dist/main.js +12 -0
- package/dist/markdown-format.d.ts +22 -0
- package/dist/markdown-format.js +542 -0
- package/dist/sdk.d.ts +3 -0
- package/dist/sdk.js +1 -0
- package/dist/syntax-highlight.d.ts +22 -0
- package/dist/syntax-highlight.js +528 -0
- package/dist/terminal-width.d.ts +6 -0
- package/dist/terminal-width.js +245 -0
- package/dist/theme.d.ts +56 -0
- package/dist/theme.js +118 -0
- package/dist/tool-renderers/apply-patch.d.ts +2 -0
- package/dist/tool-renderers/apply-patch.js +36 -0
- package/dist/tool-renderers/ast.d.ts +2 -0
- package/dist/tool-renderers/ast.js +5 -0
- package/dist/tool-renderers/compress.d.ts +2 -0
- package/dist/tool-renderers/compress.js +126 -0
- package/dist/tool-renderers/index.d.ts +3 -0
- package/dist/tool-renderers/index.js +44 -0
- package/dist/tool-renderers/question.d.ts +2 -0
- package/dist/tool-renderers/question.js +88 -0
- package/dist/tool-renderers/read.d.ts +2 -0
- package/dist/tool-renderers/read.js +36 -0
- package/dist/tool-renderers/repo.d.ts +2 -0
- package/dist/tool-renderers/repo.js +13 -0
- package/dist/tool-renderers/shell.d.ts +3 -0
- package/dist/tool-renderers/shell.js +27 -0
- package/dist/tool-renderers/skill.d.ts +2 -0
- package/dist/tool-renderers/skill.js +132 -0
- package/dist/tool-renderers/subagents.d.ts +2 -0
- package/dist/tool-renderers/subagents.js +51 -0
- package/dist/tool-renderers/todo.d.ts +2 -0
- package/dist/tool-renderers/todo.js +9 -0
- package/dist/tool-renderers/types.d.ts +42 -0
- package/dist/tool-renderers/types.js +1 -0
- package/dist/tool-renderers/utils.d.ts +31 -0
- package/dist/tool-renderers/utils.js +230 -0
- package/dist/tool-renderers/web.d.ts +3 -0
- package/dist/tool-renderers/web.js +9 -0
- package/dist/tool-renderers/write.d.ts +2 -0
- package/dist/tool-renderers/write.js +42 -0
- package/dist/ui.d.ts +56 -0
- package/dist/ui.js +94 -0
- package/docs/release.md +81 -0
- package/extensions/question/contract.ts +100 -0
- package/extensions/question/index.ts +34 -0
- package/extensions/question/render.ts +28 -0
- package/extensions/question/result.ts +86 -0
- package/extensions/question/tool-description.ts +11 -0
- package/extensions/question/tui.ts +629 -0
- package/extensions/question/types.ts +123 -0
- package/extensions/session-title/config.ts +169 -0
- package/extensions/session-title/index.ts +459 -0
- package/extensions/terminal-bell/index.ts +315 -0
- package/external/pi-tools-suite/README.md +242 -0
- package/external/pi-tools-suite/index.ts +1 -0
- package/external/pi-tools-suite/licenses/ollama-pi-web-search.MIT +21 -0
- package/external/pi-tools-suite/licenses/opencode-mystatus-MIT.txt +21 -0
- package/external/pi-tools-suite/package.json +53 -0
- package/external/pi-tools-suite/src/antigravity-auth/auth-store.ts +194 -0
- package/external/pi-tools-suite/src/antigravity-auth/commands.ts +80 -0
- package/external/pi-tools-suite/src/antigravity-auth/constants.ts +26 -0
- package/external/pi-tools-suite/src/antigravity-auth/headers.ts +20 -0
- package/external/pi-tools-suite/src/antigravity-auth/index.ts +104 -0
- package/external/pi-tools-suite/src/antigravity-auth/models.ts +86 -0
- package/external/pi-tools-suite/src/antigravity-auth/oauth.ts +305 -0
- package/external/pi-tools-suite/src/antigravity-auth/payload.ts +423 -0
- package/external/pi-tools-suite/src/antigravity-auth/status.ts +78 -0
- package/external/pi-tools-suite/src/antigravity-auth/stream.ts +302 -0
- package/external/pi-tools-suite/src/antigravity-auth/types.ts +113 -0
- package/external/pi-tools-suite/src/ast-grep/index.ts +6 -0
- package/external/pi-tools-suite/src/ast-grep/render.ts +70 -0
- package/external/pi-tools-suite/src/ast-grep/schema.ts +109 -0
- package/external/pi-tools-suite/src/ast-grep/tool.ts +345 -0
- package/external/pi-tools-suite/src/ast-grep/types.ts +55 -0
- package/external/pi-tools-suite/src/ast-grep/utils.ts +65 -0
- package/external/pi-tools-suite/src/async-subagents/async-subagents.sample.jsonc +222 -0
- package/external/pi-tools-suite/src/async-subagents/commands.ts +518 -0
- package/external/pi-tools-suite/src/async-subagents/constants.ts +11 -0
- package/external/pi-tools-suite/src/async-subagents/core/agent-strategy.ts +74 -0
- package/external/pi-tools-suite/src/async-subagents/core/attachment-bridge.ts +133 -0
- package/external/pi-tools-suite/src/async-subagents/core/cleanup.ts +66 -0
- package/external/pi-tools-suite/src/async-subagents/core/concurrency.ts +90 -0
- package/external/pi-tools-suite/src/async-subagents/core/config.ts +819 -0
- package/external/pi-tools-suite/src/async-subagents/core/log-limits.ts +166 -0
- package/external/pi-tools-suite/src/async-subagents/core/model-fallback.ts +133 -0
- package/external/pi-tools-suite/src/async-subagents/core/paths.ts +47 -0
- package/external/pi-tools-suite/src/async-subagents/core/pi-invocation.ts +35 -0
- package/external/pi-tools-suite/src/async-subagents/core/presets.ts +67 -0
- package/external/pi-tools-suite/src/async-subagents/core/process.ts +15 -0
- package/external/pi-tools-suite/src/async-subagents/core/prompt.ts +66 -0
- package/external/pi-tools-suite/src/async-subagents/core/registry.ts +224 -0
- package/external/pi-tools-suite/src/async-subagents/core/retry.ts +191 -0
- package/external/pi-tools-suite/src/async-subagents/core/routing.ts +259 -0
- package/external/pi-tools-suite/src/async-subagents/core/sessions.ts +138 -0
- package/external/pi-tools-suite/src/async-subagents/core/spawn.ts +688 -0
- package/external/pi-tools-suite/src/async-subagents/core/state.ts +281 -0
- package/external/pi-tools-suite/src/async-subagents/core/stop.ts +131 -0
- package/external/pi-tools-suite/src/async-subagents/core/structured-result.ts +237 -0
- package/external/pi-tools-suite/src/async-subagents/core/tool-guard.ts +34 -0
- package/external/pi-tools-suite/src/async-subagents/core/types.ts +150 -0
- package/external/pi-tools-suite/src/async-subagents/core/ultrawork-auto.ts +184 -0
- package/external/pi-tools-suite/src/async-subagents/core/utils.ts +11 -0
- package/external/pi-tools-suite/src/async-subagents/format.ts +41 -0
- package/external/pi-tools-suite/src/async-subagents/index.ts +422 -0
- package/external/pi-tools-suite/src/async-subagents/lib.ts +88 -0
- package/external/pi-tools-suite/src/async-subagents/live.ts +10 -0
- package/external/pi-tools-suite/src/async-subagents/polling.ts +83 -0
- package/external/pi-tools-suite/src/async-subagents/render.ts +230 -0
- package/external/pi-tools-suite/src/async-subagents/subagent-overlay.ts +77 -0
- package/external/pi-tools-suite/src/async-subagents/tasks.ts +120 -0
- package/external/pi-tools-suite/src/async-subagents/tools/cleanup.ts +99 -0
- package/external/pi-tools-suite/src/async-subagents/tools/result.ts +179 -0
- package/external/pi-tools-suite/src/async-subagents/tools/spawn.ts +372 -0
- package/external/pi-tools-suite/src/async-subagents/tools/status.ts +60 -0
- package/external/pi-tools-suite/src/async-subagents/tools/stop.ts +79 -0
- package/external/pi-tools-suite/src/async-subagents/tools/subagents.ts +152 -0
- package/external/pi-tools-suite/src/async-subagents/tools/wait.ts +67 -0
- package/external/pi-tools-suite/src/async-subagents/types.ts +45 -0
- package/external/pi-tools-suite/src/async-subagents/ui.ts +5 -0
- package/external/pi-tools-suite/src/compress/commands.ts +440 -0
- package/external/pi-tools-suite/src/compress/compress-tool.ts +368 -0
- package/external/pi-tools-suite/src/compress/compression-blocks.ts +524 -0
- package/external/pi-tools-suite/src/compress/config.ts +310 -0
- package/external/pi-tools-suite/src/compress/dcp-tui-filter.ts +498 -0
- package/external/pi-tools-suite/src/compress/index.ts +397 -0
- package/external/pi-tools-suite/src/compress/prompts.ts +269 -0
- package/external/pi-tools-suite/src/compress/pruner-candidates.ts +176 -0
- package/external/pi-tools-suite/src/compress/pruner-compression-blocks.ts +260 -0
- package/external/pi-tools-suite/src/compress/pruner-message-ids.ts +147 -0
- package/external/pi-tools-suite/src/compress/pruner-metadata.ts +268 -0
- package/external/pi-tools-suite/src/compress/pruner-nudge.ts +315 -0
- package/external/pi-tools-suite/src/compress/pruner-tools.ts +263 -0
- package/external/pi-tools-suite/src/compress/pruner-types.ts +25 -0
- package/external/pi-tools-suite/src/compress/pruner.ts +92 -0
- package/external/pi-tools-suite/src/compress/state.ts +486 -0
- package/external/pi-tools-suite/src/compress/ui.ts +308 -0
- package/external/pi-tools-suite/src/config.ts +176 -0
- package/external/pi-tools-suite/src/context-usage.ts +31 -0
- package/external/pi-tools-suite/src/default-pi-tools-suite-config.ts +355 -0
- package/external/pi-tools-suite/src/index.ts +46 -0
- package/external/pi-tools-suite/src/lib/lsp.ts +62 -0
- package/external/pi-tools-suite/src/lib/project.ts +42 -0
- package/external/pi-tools-suite/src/lib/tool-args.ts +137 -0
- package/external/pi-tools-suite/src/lsp/_shared/config.ts +156 -0
- package/external/pi-tools-suite/src/lsp/_shared/glob.ts +60 -0
- package/external/pi-tools-suite/src/lsp/_shared/output.ts +102 -0
- package/external/pi-tools-suite/src/lsp/_shared/paths.ts +138 -0
- package/external/pi-tools-suite/src/lsp/_shared/runner.ts +64 -0
- package/external/pi-tools-suite/src/lsp/_shared/template.ts +23 -0
- package/external/pi-tools-suite/src/lsp/_shared/trust.ts +116 -0
- package/external/pi-tools-suite/src/lsp/_shared/types.ts +98 -0
- package/external/pi-tools-suite/src/lsp/async.ts +29 -0
- package/external/pi-tools-suite/src/lsp/child-process.ts +81 -0
- package/external/pi-tools-suite/src/lsp/client.ts +340 -0
- package/external/pi-tools-suite/src/lsp/constants.ts +9 -0
- package/external/pi-tools-suite/src/lsp/diagnostics-store.ts +64 -0
- package/external/pi-tools-suite/src/lsp/documents.ts +24 -0
- package/external/pi-tools-suite/src/lsp/index.ts +31 -0
- package/external/pi-tools-suite/src/lsp/lsp-utils.ts +37 -0
- package/external/pi-tools-suite/src/lsp/manager.ts +190 -0
- package/external/pi-tools-suite/src/lsp/mutation-events.ts +78 -0
- package/external/pi-tools-suite/src/lsp/renderer.ts +1 -0
- package/external/pi-tools-suite/src/lsp/tool-result.ts +6 -0
- package/external/pi-tools-suite/src/lsp/tsserver.ts +107 -0
- package/external/pi-tools-suite/src/lsp/types.ts +15 -0
- package/external/pi-tools-suite/src/model-tools/apply-patch.ts +590 -0
- package/external/pi-tools-suite/src/model-tools/index.ts +430 -0
- package/external/pi-tools-suite/src/model-tools/path-utils.ts +6 -0
- package/external/pi-tools-suite/src/model-tools/tool-args.ts +11 -0
- package/external/pi-tools-suite/src/prompt-commands/index.ts +349 -0
- package/external/pi-tools-suite/src/repo-discovery/index.ts +384 -0
- package/external/pi-tools-suite/src/repo-discovery/project.ts +7 -0
- package/external/pi-tools-suite/src/startup-section.ts +13 -0
- package/external/pi-tools-suite/src/terminal-bell/index.ts +309 -0
- package/external/pi-tools-suite/src/todo/index.ts +201 -0
- package/external/pi-tools-suite/src/todo/state/auto-clear.ts +13 -0
- package/external/pi-tools-suite/src/todo/state/invariants.ts +21 -0
- package/external/pi-tools-suite/src/todo/state/persistence.ts +94 -0
- package/external/pi-tools-suite/src/todo/state/replay.ts +38 -0
- package/external/pi-tools-suite/src/todo/state/selectors.ts +49 -0
- package/external/pi-tools-suite/src/todo/state/state-reducer.ts +362 -0
- package/external/pi-tools-suite/src/todo/state/state.ts +18 -0
- package/external/pi-tools-suite/src/todo/state/store.ts +52 -0
- package/external/pi-tools-suite/src/todo/state/task-graph.ts +57 -0
- package/external/pi-tools-suite/src/todo/todo.ts +487 -0
- package/external/pi-tools-suite/src/todo/tool/response-envelope.ts +143 -0
- package/external/pi-tools-suite/src/todo/tool/types.ts +188 -0
- package/external/pi-tools-suite/src/todo/view/format.ts +18 -0
- package/external/pi-tools-suite/src/todo/view/labels.ts +13 -0
- package/external/pi-tools-suite/src/tool-descriptions.ts +369 -0
- package/external/pi-tools-suite/src/usage/index.ts +152 -0
- package/external/pi-tools-suite/src/usage/lib/copilot.ts +535 -0
- package/external/pi-tools-suite/src/usage/lib/google.ts +478 -0
- package/external/pi-tools-suite/src/usage/lib/openai.ts +268 -0
- package/external/pi-tools-suite/src/usage/lib/types.ts +114 -0
- package/external/pi-tools-suite/src/usage/lib/utils.ts +134 -0
- package/external/pi-tools-suite/src/usage/lib/zhipu.ts +228 -0
- package/external/pi-tools-suite/src/web-search/index.ts +397 -0
- package/package.json +89 -0
- package/skills/context7/SKILL.md +69 -0
- package/skills/context7/scripts/context7.sh +73 -0
- package/skills/handoff/SKILL.md +15 -0
- package/skills/pdf/LICENSE.txt +30 -0
- package/skills/pdf/SKILL.md +314 -0
- package/skills/pdf/forms.md +294 -0
- package/skills/pdf/reference.md +612 -0
- package/skills/pdf/scripts/check_bounding_boxes.py +65 -0
- package/skills/pdf/scripts/check_fillable_fields.py +11 -0
- package/skills/pdf/scripts/convert_pdf_to_images.py +33 -0
- package/skills/pdf/scripts/create_validation_image.py +37 -0
- package/skills/pdf/scripts/extract_form_field_info.py +122 -0
- package/skills/pdf/scripts/extract_form_structure.py +115 -0
- package/skills/pdf/scripts/fill_fillable_fields.py +98 -0
- package/skills/pdf/scripts/fill_pdf_form_with_annotations.py +107 -0
- package/skills/playwright-cli/SKILL.md +388 -0
- package/skills/playwright-cli/references/element-attributes.md +23 -0
- package/skills/playwright-cli/references/playwright-tests.md +39 -0
- package/skills/playwright-cli/references/request-mocking.md +87 -0
- package/skills/playwright-cli/references/running-code.md +241 -0
- package/skills/playwright-cli/references/session-management.md +225 -0
- package/skills/playwright-cli/references/spec-driven-testing.md +305 -0
- package/skills/playwright-cli/references/storage-state.md +275 -0
- package/skills/playwright-cli/references/test-generation.md +134 -0
- package/skills/playwright-cli/references/tracing.md +139 -0
- package/skills/playwright-cli/references/video-recording.md +143 -0
- package/skills/simplify/SKILL.md +51 -0
- package/skills/skill-creator/LICENSE.txt +202 -0
- package/skills/skill-creator/SKILL.md +485 -0
- package/skills/skill-creator/agents/analyzer.md +274 -0
- package/skills/skill-creator/agents/comparator.md +202 -0
- package/skills/skill-creator/agents/grader.md +223 -0
- package/skills/skill-creator/assets/eval_review.html +146 -0
- package/skills/skill-creator/eval-viewer/generate_review.py +471 -0
- package/skills/skill-creator/eval-viewer/viewer.html +1325 -0
- package/skills/skill-creator/references/schemas.md +430 -0
- package/skills/skill-creator/scripts/__init__.py +0 -0
- package/skills/skill-creator/scripts/aggregate_benchmark.py +401 -0
- package/skills/skill-creator/scripts/generate_report.py +326 -0
- package/skills/skill-creator/scripts/improve_description.py +247 -0
- package/skills/skill-creator/scripts/package_skill.py +136 -0
- package/skills/skill-creator/scripts/quick_validate.py +103 -0
- package/skills/skill-creator/scripts/run_eval.py +310 -0
- package/skills/skill-creator/scripts/run_loop.py +328 -0
- package/skills/skill-creator/scripts/utils.py +47 -0
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "pi-tools-suite-local",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"private": true,
|
|
5
|
+
"type": "module",
|
|
6
|
+
"description": "Local all-in-one Pi extension package for ast-grep, async subagents, LSP, model tools, and todos.",
|
|
7
|
+
"keywords": [
|
|
8
|
+
"pi-package",
|
|
9
|
+
"pi-extension"
|
|
10
|
+
],
|
|
11
|
+
"module": "./src/index.ts",
|
|
12
|
+
"files": [
|
|
13
|
+
"index.ts",
|
|
14
|
+
"src",
|
|
15
|
+
"docs",
|
|
16
|
+
"licenses",
|
|
17
|
+
"README.md"
|
|
18
|
+
],
|
|
19
|
+
"scripts": {
|
|
20
|
+
"smoke:explicit": "PI_OFFLINE=1 pi --extension ./index.ts --no-session --no-tools -p \"ping\"",
|
|
21
|
+
"smoke:auto": "PI_OFFLINE=1 pi --no-session --no-tools -p \"ping\"",
|
|
22
|
+
"smoke:tools": "PI_OFFLINE=1 pi --no-session -p \"ping\"",
|
|
23
|
+
"smoke": "npm run smoke:explicit && npm run smoke:auto && npm run smoke:tools",
|
|
24
|
+
"test": "bun test test",
|
|
25
|
+
"test:async-subagents-e2e": "ASYNC_SUBAGENTS_E2E=1 ASYNC_SUBAGENTS_MODEL=zai/glm-5-turbo bun test --concurrent --max-concurrency=30 test/async-subagents",
|
|
26
|
+
"test:async-subagents-selection-e2e": "ASYNC_SUBAGENTS_SELECTION_E2E=1 ASYNC_SUBAGENTS_MODEL=zai/glm-5-turbo bun test --concurrent --max-concurrency=30 test/async-subagents/selection-e2e.test.ts",
|
|
27
|
+
"bench:locate": "PI_LOCATE_BENCH_ITERATIONS=5 PI_LOCATE_BENCH_FAKE_IDX=0 PI_LOCATE_BENCH_MODEL=zai/glm-5-turbo PI_LOCATE_BENCH_MODES=direct-read-grep,ast-structural,repo-search-hybrid,repo-discovery,subagent-search,unrestricted-suite node test/fixtures/hard-to-find-project/benchmark/run-locate-benchmark.mjs",
|
|
28
|
+
"bench:locate:analyze": "node test/fixtures/hard-to-find-project/benchmark/analyze-locate-benchmark.mjs",
|
|
29
|
+
"test:locate-benchmark-e2e": "PI_LOCATE_BENCH_E2E=1 PI_LOCATE_BENCH_MODEL=zai/glm-5-turbo bun test test/locate-benchmark-e2e.test.ts",
|
|
30
|
+
"test:tool-selection-e2e": "TOOL_SELECTION_E2E=1 TOOL_SELECTION_E2E_MODEL=zai/glm-5-turbo bun test --concurrent --max-concurrency=30 test/tool-selection-e2e.test.ts",
|
|
31
|
+
"test:e2e": "TOOL_SELECTION_E2E=1 TOOL_SELECTION_E2E_MODEL=zai/glm-5-turbo ASYNC_SUBAGENTS_E2E=1 ASYNC_SUBAGENTS_MODEL=zai/glm-5-turbo bun test --concurrent --max-concurrency=5 test/tool-selection-e2e.test.ts test/async-subagents/e2e.test.ts test/async-subagents/selection-e2e.test.ts test/todo-persistence-e2e.test.ts",
|
|
32
|
+
"typecheck:async-subagents": "bash scripts/typecheck-source.sh",
|
|
33
|
+
"check": "npm run smoke"
|
|
34
|
+
},
|
|
35
|
+
"dependencies": {
|
|
36
|
+
"jsonc-parser": "^3.3.1",
|
|
37
|
+
"vscode-jsonrpc": "^8.2.1",
|
|
38
|
+
"vscode-languageserver-protocol": "^3.17.5"
|
|
39
|
+
},
|
|
40
|
+
"peerDependencies": {
|
|
41
|
+
"@earendil-works/pi-ai": "*",
|
|
42
|
+
"@earendil-works/pi-coding-agent": "*",
|
|
43
|
+
"@earendil-works/pi-tui": "*",
|
|
44
|
+
"@mariozechner/pi-ai": "*",
|
|
45
|
+
"@mariozechner/pi-coding-agent": "*",
|
|
46
|
+
"@mariozechner/pi-tui": "*",
|
|
47
|
+
"typebox": "*"
|
|
48
|
+
},
|
|
49
|
+
"devDependencies": {
|
|
50
|
+
"@types/bun": "latest",
|
|
51
|
+
"typescript": "^5"
|
|
52
|
+
}
|
|
53
|
+
}
|
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
import { promises as fs } from "node:fs";
|
|
2
|
+
import { homedir } from "node:os";
|
|
3
|
+
import { dirname, join } from "node:path";
|
|
4
|
+
import { getAgentDir } from "@earendil-works/pi-coding-agent";
|
|
5
|
+
import { DEFAULT_PROJECT_ID, PROVIDER_ID } from "./constants";
|
|
6
|
+
import type { OpencodeAntigravityAccount, OpencodeAntigravityImportResult, OpencodeAntigravityStorage, PiAuthCredential, PiAuthData } from "./types";
|
|
7
|
+
|
|
8
|
+
export function splitRefresh(refresh: string): { refreshToken: string; projectId?: string; managedProjectId?: string } {
|
|
9
|
+
const [refreshToken = "", projectId = "", managedProjectId = ""] = refresh.split("|");
|
|
10
|
+
return {
|
|
11
|
+
refreshToken: refreshToken || refresh,
|
|
12
|
+
projectId: projectId || undefined,
|
|
13
|
+
managedProjectId: managedProjectId || undefined,
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export function joinRefresh(refreshToken: string, projectId?: string, managedProjectId?: string): string {
|
|
18
|
+
const base = `${refreshToken}|${projectId ?? ""}`;
|
|
19
|
+
return managedProjectId ? `${base}|${managedProjectId}` : base;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export function getEffectiveProjectId(refresh: string): string | undefined {
|
|
23
|
+
const { projectId, managedProjectId } = splitRefresh(refresh);
|
|
24
|
+
return projectId || managedProjectId;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export function encodeApiKey(access: string, projectId?: string): string {
|
|
28
|
+
return projectId ? `${access}|${projectId}` : access;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export function decodeApiKey(apiKey: string): { access: string; projectId?: string } {
|
|
32
|
+
const [access = apiKey, projectId = ""] = apiKey.split("|");
|
|
33
|
+
return { access, projectId: projectId || undefined };
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
function getDefaultOpencodeAccountsPath(): string {
|
|
37
|
+
const configDir = process.env.OPENCODE_CONFIG_DIR ?? join(process.env.XDG_CONFIG_HOME ?? join(homedir(), ".config"), "opencode");
|
|
38
|
+
return join(configDir, "antigravity-accounts.json");
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export function getPiAuthPath(): string {
|
|
42
|
+
return join(getAgentDir(), "auth.json");
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export async function readJsonFile<T>(path: string, fallback: T): Promise<T> {
|
|
46
|
+
try {
|
|
47
|
+
return JSON.parse(await fs.readFile(path, "utf8")) as T;
|
|
48
|
+
} catch (error) {
|
|
49
|
+
if ((error as NodeJS.ErrnoException).code === "ENOENT") return fallback;
|
|
50
|
+
throw error;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
export async function writeJsonFileSecure(path: string, data: unknown): Promise<void> {
|
|
55
|
+
await fs.mkdir(dirname(path), { recursive: true });
|
|
56
|
+
await fs.writeFile(path, `${JSON.stringify(data, null, 2)}\n`, { encoding: "utf8", mode: 0o600 });
|
|
57
|
+
await fs.chmod(path, 0o600).catch(() => undefined);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
export function getStoredAccounts(credential?: PiAuthCredential): OpencodeAntigravityAccount[] {
|
|
61
|
+
return Array.isArray(credential?.accounts) ? credential.accounts.filter((account) => account.enabled !== false && account.refreshToken) : [];
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
export function clampAccountIndex(index: unknown, accountCount: number): number {
|
|
65
|
+
if (!Number.isInteger(index) || accountCount <= 0) return 0;
|
|
66
|
+
return Math.max(0, Math.min(index as number, accountCount - 1));
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
export function getAccountProjectId(account: OpencodeAntigravityAccount): string {
|
|
70
|
+
return account.projectId || account.managedProjectId || DEFAULT_PROJECT_ID;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export function accountFromCredential(credential?: PiAuthCredential): OpencodeAntigravityAccount | undefined {
|
|
74
|
+
if (credential?.type !== "oauth" || !credential.refresh) return undefined;
|
|
75
|
+
const refresh = splitRefresh(credential.refresh);
|
|
76
|
+
if (!refresh.refreshToken) return undefined;
|
|
77
|
+
return {
|
|
78
|
+
email: credential.email,
|
|
79
|
+
refreshToken: refresh.refreshToken,
|
|
80
|
+
projectId: refresh.projectId || refresh.managedProjectId || DEFAULT_PROJECT_ID,
|
|
81
|
+
managedProjectId: refresh.managedProjectId,
|
|
82
|
+
enabled: true,
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
export function findMatchingAccountIndex(accounts: OpencodeAntigravityAccount[], account: OpencodeAntigravityAccount): number {
|
|
87
|
+
const email = account.email?.toLowerCase();
|
|
88
|
+
if (email) {
|
|
89
|
+
const byEmail = accounts.findIndex((existing) => existing.email?.toLowerCase() === email);
|
|
90
|
+
if (byEmail >= 0) return byEmail;
|
|
91
|
+
}
|
|
92
|
+
if (account.refreshToken) {
|
|
93
|
+
return accounts.findIndex((existing) => existing.refreshToken === account.refreshToken);
|
|
94
|
+
}
|
|
95
|
+
return -1;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
function selectOpencodeAccount(
|
|
99
|
+
storage: OpencodeAntigravityStorage,
|
|
100
|
+
options: { accountIndex?: number; email?: string },
|
|
101
|
+
): { account: OpencodeAntigravityAccount; index: number; count: number } | undefined {
|
|
102
|
+
const accounts = storage.accounts?.filter((account) => account && typeof account.refreshToken === "string" && account.refreshToken) ?? [];
|
|
103
|
+
if (accounts.length === 0) return undefined;
|
|
104
|
+
|
|
105
|
+
if (options.email) {
|
|
106
|
+
const email = options.email.toLowerCase();
|
|
107
|
+
const index = accounts.findIndex((account) => account.email?.toLowerCase() === email);
|
|
108
|
+
return index >= 0 ? { account: accounts[index], index, count: accounts.length } : undefined;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
if (typeof options.accountIndex === "number") {
|
|
112
|
+
const index = options.accountIndex;
|
|
113
|
+
return index >= 0 && index < accounts.length ? { account: accounts[index], index, count: accounts.length } : undefined;
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
const activeIndex = Number.isInteger(storage.activeIndex) ? Math.max(0, Math.min(storage.activeIndex ?? 0, accounts.length - 1)) : 0;
|
|
117
|
+
const activeAccount = accounts[activeIndex];
|
|
118
|
+
if (activeAccount?.enabled !== false) return { account: activeAccount, index: activeIndex, count: accounts.length };
|
|
119
|
+
|
|
120
|
+
const firstEnabledIndex = accounts.findIndex((account) => account.enabled !== false);
|
|
121
|
+
return firstEnabledIndex >= 0 ? { account: accounts[firstEnabledIndex], index: firstEnabledIndex, count: accounts.length } : undefined;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
export async function importOpencodeAntigravityAccount(options: {
|
|
125
|
+
sourcePath?: string;
|
|
126
|
+
authPath?: string;
|
|
127
|
+
overwrite?: boolean;
|
|
128
|
+
accountIndex?: number;
|
|
129
|
+
email?: string;
|
|
130
|
+
} = {}): Promise<OpencodeAntigravityImportResult> {
|
|
131
|
+
const sourcePath = options.sourcePath ?? getDefaultOpencodeAccountsPath();
|
|
132
|
+
const authPath = options.authPath ?? getPiAuthPath();
|
|
133
|
+
const storage = await readJsonFile<OpencodeAntigravityStorage | null>(sourcePath, null);
|
|
134
|
+
if (!storage || !Array.isArray(storage.accounts)) {
|
|
135
|
+
return { imported: false, reason: "source-missing-or-invalid", sourcePath, authPath };
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
const selected = selectOpencodeAccount(storage, options);
|
|
139
|
+
if (!selected) {
|
|
140
|
+
return { imported: false, reason: "matching-account-not-found", sourcePath, authPath, accountCount: storage.accounts.length };
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
const piAuth = await readJsonFile<PiAuthData>(authPath, {});
|
|
144
|
+
const existing = piAuth[PROVIDER_ID];
|
|
145
|
+
const refresh = joinRefresh(
|
|
146
|
+
selected.account.refreshToken!,
|
|
147
|
+
selected.account.projectId || selected.account.managedProjectId || DEFAULT_PROJECT_ID,
|
|
148
|
+
selected.account.managedProjectId,
|
|
149
|
+
);
|
|
150
|
+
|
|
151
|
+
if (existing?.type === "oauth" && existing.refresh === refresh) {
|
|
152
|
+
return {
|
|
153
|
+
imported: false,
|
|
154
|
+
reason: "already-imported",
|
|
155
|
+
sourcePath,
|
|
156
|
+
authPath,
|
|
157
|
+
email: selected.account.email,
|
|
158
|
+
accountIndex: selected.index,
|
|
159
|
+
accountCount: selected.count,
|
|
160
|
+
};
|
|
161
|
+
}
|
|
162
|
+
if (existing && !options.overwrite) {
|
|
163
|
+
return {
|
|
164
|
+
imported: false,
|
|
165
|
+
reason: "auth-exists-use-force",
|
|
166
|
+
sourcePath,
|
|
167
|
+
authPath,
|
|
168
|
+
email: selected.account.email,
|
|
169
|
+
accountIndex: selected.index,
|
|
170
|
+
accountCount: selected.count,
|
|
171
|
+
};
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
piAuth[PROVIDER_ID] = {
|
|
175
|
+
type: "oauth",
|
|
176
|
+
refresh,
|
|
177
|
+
access: "",
|
|
178
|
+
expires: 0,
|
|
179
|
+
email: selected.account.email,
|
|
180
|
+
accounts: storage.accounts.filter((account) => account.enabled !== false && account.refreshToken),
|
|
181
|
+
activeIndex: selected.index,
|
|
182
|
+
};
|
|
183
|
+
await writeJsonFileSecure(authPath, piAuth);
|
|
184
|
+
|
|
185
|
+
return {
|
|
186
|
+
imported: true,
|
|
187
|
+
sourcePath,
|
|
188
|
+
authPath,
|
|
189
|
+
email: selected.account.email,
|
|
190
|
+
accountIndex: selected.index,
|
|
191
|
+
accountCount: selected.count,
|
|
192
|
+
overwroteExisting: !!existing,
|
|
193
|
+
};
|
|
194
|
+
}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import type { AntigravityAddAccountResult, AntigravityStatusDetails, OpencodeAntigravityImportResult } from "./types";
|
|
2
|
+
|
|
3
|
+
function tokenizeArgs(args: string): string[] {
|
|
4
|
+
return args.match(/(?:[^\s"']+|"[^"]*"|'[^']*')+/g)?.map((part) => part.replace(/^("|')|("|')$/g, "")) ?? [];
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
export function parseImportCommandArgs(args: string): { sourcePath?: string; overwrite?: boolean; accountIndex?: number; email?: string } {
|
|
8
|
+
const tokens = tokenizeArgs(args);
|
|
9
|
+
const parsed: { sourcePath?: string; overwrite?: boolean; accountIndex?: number; email?: string } = {};
|
|
10
|
+
for (let i = 0; i < tokens.length; i += 1) {
|
|
11
|
+
const token = tokens[i];
|
|
12
|
+
if (token === "--force" || token === "-f") {
|
|
13
|
+
parsed.overwrite = true;
|
|
14
|
+
} else if (token === "--path" && tokens[i + 1]) {
|
|
15
|
+
parsed.sourcePath = tokens[++i];
|
|
16
|
+
} else if ((token === "--index" || token === "--account-index") && tokens[i + 1]) {
|
|
17
|
+
const index = Number(tokens[++i]);
|
|
18
|
+
if (Number.isInteger(index)) parsed.accountIndex = index;
|
|
19
|
+
} else if (token === "--email" && tokens[i + 1]) {
|
|
20
|
+
parsed.email = tokens[++i];
|
|
21
|
+
} else if (!token.startsWith("-") && !parsed.sourcePath) {
|
|
22
|
+
parsed.sourcePath = token;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
return parsed;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export function formatImportResult(result: OpencodeAntigravityImportResult): string {
|
|
29
|
+
const account = result.email ? `${result.email} ` : "";
|
|
30
|
+
const position = typeof result.accountIndex === "number" && result.accountCount ? `(account ${result.accountIndex}/${result.accountCount - 1}) ` : "";
|
|
31
|
+
if (result.imported) {
|
|
32
|
+
return `Imported ${account}${position}from ${result.sourcePath} into ${result.authPath}. Token will refresh on first use.${result.overwroteExisting ? " Existing Antigravity auth was overwritten." : ""}`;
|
|
33
|
+
}
|
|
34
|
+
if (result.reason === "auth-exists-use-force") {
|
|
35
|
+
return `Antigravity auth already exists in ${result.authPath}; run /antigravity-import --force to overwrite it with ${account}${position}from ${result.sourcePath}.`;
|
|
36
|
+
}
|
|
37
|
+
if (result.reason === "already-imported") {
|
|
38
|
+
return `Antigravity auth is already imported from ${result.sourcePath} (${account}${position.trim()}).`;
|
|
39
|
+
}
|
|
40
|
+
return `Could not import Antigravity auth from ${result.sourcePath}: ${result.reason ?? "unknown error"}.`;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export function parseAddAccountCommandArgs(args: string): { activate?: boolean; email?: string; authPath?: string } {
|
|
44
|
+
const tokens = tokenizeArgs(args);
|
|
45
|
+
const parsed: { activate?: boolean; email?: string; authPath?: string } = {};
|
|
46
|
+
for (let i = 0; i < tokens.length; i += 1) {
|
|
47
|
+
const token = tokens[i];
|
|
48
|
+
if (token === "--activate" || token === "-a") {
|
|
49
|
+
parsed.activate = true;
|
|
50
|
+
} else if (token === "--email" && tokens[i + 1]) {
|
|
51
|
+
parsed.email = tokens[++i];
|
|
52
|
+
} else if (token === "--auth-path" && tokens[i + 1]) {
|
|
53
|
+
parsed.authPath = tokens[++i];
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
return parsed;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
export function formatAddAccountResult(result: AntigravityAddAccountResult): string {
|
|
60
|
+
const account = result.email ?? "unknown account";
|
|
61
|
+
const action = result.updatedExisting ? "Updated" : "Added";
|
|
62
|
+
const active = result.activated ? " and activated" : "";
|
|
63
|
+
const project = result.projectId ? ` project ${result.projectId}` : "";
|
|
64
|
+
return `${action} Antigravity account ${account}${active} (${result.accountIndex + 1}/${result.accountCount})${project}. Saved to ${result.authPath}.`;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
function formatAccountPosition(index?: number, count?: number): string {
|
|
68
|
+
return typeof index === "number" && typeof count === "number" ? `${index + 1}/${count}` : "unknown";
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
export function formatAntigravityStatus(details: AntigravityStatusDetails): string {
|
|
72
|
+
const account = details.email ?? "unknown account";
|
|
73
|
+
const position = formatAccountPosition(details.accountIndex, details.accountCount);
|
|
74
|
+
const project = details.projectId ? ` project ${details.projectId}` : "";
|
|
75
|
+
if (details.kind === "switch") {
|
|
76
|
+
return `Antigravity switched to ${account} (${position})`;
|
|
77
|
+
}
|
|
78
|
+
const expiry = details.expires && details.expires > 0 ? ` token expires ${new Date(details.expires).toLocaleTimeString()}` : " token will refresh on next use";
|
|
79
|
+
return `Antigravity current account: ${account} (${position})${project};${expiry}.`;
|
|
80
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export const PROVIDER_ID = "antigravity";
|
|
2
|
+
export const API_ID = "antigravity-unified-gateway";
|
|
3
|
+
export const STATUS_KEY = "dcp:antigravity";
|
|
4
|
+
export const LEGACY_STATUS_KEY = "antigravity";
|
|
5
|
+
export const ALL_ACCOUNTS_EXHAUSTED_MARKER = "ANTIGRAVITY_ALL_ACCOUNTS_EXHAUSTED";
|
|
6
|
+
|
|
7
|
+
export const CLIENT_ID = process.env.PIX_ANTIGRAVITY_GOOGLE_CLIENT_ID ?? process.env.ANTIGRAVITY_GOOGLE_CLIENT_ID ?? "";
|
|
8
|
+
export const CLIENT_SECRET = process.env.PIX_ANTIGRAVITY_GOOGLE_CLIENT_SECRET ?? process.env.ANTIGRAVITY_GOOGLE_CLIENT_SECRET ?? "";
|
|
9
|
+
export const REDIRECT_URI = "http://localhost:51121/oauth-callback";
|
|
10
|
+
export const SCOPES = [
|
|
11
|
+
"https://www.googleapis.com/auth/cloud-platform",
|
|
12
|
+
"https://www.googleapis.com/auth/userinfo.email",
|
|
13
|
+
"https://www.googleapis.com/auth/userinfo.profile",
|
|
14
|
+
"https://www.googleapis.com/auth/cclog",
|
|
15
|
+
"https://www.googleapis.com/auth/experimentsandconfigs",
|
|
16
|
+
];
|
|
17
|
+
|
|
18
|
+
export const ENDPOINT_DAILY = "https://daily-cloudcode-pa.sandbox.googleapis.com";
|
|
19
|
+
export const ENDPOINT_PROD = "https://cloudcode-pa.googleapis.com";
|
|
20
|
+
export const ENDPOINT_AUTOPUSH = "https://autopush-cloudcode-pa.sandbox.googleapis.com";
|
|
21
|
+
export const STREAM_ENDPOINTS = [ENDPOINT_DAILY, ENDPOINT_AUTOPUSH, ENDPOINT_PROD];
|
|
22
|
+
export const LOAD_ENDPOINTS = [ENDPOINT_PROD, ENDPOINT_DAILY, ENDPOINT_AUTOPUSH];
|
|
23
|
+
export const DEFAULT_PROJECT_ID = "rising-fact-p41fc";
|
|
24
|
+
export const TOKEN_EXPIRY_SKEW_MS = 5 * 60 * 1000;
|
|
25
|
+
export const SKIP_THOUGHT_SIGNATURE = "skip_thought_signature_validator";
|
|
26
|
+
export const MIN_THOUGHT_SIGNATURE_LENGTH = 50;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { AntigravityModel, HeaderStyle } from "./types";
|
|
2
|
+
|
|
3
|
+
export function getAntigravityHeaders(style: "antigravity" | "gemini-cli" = "antigravity"): Record<string, string> {
|
|
4
|
+
if (style === "gemini-cli") {
|
|
5
|
+
return {
|
|
6
|
+
"User-Agent": "google-api-nodejs-client/9.15.1",
|
|
7
|
+
"X-Goog-Api-Client": "gl-node/22.17.0",
|
|
8
|
+
"Client-Metadata": "ideType=IDE_UNSPECIFIED,platform=PLATFORM_UNSPECIFIED,pluginType=GEMINI",
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
return {
|
|
12
|
+
"User-Agent": "antigravity/1.18.3 darwin/arm64",
|
|
13
|
+
"X-Goog-Api-Client": "google-cloud-sdk vscode_cloudshelleditor/0.1",
|
|
14
|
+
"Client-Metadata": `{"ideType":"ANTIGRAVITY","platform":"${process.platform === "win32" ? "WINDOWS" : "MACOS"}","pluginType":"GEMINI"}`,
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export function getModelHeaderStyle(model: AntigravityModel): HeaderStyle {
|
|
19
|
+
return model.antigravityHeaderStyle ?? "antigravity";
|
|
20
|
+
}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import type { ExtensionAPI } from "@earendil-works/pi-coding-agent";
|
|
2
|
+
import { decodeApiKey, getEffectiveProjectId, importOpencodeAntigravityAccount } from "./auth-store";
|
|
3
|
+
import { formatAddAccountResult, formatImportResult, parseAddAccountCommandArgs, parseImportCommandArgs } from "./commands";
|
|
4
|
+
import { API_ID, DEFAULT_PROJECT_ID, ENDPOINT_DAILY, PROVIDER_ID } from "./constants";
|
|
5
|
+
import { modelDefinitions } from "./models";
|
|
6
|
+
import { addAntigravityAccount, loginAntigravity, refreshAntigravityToken } from "./oauth";
|
|
7
|
+
import { emitAntigravityStatus, getCurrentAntigravityStatus, publishAntigravityAuthStartupSection, rememberAntigravityApi, rememberAntigravityUi } from "./status";
|
|
8
|
+
import { streamAntigravity } from "./stream";
|
|
9
|
+
|
|
10
|
+
export { importOpencodeAntigravityAccount } from "./auth-store";
|
|
11
|
+
export { addAntigravityAccount } from "./oauth";
|
|
12
|
+
export type { AntigravityAddAccountResult, OpencodeAntigravityImportResult } from "./types";
|
|
13
|
+
|
|
14
|
+
export default async function antigravityAuth(pi: ExtensionAPI): Promise<void> {
|
|
15
|
+
rememberAntigravityApi(pi);
|
|
16
|
+
await publishAntigravityAuthStartupSection();
|
|
17
|
+
|
|
18
|
+
if (typeof pi.on === "function") {
|
|
19
|
+
pi.on("turn_start", (_event, ctx) => {
|
|
20
|
+
rememberAntigravityUi(ctx.ui);
|
|
21
|
+
});
|
|
22
|
+
pi.on("before_provider_request", (_event, ctx) => {
|
|
23
|
+
rememberAntigravityUi(ctx.ui);
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
pi.registerCommand("antigravity-import", {
|
|
28
|
+
description: "Import Antigravity OAuth from opencode antigravity-accounts.json into Pi auth.json",
|
|
29
|
+
handler: async (args: string, ctx: any) => {
|
|
30
|
+
try {
|
|
31
|
+
const result = await importOpencodeAntigravityAccount(parseImportCommandArgs(args));
|
|
32
|
+
ctx.ui?.notify?.(formatImportResult(result), result.imported ? "info" : result.reason === "auth-exists-use-force" ? "warn" : "error");
|
|
33
|
+
} catch (error) {
|
|
34
|
+
ctx.ui?.notify?.(error instanceof Error ? error.message : String(error), "error");
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
pi.registerCommand("antigravity-add-account", {
|
|
40
|
+
description: "Add a new Google Antigravity OAuth account to the Pi rotation pool",
|
|
41
|
+
handler: async (args: string, ctx: any) => {
|
|
42
|
+
rememberAntigravityUi(ctx.ui);
|
|
43
|
+
let authUrl = "";
|
|
44
|
+
try {
|
|
45
|
+
const options = parseAddAccountCommandArgs(args);
|
|
46
|
+
const result = await addAntigravityAccount(
|
|
47
|
+
{
|
|
48
|
+
onAuth: ({ url }) => {
|
|
49
|
+
authUrl = url;
|
|
50
|
+
ctx.ui?.notify?.(`Open this Antigravity OAuth URL, then paste the callback URL:\n${url}`, "info");
|
|
51
|
+
},
|
|
52
|
+
onPrompt: async ({ message }) => {
|
|
53
|
+
if (typeof ctx.ui?.input !== "function") {
|
|
54
|
+
throw new Error(`Interactive input is required. Open this URL and rerun in an interactive Pi session: ${authUrl}`);
|
|
55
|
+
}
|
|
56
|
+
const value = await ctx.ui.input("Antigravity OAuth callback URL", message);
|
|
57
|
+
if (!value) throw new Error("Antigravity OAuth was cancelled.");
|
|
58
|
+
return value;
|
|
59
|
+
},
|
|
60
|
+
},
|
|
61
|
+
options,
|
|
62
|
+
);
|
|
63
|
+
ctx.ui?.notify?.(formatAddAccountResult(result), "info");
|
|
64
|
+
emitAntigravityStatus(await getCurrentAntigravityStatus());
|
|
65
|
+
} catch (error) {
|
|
66
|
+
ctx.ui?.notify?.(error instanceof Error ? error.message : String(error), "error");
|
|
67
|
+
}
|
|
68
|
+
},
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
pi.registerCommand("antigravity-account", {
|
|
72
|
+
description: "Show the current Antigravity account, project, and rotation position",
|
|
73
|
+
handler: async (_args: string, ctx: any) => {
|
|
74
|
+
rememberAntigravityUi(ctx.ui);
|
|
75
|
+
emitAntigravityStatus(await getCurrentAntigravityStatus());
|
|
76
|
+
},
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
pi.registerCommand("antigravity-status", {
|
|
80
|
+
description: "Alias for /antigravity-account",
|
|
81
|
+
handler: async (_args: string, ctx: any) => {
|
|
82
|
+
rememberAntigravityUi(ctx.ui);
|
|
83
|
+
emitAntigravityStatus(await getCurrentAntigravityStatus());
|
|
84
|
+
},
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
pi.registerProvider(PROVIDER_ID, {
|
|
88
|
+
name: "Google Antigravity OAuth",
|
|
89
|
+
baseUrl: ENDPOINT_DAILY,
|
|
90
|
+
api: API_ID,
|
|
91
|
+
models: modelDefinitions.map((model) => ({ ...model })) as any,
|
|
92
|
+
oauth: {
|
|
93
|
+
name: "Google Antigravity OAuth",
|
|
94
|
+
login: loginAntigravity,
|
|
95
|
+
refreshToken: refreshAntigravityToken,
|
|
96
|
+
getApiKey: (credentials) => credentials.access,
|
|
97
|
+
modifyModels: (models, credentials) => {
|
|
98
|
+
const accessProjectId = decodeApiKey(credentials.access).projectId;
|
|
99
|
+
return models.map((model) => ({ ...model, antigravityProjectId: accessProjectId || getEffectiveProjectId(credentials.refresh) || DEFAULT_PROJECT_ID }));
|
|
100
|
+
},
|
|
101
|
+
},
|
|
102
|
+
streamSimple: streamAntigravity as any,
|
|
103
|
+
});
|
|
104
|
+
}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
export const modelDefinitions = [
|
|
2
|
+
{
|
|
3
|
+
id: "antigravity-gemini-3.1-pro",
|
|
4
|
+
name: "Gemini 3.1 Pro (Antigravity)",
|
|
5
|
+
reasoning: true,
|
|
6
|
+
input: ["text", "image"],
|
|
7
|
+
cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
|
|
8
|
+
contextWindow: 1_048_576,
|
|
9
|
+
maxTokens: 65_535,
|
|
10
|
+
thinkingLevelMap: { minimal: null, low: "low", medium: null, high: null, xhigh: null },
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
id: "antigravity-gemini-3-flash",
|
|
14
|
+
name: "Gemini 3 Flash (Antigravity)",
|
|
15
|
+
reasoning: true,
|
|
16
|
+
input: ["text", "image"],
|
|
17
|
+
cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
|
|
18
|
+
contextWindow: 1_048_576,
|
|
19
|
+
maxTokens: 65_536,
|
|
20
|
+
thinkingLevelMap: { minimal: "minimal", low: "low", medium: "medium", high: "high", xhigh: null },
|
|
21
|
+
},
|
|
22
|
+
// These Gemini CLI-named models mirror opencode's provider surface, but opencode
|
|
23
|
+
// routes them Antigravity-first unless cli_first is enabled.
|
|
24
|
+
{
|
|
25
|
+
id: "gemini-2.5-flash",
|
|
26
|
+
name: "Gemini 2.5 Flash (Gemini CLI)",
|
|
27
|
+
reasoning: true,
|
|
28
|
+
input: ["text", "image"],
|
|
29
|
+
cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
|
|
30
|
+
contextWindow: 1_048_576,
|
|
31
|
+
maxTokens: 65_535,
|
|
32
|
+
antigravityHeaderStyle: "antigravity",
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
id: "gemini-3-flash-preview",
|
|
36
|
+
name: "Gemini 3 Flash Preview (Gemini CLI)",
|
|
37
|
+
reasoning: true,
|
|
38
|
+
input: ["text", "image"],
|
|
39
|
+
cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
|
|
40
|
+
contextWindow: 1_048_576,
|
|
41
|
+
maxTokens: 65_536,
|
|
42
|
+
thinkingLevelMap: { minimal: "minimal", low: "low", medium: "medium", high: "high", xhigh: null },
|
|
43
|
+
antigravityHeaderStyle: "antigravity",
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
id: "gemini-3.1-pro-preview",
|
|
47
|
+
name: "Gemini 3.1 Pro Preview (Gemini CLI)",
|
|
48
|
+
reasoning: true,
|
|
49
|
+
input: ["text", "image"],
|
|
50
|
+
cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
|
|
51
|
+
contextWindow: 1_048_576,
|
|
52
|
+
maxTokens: 65_535,
|
|
53
|
+
thinkingLevelMap: { minimal: null, low: "low", medium: null, high: null, xhigh: null },
|
|
54
|
+
antigravityHeaderStyle: "antigravity",
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
id: "gemini-3.1-pro-preview-customtools",
|
|
58
|
+
name: "Gemini 3.1 Pro Preview Custom Tools (Gemini CLI)",
|
|
59
|
+
reasoning: true,
|
|
60
|
+
input: ["text", "image"],
|
|
61
|
+
cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
|
|
62
|
+
contextWindow: 1_048_576,
|
|
63
|
+
maxTokens: 65_535,
|
|
64
|
+
thinkingLevelMap: { minimal: null, low: "low", medium: null, high: null, xhigh: null },
|
|
65
|
+
antigravityHeaderStyle: "antigravity",
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
id: "antigravity-claude-sonnet-4-6",
|
|
69
|
+
name: "Claude Sonnet 4.6 (Antigravity)",
|
|
70
|
+
reasoning: false,
|
|
71
|
+
input: ["text", "image"],
|
|
72
|
+
cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
|
|
73
|
+
contextWindow: 200_000,
|
|
74
|
+
maxTokens: 64_000,
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
id: "antigravity-claude-opus-4-6-thinking",
|
|
78
|
+
name: "Claude Opus 4.6 Thinking (Antigravity)",
|
|
79
|
+
reasoning: true,
|
|
80
|
+
input: ["text", "image"],
|
|
81
|
+
cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
|
|
82
|
+
contextWindow: 200_000,
|
|
83
|
+
maxTokens: 64_000,
|
|
84
|
+
thinkingLevelMap: { minimal: null, low: "low", medium: "medium", high: "high", xhigh: "high" },
|
|
85
|
+
},
|
|
86
|
+
];
|