fix dependences of core pkg

This commit is contained in:
LaZzyMan 2026-01-22 14:09:08 +08:00
parent 06b64b07e7
commit aa80e738fb
6 changed files with 58 additions and 47 deletions

1
package-lock.json generated
View file

@ -17987,6 +17987,7 @@
"dependencies": {
"@anthropic-ai/sdk": "^0.36.1",
"@google/genai": "1.30.0",
"@iarna/toml": "^2.2.5",
"@modelcontextprotocol/sdk": "^1.25.1",
"@opentelemetry/api": "^1.9.0",
"@opentelemetry/exporter-logs-otlp-grpc": "^0.203.0",

View file

@ -23,6 +23,7 @@ vi.mock('./utils.js', () => ({
getLoadedExtensions: mockGetLoadedExtensions,
toOutputString: mockToOutputString,
}),
extensionToOutputString: mockToOutputString,
}));
vi.mock('../../utils/errors.js', () => ({

View file

@ -6,7 +6,7 @@
import type { CommandModule } from 'yargs';
import { getErrorMessage } from '../../utils/errors.js';
import { getExtensionManager } from './utils.js';
import { extensionToOutputString, getExtensionManager } from './utils.js';
import { t } from '../../i18n/index.js';
export async function handleList() {
@ -21,7 +21,7 @@ export async function handleList() {
console.log(
extensions
.map((extension, _): string =>
extensionManager.toOutputString(extension, process.cwd()),
extensionToOutputString(extension, extensionManager, process.cwd()),
)
.join('\n\n'),
);

View file

@ -4,13 +4,15 @@
* SPDX-License-Identifier: Apache-2.0
*/
import { ExtensionManager } from '@qwen-code/qwen-code-core';
import { ExtensionManager, type Extension } from '@qwen-code/qwen-code-core';
import { loadSettings } from '../../config/settings.js';
import {
requestConsentOrFail,
requestConsentNonInteractive,
} from './consent.js';
import { isWorkspaceTrusted } from '../../config/trustedFolders.js';
import * as os from 'node:os';
import chalk from 'chalk';
export async function getExtensionManager(): Promise<ExtensionManager> {
const workspaceDir = process.cwd();
@ -25,3 +27,53 @@ export async function getExtensionManager(): Promise<ExtensionManager> {
await extensionManager.refreshCache();
return extensionManager;
}
export function extensionToOutputString(
extension: Extension,
extensionManager: ExtensionManager,
workspaceDir: string,
): string {
const cwd = workspaceDir;
const userEnabled = extensionManager.isEnabled(
extension.config.name,
os.homedir(),
);
const workspaceEnabled = extensionManager.isEnabled(
extension.config.name,
cwd,
);
const status = workspaceEnabled ? chalk.green('✓') : chalk.red('✗');
let output = `${status} ${extension.config.name} (${extension.config.version})`;
output += `\n Path: ${extension.path}`;
if (extension.installMetadata) {
output += `\n Source: ${extension.installMetadata.source} (Type: ${extension.installMetadata.type})`;
if (extension.installMetadata.ref) {
output += `\n Ref: ${extension.installMetadata.ref}`;
}
if (extension.installMetadata.releaseTag) {
output += `\n Release tag: ${extension.installMetadata.releaseTag}`;
}
}
output += `\n Enabled (User): ${userEnabled}`;
output += `\n Enabled (Workspace): ${workspaceEnabled}`;
if (extension.contextFiles.length > 0) {
output += `\n Context files:`;
extension.contextFiles.forEach((contextFile) => {
output += `\n ${contextFile}`;
});
}
if (extension.commands && extension.commands.length > 0) {
output += `\n Commands:`;
extension.commands.forEach((command) => {
output += `\n /${command}`;
});
}
if (extension.config.mcpServers) {
output += `\n MCP servers:`;
Object.keys(extension.config.mcpServers).forEach((key) => {
output += `\n ${key}`;
});
}
return output;
}

View file

@ -37,6 +37,7 @@
"@opentelemetry/sdk-node": "^0.203.0",
"@types/html-to-text": "^9.0.4",
"@xterm/headless": "5.5.0",
"@iarna/toml": "^2.2.5",
"ajv": "^8.17.1",
"ajv-formats": "^3.0.0",
"async-mutex": "^0.5.0",

View file

@ -36,7 +36,6 @@ import {
} from './github.js';
import type { LoadExtensionContext } from './variableSchema.js';
import { Override, type AllExtensionsEnablementConfig } from './override.js';
import chalk from 'chalk';
import { parseMarketplaceSource } from './marketplace.js';
import {
isGeminiExtensionConfig,
@ -1056,49 +1055,6 @@ export class ExtensionManager {
);
}
/**
* Converts an extension to output string.
*/
toOutputString(extension: Extension, workspaceDir?: string): string {
const cwd = workspaceDir ?? this.workspaceDir;
const userEnabled = this.isEnabled(extension.config.name, os.homedir());
const workspaceEnabled = this.isEnabled(extension.config.name, cwd);
const status = workspaceEnabled ? chalk.green('✓') : chalk.red('✗');
let output = `${status} ${extension.config.name} (${extension.config.version})`;
output += `\n Path: ${extension.path}`;
if (extension.installMetadata) {
output += `\n Source: ${extension.installMetadata.source} (Type: ${extension.installMetadata.type})`;
if (extension.installMetadata.ref) {
output += `\n Ref: ${extension.installMetadata.ref}`;
}
if (extension.installMetadata.releaseTag) {
output += `\n Release tag: ${extension.installMetadata.releaseTag}`;
}
}
output += `\n Enabled (User): ${userEnabled}`;
output += `\n Enabled (Workspace): ${workspaceEnabled}`;
if (extension.contextFiles.length > 0) {
output += `\n Context files:`;
extension.contextFiles.forEach((contextFile) => {
output += `\n ${contextFile}`;
});
}
if (extension.commands && extension.commands.length > 0) {
output += `\n Commands:`;
extension.commands.forEach((command) => {
output += `\n /${command}`;
});
}
if (extension.config.mcpServers) {
output += `\n MCP servers:`;
Object.keys(extension.config.mcpServers).forEach((key) => {
output += `\n ${key}`;
});
}
return output;
}
async performWorkspaceExtensionMigration(
extensions: Extension[],
requestConsent: (options?: ExtensionRequestOptions) => Promise<void>,