mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-06 17:23:53 -05:00
* Fix project context menu actions (#12541) * delete works again * make fewer changes * update all sql db project commands * cleanup * Remove old projects view (#12563) * remove old projects view from file explorer view * fix tests failing * remove projects in open folder opening up in old view * Update db reference dialog to show projects in the workspace (#12580) * update database reference dialog to show projects in the workspace in the project dropdown * remove workspace stuff from sql projects extension * undo change * add class that implements IExtension * undo a change * update DataWorkspaceExtension to take workspaceService as a parameter * add type * Update sql database project commands (#12595) * remove sql proj's open and create new project from comman palette * hook up create project from database to data workspace * rename the remaining import databases to create project from database * remove open, new, and close commands * expose addProjectsToWorkspace() in IExtension instead of calling command * Addressing comments * fix failing sql project tests (#12651) * update SSDT projects opened in projects viewlet (#12669) * fix action not refreshing the tree issue (#12692) * fix adding project references in new projects viewlet (#12688) * Remove old projects tree provider (#12702) * Remove old projects tree provider and fix tests * formatting * update refreshProjectsTree() to accept workspaceTreeItem() * Cleanup ProjectsController (#12718) * remove openProject from ProjectController and some cleanup * rename * add project and open project dialogs (#12729) * empty dialogs * wip * new project dialog implementation * revert gitattributes * open project dialog * implement add project * remove icon helper * refactor * revert script change * adjust views * more updates * make data-workspace a builtin extension * show the view only when project provider is detected (#12819) * only show the view when proj provider is available * update * fix sql project tests after merge (#12793) * Update dialogs to be closer to mockups (#12879) * small UI changes to dialogs * center radio card group text * Create workspace if needed when opening/new project (#12930) * empty dialogs * wip * new project dialog implementation * revert gitattributes * open project dialog * implement add project * remove icon helper * refactor * revert script change * create workspace * initial changes * create new workspace working * fix tests * cleanup * remove showWorkspaceRequiredNotification() * Add test for no workspace open * update blue buttons * move loading temp project to activate() instead of workspaceService constructor * move workspace creation warning message to before project is created * pass uri to createWorkspace * add tests Co-authored-by: Alan Ren <alanren@microsoft.com> * Additional create workspace changes (#13004) * Dialogs workspace updates (#13010) * adding workspace text boxes * match new project dialog to mockups * Add validation error message for workspace file * add enterWorkspace api * add warning message for opening workspace * cleanup * update commands to remove project so they're more generic * remove 'empty' from string * Move default project location setting to data workspace extension (#13022) * remove project location setting and notification from sql database projects extension * add default project location setting to data workspace extension * fix typo * Add back project name incrementing * other merge fixes * fix strings from other PR * default to last opened directory instead of home directory if no specified default location * A few small updates (#13092) * fix build error * update title for inputboxes * add missing file * Add tests for data workspace dialogs (#13324) * add tests for dialogs * create helper functions * New project dialog workspace inputbox fixes (#13407) * workspace inputbox fixes * fix folder icons * Update package.jsons and readme (#13451) * update package.jsons * update readme * add workspace information to open existing dialog (#13455) Co-authored-by: Alan Ren <alanren@microsoft.com>
134 lines
6.8 KiB
TypeScript
134 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 * as mssql from '../mssql';
|
|
import { AppContext } from '../appContext';
|
|
import { ISqlOpsFeature, SqlOpsDataClient } from 'dataprotocol-client';
|
|
import { ClientCapabilities } from 'vscode-languageclient';
|
|
import * as constants from '../constants';
|
|
import * as Utils from '../utils';
|
|
import * as azdata from 'azdata';
|
|
import * as contracts from '../contracts';
|
|
|
|
export class DacFxService implements mssql.IDacFxService {
|
|
public static asFeature(context: AppContext): ISqlOpsFeature {
|
|
return class extends DacFxService {
|
|
constructor(client: SqlOpsDataClient) {
|
|
super(context, client);
|
|
}
|
|
|
|
fillClientCapabilities(capabilities: ClientCapabilities): void {
|
|
Utils.ensure(capabilities, 'dacfx')!.dacfx = true;
|
|
}
|
|
|
|
initialize(): void {
|
|
}
|
|
};
|
|
}
|
|
|
|
private constructor(context: AppContext, protected readonly client: SqlOpsDataClient) {
|
|
context.registerService(constants.DacFxService, this);
|
|
}
|
|
|
|
public exportBacpac(databaseName: string, packageFilePath: string, ownerUri: string, taskExecutionMode: azdata.TaskExecutionMode): Thenable<mssql.DacFxResult> {
|
|
const params: contracts.ExportParams = { databaseName: databaseName, packageFilePath: packageFilePath, ownerUri: ownerUri, taskExecutionMode: taskExecutionMode };
|
|
return this.client.sendRequest(contracts.ExportRequest.type, params).then(
|
|
undefined,
|
|
e => {
|
|
this.client.logFailedRequest(contracts.ExportRequest.type, e);
|
|
return Promise.resolve(undefined);
|
|
}
|
|
);
|
|
}
|
|
|
|
public importBacpac(packageFilePath: string, databaseName: string, ownerUri: string, taskExecutionMode: azdata.TaskExecutionMode): Thenable<mssql.DacFxResult> {
|
|
const params: contracts.ImportParams = { packageFilePath: packageFilePath, databaseName: databaseName, ownerUri: ownerUri, taskExecutionMode: taskExecutionMode };
|
|
return this.client.sendRequest(contracts.ImportRequest.type, params).then(
|
|
undefined,
|
|
e => {
|
|
this.client.logFailedRequest(contracts.ImportRequest.type, e);
|
|
return Promise.resolve(undefined);
|
|
}
|
|
);
|
|
}
|
|
|
|
public extractDacpac(databaseName: string, packageFilePath: string, applicationName: string, applicationVersion: string, ownerUri: string, taskExecutionMode: azdata.TaskExecutionMode): Thenable<mssql.DacFxResult> {
|
|
const params: contracts.ExtractParams = { databaseName: databaseName, packageFilePath: packageFilePath, applicationName: applicationName, applicationVersion: applicationVersion, ownerUri: ownerUri, extractTarget: mssql.ExtractTarget.dacpac, taskExecutionMode: taskExecutionMode };
|
|
return this.client.sendRequest(contracts.ExtractRequest.type, params).then(
|
|
undefined,
|
|
e => {
|
|
this.client.logFailedRequest(contracts.ExtractRequest.type, e);
|
|
return Promise.resolve(undefined);
|
|
}
|
|
);
|
|
}
|
|
|
|
public createProjectFromDatabase(databaseName: string, targetFilePath: string, applicationName: string, applicationVersion: string, ownerUri: string, extractTarget: mssql.ExtractTarget, taskExecutionMode: azdata.TaskExecutionMode): Thenable<mssql.DacFxResult> {
|
|
const params: contracts.ExtractParams = { databaseName: databaseName, packageFilePath: targetFilePath, applicationName: applicationName, applicationVersion: applicationVersion, ownerUri: ownerUri, extractTarget: extractTarget, taskExecutionMode: taskExecutionMode };
|
|
return this.client.sendRequest(contracts.ExtractRequest.type, params).then(
|
|
undefined,
|
|
e => {
|
|
this.client.logFailedRequest(contracts.ExtractRequest.type, e);
|
|
return Promise.resolve(undefined);
|
|
}
|
|
);
|
|
}
|
|
|
|
public deployDacpac(packageFilePath: string, targetDatabaseName: string, upgradeExisting: boolean, ownerUri: string, taskExecutionMode: azdata.TaskExecutionMode, sqlCommandVariableValues?: Record<string, string>, deploymentOptions?: mssql.DeploymentOptions): Thenable<mssql.DacFxResult> {
|
|
const params: contracts.DeployParams = { packageFilePath: packageFilePath, databaseName: targetDatabaseName, upgradeExisting: upgradeExisting, sqlCommandVariableValues: sqlCommandVariableValues, deploymentOptions: deploymentOptions, ownerUri: ownerUri, taskExecutionMode: taskExecutionMode };
|
|
return this.client.sendRequest(contracts.DeployRequest.type, params).then(
|
|
undefined,
|
|
e => {
|
|
this.client.logFailedRequest(contracts.DeployRequest.type, e);
|
|
return Promise.resolve(undefined);
|
|
}
|
|
);
|
|
}
|
|
|
|
public generateDeployScript(packageFilePath: string, targetDatabaseName: string, ownerUri: string, taskExecutionMode: azdata.TaskExecutionMode, sqlCommandVariableValues?: Record<string, string>, deploymentOptions?: mssql.DeploymentOptions): Thenable<mssql.DacFxResult> {
|
|
const params: contracts.GenerateDeployScriptParams = { packageFilePath: packageFilePath, databaseName: targetDatabaseName, sqlCommandVariableValues: sqlCommandVariableValues, deploymentOptions: deploymentOptions, ownerUri: ownerUri, taskExecutionMode: taskExecutionMode };
|
|
return this.client.sendRequest(contracts.GenerateDeployScriptRequest.type, params).then(
|
|
undefined,
|
|
e => {
|
|
this.client.logFailedRequest(contracts.GenerateDeployScriptRequest.type, e);
|
|
return Promise.resolve(undefined);
|
|
}
|
|
);
|
|
}
|
|
|
|
public generateDeployPlan(packageFilePath: string, targetDatabaseName: string, ownerUri: string, taskExecutionMode: azdata.TaskExecutionMode): Thenable<mssql.GenerateDeployPlanResult> {
|
|
const params: contracts.GenerateDeployPlanParams = { packageFilePath: packageFilePath, databaseName: targetDatabaseName, ownerUri: ownerUri, taskExecutionMode: taskExecutionMode };
|
|
return this.client.sendRequest(contracts.GenerateDeployPlanRequest.type, params).then(
|
|
undefined,
|
|
e => {
|
|
this.client.logFailedRequest(contracts.GenerateDeployPlanRequest.type, e);
|
|
return Promise.resolve(undefined);
|
|
}
|
|
);
|
|
}
|
|
|
|
public getOptionsFromProfile(profilePath: string): Thenable<mssql.DacFxOptionsResult> {
|
|
const params: contracts.GetOptionsFromProfileParams = { profilePath: profilePath };
|
|
return this.client.sendRequest(contracts.GetOptionsFromProfileRequest.type, params).then(
|
|
undefined,
|
|
e => {
|
|
this.client.logFailedRequest(contracts.GetOptionsFromProfileRequest.type, e);
|
|
return Promise.resolve(undefined);
|
|
}
|
|
);
|
|
}
|
|
|
|
public validateStreamingJob(packageFilePath: string, createStreamingJobTsql: string): Thenable<mssql.ValidateStreamingJobResult> {
|
|
const params: contracts.ValidateStreamingJobParams = { packageFilePath: packageFilePath, createStreamingJobTsql: createStreamingJobTsql };
|
|
return this.client.sendRequest(contracts.ValidateStreamingJobRequest.type, params).then(
|
|
undefined,
|
|
e => {
|
|
this.client.logFailedRequest(contracts.ValidateStreamingJobRequest.type, e);
|
|
return Promise.resolve(undefined);
|
|
}
|
|
);
|
|
}
|
|
}
|