@su-record/vibe 2.9.3 → 2.9.5
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 +190 -190
- package/LICENSE +21 -21
- package/README.ko.md +170 -170
- package/README.md +219 -219
- 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 -294
- package/agents/event/event-comms.md +78 -78
- package/agents/event/event-content.md +68 -68
- package/agents/event/event-image.md +95 -95
- package/agents/event/event-ops.md +84 -84
- package/agents/event/event-scheduler.md +69 -69
- package/agents/event/event-speaker.md +86 -86
- 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/qa/qa-coordinator.md +131 -131
- 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/teams/debug-team.md +70 -70
- package/agents/teams/dev-team.md +88 -88
- package/agents/teams/docs-team.md +80 -80
- package/agents/teams/figma/figma-analyst.md +52 -52
- package/agents/teams/figma/figma-architect.md +112 -112
- package/agents/teams/figma/figma-auditor.md +82 -82
- package/agents/teams/figma/figma-builder.md +100 -100
- package/agents/teams/figma-team.md +85 -85
- package/agents/teams/fullstack-team.md +83 -83
- package/agents/teams/lite-team.md +69 -69
- package/agents/teams/migration-team.md +78 -78
- package/agents/teams/refactor-team.md +94 -94
- package/agents/teams/research-team.md +86 -86
- package/agents/teams/review-debate-team.md +125 -125
- package/agents/teams/security-team.md +81 -81
- package/agents/tester.md +49 -49
- package/agents/ui/ui-a11y-auditor.md +93 -93
- package/agents/ui/ui-antipattern-detector.md +102 -102
- 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 -258
- package/commands/vibe.analyze.md +533 -533
- package/commands/vibe.docs.md +32 -32
- package/commands/vibe.event.md +163 -163
- package/commands/vibe.figma.md +584 -584
- package/commands/vibe.harness.md +177 -177
- package/commands/vibe.review.md +624 -624
- package/commands/vibe.run.md +1925 -1925
- package/commands/vibe.scaffold.md +195 -195
- package/commands/vibe.spec.md +565 -565
- package/commands/vibe.trace.md +276 -276
- package/commands/vibe.utils.md +413 -413
- package/commands/vibe.verify.md +519 -519
- package/dist/cli/collaborator.js +52 -52
- package/dist/cli/commands/codex-proxy.d.ts +10 -0
- package/dist/cli/commands/codex-proxy.d.ts.map +1 -0
- package/dist/cli/commands/codex-proxy.js +221 -0
- package/dist/cli/commands/codex-proxy.js.map +1 -0
- package/dist/cli/commands/config.js +9 -9
- package/dist/cli/commands/evolution.js +12 -12
- package/dist/cli/commands/figma.js +20 -20
- package/dist/cli/commands/index.d.ts +1 -0
- package/dist/cli/commands/index.d.ts.map +1 -1
- package/dist/cli/commands/index.js +1 -0
- package/dist/cli/commands/index.js.map +1 -1
- package/dist/cli/commands/info.d.ts.map +1 -1
- package/dist/cli/commands/info.js +50 -53
- package/dist/cli/commands/info.js.map +1 -1
- package/dist/cli/commands/init.js +5 -5
- package/dist/cli/commands/remove.js +14 -14
- package/dist/cli/commands/sentinel.js +27 -27
- package/dist/cli/commands/skills.js +5 -5
- package/dist/cli/commands/slack.js +10 -10
- package/dist/cli/commands/stats.js +6 -6
- package/dist/cli/commands/telegram.js +12 -12
- package/dist/cli/detect.js +32 -32
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +67 -53
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/llm/claude-commands.js +16 -16
- package/dist/cli/llm/config.js +18 -18
- package/dist/cli/llm/gemini-commands.js +16 -16
- package/dist/cli/llm/gpt-commands.js +19 -19
- package/dist/cli/llm/help.js +21 -21
- package/dist/cli/postinstall/constants.d.ts.map +1 -1
- package/dist/cli/postinstall/constants.js +17 -13
- 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/fs-utils.d.ts +6 -0
- package/dist/cli/postinstall/fs-utils.d.ts.map +1 -1
- package/dist/cli/postinstall/fs-utils.js +15 -0
- package/dist/cli/postinstall/fs-utils.js.map +1 -1
- package/dist/cli/postinstall/main.d.ts.map +1 -1
- package/dist/cli/postinstall/main.js +8 -8
- package/dist/cli/postinstall/main.js.map +1 -1
- package/dist/cli/setup/Provisioner.js +42 -42
- package/dist/cli/types.d.ts +8 -0
- package/dist/cli/types.d.ts.map +1 -1
- package/dist/infra/lib/DeepInit.js +24 -24
- package/dist/infra/lib/IterationTracker.js +11 -11
- package/dist/infra/lib/OrchestrateWorkflow.js +1 -1
- 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.d.ts +3 -3
- 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/codex-proxy.d.ts +21 -0
- package/dist/infra/lib/codex-proxy.d.ts.map +1 -0
- package/dist/infra/lib/codex-proxy.js +510 -0
- package/dist/infra/lib/codex-proxy.js.map +1 -0
- 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/ParityTester.js +57 -57
- 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/orchestration.js +5 -5
- package/dist/infra/lib/gpt/orchestration.js +4 -4
- 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/lib/telemetry/SkillTelemetry.test.js +4 -4
- 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 +174 -174
- package/hooks/scripts/__tests__/keyword-detector.test.js +199 -199
- package/hooks/scripts/__tests__/pre-tool-guard.test.js +286 -286
- package/hooks/scripts/__tests__/sentinel-guard.test.js +210 -210
- package/hooks/scripts/auto-commit.js +97 -97
- package/hooks/scripts/auto-format.js +64 -64
- package/hooks/scripts/auto-test.js +81 -81
- package/hooks/scripts/code-check.js +268 -268
- package/hooks/scripts/codex-detect.js +46 -46
- package/hooks/scripts/codex-review-gate.js +80 -80
- package/hooks/scripts/command-log.js +32 -32
- package/hooks/scripts/context-save.js +353 -353
- package/hooks/scripts/evolution-engine.js +91 -91
- package/hooks/scripts/figma-extract.js +635 -635
- package/hooks/scripts/figma-guard.js +220 -220
- package/hooks/scripts/figma-refine.js +315 -315
- package/hooks/scripts/figma-to-scss.js +394 -394
- package/hooks/scripts/figma-validate.js +353 -353
- package/hooks/scripts/hud-status.js +321 -321
- package/hooks/scripts/keyword-detector.js +214 -214
- package/hooks/scripts/llm-orchestrate.js +572 -572
- package/hooks/scripts/post-edit.js +32 -32
- package/hooks/scripts/pr-test-gate.js +52 -52
- package/hooks/scripts/pre-tool-guard.js +214 -214
- package/hooks/scripts/prompt-dispatcher.js +185 -185
- package/hooks/scripts/sentinel-guard.js +131 -131
- package/hooks/scripts/session-start.js +177 -177
- package/hooks/scripts/skill-injector.js +83 -83
- package/hooks/scripts/stop-notify.js +209 -209
- package/hooks/scripts/utils.js +243 -243
- 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 +101 -101
- package/skills/agents-md/SKILL.md +121 -121
- package/skills/agents-md/rubrics/what-to-keep.md +49 -49
- package/skills/agents-md/templates/agents-md.md +36 -36
- package/skills/arch-guard/SKILL.md +181 -181
- package/skills/arch-guard/agents/detector.md +48 -48
- package/skills/arch-guard/agents/reporter.md +48 -48
- package/skills/arch-guard/agents/rule-generator.md +49 -49
- package/skills/arch-guard/agents/violation-checker.md +51 -51
- package/skills/arch-guard/frameworks/clean-architecture.md +108 -108
- package/skills/arch-guard/frameworks/solid.md +102 -102
- package/skills/arch-guard/scripts/check-boundaries.js +90 -90
- package/skills/arch-guard/templates/arch-rules.json +47 -47
- package/skills/arch-guard/templates/violation-report.md +53 -53
- package/skills/brand-assets/SKILL.md +147 -147
- package/skills/brand-assets/rubrics/asset-checklist.md +98 -98
- package/skills/brand-assets/templates/brand-guide.md +161 -161
- package/skills/capability-loop/SKILL.md +272 -272
- package/skills/capability-loop/agents/capability-designer.md +61 -61
- package/skills/capability-loop/agents/failure-analyst.md +55 -55
- package/skills/capability-loop/agents/implementer.md +50 -50
- package/skills/capability-loop/agents/tester.md +53 -53
- package/skills/capability-loop/templates/capability-spec.md +118 -118
- package/skills/capability-loop/templates/failure-analysis.md +118 -118
- package/skills/characterization-test/SKILL.md +207 -207
- package/skills/characterization-test/agents/behavior-capturer.md +50 -50
- package/skills/characterization-test/agents/coverage-checker.md +54 -54
- package/skills/characterization-test/agents/reporter.md +50 -50
- package/skills/characterization-test/agents/test-writer.md +49 -49
- package/skills/characterization-test/rubrics/coverage-criteria.md +53 -53
- package/skills/characterization-test/templates/test-template.ts +101 -101
- package/skills/chub-usage/SKILL.md +139 -139
- package/skills/claude-md-guide/SKILL.md +351 -351
- package/skills/claude-md-guide/rubrics/anti-patterns.md +88 -88
- package/skills/claude-md-guide/templates/claude-md.md +54 -54
- package/skills/commerce-patterns/SKILL.md +64 -64
- package/skills/commerce-patterns/rubrics/checkout-flow.md +48 -48
- package/skills/commerce-patterns/templates/product-schema.md +85 -85
- package/skills/commit-push-pr/SKILL.md +77 -77
- package/skills/commit-push-pr/agents/change-analyzer.md +55 -55
- package/skills/commit-push-pr/agents/message-writer.md +50 -50
- package/skills/commit-push-pr/agents/pr-writer.md +58 -58
- package/skills/commit-push-pr/agents/reviewer.md +52 -52
- package/skills/commit-push-pr/rubrics/commit-message.md +73 -73
- package/skills/commit-push-pr/templates/pr-body.md +63 -63
- package/skills/context7-usage/SKILL.md +106 -106
- package/skills/context7-usage/rubrics/when-to-use.md +50 -50
- package/skills/create-prd/SKILL.md +90 -90
- package/skills/create-prd/agents/edge-case-finder.md +48 -48
- package/skills/create-prd/agents/prioritizer.md +60 -60
- package/skills/create-prd/agents/requirements-writer.md +48 -48
- package/skills/create-prd/agents/researcher.md +55 -55
- package/skills/create-prd/agents/reviewer.md +54 -54
- package/skills/create-prd/frameworks/jobs-to-be-done.md +96 -96
- package/skills/create-prd/frameworks/rice-scoring.md +97 -97
- package/skills/create-prd/orchestrator.md +70 -70
- package/skills/create-prd/rubrics/completeness.md +58 -58
- package/skills/create-prd/templates/prd.md +139 -139
- package/skills/design-audit/SKILL.md +152 -152
- package/skills/design-audit/agents/a11y-auditor.md +43 -43
- package/skills/design-audit/agents/performance-auditor.md +46 -46
- package/skills/design-audit/agents/responsive-auditor.md +46 -46
- package/skills/design-audit/agents/scorer.md +47 -47
- package/skills/design-audit/agents/slop-detector.md +47 -47
- package/skills/design-audit/frameworks/core-web-vitals.md +107 -107
- package/skills/design-audit/frameworks/wcag-checklist.md +64 -64
- package/skills/design-audit/orchestrator.md +64 -64
- package/skills/design-audit/rubrics/ai-slop-patterns.md +83 -83
- package/skills/design-audit/rubrics/scoring.md +63 -63
- package/skills/design-audit/templates/report.md +88 -88
- package/skills/design-critique/SKILL.md +139 -139
- package/skills/design-critique/rubrics/ux-heuristics.md +143 -143
- package/skills/design-critique/templates/critique-report.md +86 -86
- package/skills/design-distill/SKILL.md +130 -130
- package/skills/design-distill/templates/design-system.md +132 -132
- package/skills/design-normalize/SKILL.md +133 -133
- package/skills/design-normalize/rubrics/token-naming.md +117 -117
- package/skills/design-normalize/templates/token-audit.md +89 -89
- package/skills/design-polish/SKILL.md +131 -131
- package/skills/design-polish/rubrics/polish-checklist.md +68 -68
- package/skills/design-polish/templates/polish-report.md +64 -64
- package/skills/design-teach/SKILL.md +182 -182
- package/skills/design-teach/rubrics/brand-personality.md +73 -73
- package/skills/design-teach/templates/design-context.json +36 -36
- package/skills/devlog/SKILL.md +143 -143
- package/skills/e2e-commerce/SKILL.md +62 -62
- package/skills/e2e-commerce/templates/test-scenarios.md +170 -170
- package/skills/event-comms/SKILL.md +172 -172
- package/skills/event-comms/templates/email-invite.md +99 -99
- package/skills/event-comms/templates/sns-post.md +133 -133
- package/skills/event-ops/SKILL.md +207 -207
- package/skills/event-ops/rubrics/contingency.md +85 -85
- package/skills/event-ops/templates/d-day-checklist.md +65 -65
- package/skills/event-planning/SKILL.md +144 -144
- package/skills/event-planning/rubrics/timeline.md +70 -70
- package/skills/event-planning/templates/event-plan.md +91 -91
- package/skills/exec-plan/SKILL.md +149 -149
- package/skills/exec-plan/agents/decomposer.md +47 -47
- package/skills/exec-plan/agents/dependency-mapper.md +44 -44
- package/skills/exec-plan/agents/estimator.md +43 -43
- package/skills/exec-plan/agents/validator.md +55 -55
- package/skills/exec-plan/orchestrator.md +70 -70
- package/skills/exec-plan/rubrics/complexity-scoring.md +75 -75
- package/skills/exec-plan/templates/plan.md +147 -147
- package/skills/git-worktree/SKILL.md +73 -73
- package/skills/git-worktree/rubrics/when-to-use.md +55 -55
- package/skills/handoff/SKILL.md +110 -110
- package/skills/handoff/agents/context-summarizer.md +51 -51
- package/skills/handoff/agents/document-writer.md +63 -63
- package/skills/handoff/agents/state-collector.md +53 -53
- package/skills/handoff/agents/verifier.md +48 -48
- package/skills/handoff/rubrics/completeness.md +62 -62
- package/skills/handoff/templates/handoff.md +107 -107
- package/skills/parallel-research/SKILL.md +89 -89
- package/skills/parallel-research/agents/best-practices.md +43 -43
- package/skills/parallel-research/agents/codebase-patterns.md +46 -46
- package/skills/parallel-research/agents/framework-docs.md +45 -45
- package/skills/parallel-research/agents/security-advisory.md +46 -46
- package/skills/parallel-research/agents/synthesizer.md +52 -52
- package/skills/parallel-research/experts/best-practices.md +50 -50
- package/skills/parallel-research/experts/codebase-patterns.md +70 -70
- package/skills/parallel-research/experts/framework-docs.md +65 -65
- package/skills/parallel-research/experts/security-advisory.md +69 -69
- package/skills/parallel-research/orchestrator.md +65 -65
- package/skills/parallel-research/templates/synthesis.md +101 -101
- package/skills/prioritization-frameworks/SKILL.md +87 -87
- package/skills/prioritization-frameworks/rubrics/frameworks.md +79 -79
- package/skills/prioritization-frameworks/templates/scoring-matrix.md +69 -69
- package/skills/priority-todos/SKILL.md +64 -64
- package/skills/priority-todos/rubrics/prioritization.md +70 -70
- package/skills/priority-todos/templates/todo-board.md +59 -59
- package/skills/seo-checklist/SKILL.md +58 -58
- package/skills/seo-checklist/frameworks/structured-data.md +153 -153
- package/skills/seo-checklist/rubrics/content-seo.md +42 -42
- package/skills/seo-checklist/rubrics/technical-seo.md +48 -48
- package/skills/techdebt/SKILL.md +124 -124
- package/skills/techdebt/agents/analyzer.md +50 -50
- package/skills/techdebt/agents/fixer.md +41 -41
- package/skills/techdebt/agents/reviewer.md +47 -47
- package/skills/techdebt/agents/scanner.md +44 -44
- package/skills/techdebt/orchestrator.md +70 -70
- package/skills/techdebt/rubrics/severity.md +51 -51
- package/skills/techdebt/scripts/scan.js +90 -90
- package/skills/techdebt/templates/report.md +86 -86
- package/skills/tool-fallback/SKILL.md +104 -104
- package/skills/tool-fallback/rubrics/fallback-chain.md +58 -58
- package/skills/typescript-advanced-types/SKILL.md +67 -67
- package/skills/typescript-advanced-types/rubrics/type-patterns.md +109 -109
- package/skills/ui-ux-pro-max/SKILL.md +236 -236
- package/skills/ui-ux-pro-max/reference/color-and-contrast.md +517 -517
- package/skills/ui-ux-pro-max/reference/interaction-design.md +544 -544
- package/skills/ui-ux-pro-max/reference/motion-design.md +591 -591
- package/skills/ui-ux-pro-max/reference/responsive-design.md +463 -463
- package/skills/ui-ux-pro-max/reference/spatial-design.md +390 -390
- package/skills/ui-ux-pro-max/reference/typography.md +455 -455
- package/skills/ui-ux-pro-max/reference/ux-writing.md +469 -469
- package/skills/ui-ux-pro-max/rubrics/interaction-states.md +83 -83
- package/skills/ui-ux-pro-max/rubrics/responsive-breakpoints.md +99 -99
- package/skills/user-personas/SKILL.md +75 -75
- package/skills/user-personas/rubrics/research-methods.md +56 -56
- package/skills/user-personas/templates/persona.md +89 -89
- package/skills/vercel-react-best-practices/SKILL.md +60 -60
- package/skills/vercel-react-best-practices/rubrics/performance.md +82 -82
- package/skills/vercel-react-best-practices/rubrics/server-components.md +86 -86
- package/skills/{vibe.docs → vibe-docs}/SKILL.md +171 -171
- package/skills/{vibe.docs → vibe-docs}/templates/architecture.md +80 -80
- package/skills/{vibe.docs → vibe-docs}/templates/readme.md +84 -84
- package/skills/{vibe.docs → vibe-docs}/templates/release-notes.md +74 -74
- package/skills/{vibe.figma → vibe-figma}/SKILL.md +363 -363
- package/skills/{vibe.figma → vibe-figma}/rubrics/extraction-checklist.md +51 -51
- package/skills/{vibe.figma → vibe-figma}/templates/component-index.md +126 -126
- package/skills/{vibe.figma → vibe-figma}/templates/component-spec.md +168 -168
- package/skills/{vibe.figma → vibe-figma}/templates/figma-handoff.md +100 -100
- package/skills/{vibe.figma → vibe-figma}/templates/remapped-tree.md +277 -277
- package/skills/{vibe.figma.convert → vibe-figma-convert}/SKILL.md +235 -235
- package/skills/{vibe.figma.convert → vibe-figma-convert}/rubrics/conversion-rules.md +141 -141
- package/skills/{vibe.figma.convert → vibe-figma-convert}/templates/component.md +140 -140
- package/skills/{vibe.figma.extract → vibe-figma-extract}/SKILL.md +219 -219
- package/skills/{vibe.figma.extract → vibe-figma-extract}/rubrics/image-rules.md +157 -157
- package/skills/{vibe.interview → vibe-interview}/SKILL.md +358 -358
- package/skills/{vibe.interview → vibe-interview}/checklists/api.md +101 -101
- package/skills/{vibe.interview → vibe-interview}/checklists/feature.md +88 -88
- package/skills/{vibe.interview → vibe-interview}/checklists/library.md +95 -95
- package/skills/{vibe.interview → vibe-interview}/checklists/mobile.md +89 -89
- package/skills/{vibe.interview → vibe-interview}/checklists/webapp.md +97 -97
- package/skills/{vibe.interview → vibe-interview}/checklists/website.md +99 -99
- package/skills/{vibe.plan → vibe-plan}/SKILL.md +254 -216
- package/skills/{vibe.spec → vibe-spec}/SKILL.md +1155 -1155
- package/skills/{vibe.spec.review → vibe-spec-review}/SKILL.md +726 -726
- package/skills/video-production/SKILL.md +52 -52
- package/skills/video-production/rubrics/quality-checklist.md +58 -58
- package/skills/video-production/templates/production-plan.md +104 -104
- 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/claudemd-template.md +74 -74
- package/vibe/templates/constitution-template.md +267 -267
- 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/plan-template.md +194 -194
- 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
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Codex Proxy — Anthropic Messages API → OpenAI Chat Completions API
|
|
3
|
+
* Claude Code에서 OpenAI 호환 모델을 백엔드로 사용하는 로컬 프록시
|
|
4
|
+
*/
|
|
5
|
+
import http from 'http';
|
|
6
|
+
import type { CodexProxyConfig } from '../../cli/types.js';
|
|
7
|
+
interface ProxyConfig {
|
|
8
|
+
port: number;
|
|
9
|
+
defaultModel?: string;
|
|
10
|
+
}
|
|
11
|
+
export interface AuthSource {
|
|
12
|
+
source: 'codex-cli' | 'apikey' | 'env';
|
|
13
|
+
email?: string;
|
|
14
|
+
}
|
|
15
|
+
export declare function getProxySettings(): CodexProxyConfig;
|
|
16
|
+
export declare function checkAuthSource(): AuthSource | null;
|
|
17
|
+
export declare function createProxyServer(config: ProxyConfig): http.Server;
|
|
18
|
+
export declare function launchSession(model?: string, claudeArgs?: string[]): void;
|
|
19
|
+
export declare function generateShellFunction(model?: string): string;
|
|
20
|
+
export {};
|
|
21
|
+
//# sourceMappingURL=codex-proxy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"codex-proxy.d.ts","sourceRoot":"","sources":["../../../src/infra/lib/codex-proxy.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,IAAI,MAAM,MAAM,CAAC;AAKxB,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AA+D3D,UAAU,WAAW;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,UAAU;IACzB,MAAM,EAAE,WAAW,GAAG,QAAQ,GAAG,KAAK,CAAC;IACvC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAoXD,wBAAgB,gBAAgB,IAAI,gBAAgB,CAGnD;AAID,wBAAgB,eAAe,IAAI,UAAU,GAAG,IAAI,CAUnD;AA4ED,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI,CAAC,MAAM,CAkBlE;AAID,wBAAgB,aAAa,CAC3B,KAAK,CAAC,EAAE,MAAM,EACd,UAAU,GAAE,MAAM,EAAO,GACxB,IAAI,CA+CN;AAUD,wBAAgB,qBAAqB,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAK5D"}
|
|
@@ -0,0 +1,510 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Codex Proxy — Anthropic Messages API → OpenAI Chat Completions API
|
|
3
|
+
* Claude Code에서 OpenAI 호환 모델을 백엔드로 사용하는 로컬 프록시
|
|
4
|
+
*/
|
|
5
|
+
import http from 'http';
|
|
6
|
+
import crypto from 'crypto';
|
|
7
|
+
import { spawn } from 'child_process';
|
|
8
|
+
import { getApiKeyFromConfig, findCodexCredentials, getAuthInfo } from './gpt/auth.js';
|
|
9
|
+
import { readGlobalConfig, getGeminiApiKey } from './config/GlobalConfigManager.js';
|
|
10
|
+
// ─── Constants ───────────────────────────────────────────────
|
|
11
|
+
const DEFAULT_TARGET_URL = 'https://api.openai.com';
|
|
12
|
+
// ─── System Prompt Extraction ────────────────────────────────
|
|
13
|
+
function extractSystemText(system) {
|
|
14
|
+
if (!system)
|
|
15
|
+
return '';
|
|
16
|
+
if (typeof system === 'string')
|
|
17
|
+
return system;
|
|
18
|
+
return system.filter(b => b.type === 'text' && b.text).map(b => b.text).join('\n');
|
|
19
|
+
}
|
|
20
|
+
function translateContentPart(block) {
|
|
21
|
+
if (block.type === 'text')
|
|
22
|
+
return { type: 'text', text: block.text || '' };
|
|
23
|
+
if (block.type === 'image' && block.source?.data) {
|
|
24
|
+
const media = block.source.media_type || 'image/png';
|
|
25
|
+
return { type: 'image_url', image_url: { url: `data:${media};base64,${block.source.data}` } };
|
|
26
|
+
}
|
|
27
|
+
return null;
|
|
28
|
+
}
|
|
29
|
+
// ─── Assistant Message Translation ───────────────────────────
|
|
30
|
+
function translateAssistantMsg(msg) {
|
|
31
|
+
if (typeof msg.content === 'string') {
|
|
32
|
+
return { role: 'assistant', content: msg.content };
|
|
33
|
+
}
|
|
34
|
+
const blocks = msg.content;
|
|
35
|
+
const text = blocks.filter(b => b.type === 'text').map(b => b.text || '').join('');
|
|
36
|
+
const tools = blocks.filter(b => b.type === 'tool_use');
|
|
37
|
+
const result = { role: 'assistant', content: text || null };
|
|
38
|
+
if (tools.length > 0) {
|
|
39
|
+
result.tool_calls = tools.map(t => ({
|
|
40
|
+
id: t.id || `call_${crypto.randomUUID()}`,
|
|
41
|
+
type: 'function',
|
|
42
|
+
function: { name: t.name || '', arguments: JSON.stringify(t.input || {}) },
|
|
43
|
+
}));
|
|
44
|
+
}
|
|
45
|
+
return result;
|
|
46
|
+
}
|
|
47
|
+
// ─── User Message Translation ────────────────────────────────
|
|
48
|
+
function translateUserMsg(msg, result) {
|
|
49
|
+
if (typeof msg.content === 'string') {
|
|
50
|
+
result.push({ role: 'user', content: msg.content });
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
const blocks = msg.content;
|
|
54
|
+
const toolResults = blocks.filter(b => b.type === 'tool_result');
|
|
55
|
+
const others = blocks.filter(b => b.type !== 'tool_result' && b.type !== 'thinking');
|
|
56
|
+
for (const tr of toolResults) {
|
|
57
|
+
const text = typeof tr.content === 'string'
|
|
58
|
+
? tr.content
|
|
59
|
+
: Array.isArray(tr.content)
|
|
60
|
+
? tr.content.filter(b => b.type === 'text').map(b => b.text || '').join('')
|
|
61
|
+
: '';
|
|
62
|
+
result.push({ role: 'tool', tool_call_id: tr.tool_use_id || '', content: text });
|
|
63
|
+
}
|
|
64
|
+
if (others.length === 0)
|
|
65
|
+
return;
|
|
66
|
+
const parts = others
|
|
67
|
+
.map(b => translateContentPart(b))
|
|
68
|
+
.filter((p) => p !== null);
|
|
69
|
+
if (parts.length === 1 && parts[0].type === 'text') {
|
|
70
|
+
result.push({ role: 'user', content: parts[0].text || '' });
|
|
71
|
+
}
|
|
72
|
+
else if (parts.length > 0) {
|
|
73
|
+
result.push({ role: 'user', content: parts });
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
// ─── Full Message Array Translation ──────────────────────────
|
|
77
|
+
function buildOMessages(system, messages) {
|
|
78
|
+
const result = [];
|
|
79
|
+
const sysText = extractSystemText(system);
|
|
80
|
+
if (sysText)
|
|
81
|
+
result.push({ role: 'system', content: sysText });
|
|
82
|
+
for (const msg of messages) {
|
|
83
|
+
if (msg.role === 'assistant') {
|
|
84
|
+
result.push(translateAssistantMsg(msg));
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
translateUserMsg(msg, result);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return result;
|
|
91
|
+
}
|
|
92
|
+
// ─── Tool Definition Translation ─────────────────────────────
|
|
93
|
+
function translateTools(tools) {
|
|
94
|
+
if (!tools?.length)
|
|
95
|
+
return undefined;
|
|
96
|
+
return tools.map(t => ({
|
|
97
|
+
type: 'function',
|
|
98
|
+
function: { name: t.name, description: t.description || '', parameters: t.input_schema },
|
|
99
|
+
}));
|
|
100
|
+
}
|
|
101
|
+
function translateToolChoice(choice) {
|
|
102
|
+
if (!choice)
|
|
103
|
+
return undefined;
|
|
104
|
+
if (choice.type === 'auto')
|
|
105
|
+
return 'auto';
|
|
106
|
+
if (choice.type === 'any')
|
|
107
|
+
return 'required';
|
|
108
|
+
if (choice.type === 'tool' && choice.name) {
|
|
109
|
+
return { type: 'function', function: { name: choice.name } };
|
|
110
|
+
}
|
|
111
|
+
return undefined;
|
|
112
|
+
}
|
|
113
|
+
// ─── Build OpenAI Request Body ───────────────────────────────
|
|
114
|
+
function buildORequest(req, defaultModel) {
|
|
115
|
+
const body = {
|
|
116
|
+
model: defaultModel || req.model,
|
|
117
|
+
messages: buildOMessages(req.system, req.messages),
|
|
118
|
+
max_tokens: req.max_tokens,
|
|
119
|
+
stream: req.stream ?? false,
|
|
120
|
+
};
|
|
121
|
+
if (req.temperature !== undefined)
|
|
122
|
+
body.temperature = req.temperature;
|
|
123
|
+
if (req.top_p !== undefined)
|
|
124
|
+
body.top_p = req.top_p;
|
|
125
|
+
if (req.stop_sequences)
|
|
126
|
+
body.stop = req.stop_sequences;
|
|
127
|
+
const tools = translateTools(req.tools);
|
|
128
|
+
if (tools)
|
|
129
|
+
body.tools = tools;
|
|
130
|
+
const tc = translateToolChoice(req.tool_choice);
|
|
131
|
+
if (tc !== undefined)
|
|
132
|
+
body.tool_choice = tc;
|
|
133
|
+
if (req.stream)
|
|
134
|
+
body.stream_options = { include_usage: true };
|
|
135
|
+
return body;
|
|
136
|
+
}
|
|
137
|
+
// ─── Finish Reason Mapping ───────────────────────────────────
|
|
138
|
+
function mapFinishReason(reason) {
|
|
139
|
+
if (reason === 'stop')
|
|
140
|
+
return 'end_turn';
|
|
141
|
+
if (reason === 'tool_calls')
|
|
142
|
+
return 'tool_use';
|
|
143
|
+
if (reason === 'length')
|
|
144
|
+
return 'max_tokens';
|
|
145
|
+
return 'end_turn';
|
|
146
|
+
}
|
|
147
|
+
// ─── Build Anthropic Response (Non-Streaming) ────────────────
|
|
148
|
+
function buildAResponse(oResp, model) {
|
|
149
|
+
const choices = oResp.choices || [];
|
|
150
|
+
const choice = choices[0] || {};
|
|
151
|
+
const msg = choice.message || {};
|
|
152
|
+
const usage = oResp.usage || {};
|
|
153
|
+
const content = [];
|
|
154
|
+
if (msg.content)
|
|
155
|
+
content.push({ type: 'text', text: msg.content });
|
|
156
|
+
const tcs = msg.tool_calls;
|
|
157
|
+
if (tcs) {
|
|
158
|
+
for (const tc of tcs) {
|
|
159
|
+
const fn = tc.function;
|
|
160
|
+
let input = {};
|
|
161
|
+
try {
|
|
162
|
+
input = JSON.parse(fn.arguments || '{}');
|
|
163
|
+
}
|
|
164
|
+
catch { /* use empty */ }
|
|
165
|
+
content.push({ type: 'tool_use', id: tc.id, name: fn.name, input });
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
return {
|
|
169
|
+
id: `msg_${crypto.randomUUID().replace(/-/g, '').slice(0, 24)}`,
|
|
170
|
+
type: 'message',
|
|
171
|
+
role: 'assistant',
|
|
172
|
+
content,
|
|
173
|
+
model,
|
|
174
|
+
stop_reason: mapFinishReason(choice.finish_reason),
|
|
175
|
+
stop_sequence: null,
|
|
176
|
+
usage: { input_tokens: usage.prompt_tokens || 0, output_tokens: usage.completion_tokens || 0 },
|
|
177
|
+
};
|
|
178
|
+
}
|
|
179
|
+
// ─── SSE Helpers ─────────────────────────────────────────────
|
|
180
|
+
function writeSSE(res, event, data) {
|
|
181
|
+
res.write(`event: ${event}\ndata: ${JSON.stringify(data)}\n\n`);
|
|
182
|
+
}
|
|
183
|
+
function newStreamState(model) {
|
|
184
|
+
return {
|
|
185
|
+
messageId: `msg_${crypto.randomUUID().replace(/-/g, '').slice(0, 24)}`,
|
|
186
|
+
model,
|
|
187
|
+
nextBlockIndex: 0,
|
|
188
|
+
textBlockIndex: -1,
|
|
189
|
+
textBlockOpen: false,
|
|
190
|
+
toolBlockMap: new Map(),
|
|
191
|
+
finishReason: null,
|
|
192
|
+
inputTokens: 0,
|
|
193
|
+
outputTokens: 0,
|
|
194
|
+
};
|
|
195
|
+
}
|
|
196
|
+
// ─── Stream Chunk Processing ─────────────────────────────────
|
|
197
|
+
function processChunk(res, s, chunk) {
|
|
198
|
+
if (chunk.usage) {
|
|
199
|
+
s.inputTokens = chunk.usage.prompt_tokens ?? s.inputTokens;
|
|
200
|
+
s.outputTokens = chunk.usage.completion_tokens ?? s.outputTokens;
|
|
201
|
+
}
|
|
202
|
+
const choice = chunk.choices?.[0];
|
|
203
|
+
if (!choice)
|
|
204
|
+
return;
|
|
205
|
+
if (choice.delta?.content) {
|
|
206
|
+
if (s.textBlockIndex < 0) {
|
|
207
|
+
s.textBlockIndex = s.nextBlockIndex++;
|
|
208
|
+
writeSSE(res, 'content_block_start', {
|
|
209
|
+
type: 'content_block_start', index: s.textBlockIndex,
|
|
210
|
+
content_block: { type: 'text', text: '' },
|
|
211
|
+
});
|
|
212
|
+
s.textBlockOpen = true;
|
|
213
|
+
}
|
|
214
|
+
writeSSE(res, 'content_block_delta', {
|
|
215
|
+
type: 'content_block_delta', index: s.textBlockIndex,
|
|
216
|
+
delta: { type: 'text_delta', text: choice.delta.content },
|
|
217
|
+
});
|
|
218
|
+
}
|
|
219
|
+
if (choice.delta?.tool_calls) {
|
|
220
|
+
for (const tc of choice.delta.tool_calls) {
|
|
221
|
+
processToolDelta(res, s, tc);
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
if (choice.finish_reason)
|
|
225
|
+
s.finishReason = choice.finish_reason;
|
|
226
|
+
}
|
|
227
|
+
function processToolDelta(res, s, tc) {
|
|
228
|
+
const idx = tc.index;
|
|
229
|
+
if (!s.toolBlockMap.has(idx)) {
|
|
230
|
+
if (s.textBlockOpen) {
|
|
231
|
+
writeSSE(res, 'content_block_stop', { type: 'content_block_stop', index: s.textBlockIndex });
|
|
232
|
+
s.textBlockOpen = false;
|
|
233
|
+
}
|
|
234
|
+
const blockIdx = s.nextBlockIndex++;
|
|
235
|
+
s.toolBlockMap.set(idx, blockIdx);
|
|
236
|
+
writeSSE(res, 'content_block_start', {
|
|
237
|
+
type: 'content_block_start', index: blockIdx,
|
|
238
|
+
content_block: {
|
|
239
|
+
type: 'tool_use',
|
|
240
|
+
id: tc.id || `call_${crypto.randomUUID()}`,
|
|
241
|
+
name: tc.function?.name || '',
|
|
242
|
+
input: {},
|
|
243
|
+
},
|
|
244
|
+
});
|
|
245
|
+
}
|
|
246
|
+
if (tc.function?.arguments) {
|
|
247
|
+
writeSSE(res, 'content_block_delta', {
|
|
248
|
+
type: 'content_block_delta', index: s.toolBlockMap.get(idx),
|
|
249
|
+
delta: { type: 'input_json_delta', partial_json: tc.function.arguments },
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
// ─── Close All Stream Blocks ─────────────────────────────────
|
|
254
|
+
function closeStream(res, s) {
|
|
255
|
+
if (s.textBlockOpen) {
|
|
256
|
+
writeSSE(res, 'content_block_stop', { type: 'content_block_stop', index: s.textBlockIndex });
|
|
257
|
+
}
|
|
258
|
+
for (const [, blockIdx] of s.toolBlockMap) {
|
|
259
|
+
writeSSE(res, 'content_block_stop', { type: 'content_block_stop', index: blockIdx });
|
|
260
|
+
}
|
|
261
|
+
writeSSE(res, 'message_delta', {
|
|
262
|
+
type: 'message_delta',
|
|
263
|
+
delta: { stop_reason: mapFinishReason(s.finishReason), stop_sequence: null },
|
|
264
|
+
usage: { output_tokens: s.outputTokens },
|
|
265
|
+
});
|
|
266
|
+
writeSSE(res, 'message_stop', { type: 'message_stop' });
|
|
267
|
+
}
|
|
268
|
+
// ─── Streaming Response Handler ──────────────────────────────
|
|
269
|
+
async function handleStream(fetchRes, httpRes, model) {
|
|
270
|
+
const s = newStreamState(model);
|
|
271
|
+
httpRes.writeHead(200, {
|
|
272
|
+
'Content-Type': 'text/event-stream',
|
|
273
|
+
'Cache-Control': 'no-cache',
|
|
274
|
+
'Connection': 'keep-alive',
|
|
275
|
+
});
|
|
276
|
+
writeSSE(httpRes, 'message_start', {
|
|
277
|
+
type: 'message_start',
|
|
278
|
+
message: {
|
|
279
|
+
id: s.messageId, type: 'message', role: 'assistant', content: [],
|
|
280
|
+
model: s.model, stop_reason: null, stop_sequence: null,
|
|
281
|
+
usage: { input_tokens: s.inputTokens, output_tokens: 0 },
|
|
282
|
+
},
|
|
283
|
+
});
|
|
284
|
+
const reader = fetchRes.body.getReader();
|
|
285
|
+
const decoder = new TextDecoder();
|
|
286
|
+
let buffer = '';
|
|
287
|
+
try {
|
|
288
|
+
let streamDone = false;
|
|
289
|
+
while (!streamDone) {
|
|
290
|
+
const read = await reader.read();
|
|
291
|
+
if (read.done)
|
|
292
|
+
break;
|
|
293
|
+
buffer += decoder.decode(read.value, { stream: true });
|
|
294
|
+
const lines = buffer.split('\n');
|
|
295
|
+
buffer = lines.pop() || '';
|
|
296
|
+
for (const line of lines) {
|
|
297
|
+
if (!line.startsWith('data: '))
|
|
298
|
+
continue;
|
|
299
|
+
const data = line.slice(6).trim();
|
|
300
|
+
if (data === '[DONE]') {
|
|
301
|
+
streamDone = true;
|
|
302
|
+
break;
|
|
303
|
+
}
|
|
304
|
+
try {
|
|
305
|
+
processChunk(httpRes, s, JSON.parse(data));
|
|
306
|
+
}
|
|
307
|
+
catch { /* skip malformed chunk */ }
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
catch (err) {
|
|
312
|
+
try {
|
|
313
|
+
writeSSE(httpRes, 'error', {
|
|
314
|
+
type: 'error', error: { type: 'api_error', message: err.message },
|
|
315
|
+
});
|
|
316
|
+
}
|
|
317
|
+
catch { /* response may be closed */ }
|
|
318
|
+
}
|
|
319
|
+
closeStream(httpRes, s);
|
|
320
|
+
httpRes.end();
|
|
321
|
+
}
|
|
322
|
+
// ─── HTTP Helpers ────────────────────────────────────────────
|
|
323
|
+
function collectBody(req) {
|
|
324
|
+
return new Promise((resolve, reject) => {
|
|
325
|
+
const chunks = [];
|
|
326
|
+
req.on('data', (c) => chunks.push(c));
|
|
327
|
+
req.on('end', () => resolve(Buffer.concat(chunks).toString()));
|
|
328
|
+
req.on('error', reject);
|
|
329
|
+
});
|
|
330
|
+
}
|
|
331
|
+
function sendError(res, status, message) {
|
|
332
|
+
res.writeHead(status, { 'Content-Type': 'application/json' });
|
|
333
|
+
res.end(JSON.stringify({ type: 'error', error: { type: 'api_error', message } }));
|
|
334
|
+
}
|
|
335
|
+
// ─── Config 읽기 ─────────────────────────────────────────────
|
|
336
|
+
export function getProxySettings() {
|
|
337
|
+
const config = readGlobalConfig();
|
|
338
|
+
return config.codexProxy || {};
|
|
339
|
+
}
|
|
340
|
+
// ─── 인증 소스 확인 (동기, 시작/상태 표시용) ────────────────
|
|
341
|
+
export function checkAuthSource() {
|
|
342
|
+
if (process.env.CODEX_PROXY_API_KEY)
|
|
343
|
+
return { source: 'env' };
|
|
344
|
+
const settings = getProxySettings();
|
|
345
|
+
if (settings.apiKey)
|
|
346
|
+
return { source: 'apikey' };
|
|
347
|
+
if (settings.provider === 'gemini' && getGeminiApiKey())
|
|
348
|
+
return { source: 'apikey' };
|
|
349
|
+
const codex = findCodexCredentials();
|
|
350
|
+
if (codex)
|
|
351
|
+
return { source: 'codex-cli' };
|
|
352
|
+
const apiKey = process.env.OPENAI_API_KEY || getApiKeyFromConfig();
|
|
353
|
+
if (apiKey)
|
|
354
|
+
return { source: 'apikey' };
|
|
355
|
+
return null;
|
|
356
|
+
}
|
|
357
|
+
// ─── 요청별 인증 해석 (비동기, 토큰 갱신 포함) ──────────────
|
|
358
|
+
async function resolveRequestAuth() {
|
|
359
|
+
const settings = getProxySettings();
|
|
360
|
+
const baseUrl = process.env.CODEX_PROXY_TARGET_URL || settings.targetUrl || DEFAULT_TARGET_URL;
|
|
361
|
+
// 1. 환경변수 최우선
|
|
362
|
+
const proxyKey = process.env.CODEX_PROXY_API_KEY;
|
|
363
|
+
if (proxyKey)
|
|
364
|
+
return { token: proxyKey, baseUrl };
|
|
365
|
+
// 2. Config의 커스텀 API key
|
|
366
|
+
if (settings.apiKey)
|
|
367
|
+
return { token: settings.apiKey, baseUrl };
|
|
368
|
+
// 3. Gemini provider → credentials.gemini.apiKey
|
|
369
|
+
if (settings.provider === 'gemini') {
|
|
370
|
+
const geminiKey = getGeminiApiKey();
|
|
371
|
+
if (geminiKey)
|
|
372
|
+
return { token: geminiKey, baseUrl };
|
|
373
|
+
}
|
|
374
|
+
// 4. GPT 인증 (codex-cli OAuth → apikey 순서, 토큰 자동 갱신)
|
|
375
|
+
const auth = await getAuthInfo();
|
|
376
|
+
const token = auth.accessToken || auth.apiKey;
|
|
377
|
+
if (token)
|
|
378
|
+
return { token, baseUrl };
|
|
379
|
+
throw new Error('인증 정보 없음. vibe codex --setup 실행 필요');
|
|
380
|
+
}
|
|
381
|
+
// ─── Messages Endpoint Handler ───────────────────────────────
|
|
382
|
+
async function handleMessages(req, res, config) {
|
|
383
|
+
const body = await collectBody(req);
|
|
384
|
+
let aReq;
|
|
385
|
+
try {
|
|
386
|
+
aReq = JSON.parse(body);
|
|
387
|
+
}
|
|
388
|
+
catch {
|
|
389
|
+
sendError(res, 400, 'Invalid JSON');
|
|
390
|
+
return;
|
|
391
|
+
}
|
|
392
|
+
// 요청마다 인증 해석 (Codex CLI 토큰 갱신 포함)
|
|
393
|
+
let auth;
|
|
394
|
+
try {
|
|
395
|
+
auth = await resolveRequestAuth();
|
|
396
|
+
}
|
|
397
|
+
catch (err) {
|
|
398
|
+
sendError(res, 401, err.message);
|
|
399
|
+
return;
|
|
400
|
+
}
|
|
401
|
+
const oBody = buildORequest(aReq, config.defaultModel);
|
|
402
|
+
const targetUrl = `${auth.baseUrl}/v1/chat/completions`;
|
|
403
|
+
const fetchRes = await fetch(targetUrl, {
|
|
404
|
+
method: 'POST',
|
|
405
|
+
headers: {
|
|
406
|
+
'Authorization': `Bearer ${auth.token}`,
|
|
407
|
+
'Content-Type': 'application/json',
|
|
408
|
+
},
|
|
409
|
+
body: JSON.stringify(oBody),
|
|
410
|
+
});
|
|
411
|
+
if (!fetchRes.ok) {
|
|
412
|
+
const errText = await fetchRes.text();
|
|
413
|
+
sendError(res, fetchRes.status, `OpenAI error: ${errText.slice(0, 500)}`);
|
|
414
|
+
return;
|
|
415
|
+
}
|
|
416
|
+
if (aReq.stream) {
|
|
417
|
+
await handleStream(fetchRes, res, aReq.model);
|
|
418
|
+
}
|
|
419
|
+
else {
|
|
420
|
+
const oResp = await fetchRes.json();
|
|
421
|
+
const aResp = buildAResponse(oResp, aReq.model);
|
|
422
|
+
res.writeHead(200, { 'Content-Type': 'application/json' });
|
|
423
|
+
res.end(JSON.stringify(aResp));
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
// ─── HTTP Server ─────────────────────────────────────────────
|
|
427
|
+
export function createProxyServer(config) {
|
|
428
|
+
return http.createServer(async (req, res) => {
|
|
429
|
+
res.setHeader('Access-Control-Allow-Origin', '*');
|
|
430
|
+
res.setHeader('Access-Control-Allow-Methods', 'POST, OPTIONS');
|
|
431
|
+
res.setHeader('Access-Control-Allow-Headers', '*');
|
|
432
|
+
if (req.method === 'OPTIONS') {
|
|
433
|
+
res.writeHead(204);
|
|
434
|
+
res.end();
|
|
435
|
+
return;
|
|
436
|
+
}
|
|
437
|
+
const url = req.url || '';
|
|
438
|
+
if (url === '/v1/messages' && req.method === 'POST') {
|
|
439
|
+
try {
|
|
440
|
+
await handleMessages(req, res, config);
|
|
441
|
+
}
|
|
442
|
+
catch (err) {
|
|
443
|
+
sendError(res, 500, err.message);
|
|
444
|
+
}
|
|
445
|
+
}
|
|
446
|
+
else if (url === '/health') {
|
|
447
|
+
res.writeHead(200, { 'Content-Type': 'application/json' });
|
|
448
|
+
res.end(JSON.stringify({ status: 'ok', port: config.port }));
|
|
449
|
+
}
|
|
450
|
+
else {
|
|
451
|
+
sendError(res, 404, `Unknown endpoint: ${url}`);
|
|
452
|
+
}
|
|
453
|
+
});
|
|
454
|
+
}
|
|
455
|
+
// ─── 세션 실행 (프록시 + Claude Code 원샷) ──────────────────
|
|
456
|
+
export function launchSession(model, claudeArgs = []) {
|
|
457
|
+
const authSource = checkAuthSource();
|
|
458
|
+
if (!authSource) {
|
|
459
|
+
console.error('인증 정보 없음.');
|
|
460
|
+
console.error(' ChatGPT Pro: npm i -g @openai/codex && codex login');
|
|
461
|
+
console.error(' Gemini: GEMINI_API_KEY 또는 CODEX_PROXY_API_KEY 설정');
|
|
462
|
+
console.error(' OpenAI: vibe gpt key <key> 또는 OPENAI_API_KEY 설정');
|
|
463
|
+
process.exit(1);
|
|
464
|
+
}
|
|
465
|
+
const settings = getProxySettings();
|
|
466
|
+
const defaultModel = model || process.env.CODEX_PROXY_MODEL || settings.model || 'gpt-4o';
|
|
467
|
+
const config = { port: 0, defaultModel };
|
|
468
|
+
const server = createProxyServer(config);
|
|
469
|
+
server.listen(0, '127.0.0.1', () => {
|
|
470
|
+
const addr = server.address();
|
|
471
|
+
const port = addr.port;
|
|
472
|
+
const authLabel = AUTH_SOURCE_LABELS[authSource.source];
|
|
473
|
+
console.log(`Codex Proxy :${port} | ${authLabel} | ${defaultModel}`);
|
|
474
|
+
const child = spawn('claude', claudeArgs, {
|
|
475
|
+
stdio: 'inherit',
|
|
476
|
+
env: {
|
|
477
|
+
...process.env,
|
|
478
|
+
ANTHROPIC_BASE_URL: `http://localhost:${port}`,
|
|
479
|
+
ANTHROPIC_API_KEY: 'codex-proxy',
|
|
480
|
+
ANTHROPIC_DEFAULT_SONNET_MODEL: defaultModel,
|
|
481
|
+
ANTHROPIC_DEFAULT_HAIKU_MODEL: defaultModel,
|
|
482
|
+
},
|
|
483
|
+
});
|
|
484
|
+
child.on('error', (err) => {
|
|
485
|
+
console.error(`claude 실행 실패: ${err.message}`);
|
|
486
|
+
console.error('Claude Code 설치: npm i -g @anthropic-ai/claude-code');
|
|
487
|
+
server.close();
|
|
488
|
+
process.exit(1);
|
|
489
|
+
});
|
|
490
|
+
child.on('exit', (code) => {
|
|
491
|
+
server.close();
|
|
492
|
+
process.exit(code ?? 0);
|
|
493
|
+
});
|
|
494
|
+
});
|
|
495
|
+
process.on('SIGINT', () => { server.close(); });
|
|
496
|
+
process.on('SIGTERM', () => { server.close(); process.exit(0); });
|
|
497
|
+
}
|
|
498
|
+
const AUTH_SOURCE_LABELS = {
|
|
499
|
+
'codex-cli': 'Codex CLI (ChatGPT Pro)',
|
|
500
|
+
'apikey': 'API Key',
|
|
501
|
+
'env': 'CODEX_PROXY_API_KEY',
|
|
502
|
+
};
|
|
503
|
+
// ─── 셸 함수 생성 ───────────────────────────────────────────
|
|
504
|
+
export function generateShellFunction(model) {
|
|
505
|
+
if (model) {
|
|
506
|
+
return `codex-cc() { CODEX_PROXY_MODEL="${model}" vibe codex "$@"; }`;
|
|
507
|
+
}
|
|
508
|
+
return `codex-cc() { vibe codex "$@"; }`;
|
|
509
|
+
}
|
|
510
|
+
//# sourceMappingURL=codex-proxy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"codex-proxy.js","sourceRoot":"","sources":["../../../src/infra/lib/codex-proxy.ts"],"names":[],"mappings":"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"}
|
|
@@ -13,22 +13,22 @@ export class VectorStore {
|
|
|
13
13
|
this.initializeTables();
|
|
14
14
|
}
|
|
15
15
|
initializeTables() {
|
|
16
|
-
this.db.exec(`
|
|
17
|
-
CREATE TABLE IF NOT EXISTS memory_vectors (
|
|
18
|
-
key TEXT PRIMARY KEY,
|
|
19
|
-
embedding BLOB NOT NULL,
|
|
20
|
-
dimension INTEGER NOT NULL,
|
|
21
|
-
updatedAt TEXT NOT NULL
|
|
22
|
-
);
|
|
23
|
-
|
|
24
|
-
CREATE TABLE IF NOT EXISTS session_vectors (
|
|
25
|
-
entityType TEXT NOT NULL,
|
|
26
|
-
entityId INTEGER NOT NULL,
|
|
27
|
-
embedding BLOB NOT NULL,
|
|
28
|
-
dimension INTEGER NOT NULL,
|
|
29
|
-
updatedAt TEXT NOT NULL,
|
|
30
|
-
PRIMARY KEY (entityType, entityId)
|
|
31
|
-
);
|
|
16
|
+
this.db.exec(`
|
|
17
|
+
CREATE TABLE IF NOT EXISTS memory_vectors (
|
|
18
|
+
key TEXT PRIMARY KEY,
|
|
19
|
+
embedding BLOB NOT NULL,
|
|
20
|
+
dimension INTEGER NOT NULL,
|
|
21
|
+
updatedAt TEXT NOT NULL
|
|
22
|
+
);
|
|
23
|
+
|
|
24
|
+
CREATE TABLE IF NOT EXISTS session_vectors (
|
|
25
|
+
entityType TEXT NOT NULL,
|
|
26
|
+
entityId INTEGER NOT NULL,
|
|
27
|
+
embedding BLOB NOT NULL,
|
|
28
|
+
dimension INTEGER NOT NULL,
|
|
29
|
+
updatedAt TEXT NOT NULL,
|
|
30
|
+
PRIMARY KEY (entityType, entityId)
|
|
31
|
+
);
|
|
32
32
|
`);
|
|
33
33
|
}
|
|
34
34
|
/**
|
|
@@ -37,9 +37,9 @@ export class VectorStore {
|
|
|
37
37
|
saveMemoryVector(key, embedding) {
|
|
38
38
|
const blob = serializeVector(embedding);
|
|
39
39
|
const now = new Date().toISOString();
|
|
40
|
-
this.db.prepare(`
|
|
41
|
-
INSERT OR REPLACE INTO memory_vectors (key, embedding, dimension, updatedAt)
|
|
42
|
-
VALUES (?, ?, ?, ?)
|
|
40
|
+
this.db.prepare(`
|
|
41
|
+
INSERT OR REPLACE INTO memory_vectors (key, embedding, dimension, updatedAt)
|
|
42
|
+
VALUES (?, ?, ?, ?)
|
|
43
43
|
`).run(key, blob, embedding.length, now);
|
|
44
44
|
}
|
|
45
45
|
/**
|
|
@@ -48,9 +48,9 @@ export class VectorStore {
|
|
|
48
48
|
saveSessionVector(entityType, entityId, embedding) {
|
|
49
49
|
const blob = serializeVector(embedding);
|
|
50
50
|
const now = new Date().toISOString();
|
|
51
|
-
this.db.prepare(`
|
|
52
|
-
INSERT OR REPLACE INTO session_vectors (entityType, entityId, embedding, dimension, updatedAt)
|
|
53
|
-
VALUES (?, ?, ?, ?, ?)
|
|
51
|
+
this.db.prepare(`
|
|
52
|
+
INSERT OR REPLACE INTO session_vectors (entityType, entityId, embedding, dimension, updatedAt)
|
|
53
|
+
VALUES (?, ?, ?, ?, ?)
|
|
54
54
|
`).run(entityType, entityId, blob, embedding.length, now);
|
|
55
55
|
}
|
|
56
56
|
/**
|
|
@@ -23,16 +23,16 @@ export class AgentAnalyzer {
|
|
|
23
23
|
if (!this.agentDb)
|
|
24
24
|
return result;
|
|
25
25
|
try {
|
|
26
|
-
const stats = this.agentDb.prepare(`
|
|
27
|
-
SELECT
|
|
28
|
-
agentName,
|
|
29
|
-
COUNT(*) as totalRuns,
|
|
30
|
-
SUM(CASE WHEN status = 'failed' THEN 1 ELSE 0 END) as failedRuns,
|
|
31
|
-
AVG(duration) as avgDuration
|
|
32
|
-
FROM agent_executions
|
|
33
|
-
WHERE createdAt > datetime('now', '-7 days')
|
|
34
|
-
GROUP BY agentName
|
|
35
|
-
HAVING totalRuns >= 5
|
|
26
|
+
const stats = this.agentDb.prepare(`
|
|
27
|
+
SELECT
|
|
28
|
+
agentName,
|
|
29
|
+
COUNT(*) as totalRuns,
|
|
30
|
+
SUM(CASE WHEN status = 'failed' THEN 1 ELSE 0 END) as failedRuns,
|
|
31
|
+
AVG(duration) as avgDuration
|
|
32
|
+
FROM agent_executions
|
|
33
|
+
WHERE createdAt > datetime('now', '-7 days')
|
|
34
|
+
GROUP BY agentName
|
|
35
|
+
HAVING totalRuns >= 5
|
|
36
36
|
`).all();
|
|
37
37
|
result.agentsAnalyzed = stats.length;
|
|
38
38
|
for (const stat of stats) {
|