Files
oh-my-openagent/src/agents/types.ts
rluisr 2594a1c5aa fix: register sisyphus-junior as builtin agent across type system and model fallback
Sisyphus-Junior was missing from BuiltinAgentName type, agentSources map,
barrel exports, and AGENT_MODEL_REQUIREMENTS. This caused type inconsistencies
and prevented model-fallback hooks from working for sisyphus-junior sessions.

Closes code-yeongyu/oh-my-openagent#1697
2026-03-07 16:45:32 +09:00

132 lines
3.6 KiB
TypeScript

import type { AgentConfig } from "@opencode-ai/sdk";
/**
* Agent mode determines UI model selection behavior:
* - "primary": Respects user's UI-selected model (sisyphus, atlas)
* - "subagent": Uses own fallback chain, ignores UI selection (oracle, explore, etc.)
* - "all": Available in both contexts (OpenCode compatibility)
*/
export type AgentMode = "primary" | "subagent" | "all";
/**
* Agent factory function with static mode property.
* Mode is exposed as static property for pre-instantiation access.
*/
export type AgentFactory = ((model: string) => AgentConfig) & {
mode: AgentMode;
};
/**
* Agent category for grouping in Sisyphus prompt sections
*/
export type AgentCategory =
| "exploration"
| "specialist"
| "advisor"
| "utility";
/**
* Cost classification for Tool Selection table
*/
export type AgentCost = "FREE" | "CHEAP" | "EXPENSIVE";
/**
* Delegation trigger for Sisyphus prompt's Delegation Table
*/
export interface DelegationTrigger {
/** Domain of work (e.g., "Frontend UI/UX") */
domain: string;
/** When to delegate (e.g., "Visual changes only...") */
trigger: string;
}
/**
* Metadata for generating Sisyphus prompt sections dynamically
* This allows adding/removing agents without manually updating the Sisyphus prompt
*/
export interface AgentPromptMetadata {
/** Category for grouping in prompt sections */
category: AgentCategory;
/** Cost classification for Tool Selection table */
cost: AgentCost;
/** Domain triggers for Delegation Table */
triggers: DelegationTrigger[];
/** When to use this agent (for detailed sections) */
useWhen?: string[];
/** When NOT to use this agent */
avoidWhen?: string[];
/** Optional dedicated prompt section (markdown) - for agents like Oracle that have special sections */
dedicatedSection?: string;
/** Nickname/alias used in prompt (e.g., "Oracle" instead of "oracle") */
promptAlias?: string;
/** Key triggers that should appear in Phase 0 (e.g., "External library mentioned → fire librarian") */
keyTrigger?: string;
}
function extractModelName(model: string): string {
return model.includes("/") ? (model.split("/").pop() ?? model) : model;
}
export function isGptModel(model: string): boolean {
const modelName = extractModelName(model).toLowerCase();
return modelName.includes("gpt");
}
export function isGpt5_4Model(model: string): boolean {
const modelName = extractModelName(model).toLowerCase();
return modelName.includes("gpt-5.4") || modelName.includes("gpt-5-4");
}
export function isGpt5_3CodexModel(model: string): boolean {
const modelName = extractModelName(model).toLowerCase();
return modelName.includes("gpt-5.3-codex") || modelName.includes("gpt-5-3-codex");
}
const GEMINI_PROVIDERS = ["google/", "google-vertex/"];
export function isGeminiModel(model: string): boolean {
if (GEMINI_PROVIDERS.some((prefix) => model.startsWith(prefix))) return true;
if (
model.startsWith("github-copilot/") &&
extractModelName(model).toLowerCase().startsWith("gemini")
)
return true;
const modelName = extractModelName(model).toLowerCase();
return modelName.startsWith("gemini-");
}
export type BuiltinAgentName =
| "sisyphus"
| "hephaestus"
| "oracle"
| "librarian"
| "explore"
| "multimodal-looker"
| "metis"
| "momus"
| "atlas"
| "sisyphus-junior";
export type OverridableAgentName = "build" | BuiltinAgentName;
export type AgentName = BuiltinAgentName;
export type AgentOverrideConfig = Partial<AgentConfig> & {
prompt_append?: string;
variant?: string;
fallback_models?: string | string[];
};
export type AgentOverrides = Partial<
Record<OverridableAgentName, AgentOverrideConfig>
>;