mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-01-20 09:35:38 -05:00
* Added syncSecondaryToCommit to SQL update and create, as well as notebook, wizard, and compute+storage interfaces * Added readable secondaries and syncSecondaryToCommit to cost and SQL MI create * Added readable secondaries to notebook * removed resource-deployment changes Co-authored-by: Candice Ye <canye@microsoft.com>
121 lines
5.1 KiB
TypeScript
121 lines
5.1 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import * as arc from 'arc';
|
|
import * as rd from 'resource-deployment';
|
|
import * as vscode from 'vscode';
|
|
import { arcApi } from './common/api';
|
|
import { IconPathHelper, refreshActionId } from './constants';
|
|
import * as loc from './localizedConstants';
|
|
import { ArcControllersOptionsSourceProvider } from './providers/arcControllersOptionsSourceProvider';
|
|
import { ConnectToControllerDialog } from './ui/dialogs/connectControllerDialog';
|
|
import { AzureArcTreeDataProvider } from './ui/tree/azureArcTreeDataProvider';
|
|
import { ControllerTreeNode } from './ui/tree/controllerTreeNode';
|
|
import { TreeNode } from './ui/tree/treeNode';
|
|
import * as pricing from './common/pricingUtils';
|
|
import * as workspace from './common/workspaceUtils';
|
|
import { LogAnalyticsWorkspaceOptionsSourceProvider } from './providers/logAnalyticsWorkspaceOptionsSourceProvider';
|
|
|
|
export async function activate(context: vscode.ExtensionContext): Promise<arc.IExtension> {
|
|
IconPathHelper.setExtensionContext(context);
|
|
|
|
await vscode.commands.executeCommand('setContext', 'arc.loaded', false);
|
|
|
|
const treeDataProvider = new AzureArcTreeDataProvider(context);
|
|
vscode.window.registerTreeDataProvider('azureArc', treeDataProvider);
|
|
|
|
vscode.commands.registerCommand('arc.createController', async () => {
|
|
await vscode.commands.executeCommand('azdata.resource.deploy', 'arc-controller', ['arc-controller']);
|
|
});
|
|
|
|
vscode.commands.registerCommand('arc.connectToController', async () => {
|
|
const dialog = new ConnectToControllerDialog(treeDataProvider);
|
|
dialog.showDialog();
|
|
const model = await dialog.waitForClose();
|
|
if (model) {
|
|
await treeDataProvider.addOrUpdateController(model.controllerModel);
|
|
}
|
|
});
|
|
|
|
vscode.commands.registerCommand('arc.removeController', async (controllerNode: ControllerTreeNode) => {
|
|
await treeDataProvider.removeController(controllerNode);
|
|
});
|
|
|
|
vscode.commands.registerCommand(refreshActionId, async (treeNode: TreeNode) => {
|
|
treeDataProvider.refreshNode(treeNode);
|
|
});
|
|
|
|
vscode.commands.registerCommand('arc.openDashboard', async (treeNode: TreeNode) => {
|
|
await treeNode.openDashboard().catch(err => vscode.window.showErrorMessage(loc.openDashboardFailed(err)));
|
|
});
|
|
|
|
vscode.commands.registerCommand('arc.editConnection', async (treeNode: ControllerTreeNode) => {
|
|
const dialog = new ConnectToControllerDialog(treeDataProvider);
|
|
dialog.showDialog(treeNode.model.info);
|
|
const model = await dialog.waitForClose();
|
|
if (model) {
|
|
await treeDataProvider.addOrUpdateController(model.controllerModel, true);
|
|
}
|
|
});
|
|
|
|
// register option sources
|
|
const rdApi = <rd.IExtension>vscode.extensions.getExtension(rd.extension.name)?.exports;
|
|
context.subscriptions.push(rdApi.registerOptionsSourceProvider(new ArcControllersOptionsSourceProvider(treeDataProvider)));
|
|
context.subscriptions.push(rdApi.registerOptionsSourceProvider(new LogAnalyticsWorkspaceOptionsSourceProvider()));
|
|
|
|
// Register valueprovider for getting the Log Analytics workspace id from the workspace name.
|
|
context.subscriptions.push(rdApi.registerValueProvider({
|
|
id: 'workspace-name-to-id',
|
|
getValue: async (triggerFields: { [key: string]: rd.InputValueType }) => {
|
|
return workspace.getWorkspaceIdFromName(triggerFields);
|
|
}
|
|
}));
|
|
|
|
// Register valueprovider for getting the calculated cost per VCore.
|
|
context.subscriptions.push(rdApi.registerValueProvider({
|
|
id: 'params-to-cost-per-vcore',
|
|
getValue: async (mapping: { [key: string]: rd.InputValueType }) => {
|
|
return pricing.fullPriceForOneVCore(mapping);
|
|
}
|
|
}));
|
|
|
|
// Register valueprovider for getting the number of CPU VCores Limit input by the user.
|
|
context.subscriptions.push(rdApi.registerValueProvider({
|
|
id: 'params-to-vcore-limit',
|
|
getValue: async (mapping: { [key: string]: rd.InputValueType }) => {
|
|
return 'x ' + pricing.numCores(mapping).toString();
|
|
}
|
|
}));
|
|
|
|
// Register valueprovider for getting the number of billable replicas.
|
|
context.subscriptions.push(rdApi.registerValueProvider({
|
|
id: 'params-to-billable-replicas',
|
|
getValue: async (mapping: { [key: string]: rd.InputValueType }) => {
|
|
return 'x ' + pricing.numBillableReplicas(mapping).toString();
|
|
}
|
|
}));
|
|
|
|
// Register valueprovider for getting the amount of hybrid benefit discount to be applied.
|
|
context.subscriptions.push(rdApi.registerValueProvider({
|
|
id: 'params-to-hybrid-benefit-discount',
|
|
getValue: async (mapping: { [key: string]: rd.InputValueType }) => {
|
|
return '- ' + pricing.azureHybridBenefitDiscount(mapping).toString();
|
|
}
|
|
}));
|
|
|
|
// Register valueprovider for getting the total estimated cost.
|
|
context.subscriptions.push(rdApi.registerValueProvider({
|
|
id: 'params-to-estimated-cost',
|
|
getValue: async (mapping: { [key: string]: rd.InputValueType }) => {
|
|
return pricing.total(mapping).toString() + ' ' + loc.USD;
|
|
}
|
|
}));
|
|
|
|
return arcApi(treeDataProvider);
|
|
}
|
|
|
|
export function deactivate(): void {
|
|
}
|