Path: blob/main/src/vs/code/electron-utility/sharedProcess/sharedProcessMain.ts
3294 views
/*---------------------------------------------------------------------------------------------1* Copyright (c) Microsoft Corporation. All rights reserved.2* Licensed under the MIT License. See License.txt in the project root for license information.3*--------------------------------------------------------------------------------------------*/45import { hostname, release } from 'os';6import { MessagePortMain, MessageEvent } from '../../../base/parts/sandbox/node/electronTypes.js';7import { toErrorMessage } from '../../../base/common/errorMessage.js';8import { onUnexpectedError, setUnexpectedErrorHandler } from '../../../base/common/errors.js';9import { combinedDisposable, Disposable, toDisposable } from '../../../base/common/lifecycle.js';10import { Schemas } from '../../../base/common/network.js';11import { URI } from '../../../base/common/uri.js';12import { Emitter } from '../../../base/common/event.js';13import { ProxyChannel, StaticRouter } from '../../../base/parts/ipc/common/ipc.js';14import { IClientConnectionFilter, Server as UtilityProcessMessagePortServer, once } from '../../../base/parts/ipc/node/ipc.mp.js';15import { CodeCacheCleaner } from './contrib/codeCacheCleaner.js';16import { LanguagePackCachedDataCleaner } from './contrib/languagePackCachedDataCleaner.js';17import { LocalizationsUpdater } from './contrib/localizationsUpdater.js';18import { LogsDataCleaner } from './contrib/logsDataCleaner.js';19import { UnusedWorkspaceStorageDataCleaner } from './contrib/storageDataCleaner.js';20import { IChecksumService } from '../../../platform/checksum/common/checksumService.js';21import { ChecksumService } from '../../../platform/checksum/node/checksumService.js';22import { IConfigurationService } from '../../../platform/configuration/common/configuration.js';23import { ConfigurationService } from '../../../platform/configuration/common/configurationService.js';24import { IDiagnosticsService } from '../../../platform/diagnostics/common/diagnostics.js';25import { DiagnosticsService } from '../../../platform/diagnostics/node/diagnosticsService.js';26import { IDownloadService } from '../../../platform/download/common/download.js';27import { DownloadService } from '../../../platform/download/common/downloadService.js';28import { INativeEnvironmentService } from '../../../platform/environment/common/environment.js';29import { GlobalExtensionEnablementService } from '../../../platform/extensionManagement/common/extensionEnablementService.js';30import { ExtensionGalleryService } from '../../../platform/extensionManagement/common/extensionGalleryService.js';31import { IAllowedExtensionsService, IExtensionGalleryService, IExtensionManagementService, IExtensionTipsService, IGlobalExtensionEnablementService } from '../../../platform/extensionManagement/common/extensionManagement.js';32import { ExtensionSignatureVerificationService, IExtensionSignatureVerificationService } from '../../../platform/extensionManagement/node/extensionSignatureVerificationService.js';33import { ExtensionManagementChannel, ExtensionTipsChannel } from '../../../platform/extensionManagement/common/extensionManagementIpc.js';34import { ExtensionManagementService, INativeServerExtensionManagementService } from '../../../platform/extensionManagement/node/extensionManagementService.js';35import { IExtensionRecommendationNotificationService } from '../../../platform/extensionRecommendations/common/extensionRecommendations.js';36import { IFileService } from '../../../platform/files/common/files.js';37import { FileService } from '../../../platform/files/common/fileService.js';38import { DiskFileSystemProvider } from '../../../platform/files/node/diskFileSystemProvider.js';39import { SyncDescriptor } from '../../../platform/instantiation/common/descriptors.js';40import { IInstantiationService, ServicesAccessor } from '../../../platform/instantiation/common/instantiation.js';41import { InstantiationService } from '../../../platform/instantiation/common/instantiationService.js';42import { ServiceCollection } from '../../../platform/instantiation/common/serviceCollection.js';43import { ILanguagePackService } from '../../../platform/languagePacks/common/languagePacks.js';44import { NativeLanguagePackService } from '../../../platform/languagePacks/node/languagePacks.js';45import { ConsoleLogger, ILoggerService, ILogService, LoggerGroup } from '../../../platform/log/common/log.js';46import { LoggerChannelClient } from '../../../platform/log/common/logIpc.js';47import product from '../../../platform/product/common/product.js';48import { IProductService } from '../../../platform/product/common/productService.js';49import { IRequestService } from '../../../platform/request/common/request.js';50import { ISharedProcessConfiguration } from '../../../platform/sharedProcess/node/sharedProcess.js';51import { IStorageService } from '../../../platform/storage/common/storage.js';52import { resolveCommonProperties } from '../../../platform/telemetry/common/commonProperties.js';53import { ICustomEndpointTelemetryService, ITelemetryService } from '../../../platform/telemetry/common/telemetry.js';54import { TelemetryAppenderChannel } from '../../../platform/telemetry/common/telemetryIpc.js';55import { TelemetryLogAppender } from '../../../platform/telemetry/common/telemetryLogAppender.js';56import { TelemetryService } from '../../../platform/telemetry/common/telemetryService.js';57import { supportsTelemetry, ITelemetryAppender, NullAppender, NullTelemetryService, getPiiPathsFromEnvironment, isInternalTelemetry, isLoggingOnly } from '../../../platform/telemetry/common/telemetryUtils.js';58import { CustomEndpointTelemetryService } from '../../../platform/telemetry/node/customEndpointTelemetryService.js';59import { ExtensionStorageService, IExtensionStorageService } from '../../../platform/extensionManagement/common/extensionStorage.js';60import { IgnoredExtensionsManagementService, IIgnoredExtensionsManagementService } from '../../../platform/userDataSync/common/ignoredExtensions.js';61import { IUserDataSyncLocalStoreService, IUserDataSyncLogService, IUserDataSyncEnablementService, IUserDataSyncService, IUserDataSyncStoreManagementService, IUserDataSyncStoreService, IUserDataSyncUtilService, registerConfiguration as registerUserDataSyncConfiguration, IUserDataSyncResourceProviderService } from '../../../platform/userDataSync/common/userDataSync.js';62import { IUserDataSyncAccountService, UserDataSyncAccountService } from '../../../platform/userDataSync/common/userDataSyncAccount.js';63import { UserDataSyncLocalStoreService } from '../../../platform/userDataSync/common/userDataSyncLocalStoreService.js';64import { UserDataSyncAccountServiceChannel, UserDataSyncStoreManagementServiceChannel } from '../../../platform/userDataSync/common/userDataSyncIpc.js';65import { UserDataSyncLogService } from '../../../platform/userDataSync/common/userDataSyncLog.js';66import { IUserDataSyncMachinesService, UserDataSyncMachinesService } from '../../../platform/userDataSync/common/userDataSyncMachines.js';67import { UserDataSyncEnablementService } from '../../../platform/userDataSync/common/userDataSyncEnablementService.js';68import { UserDataSyncService } from '../../../platform/userDataSync/common/userDataSyncService.js';69import { UserDataSyncServiceChannel } from '../../../platform/userDataSync/common/userDataSyncServiceIpc.js';70import { UserDataSyncStoreManagementService, UserDataSyncStoreService } from '../../../platform/userDataSync/common/userDataSyncStoreService.js';71import { IUserDataProfileStorageService } from '../../../platform/userDataProfile/common/userDataProfileStorageService.js';72import { SharedProcessUserDataProfileStorageService } from '../../../platform/userDataProfile/node/userDataProfileStorageService.js';73import { ActiveWindowManager } from '../../../platform/windows/node/windowTracker.js';74import { ISignService } from '../../../platform/sign/common/sign.js';75import { SignService } from '../../../platform/sign/node/signService.js';76import { ISharedTunnelsService } from '../../../platform/tunnel/common/tunnel.js';77import { SharedTunnelsService } from '../../../platform/tunnel/node/tunnelService.js';78import { ipcSharedProcessTunnelChannelName, ISharedProcessTunnelService } from '../../../platform/remote/common/sharedProcessTunnelService.js';79import { SharedProcessTunnelService } from '../../../platform/tunnel/node/sharedProcessTunnelService.js';80import { IUriIdentityService } from '../../../platform/uriIdentity/common/uriIdentity.js';81import { UriIdentityService } from '../../../platform/uriIdentity/common/uriIdentityService.js';82import { isLinux } from '../../../base/common/platform.js';83import { FileUserDataProvider } from '../../../platform/userData/common/fileUserDataProvider.js';84import { DiskFileSystemProviderClient, LOCAL_FILE_SYSTEM_CHANNEL_NAME } from '../../../platform/files/common/diskFileSystemProviderClient.js';85import { InspectProfilingService as V8InspectProfilingService } from '../../../platform/profiling/node/profilingService.js';86import { IV8InspectProfilingService } from '../../../platform/profiling/common/profiling.js';87import { IExtensionsScannerService } from '../../../platform/extensionManagement/common/extensionsScannerService.js';88import { ExtensionsScannerService } from '../../../platform/extensionManagement/node/extensionsScannerService.js';89import { IUserDataProfilesService } from '../../../platform/userDataProfile/common/userDataProfile.js';90import { IExtensionsProfileScannerService } from '../../../platform/extensionManagement/common/extensionsProfileScannerService.js';91import { PolicyChannelClient } from '../../../platform/policy/common/policyIpc.js';92import { IPolicyService, NullPolicyService } from '../../../platform/policy/common/policy.js';93import { UserDataProfilesService } from '../../../platform/userDataProfile/common/userDataProfileIpc.js';94import { OneDataSystemAppender } from '../../../platform/telemetry/node/1dsAppender.js';95import { UserDataProfilesCleaner } from './contrib/userDataProfilesCleaner.js';96import { IRemoteTunnelService } from '../../../platform/remoteTunnel/common/remoteTunnel.js';97import { UserDataSyncResourceProviderService } from '../../../platform/userDataSync/common/userDataSyncResourceProvider.js';98import { ExtensionsContributions } from './contrib/extensions.js';99import { localize } from '../../../nls.js';100import { LogService } from '../../../platform/log/common/logService.js';101import { ISharedProcessLifecycleService, SharedProcessLifecycleService } from '../../../platform/lifecycle/node/sharedProcessLifecycleService.js';102import { RemoteTunnelService } from '../../../platform/remoteTunnel/node/remoteTunnelService.js';103import { ExtensionsProfileScannerService } from '../../../platform/extensionManagement/node/extensionsProfileScannerService.js';104import { ExtensionRecommendationNotificationServiceChannelClient } from '../../../platform/extensionRecommendations/common/extensionRecommendationsIpc.js';105import { INativeHostService } from '../../../platform/native/common/native.js';106import { NativeHostService } from '../../../platform/native/common/nativeHostService.js';107import { UserDataAutoSyncService } from '../../../platform/userDataSync/node/userDataAutoSyncService.js';108import { ExtensionTipsService } from '../../../platform/extensionManagement/node/extensionTipsService.js';109import { IMainProcessService, MainProcessService } from '../../../platform/ipc/common/mainProcessService.js';110import { RemoteStorageService } from '../../../platform/storage/common/storageService.js';111import { IRemoteSocketFactoryService, RemoteSocketFactoryService } from '../../../platform/remote/common/remoteSocketFactoryService.js';112import { RemoteConnectionType } from '../../../platform/remote/common/remoteAuthorityResolver.js';113import { nodeSocketFactory } from '../../../platform/remote/node/nodeSocketFactory.js';114import { NativeEnvironmentService } from '../../../platform/environment/node/environmentService.js';115import { SharedProcessRawConnection, SharedProcessLifecycle } from '../../../platform/sharedProcess/common/sharedProcess.js';116import { getOSReleaseInfo } from '../../../base/node/osReleaseInfo.js';117import { getDesktopEnvironment } from '../../../base/common/desktopEnvironmentInfo.js';118import { getCodeDisplayProtocol, getDisplayProtocol } from '../../../base/node/osDisplayProtocolInfo.js';119import { RequestService } from '../../../platform/request/electron-utility/requestService.js';120import { DefaultExtensionsInitializer } from './contrib/defaultExtensionsInitializer.js';121import { AllowedExtensionsService } from '../../../platform/extensionManagement/common/allowedExtensionsService.js';122import { IExtensionGalleryManifestService } from '../../../platform/extensionManagement/common/extensionGalleryManifest.js';123import { ExtensionGalleryManifestIPCService } from '../../../platform/extensionManagement/common/extensionGalleryManifestServiceIpc.js';124import { ISharedWebContentExtractorService } from '../../../platform/webContentExtractor/common/webContentExtractor.js';125import { SharedWebContentExtractorService } from '../../../platform/webContentExtractor/node/sharedWebContentExtractorService.js';126import { McpManagementService } from '../../../platform/mcp/node/mcpManagementService.js';127import { IAllowedMcpServersService, IMcpGalleryService, IMcpManagementService } from '../../../platform/mcp/common/mcpManagement.js';128import { IMcpResourceScannerService, McpResourceScannerService } from '../../../platform/mcp/common/mcpResourceScannerService.js';129import { McpGalleryService } from '../../../platform/mcp/common/mcpGalleryService.js';130import { McpManagementChannel } from '../../../platform/mcp/common/mcpManagementIpc.js';131import { AllowedMcpServersService } from '../../../platform/mcp/common/allowedMcpServersService.js';132import { IMcpGalleryManifestService } from '../../../platform/mcp/common/mcpGalleryManifest.js';133import { McpGalleryManifestIPCService } from '../../../platform/mcp/common/mcpGalleryManifestServiceIpc.js';134135class SharedProcessMain extends Disposable implements IClientConnectionFilter {136137private readonly server = this._register(new UtilityProcessMessagePortServer(this));138139private lifecycleService: SharedProcessLifecycleService | undefined = undefined;140141private readonly onDidWindowConnectRaw = this._register(new Emitter<MessagePortMain>());142143constructor(private configuration: ISharedProcessConfiguration) {144super();145146this.registerListeners();147}148149private registerListeners(): void {150151// Shared process lifecycle152let didExit = false;153const onExit = () => {154if (!didExit) {155didExit = true;156157this.lifecycleService?.fireOnWillShutdown();158this.dispose();159}160};161process.once('exit', onExit);162once(process.parentPort, SharedProcessLifecycle.exit, onExit);163}164165async init(): Promise<void> {166167// Services168const instantiationService = await this.initServices();169170// Config171registerUserDataSyncConfiguration();172173instantiationService.invokeFunction(accessor => {174const logService = accessor.get(ILogService);175const telemetryService = accessor.get(ITelemetryService);176177// Log info178logService.trace('sharedProcess configuration', JSON.stringify(this.configuration));179180// Channels181this.initChannels(accessor);182183// Error handler184this.registerErrorHandler(logService);185186// Report Client OS/DE Info187this.reportClientOSInfo(telemetryService, logService);188});189190// Instantiate Contributions191this._register(combinedDisposable(192instantiationService.createInstance(CodeCacheCleaner, this.configuration.codeCachePath),193instantiationService.createInstance(LanguagePackCachedDataCleaner),194instantiationService.createInstance(UnusedWorkspaceStorageDataCleaner),195instantiationService.createInstance(LogsDataCleaner),196instantiationService.createInstance(LocalizationsUpdater),197instantiationService.createInstance(ExtensionsContributions),198instantiationService.createInstance(UserDataProfilesCleaner),199instantiationService.createInstance(DefaultExtensionsInitializer)200));201}202203private async initServices(): Promise<IInstantiationService> {204const services = new ServiceCollection();205206// Product207const productService = { _serviceBrand: undefined, ...product };208services.set(IProductService, productService);209210// Main Process211const mainRouter = new StaticRouter(ctx => ctx === 'main');212const mainProcessService = new MainProcessService(this.server, mainRouter);213services.set(IMainProcessService, mainProcessService);214215// Policies216const policyService = this.configuration.policiesData ? new PolicyChannelClient(this.configuration.policiesData, mainProcessService.getChannel('policy')) : new NullPolicyService();217services.set(IPolicyService, policyService);218219// Environment220const environmentService = new NativeEnvironmentService(this.configuration.args, productService);221services.set(INativeEnvironmentService, environmentService);222223// Logger224const loggerService = new LoggerChannelClient(undefined, this.configuration.logLevel, environmentService.logsHome, this.configuration.loggers.map(loggerResource => ({ ...loggerResource, resource: URI.revive(loggerResource.resource) })), mainProcessService.getChannel('logger'));225services.set(ILoggerService, loggerService);226227// Log228const sharedLogGroup: LoggerGroup = { id: 'shared', name: localize('sharedLog', "Shared") };229const logger = this._register(loggerService.createLogger('sharedprocess', { name: localize('sharedLog', "Shared"), group: sharedLogGroup }));230const consoleLogger = this._register(new ConsoleLogger(logger.getLevel()));231const logService = this._register(new LogService(logger, [consoleLogger]));232services.set(ILogService, logService);233234// Lifecycle235this.lifecycleService = this._register(new SharedProcessLifecycleService(logService));236services.set(ISharedProcessLifecycleService, this.lifecycleService);237238// Files239const fileService = this._register(new FileService(logService));240services.set(IFileService, fileService);241242const diskFileSystemProvider = this._register(new DiskFileSystemProvider(logService));243fileService.registerProvider(Schemas.file, diskFileSystemProvider);244245// URI Identity246const uriIdentityService = new UriIdentityService(fileService);247services.set(IUriIdentityService, uriIdentityService);248249// User Data Profiles250const userDataProfilesService = this._register(new UserDataProfilesService(this.configuration.profiles.all, URI.revive(this.configuration.profiles.home).with({ scheme: environmentService.userRoamingDataHome.scheme }), mainProcessService.getChannel('userDataProfiles')));251services.set(IUserDataProfilesService, userDataProfilesService);252253const userDataFileSystemProvider = this._register(new FileUserDataProvider(254Schemas.file,255// Specifically for user data, use the disk file system provider256// from the main process to enable atomic read/write operations.257// Since user data can change very frequently across multiple258// processes, we want a single process handling these operations.259this._register(new DiskFileSystemProviderClient(mainProcessService.getChannel(LOCAL_FILE_SYSTEM_CHANNEL_NAME), { pathCaseSensitive: isLinux })),260Schemas.vscodeUserData,261userDataProfilesService,262uriIdentityService,263logService264));265fileService.registerProvider(Schemas.vscodeUserData, userDataFileSystemProvider);266267// Configuration268const configurationService = this._register(new ConfigurationService(userDataProfilesService.defaultProfile.settingsResource, fileService, policyService, logService));269services.set(IConfigurationService, configurationService);270271// Storage (global access only)272const storageService = new RemoteStorageService(undefined, { defaultProfile: userDataProfilesService.defaultProfile, currentProfile: userDataProfilesService.defaultProfile }, mainProcessService, environmentService);273services.set(IStorageService, storageService);274this._register(toDisposable(() => storageService.flush()));275276// Initialize config & storage in parallel277await Promise.all([278configurationService.initialize(),279storageService.initialize()280]);281282// Request283const networkLogger = this._register(loggerService.createLogger(`network-shared`, { name: localize('networkk', "Network"), group: sharedLogGroup }));284const requestService = new RequestService(configurationService, environmentService, this._register(new LogService(networkLogger)));285services.set(IRequestService, requestService);286287// Checksum288services.set(IChecksumService, new SyncDescriptor(ChecksumService, undefined, false /* proxied to other processes */));289290// V8 Inspect profiler291services.set(IV8InspectProfilingService, new SyncDescriptor(V8InspectProfilingService, undefined, false /* proxied to other processes */));292293// Native Host294const nativeHostService = new NativeHostService(-1 /* we are not running in a browser window context */, mainProcessService) as INativeHostService;295services.set(INativeHostService, nativeHostService);296297// Download298services.set(IDownloadService, new SyncDescriptor(DownloadService, undefined, true));299300// Extension recommendations301const activeWindowManager = this._register(new ActiveWindowManager(nativeHostService));302const activeWindowRouter = new StaticRouter(ctx => activeWindowManager.getActiveClientId().then(id => ctx === id));303services.set(IExtensionRecommendationNotificationService, new ExtensionRecommendationNotificationServiceChannelClient(this.server.getChannel('extensionRecommendationNotification', activeWindowRouter)));304305// Telemetry306let telemetryService: ITelemetryService;307const appenders: ITelemetryAppender[] = [];308const internalTelemetry = isInternalTelemetry(productService, configurationService);309if (supportsTelemetry(productService, environmentService)) {310const logAppender = new TelemetryLogAppender('', false, loggerService, environmentService, productService);311appenders.push(logAppender);312if (!isLoggingOnly(productService, environmentService) && productService.aiConfig?.ariaKey) {313const collectorAppender = new OneDataSystemAppender(requestService, internalTelemetry, 'monacoworkbench', null, productService.aiConfig.ariaKey);314this._register(toDisposable(() => collectorAppender.flush())); // Ensure the 1DS appender is disposed so that it flushes remaining data315appenders.push(collectorAppender);316}317318telemetryService = new TelemetryService({319appenders,320commonProperties: resolveCommonProperties(release(), hostname(), process.arch, productService.commit, productService.version, this.configuration.machineId, this.configuration.sqmId, this.configuration.devDeviceId, internalTelemetry, productService.date),321sendErrorTelemetry: true,322piiPaths: getPiiPathsFromEnvironment(environmentService),323}, configurationService, productService);324} else {325telemetryService = NullTelemetryService;326const nullAppender = NullAppender;327appenders.push(nullAppender);328}329330this.server.registerChannel('telemetryAppender', new TelemetryAppenderChannel(appenders));331services.set(ITelemetryService, telemetryService);332333// Custom Endpoint Telemetry334const customEndpointTelemetryService = new CustomEndpointTelemetryService(configurationService, telemetryService, loggerService, environmentService, productService);335services.set(ICustomEndpointTelemetryService, customEndpointTelemetryService);336337// Extension Management338services.set(IExtensionsProfileScannerService, new SyncDescriptor(ExtensionsProfileScannerService, undefined, true));339services.set(IExtensionsScannerService, new SyncDescriptor(ExtensionsScannerService, undefined, true));340services.set(IExtensionSignatureVerificationService, new SyncDescriptor(ExtensionSignatureVerificationService, undefined, true));341services.set(IAllowedExtensionsService, new SyncDescriptor(AllowedExtensionsService, undefined, true));342services.set(INativeServerExtensionManagementService, new SyncDescriptor(ExtensionManagementService, undefined, true));343344// MCP Management345services.set(IAllowedMcpServersService, new SyncDescriptor(AllowedMcpServersService, undefined, true));346services.set(IMcpGalleryManifestService, new McpGalleryManifestIPCService(this.server));347services.set(IMcpGalleryService, new SyncDescriptor(McpGalleryService, undefined, true));348services.set(IMcpResourceScannerService, new SyncDescriptor(McpResourceScannerService, undefined, true));349services.set(IMcpManagementService, new SyncDescriptor(McpManagementService, undefined, true));350351// Extension Gallery352services.set(IExtensionGalleryManifestService, new ExtensionGalleryManifestIPCService(this.server, productService));353services.set(IExtensionGalleryService, new SyncDescriptor(ExtensionGalleryService, undefined, true));354355// Extension Tips356services.set(IExtensionTipsService, new SyncDescriptor(ExtensionTipsService, undefined, false /* Eagerly scans and computes exe based recommendations */));357358// Localizations359services.set(ILanguagePackService, new SyncDescriptor(NativeLanguagePackService, undefined, false /* proxied to other processes */));360361// Diagnostics362services.set(IDiagnosticsService, new SyncDescriptor(DiagnosticsService, undefined, false /* proxied to other processes */));363364// Settings Sync365services.set(IUserDataSyncAccountService, new SyncDescriptor(UserDataSyncAccountService, undefined, true));366services.set(IUserDataSyncLogService, new SyncDescriptor(UserDataSyncLogService, undefined, true));367services.set(IUserDataSyncUtilService, ProxyChannel.toService(this.server.getChannel('userDataSyncUtil', client => client.ctx !== 'main')));368services.set(IGlobalExtensionEnablementService, new SyncDescriptor(GlobalExtensionEnablementService, undefined, false /* Eagerly resets installed extensions */));369services.set(IIgnoredExtensionsManagementService, new SyncDescriptor(IgnoredExtensionsManagementService, undefined, true));370services.set(IExtensionStorageService, new SyncDescriptor(ExtensionStorageService));371services.set(IUserDataSyncStoreManagementService, new SyncDescriptor(UserDataSyncStoreManagementService, undefined, true));372services.set(IUserDataSyncStoreService, new SyncDescriptor(UserDataSyncStoreService, undefined, true));373services.set(IUserDataSyncMachinesService, new SyncDescriptor(UserDataSyncMachinesService, undefined, true));374services.set(IUserDataSyncLocalStoreService, new SyncDescriptor(UserDataSyncLocalStoreService, undefined, false /* Eagerly cleans up old backups */));375services.set(IUserDataSyncEnablementService, new SyncDescriptor(UserDataSyncEnablementService, undefined, true));376services.set(IUserDataSyncService, new SyncDescriptor(UserDataSyncService, undefined, false /* Initializes the Sync State */));377services.set(IUserDataProfileStorageService, new SyncDescriptor(SharedProcessUserDataProfileStorageService, undefined, true));378services.set(IUserDataSyncResourceProviderService, new SyncDescriptor(UserDataSyncResourceProviderService, undefined, true));379380// Signing381services.set(ISignService, new SyncDescriptor(SignService, undefined, false /* proxied to other processes */));382383// Tunnel384const remoteSocketFactoryService = new RemoteSocketFactoryService();385services.set(IRemoteSocketFactoryService, remoteSocketFactoryService);386remoteSocketFactoryService.register(RemoteConnectionType.WebSocket, nodeSocketFactory);387services.set(ISharedTunnelsService, new SyncDescriptor(SharedTunnelsService));388services.set(ISharedProcessTunnelService, new SyncDescriptor(SharedProcessTunnelService));389390// Remote Tunnel391services.set(IRemoteTunnelService, new SyncDescriptor(RemoteTunnelService));392393// Web Content Extractor394services.set(ISharedWebContentExtractorService, new SyncDescriptor(SharedWebContentExtractorService));395396return new InstantiationService(services);397}398399private initChannels(accessor: ServicesAccessor): void {400401// Extensions Management402const channel = new ExtensionManagementChannel(accessor.get(IExtensionManagementService), () => null);403this.server.registerChannel('extensions', channel);404405// Mcp Management406const mcpManagementChannel = new McpManagementChannel(accessor.get(IMcpManagementService), () => null);407this.server.registerChannel('mcpManagement', mcpManagementChannel);408409// Language Packs410const languagePacksChannel = ProxyChannel.fromService(accessor.get(ILanguagePackService), this._store);411this.server.registerChannel('languagePacks', languagePacksChannel);412413// Diagnostics414const diagnosticsChannel = ProxyChannel.fromService(accessor.get(IDiagnosticsService), this._store);415this.server.registerChannel('diagnostics', diagnosticsChannel);416417// Extension Tips418const extensionTipsChannel = new ExtensionTipsChannel(accessor.get(IExtensionTipsService));419this.server.registerChannel('extensionTipsService', extensionTipsChannel);420421// Checksum422const checksumChannel = ProxyChannel.fromService(accessor.get(IChecksumService), this._store);423this.server.registerChannel('checksum', checksumChannel);424425// Profiling426const profilingChannel = ProxyChannel.fromService(accessor.get(IV8InspectProfilingService), this._store);427this.server.registerChannel('v8InspectProfiling', profilingChannel);428429// Settings Sync430const userDataSyncMachineChannel = ProxyChannel.fromService(accessor.get(IUserDataSyncMachinesService), this._store);431this.server.registerChannel('userDataSyncMachines', userDataSyncMachineChannel);432433// Custom Endpoint Telemetry434const customEndpointTelemetryChannel = ProxyChannel.fromService(accessor.get(ICustomEndpointTelemetryService), this._store);435this.server.registerChannel('customEndpointTelemetry', customEndpointTelemetryChannel);436437const userDataSyncAccountChannel = new UserDataSyncAccountServiceChannel(accessor.get(IUserDataSyncAccountService));438this.server.registerChannel('userDataSyncAccount', userDataSyncAccountChannel);439440const userDataSyncStoreManagementChannel = new UserDataSyncStoreManagementServiceChannel(accessor.get(IUserDataSyncStoreManagementService));441this.server.registerChannel('userDataSyncStoreManagement', userDataSyncStoreManagementChannel);442443const userDataSyncChannel = new UserDataSyncServiceChannel(accessor.get(IUserDataSyncService), accessor.get(IUserDataProfilesService), accessor.get(ILogService));444this.server.registerChannel('userDataSync', userDataSyncChannel);445446const userDataAutoSync = this._register(accessor.get(IInstantiationService).createInstance(UserDataAutoSyncService));447this.server.registerChannel('userDataAutoSync', ProxyChannel.fromService(userDataAutoSync, this._store));448449this.server.registerChannel('IUserDataSyncResourceProviderService', ProxyChannel.fromService(accessor.get(IUserDataSyncResourceProviderService), this._store));450451// Tunnel452const sharedProcessTunnelChannel = ProxyChannel.fromService(accessor.get(ISharedProcessTunnelService), this._store);453this.server.registerChannel(ipcSharedProcessTunnelChannelName, sharedProcessTunnelChannel);454455// Remote Tunnel456const remoteTunnelChannel = ProxyChannel.fromService(accessor.get(IRemoteTunnelService), this._store);457this.server.registerChannel('remoteTunnel', remoteTunnelChannel);458459// Web Content Extractor460const webContentExtractorChannel = ProxyChannel.fromService(accessor.get(ISharedWebContentExtractorService), this._store);461this.server.registerChannel('sharedWebContentExtractor', webContentExtractorChannel);462}463464private registerErrorHandler(logService: ILogService): void {465466// Listen on global error events467process.on('uncaughtException', error => onUnexpectedError(error));468process.on('unhandledRejection', (reason: unknown) => onUnexpectedError(reason));469470// Install handler for unexpected errors471setUnexpectedErrorHandler(error => {472const message = toErrorMessage(error, true);473if (!message) {474return;475}476477logService.error(`[uncaught exception in sharedProcess]: ${message}`);478});479}480481private async reportClientOSInfo(telemetryService: ITelemetryService, logService: ILogService): Promise<void> {482if (isLinux) {483const [releaseInfo, displayProtocol] = await Promise.all([484getOSReleaseInfo(logService.error.bind(logService)),485getDisplayProtocol(logService.error.bind(logService))486]);487const desktopEnvironment = getDesktopEnvironment();488const codeSessionType = getCodeDisplayProtocol(displayProtocol, this.configuration.args['ozone-platform']);489if (releaseInfo) {490type ClientPlatformInfoClassification = {491platformId: { classification: 'SystemMetaData'; purpose: 'FeatureInsight'; comment: 'A string identifying the operating system without any version information.' };492platformVersionId: { classification: 'SystemMetaData'; purpose: 'FeatureInsight'; comment: 'A string identifying the operating system version excluding any name information or release code.' };493platformIdLike: { classification: 'SystemMetaData'; purpose: 'FeatureInsight'; comment: 'A string identifying the operating system the current OS derivate is closely related to.' };494desktopEnvironment: { classification: 'SystemMetaData'; purpose: 'FeatureInsight'; comment: 'A string identifying the desktop environment the user is using.' };495displayProtocol: { classification: 'SystemMetaData'; purpose: 'FeatureInsight'; comment: 'A string identifying the users display protocol type.' };496codeDisplayProtocol: { classification: 'SystemMetaData'; purpose: 'FeatureInsight'; comment: 'A string identifying the vscode display protocol type.' };497owner: 'benibenj';498comment: 'Provides insight into the distro and desktop environment information on Linux.';499};500type ClientPlatformInfoEvent = {501platformId: string;502platformVersionId: string | undefined;503platformIdLike: string | undefined;504desktopEnvironment: string | undefined;505displayProtocol: string | undefined;506codeDisplayProtocol: string | undefined;507};508telemetryService.publicLog2<ClientPlatformInfoEvent, ClientPlatformInfoClassification>('clientPlatformInfo', {509platformId: releaseInfo.id,510platformVersionId: releaseInfo.version_id,511platformIdLike: releaseInfo.id_like,512desktopEnvironment: desktopEnvironment,513displayProtocol: displayProtocol,514codeDisplayProtocol: codeSessionType515});516}517}518}519520handledClientConnection(e: MessageEvent): boolean {521522// This filter on message port messages will look for523// attempts of a window to connect raw to the shared524// process to handle these connections separate from525// our IPC based protocol.526527if (e.data !== SharedProcessRawConnection.response) {528return false;529}530531const port = e.ports.at(0);532if (port) {533this.onDidWindowConnectRaw.fire(port);534535return true;536}537538return false;539}540}541542export async function main(configuration: ISharedProcessConfiguration): Promise<void> {543544// create shared process and signal back to main that we are545// ready to accept message ports as client connections546547try {548const sharedProcess = new SharedProcessMain(configuration);549process.parentPort.postMessage(SharedProcessLifecycle.ipcReady);550551// await initialization and signal this back to electron-main552await sharedProcess.init();553554process.parentPort.postMessage(SharedProcessLifecycle.initDone);555} catch (error) {556process.parentPort.postMessage({ error: error.toString() });557}558}559560const handle = setTimeout(() => {561process.parentPort.postMessage({ warning: '[SharedProcess] did not receive configuration within 30s...' });562}, 30000);563564process.parentPort.once('message', (e: Electron.MessageEvent) => {565clearTimeout(handle);566main(e.data as ISharedProcessConfiguration);567});568569570