mirror of
https://github.com/NoFxAiOS/nofx.git
synced 2026-07-06 04:20:59 +08:00
- Rename experience/ to telemetry/ for clarity - Split 15+ large Go files (800-2200 lines) into focused modules: kernel/engine.go, backtest/runner.go, market/data.go, store/position.go, api/handler_trader.go, trader/auto_trader_grid.go, and 9 exchange traders - Split frontend monoliths: types.ts, api.ts, AITradersPage.tsx, BacktestPage.tsx into domain-specific modules with barrel re-exports - Remove stale files: screenshots, .yml.old, pyproject.toml - Remove unused scripts/ and cmd/ directories - Remove broken/outdated test files (network-dependent, stale expectations)
165 lines
5.9 KiB
TypeScript
165 lines
5.9 KiB
TypeScript
// Constants for AI model and provider configuration
|
|
|
|
export interface BlockrunModel {
|
|
id: string
|
|
name: string
|
|
desc: string
|
|
}
|
|
|
|
export interface Claw402Model {
|
|
id: string
|
|
name: string
|
|
provider: string
|
|
desc: string
|
|
icon: string
|
|
}
|
|
|
|
export interface AIProviderConfig {
|
|
defaultModel: string
|
|
apiUrl: string
|
|
apiName: string
|
|
}
|
|
|
|
// Get friendly AI model display name
|
|
export function getModelDisplayName(modelId: string): string {
|
|
switch (modelId.toLowerCase()) {
|
|
case 'deepseek':
|
|
return 'DeepSeek'
|
|
case 'qwen':
|
|
return 'Qwen'
|
|
case 'claude':
|
|
return 'Claude'
|
|
default:
|
|
return modelId.toUpperCase()
|
|
}
|
|
}
|
|
|
|
// Extract name part after underscore
|
|
export function getShortName(fullName: string): string {
|
|
const parts = fullName.split('_')
|
|
return parts.length > 1 ? parts[parts.length - 1] : fullName
|
|
}
|
|
|
|
// Top models available through BlockRun wallet providers
|
|
export const BLOCKRUN_MODELS: BlockrunModel[] = [
|
|
{ id: 'gpt-5.4', name: 'GPT-5.4', desc: 'OpenAI · Flagship' },
|
|
{ id: 'claude-opus-4.6', name: 'Claude Opus 4.6', desc: 'Anthropic · Flagship' },
|
|
{ id: 'gemini-3.1-pro', name: 'Gemini 3.1 Pro', desc: 'Google · Flagship' },
|
|
{ id: 'grok-3', name: 'Grok 3', desc: 'xAI · Flagship' },
|
|
{ id: 'deepseek-chat', name: 'DeepSeek Chat', desc: 'DeepSeek · Flagship' },
|
|
{ id: 'minimax-m2.5', name: 'MiniMax M2.5', desc: 'MiniMax · Flagship' },
|
|
]
|
|
|
|
// Models available through Claw402 (x402 USDC payment protocol)
|
|
export const CLAW402_MODELS: Claw402Model[] = [
|
|
{ id: 'gpt-5.4', name: 'GPT-5.4', provider: 'OpenAI', desc: 'Flagship · Fast', icon: '⚡' },
|
|
{ id: 'gpt-5.4-pro', name: 'GPT-5.4 Pro', provider: 'OpenAI', desc: 'Reasoning · Pro', icon: '🧠' },
|
|
{ id: 'gpt-5.3', name: 'GPT-5.3', provider: 'OpenAI', desc: 'Balanced', icon: '💡' },
|
|
{ id: 'gpt-5-mini', name: 'GPT-5 Mini', provider: 'OpenAI', desc: 'Fast · Cheap', icon: '🚀' },
|
|
{ id: 'claude-opus', name: 'Claude Opus', provider: 'Anthropic', desc: 'Flagship · Deep', icon: '🎯' },
|
|
{ id: 'deepseek', name: 'DeepSeek V3', provider: 'DeepSeek', desc: 'Best Value', icon: '🔥' },
|
|
{ id: 'deepseek-reasoner', name: 'DeepSeek R1', provider: 'DeepSeek', desc: 'Reasoning', icon: '🤔' },
|
|
{ id: 'qwen-max', name: 'Qwen Max', provider: 'Alibaba', desc: 'Flagship', icon: '🌟' },
|
|
{ id: 'qwen-plus', name: 'Qwen Plus', provider: 'Alibaba', desc: 'Balanced', icon: '✨' },
|
|
{ id: 'grok-4.1', name: 'Grok 4.1', provider: 'xAI', desc: 'Flagship', icon: '⚡' },
|
|
{ id: 'gemini-3.1-pro', name: 'Gemini 3.1 Pro', provider: 'Google', desc: 'Flagship', icon: '💎' },
|
|
{ id: 'kimi-k2.5', name: 'Kimi K2.5', provider: 'Moonshot', desc: 'Balanced', icon: '🌙' },
|
|
]
|
|
|
|
// AI Provider configuration - default models and API links
|
|
export const AI_PROVIDER_CONFIG: Record<string, AIProviderConfig> = {
|
|
deepseek: {
|
|
defaultModel: 'deepseek-chat',
|
|
apiUrl: 'https://platform.deepseek.com/api_keys',
|
|
apiName: 'DeepSeek',
|
|
},
|
|
qwen: {
|
|
defaultModel: 'qwen3-max',
|
|
apiUrl: 'https://dashscope.console.aliyun.com/apiKey',
|
|
apiName: 'Alibaba Cloud',
|
|
},
|
|
openai: {
|
|
defaultModel: 'gpt-5.2',
|
|
apiUrl: 'https://platform.openai.com/api-keys',
|
|
apiName: 'OpenAI',
|
|
},
|
|
claude: {
|
|
defaultModel: 'claude-opus-4-6',
|
|
apiUrl: 'https://console.anthropic.com/settings/keys',
|
|
apiName: 'Anthropic',
|
|
},
|
|
gemini: {
|
|
defaultModel: 'gemini-3-pro-preview',
|
|
apiUrl: 'https://aistudio.google.com/app/apikey',
|
|
apiName: 'Google AI Studio',
|
|
},
|
|
grok: {
|
|
defaultModel: 'grok-3-latest',
|
|
apiUrl: 'https://console.x.ai/',
|
|
apiName: 'xAI',
|
|
},
|
|
kimi: {
|
|
defaultModel: 'moonshot-v1-auto',
|
|
apiUrl: 'https://platform.moonshot.ai/console/api-keys',
|
|
apiName: 'Moonshot',
|
|
},
|
|
minimax: {
|
|
defaultModel: 'MiniMax-M2.5',
|
|
apiUrl: 'https://platform.minimax.io',
|
|
apiName: 'MiniMax',
|
|
},
|
|
claw402: {
|
|
defaultModel: 'deepseek',
|
|
apiUrl: 'https://claw402.ai',
|
|
apiName: 'Claw402',
|
|
},
|
|
'blockrun-base': {
|
|
defaultModel: 'gpt-5.4',
|
|
apiUrl: 'https://blockrun.ai',
|
|
apiName: 'BlockRun',
|
|
},
|
|
'blockrun-sol': {
|
|
defaultModel: 'gpt-5.4',
|
|
apiUrl: 'https://sol.blockrun.ai',
|
|
apiName: 'BlockRun',
|
|
},
|
|
}
|
|
|
|
// Helper function to get exchange display name from exchange ID (UUID)
|
|
export function getExchangeDisplayName(exchangeId: string | undefined, exchanges: { id: string; exchange_type?: string; name: string; account_name?: string }[]): string {
|
|
if (!exchangeId) return 'Unknown'
|
|
const exchange = exchanges.find(e => e.id === exchangeId)
|
|
if (!exchange) return exchangeId.substring(0, 8).toUpperCase() + '...' // Show truncated UUID if not found
|
|
const typeName = exchange.exchange_type?.toUpperCase() || exchange.name
|
|
return exchange.account_name ? `${typeName} - ${exchange.account_name}` : typeName
|
|
}
|
|
|
|
// Helper function to check if exchange is a perp-dex type (wallet-based)
|
|
export function isPerpDexExchange(exchangeType: string | undefined): boolean {
|
|
if (!exchangeType) return false
|
|
const perpDexTypes = ['hyperliquid', 'lighter', 'aster']
|
|
return perpDexTypes.includes(exchangeType.toLowerCase())
|
|
}
|
|
|
|
// Helper function to get wallet address for perp-dex exchanges
|
|
export function getWalletAddress(exchange: { exchange_type?: string; hyperliquidWalletAddr?: string; lighterWalletAddr?: string; asterSigner?: string } | undefined): string | undefined {
|
|
if (!exchange) return undefined
|
|
const type = exchange.exchange_type?.toLowerCase()
|
|
switch (type) {
|
|
case 'hyperliquid':
|
|
return exchange.hyperliquidWalletAddr
|
|
case 'lighter':
|
|
return exchange.lighterWalletAddr
|
|
case 'aster':
|
|
return exchange.asterSigner
|
|
default:
|
|
return undefined
|
|
}
|
|
}
|
|
|
|
// Helper function to truncate wallet address for display
|
|
export function truncateAddress(address: string, startLen = 6, endLen = 4): string {
|
|
if (address.length <= startLen + endLen + 3) return address
|
|
return `${address.slice(0, startLen)}...${address.slice(-endLen)}`
|
|
}
|