mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-01-14 09:59:47 -05:00
* Enable notification for accounts change * Fixed bugs in extHostAccountManagement.test.ts * Fixed as commented: 1. Removed AccountWithProviderHandle 2. Use a private dictionary _accounts in ExtHostAccountManagement to cache all accounts and corresponding provider handles. 3. getSecurityToken gets provider handle from _accounts for specified account. 4. Added / changed unit tests for getAllAccounts & getSecurityToken
107 lines
4.1 KiB
TypeScript
107 lines
4.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.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
'use strict';
|
|
|
|
import * as sqlops from 'sqlops';
|
|
import { TPromise } from 'vs/base/common/winjs.base';
|
|
import { IAccountManagementService } from 'sql/services/accountManagement/interfaces';
|
|
import { dispose, IDisposable } from 'vs/base/common/lifecycle';
|
|
import {
|
|
ExtHostAccountManagementShape,
|
|
MainThreadAccountManagementShape,
|
|
SqlExtHostContext,
|
|
SqlMainContext
|
|
} from 'sql/workbench/api/node/sqlExtHost.protocol';
|
|
import { IExtHostContext } from 'vs/workbench/api/node/extHost.protocol';
|
|
import { extHostNamedCustomer } from 'vs/workbench/api/electron-browser/extHostCustomers';
|
|
import { UpdateAccountListEventParams } from 'sql/services/accountManagement/eventTypes';
|
|
|
|
@extHostNamedCustomer(SqlMainContext.MainThreadAccountManagement)
|
|
export class MainThreadAccountManagement implements MainThreadAccountManagementShape {
|
|
private _providerMetadata: { [handle: number]: sqlops.AccountProviderMetadata };
|
|
private _proxy: ExtHostAccountManagementShape;
|
|
private _toDispose: IDisposable[];
|
|
|
|
constructor(
|
|
extHostContext: IExtHostContext,
|
|
@IAccountManagementService private _accountManagementService: IAccountManagementService
|
|
) {
|
|
this._providerMetadata = {};
|
|
if (extHostContext) {
|
|
this._proxy = extHostContext.getProxy(SqlExtHostContext.ExtHostAccountManagement);
|
|
}
|
|
this._toDispose = [];
|
|
|
|
this._accountManagementService.updateAccountListEvent((e: UpdateAccountListEventParams) => {
|
|
if (!e) {
|
|
return;
|
|
}
|
|
|
|
const providerMetadataIndex = Object.values(this._providerMetadata).findIndex((providerMetadata: sqlops.AccountProviderMetadata) => providerMetadata.id === e.providerId);
|
|
if (providerMetadataIndex === -1) {
|
|
return;
|
|
}
|
|
|
|
const providerHandle = parseInt(Object.keys(this._providerMetadata)[providerMetadataIndex]);
|
|
this._proxy.$accountsChanged(providerHandle, e.accountList);
|
|
});
|
|
}
|
|
|
|
public $beginAutoOAuthDeviceCode(providerId: string, title: string, message: string, userCode: string, uri: string): Thenable<void> {
|
|
return this._accountManagementService.beginAutoOAuthDeviceCode(providerId, title, message, userCode, uri);
|
|
}
|
|
|
|
public $endAutoOAuthDeviceCode(): void {
|
|
return this._accountManagementService.endAutoOAuthDeviceCode();
|
|
}
|
|
|
|
$accountUpdated(updatedAccount: sqlops.Account): void {
|
|
this._accountManagementService.accountUpdated(updatedAccount);
|
|
}
|
|
|
|
public $getAccountsForProvider(providerId: string): Thenable<sqlops.Account[]> {
|
|
return this._accountManagementService.getAccountsForProvider(providerId);
|
|
}
|
|
|
|
public $registerAccountProvider(providerMetadata: sqlops.AccountProviderMetadata, handle: number): Thenable<any> {
|
|
let self = this;
|
|
|
|
// Create the account provider that interfaces with the extension via the proxy and register it
|
|
let accountProvider: sqlops.AccountProvider = {
|
|
autoOAuthCancelled(): Thenable<void> {
|
|
return self._proxy.$autoOAuthCancelled(handle);
|
|
},
|
|
clear(accountKey: sqlops.AccountKey): Thenable<void> {
|
|
return self._proxy.$clear(handle, accountKey);
|
|
},
|
|
getSecurityToken(account: sqlops.Account): Thenable<{}> {
|
|
return self._proxy.$getSecurityToken(account);
|
|
},
|
|
initialize(restoredAccounts: sqlops.Account[]): Thenable<sqlops.Account[]> {
|
|
return self._proxy.$initialize(handle, restoredAccounts);
|
|
},
|
|
prompt(): Thenable<sqlops.Account> {
|
|
return self._proxy.$prompt(handle);
|
|
},
|
|
refresh(account: sqlops.Account): Thenable<sqlops.Account> {
|
|
return self._proxy.$refresh(handle, account);
|
|
}
|
|
};
|
|
this._accountManagementService.registerProvider(providerMetadata, accountProvider);
|
|
this._providerMetadata[handle] = providerMetadata;
|
|
|
|
return TPromise.as(null);
|
|
}
|
|
|
|
public $unregisterAccountProvider(handle: number): Thenable<any> {
|
|
this._accountManagementService.unregisterProvider(this._providerMetadata[handle]);
|
|
return TPromise.as(null);
|
|
}
|
|
|
|
public dispose(): void {
|
|
this._toDispose = dispose(this._toDispose);
|
|
}
|
|
}
|