The GitHub repository was renamed from oh-my-opencode to oh-my-openagent, but all documentation, scripts, and source code references still pointed to the old repository name. This caused confusion for users who saw 'oh-my-opencode' in docs but a different repo name on GitHub. Updated all references across: - README files (en, ko, ja, zh-cn, ru) - CONTRIBUTING.md - docs/ (installation, overview, configuration, etc.) - Source code (schema URLs, GitHub API calls, issue links) - Test snapshots The npm package name remains 'oh-my-opencode' (unchanged). Fixes: https://x.com/Dhruv14588676/status/2031216617762468348
143 lines
4.7 KiB
TypeScript
143 lines
4.7 KiB
TypeScript
import color from "picocolors"
|
|
import type { InstallArgs } from "./types"
|
|
import {
|
|
addPluginToOpenCodeConfig,
|
|
detectCurrentConfig,
|
|
getOpenCodeVersion,
|
|
isOpenCodeInstalled,
|
|
writeOmoConfig,
|
|
} from "./config-manager"
|
|
import {
|
|
SYMBOLS,
|
|
argsToConfig,
|
|
detectedToInitialValues,
|
|
formatConfigSummary,
|
|
printBox,
|
|
printError,
|
|
printHeader,
|
|
printInfo,
|
|
printStep,
|
|
printSuccess,
|
|
printWarning,
|
|
validateNonTuiArgs,
|
|
} from "./install-validators"
|
|
|
|
export async function runCliInstaller(args: InstallArgs, version: string): Promise<number> {
|
|
const validation = validateNonTuiArgs(args)
|
|
if (!validation.valid) {
|
|
printHeader(false)
|
|
printError("Validation failed:")
|
|
for (const err of validation.errors) {
|
|
console.log(` ${SYMBOLS.bullet} ${err}`)
|
|
}
|
|
console.log()
|
|
printInfo(
|
|
"Usage: bunx oh-my-opencode install --no-tui --claude=<no|yes|max20> --gemini=<no|yes> --copilot=<no|yes>",
|
|
)
|
|
console.log()
|
|
return 1
|
|
}
|
|
|
|
const detected = detectCurrentConfig()
|
|
const isUpdate = detected.isInstalled
|
|
|
|
printHeader(isUpdate)
|
|
|
|
const totalSteps = 4
|
|
let step = 1
|
|
|
|
printStep(step++, totalSteps, "Checking OpenCode installation...")
|
|
const installed = await isOpenCodeInstalled()
|
|
const openCodeVersion = await getOpenCodeVersion()
|
|
if (!installed) {
|
|
printWarning(
|
|
"OpenCode binary not found. Plugin will be configured, but you'll need to install OpenCode to use it.",
|
|
)
|
|
printInfo("Visit https://opencode.ai/docs for installation instructions")
|
|
} else {
|
|
printSuccess(`OpenCode ${openCodeVersion ?? ""} detected`)
|
|
}
|
|
|
|
if (isUpdate) {
|
|
const initial = detectedToInitialValues(detected)
|
|
printInfo(`Current config: Claude=${initial.claude}, Gemini=${initial.gemini}`)
|
|
}
|
|
|
|
const config = argsToConfig(args)
|
|
|
|
printStep(step++, totalSteps, "Adding oh-my-opencode plugin...")
|
|
const pluginResult = await addPluginToOpenCodeConfig(version)
|
|
if (!pluginResult.success) {
|
|
printError(`Failed: ${pluginResult.error}`)
|
|
return 1
|
|
}
|
|
printSuccess(
|
|
`Plugin ${isUpdate ? "verified" : "added"} ${SYMBOLS.arrow} ${color.dim(pluginResult.configPath)}`,
|
|
)
|
|
|
|
printStep(step++, totalSteps, "Writing oh-my-opencode configuration...")
|
|
const omoResult = writeOmoConfig(config)
|
|
if (!omoResult.success) {
|
|
printError(`Failed: ${omoResult.error}`)
|
|
return 1
|
|
}
|
|
printSuccess(`Config written ${SYMBOLS.arrow} ${color.dim(omoResult.configPath)}`)
|
|
|
|
printBox(formatConfigSummary(config), isUpdate ? "Updated Configuration" : "Installation Complete")
|
|
|
|
if (!config.hasClaude) {
|
|
console.log()
|
|
console.log(color.bgRed(color.white(color.bold(" CRITICAL WARNING "))))
|
|
console.log()
|
|
console.log(color.red(color.bold(" Sisyphus agent is STRONGLY optimized for Claude Opus 4.5.")))
|
|
console.log(color.red(" Without Claude, you may experience significantly degraded performance:"))
|
|
console.log(color.dim(" • Reduced orchestration quality"))
|
|
console.log(color.dim(" • Weaker tool selection and delegation"))
|
|
console.log(color.dim(" • Less reliable task completion"))
|
|
console.log()
|
|
console.log(color.yellow(" Consider subscribing to Claude Pro/Max for the best experience."))
|
|
console.log()
|
|
}
|
|
|
|
if (
|
|
!config.hasClaude &&
|
|
!config.hasOpenAI &&
|
|
!config.hasGemini &&
|
|
!config.hasCopilot &&
|
|
!config.hasOpencodeZen
|
|
) {
|
|
printWarning("No model providers configured. Using opencode/big-pickle as fallback.")
|
|
}
|
|
|
|
console.log(`${SYMBOLS.star} ${color.bold(color.green(isUpdate ? "Configuration updated!" : "Installation complete!"))}`)
|
|
console.log(` Run ${color.cyan("opencode")} to start!`)
|
|
console.log()
|
|
|
|
printBox(
|
|
`${color.bold("Pro Tip:")} Include ${color.cyan("ultrawork")} (or ${color.cyan("ulw")}) in your prompt.\n` +
|
|
`All features work like magic—parallel agents, background tasks,\n` +
|
|
`deep exploration, and relentless execution until completion.`,
|
|
"The Magic Word",
|
|
)
|
|
|
|
console.log(`${SYMBOLS.star} ${color.yellow("If you found this helpful, consider starring the repo!")}`)
|
|
console.log(
|
|
` ${color.dim("gh api --silent --method PUT /user/starred/code-yeongyu/oh-my-openagent >/dev/null 2>&1 || true")}`,
|
|
)
|
|
console.log()
|
|
console.log(color.dim("oMoMoMoMo... Enjoy!"))
|
|
console.log()
|
|
|
|
if ((config.hasClaude || config.hasGemini || config.hasCopilot) && !args.skipAuth) {
|
|
printBox(
|
|
`Run ${color.cyan("opencode auth login")} and select your provider:\n` +
|
|
(config.hasClaude ? ` ${SYMBOLS.bullet} Anthropic ${color.gray("→ Claude Pro/Max")}\n` : "") +
|
|
(config.hasGemini ? ` ${SYMBOLS.bullet} Google ${color.gray("→ Gemini")}\n` : "") +
|
|
(config.hasCopilot ? ` ${SYMBOLS.bullet} GitHub ${color.gray("→ Copilot")}` : ""),
|
|
"Authenticate Your Providers",
|
|
)
|
|
}
|
|
|
|
return 0
|
|
}
|