refactor: Replace AgentModel enum with unified Model struct #452
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Summary
This PR implements RFC 007 for dynamic model switching with a unified type system. It replaces the
AgentModelenum (Smart/Eco/Recovery tiers) with a unifiedModelstruct that contains all model metadata.Changes Made
New Unified Model Type (
libs/ai/src/types/model.rs)Modelstruct with fields:id,name,provider,reasoning,cost,limitModelCostfor pricing info (input/output per 1M tokens, cache pricing)ModelLimitfor token limits (context window, max output)Model Catalogs
libs/ai/src/providers/anthropic/models.rs)libs/ai/src/providers/openai/models.rs)libs/ai/src/providers/gemini/models.rs)API Changes
AgentProvidertrait methods now takeModelinstead of string/enumfind_model()helper to search model catalog by IDModel,ModelCost,ModelLimitfromstakpak_apiTUI Updates
ModelstructModelCLI Changes
--modelCLI argumentget_default_model()Cleanup
AgentModelenum entirelyModelSetstructparse_model,detect_providermethodseprintln!statementsTesting
Breaking Changes
AgentModelenum removed - useModelstruct instead--modelCLI argument removed - configure model in config file