@su-record/vibe 2.7.12 → 2.7.14
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/.env.example +37 -37
- package/CLAUDE.md +126 -126
- package/LICENSE +21 -21
- package/README.md +449 -580
- package/agents/architect-low.md +41 -41
- package/agents/architect-medium.md +59 -59
- package/agents/architect.md +80 -80
- package/agents/build-error-resolver.md +115 -115
- package/agents/compounder.md +261 -261
- package/agents/diagrammer.md +178 -178
- package/agents/docs/api-documenter.md +99 -99
- package/agents/docs/changelog-writer.md +93 -93
- package/agents/e2e-tester.md +294 -266
- package/agents/explorer-low.md +42 -42
- package/agents/explorer-medium.md +59 -59
- package/agents/explorer.md +48 -48
- package/agents/implementer-low.md +43 -43
- package/agents/implementer-medium.md +52 -52
- package/agents/implementer.md +54 -54
- package/agents/junior-mentor.md +141 -141
- package/agents/planning/requirements-analyst.md +84 -84
- package/agents/planning/ux-advisor.md +83 -83
- package/agents/qa/acceptance-tester.md +86 -86
- package/agents/qa/edge-case-finder.md +93 -93
- package/agents/refactor-cleaner.md +143 -143
- package/agents/research/best-practices-agent.md +199 -199
- package/agents/research/codebase-patterns-agent.md +157 -157
- package/agents/research/framework-docs-agent.md +188 -188
- package/agents/research/security-advisory-agent.md +213 -213
- package/agents/review/architecture-reviewer.md +107 -107
- package/agents/review/complexity-reviewer.md +116 -116
- package/agents/review/data-integrity-reviewer.md +88 -88
- package/agents/review/git-history-reviewer.md +103 -103
- package/agents/review/performance-reviewer.md +86 -86
- package/agents/review/python-reviewer.md +150 -150
- package/agents/review/rails-reviewer.md +139 -139
- package/agents/review/react-reviewer.md +144 -144
- package/agents/review/security-reviewer.md +80 -80
- package/agents/review/simplicity-reviewer.md +140 -140
- package/agents/review/test-coverage-reviewer.md +116 -116
- package/agents/review/typescript-reviewer.md +127 -127
- package/agents/searcher.md +54 -54
- package/agents/simplifier.md +120 -120
- package/agents/tester.md +49 -49
- package/agents/ui/ui-a11y-auditor.md +93 -93
- package/agents/ui/ui-antipattern-detector.md +94 -94
- package/agents/ui/ui-dataviz-advisor.md +69 -69
- package/agents/ui/ui-design-system-gen.md +57 -57
- package/agents/ui/ui-industry-analyzer.md +49 -49
- package/agents/ui/ui-layout-architect.md +65 -65
- package/agents/ui/ui-stack-implementer.md +68 -68
- package/agents/ui/ux-compliance-reviewer.md +81 -81
- package/agents/ui-previewer.md +258 -260
- package/commands/vibe.analyze.md +8 -0
- package/commands/vibe.review.md +10 -3
- package/commands/vibe.run.md +2078 -2022
- package/commands/vibe.spec.md +10 -10
- package/commands/vibe.spec.review.md +565 -558
- package/commands/vibe.utils.md +413 -413
- package/commands/vibe.verify.md +45 -0
- package/dist/cli/auth.d.ts.map +1 -1
- package/dist/cli/auth.js +1 -7
- package/dist/cli/auth.js.map +1 -1
- package/dist/cli/collaborator.js +52 -52
- package/dist/cli/commands/evolution.js +12 -12
- package/dist/cli/commands/info.d.ts.map +1 -1
- package/dist/cli/commands/info.js +55 -70
- package/dist/cli/commands/info.js.map +1 -1
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +6 -7
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/remove.js +14 -14
- package/dist/cli/commands/sentinel.js +27 -27
- package/dist/cli/commands/setup.js +1 -1
- package/dist/cli/commands/setup.js.map +1 -1
- package/dist/cli/commands/skills.js +5 -5
- package/dist/cli/commands/slack.js +10 -10
- package/dist/cli/commands/telegram.js +12 -12
- package/dist/cli/commands/update.d.ts.map +1 -1
- package/dist/cli/commands/update.js +3 -4
- package/dist/cli/commands/update.js.map +1 -1
- package/dist/cli/detect.js +32 -32
- package/dist/cli/index.js +51 -55
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/llm/claude-commands.js +16 -16
- package/dist/cli/llm/config.js +20 -20
- package/dist/cli/llm/config.js.map +1 -1
- package/dist/cli/llm/gemini-commands.d.ts +4 -6
- package/dist/cli/llm/gemini-commands.d.ts.map +1 -1
- package/dist/cli/llm/gemini-commands.js +52 -322
- package/dist/cli/llm/gemini-commands.js.map +1 -1
- package/dist/cli/llm/gpt-commands.js +21 -21
- package/dist/cli/llm/gpt-commands.js.map +1 -1
- package/dist/cli/llm/help.js +21 -21
- package/dist/cli/postinstall/constants.js +1 -1
- package/dist/cli/postinstall/constants.js.map +1 -1
- package/dist/cli/postinstall/cursor-agents.js +32 -32
- package/dist/cli/postinstall/cursor-rules.js +83 -83
- package/dist/cli/postinstall/cursor-skills.js +743 -743
- package/dist/cli/postinstall/inline-skills.js +1 -1
- package/dist/cli/postinstall/inline-skills.js.map +1 -1
- package/dist/cli/setup/Provisioner.js +42 -42
- package/dist/cli/types.d.ts +2 -18
- package/dist/cli/types.d.ts.map +1 -1
- package/dist/cli/utils.d.ts +0 -9
- package/dist/cli/utils.d.ts.map +1 -1
- package/dist/cli/utils.js +0 -28
- package/dist/cli/utils.js.map +1 -1
- package/dist/infra/lib/DeepInit.js +24 -24
- package/dist/infra/lib/IterationTracker.js +11 -11
- package/dist/infra/lib/PythonParser.js +108 -108
- package/dist/infra/lib/ReviewRace.js +96 -96
- package/dist/infra/lib/SkillFrontmatter.js +28 -28
- package/dist/infra/lib/SkillQualityGate.js +9 -9
- package/dist/infra/lib/SkillRepository.js +159 -159
- package/dist/infra/lib/UltraQA.js +99 -99
- package/dist/infra/lib/autonomy/AuditStore.js +41 -41
- package/dist/infra/lib/autonomy/ConfirmationStore.js +30 -30
- package/dist/infra/lib/autonomy/EventOutbox.js +38 -38
- package/dist/infra/lib/autonomy/PolicyEngine.js +18 -18
- package/dist/infra/lib/autonomy/SecuritySentinel.js +1 -1
- package/dist/infra/lib/autonomy/SuggestionStore.js +33 -33
- package/dist/infra/lib/config/GlobalConfigManager.d.ts +0 -2
- package/dist/infra/lib/config/GlobalConfigManager.d.ts.map +1 -1
- package/dist/infra/lib/config/GlobalConfigManager.js +0 -27
- package/dist/infra/lib/config/GlobalConfigManager.js.map +1 -1
- package/dist/infra/lib/embedding/VectorStore.js +22 -22
- package/dist/infra/lib/evolution/AgentAnalyzer.js +10 -10
- package/dist/infra/lib/evolution/DescriptionOptimizer.js +21 -21
- package/dist/infra/lib/evolution/GenerationRegistry.js +36 -36
- package/dist/infra/lib/evolution/InsightStore.js +90 -90
- package/dist/infra/lib/evolution/RollbackManager.js +5 -5
- package/dist/infra/lib/evolution/SkillBenchmark.js +23 -23
- package/dist/infra/lib/evolution/SkillEvalRunner.js +50 -50
- package/dist/infra/lib/evolution/SkillGapDetector.js +10 -10
- package/dist/infra/lib/evolution/UsageTracker.js +28 -28
- package/dist/infra/lib/gemini/auth.d.ts +4 -16
- package/dist/infra/lib/gemini/auth.d.ts.map +1 -1
- package/dist/infra/lib/gemini/auth.js +10 -405
- package/dist/infra/lib/gemini/auth.js.map +1 -1
- package/dist/infra/lib/gemini/capabilities.d.ts +4 -8
- package/dist/infra/lib/gemini/capabilities.d.ts.map +1 -1
- package/dist/infra/lib/gemini/capabilities.js +8 -166
- package/dist/infra/lib/gemini/capabilities.js.map +1 -1
- package/dist/infra/lib/gemini/chat.d.ts +4 -13
- package/dist/infra/lib/gemini/chat.d.ts.map +1 -1
- package/dist/infra/lib/gemini/chat.js +10 -323
- package/dist/infra/lib/gemini/chat.js.map +1 -1
- package/dist/infra/lib/gemini/completion.d.ts +5 -15
- package/dist/infra/lib/gemini/completion.d.ts.map +1 -1
- package/dist/infra/lib/gemini/completion.js +6 -97
- package/dist/infra/lib/gemini/completion.js.map +1 -1
- package/dist/infra/lib/gemini/constants.d.ts +2 -31
- package/dist/infra/lib/gemini/constants.d.ts.map +1 -1
- package/dist/infra/lib/gemini/constants.js +2 -77
- package/dist/infra/lib/gemini/constants.js.map +1 -1
- package/dist/infra/lib/gemini/index.d.ts +5 -8
- package/dist/infra/lib/gemini/index.d.ts.map +1 -1
- package/dist/infra/lib/gemini/index.js +4 -7
- package/dist/infra/lib/gemini/index.js.map +1 -1
- package/dist/infra/lib/gemini/models.d.ts +3 -4
- package/dist/infra/lib/gemini/models.d.ts.map +1 -1
- package/dist/infra/lib/gemini/models.js +8 -84
- package/dist/infra/lib/gemini/models.js.map +1 -1
- package/dist/infra/lib/gemini/orchestration.js +5 -5
- package/dist/infra/lib/gemini/types.d.ts +16 -44
- package/dist/infra/lib/gemini/types.d.ts.map +1 -1
- package/dist/infra/lib/gemini/types.js +1 -1
- package/dist/infra/lib/gpt/auth.d.ts +2 -5
- package/dist/infra/lib/gpt/auth.d.ts.map +1 -1
- package/dist/infra/lib/gpt/auth.js +8 -38
- package/dist/infra/lib/gpt/auth.js.map +1 -1
- package/dist/infra/lib/gpt/chat.d.ts +3 -3
- package/dist/infra/lib/gpt/chat.d.ts.map +1 -1
- package/dist/infra/lib/gpt/chat.js +37 -53
- package/dist/infra/lib/gpt/chat.js.map +1 -1
- package/dist/infra/lib/gpt/constants.d.ts +2 -5
- package/dist/infra/lib/gpt/constants.d.ts.map +1 -1
- package/dist/infra/lib/gpt/constants.js +4 -9
- package/dist/infra/lib/gpt/constants.js.map +1 -1
- package/dist/infra/lib/gpt/embedding.d.ts +1 -1
- package/dist/infra/lib/gpt/embedding.js +3 -3
- package/dist/infra/lib/gpt/embedding.js.map +1 -1
- package/dist/infra/lib/gpt/oauth.d.ts +6 -39
- package/dist/infra/lib/gpt/oauth.d.ts.map +1 -1
- package/dist/infra/lib/gpt/oauth.js +8 -340
- package/dist/infra/lib/gpt/oauth.js.map +1 -1
- package/dist/infra/lib/gpt/orchestration.js +5 -5
- package/dist/infra/lib/gpt/orchestration.js.map +1 -1
- package/dist/infra/lib/gpt/specializations.d.ts +2 -2
- package/dist/infra/lib/gpt/specializations.js +3 -3
- package/dist/infra/lib/gpt/specializations.js.map +1 -1
- package/dist/infra/lib/gpt/types.d.ts +1 -1
- package/dist/infra/lib/gpt/types.d.ts.map +1 -1
- package/dist/infra/lib/llm/auth/AuthProfileManager.d.ts +2 -2
- package/dist/infra/lib/llm/auth/AuthProfileManager.d.ts.map +1 -1
- package/dist/infra/lib/llm/auth/AuthProfileManager.js.map +1 -1
- package/dist/infra/lib/llm/auth/AuthProfileManager.test.js +1 -1
- package/dist/infra/lib/llm/auth/AuthProfileManager.test.js.map +1 -1
- package/dist/infra/lib/llm/auth/TokenRefresher.d.ts +1 -1
- package/dist/infra/lib/llm/auth/TokenRefresher.js +1 -1
- package/dist/infra/lib/llm/auth/index.d.ts +2 -12
- package/dist/infra/lib/llm/auth/index.d.ts.map +1 -1
- package/dist/infra/lib/llm/auth/index.js +5 -63
- package/dist/infra/lib/llm/auth/index.js.map +1 -1
- package/dist/infra/lib/llm/types.d.ts +1 -1
- package/dist/infra/lib/llm/types.d.ts.map +1 -1
- package/dist/infra/lib/memory/KnowledgeGraph.js +4 -4
- package/dist/infra/lib/memory/MemorySearch.js +57 -57
- package/dist/infra/lib/memory/MemoryStorage.js +181 -181
- package/dist/infra/lib/memory/ObservationStore.js +28 -28
- package/dist/infra/lib/memory/ReflectionStore.js +30 -30
- package/dist/infra/lib/memory/SessionRAGRetriever.js +7 -7
- package/dist/infra/lib/memory/SessionRAGStore.js +225 -225
- package/dist/infra/lib/memory/SessionSummarizer.js +9 -9
- package/dist/infra/orchestrator/AgentManager.js +12 -12
- package/dist/infra/orchestrator/AgentRegistry.js +65 -65
- package/dist/infra/orchestrator/MultiLlmResearch.js +8 -8
- package/dist/infra/orchestrator/SwarmOrchestrator.test.js +16 -16
- package/dist/infra/orchestrator/parallelResearch.js +24 -24
- package/dist/tools/convention/analyzeComplexity.test.js +115 -115
- package/dist/tools/convention/validateCodeQuality.test.js +104 -104
- package/dist/tools/memory/createMemoryTimeline.js +10 -10
- package/dist/tools/memory/getMemoryGraph.js +12 -12
- package/dist/tools/memory/getSessionContext.js +9 -9
- package/dist/tools/memory/linkMemories.js +14 -14
- package/dist/tools/memory/listMemories.js +4 -4
- package/dist/tools/memory/recallMemory.js +4 -4
- package/dist/tools/memory/saveMemory.js +4 -4
- package/dist/tools/memory/searchMemoriesAdvanced.js +23 -23
- package/dist/tools/semantic/analyzeDependencyGraph.js +12 -12
- package/dist/tools/semantic/astGrep.test.js +6 -6
- package/dist/tools/spec/prdParser.test.js +171 -171
- package/dist/tools/spec/specGenerator.js +169 -169
- package/dist/tools/spec/traceabilityMatrix.js +64 -64
- package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
- package/hooks/gemini-hooks.json +73 -73
- package/hooks/hooks.json +137 -137
- package/hooks/scripts/code-check.js +70 -70
- package/hooks/scripts/context-save.js +212 -212
- package/hooks/scripts/hud-status.js +291 -291
- package/hooks/scripts/keyword-detector.js +214 -214
- package/hooks/scripts/llm-orchestrate.js +475 -646
- package/hooks/scripts/post-edit.js +32 -32
- package/hooks/scripts/pre-tool-guard.js +125 -125
- package/hooks/scripts/prompt-dispatcher.js +185 -185
- package/hooks/scripts/sentinel-guard.js +104 -104
- package/hooks/scripts/session-start.js +106 -106
- package/hooks/scripts/stop-notify.js +209 -209
- package/hooks/scripts/utils.js +100 -100
- package/languages/csharp-unity.md +515 -515
- package/languages/gdscript-godot.md +470 -470
- package/languages/ruby-rails.md +489 -489
- package/languages/typescript-angular.md +433 -433
- package/languages/typescript-astro.md +416 -416
- package/languages/typescript-electron.md +406 -406
- package/languages/typescript-nestjs.md +524 -524
- package/languages/typescript-svelte.md +407 -407
- package/languages/typescript-tauri.md +365 -365
- package/package.json +121 -121
- package/skills/agents-md/SKILL.md +120 -120
- package/skills/arch-guard/SKILL.md +180 -180
- package/skills/brand-assets/SKILL.md +146 -146
- package/skills/capability-loop/SKILL.md +167 -167
- package/skills/characterization-test/SKILL.md +206 -206
- package/skills/commerce-patterns/SKILL.md +59 -59
- package/skills/commit-push-pr/SKILL.md +75 -75
- package/skills/context7-usage/SKILL.md +105 -105
- package/skills/core-capabilities/SKILL.md +48 -48
- package/skills/e2e-commerce/SKILL.md +57 -57
- package/skills/exec-plan/SKILL.md +147 -147
- package/skills/frontend-design/SKILL.md +73 -73
- package/skills/git-worktree/SKILL.md +72 -72
- package/skills/handoff/SKILL.md +109 -109
- package/skills/parallel-research/SKILL.md +87 -87
- package/skills/priority-todos/SKILL.md +63 -63
- package/skills/seo-checklist/SKILL.md +57 -57
- package/skills/techdebt/SKILL.md +122 -122
- package/skills/tool-fallback/SKILL.md +103 -103
- package/skills/typescript-advanced-types/SKILL.md +66 -65
- package/skills/ui-ux-pro-max/SKILL.md +206 -206
- package/skills/vercel-react-best-practices/SKILL.md +59 -59
- package/skills/video-production/SKILL.md +51 -51
- package/vibe/config.json +29 -29
- package/vibe/constitution.md +227 -227
- package/vibe/rules/principles/communication-guide.md +98 -98
- package/vibe/rules/principles/development-philosophy.md +52 -52
- package/vibe/rules/principles/quick-start.md +102 -102
- package/vibe/rules/quality/bdd-contract-testing.md +393 -393
- package/vibe/rules/quality/checklist.md +276 -276
- package/vibe/rules/quality/performance.md +236 -236
- package/vibe/rules/quality/testing-strategy.md +440 -440
- package/vibe/rules/standards/anti-patterns.md +541 -541
- package/vibe/rules/standards/code-structure.md +291 -291
- package/vibe/rules/standards/complexity-metrics.md +313 -313
- package/vibe/rules/standards/git-workflow.md +237 -237
- package/vibe/rules/standards/naming-conventions.md +198 -198
- package/vibe/rules/standards/security.md +305 -305
- package/vibe/rules/writing/document-style.md +74 -74
- package/vibe/setup.sh +31 -31
- package/vibe/templates/constitution-template.md +252 -252
- package/vibe/templates/contract-backend-template.md +526 -526
- package/vibe/templates/contract-frontend-template.md +599 -599
- package/vibe/templates/feature-template.md +96 -96
- package/vibe/templates/spec-template.md +221 -221
- package/vibe/ui-ux-data/charts.csv +26 -26
- package/vibe/ui-ux-data/colors.csv +97 -97
- package/vibe/ui-ux-data/icons.csv +101 -101
- package/vibe/ui-ux-data/landing.csv +31 -31
- package/vibe/ui-ux-data/products.csv +96 -96
- package/vibe/ui-ux-data/react-performance.csv +45 -45
- package/vibe/ui-ux-data/stacks/astro.csv +54 -54
- package/vibe/ui-ux-data/stacks/flutter.csv +53 -53
- package/vibe/ui-ux-data/stacks/html-tailwind.csv +56 -56
- package/vibe/ui-ux-data/stacks/jetpack-compose.csv +53 -53
- package/vibe/ui-ux-data/stacks/nextjs.csv +53 -53
- package/vibe/ui-ux-data/stacks/nuxt-ui.csv +51 -51
- package/vibe/ui-ux-data/stacks/nuxtjs.csv +59 -59
- package/vibe/ui-ux-data/stacks/react-native.csv +52 -52
- package/vibe/ui-ux-data/stacks/react.csv +54 -54
- package/vibe/ui-ux-data/stacks/shadcn.csv +61 -61
- package/vibe/ui-ux-data/stacks/svelte.csv +54 -54
- package/vibe/ui-ux-data/stacks/swiftui.csv +51 -51
- package/vibe/ui-ux-data/stacks/vue.csv +50 -50
- package/vibe/ui-ux-data/styles.csv +68 -68
- package/vibe/ui-ux-data/typography.csv +57 -57
- package/vibe/ui-ux-data/ui-reasoning.csv +101 -101
- package/vibe/ui-ux-data/ux-guidelines.csv +99 -99
- package/vibe/ui-ux-data/version.json +31 -31
- package/vibe/ui-ux-data/web-interface.csv +31 -31
- package/commands/vibe.voice.md +0 -79
|
@@ -1,24 +1,13 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Gemini
|
|
2
|
+
* Gemini 확장 기능
|
|
3
3
|
*
|
|
4
|
-
* - 웹 검색, UI 분석, 이미지 생성, 이미지
|
|
5
|
-
* -
|
|
4
|
+
* - 웹 검색, UI 분석, 이미지 생성, 이미지 분석
|
|
5
|
+
* - API Key → Google AI Studio
|
|
6
6
|
*/
|
|
7
7
|
import path from 'path';
|
|
8
8
|
import fs from 'fs';
|
|
9
|
-
import {
|
|
9
|
+
import { getApiKeyFromConfig } from './auth.js';
|
|
10
10
|
import { ask, getGeminiModels, DEFAULT_MODEL } from './chat.js';
|
|
11
|
-
import { ENDPOINT_FALLBACKS, API_VERSION, ANTIGRAVITY_HEADERS, } from './constants.js';
|
|
12
|
-
// =============================================
|
|
13
|
-
// v1internal 요청 래핑
|
|
14
|
-
// =============================================
|
|
15
|
-
function wrapRequest(body, projectId, modelId) {
|
|
16
|
-
return {
|
|
17
|
-
project: projectId,
|
|
18
|
-
model: modelId,
|
|
19
|
-
request: body,
|
|
20
|
-
};
|
|
21
|
-
}
|
|
22
11
|
// =============================================
|
|
23
12
|
// 웹 검색
|
|
24
13
|
// =============================================
|
|
@@ -63,7 +52,7 @@ export async function analyzeUI(prompt) {
|
|
|
63
52
|
// 이미지 생성
|
|
64
53
|
// =============================================
|
|
65
54
|
const IMAGE_MODELS = {
|
|
66
|
-
'nano-banana': 'gemini-
|
|
55
|
+
'nano-banana': 'gemini-3.1-flash-image-preview',
|
|
67
56
|
'nano-banana-pro': 'gemini-3-pro-image-preview',
|
|
68
57
|
};
|
|
69
58
|
/**
|
|
@@ -161,60 +150,6 @@ async function analyzeImageWithApiKey(apiKey, contents, options) {
|
|
|
161
150
|
}
|
|
162
151
|
return result.candidates[0].content?.parts?.[0]?.text || '';
|
|
163
152
|
}
|
|
164
|
-
async function analyzeImageWithOAuth(accessToken, projectId, contents, options) {
|
|
165
|
-
const modelInfo = getGeminiModels()[options.model] || getGeminiModels()[DEFAULT_MODEL];
|
|
166
|
-
const effectiveModelId = modelInfo.oauthId || modelInfo.id;
|
|
167
|
-
const innerRequest = {
|
|
168
|
-
contents,
|
|
169
|
-
generationConfig: {
|
|
170
|
-
maxOutputTokens: Math.min(options.maxTokens, modelInfo.maxTokens),
|
|
171
|
-
temperature: options.temperature,
|
|
172
|
-
},
|
|
173
|
-
};
|
|
174
|
-
if (options.systemPrompt) {
|
|
175
|
-
innerRequest.systemInstruction = { parts: [{ text: options.systemPrompt }] };
|
|
176
|
-
}
|
|
177
|
-
const requestBody = wrapRequest(innerRequest, projectId || '', effectiveModelId);
|
|
178
|
-
let lastError = null;
|
|
179
|
-
for (const endpoint of ENDPOINT_FALLBACKS) {
|
|
180
|
-
const url = `${endpoint}/${API_VERSION}:generateContent`;
|
|
181
|
-
const headers = {
|
|
182
|
-
'Authorization': `Bearer ${accessToken}`,
|
|
183
|
-
'Content-Type': 'application/json',
|
|
184
|
-
...ANTIGRAVITY_HEADERS,
|
|
185
|
-
};
|
|
186
|
-
try {
|
|
187
|
-
const response = await fetch(url, {
|
|
188
|
-
method: 'POST',
|
|
189
|
-
headers,
|
|
190
|
-
body: JSON.stringify(requestBody),
|
|
191
|
-
});
|
|
192
|
-
if (!response.ok) {
|
|
193
|
-
const errorText = await response.text();
|
|
194
|
-
if (response.status === 404) {
|
|
195
|
-
lastError = new Error(`API not found: ${errorText}`);
|
|
196
|
-
continue;
|
|
197
|
-
}
|
|
198
|
-
throw new Error(`Gemini API error (${response.status}): ${errorText}`);
|
|
199
|
-
}
|
|
200
|
-
const result = await response.json();
|
|
201
|
-
const responseData = result.response || result;
|
|
202
|
-
if (!responseData.candidates || responseData.candidates.length === 0) {
|
|
203
|
-
throw new Error('Gemini API response is empty.');
|
|
204
|
-
}
|
|
205
|
-
return responseData.candidates[0].content?.parts?.[0]?.text || '';
|
|
206
|
-
}
|
|
207
|
-
catch (error) {
|
|
208
|
-
lastError = error;
|
|
209
|
-
const msg = error.message || '';
|
|
210
|
-
if (error.name === 'TypeError' || msg.includes('not found')) {
|
|
211
|
-
continue;
|
|
212
|
-
}
|
|
213
|
-
throw error;
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
throw lastError || new Error('All endpoints failed');
|
|
217
|
-
}
|
|
218
153
|
/**
|
|
219
154
|
* Gemini 이미지 분석 (Multimodal)
|
|
220
155
|
*/
|
|
@@ -234,103 +169,10 @@ export async function analyzeImage(imagePath, prompt, options = {}) {
|
|
|
234
169
|
{ text: prompt },
|
|
235
170
|
],
|
|
236
171
|
}];
|
|
237
|
-
const authInfo = await getAuthInfo();
|
|
238
172
|
const apiKey = getApiKeyFromConfig();
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
return analyzeImageWithApiKey(authInfo.apiKey, contents, callOptions);
|
|
242
|
-
}
|
|
243
|
-
if (authInfo.accessToken) {
|
|
244
|
-
try {
|
|
245
|
-
return await analyzeImageWithOAuth(authInfo.accessToken, authInfo.projectId, contents, callOptions);
|
|
246
|
-
}
|
|
247
|
-
catch (error) {
|
|
248
|
-
const errorMsg = error.message;
|
|
249
|
-
if (apiKey && (errorMsg.includes('429') || errorMsg.includes('401') || errorMsg.includes('403') || errorMsg.includes('404'))) {
|
|
250
|
-
return analyzeImageWithApiKey(apiKey, contents, callOptions);
|
|
251
|
-
}
|
|
252
|
-
throw error;
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
throw new Error('Gemini credentials not found.');
|
|
256
|
-
}
|
|
257
|
-
// =============================================
|
|
258
|
-
// 오디오 전사 (STT)
|
|
259
|
-
// =============================================
|
|
260
|
-
function getAudioMimeType(filePath) {
|
|
261
|
-
const ext = path.extname(filePath).toLowerCase();
|
|
262
|
-
const mimeMap = {
|
|
263
|
-
'.wav': 'audio/wav',
|
|
264
|
-
'.mp3': 'audio/mp3',
|
|
265
|
-
'.mpeg': 'audio/mpeg',
|
|
266
|
-
'.aiff': 'audio/aiff',
|
|
267
|
-
'.aac': 'audio/aac',
|
|
268
|
-
'.ogg': 'audio/ogg',
|
|
269
|
-
'.flac': 'audio/flac',
|
|
270
|
-
'.webm': 'audio/webm',
|
|
271
|
-
};
|
|
272
|
-
return mimeMap[ext] || 'audio/wav';
|
|
273
|
-
}
|
|
274
|
-
/**
|
|
275
|
-
* Gemini 오디오 전사 (STT)
|
|
276
|
-
*/
|
|
277
|
-
export async function transcribeAudio(audioPath, options = {}) {
|
|
278
|
-
const { model = 'gemini-flash', maxTokens = 4096, temperature = 0.1, language, systemPrompt, } = options;
|
|
279
|
-
const absolutePath = path.resolve(audioPath);
|
|
280
|
-
if (!fs.existsSync(absolutePath)) {
|
|
281
|
-
throw new Error(`Audio file not found: ${absolutePath}`);
|
|
282
|
-
}
|
|
283
|
-
const audioData = fs.readFileSync(absolutePath);
|
|
284
|
-
const base64Data = audioData.toString('base64');
|
|
285
|
-
const mimeType = getAudioMimeType(absolutePath);
|
|
286
|
-
const stats = fs.statSync(absolutePath);
|
|
287
|
-
const WAV_HEADER_SIZE = 44;
|
|
288
|
-
const BYTES_PER_SECOND = 16000 * 2 * 1;
|
|
289
|
-
const estimatedDuration = Math.max(0, (stats.size - WAV_HEADER_SIZE) / BYTES_PER_SECOND);
|
|
290
|
-
let transcriptionPrompt = 'Transcribe this audio accurately. Output ONLY the transcribed text, nothing else.';
|
|
291
|
-
if (language) {
|
|
292
|
-
transcriptionPrompt += ` The audio is in ${language}. Transcribe in the original language.`;
|
|
293
|
-
}
|
|
294
|
-
const contents = [{
|
|
295
|
-
role: 'user',
|
|
296
|
-
parts: [
|
|
297
|
-
{ inlineData: { mimeType, data: base64Data } },
|
|
298
|
-
{ text: transcriptionPrompt },
|
|
299
|
-
],
|
|
300
|
-
}];
|
|
301
|
-
const authInfo = await getAuthInfo();
|
|
302
|
-
const apiKey = getApiKeyFromConfig();
|
|
303
|
-
const callOptions = {
|
|
304
|
-
model,
|
|
305
|
-
maxTokens,
|
|
306
|
-
temperature,
|
|
307
|
-
systemPrompt: systemPrompt || 'You are a precise audio transcription system. Output only the exact words spoken.',
|
|
308
|
-
};
|
|
309
|
-
let transcription;
|
|
310
|
-
if (authInfo.type === 'apikey' && authInfo.apiKey) {
|
|
311
|
-
transcription = await analyzeImageWithApiKey(authInfo.apiKey, contents, callOptions);
|
|
312
|
-
}
|
|
313
|
-
else if (authInfo.accessToken) {
|
|
314
|
-
try {
|
|
315
|
-
transcription = await analyzeImageWithOAuth(authInfo.accessToken, authInfo.projectId, contents, callOptions);
|
|
316
|
-
}
|
|
317
|
-
catch (error) {
|
|
318
|
-
const errorMsg = error.message;
|
|
319
|
-
if (apiKey && (errorMsg.includes('429') || errorMsg.includes('401') || errorMsg.includes('403') || errorMsg.includes('404'))) {
|
|
320
|
-
transcription = await analyzeImageWithApiKey(apiKey, contents, callOptions);
|
|
321
|
-
}
|
|
322
|
-
else {
|
|
323
|
-
throw error;
|
|
324
|
-
}
|
|
325
|
-
}
|
|
326
|
-
}
|
|
327
|
-
else {
|
|
328
|
-
throw new Error('Gemini credentials not found.');
|
|
173
|
+
if (!apiKey) {
|
|
174
|
+
throw new Error('Gemini API key required for image analysis.');
|
|
329
175
|
}
|
|
330
|
-
return {
|
|
331
|
-
transcription: transcription.trim(),
|
|
332
|
-
model,
|
|
333
|
-
duration: Math.round(estimatedDuration * 10) / 10,
|
|
334
|
-
};
|
|
176
|
+
return analyzeImageWithApiKey(apiKey, contents, { model, maxTokens, temperature, systemPrompt });
|
|
335
177
|
}
|
|
336
178
|
//# sourceMappingURL=capabilities.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"capabilities.js","sourceRoot":"","sources":["../../../../src/infra/lib/gemini/capabilities.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"capabilities.js","sourceRoot":"","sources":["../../../../src/infra/lib/gemini/capabilities.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,7 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Gemini
|
|
2
|
+
* Gemini Chat API (generateContent)
|
|
3
3
|
*
|
|
4
|
-
*
|
|
5
|
-
* - OAuth (antigravity/gemini-cli) → v1internal 엔드포인트 (Production 우선)
|
|
6
|
-
* - API Key → Google AI Studio
|
|
7
|
-
*
|
|
8
|
-
* SSE 스트리밍 지원
|
|
4
|
+
* API Key → Google AI Studio
|
|
9
5
|
*/
|
|
10
6
|
import type { GeminiModelInfo, ChatOptions, ChatResponse, StreamChunk } from './types.js';
|
|
11
7
|
export declare function getGeminiModels(): Record<string, GeminiModelInfo>;
|
|
@@ -13,16 +9,11 @@ export declare function getGeminiModels(): Record<string, GeminiModelInfo>;
|
|
|
13
9
|
export declare const GEMINI_MODELS: Record<string, GeminiModelInfo>;
|
|
14
10
|
export declare const DEFAULT_MODEL = "gemini-flash";
|
|
15
11
|
/**
|
|
16
|
-
* Gemini API 호출 (
|
|
17
|
-
*
|
|
18
|
-
* 라우팅:
|
|
19
|
-
* - antigravity/gemini-cli → v1internal (Production 우선)
|
|
20
|
-
* - apikey → Google AI Studio
|
|
12
|
+
* Gemini API 호출 (API Key)
|
|
21
13
|
*/
|
|
22
14
|
export declare function chat(options: ChatOptions): Promise<ChatResponse>;
|
|
23
15
|
/**
|
|
24
|
-
*
|
|
25
|
-
* OAuth Pro → OAuth Flash → API Key (단일 yield) fallback
|
|
16
|
+
* 스트리밍 Chat (API Key → 단일 yield)
|
|
26
17
|
*/
|
|
27
18
|
export declare function chatStream(options: ChatOptions): AsyncGenerator<StreamChunk>;
|
|
28
19
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chat.d.ts","sourceRoot":"","sources":["../../../../src/infra/lib/gemini/chat.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"chat.d.ts","sourceRoot":"","sources":["../../../../src/infra/lib/gemini/chat.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AASH,OAAO,KAAK,EACV,eAAe,EACf,WAAW,EACX,YAAY,EACZ,WAAW,EAEZ,MAAM,YAAY,CAAC;AAMpB,wBAAgB,eAAe,IAAI,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAkBjE;AAED,0CAA0C;AAC1C,eAAO,MAAM,aAAa,iCAAoB,CAAC;AAE/C,eAAO,MAAM,aAAa,iBAAiB,CAAC;AAgG5C;;GAEG;AACH,wBAAsB,IAAI,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,YAAY,CAAC,CAQtE;AAED;;GAEG;AACH,wBAAuB,UAAU,CAAC,OAAO,EAAE,WAAW,GAAG,cAAc,CAAC,WAAW,CAAC,CASnF;AAED;;GAEG;AACH,wBAAgB,kBAAkB,IAAI,eAAe,EAAE,CAEtD;AAED;;GAEG;AACH,wBAAgB,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,eAAe,GAAG,IAAI,CAEpE;AAED;;GAEG;AACH,wBAAsB,GAAG,CACvB,MAAM,EAAE,MAAM,EACd,OAAO,GAAE,IAAI,CAAC,WAAW,EAAE,UAAU,CAAM,GAC1C,OAAO,CAAC,MAAM,CAAC,CAMjB;AAED;;GAEG;AACH,wBAAsB,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAM9D"}
|
|
@@ -1,35 +1,27 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Gemini
|
|
2
|
+
* Gemini Chat API (generateContent)
|
|
3
3
|
*
|
|
4
|
-
*
|
|
5
|
-
* - OAuth (antigravity/gemini-cli) → v1internal 엔드포인트 (Production 우선)
|
|
6
|
-
* - API Key → Google AI Studio
|
|
7
|
-
*
|
|
8
|
-
* SSE 스트리밍 지원
|
|
4
|
+
* API Key → Google AI Studio
|
|
9
5
|
*/
|
|
10
6
|
import { sleep } from '../utils.js';
|
|
11
|
-
import { getAuthInfo
|
|
7
|
+
import { getAuthInfo } from './auth.js';
|
|
12
8
|
import { getModelOverride } from '../config/GlobalConfigManager.js';
|
|
13
|
-
import {
|
|
9
|
+
import { MAX_RETRIES, RETRY_BASE_DELAY_MS, } from './constants.js';
|
|
14
10
|
// =============================================
|
|
15
11
|
// 모델 레지스트리
|
|
16
12
|
// =============================================
|
|
17
13
|
export function getGeminiModels() {
|
|
18
|
-
const proId = getModelOverride('gemini') ?? process.env.GEMINI_MODEL ?? '';
|
|
19
|
-
const flashId = getModelOverride('geminiFlash') ?? process.env.GEMINI_FLASH_MODEL ?? '';
|
|
20
|
-
const oauthProId = getModelOverride('geminiOauth') ?? process.env.GEMINI_OAUTH_MODEL ?? proId.replace(/-preview$/, '');
|
|
21
|
-
const oauthFlashId = getModelOverride('geminiOauthFlash') ?? process.env.GEMINI_OAUTH_FLASH_MODEL ?? flashId.replace(/-preview$/, '');
|
|
14
|
+
const proId = getModelOverride('gemini') ?? process.env.GEMINI_MODEL ?? 'gemini-3.1-pro-preview';
|
|
15
|
+
const flashId = getModelOverride('geminiFlash') ?? process.env.GEMINI_FLASH_MODEL ?? 'gemini-3.1-flash-lite-preview';
|
|
22
16
|
return {
|
|
23
17
|
'gemini-pro': {
|
|
24
18
|
id: proId,
|
|
25
|
-
oauthId: oauthProId,
|
|
26
19
|
name: 'Gemini Pro',
|
|
27
20
|
description: 'Pro model for complex tasks',
|
|
28
21
|
maxTokens: 8192,
|
|
29
22
|
},
|
|
30
23
|
'gemini-flash': {
|
|
31
24
|
id: flashId,
|
|
32
|
-
oauthId: oauthFlashId,
|
|
33
25
|
name: 'Gemini Flash',
|
|
34
26
|
description: 'Flash model, fastest',
|
|
35
27
|
maxTokens: 8192,
|
|
@@ -40,16 +32,6 @@ export function getGeminiModels() {
|
|
|
40
32
|
export const GEMINI_MODELS = getGeminiModels();
|
|
41
33
|
export const DEFAULT_MODEL = 'gemini-flash';
|
|
42
34
|
// =============================================
|
|
43
|
-
// v1internal 요청 래핑
|
|
44
|
-
// =============================================
|
|
45
|
-
function wrapRequest(body, projectId, modelId) {
|
|
46
|
-
return {
|
|
47
|
-
project: projectId,
|
|
48
|
-
model: modelId,
|
|
49
|
-
request: body,
|
|
50
|
-
};
|
|
51
|
-
}
|
|
52
|
-
// =============================================
|
|
53
35
|
// API Key 방식 (Google AI Studio)
|
|
54
36
|
// =============================================
|
|
55
37
|
async function chatWithApiKey(apiKey, options) {
|
|
@@ -119,317 +101,22 @@ async function chatWithApiKey(apiKey, options) {
|
|
|
119
101
|
}
|
|
120
102
|
}
|
|
121
103
|
// =============================================
|
|
122
|
-
// OAuth 방식 (v1internal — Production 우선)
|
|
123
|
-
// =============================================
|
|
124
|
-
async function chatWithOAuth(accessToken, projectId, options) {
|
|
125
|
-
const { model = DEFAULT_MODEL, messages = [], maxTokens = 4096, temperature = 0.7, systemPrompt = '', webSearch = false, jsonMode = false, } = options;
|
|
126
|
-
const models = getGeminiModels();
|
|
127
|
-
const modelInfo = models[model] || models[DEFAULT_MODEL];
|
|
128
|
-
const effectiveModelId = modelInfo.oauthId || modelInfo.id;
|
|
129
|
-
const contents = messages.map(msg => ({
|
|
130
|
-
role: msg.role === 'assistant' || msg.role === 'model' ? 'model' : 'user',
|
|
131
|
-
parts: [{ text: msg.content }],
|
|
132
|
-
}));
|
|
133
|
-
const generationConfig = {
|
|
134
|
-
maxOutputTokens: Math.min(maxTokens, modelInfo.maxTokens),
|
|
135
|
-
temperature,
|
|
136
|
-
};
|
|
137
|
-
if (jsonMode) {
|
|
138
|
-
generationConfig.responseMimeType = 'application/json';
|
|
139
|
-
}
|
|
140
|
-
const innerRequest = {
|
|
141
|
-
contents,
|
|
142
|
-
generationConfig,
|
|
143
|
-
};
|
|
144
|
-
if (systemPrompt) {
|
|
145
|
-
innerRequest.systemInstruction = { parts: [{ text: systemPrompt }] };
|
|
146
|
-
}
|
|
147
|
-
if (webSearch) {
|
|
148
|
-
innerRequest.tools = [{ googleSearch: {} }];
|
|
149
|
-
}
|
|
150
|
-
const requestBody = wrapRequest(innerRequest, projectId || '', effectiveModelId);
|
|
151
|
-
// Claude thinking 모델용 헤더
|
|
152
|
-
const isClaudeModel = effectiveModelId.startsWith('claude-');
|
|
153
|
-
const isThinkingModel = effectiveModelId.includes('thinking');
|
|
154
|
-
let lastError = null;
|
|
155
|
-
for (const endpoint of ENDPOINT_FALLBACKS) {
|
|
156
|
-
const url = `${endpoint}/${API_VERSION}:generateContent`;
|
|
157
|
-
const headers = {
|
|
158
|
-
'Authorization': `Bearer ${accessToken}`,
|
|
159
|
-
'Content-Type': 'application/json',
|
|
160
|
-
...ANTIGRAVITY_HEADERS,
|
|
161
|
-
};
|
|
162
|
-
if (isClaudeModel && isThinkingModel) {
|
|
163
|
-
headers['anthropic-beta'] = 'interleaved-thinking-2025-05-14';
|
|
164
|
-
}
|
|
165
|
-
try {
|
|
166
|
-
const response = await fetch(url, {
|
|
167
|
-
method: 'POST',
|
|
168
|
-
headers,
|
|
169
|
-
body: JSON.stringify(requestBody),
|
|
170
|
-
});
|
|
171
|
-
if (!response.ok) {
|
|
172
|
-
const errorText = await response.text();
|
|
173
|
-
// 404 → 다음 엔드포인트 시도
|
|
174
|
-
if (response.status === 404) {
|
|
175
|
-
lastError = new Error(`API not found: ${errorText}`);
|
|
176
|
-
continue;
|
|
177
|
-
}
|
|
178
|
-
// 429 → 재시도
|
|
179
|
-
if (response.status === 429) {
|
|
180
|
-
const retryCount = options._retryCount || 0;
|
|
181
|
-
if (retryCount < MAX_RETRIES) {
|
|
182
|
-
await sleep(Math.pow(2, retryCount) * RETRY_BASE_DELAY_MS);
|
|
183
|
-
return chatWithOAuth(accessToken, projectId, {
|
|
184
|
-
...options,
|
|
185
|
-
_retryCount: retryCount + 1,
|
|
186
|
-
});
|
|
187
|
-
}
|
|
188
|
-
}
|
|
189
|
-
throw new Error(`Gemini API error (${response.status}): ${errorText}`);
|
|
190
|
-
}
|
|
191
|
-
const result = await response.json();
|
|
192
|
-
const responseData = result.response || result;
|
|
193
|
-
if (!responseData.candidates || responseData.candidates.length === 0) {
|
|
194
|
-
throw new Error('Gemini API response is empty.');
|
|
195
|
-
}
|
|
196
|
-
const candidate = responseData.candidates[0];
|
|
197
|
-
return {
|
|
198
|
-
content: candidate.content?.parts?.[0]?.text || '',
|
|
199
|
-
model: modelInfo.name,
|
|
200
|
-
finishReason: candidate.finishReason,
|
|
201
|
-
usage: responseData.usageMetadata,
|
|
202
|
-
};
|
|
203
|
-
}
|
|
204
|
-
catch (error) {
|
|
205
|
-
lastError = error;
|
|
206
|
-
const msg = error.message || '';
|
|
207
|
-
if (error.name === 'TypeError' || msg.includes('not found')) {
|
|
208
|
-
continue;
|
|
209
|
-
}
|
|
210
|
-
throw error;
|
|
211
|
-
}
|
|
212
|
-
}
|
|
213
|
-
throw lastError || new Error('All endpoints failed');
|
|
214
|
-
}
|
|
215
|
-
// =============================================
|
|
216
|
-
// SSE 스트리밍 (v1internal)
|
|
217
|
-
// =============================================
|
|
218
|
-
async function* streamWithOAuth(accessToken, projectId, options) {
|
|
219
|
-
const { model = DEFAULT_MODEL, messages = [], maxTokens = 4096, temperature = 0.7, systemPrompt = '', webSearch = false, jsonMode = false, } = options;
|
|
220
|
-
const models = getGeminiModels();
|
|
221
|
-
const modelInfo = models[model] || models[DEFAULT_MODEL];
|
|
222
|
-
const effectiveModelId = modelInfo.oauthId || modelInfo.id;
|
|
223
|
-
const contents = messages.map(msg => ({
|
|
224
|
-
role: msg.role === 'assistant' || msg.role === 'model' ? 'model' : 'user',
|
|
225
|
-
parts: [{ text: msg.content }],
|
|
226
|
-
}));
|
|
227
|
-
const generationConfig = {
|
|
228
|
-
maxOutputTokens: Math.min(maxTokens, modelInfo.maxTokens),
|
|
229
|
-
temperature,
|
|
230
|
-
};
|
|
231
|
-
if (jsonMode) {
|
|
232
|
-
generationConfig.responseMimeType = 'application/json';
|
|
233
|
-
}
|
|
234
|
-
const innerRequest = {
|
|
235
|
-
contents,
|
|
236
|
-
generationConfig,
|
|
237
|
-
};
|
|
238
|
-
if (systemPrompt) {
|
|
239
|
-
innerRequest.systemInstruction = { parts: [{ text: systemPrompt }] };
|
|
240
|
-
}
|
|
241
|
-
if (webSearch) {
|
|
242
|
-
innerRequest.tools = [{ googleSearch: {} }];
|
|
243
|
-
}
|
|
244
|
-
const requestBody = wrapRequest(innerRequest, projectId || '', effectiveModelId);
|
|
245
|
-
const isClaudeModel = effectiveModelId.startsWith('claude-');
|
|
246
|
-
const isThinkingModel = effectiveModelId.includes('thinking');
|
|
247
|
-
for (const endpoint of ENDPOINT_FALLBACKS) {
|
|
248
|
-
const url = `${endpoint}/${API_VERSION}:streamGenerateContent?alt=sse`;
|
|
249
|
-
const headers = {
|
|
250
|
-
'Authorization': `Bearer ${accessToken}`,
|
|
251
|
-
'Content-Type': 'application/json',
|
|
252
|
-
'Accept': 'text/event-stream',
|
|
253
|
-
...ANTIGRAVITY_HEADERS,
|
|
254
|
-
};
|
|
255
|
-
if (isClaudeModel && isThinkingModel) {
|
|
256
|
-
headers['anthropic-beta'] = 'interleaved-thinking-2025-05-14';
|
|
257
|
-
}
|
|
258
|
-
try {
|
|
259
|
-
const response = await fetch(url, {
|
|
260
|
-
method: 'POST',
|
|
261
|
-
headers,
|
|
262
|
-
body: JSON.stringify(requestBody),
|
|
263
|
-
});
|
|
264
|
-
if (!response.ok) {
|
|
265
|
-
const errorText = await response.text();
|
|
266
|
-
if (response.status === 404 || response.status === 429 || response.status === 503) {
|
|
267
|
-
continue;
|
|
268
|
-
}
|
|
269
|
-
throw new Error(`Gemini streaming error (${response.status}): ${errorText}`);
|
|
270
|
-
}
|
|
271
|
-
if (!response.body) {
|
|
272
|
-
throw new Error('No response body for streaming');
|
|
273
|
-
}
|
|
274
|
-
const reader = response.body.getReader();
|
|
275
|
-
const decoder = new TextDecoder();
|
|
276
|
-
let buffer = '';
|
|
277
|
-
while (true) {
|
|
278
|
-
const { done, value } = await reader.read();
|
|
279
|
-
if (done)
|
|
280
|
-
break;
|
|
281
|
-
buffer += decoder.decode(value, { stream: true });
|
|
282
|
-
const lines = buffer.split('\n');
|
|
283
|
-
buffer = lines.pop() || '';
|
|
284
|
-
for (const line of lines) {
|
|
285
|
-
if (!line.startsWith('data: '))
|
|
286
|
-
continue;
|
|
287
|
-
const jsonStr = line.slice(6).trim();
|
|
288
|
-
if (!jsonStr || jsonStr === '[DONE]')
|
|
289
|
-
continue;
|
|
290
|
-
try {
|
|
291
|
-
const chunk = JSON.parse(jsonStr);
|
|
292
|
-
const responseData = chunk.response || chunk;
|
|
293
|
-
const candidate = responseData.candidates?.[0];
|
|
294
|
-
const text = candidate?.content?.parts?.[0]?.text || '';
|
|
295
|
-
const finishReason = candidate?.finishReason;
|
|
296
|
-
yield {
|
|
297
|
-
content: text,
|
|
298
|
-
done: finishReason === 'STOP',
|
|
299
|
-
model: modelInfo.name,
|
|
300
|
-
finishReason,
|
|
301
|
-
usage: responseData.usageMetadata,
|
|
302
|
-
};
|
|
303
|
-
}
|
|
304
|
-
catch {
|
|
305
|
-
// 파싱 실패 무시
|
|
306
|
-
}
|
|
307
|
-
}
|
|
308
|
-
}
|
|
309
|
-
// 마지막 버퍼 처리
|
|
310
|
-
if (buffer.startsWith('data: ')) {
|
|
311
|
-
const jsonStr = buffer.slice(6).trim();
|
|
312
|
-
if (jsonStr && jsonStr !== '[DONE]') {
|
|
313
|
-
try {
|
|
314
|
-
const chunk = JSON.parse(jsonStr);
|
|
315
|
-
const responseData = chunk.response || chunk;
|
|
316
|
-
const candidate = responseData.candidates?.[0];
|
|
317
|
-
yield {
|
|
318
|
-
content: candidate?.content?.parts?.[0]?.text || '',
|
|
319
|
-
done: true,
|
|
320
|
-
model: modelInfo.name,
|
|
321
|
-
finishReason: candidate?.finishReason,
|
|
322
|
-
usage: responseData.usageMetadata,
|
|
323
|
-
};
|
|
324
|
-
}
|
|
325
|
-
catch {
|
|
326
|
-
// ignore
|
|
327
|
-
}
|
|
328
|
-
}
|
|
329
|
-
}
|
|
330
|
-
return;
|
|
331
|
-
}
|
|
332
|
-
catch (error) {
|
|
333
|
-
const msg = error.message || '';
|
|
334
|
-
if (error.name === 'TypeError' || msg.includes('not found')) {
|
|
335
|
-
continue;
|
|
336
|
-
}
|
|
337
|
-
throw error;
|
|
338
|
-
}
|
|
339
|
-
}
|
|
340
|
-
throw new Error('All streaming endpoints failed');
|
|
341
|
-
}
|
|
342
|
-
// =============================================
|
|
343
104
|
// Public API
|
|
344
105
|
// =============================================
|
|
345
106
|
/**
|
|
346
|
-
* Gemini API 호출 (
|
|
347
|
-
*
|
|
348
|
-
* 라우팅:
|
|
349
|
-
* - antigravity/gemini-cli → v1internal (Production 우선)
|
|
350
|
-
* - apikey → Google AI Studio
|
|
107
|
+
* Gemini API 호출 (API Key)
|
|
351
108
|
*/
|
|
352
109
|
export async function chat(options) {
|
|
353
110
|
const authInfo = await getAuthInfo();
|
|
354
|
-
|
|
355
|
-
// API Key 방식
|
|
356
|
-
if (authInfo.type === 'apikey' && authInfo.apiKey) {
|
|
111
|
+
if (authInfo.apiKey) {
|
|
357
112
|
return chatWithApiKey(authInfo.apiKey, options);
|
|
358
113
|
}
|
|
359
|
-
|
|
360
|
-
if (authInfo.accessToken) {
|
|
361
|
-
const requestedModel = options.model || DEFAULT_MODEL;
|
|
362
|
-
try {
|
|
363
|
-
return await chatWithOAuth(authInfo.accessToken, authInfo.projectId, options);
|
|
364
|
-
}
|
|
365
|
-
catch (error) {
|
|
366
|
-
const errorMsg = error.message;
|
|
367
|
-
const isRateLimit = errorMsg.includes('429') || errorMsg.includes('503') || errorMsg.includes('capacity');
|
|
368
|
-
const isNotFound = errorMsg.includes('404') || errorMsg.includes('not found');
|
|
369
|
-
const isAuthError = errorMsg.includes('401') || errorMsg.includes('403');
|
|
370
|
-
// 모델 fallback: pro → flash
|
|
371
|
-
if (isRateLimit && requestedModel !== 'gemini-flash') {
|
|
372
|
-
try {
|
|
373
|
-
return await chatWithOAuth(authInfo.accessToken, authInfo.projectId, { ...options, model: 'gemini-flash' });
|
|
374
|
-
}
|
|
375
|
-
catch (flashError) {
|
|
376
|
-
if (apiKey)
|
|
377
|
-
return chatWithApiKey(apiKey, options);
|
|
378
|
-
throw flashError;
|
|
379
|
-
}
|
|
380
|
-
}
|
|
381
|
-
// API Key fallback
|
|
382
|
-
if ((isRateLimit || isNotFound || isAuthError) && apiKey) {
|
|
383
|
-
return chatWithApiKey(apiKey, options);
|
|
384
|
-
}
|
|
385
|
-
throw error;
|
|
386
|
-
}
|
|
387
|
-
}
|
|
388
|
-
throw new Error('Gemini credentials not found.');
|
|
114
|
+
throw new Error('Gemini API key not found.');
|
|
389
115
|
}
|
|
390
116
|
/**
|
|
391
|
-
*
|
|
392
|
-
* OAuth Pro → OAuth Flash → API Key (단일 yield) fallback
|
|
117
|
+
* 스트리밍 Chat (API Key → 단일 yield)
|
|
393
118
|
*/
|
|
394
119
|
export async function* chatStream(options) {
|
|
395
|
-
const authInfo = await getAuthInfo();
|
|
396
|
-
const apiKey = getApiKeyFromConfig();
|
|
397
|
-
if (authInfo.accessToken) {
|
|
398
|
-
const requestedModel = options.model || DEFAULT_MODEL;
|
|
399
|
-
try {
|
|
400
|
-
yield* streamWithOAuth(authInfo.accessToken, authInfo.projectId, options);
|
|
401
|
-
return;
|
|
402
|
-
}
|
|
403
|
-
catch (error) {
|
|
404
|
-
const errorMsg = error.message;
|
|
405
|
-
const isRateLimit = errorMsg.includes('429') || errorMsg.includes('503');
|
|
406
|
-
const isAuthError = errorMsg.includes('401') || errorMsg.includes('403');
|
|
407
|
-
// Pro → Flash fallback (streaming)
|
|
408
|
-
if (isRateLimit && requestedModel !== 'gemini-flash') {
|
|
409
|
-
try {
|
|
410
|
-
yield* streamWithOAuth(authInfo.accessToken, authInfo.projectId, { ...options, model: 'gemini-flash' });
|
|
411
|
-
return;
|
|
412
|
-
}
|
|
413
|
-
catch {
|
|
414
|
-
// Flash도 실패 → API Key fallback
|
|
415
|
-
}
|
|
416
|
-
}
|
|
417
|
-
// API Key fallback (단일 yield)
|
|
418
|
-
if ((isRateLimit || isAuthError) && apiKey) {
|
|
419
|
-
const result = await chatWithApiKey(apiKey, options);
|
|
420
|
-
yield {
|
|
421
|
-
content: result.content,
|
|
422
|
-
done: true,
|
|
423
|
-
model: result.model,
|
|
424
|
-
finishReason: result.finishReason,
|
|
425
|
-
usage: result.usage,
|
|
426
|
-
};
|
|
427
|
-
return;
|
|
428
|
-
}
|
|
429
|
-
throw error;
|
|
430
|
-
}
|
|
431
|
-
}
|
|
432
|
-
// OAuth 없으면 API Key
|
|
433
120
|
const result = await chat(options);
|
|
434
121
|
yield {
|
|
435
122
|
content: result.content,
|