|
|
|
|
@@ -3,16 +3,17 @@
|
|
|
|
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
|
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
|
|
import product from 'vs/platform/product/common/product';
|
|
|
|
|
import * as fs from 'fs';
|
|
|
|
|
import { release } from 'os';
|
|
|
|
|
import { release, hostname } from 'os';
|
|
|
|
|
import { gracefulify } from 'graceful-fs';
|
|
|
|
|
import { Server as MessagePortServer } from 'vs/base/parts/ipc/electron-sandbox/ipc.mp';
|
|
|
|
|
import { StaticRouter, createChannelSender, createChannelReceiver } from 'vs/base/parts/ipc/common/ipc';
|
|
|
|
|
import { ipcRenderer } from 'electron';
|
|
|
|
|
import product from 'vs/platform/product/common/product';
|
|
|
|
|
import { Server as MessagePortServer } from 'vs/base/parts/ipc/electron-browser/ipc.mp';
|
|
|
|
|
import { StaticRouter, ProxyChannel } from 'vs/base/parts/ipc/common/ipc';
|
|
|
|
|
import { ServiceCollection } from 'vs/platform/instantiation/common/serviceCollection';
|
|
|
|
|
import { SyncDescriptor } from 'vs/platform/instantiation/common/descriptors';
|
|
|
|
|
import { InstantiationService } from 'vs/platform/instantiation/common/instantiationService';
|
|
|
|
|
import { IEnvironmentService, INativeEnvironmentService } from 'vs/platform/environment/common/environment';
|
|
|
|
|
import { INativeEnvironmentService } from 'vs/platform/environment/common/environment';
|
|
|
|
|
import { NativeEnvironmentService } from 'vs/platform/environment/node/environmentService';
|
|
|
|
|
import { ExtensionManagementChannel, ExtensionTipsChannel } from 'vs/platform/extensionManagement/common/extensionManagementIpc';
|
|
|
|
|
import { IExtensionManagementService, IExtensionGalleryService, IGlobalExtensionEnablementService, IExtensionTipsService } from 'vs/platform/extensionManagement/common/extensionManagement';
|
|
|
|
|
@@ -22,15 +23,14 @@ import { IConfigurationService } from 'vs/platform/configuration/common/configur
|
|
|
|
|
import { ConfigurationService } from 'vs/platform/configuration/common/configurationService';
|
|
|
|
|
import { IRequestService } from 'vs/platform/request/common/request';
|
|
|
|
|
import { RequestService } from 'vs/platform/request/browser/requestService';
|
|
|
|
|
import { ITelemetryService } from 'vs/platform/telemetry/common/telemetry';
|
|
|
|
|
import { ICustomEndpointTelemetryService, ITelemetryService } from 'vs/platform/telemetry/common/telemetry';
|
|
|
|
|
import { combinedAppender, NullTelemetryService, ITelemetryAppender, NullAppender } from 'vs/platform/telemetry/common/telemetryUtils';
|
|
|
|
|
import { resolveCommonProperties } from 'vs/platform/telemetry/common/commonProperties';
|
|
|
|
|
import { TelemetryAppenderChannel } from 'vs/platform/telemetry/common/telemetryIpc';
|
|
|
|
|
import { TelemetryService } from 'vs/platform/telemetry/common/telemetryService';
|
|
|
|
|
import { AppInsightsAppender } from 'vs/platform/telemetry/node/appInsightsAppender';
|
|
|
|
|
import { ipcRenderer } from 'vs/base/parts/sandbox/electron-sandbox/globals';
|
|
|
|
|
import { ILogService, ILoggerService, MultiplexLogService, ConsoleLogService } from 'vs/platform/log/common/log';
|
|
|
|
|
import { LoggerChannelClient, FollowerLogService } from 'vs/platform/log/common/logIpc';
|
|
|
|
|
import { ILogService, ILoggerService, MultiplexLogService, ConsoleLogger } from 'vs/platform/log/common/log';
|
|
|
|
|
import { LogLevelChannelClient, FollowerLogService, LoggerChannelClient } from 'vs/platform/log/common/logIpc';
|
|
|
|
|
import { LocalizationsService } from 'vs/platform/localizations/node/localizations';
|
|
|
|
|
import { ILocalizationsService } from 'vs/platform/localizations/common/localizations';
|
|
|
|
|
import { combinedDisposable, Disposable, toDisposable } from 'vs/base/common/lifecycle';
|
|
|
|
|
@@ -40,9 +40,10 @@ import { NodeCachedDataCleaner } from 'vs/code/electron-browser/sharedProcess/co
|
|
|
|
|
import { LanguagePackCachedDataCleaner } from 'vs/code/electron-browser/sharedProcess/contrib/languagePackCachedDataCleaner';
|
|
|
|
|
import { StorageDataCleaner } from 'vs/code/electron-browser/sharedProcess/contrib/storageDataCleaner';
|
|
|
|
|
import { LogsDataCleaner } from 'vs/code/electron-browser/sharedProcess/contrib/logsDataCleaner';
|
|
|
|
|
import { IMainProcessService, MessagePortMainProcessService } from 'vs/platform/ipc/electron-sandbox/mainProcessService';
|
|
|
|
|
import { SpdLogService } from 'vs/platform/log/node/spdlogService';
|
|
|
|
|
import { DiagnosticsService, IDiagnosticsService } from 'vs/platform/diagnostics/node/diagnosticsService';
|
|
|
|
|
import { IMainProcessService } from 'vs/platform/ipc/electron-sandbox/services';
|
|
|
|
|
import { MessagePortMainProcessService } from 'vs/platform/ipc/electron-browser/mainProcessService';
|
|
|
|
|
import { DiagnosticsService } from 'vs/platform/diagnostics/node/diagnosticsService';
|
|
|
|
|
import { IDiagnosticsService } from 'vs/platform/diagnostics/common/diagnostics';
|
|
|
|
|
import { FileService } from 'vs/platform/files/common/fileService';
|
|
|
|
|
import { IFileService } from 'vs/platform/files/common/files';
|
|
|
|
|
import { DiskFileSystemProvider } from 'vs/platform/files/node/diskFileSystemProvider';
|
|
|
|
|
@@ -51,13 +52,11 @@ import { IProductService } from 'vs/platform/product/common/productService';
|
|
|
|
|
import { IUserDataSyncService, IUserDataSyncStoreService, registerConfiguration as registerUserDataSyncConfiguration, IUserDataSyncLogService, IUserDataSyncUtilService, IUserDataSyncResourceEnablementService, IUserDataSyncBackupStoreService, IUserDataSyncStoreManagementService, IUserDataAutoSyncEnablementService } from 'vs/platform/userDataSync/common/userDataSync';
|
|
|
|
|
import { UserDataSyncService } from 'vs/platform/userDataSync/common/userDataSyncService';
|
|
|
|
|
import { UserDataSyncStoreService, UserDataSyncStoreManagementService } from 'vs/platform/userDataSync/common/userDataSyncStoreService';
|
|
|
|
|
import { UserDataSyncChannel, UserDataSyncUtilServiceClient, UserDataAutoSyncChannel, UserDataSyncMachinesServiceChannel, UserDataSyncAccountServiceChannel, UserDataSyncStoreManagementServiceChannel } from 'vs/platform/userDataSync/common/userDataSyncIpc';
|
|
|
|
|
import { UserDataSyncUtilServiceClient, UserDataAutoSyncChannel, UserDataSyncMachinesServiceChannel, UserDataSyncAccountServiceChannel, UserDataSyncStoreManagementServiceChannel } from 'vs/platform/userDataSync/common/userDataSyncIpc';
|
|
|
|
|
import { INativeHostService } from 'vs/platform/native/electron-sandbox/native';
|
|
|
|
|
import { LoggerService } from 'vs/platform/log/node/loggerService';
|
|
|
|
|
import { UserDataSyncLogService } from 'vs/platform/userDataSync/common/userDataSyncLog';
|
|
|
|
|
import { UserDataAutoSyncService } from 'vs/platform/userDataSync/electron-sandbox/userDataAutoSyncService';
|
|
|
|
|
import { NativeStorageService } from 'vs/platform/storage/node/storageService';
|
|
|
|
|
import { GlobalStorageDatabaseChannelClient } from 'vs/platform/storage/node/storageIpc';
|
|
|
|
|
import { NativeStorageService } from 'vs/platform/storage/electron-sandbox/storageService';
|
|
|
|
|
import { IStorageService } from 'vs/platform/storage/common/storage';
|
|
|
|
|
import { GlobalExtensionEnablementService } from 'vs/platform/extensionManagement/common/extensionEnablementService';
|
|
|
|
|
import { UserDataSyncResourceEnablementService } from 'vs/platform/userDataSync/common/userDataSyncResourceEnablementService';
|
|
|
|
|
@@ -78,6 +77,15 @@ import { LocalizationsUpdater } from 'vs/code/electron-browser/sharedProcess/con
|
|
|
|
|
import { DeprecatedExtensionsCleaner } from 'vs/code/electron-browser/sharedProcess/contrib/deprecatedExtensionsCleaner';
|
|
|
|
|
import { onUnexpectedError, setUnexpectedErrorHandler } from 'vs/base/common/errors';
|
|
|
|
|
import { toErrorMessage } from 'vs/base/common/errorMessage';
|
|
|
|
|
import { TerminalIpcChannels } from 'vs/platform/terminal/common/terminal';
|
|
|
|
|
import { PtyHostService } from 'vs/platform/terminal/node/ptyHostService';
|
|
|
|
|
import { ILocalPtyService } from 'vs/platform/terminal/electron-sandbox/terminal';
|
|
|
|
|
import { UserDataSyncChannel } from 'vs/platform/userDataSync/common/userDataSyncServiceIpc';
|
|
|
|
|
import { IChecksumService } from 'vs/platform/checksum/common/checksumService';
|
|
|
|
|
import { ChecksumService } from 'vs/platform/checksum/node/checksumService';
|
|
|
|
|
import { CustomEndpointTelemetryService } from 'vs/platform/telemetry/node/customEndpointTelemetryService';
|
|
|
|
|
import { URI } from 'vs/base/common/uri';
|
|
|
|
|
import { joinPath } from 'vs/base/common/resources';
|
|
|
|
|
|
|
|
|
|
class SharedProcessMain extends Disposable {
|
|
|
|
|
|
|
|
|
|
@@ -123,7 +131,7 @@ class SharedProcessMain extends Disposable {
|
|
|
|
|
|
|
|
|
|
// Instantiate Contributions
|
|
|
|
|
this._register(combinedDisposable(
|
|
|
|
|
new NodeCachedDataCleaner(this.configuration.nodeCachedDataDir),
|
|
|
|
|
instantiationService.createInstance(NodeCachedDataCleaner, this.configuration.nodeCachedDataDir),
|
|
|
|
|
instantiationService.createInstance(LanguagePackCachedDataCleaner),
|
|
|
|
|
instantiationService.createInstance(StorageDataCleaner, this.configuration.backupWorkspacesPath),
|
|
|
|
|
instantiationService.createInstance(LogsDataCleaner),
|
|
|
|
|
@@ -135,26 +143,33 @@ class SharedProcessMain extends Disposable {
|
|
|
|
|
private async initServices(): Promise<IInstantiationService> {
|
|
|
|
|
const services = new ServiceCollection();
|
|
|
|
|
|
|
|
|
|
// Environment
|
|
|
|
|
const environmentService = new NativeEnvironmentService(this.configuration.args);
|
|
|
|
|
services.set(IEnvironmentService, environmentService);
|
|
|
|
|
services.set(INativeEnvironmentService, environmentService);
|
|
|
|
|
|
|
|
|
|
// Log
|
|
|
|
|
const mainRouter = new StaticRouter(ctx => ctx === 'main');
|
|
|
|
|
const loggerClient = new LoggerChannelClient(this.server.getChannel('logger', mainRouter)); // we only use this for log levels
|
|
|
|
|
const multiplexLogger = this._register(new MultiplexLogService([
|
|
|
|
|
this._register(new ConsoleLogService(this.configuration.logLevel)),
|
|
|
|
|
this._register(new SpdLogService('sharedprocess', environmentService.logsPath, this.configuration.logLevel))
|
|
|
|
|
]));
|
|
|
|
|
|
|
|
|
|
const logService = this._register(new FollowerLogService(loggerClient, multiplexLogger));
|
|
|
|
|
services.set(ILogService, logService);
|
|
|
|
|
// Product
|
|
|
|
|
const productService = { _serviceBrand: undefined, ...product };
|
|
|
|
|
services.set(IProductService, productService);
|
|
|
|
|
|
|
|
|
|
// Main Process
|
|
|
|
|
const mainRouter = new StaticRouter(ctx => ctx === 'main');
|
|
|
|
|
const mainProcessService = new MessagePortMainProcessService(this.server, mainRouter);
|
|
|
|
|
services.set(IMainProcessService, mainProcessService);
|
|
|
|
|
|
|
|
|
|
// Environment
|
|
|
|
|
const environmentService = new NativeEnvironmentService(this.configuration.args, productService);
|
|
|
|
|
services.set(INativeEnvironmentService, environmentService);
|
|
|
|
|
|
|
|
|
|
// Logger
|
|
|
|
|
const logLevelClient = new LogLevelChannelClient(this.server.getChannel('logLevel', mainRouter));
|
|
|
|
|
const loggerService = new LoggerChannelClient(this.configuration.logLevel, logLevelClient.onDidChangeLogLevel, mainProcessService.getChannel('logger'));
|
|
|
|
|
services.set(ILoggerService, loggerService);
|
|
|
|
|
|
|
|
|
|
// Log
|
|
|
|
|
const multiplexLogger = this._register(new MultiplexLogService([
|
|
|
|
|
this._register(new ConsoleLogger(this.configuration.logLevel)),
|
|
|
|
|
this._register(loggerService.createLogger(joinPath(URI.file(environmentService.logsPath), 'sharedprocess.log'), { name: 'sharedprocess' }))
|
|
|
|
|
]));
|
|
|
|
|
|
|
|
|
|
const logService = this._register(new FollowerLogService(logLevelClient, multiplexLogger));
|
|
|
|
|
services.set(ILogService, logService);
|
|
|
|
|
|
|
|
|
|
// Files
|
|
|
|
|
const fileService = this._register(new FileService(logService));
|
|
|
|
|
services.set(IFileService, fileService);
|
|
|
|
|
@@ -168,21 +183,21 @@ class SharedProcessMain extends Disposable {
|
|
|
|
|
|
|
|
|
|
await configurationService.initialize();
|
|
|
|
|
|
|
|
|
|
// Storage
|
|
|
|
|
const storageService = new NativeStorageService(new GlobalStorageDatabaseChannelClient(mainProcessService.getChannel('storage')), logService, environmentService);
|
|
|
|
|
// Storage (global access only)
|
|
|
|
|
const storageService = new NativeStorageService(undefined, mainProcessService, environmentService);
|
|
|
|
|
services.set(IStorageService, storageService);
|
|
|
|
|
|
|
|
|
|
await storageService.initialize();
|
|
|
|
|
this._register(toDisposable(() => storageService.flush()));
|
|
|
|
|
|
|
|
|
|
// Product
|
|
|
|
|
services.set(IProductService, { _serviceBrand: undefined, ...product });
|
|
|
|
|
|
|
|
|
|
// Request
|
|
|
|
|
services.set(IRequestService, new SyncDescriptor(RequestService));
|
|
|
|
|
|
|
|
|
|
// Checksum
|
|
|
|
|
services.set(IChecksumService, new SyncDescriptor(ChecksumService));
|
|
|
|
|
|
|
|
|
|
// Native Host
|
|
|
|
|
const nativeHostService = createChannelSender<INativeHostService>(mainProcessService.getChannel('nativeHost'), { context: this.configuration.windowId });
|
|
|
|
|
const nativeHostService = ProxyChannel.toService<INativeHostService>(mainProcessService.getChannel('nativeHost'), { context: this.configuration.windowId });
|
|
|
|
|
services.set(INativeHostService, nativeHostService);
|
|
|
|
|
|
|
|
|
|
// Download
|
|
|
|
|
@@ -193,28 +208,24 @@ class SharedProcessMain extends Disposable {
|
|
|
|
|
const activeWindowRouter = new StaticRouter(ctx => activeWindowManager.getActiveClientId().then(id => ctx === id));
|
|
|
|
|
services.set(IExtensionRecommendationNotificationService, new ExtensionRecommendationNotificationServiceChannelClient(this.server.getChannel('extensionRecommendationNotification', activeWindowRouter)));
|
|
|
|
|
|
|
|
|
|
// Logger
|
|
|
|
|
const loggerService = this._register(new LoggerService(logService, fileService));
|
|
|
|
|
services.set(ILoggerService, loggerService);
|
|
|
|
|
|
|
|
|
|
// Telemetry
|
|
|
|
|
const { appRoot, extensionsPath, extensionDevelopmentLocationURI, isBuilt, installSourcePath } = environmentService;
|
|
|
|
|
|
|
|
|
|
let telemetryService: ITelemetryService;
|
|
|
|
|
let telemetryAppender: ITelemetryAppender;
|
|
|
|
|
if (!extensionDevelopmentLocationURI && !environmentService.disableTelemetry && product.enableTelemetry) {
|
|
|
|
|
if (!environmentService.isExtensionDevelopment && !environmentService.disableTelemetry && productService.enableTelemetry) {
|
|
|
|
|
telemetryAppender = new TelemetryLogAppender(loggerService, environmentService);
|
|
|
|
|
|
|
|
|
|
const { appRoot, extensionsPath, isBuilt, installSourcePath } = environmentService;
|
|
|
|
|
|
|
|
|
|
// Application Insights
|
|
|
|
|
if (product.aiConfig && product.aiConfig.asimovKey && isBuilt) {
|
|
|
|
|
const appInsightsAppender = new AppInsightsAppender('adsworkbench', null, product.aiConfig.asimovKey); // {{SQL CARBON EDIT}} Use our own event prefix
|
|
|
|
|
if (productService.aiConfig && productService.aiConfig.asimovKey && isBuilt) {
|
|
|
|
|
const appInsightsAppender = new AppInsightsAppender('adsworkbench', null, productService.aiConfig.asimovKey); // {{SQL CARBON EDIT}} Use our own event prefix
|
|
|
|
|
this._register(toDisposable(() => appInsightsAppender.flush())); // Ensure the AI appender is disposed so that it flushes remaining data
|
|
|
|
|
telemetryAppender = combinedAppender(appInsightsAppender, telemetryAppender);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
telemetryService = new TelemetryService({
|
|
|
|
|
appender: telemetryAppender,
|
|
|
|
|
commonProperties: resolveCommonProperties(fileService, release(), process.arch, product.commit, product.version, this.configuration.machineId, product.msftInternalDomains, installSourcePath),
|
|
|
|
|
commonProperties: resolveCommonProperties(fileService, release(), hostname(), process.arch, productService.commit, productService.version, this.configuration.machineId, productService.msftInternalDomains, installSourcePath),
|
|
|
|
|
sendErrorTelemetry: true,
|
|
|
|
|
piiPaths: [appRoot, extensionsPath]
|
|
|
|
|
}, configurationService);
|
|
|
|
|
@@ -226,6 +237,10 @@ class SharedProcessMain extends Disposable {
|
|
|
|
|
this.server.registerChannel('telemetryAppender', new TelemetryAppenderChannel(telemetryAppender));
|
|
|
|
|
services.set(ITelemetryService, telemetryService);
|
|
|
|
|
|
|
|
|
|
// Custom Endpoint Telemetry
|
|
|
|
|
const customEndpointTelemetryService = new CustomEndpointTelemetryService(configurationService, telemetryService);
|
|
|
|
|
services.set(ICustomEndpointTelemetryService, customEndpointTelemetryService);
|
|
|
|
|
|
|
|
|
|
// Extension Management
|
|
|
|
|
services.set(IExtensionManagementService, new SyncDescriptor(ExtensionManagementService));
|
|
|
|
|
|
|
|
|
|
@@ -256,51 +271,59 @@ class SharedProcessMain extends Disposable {
|
|
|
|
|
services.set(IUserDataSyncResourceEnablementService, new SyncDescriptor(UserDataSyncResourceEnablementService));
|
|
|
|
|
services.set(IUserDataSyncService, new SyncDescriptor(UserDataSyncService));
|
|
|
|
|
|
|
|
|
|
// Terminal
|
|
|
|
|
services.set(ILocalPtyService, this._register(new PtyHostService(logService, telemetryService)));
|
|
|
|
|
|
|
|
|
|
return new InstantiationService(services);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private initChannels(accessor: ServicesAccessor): void {
|
|
|
|
|
|
|
|
|
|
// Extensions Management
|
|
|
|
|
const extensionManagementService = accessor.get(IExtensionManagementService);
|
|
|
|
|
const channel = new ExtensionManagementChannel(extensionManagementService, () => null);
|
|
|
|
|
const channel = new ExtensionManagementChannel(accessor.get(IExtensionManagementService), () => null);
|
|
|
|
|
this.server.registerChannel('extensions', channel);
|
|
|
|
|
|
|
|
|
|
// Localizations
|
|
|
|
|
const localizationsService = accessor.get(ILocalizationsService);
|
|
|
|
|
const localizationsChannel = createChannelReceiver(localizationsService);
|
|
|
|
|
const localizationsChannel = ProxyChannel.fromService(accessor.get(ILocalizationsService));
|
|
|
|
|
this.server.registerChannel('localizations', localizationsChannel);
|
|
|
|
|
|
|
|
|
|
// Diagnostics
|
|
|
|
|
const diagnosticsService = accessor.get(IDiagnosticsService);
|
|
|
|
|
const diagnosticsChannel = createChannelReceiver(diagnosticsService);
|
|
|
|
|
const diagnosticsChannel = ProxyChannel.fromService(accessor.get(IDiagnosticsService));
|
|
|
|
|
this.server.registerChannel('diagnostics', diagnosticsChannel);
|
|
|
|
|
|
|
|
|
|
// Extension Tips
|
|
|
|
|
const extensionTipsService = accessor.get(IExtensionTipsService);
|
|
|
|
|
const extensionTipsChannel = new ExtensionTipsChannel(extensionTipsService);
|
|
|
|
|
const extensionTipsChannel = new ExtensionTipsChannel(accessor.get(IExtensionTipsService));
|
|
|
|
|
this.server.registerChannel('extensionTipsService', extensionTipsChannel);
|
|
|
|
|
|
|
|
|
|
// Checksum
|
|
|
|
|
const checksumChannel = ProxyChannel.fromService(accessor.get(IChecksumService));
|
|
|
|
|
this.server.registerChannel('checksum', checksumChannel);
|
|
|
|
|
|
|
|
|
|
// Settings Sync
|
|
|
|
|
const userDataSyncMachinesService = accessor.get(IUserDataSyncMachinesService);
|
|
|
|
|
const userDataSyncMachineChannel = new UserDataSyncMachinesServiceChannel(userDataSyncMachinesService);
|
|
|
|
|
const userDataSyncMachineChannel = new UserDataSyncMachinesServiceChannel(accessor.get(IUserDataSyncMachinesService));
|
|
|
|
|
this.server.registerChannel('userDataSyncMachines', userDataSyncMachineChannel);
|
|
|
|
|
|
|
|
|
|
const authTokenService = accessor.get(IUserDataSyncAccountService);
|
|
|
|
|
const authTokenChannel = new UserDataSyncAccountServiceChannel(authTokenService);
|
|
|
|
|
this.server.registerChannel('userDataSyncAccount', authTokenChannel);
|
|
|
|
|
// Custom Endpoint Telemetry
|
|
|
|
|
const customEndpointTelemetryChannel = ProxyChannel.fromService(accessor.get(ICustomEndpointTelemetryService));
|
|
|
|
|
this.server.registerChannel('customEndpointTelemetry', customEndpointTelemetryChannel);
|
|
|
|
|
|
|
|
|
|
const userDataSyncStoreManagementService = accessor.get(IUserDataSyncStoreManagementService);
|
|
|
|
|
const userDataSyncStoreManagementChannel = new UserDataSyncStoreManagementServiceChannel(userDataSyncStoreManagementService);
|
|
|
|
|
const userDataSyncAccountChannel = new UserDataSyncAccountServiceChannel(accessor.get(IUserDataSyncAccountService));
|
|
|
|
|
this.server.registerChannel('userDataSyncAccount', userDataSyncAccountChannel);
|
|
|
|
|
|
|
|
|
|
const userDataSyncStoreManagementChannel = new UserDataSyncStoreManagementServiceChannel(accessor.get(IUserDataSyncStoreManagementService));
|
|
|
|
|
this.server.registerChannel('userDataSyncStoreManagement', userDataSyncStoreManagementChannel);
|
|
|
|
|
|
|
|
|
|
const userDataSyncService = accessor.get(IUserDataSyncService);
|
|
|
|
|
const userDataSyncChannel = new UserDataSyncChannel(this.server, userDataSyncService, accessor.get(ILogService));
|
|
|
|
|
const userDataSyncChannel = new UserDataSyncChannel(accessor.get(IUserDataSyncService), accessor.get(ILogService));
|
|
|
|
|
this.server.registerChannel('userDataSync', userDataSyncChannel);
|
|
|
|
|
|
|
|
|
|
const userDataAutoSync = this._register(accessor.get(IInstantiationService).createInstance(UserDataAutoSyncService));
|
|
|
|
|
const userDataAutoSyncChannel = new UserDataAutoSyncChannel(userDataAutoSync);
|
|
|
|
|
this.server.registerChannel('userDataAutoSync', userDataAutoSyncChannel);
|
|
|
|
|
|
|
|
|
|
// Terminal
|
|
|
|
|
const localPtyService = accessor.get(ILocalPtyService);
|
|
|
|
|
const localPtyChannel = ProxyChannel.fromService(localPtyService);
|
|
|
|
|
this.server.registerChannel(TerminalIpcChannels.LocalPty, localPtyChannel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private registerErrorHandler(logService: ILogService): void {
|
|
|
|
|
|