mirror of
https://github.com/claude-code-best/claude-code.git
synced 2026-06-17 13:55:50 +00:00
* feat: 第一版大重构 * fix: 修复类型问题 * chore: 更新版本到 1.3.2 * Add brave as alternative WebSearchTool * fix: 修正顺序 * fix: 修复对穷鬼模式的 auto dream 和 session memory 越过 * feat: 穷鬼模式去除 session-summary * feat: 创建 builtin-tools 包,搬运所有工具实现 将 src/tools/ 下的全部 60 个工具目录迁移至 packages/builtin-tools/src/tools/, 内部导入路径已更新为 src/ alias 模式。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * refactor: 更新 src/ 中所有工具引用至 builtin-tools 包,删除 src/tools/ - src/tools.ts 及 178 个 src/ 文件的 import 路径从 ./tools/ 改为 builtin-tools/tools/ - 删除 src/tools/ 整个目录(已迁移至 packages/builtin-tools/) Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * chore: 添加 builtin-tools 路径别名至 tsconfig,更新 bun.lock - tsconfig.json 新增 builtin-tools/* 和 builtin-tools 路径映射 - 新增 packages/builtin-tools/src 至 include Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * refactor: 为 builtin-tools、mcp-client、agent-tools 添加 @claude-code-best 作用域前缀 所有包名及 import 路径统一添加 @claude-code-best/ 前缀: - builtin-tools → @claude-code-best/builtin-tools - mcp-client → @claude-code-best/mcp-client - agent-tools → @claude-code-best/agent-tools Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix: 修复 node 环境没有 bun 的问题 --------- Co-authored-by: Eric-Guo <eric.guocz@gmail.com> Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
87 lines
2.6 KiB
TypeScript
87 lines
2.6 KiB
TypeScript
// MCP string utility functions — pure, no dependencies
|
|
// Extracted from src/services/mcp/mcpStringUtils.ts and normalization.ts
|
|
|
|
// Claude.ai server names are prefixed with this string
|
|
const CLAUDEAI_SERVER_PREFIX = 'claude.ai '
|
|
|
|
/**
|
|
* Normalize server names to be compatible with the API pattern ^[a-zA-Z0-9_-]{1,64}$
|
|
* Replaces any invalid characters (including dots and spaces) with underscores.
|
|
*/
|
|
export function normalizeNameForMCP(name: string): string {
|
|
let normalized = name.replace(/[^a-zA-Z0-9_-]/g, '_')
|
|
if (name.startsWith(CLAUDEAI_SERVER_PREFIX)) {
|
|
normalized = normalized.replace(/_+/g, '_').replace(/^_|_$/g, '')
|
|
}
|
|
return normalized
|
|
}
|
|
|
|
/**
|
|
* Generates the MCP tool/command name prefix for a given server
|
|
*/
|
|
export function getMcpPrefix(serverName: string): string {
|
|
return `mcp__${normalizeNameForMCP(serverName)}__`
|
|
}
|
|
|
|
/**
|
|
* Builds a fully qualified MCP tool name from server and tool names.
|
|
* Inverse of mcpInfoFromString().
|
|
*/
|
|
export function buildMcpToolName(serverName: string, toolName: string): string {
|
|
return `${getMcpPrefix(serverName)}${normalizeNameForMCP(toolName)}`
|
|
}
|
|
|
|
/**
|
|
* Extracts MCP server information from a tool name string.
|
|
* @param toolString Expected format: "mcp__serverName__toolName"
|
|
*/
|
|
export function mcpInfoFromString(toolString: string): {
|
|
serverName: string
|
|
toolName: string | undefined
|
|
} | null {
|
|
const parts = toolString.split('__')
|
|
const [mcpPart, serverName, ...toolNameParts] = parts
|
|
if (mcpPart !== 'mcp' || !serverName) {
|
|
return null
|
|
}
|
|
const toolName =
|
|
toolNameParts.length > 0 ? toolNameParts.join('__') : undefined
|
|
return { serverName, toolName }
|
|
}
|
|
|
|
/**
|
|
* Returns the name to use for permission rule matching.
|
|
*/
|
|
export function getToolNameForPermissionCheck(tool: {
|
|
name: string
|
|
mcpInfo?: { serverName: string; toolName: string }
|
|
}): string {
|
|
return tool.mcpInfo
|
|
? buildMcpToolName(tool.mcpInfo.serverName, tool.mcpInfo.toolName)
|
|
: tool.name
|
|
}
|
|
|
|
/**
|
|
* Extracts the display name from an MCP tool/command name
|
|
*/
|
|
export function getMcpDisplayName(
|
|
fullName: string,
|
|
serverName: string,
|
|
): string {
|
|
const prefix = `mcp__${normalizeNameForMCP(serverName)}__`
|
|
return fullName.replace(prefix, '')
|
|
}
|
|
|
|
/**
|
|
* Extracts just the tool/command display name from a userFacingName
|
|
*/
|
|
export function extractMcpToolDisplayName(userFacingName: string): string {
|
|
let withoutSuffix = userFacingName.replace(/\s*\(MCP\)\s*$/, '')
|
|
withoutSuffix = withoutSuffix.trim()
|
|
const dashIndex = withoutSuffix.indexOf(' - ')
|
|
if (dashIndex !== -1) {
|
|
return withoutSuffix.substring(dashIndex + 3).trim()
|
|
}
|
|
return withoutSuffix
|
|
}
|