mirror of https://git.tuxpa.in/a/code-server.git
80 lines
2.6 KiB
TypeScript
80 lines
2.6 KiB
TypeScript
|
/*---------------------------------------------------------------------------------------------
|
||
|
* 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';
|
||
|
import { GitHubAuthenticationProvider, onDidChangeSessions } from './github';
|
||
|
import { uriHandler } from './githubServer';
|
||
|
import Logger from './common/logger';
|
||
|
import TelemetryReporter from 'vscode-extension-telemetry';
|
||
|
|
||
|
export async function activate(context: vscode.ExtensionContext) {
|
||
|
const { name, version, aiKey } = require('../package.json') as { name: string, version: string, aiKey: string };
|
||
|
const telemetryReporter = new TelemetryReporter(name, version, aiKey);
|
||
|
|
||
|
context.subscriptions.push(vscode.window.registerUriHandler(uriHandler));
|
||
|
const loginService = new GitHubAuthenticationProvider();
|
||
|
|
||
|
await loginService.initialize(context);
|
||
|
|
||
|
context.subscriptions.push(vscode.commands.registerCommand('github.provide-token', () => {
|
||
|
return loginService.manuallyProvideToken();
|
||
|
}));
|
||
|
|
||
|
context.subscriptions.push(vscode.authentication.registerAuthenticationProvider({
|
||
|
id: 'github',
|
||
|
label: 'GitHub',
|
||
|
supportsMultipleAccounts: false,
|
||
|
onDidChangeSessions: onDidChangeSessions.event,
|
||
|
getSessions: () => Promise.resolve(loginService.sessions),
|
||
|
login: async (scopeList: string[]) => {
|
||
|
try {
|
||
|
/* __GDPR__
|
||
|
"login" : { }
|
||
|
*/
|
||
|
telemetryReporter.sendTelemetryEvent('login');
|
||
|
|
||
|
const session = await loginService.login(scopeList.sort().join(' '));
|
||
|
Logger.info('Login success!');
|
||
|
onDidChangeSessions.fire({ added: [session.id], removed: [], changed: [] });
|
||
|
return session;
|
||
|
} catch (e) {
|
||
|
/* __GDPR__
|
||
|
"loginFailed" : { }
|
||
|
*/
|
||
|
telemetryReporter.sendTelemetryEvent('loginFailed');
|
||
|
|
||
|
vscode.window.showErrorMessage(`Sign in failed: ${e}`);
|
||
|
Logger.error(e);
|
||
|
throw e;
|
||
|
}
|
||
|
},
|
||
|
logout: async (id: string) => {
|
||
|
try {
|
||
|
/* __GDPR__
|
||
|
"logout" : { }
|
||
|
*/
|
||
|
telemetryReporter.sendTelemetryEvent('logout');
|
||
|
|
||
|
await loginService.logout(id);
|
||
|
onDidChangeSessions.fire({ added: [], removed: [id], changed: [] });
|
||
|
} catch (e) {
|
||
|
/* __GDPR__
|
||
|
"logoutFailed" : { }
|
||
|
*/
|
||
|
telemetryReporter.sendTelemetryEvent('logoutFailed');
|
||
|
|
||
|
vscode.window.showErrorMessage(`Sign out failed: ${e}`);
|
||
|
Logger.error(e);
|
||
|
throw e;
|
||
|
}
|
||
|
}
|
||
|
}));
|
||
|
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
// this method is called when your extension is deactivated
|
||
|
export function deactivate() { }
|