mirror of https://github.com/coder/code-server.git
84 lines
2.5 KiB
TypeScript
84 lines
2.5 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import * as vscode from 'vscode';
|
|
import * as nls from 'vscode-nls';
|
|
import { SimpleBrowserManager } from './simpleBrowserManager';
|
|
|
|
declare const URL: typeof import('url').URL;
|
|
|
|
const localize = nls.loadMessageBundle();
|
|
|
|
const openApiCommand = 'simpleBrowser.api.open';
|
|
const showCommand = 'simpleBrowser.show';
|
|
|
|
const enabledHosts = new Set<string>([
|
|
'localhost',
|
|
// localhost IPv4
|
|
'127.0.0.1',
|
|
// localhost IPv6
|
|
'0:0:0:0:0:0:0:1',
|
|
'::1',
|
|
// all interfaces IPv4
|
|
'0.0.0.0',
|
|
// all interfaces IPv6
|
|
'0:0:0:0:0:0:0:0',
|
|
'::'
|
|
]);
|
|
|
|
const openerId = 'simpleBrowser.open';
|
|
|
|
export function activate(context: vscode.ExtensionContext) {
|
|
|
|
const manager = new SimpleBrowserManager(context.extensionUri);
|
|
context.subscriptions.push(manager);
|
|
|
|
context.subscriptions.push(vscode.commands.registerCommand(showCommand, async (url?: string) => {
|
|
if (!url) {
|
|
url = await vscode.window.showInputBox({
|
|
placeHolder: localize('simpleBrowser.show.placeholder', "https://example.com"),
|
|
prompt: localize('simpleBrowser.show.prompt', "Enter url to visit")
|
|
});
|
|
}
|
|
|
|
if (url) {
|
|
manager.show(url);
|
|
}
|
|
}));
|
|
|
|
context.subscriptions.push(vscode.commands.registerCommand(openApiCommand, (url: vscode.Uri, showOptions?: {
|
|
preserveFocus?: boolean,
|
|
viewColumn: vscode.ViewColumn,
|
|
}) => {
|
|
manager.show(url.toString(), showOptions);
|
|
}));
|
|
|
|
context.subscriptions.push(vscode.window.registerExternalUriOpener(openerId, {
|
|
canOpenExternalUri(uri: vscode.Uri) {
|
|
const originalUri = new URL(uri.toString());
|
|
if (enabledHosts.has(originalUri.hostname)) {
|
|
return isWeb()
|
|
? vscode.ExternalUriOpenerPriority.Default
|
|
: vscode.ExternalUriOpenerPriority.Option;
|
|
}
|
|
|
|
return vscode.ExternalUriOpenerPriority.None;
|
|
},
|
|
openExternalUri(resolveUri: vscode.Uri) {
|
|
return manager.show(resolveUri.toString(), {
|
|
viewColumn: vscode.window.activeTextEditor ? vscode.ViewColumn.Beside : vscode.ViewColumn.Active
|
|
});
|
|
}
|
|
}, {
|
|
schemes: ['http', 'https'],
|
|
label: localize('openTitle', "Open in simple browser"),
|
|
}));
|
|
}
|
|
|
|
function isWeb(): boolean {
|
|
// @ts-expect-error
|
|
return typeof navigator !== 'undefined' && vscode.env.uiKind === vscode.UIKind.Web;
|
|
}
|