extension.ts 3.1 KB
Newer Older
1 2 3 4 5 6
/*---------------------------------------------------------------------------------------------
 *  Copyright (c) Microsoft Corporation. All rights reserved.
 *  Licensed under the MIT License. See License.txt in the project root for license information.
 *--------------------------------------------------------------------------------------------*/

import * as vscode from 'vscode';
7
import { AzureActiveDirectoryService, onDidChangeSessions } from './AADHelper';
8
import * as nls from 'vscode-nls';
9
import TelemetryReporter from 'vscode-extension-telemetry';
10 11

const localize = nls.loadMessageBundle();
12

13 14 15
export const DEFAULT_SCOPES = 'https://management.core.windows.net/.default offline_access';

export async function activate(context: vscode.ExtensionContext) {
16 17
	const { name, version, aiKey } = require('../package.json') as { name: string, version: string, aiKey: string };
	const telemetryReporter = new TelemetryReporter(name, version, aiKey);
18 19 20 21 22

	const loginService = new AzureActiveDirectoryService();

	await loginService.initialize();

23
	context.subscriptions.push(vscode.authentication.registerAuthenticationProvider({
24
		id: 'microsoft',
25
		displayName: 'Microsoft',
26 27
		onDidChangeSessions: onDidChangeSessions.event,
		getSessions: () => Promise.resolve(loginService.sessions),
28
		login: async (scopes: string[]) => {
29 30
			try {
				telemetryReporter.sendTelemetryEvent('login');
31
				await loginService.login(scopes.sort().join(' '));
32 33 34 35 36 37 38
				const session = loginService.sessions[loginService.sessions.length - 1];
				onDidChangeSessions.fire({ added: [session.id], removed: [], changed: [] });
				return loginService.sessions[0]!;
			} catch (e) {
				telemetryReporter.sendTelemetryEvent('loginFailed');
				throw e;
			}
39 40
		},
		logout: async (id: string) => {
41 42 43 44 45 46 47
			try {
				telemetryReporter.sendTelemetryEvent('logout');
				await loginService.logout(id);
				onDidChangeSessions.fire({ added: [], removed: [id], changed: [] });
			} catch (e) {
				telemetryReporter.sendTelemetryEvent('logoutFailed');
			}
48
		}
49 50 51 52 53 54 55 56 57 58 59 60 61
	}));

	context.subscriptions.push(vscode.commands.registerCommand('microsoft.signin', () => {
		return loginService.login(DEFAULT_SCOPES);
	}));

	context.subscriptions.push(vscode.commands.registerCommand('microsoft.signout', async () => {
		const sessions = loginService.sessions;
		if (sessions.length === 0) {
			return;
		}

		if (sessions.length === 1) {
62 63 64
			const id = loginService.sessions[0].id;
			await loginService.logout(id);
			onDidChangeSessions.fire({ added: [], removed: [id], changed: [] });
65
			vscode.window.showInformationMessage(localize('signedOut', "Successfully signed out."));
66 67 68 69 70 71
			return;
		}

		const selectedSession = await vscode.window.showQuickPick(sessions.map(session => {
			return {
				id: session.id,
72
				label: session.account.displayName
73 74 75 76 77
			};
		}));

		if (selectedSession) {
			await loginService.logout(selectedSession.id);
78
			onDidChangeSessions.fire({ added: [], removed: [selectedSession.id], changed: [] });
79
			vscode.window.showInformationMessage(localize('signedOut', "Successfully signed out."));
80 81 82
			return;
		}
	}));
83 84 85 86 87 88

	return;
}

// this method is called when your extension is deactivated
export function deactivate() { }