/*--------------------------------------------------------------------------------------------- * Copyright (c) Microsoft Corporation. All rights reserved. * Licensed under the Source EULA. See License.txt in the project root for license information. *--------------------------------------------------------------------------------------------*/ 'use strict'; import { createMainContextProxyIdentifier as createMainId, createExtHostContextProxyIdentifier as createExtId, ProxyIdentifier, IThreadService } from 'vs/workbench/services/thread/common/threadService'; import * as data from 'data'; import { TPromise } from 'vs/base/common/winjs.base'; import { IDisposable } from 'vs/base/common/lifecycle'; export abstract class ExtHostAccountManagementShape { $autoOAuthCancelled(handle: number): Thenable { throw ni(); } $clear(handle: number, accountKey: data.AccountKey): Thenable { throw ni(); } $getSecurityToken(handle: number, account: data.Account): Thenable<{}> { throw ni(); } $initialize(handle: number, restoredAccounts: data.Account[]): Thenable { throw ni(); } $prompt(handle: number): Thenable { throw ni(); } $refresh(handle: number, account: data.Account): Thenable { throw ni(); } } export abstract class ExtHostDataProtocolShape { /** * Establish a connection to a data source using the provided ConnectionInfo instance. */ $connect(handle: number, connectionUri: string, connection: data.ConnectionInfo): Thenable { throw ni(); } /** * Disconnect from a data source using the provided connectionUri string. */ $disconnect(handle: number, connectionUri: string): Thenable { throw ni(); } /** * Cancel a connection to a data source using the provided connectionUri string. */ $cancelConnect(handle: number, connectionUri: string): Thenable { throw ni(); } /** * Change the database for the connection. */ $changeDatabase(handle: number, connectionUri: string, newDatabase: string): Thenable { throw ni(); } /** * List databases for a data source using the provided connectionUri string. * @param handle the handle to use when looking up a provider * @param connectionUri URI identifying a connected resource */ $listDatabases(handle: number, connectionUri: string): Thenable { throw ni(); } /** * Notifies all listeners on the Extension Host side that a language change occurred * for a dataprotocol language. The sub-flavor is the specific implementation used for query * and other events * @param params information on what URI was changed and the new language */ $languageFlavorChanged(params: data.DidChangeLanguageFlavorParams): void { throw ni(); } /** * Callback when a connection request has completed */ $onConnectComplete(handle: number, connectionInfoSummary: data.ConnectionInfoSummary): void { throw ni(); } /** * Callback when a IntelliSense cache has been built */ $onIntelliSenseCacheComplete(handle: number, connectionUri: string): void { throw ni(); } $getServerCapabilities(handle: number, client: data.DataProtocolClientCapabilities): Thenable { throw ni(); } /** * Metadata service methods * */ $getMetadata(handle: number, connectionUri: string): Thenable { throw ni(); } $getDatabases(handle: number, connectionUri: string): Thenable { throw ni(); } $getTableInfo(handle: number, connectionUri: string, metadata: data.ObjectMetadata): Thenable { throw ni(); } $getViewInfo(handle: number, connectionUri: string, metadata: data.ObjectMetadata): Thenable { throw ni(); } /** * Object Explorer */ $createObjectExplorerSession(handle: number, connInfo: data.ConnectionInfo): Thenable { throw ni(); } $expandObjectExplorerNode(handle: number, nodeInfo: data.ExpandNodeInfo): Thenable { throw ni(); } $refreshObjectExplorerNode(handle: number, nodeInfo: data.ExpandNodeInfo): Thenable { throw ni(); } $closeObjectExplorerSession(handle: number, closeSessionInfo: data.ObjectExplorerCloseSessionInfo): Thenable { throw ni(); } /** * Tasks */ $getAllTasks(handle: number, listTasksParams: data.ListTasksParams): Thenable { throw ni(); } $cancelTask(handle: number, cancelTaskParams: data.CancelTaskParams): Thenable { throw ni(); } /** * Scripting methods */ $scriptAsOperation(handle: number, connectionUri: string, operation: data.ScriptOperation, metadata: data.ObjectMetadata, paramDetails: data.ScriptingParamDetails): Thenable { throw ni(); } /** * Cancels the currently running query for a URI */ $cancelQuery(handle: number, ownerUri: string): Thenable { throw ni(); } /** * Runs a query for a text selection inside a document */ $runQuery(handle: number, ownerUri: string, selection: data.ISelectionData, runOptions?: data.ExecutionPlanOptions): Thenable { throw ni(); } /** * Runs the current SQL statement query for a text document */ $runQueryStatement(handle: number, ownerUri: string, line: number, column: number): Thenable { throw ni(); } /** * Runs a query for a provided query */ $runQueryString(handle: number, ownerUri: string, queryString: string): Thenable { throw ni(); } /** * Runs a query for a provided query and returns result */ $runQueryAndReturn(handle: number, ownerUri: string, queryString: string): Thenable { throw ni(); } /** * Gets a subset of rows in a result set in order to display in the UI */ $getQueryRows(handle: number, rowData: data.QueryExecuteSubsetParams): Thenable { throw ni(); } /** * Disposes the cached information regarding a query */ $disposeQuery(handle: number, ownerUri: string): Thenable { throw ni(); } /** * Refreshes the IntelliSense cache */ $rebuildIntelliSenseCache(handle: number, ownerUri: string): Thenable { throw ni(); } /** * Callback when a query has completed */ $onQueryComplete(handle: number, result: data.QueryExecuteCompleteNotificationResult): void { throw ni(); } /** * Callback when a batch has started. This enables the UI to display when batch execution has started */ $onBatchStart(handle: number, batchInfo: data.QueryExecuteBatchNotificationParams): void { throw ni(); } /** * Callback when a batch is complete. This includes updated information on result sets, time to execute, and * other relevant batch information */ $onBatchComplete(handle: number, batchInfo: data.QueryExecuteBatchNotificationParams): void { throw ni(); } /** * Callback when a result set has been returned from query execution and can be displayed */ $onResultSetComplete(handle: number, resultSetInfo: data.QueryExecuteResultSetCompleteNotificationParams): void { throw ni(); } /** * Callback when a message generated during query execution is issued */ $onQueryMessage(handle: number, message: data.QueryExecuteMessageParams): void { throw ni(); } /** * Requests saving of the results from a result set into a specific format (CSV, JSON, Excel) */ $saveResults(handle: number, requestParams: data.SaveResultsRequestParams): Thenable { throw ni(); } /** * Commits all pending edits in an edit session */ $commitEdit(handle: number, ownerUri: string): Thenable { throw ni(); } /** * Creates a new row in the edit session */ $createRow(handle: number, ownerUri: string): Thenable { throw ni(); } /** * Marks the selected row for deletion in the edit session */ $deleteRow(handle: number, ownerUri: string, rowId: number): Thenable { throw ni(); } /** * Initializes a new edit data session for the requested table/view */ $initializeEdit(handle: number, ownerUri: string, schemaName: string, objectName: string, objectType: string, rowLimit: number): Thenable { throw ni(); } /** * Reverts any pending changes for the requested cell and returns the original value */ $revertCell(handle: number, ownerUri: string, rowId: number, columnId: number): Thenable { throw ni(); } /** * Reverts any pending changes for the requested row */ $revertRow(handle: number, ownerUri: string, rowId: number): Thenable { throw ni(); } /** * Updates a cell value in the requested row. Returns if there are any corrections to the value */ $updateCell(handle: number, ownerUri: string, rowId: number, columId: number, newValue: string): Thenable { throw ni(); } /** * Gets a subset of rows in a result set, merging pending edit changes in order to display in the UI */ $getEditRows(handle: number, rowData: data.EditSubsetParams): Thenable { throw ni(); } /** * Diposes an initialized edit session and cleans up pending edits */ $disposeEdit(handle: number, ownerUri: string): Thenable { throw ni(); } /** * Create a new database on the provided connection */ $createDatabase(handle: number, connectionUri: string, database: data.DatabaseInfo): Thenable { throw ni(); } /** * Get the default database prototype */ $getDefaultDatabaseInfo(handle: number, connectionUri: string): Thenable { throw ni(); } /** * Get the database info */ $getDatabaseInfo(handle: number, connectionUri: string): Thenable { throw ni(); } /** * Create a new login on the provided connection */ $createLogin(handle: number, connectionUri: string, login: data.LoginInfo): Thenable { throw ni(); } /** * Backup a database */ $backup(handle: number, connectionUri: string, backupInfo: { [key: string]: any }, taskExecutionMode: data.TaskExecutionMode): Thenable { throw ni(); } /** * Get the extended database prototype */ $getBackupConfigInfo(handle: number, connectionUri: string): Thenable { throw ni(); } /** * Restores a database */ $restore(handle: number, connectionUri: string, restoreInfo: data.RestoreInfo): Thenable { throw ni(); } /** * Gets a plan for restoring a database */ $getRestorePlan(handle: number, connectionUri: string, restoreInfo: data.RestoreInfo): Thenable { throw ni(); } /** * Cancels a plan */ $cancelRestorePlan(handle: number, connectionUri: string, restoreInfo: data.RestoreInfo): Thenable { throw ni(); } /** * Gets restore config Info */ $getRestoreConfigInfo(handle: number, connectionUri: string): Thenable { throw ni(); } /** * Open a file browser */ $openFileBrowser(handle: number, ownerUri: string, expandPath: string, fileFilters: string[], changeFilter: boolean): Thenable { throw ni(); } /** * Expand a folder node */ $expandFolderNode(handle: number, ownerUri: string, expandPath: string): Thenable { throw ni(); } /** * Validate selected file paths */ $validateFilePaths(handle: number, ownerUri: string, serviceType: string, selectedFiles: string[]): Thenable { throw ni(); } /** * Close file browser */ $closeFileBrowser(handle: number, ownerUri: string): Thenable { throw ni(); } /** * Profiler Provider methods */ /** * Start a profiler session */ $startSession(handle: number, sessionId: string): Thenable { throw ni(); } /** * Stop a profiler session */ $stopSession(handle: number, sessionId: string): Thenable { throw ni(); } } /** * ResourceProvider extension host class. */ export abstract class ExtHostResourceProviderShape { /** * Create a firewall rule */ $createFirewallRule(handle: number, account: data.Account, firewallRuleInfo: data.FirewallRuleInfo): Thenable { throw ni(); } /** * Handle firewall rule */ $handleFirewallRule(handle: number, errorCode: number, errorMessage: string, connectionTypeId: string): Thenable { throw ni(); } } /** * Credential Management extension host class. */ export abstract class ExtHostCredentialManagementShape { $saveCredential(credentialId: string, password: string): Thenable { throw ni(); } $readCredential(credentialId: string): Thenable { throw ni(); } $deleteCredential(credentialId: string): Thenable { throw ni(); } } /** * Serialization provider extension host class. */ export abstract class ExtHostSerializationProviderShape { $saveAs(saveFormat: string, savePath: string, results: string, appendToFile: boolean): Thenable { throw ni(); } } export interface MainThreadAccountManagementShape extends IDisposable { $registerAccountProvider(providerMetadata: data.AccountProviderMetadata, handle: number): Thenable; $unregisterAccountProvider(handle: number): Thenable; $beginAutoOAuthDeviceCode(providerId: string, title: string, message: string, userCode: string, uri: string): Thenable; $endAutoOAuthDeviceCode(): void; $accountUpdated(updatedAccount: data.Account): void; } export interface MainThreadResourceProviderShape extends IDisposable { $registerResourceProvider(providerMetadata: data.ResourceProviderMetadata, handle: number): Thenable; $unregisterResourceProvider(handle: number): Thenable; } export interface MainThreadDataProtocolShape extends IDisposable { $registerConnectionProvider(providerId: string, handle: number): TPromise; $registerBackupProvider(providerId: string, handle: number): TPromise; $registerRestoreProvider(providerId: string, handle: number): TPromise; $registerScriptingProvider(providerId: string, handle: number): TPromise; $registerQueryProvider(providerId: string, handle: number): TPromise; $registerProfilerProvider(providerId: string, handle: number): TPromise; $registerObjectExplorerProvider(providerId: string, handle: number): TPromise; $registerMetadataProvider(providerId: string, handle: number): TPromise; $registerTaskServicesProvider(providerId: string, handle: number): TPromise; $registerFileBrowserProvider(providerId: string, handle: number): TPromise; $registerCapabilitiesServiceProvider(providerId: string, handle: number): TPromise; $registerAdminServicesProvider(providerId: string, handle: number): TPromise; $unregisterProvider(handle: number): TPromise; $onConnectionComplete(handle: number, connectionInfoSummary: data.ConnectionInfoSummary): void; $onIntelliSenseCacheComplete(handle: number, connectionUri: string): void; $onConnectionChangeNotification(handle: number, changedConnInfo: data.ChangedConnectionInfo): void; $onQueryComplete(handle: number, result: data.QueryExecuteCompleteNotificationResult): void; $onBatchStart(handle: number, batchInfo: data.QueryExecuteBatchNotificationParams): void; $onBatchComplete(handle: number, batchInfo: data.QueryExecuteBatchNotificationParams): void; $onResultSetComplete(handle: number, resultSetInfo: data.QueryExecuteResultSetCompleteNotificationParams): void; $onQueryMessage(handle: number, message: data.QueryExecuteMessageParams): void; $onObjectExplorerSessionCreated(handle: number, message: data.ObjectExplorerSession): void; $onObjectExplorerNodeExpanded(handle: number, message: data.ObjectExplorerExpandInfo): void; $onTaskCreated(handle: number, sessionResponse: data.TaskInfo): void; $onTaskStatusChanged(handle: number, sessionResponse: data.TaskProgressInfo): void; $onFileBrowserOpened(handle: number, response: data.FileBrowserOpenedParams): void; $onFolderNodeExpanded(handle: number, response: data.FileBrowserExpandedParams): void; $onFilePathsValidated(handle: number, response: data.FileBrowserValidatedParams): void; $onScriptingComplete(handle: number, message: data.ScriptingCompleteResult): void; $onSessionEventsAvailable(handle: number, response: data.ProfilerSessionEvents): void; /** * Callback when a session has completed initialization */ $onEditSessionReady(handle: number, ownerUri: string, success: boolean, message: string); } export interface MainThreadCredentialManagementShape extends IDisposable { $registerCredentialProvider(handle: number): TPromise; $unregisterCredentialProvider(handle: number): TPromise; } export interface MainThreadSerializationProviderShape extends IDisposable { $registerSerializationProvider(handle: number): TPromise; $unregisterSerializationProvider(handle: number): TPromise; } function ni() { return new Error('Not implemented'); } // --- proxy identifiers export const SqlMainContext = { // SQL entries MainThreadAccountManagement: createMainId('MainThreadAccountManagement'), MainThreadCredentialManagement: createMainId('MainThreadCredentialManagement'), MainThreadDataProtocol: createMainId('MainThreadDataProtocol'), MainThreadSerializationProvider: createMainId('MainThreadSerializationProvider'), MainThreadResourceProvider: createMainId('MainThreadResourceProvider'), MainThreadModalDialog: createMainId('MainThreadModalDialog'), }; export const SqlExtHostContext = { ExtHostAccountManagement: createExtId('ExtHostAccountManagement'), ExtHostCredentialManagement: createExtId('ExtHostCredentialManagement'), ExtHostDataProtocol: createExtId('ExtHostDataProtocol'), ExtHostSerializationProvider: createExtId('ExtHostSerializationProvider'), ExtHostResourceProvider: createExtId('ExtHostResourceProvider'), ExtHostModalDialogs: createExtId('ExtHostModalDialogs') }; export interface MainThreadModalDialogShape extends IDisposable { $createDialog(handle: number): void; $disposeDialog(handle: number): void; $show(handle: number): void; $setTitle(handle: number, value: string): void; $setHtml(handle: number, value: string): void; $sendMessage(handle: number, value: any): Thenable; } export interface ExtHostModalDialogsShape { $onMessage(handle: number, message: any): void; $onClosed(handle: number): void; }