mirror of
https://github.com/google-gemini/gemini-cli.git
synced 2026-04-01 17:02:29 -07:00
64 lines
1.8 KiB
TypeScript
64 lines
1.8 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright 2025 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
import type { CommandModule } from 'yargs';
|
|
import {
|
|
debugLogger,
|
|
type ExtensionInstallMetadata,
|
|
} from '@google/gemini-cli-core';
|
|
|
|
import { getErrorMessage } from '../../utils/errors.js';
|
|
import { requestConsentNonInteractive } from '../../config/extensions/consent.js';
|
|
import { ExtensionManager } from '../../config/extension-manager.js';
|
|
import { loadSettings } from '../../config/settings.js';
|
|
import { promptForSetting } from '../../config/extensions/extensionSettings.js';
|
|
|
|
interface InstallArgs {
|
|
path: string;
|
|
}
|
|
|
|
export async function handleLink(args: InstallArgs) {
|
|
try {
|
|
const installMetadata: ExtensionInstallMetadata = {
|
|
source: args.path,
|
|
type: 'link',
|
|
};
|
|
const workspaceDir = process.cwd();
|
|
const extensionManager = new ExtensionManager({
|
|
workspaceDir,
|
|
requestConsent: requestConsentNonInteractive,
|
|
requestSetting: promptForSetting,
|
|
loadedSettings: loadSettings(workspaceDir),
|
|
});
|
|
const extensionName =
|
|
await extensionManager.installOrUpdateExtension(installMetadata);
|
|
debugLogger.log(
|
|
`Extension "${extensionName}" linked successfully and enabled.`,
|
|
);
|
|
} catch (error) {
|
|
debugLogger.error(getErrorMessage(error));
|
|
process.exit(1);
|
|
}
|
|
}
|
|
|
|
export const linkCommand: CommandModule = {
|
|
command: 'link <path>',
|
|
describe:
|
|
'Links an extension from a local path. Updates made to the local path will always be reflected.',
|
|
builder: (yargs) =>
|
|
yargs
|
|
.positional('path', {
|
|
describe: 'The name of the extension to link.',
|
|
type: 'string',
|
|
})
|
|
.check((_) => true),
|
|
handler: async (argv) => {
|
|
await handleLink({
|
|
path: argv['path'] as string,
|
|
});
|
|
},
|
|
};
|