mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-01-20 09:35:38 -05:00
* Build breaks 1 * Build breaks * Build breaks * Build breaks * More build breaks * Build breaks (#2512) * Runtime breaks * Build breaks * Fix dialog location break * Update typescript * Fix ASAR break issue * Unit test breaks * Update distro * Fix breaks in ADO builds (#2513) * Bump to node 16 * Fix hygiene errors * Bump distro * Remove reference to node type * Delete vscode specific extension * Bump to node 16 in CI yaml * Skip integration tests in CI builds (while fixing) * yarn.lock update * Bump moment dependency in remote yarn * Fix drop-down chevron style * Bump to node 16 * Remove playwrite from ci.yaml * Skip building build scripts in hygine check
71 lines
2.4 KiB
TypeScript
71 lines
2.4 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 vscode from 'vscode';
|
|
import { AzureActiveDirectoryService, onDidChangeSessions } from './AADHelper';
|
|
import TelemetryReporter from 'vscode-extension-telemetry';
|
|
|
|
export async function activate(context: vscode.ExtensionContext) {
|
|
const { name, version, aiKey } = context.extension.packageJSON as { name: string, version: string, aiKey: string };
|
|
const telemetryReporter = new TelemetryReporter(name, version, aiKey);
|
|
|
|
const loginService = new AzureActiveDirectoryService(context);
|
|
context.subscriptions.push(loginService);
|
|
|
|
await loginService.initialize();
|
|
|
|
context.subscriptions.push(vscode.authentication.registerAuthenticationProvider('microsoft', 'Microsoft', {
|
|
onDidChangeSessions: onDidChangeSessions.event,
|
|
getSessions: (scopes: string[]) => loginService.getSessions(scopes),
|
|
createSession: async (scopes: string[]) => {
|
|
try {
|
|
/* __GDPR__
|
|
"login" : {
|
|
"scopes": { "classification": "PublicNonPersonalData", "purpose": "FeatureInsight" }
|
|
}
|
|
*/
|
|
telemetryReporter.sendTelemetryEvent('login', {
|
|
// Get rid of guids from telemetry.
|
|
scopes: JSON.stringify(scopes.map(s => s.replace(/[0-9A-F]{8}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{12}/i, '{guid}'))),
|
|
});
|
|
|
|
const session = await loginService.createSession(scopes.sort().join(' '));
|
|
onDidChangeSessions.fire({ added: [session], removed: [], changed: [] });
|
|
return session;
|
|
} catch (e) {
|
|
/* __GDPR__
|
|
"loginFailed" : { }
|
|
*/
|
|
telemetryReporter.sendTelemetryEvent('loginFailed');
|
|
|
|
throw e;
|
|
}
|
|
},
|
|
removeSession: async (id: string) => {
|
|
try {
|
|
/* __GDPR__
|
|
"logout" : { }
|
|
*/
|
|
telemetryReporter.sendTelemetryEvent('logout');
|
|
|
|
const session = await loginService.removeSession(id);
|
|
if (session) {
|
|
onDidChangeSessions.fire({ added: [], removed: [session], changed: [] });
|
|
}
|
|
} catch (e) {
|
|
/* __GDPR__
|
|
"logoutFailed" : { }
|
|
*/
|
|
telemetryReporter.sendTelemetryEvent('logoutFailed');
|
|
}
|
|
}
|
|
}, { supportsMultipleAccounts: true }));
|
|
|
|
return;
|
|
}
|
|
|
|
// this method is called when your extension is deactivated
|
|
export function deactivate() { }
|