mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-01-30 01:25:38 -05:00
* Update deletion strings to refer to instances instead of resources * one more * Remove unused * More
215 lines
6.8 KiB
TypeScript
215 lines
6.8 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 { ResourceType } from 'arc';
|
|
import * as azurecore from 'azurecore';
|
|
import * as vscode from 'vscode';
|
|
import { ConnectionMode, IconPath, IconPathHelper } from '../constants';
|
|
import * as loc from '../localizedConstants';
|
|
|
|
export class UserCancelledError extends Error { }
|
|
|
|
/**
|
|
* Converts the resource type name into the localized Display Name for that type.
|
|
* @param resourceType The resource type name to convert
|
|
*/
|
|
export function resourceTypeToDisplayName(resourceType: string | undefined): string {
|
|
resourceType = resourceType || 'undefined';
|
|
switch (resourceType) {
|
|
case ResourceType.dataControllers:
|
|
return loc.dataControllersType;
|
|
case ResourceType.postgresInstances:
|
|
return loc.pgSqlType;
|
|
case ResourceType.sqlManagedInstances:
|
|
return loc.miaaType;
|
|
}
|
|
return resourceType;
|
|
}
|
|
|
|
export function parseEndpoint(endpoint?: string): { ip: string, port: string } {
|
|
endpoint = endpoint || '';
|
|
const separatorIndex = endpoint.indexOf(':');
|
|
return {
|
|
ip: endpoint.substr(0, separatorIndex),
|
|
port: endpoint.substr(separatorIndex + 1)
|
|
};
|
|
}
|
|
|
|
let azurecoreApi: azurecore.IExtension;
|
|
|
|
export async function getAzurecoreApi(): Promise<azurecore.IExtension> {
|
|
if (!azurecoreApi) {
|
|
azurecoreApi = await vscode.extensions.getExtension(azurecore.extension.name)?.activate();
|
|
if (!azurecoreApi) {
|
|
throw new Error('Unable to retrieve azurecore API');
|
|
}
|
|
}
|
|
return azurecoreApi;
|
|
}
|
|
|
|
/**
|
|
* Gets the IconPath for the specified resource type, or undefined if the type is unknown.
|
|
* @param resourceType The resource type
|
|
*/
|
|
export function getResourceTypeIcon(resourceType: string | undefined): IconPath | undefined {
|
|
switch (resourceType) {
|
|
case ResourceType.sqlManagedInstances:
|
|
return IconPathHelper.miaa;
|
|
case ResourceType.postgresInstances:
|
|
return IconPathHelper.postgres;
|
|
case ResourceType.dataControllers:
|
|
return IconPathHelper.controller;
|
|
}
|
|
return undefined;
|
|
}
|
|
|
|
/**
|
|
* Returns the text to display for known connection modes
|
|
* @param connectionMode The string repsenting the connection mode
|
|
*/
|
|
export function getConnectionModeDisplayText(connectionMode: string | undefined): string {
|
|
connectionMode = connectionMode ?? '';
|
|
switch (connectionMode) {
|
|
case ConnectionMode.direct:
|
|
return loc.direct;
|
|
case ConnectionMode.indirect:
|
|
return loc.indirect;
|
|
}
|
|
return connectionMode;
|
|
}
|
|
|
|
/**
|
|
* Gets the display text for the database state returned from querying the database.
|
|
* @param state The state value returned from the database
|
|
*/
|
|
export function getDatabaseStateDisplayText(state: string): string {
|
|
switch (state.toUpperCase()) {
|
|
case 'ONLINE':
|
|
return loc.online;
|
|
case 'OFFLINE':
|
|
return loc.offline;
|
|
case 'RESTORING':
|
|
return loc.restoring;
|
|
case 'RECOVERING':
|
|
return loc.recovering;
|
|
case 'RECOVERY PENDING':
|
|
return loc.recoveryPending;
|
|
case 'SUSPECT':
|
|
return loc.suspect;
|
|
case 'EMERGENCY':
|
|
return loc.emergency;
|
|
}
|
|
return state;
|
|
}
|
|
|
|
/**
|
|
* Opens an input box prompting and validating the user's input.
|
|
* @param options Options for the input box
|
|
* @param title An optional title for the input box
|
|
* @returns Promise resolving to the user's input if it passed validation,
|
|
* or undefined if the input box was closed for any other reason
|
|
*/
|
|
async function promptInputBox(title: string, options: vscode.InputBoxOptions): Promise<string> {
|
|
const inputBox = vscode.window.createInputBox();
|
|
inputBox.title = title;
|
|
inputBox.prompt = options.prompt;
|
|
inputBox.placeholder = options.placeHolder;
|
|
inputBox.password = options.password ?? false;
|
|
inputBox.value = options.value ?? '';
|
|
inputBox.ignoreFocusOut = options.ignoreFocusOut ?? false;
|
|
|
|
return new Promise(resolve => {
|
|
let valueAccepted = false;
|
|
inputBox.onDidAccept(async () => {
|
|
if (options.validateInput) {
|
|
const errorMessage = await options.validateInput(inputBox.value);
|
|
if (errorMessage) {
|
|
inputBox.validationMessage = errorMessage;
|
|
return;
|
|
}
|
|
}
|
|
valueAccepted = true;
|
|
inputBox.hide();
|
|
resolve(inputBox.value);
|
|
});
|
|
inputBox.onDidHide(() => {
|
|
if (!valueAccepted) {
|
|
resolve(undefined);
|
|
}
|
|
inputBox.dispose();
|
|
});
|
|
inputBox.onDidChangeValue(() => {
|
|
inputBox.validationMessage = '';
|
|
});
|
|
inputBox.show();
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Opens an input box prompting the user to enter in the name of an instance to delete
|
|
* @param name The name of the instance to delete
|
|
* @returns Promise resolving to true if the user confirmed the name, false if the input box was closed for any other reason
|
|
*/
|
|
export async function promptForInstanceDeletion(name: string): Promise<boolean> {
|
|
const title = loc.instanceDeletionWarning(name);
|
|
const options: vscode.InputBoxOptions = {
|
|
placeHolder: name,
|
|
validateInput: input => input !== name ? loc.invalidInstanceDeletionName(name) : ''
|
|
};
|
|
|
|
return await promptInputBox(title, options) !== undefined;
|
|
}
|
|
|
|
/**
|
|
* Opens an input box prompting the user to enter and confirm a password
|
|
* @param validate A function that accepts the password and returns an error message if it's invalid
|
|
* @returns Promise resolving to the password if it passed validation,
|
|
* or undefined if the input box was closed for any other reason
|
|
*/
|
|
export async function promptAndConfirmPassword(validate: (input: string) => string): Promise<string | undefined> {
|
|
const title = loc.resetPassword;
|
|
const options: vscode.InputBoxOptions = {
|
|
prompt: loc.enterNewPassword,
|
|
password: true,
|
|
validateInput: input => validate(input)
|
|
};
|
|
|
|
const password = await promptInputBox(title, options);
|
|
if (password) {
|
|
options.prompt = loc.confirmNewPassword;
|
|
options.validateInput = input => input !== password ? loc.thePasswordsDoNotMatch : '';
|
|
return promptInputBox(title, options);
|
|
}
|
|
|
|
return undefined;
|
|
}
|
|
|
|
/**
|
|
* Gets the message to display for a given error object that may be a variety of types.
|
|
* @param error The error object
|
|
*/
|
|
export function getErrorMessage(error: any): string {
|
|
return error.message ?? error;
|
|
}
|
|
|
|
/**
|
|
* Parses an address into its separate ip and port values. Address must be in the form <ip>:<port>
|
|
* @param address The address to parse
|
|
*/
|
|
export function parseIpAndPort(address: string): { ip: string, port: string } {
|
|
const sections = address.split(':');
|
|
if (sections.length !== 2) {
|
|
throw new Error(`Invalid address format for ${address}. Address must be in the form <ip>:<port>`);
|
|
}
|
|
return {
|
|
ip: sections[0],
|
|
port: sections[1]
|
|
};
|
|
}
|
|
|
|
export function createCredentialId(controllerId: string, resourceType: string, instanceName: string): string {
|
|
return `${controllerId}::${resourceType}::${instanceName}`;
|
|
}
|