@cloudbase/cloudbase-mcp 2.0.2 → 2.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli.cjs +20 -26
- package/dist/index.cjs +20 -26
- package/dist/index.js +20 -26
- package/package.json +1 -1
package/dist/cli.cjs
CHANGED
|
@@ -1580,14 +1580,17 @@ function registerEnvTools(server) {
|
|
|
1580
1580
|
return { content: [{ type: "text", text: "用户取消了登录" }] };
|
|
1581
1581
|
}
|
|
1582
1582
|
if (selectedEnvId) {
|
|
1583
|
-
// Get CLAUDE.md prompt content
|
|
1583
|
+
// Get CLAUDE.md prompt content (skip for CodeBuddy IDE)
|
|
1584
1584
|
let promptContent = "";
|
|
1585
|
-
|
|
1586
|
-
|
|
1587
|
-
|
|
1588
|
-
|
|
1589
|
-
|
|
1590
|
-
|
|
1585
|
+
const currentIde = server.ide || process.env.INTEGRATION_IDE;
|
|
1586
|
+
if (currentIde !== "CodeBuddy") {
|
|
1587
|
+
try {
|
|
1588
|
+
promptContent = await (0, rag_js_1.getClaudePrompt)();
|
|
1589
|
+
}
|
|
1590
|
+
catch (promptError) {
|
|
1591
|
+
(0, logger_js_1.debug)("Failed to get CLAUDE prompt", { error: promptError });
|
|
1592
|
+
// Continue with login success even if prompt fetch fails
|
|
1593
|
+
}
|
|
1591
1594
|
}
|
|
1592
1595
|
const successMessage = `✅ 登录成功,当前环境: ${selectedEnvId}`;
|
|
1593
1596
|
const promptMessage = promptContent
|
|
@@ -1719,8 +1722,9 @@ function registerEnvTools(server) {
|
|
|
1719
1722
|
throw new Error(`不支持的查询类型: ${action}`);
|
|
1720
1723
|
}
|
|
1721
1724
|
let responseText = JSON.stringify(result, null, 2);
|
|
1722
|
-
// For info action, append CLAUDE.md prompt content
|
|
1723
|
-
|
|
1725
|
+
// For info action, append CLAUDE.md prompt content (skip for CodeBuddy IDE)
|
|
1726
|
+
const currentIde = server.ide || process.env.INTEGRATION_IDE;
|
|
1727
|
+
if (action === "info" && currentIde !== "CodeBuddy") {
|
|
1724
1728
|
try {
|
|
1725
1729
|
const promptContent = await (0, rag_js_1.getClaudePrompt)();
|
|
1726
1730
|
if (promptContent) {
|
|
@@ -134857,7 +134861,7 @@ class TelemetryReporter {
|
|
|
134857
134861
|
const nodeVersion = process.version; // Node.js版本
|
|
134858
134862
|
const arch = os_1.default.arch(); // 系统架构
|
|
134859
134863
|
// 从构建时注入的版本号获取MCP版本信息
|
|
134860
|
-
const mcpVersion = process.env.npm_package_version || "2.0.
|
|
134864
|
+
const mcpVersion = process.env.npm_package_version || "2.0.4" || 0;
|
|
134861
134865
|
return {
|
|
134862
134866
|
userAgent: `${osType} ${osRelease} ${arch} ${nodeVersion} CloudBase-MCP/${mcpVersion}`,
|
|
134863
134867
|
deviceId: this.deviceId,
|
|
@@ -185375,24 +185379,13 @@ function safeStringify(obj) {
|
|
|
185375
185379
|
}
|
|
185376
185380
|
}
|
|
185377
185381
|
// Download and extract web template, return extract directory path
|
|
185378
|
-
//
|
|
185382
|
+
// Always downloads and overwrites existing template
|
|
185379
185383
|
async function downloadWebTemplate() {
|
|
185380
185384
|
const baseDir = path.join(os.homedir(), ".cloudbase-mcp");
|
|
185381
185385
|
const zipPath = path.join(baseDir, "web-cloudbase-project.zip");
|
|
185382
185386
|
const extractDir = path.join(baseDir, "web-template");
|
|
185383
185387
|
const url = "https://static.cloudbase.net/cloudbase-examples/web-cloudbase-project.zip";
|
|
185384
185388
|
await fs.mkdir(baseDir, { recursive: true });
|
|
185385
|
-
// Check if extractDir already exists (cache hit)
|
|
185386
|
-
try {
|
|
185387
|
-
const stats = await fs.stat(extractDir);
|
|
185388
|
-
if (stats.isDirectory()) {
|
|
185389
|
-
// Directory exists, return it directly (use cache)
|
|
185390
|
-
return extractDir;
|
|
185391
|
-
}
|
|
185392
|
-
}
|
|
185393
|
-
catch (error) {
|
|
185394
|
-
// Directory doesn't exist, proceed with download
|
|
185395
|
-
}
|
|
185396
185389
|
// Download zip to specified path (overwrite)
|
|
185397
185390
|
const response = await fetch(url);
|
|
185398
185391
|
if (!response.ok) {
|
|
@@ -200513,7 +200506,7 @@ ${envIdSection}
|
|
|
200513
200506
|
## 环境信息
|
|
200514
200507
|
- 操作系统: ${os_1.default.type()} ${os_1.default.release()}
|
|
200515
200508
|
- Node.js版本: ${process.version}
|
|
200516
|
-
- MCP 版本:${process.env.npm_package_version || "2.0.
|
|
200509
|
+
- MCP 版本:${process.env.npm_package_version || "2.0.4" || 0}
|
|
200517
200510
|
- 系统架构: ${os_1.default.arch()}
|
|
200518
200511
|
- 时间: ${new Date().toISOString()}
|
|
200519
200512
|
- 请求ID: ${requestId}
|
|
@@ -215090,7 +215083,7 @@ function registerSetupTools(server) {
|
|
|
215090
215083
|
title: "下载项目模板",
|
|
215091
215084
|
description: `自动下载并部署CloudBase项目模板。⚠️ **MANDATORY FOR NEW PROJECTS** ⚠️
|
|
215092
215085
|
|
|
215093
|
-
**CRITICAL**: This tool MUST be called FIRST when starting a new project.\n\n支持的模板:\n- react: React + CloudBase 全栈应用模板\n- vue: Vue + CloudBase 全栈应用模板\n- miniprogram: 微信小程序 + 云开发模板 \n- uniapp: UniApp + CloudBase 跨端应用模板\n- rules: 只包含AI编辑器配置文件(包含Cursor、WindSurf、CodeBuddy等所有主流编辑器配置),适合在已有项目中补充AI编辑器配置\n\n支持的IDE类型:\n- all: 下载所有IDE配置(默认)\n- cursor: Cursor AI编辑器\n- windsurf: WindSurf AI编辑器\n- codebuddy: CodeBuddy AI编辑器\n- claude-code: Claude Code AI编辑器\n- cline: Cline AI编辑器\n- gemini-cli: Gemini CLI\n- opencode: OpenCode AI编辑器\n- qwen-code: 通义灵码\n- baidu-comate: 百度Comate\n- openai-codex-cli: OpenAI Codex CLI\n- augment-code: Augment Code\n- github-copilot: GitHub Copilot\n- roocode: RooCode AI编辑器\n- tongyi-lingma: 通义灵码\n- trae: Trae AI编辑器\n- vscode: Visual Studio Code\n\n特别说明:\n- rules 模板会自动包含当前 mcp 版本号信息(版本号:${ true ? "2.0.
|
|
215086
|
+
**CRITICAL**: This tool MUST be called FIRST when starting a new project.\n\n支持的模板:\n- react: React + CloudBase 全栈应用模板\n- vue: Vue + CloudBase 全栈应用模板\n- miniprogram: 微信小程序 + 云开发模板 \n- uniapp: UniApp + CloudBase 跨端应用模板\n- rules: 只包含AI编辑器配置文件(包含Cursor、WindSurf、CodeBuddy等所有主流编辑器配置),适合在已有项目中补充AI编辑器配置\n\n支持的IDE类型:\n- all: 下载所有IDE配置(默认)\n- cursor: Cursor AI编辑器\n- windsurf: WindSurf AI编辑器\n- codebuddy: CodeBuddy AI编辑器\n- claude-code: Claude Code AI编辑器\n- cline: Cline AI编辑器\n- gemini-cli: Gemini CLI\n- opencode: OpenCode AI编辑器\n- qwen-code: 通义灵码\n- baidu-comate: 百度Comate\n- openai-codex-cli: OpenAI Codex CLI\n- augment-code: Augment Code\n- github-copilot: GitHub Copilot\n- roocode: RooCode AI编辑器\n- tongyi-lingma: 通义灵码\n- trae: Trae AI编辑器\n- vscode: Visual Studio Code\n\n特别说明:\n- rules 模板会自动包含当前 mcp 版本号信息(版本号:${ true ? "2.0.4" : 0}),便于后续维护和版本追踪\n- 下载 rules 模板时,如果项目中已存在 README.md 文件,系统会自动保护该文件不被覆盖(除非设置 overwrite=true)`,
|
|
215094
215087
|
inputSchema: {
|
|
215095
215088
|
template: zod_1.z.enum(["react", "vue", "miniprogram", "uniapp", "rules"]).describe("要下载的模板类型"),
|
|
215096
215089
|
ide: zod_1.z.enum(IDE_TYPES).optional().default("all").describe("指定要下载的IDE类型,默认为all(下载所有IDE配置)"),
|
|
@@ -252587,8 +252580,9 @@ const ws_1 = __webpack_require__(17699);
|
|
|
252587
252580
|
const logger_js_1 = __webpack_require__(13039);
|
|
252588
252581
|
// 动态导入 open 模块,兼容 ESM/CJS 环境
|
|
252589
252582
|
async function openUrl(url, options, server) {
|
|
252590
|
-
// 检查是否为 CodeBuddy IDE
|
|
252591
|
-
|
|
252583
|
+
// 检查是否为 CodeBuddy IDE (优先使用 server.ide,回退到环境变量)
|
|
252584
|
+
const currentIde = server?.ide || process.env.INTEGRATION_IDE;
|
|
252585
|
+
if (currentIde === 'CodeBuddy' && server) {
|
|
252592
252586
|
try {
|
|
252593
252587
|
// 发送通知而不是直接打开网页
|
|
252594
252588
|
server.server.sendLoggingMessage({
|
package/dist/index.cjs
CHANGED
|
@@ -1579,14 +1579,17 @@ function registerEnvTools(server) {
|
|
|
1579
1579
|
return { content: [{ type: "text", text: "用户取消了登录" }] };
|
|
1580
1580
|
}
|
|
1581
1581
|
if (selectedEnvId) {
|
|
1582
|
-
// Get CLAUDE.md prompt content
|
|
1582
|
+
// Get CLAUDE.md prompt content (skip for CodeBuddy IDE)
|
|
1583
1583
|
let promptContent = "";
|
|
1584
|
-
|
|
1585
|
-
|
|
1586
|
-
|
|
1587
|
-
|
|
1588
|
-
|
|
1589
|
-
|
|
1584
|
+
const currentIde = server.ide || process.env.INTEGRATION_IDE;
|
|
1585
|
+
if (currentIde !== "CodeBuddy") {
|
|
1586
|
+
try {
|
|
1587
|
+
promptContent = await (0, rag_js_1.getClaudePrompt)();
|
|
1588
|
+
}
|
|
1589
|
+
catch (promptError) {
|
|
1590
|
+
(0, logger_js_1.debug)("Failed to get CLAUDE prompt", { error: promptError });
|
|
1591
|
+
// Continue with login success even if prompt fetch fails
|
|
1592
|
+
}
|
|
1590
1593
|
}
|
|
1591
1594
|
const successMessage = `✅ 登录成功,当前环境: ${selectedEnvId}`;
|
|
1592
1595
|
const promptMessage = promptContent
|
|
@@ -1718,8 +1721,9 @@ function registerEnvTools(server) {
|
|
|
1718
1721
|
throw new Error(`不支持的查询类型: ${action}`);
|
|
1719
1722
|
}
|
|
1720
1723
|
let responseText = JSON.stringify(result, null, 2);
|
|
1721
|
-
// For info action, append CLAUDE.md prompt content
|
|
1722
|
-
|
|
1724
|
+
// For info action, append CLAUDE.md prompt content (skip for CodeBuddy IDE)
|
|
1725
|
+
const currentIde = server.ide || process.env.INTEGRATION_IDE;
|
|
1726
|
+
if (action === "info" && currentIde !== "CodeBuddy") {
|
|
1723
1727
|
try {
|
|
1724
1728
|
const promptContent = await (0, rag_js_1.getClaudePrompt)();
|
|
1725
1729
|
if (promptContent) {
|
|
@@ -134706,7 +134710,7 @@ class TelemetryReporter {
|
|
|
134706
134710
|
const nodeVersion = process.version; // Node.js版本
|
|
134707
134711
|
const arch = os_1.default.arch(); // 系统架构
|
|
134708
134712
|
// 从构建时注入的版本号获取MCP版本信息
|
|
134709
|
-
const mcpVersion = process.env.npm_package_version || "2.0.
|
|
134713
|
+
const mcpVersion = process.env.npm_package_version || "2.0.4" || 0;
|
|
134710
134714
|
return {
|
|
134711
134715
|
userAgent: `${osType} ${osRelease} ${arch} ${nodeVersion} CloudBase-MCP/${mcpVersion}`,
|
|
134712
134716
|
deviceId: this.deviceId,
|
|
@@ -185224,24 +185228,13 @@ function safeStringify(obj) {
|
|
|
185224
185228
|
}
|
|
185225
185229
|
}
|
|
185226
185230
|
// Download and extract web template, return extract directory path
|
|
185227
|
-
//
|
|
185231
|
+
// Always downloads and overwrites existing template
|
|
185228
185232
|
async function downloadWebTemplate() {
|
|
185229
185233
|
const baseDir = path.join(os.homedir(), ".cloudbase-mcp");
|
|
185230
185234
|
const zipPath = path.join(baseDir, "web-cloudbase-project.zip");
|
|
185231
185235
|
const extractDir = path.join(baseDir, "web-template");
|
|
185232
185236
|
const url = "https://static.cloudbase.net/cloudbase-examples/web-cloudbase-project.zip";
|
|
185233
185237
|
await fs.mkdir(baseDir, { recursive: true });
|
|
185234
|
-
// Check if extractDir already exists (cache hit)
|
|
185235
|
-
try {
|
|
185236
|
-
const stats = await fs.stat(extractDir);
|
|
185237
|
-
if (stats.isDirectory()) {
|
|
185238
|
-
// Directory exists, return it directly (use cache)
|
|
185239
|
-
return extractDir;
|
|
185240
|
-
}
|
|
185241
|
-
}
|
|
185242
|
-
catch (error) {
|
|
185243
|
-
// Directory doesn't exist, proceed with download
|
|
185244
|
-
}
|
|
185245
185238
|
// Download zip to specified path (overwrite)
|
|
185246
185239
|
const response = await fetch(url);
|
|
185247
185240
|
if (!response.ok) {
|
|
@@ -200362,7 +200355,7 @@ ${envIdSection}
|
|
|
200362
200355
|
## 环境信息
|
|
200363
200356
|
- 操作系统: ${os_1.default.type()} ${os_1.default.release()}
|
|
200364
200357
|
- Node.js版本: ${process.version}
|
|
200365
|
-
- MCP 版本:${process.env.npm_package_version || "2.0.
|
|
200358
|
+
- MCP 版本:${process.env.npm_package_version || "2.0.4" || 0}
|
|
200366
200359
|
- 系统架构: ${os_1.default.arch()}
|
|
200367
200360
|
- 时间: ${new Date().toISOString()}
|
|
200368
200361
|
- 请求ID: ${requestId}
|
|
@@ -214939,7 +214932,7 @@ function registerSetupTools(server) {
|
|
|
214939
214932
|
title: "下载项目模板",
|
|
214940
214933
|
description: `自动下载并部署CloudBase项目模板。⚠️ **MANDATORY FOR NEW PROJECTS** ⚠️
|
|
214941
214934
|
|
|
214942
|
-
**CRITICAL**: This tool MUST be called FIRST when starting a new project.\n\n支持的模板:\n- react: React + CloudBase 全栈应用模板\n- vue: Vue + CloudBase 全栈应用模板\n- miniprogram: 微信小程序 + 云开发模板 \n- uniapp: UniApp + CloudBase 跨端应用模板\n- rules: 只包含AI编辑器配置文件(包含Cursor、WindSurf、CodeBuddy等所有主流编辑器配置),适合在已有项目中补充AI编辑器配置\n\n支持的IDE类型:\n- all: 下载所有IDE配置(默认)\n- cursor: Cursor AI编辑器\n- windsurf: WindSurf AI编辑器\n- codebuddy: CodeBuddy AI编辑器\n- claude-code: Claude Code AI编辑器\n- cline: Cline AI编辑器\n- gemini-cli: Gemini CLI\n- opencode: OpenCode AI编辑器\n- qwen-code: 通义灵码\n- baidu-comate: 百度Comate\n- openai-codex-cli: OpenAI Codex CLI\n- augment-code: Augment Code\n- github-copilot: GitHub Copilot\n- roocode: RooCode AI编辑器\n- tongyi-lingma: 通义灵码\n- trae: Trae AI编辑器\n- vscode: Visual Studio Code\n\n特别说明:\n- rules 模板会自动包含当前 mcp 版本号信息(版本号:${ true ? "2.0.
|
|
214935
|
+
**CRITICAL**: This tool MUST be called FIRST when starting a new project.\n\n支持的模板:\n- react: React + CloudBase 全栈应用模板\n- vue: Vue + CloudBase 全栈应用模板\n- miniprogram: 微信小程序 + 云开发模板 \n- uniapp: UniApp + CloudBase 跨端应用模板\n- rules: 只包含AI编辑器配置文件(包含Cursor、WindSurf、CodeBuddy等所有主流编辑器配置),适合在已有项目中补充AI编辑器配置\n\n支持的IDE类型:\n- all: 下载所有IDE配置(默认)\n- cursor: Cursor AI编辑器\n- windsurf: WindSurf AI编辑器\n- codebuddy: CodeBuddy AI编辑器\n- claude-code: Claude Code AI编辑器\n- cline: Cline AI编辑器\n- gemini-cli: Gemini CLI\n- opencode: OpenCode AI编辑器\n- qwen-code: 通义灵码\n- baidu-comate: 百度Comate\n- openai-codex-cli: OpenAI Codex CLI\n- augment-code: Augment Code\n- github-copilot: GitHub Copilot\n- roocode: RooCode AI编辑器\n- tongyi-lingma: 通义灵码\n- trae: Trae AI编辑器\n- vscode: Visual Studio Code\n\n特别说明:\n- rules 模板会自动包含当前 mcp 版本号信息(版本号:${ true ? "2.0.4" : 0}),便于后续维护和版本追踪\n- 下载 rules 模板时,如果项目中已存在 README.md 文件,系统会自动保护该文件不被覆盖(除非设置 overwrite=true)`,
|
|
214943
214936
|
inputSchema: {
|
|
214944
214937
|
template: zod_1.z.enum(["react", "vue", "miniprogram", "uniapp", "rules"]).describe("要下载的模板类型"),
|
|
214945
214938
|
ide: zod_1.z.enum(IDE_TYPES).optional().default("all").describe("指定要下载的IDE类型,默认为all(下载所有IDE配置)"),
|
|
@@ -252482,8 +252475,9 @@ const ws_1 = __webpack_require__(17699);
|
|
|
252482
252475
|
const logger_js_1 = __webpack_require__(13039);
|
|
252483
252476
|
// 动态导入 open 模块,兼容 ESM/CJS 环境
|
|
252484
252477
|
async function openUrl(url, options, server) {
|
|
252485
|
-
// 检查是否为 CodeBuddy IDE
|
|
252486
|
-
|
|
252478
|
+
// 检查是否为 CodeBuddy IDE (优先使用 server.ide,回退到环境变量)
|
|
252479
|
+
const currentIde = server?.ide || process.env.INTEGRATION_IDE;
|
|
252480
|
+
if (currentIde === 'CodeBuddy' && server) {
|
|
252487
252481
|
try {
|
|
252488
252482
|
// 发送通知而不是直接打开网页
|
|
252489
252483
|
server.server.sendLoggingMessage({
|
package/dist/index.js
CHANGED
|
@@ -2516,24 +2516,13 @@ function safeStringify(obj) {
|
|
|
2516
2516
|
}
|
|
2517
2517
|
}
|
|
2518
2518
|
// Download and extract web template, return extract directory path
|
|
2519
|
-
//
|
|
2519
|
+
// Always downloads and overwrites existing template
|
|
2520
2520
|
async function downloadWebTemplate() {
|
|
2521
2521
|
const baseDir = path.join(os.homedir(), ".cloudbase-mcp");
|
|
2522
2522
|
const zipPath = path.join(baseDir, "web-cloudbase-project.zip");
|
|
2523
2523
|
const extractDir = path.join(baseDir, "web-template");
|
|
2524
2524
|
const url = "https://static.cloudbase.net/cloudbase-examples/web-cloudbase-project.zip";
|
|
2525
2525
|
await fs.mkdir(baseDir, { recursive: true });
|
|
2526
|
-
// Check if extractDir already exists (cache hit)
|
|
2527
|
-
try {
|
|
2528
|
-
const stats = await fs.stat(extractDir);
|
|
2529
|
-
if (stats.isDirectory()) {
|
|
2530
|
-
// Directory exists, return it directly (use cache)
|
|
2531
|
-
return extractDir;
|
|
2532
|
-
}
|
|
2533
|
-
}
|
|
2534
|
-
catch (error) {
|
|
2535
|
-
// Directory doesn't exist, proceed with download
|
|
2536
|
-
}
|
|
2537
2526
|
// Download zip to specified path (overwrite)
|
|
2538
2527
|
const response = await fetch(url);
|
|
2539
2528
|
if (!response.ok) {
|
|
@@ -2887,14 +2876,17 @@ function registerEnvTools(server) {
|
|
|
2887
2876
|
return { content: [{ type: "text", text: "用户取消了登录" }] };
|
|
2888
2877
|
}
|
|
2889
2878
|
if (selectedEnvId) {
|
|
2890
|
-
// Get CLAUDE.md prompt content
|
|
2879
|
+
// Get CLAUDE.md prompt content (skip for CodeBuddy IDE)
|
|
2891
2880
|
let promptContent = "";
|
|
2892
|
-
|
|
2893
|
-
|
|
2894
|
-
|
|
2895
|
-
|
|
2896
|
-
|
|
2897
|
-
|
|
2881
|
+
const currentIde = server.ide || process.env.INTEGRATION_IDE;
|
|
2882
|
+
if (currentIde !== "CodeBuddy") {
|
|
2883
|
+
try {
|
|
2884
|
+
promptContent = await (0, rag_js_1.getClaudePrompt)();
|
|
2885
|
+
}
|
|
2886
|
+
catch (promptError) {
|
|
2887
|
+
(0, logger_js_1.debug)("Failed to get CLAUDE prompt", { error: promptError });
|
|
2888
|
+
// Continue with login success even if prompt fetch fails
|
|
2889
|
+
}
|
|
2898
2890
|
}
|
|
2899
2891
|
const successMessage = `✅ 登录成功,当前环境: ${selectedEnvId}`;
|
|
2900
2892
|
const promptMessage = promptContent
|
|
@@ -3026,8 +3018,9 @@ function registerEnvTools(server) {
|
|
|
3026
3018
|
throw new Error(`不支持的查询类型: ${action}`);
|
|
3027
3019
|
}
|
|
3028
3020
|
let responseText = JSON.stringify(result, null, 2);
|
|
3029
|
-
// For info action, append CLAUDE.md prompt content
|
|
3030
|
-
|
|
3021
|
+
// For info action, append CLAUDE.md prompt content (skip for CodeBuddy IDE)
|
|
3022
|
+
const currentIde = server.ide || process.env.INTEGRATION_IDE;
|
|
3023
|
+
if (action === "info" && currentIde !== "CodeBuddy") {
|
|
3031
3024
|
try {
|
|
3032
3025
|
const promptContent = await (0, rag_js_1.getClaudePrompt)();
|
|
3033
3026
|
if (promptContent) {
|
|
@@ -3445,8 +3438,9 @@ const ws_1 = __webpack_require__(220);
|
|
|
3445
3438
|
const logger_js_1 = __webpack_require__(39);
|
|
3446
3439
|
// 动态导入 open 模块,兼容 ESM/CJS 环境
|
|
3447
3440
|
async function openUrl(url, options, server) {
|
|
3448
|
-
// 检查是否为 CodeBuddy IDE
|
|
3449
|
-
|
|
3441
|
+
// 检查是否为 CodeBuddy IDE (优先使用 server.ide,回退到环境变量)
|
|
3442
|
+
const currentIde = server?.ide || process.env.INTEGRATION_IDE;
|
|
3443
|
+
if (currentIde === 'CodeBuddy' && server) {
|
|
3450
3444
|
try {
|
|
3451
3445
|
// 发送通知而不是直接打开网页
|
|
3452
3446
|
server.server.sendLoggingMessage({
|
|
@@ -6027,7 +6021,7 @@ ${envIdSection}
|
|
|
6027
6021
|
## 环境信息
|
|
6028
6022
|
- 操作系统: ${os_1.default.type()} ${os_1.default.release()}
|
|
6029
6023
|
- Node.js版本: ${process.version}
|
|
6030
|
-
- MCP 版本:${process.env.npm_package_version || "2.0.
|
|
6024
|
+
- MCP 版本:${process.env.npm_package_version || "2.0.4" || 0}
|
|
6031
6025
|
- 系统架构: ${os_1.default.arch()}
|
|
6032
6026
|
- 时间: ${new Date().toISOString()}
|
|
6033
6027
|
- 请求ID: ${requestId}
|
|
@@ -7216,7 +7210,7 @@ function registerSetupTools(server) {
|
|
|
7216
7210
|
title: "下载项目模板",
|
|
7217
7211
|
description: `自动下载并部署CloudBase项目模板。⚠️ **MANDATORY FOR NEW PROJECTS** ⚠️
|
|
7218
7212
|
|
|
7219
|
-
**CRITICAL**: This tool MUST be called FIRST when starting a new project.\n\n支持的模板:\n- react: React + CloudBase 全栈应用模板\n- vue: Vue + CloudBase 全栈应用模板\n- miniprogram: 微信小程序 + 云开发模板 \n- uniapp: UniApp + CloudBase 跨端应用模板\n- rules: 只包含AI编辑器配置文件(包含Cursor、WindSurf、CodeBuddy等所有主流编辑器配置),适合在已有项目中补充AI编辑器配置\n\n支持的IDE类型:\n- all: 下载所有IDE配置(默认)\n- cursor: Cursor AI编辑器\n- windsurf: WindSurf AI编辑器\n- codebuddy: CodeBuddy AI编辑器\n- claude-code: Claude Code AI编辑器\n- cline: Cline AI编辑器\n- gemini-cli: Gemini CLI\n- opencode: OpenCode AI编辑器\n- qwen-code: 通义灵码\n- baidu-comate: 百度Comate\n- openai-codex-cli: OpenAI Codex CLI\n- augment-code: Augment Code\n- github-copilot: GitHub Copilot\n- roocode: RooCode AI编辑器\n- tongyi-lingma: 通义灵码\n- trae: Trae AI编辑器\n- vscode: Visual Studio Code\n\n特别说明:\n- rules 模板会自动包含当前 mcp 版本号信息(版本号:${ true ? "2.0.
|
|
7213
|
+
**CRITICAL**: This tool MUST be called FIRST when starting a new project.\n\n支持的模板:\n- react: React + CloudBase 全栈应用模板\n- vue: Vue + CloudBase 全栈应用模板\n- miniprogram: 微信小程序 + 云开发模板 \n- uniapp: UniApp + CloudBase 跨端应用模板\n- rules: 只包含AI编辑器配置文件(包含Cursor、WindSurf、CodeBuddy等所有主流编辑器配置),适合在已有项目中补充AI编辑器配置\n\n支持的IDE类型:\n- all: 下载所有IDE配置(默认)\n- cursor: Cursor AI编辑器\n- windsurf: WindSurf AI编辑器\n- codebuddy: CodeBuddy AI编辑器\n- claude-code: Claude Code AI编辑器\n- cline: Cline AI编辑器\n- gemini-cli: Gemini CLI\n- opencode: OpenCode AI编辑器\n- qwen-code: 通义灵码\n- baidu-comate: 百度Comate\n- openai-codex-cli: OpenAI Codex CLI\n- augment-code: Augment Code\n- github-copilot: GitHub Copilot\n- roocode: RooCode AI编辑器\n- tongyi-lingma: 通义灵码\n- trae: Trae AI编辑器\n- vscode: Visual Studio Code\n\n特别说明:\n- rules 模板会自动包含当前 mcp 版本号信息(版本号:${ true ? "2.0.4" : 0}),便于后续维护和版本追踪\n- 下载 rules 模板时,如果项目中已存在 README.md 文件,系统会自动保护该文件不被覆盖(除非设置 overwrite=true)`,
|
|
7220
7214
|
inputSchema: {
|
|
7221
7215
|
template: zod_1.z.enum(["react", "vue", "miniprogram", "uniapp", "rules"]).describe("要下载的模板类型"),
|
|
7222
7216
|
ide: zod_1.z.enum(IDE_TYPES).optional().default("all").describe("指定要下载的IDE类型,默认为all(下载所有IDE配置)"),
|
|
@@ -8255,7 +8249,7 @@ class TelemetryReporter {
|
|
|
8255
8249
|
const nodeVersion = process.version; // Node.js版本
|
|
8256
8250
|
const arch = os_1.default.arch(); // 系统架构
|
|
8257
8251
|
// 从构建时注入的版本号获取MCP版本信息
|
|
8258
|
-
const mcpVersion = process.env.npm_package_version || "2.0.
|
|
8252
|
+
const mcpVersion = process.env.npm_package_version || "2.0.4" || 0;
|
|
8259
8253
|
return {
|
|
8260
8254
|
userAgent: `${osType} ${osRelease} ${arch} ${nodeVersion} CloudBase-MCP/${mcpVersion}`,
|
|
8261
8255
|
deviceId: this.deviceId,
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cloudbase/cloudbase-mcp",
|
|
3
|
-
"version": "2.0.
|
|
3
|
+
"version": "2.0.4",
|
|
4
4
|
"description": "腾讯云开发 MCP Server,通过AI提示词和MCP协议+云开发,让开发更智能、更高效,当你在Cursor/ VSCode GitHub Copilot/WinSurf/CodeBuddy/Augment Code/Claude Code等AI编程工具里写代码时,它能自动帮你生成可直接部署的前后端应用+小程序,并一键发布到腾讯云开发 CloudBase。",
|
|
5
5
|
"main": "./dist/index.cjs",
|
|
6
6
|
"module": "./dist/index.js",
|