/** * Agent/model detection utilities for ultrawork message routing. * * Routing logic: * 1. Planner agents (prometheus, plan) → planner.ts * 2. GPT 5.2 models → gpt5.2.ts * 3. Everything else (Claude, etc.) → default.ts */ import { isGptModel } from "../../../agents/types" /** * Checks if agent is a planner-type agent. * Planners don't need ultrawork injection (they ARE the planner). */ export function isPlannerAgent(agentName?: string): boolean { if (!agentName) return false const lowerName = agentName.toLowerCase() if (lowerName.includes("prometheus") || lowerName.includes("planner")) return true const normalized = lowerName.replace(/[_-]+/g, " ") return /\bplan\b/.test(normalized) } export { isGptModel } /** Ultrawork message source type */ export type UltraworkSource = "planner" | "gpt" | "default" /** * Determines which ultrawork message source to use. */ export function getUltraworkSource( agentName?: string, modelID?: string ): UltraworkSource { // Priority 1: Planner agents if (isPlannerAgent(agentName)) { return "planner" } // Priority 2: GPT models if (modelID && isGptModel(modelID)) { return "gpt" } // Default: Claude and other models return "default" }