Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
microsoft
GitHub Repository: microsoft/vscode
Path: blob/main/src/vs/code/electron-utility/sharedProcess/sharedProcessMain.ts
3294 views
1
/*---------------------------------------------------------------------------------------------
2
* Copyright (c) Microsoft Corporation. All rights reserved.
3
* Licensed under the MIT License. See License.txt in the project root for license information.
4
*--------------------------------------------------------------------------------------------*/
5
6
import { hostname, release } from 'os';
7
import { MessagePortMain, MessageEvent } from '../../../base/parts/sandbox/node/electronTypes.js';
8
import { toErrorMessage } from '../../../base/common/errorMessage.js';
9
import { onUnexpectedError, setUnexpectedErrorHandler } from '../../../base/common/errors.js';
10
import { combinedDisposable, Disposable, toDisposable } from '../../../base/common/lifecycle.js';
11
import { Schemas } from '../../../base/common/network.js';
12
import { URI } from '../../../base/common/uri.js';
13
import { Emitter } from '../../../base/common/event.js';
14
import { ProxyChannel, StaticRouter } from '../../../base/parts/ipc/common/ipc.js';
15
import { IClientConnectionFilter, Server as UtilityProcessMessagePortServer, once } from '../../../base/parts/ipc/node/ipc.mp.js';
16
import { CodeCacheCleaner } from './contrib/codeCacheCleaner.js';
17
import { LanguagePackCachedDataCleaner } from './contrib/languagePackCachedDataCleaner.js';
18
import { LocalizationsUpdater } from './contrib/localizationsUpdater.js';
19
import { LogsDataCleaner } from './contrib/logsDataCleaner.js';
20
import { UnusedWorkspaceStorageDataCleaner } from './contrib/storageDataCleaner.js';
21
import { IChecksumService } from '../../../platform/checksum/common/checksumService.js';
22
import { ChecksumService } from '../../../platform/checksum/node/checksumService.js';
23
import { IConfigurationService } from '../../../platform/configuration/common/configuration.js';
24
import { ConfigurationService } from '../../../platform/configuration/common/configurationService.js';
25
import { IDiagnosticsService } from '../../../platform/diagnostics/common/diagnostics.js';
26
import { DiagnosticsService } from '../../../platform/diagnostics/node/diagnosticsService.js';
27
import { IDownloadService } from '../../../platform/download/common/download.js';
28
import { DownloadService } from '../../../platform/download/common/downloadService.js';
29
import { INativeEnvironmentService } from '../../../platform/environment/common/environment.js';
30
import { GlobalExtensionEnablementService } from '../../../platform/extensionManagement/common/extensionEnablementService.js';
31
import { ExtensionGalleryService } from '../../../platform/extensionManagement/common/extensionGalleryService.js';
32
import { IAllowedExtensionsService, IExtensionGalleryService, IExtensionManagementService, IExtensionTipsService, IGlobalExtensionEnablementService } from '../../../platform/extensionManagement/common/extensionManagement.js';
33
import { ExtensionSignatureVerificationService, IExtensionSignatureVerificationService } from '../../../platform/extensionManagement/node/extensionSignatureVerificationService.js';
34
import { ExtensionManagementChannel, ExtensionTipsChannel } from '../../../platform/extensionManagement/common/extensionManagementIpc.js';
35
import { ExtensionManagementService, INativeServerExtensionManagementService } from '../../../platform/extensionManagement/node/extensionManagementService.js';
36
import { IExtensionRecommendationNotificationService } from '../../../platform/extensionRecommendations/common/extensionRecommendations.js';
37
import { IFileService } from '../../../platform/files/common/files.js';
38
import { FileService } from '../../../platform/files/common/fileService.js';
39
import { DiskFileSystemProvider } from '../../../platform/files/node/diskFileSystemProvider.js';
40
import { SyncDescriptor } from '../../../platform/instantiation/common/descriptors.js';
41
import { IInstantiationService, ServicesAccessor } from '../../../platform/instantiation/common/instantiation.js';
42
import { InstantiationService } from '../../../platform/instantiation/common/instantiationService.js';
43
import { ServiceCollection } from '../../../platform/instantiation/common/serviceCollection.js';
44
import { ILanguagePackService } from '../../../platform/languagePacks/common/languagePacks.js';
45
import { NativeLanguagePackService } from '../../../platform/languagePacks/node/languagePacks.js';
46
import { ConsoleLogger, ILoggerService, ILogService, LoggerGroup } from '../../../platform/log/common/log.js';
47
import { LoggerChannelClient } from '../../../platform/log/common/logIpc.js';
48
import product from '../../../platform/product/common/product.js';
49
import { IProductService } from '../../../platform/product/common/productService.js';
50
import { IRequestService } from '../../../platform/request/common/request.js';
51
import { ISharedProcessConfiguration } from '../../../platform/sharedProcess/node/sharedProcess.js';
52
import { IStorageService } from '../../../platform/storage/common/storage.js';
53
import { resolveCommonProperties } from '../../../platform/telemetry/common/commonProperties.js';
54
import { ICustomEndpointTelemetryService, ITelemetryService } from '../../../platform/telemetry/common/telemetry.js';
55
import { TelemetryAppenderChannel } from '../../../platform/telemetry/common/telemetryIpc.js';
56
import { TelemetryLogAppender } from '../../../platform/telemetry/common/telemetryLogAppender.js';
57
import { TelemetryService } from '../../../platform/telemetry/common/telemetryService.js';
58
import { supportsTelemetry, ITelemetryAppender, NullAppender, NullTelemetryService, getPiiPathsFromEnvironment, isInternalTelemetry, isLoggingOnly } from '../../../platform/telemetry/common/telemetryUtils.js';
59
import { CustomEndpointTelemetryService } from '../../../platform/telemetry/node/customEndpointTelemetryService.js';
60
import { ExtensionStorageService, IExtensionStorageService } from '../../../platform/extensionManagement/common/extensionStorage.js';
61
import { IgnoredExtensionsManagementService, IIgnoredExtensionsManagementService } from '../../../platform/userDataSync/common/ignoredExtensions.js';
62
import { IUserDataSyncLocalStoreService, IUserDataSyncLogService, IUserDataSyncEnablementService, IUserDataSyncService, IUserDataSyncStoreManagementService, IUserDataSyncStoreService, IUserDataSyncUtilService, registerConfiguration as registerUserDataSyncConfiguration, IUserDataSyncResourceProviderService } from '../../../platform/userDataSync/common/userDataSync.js';
63
import { IUserDataSyncAccountService, UserDataSyncAccountService } from '../../../platform/userDataSync/common/userDataSyncAccount.js';
64
import { UserDataSyncLocalStoreService } from '../../../platform/userDataSync/common/userDataSyncLocalStoreService.js';
65
import { UserDataSyncAccountServiceChannel, UserDataSyncStoreManagementServiceChannel } from '../../../platform/userDataSync/common/userDataSyncIpc.js';
66
import { UserDataSyncLogService } from '../../../platform/userDataSync/common/userDataSyncLog.js';
67
import { IUserDataSyncMachinesService, UserDataSyncMachinesService } from '../../../platform/userDataSync/common/userDataSyncMachines.js';
68
import { UserDataSyncEnablementService } from '../../../platform/userDataSync/common/userDataSyncEnablementService.js';
69
import { UserDataSyncService } from '../../../platform/userDataSync/common/userDataSyncService.js';
70
import { UserDataSyncServiceChannel } from '../../../platform/userDataSync/common/userDataSyncServiceIpc.js';
71
import { UserDataSyncStoreManagementService, UserDataSyncStoreService } from '../../../platform/userDataSync/common/userDataSyncStoreService.js';
72
import { IUserDataProfileStorageService } from '../../../platform/userDataProfile/common/userDataProfileStorageService.js';
73
import { SharedProcessUserDataProfileStorageService } from '../../../platform/userDataProfile/node/userDataProfileStorageService.js';
74
import { ActiveWindowManager } from '../../../platform/windows/node/windowTracker.js';
75
import { ISignService } from '../../../platform/sign/common/sign.js';
76
import { SignService } from '../../../platform/sign/node/signService.js';
77
import { ISharedTunnelsService } from '../../../platform/tunnel/common/tunnel.js';
78
import { SharedTunnelsService } from '../../../platform/tunnel/node/tunnelService.js';
79
import { ipcSharedProcessTunnelChannelName, ISharedProcessTunnelService } from '../../../platform/remote/common/sharedProcessTunnelService.js';
80
import { SharedProcessTunnelService } from '../../../platform/tunnel/node/sharedProcessTunnelService.js';
81
import { IUriIdentityService } from '../../../platform/uriIdentity/common/uriIdentity.js';
82
import { UriIdentityService } from '../../../platform/uriIdentity/common/uriIdentityService.js';
83
import { isLinux } from '../../../base/common/platform.js';
84
import { FileUserDataProvider } from '../../../platform/userData/common/fileUserDataProvider.js';
85
import { DiskFileSystemProviderClient, LOCAL_FILE_SYSTEM_CHANNEL_NAME } from '../../../platform/files/common/diskFileSystemProviderClient.js';
86
import { InspectProfilingService as V8InspectProfilingService } from '../../../platform/profiling/node/profilingService.js';
87
import { IV8InspectProfilingService } from '../../../platform/profiling/common/profiling.js';
88
import { IExtensionsScannerService } from '../../../platform/extensionManagement/common/extensionsScannerService.js';
89
import { ExtensionsScannerService } from '../../../platform/extensionManagement/node/extensionsScannerService.js';
90
import { IUserDataProfilesService } from '../../../platform/userDataProfile/common/userDataProfile.js';
91
import { IExtensionsProfileScannerService } from '../../../platform/extensionManagement/common/extensionsProfileScannerService.js';
92
import { PolicyChannelClient } from '../../../platform/policy/common/policyIpc.js';
93
import { IPolicyService, NullPolicyService } from '../../../platform/policy/common/policy.js';
94
import { UserDataProfilesService } from '../../../platform/userDataProfile/common/userDataProfileIpc.js';
95
import { OneDataSystemAppender } from '../../../platform/telemetry/node/1dsAppender.js';
96
import { UserDataProfilesCleaner } from './contrib/userDataProfilesCleaner.js';
97
import { IRemoteTunnelService } from '../../../platform/remoteTunnel/common/remoteTunnel.js';
98
import { UserDataSyncResourceProviderService } from '../../../platform/userDataSync/common/userDataSyncResourceProvider.js';
99
import { ExtensionsContributions } from './contrib/extensions.js';
100
import { localize } from '../../../nls.js';
101
import { LogService } from '../../../platform/log/common/logService.js';
102
import { ISharedProcessLifecycleService, SharedProcessLifecycleService } from '../../../platform/lifecycle/node/sharedProcessLifecycleService.js';
103
import { RemoteTunnelService } from '../../../platform/remoteTunnel/node/remoteTunnelService.js';
104
import { ExtensionsProfileScannerService } from '../../../platform/extensionManagement/node/extensionsProfileScannerService.js';
105
import { ExtensionRecommendationNotificationServiceChannelClient } from '../../../platform/extensionRecommendations/common/extensionRecommendationsIpc.js';
106
import { INativeHostService } from '../../../platform/native/common/native.js';
107
import { NativeHostService } from '../../../platform/native/common/nativeHostService.js';
108
import { UserDataAutoSyncService } from '../../../platform/userDataSync/node/userDataAutoSyncService.js';
109
import { ExtensionTipsService } from '../../../platform/extensionManagement/node/extensionTipsService.js';
110
import { IMainProcessService, MainProcessService } from '../../../platform/ipc/common/mainProcessService.js';
111
import { RemoteStorageService } from '../../../platform/storage/common/storageService.js';
112
import { IRemoteSocketFactoryService, RemoteSocketFactoryService } from '../../../platform/remote/common/remoteSocketFactoryService.js';
113
import { RemoteConnectionType } from '../../../platform/remote/common/remoteAuthorityResolver.js';
114
import { nodeSocketFactory } from '../../../platform/remote/node/nodeSocketFactory.js';
115
import { NativeEnvironmentService } from '../../../platform/environment/node/environmentService.js';
116
import { SharedProcessRawConnection, SharedProcessLifecycle } from '../../../platform/sharedProcess/common/sharedProcess.js';
117
import { getOSReleaseInfo } from '../../../base/node/osReleaseInfo.js';
118
import { getDesktopEnvironment } from '../../../base/common/desktopEnvironmentInfo.js';
119
import { getCodeDisplayProtocol, getDisplayProtocol } from '../../../base/node/osDisplayProtocolInfo.js';
120
import { RequestService } from '../../../platform/request/electron-utility/requestService.js';
121
import { DefaultExtensionsInitializer } from './contrib/defaultExtensionsInitializer.js';
122
import { AllowedExtensionsService } from '../../../platform/extensionManagement/common/allowedExtensionsService.js';
123
import { IExtensionGalleryManifestService } from '../../../platform/extensionManagement/common/extensionGalleryManifest.js';
124
import { ExtensionGalleryManifestIPCService } from '../../../platform/extensionManagement/common/extensionGalleryManifestServiceIpc.js';
125
import { ISharedWebContentExtractorService } from '../../../platform/webContentExtractor/common/webContentExtractor.js';
126
import { SharedWebContentExtractorService } from '../../../platform/webContentExtractor/node/sharedWebContentExtractorService.js';
127
import { McpManagementService } from '../../../platform/mcp/node/mcpManagementService.js';
128
import { IAllowedMcpServersService, IMcpGalleryService, IMcpManagementService } from '../../../platform/mcp/common/mcpManagement.js';
129
import { IMcpResourceScannerService, McpResourceScannerService } from '../../../platform/mcp/common/mcpResourceScannerService.js';
130
import { McpGalleryService } from '../../../platform/mcp/common/mcpGalleryService.js';
131
import { McpManagementChannel } from '../../../platform/mcp/common/mcpManagementIpc.js';
132
import { AllowedMcpServersService } from '../../../platform/mcp/common/allowedMcpServersService.js';
133
import { IMcpGalleryManifestService } from '../../../platform/mcp/common/mcpGalleryManifest.js';
134
import { McpGalleryManifestIPCService } from '../../../platform/mcp/common/mcpGalleryManifestServiceIpc.js';
135
136
class SharedProcessMain extends Disposable implements IClientConnectionFilter {
137
138
private readonly server = this._register(new UtilityProcessMessagePortServer(this));
139
140
private lifecycleService: SharedProcessLifecycleService | undefined = undefined;
141
142
private readonly onDidWindowConnectRaw = this._register(new Emitter<MessagePortMain>());
143
144
constructor(private configuration: ISharedProcessConfiguration) {
145
super();
146
147
this.registerListeners();
148
}
149
150
private registerListeners(): void {
151
152
// Shared process lifecycle
153
let didExit = false;
154
const onExit = () => {
155
if (!didExit) {
156
didExit = true;
157
158
this.lifecycleService?.fireOnWillShutdown();
159
this.dispose();
160
}
161
};
162
process.once('exit', onExit);
163
once(process.parentPort, SharedProcessLifecycle.exit, onExit);
164
}
165
166
async init(): Promise<void> {
167
168
// Services
169
const instantiationService = await this.initServices();
170
171
// Config
172
registerUserDataSyncConfiguration();
173
174
instantiationService.invokeFunction(accessor => {
175
const logService = accessor.get(ILogService);
176
const telemetryService = accessor.get(ITelemetryService);
177
178
// Log info
179
logService.trace('sharedProcess configuration', JSON.stringify(this.configuration));
180
181
// Channels
182
this.initChannels(accessor);
183
184
// Error handler
185
this.registerErrorHandler(logService);
186
187
// Report Client OS/DE Info
188
this.reportClientOSInfo(telemetryService, logService);
189
});
190
191
// Instantiate Contributions
192
this._register(combinedDisposable(
193
instantiationService.createInstance(CodeCacheCleaner, this.configuration.codeCachePath),
194
instantiationService.createInstance(LanguagePackCachedDataCleaner),
195
instantiationService.createInstance(UnusedWorkspaceStorageDataCleaner),
196
instantiationService.createInstance(LogsDataCleaner),
197
instantiationService.createInstance(LocalizationsUpdater),
198
instantiationService.createInstance(ExtensionsContributions),
199
instantiationService.createInstance(UserDataProfilesCleaner),
200
instantiationService.createInstance(DefaultExtensionsInitializer)
201
));
202
}
203
204
private async initServices(): Promise<IInstantiationService> {
205
const services = new ServiceCollection();
206
207
// Product
208
const productService = { _serviceBrand: undefined, ...product };
209
services.set(IProductService, productService);
210
211
// Main Process
212
const mainRouter = new StaticRouter(ctx => ctx === 'main');
213
const mainProcessService = new MainProcessService(this.server, mainRouter);
214
services.set(IMainProcessService, mainProcessService);
215
216
// Policies
217
const policyService = this.configuration.policiesData ? new PolicyChannelClient(this.configuration.policiesData, mainProcessService.getChannel('policy')) : new NullPolicyService();
218
services.set(IPolicyService, policyService);
219
220
// Environment
221
const environmentService = new NativeEnvironmentService(this.configuration.args, productService);
222
services.set(INativeEnvironmentService, environmentService);
223
224
// Logger
225
const loggerService = new LoggerChannelClient(undefined, this.configuration.logLevel, environmentService.logsHome, this.configuration.loggers.map(loggerResource => ({ ...loggerResource, resource: URI.revive(loggerResource.resource) })), mainProcessService.getChannel('logger'));
226
services.set(ILoggerService, loggerService);
227
228
// Log
229
const sharedLogGroup: LoggerGroup = { id: 'shared', name: localize('sharedLog', "Shared") };
230
const logger = this._register(loggerService.createLogger('sharedprocess', { name: localize('sharedLog', "Shared"), group: sharedLogGroup }));
231
const consoleLogger = this._register(new ConsoleLogger(logger.getLevel()));
232
const logService = this._register(new LogService(logger, [consoleLogger]));
233
services.set(ILogService, logService);
234
235
// Lifecycle
236
this.lifecycleService = this._register(new SharedProcessLifecycleService(logService));
237
services.set(ISharedProcessLifecycleService, this.lifecycleService);
238
239
// Files
240
const fileService = this._register(new FileService(logService));
241
services.set(IFileService, fileService);
242
243
const diskFileSystemProvider = this._register(new DiskFileSystemProvider(logService));
244
fileService.registerProvider(Schemas.file, diskFileSystemProvider);
245
246
// URI Identity
247
const uriIdentityService = new UriIdentityService(fileService);
248
services.set(IUriIdentityService, uriIdentityService);
249
250
// User Data Profiles
251
const userDataProfilesService = this._register(new UserDataProfilesService(this.configuration.profiles.all, URI.revive(this.configuration.profiles.home).with({ scheme: environmentService.userRoamingDataHome.scheme }), mainProcessService.getChannel('userDataProfiles')));
252
services.set(IUserDataProfilesService, userDataProfilesService);
253
254
const userDataFileSystemProvider = this._register(new FileUserDataProvider(
255
Schemas.file,
256
// Specifically for user data, use the disk file system provider
257
// from the main process to enable atomic read/write operations.
258
// Since user data can change very frequently across multiple
259
// processes, we want a single process handling these operations.
260
this._register(new DiskFileSystemProviderClient(mainProcessService.getChannel(LOCAL_FILE_SYSTEM_CHANNEL_NAME), { pathCaseSensitive: isLinux })),
261
Schemas.vscodeUserData,
262
userDataProfilesService,
263
uriIdentityService,
264
logService
265
));
266
fileService.registerProvider(Schemas.vscodeUserData, userDataFileSystemProvider);
267
268
// Configuration
269
const configurationService = this._register(new ConfigurationService(userDataProfilesService.defaultProfile.settingsResource, fileService, policyService, logService));
270
services.set(IConfigurationService, configurationService);
271
272
// Storage (global access only)
273
const storageService = new RemoteStorageService(undefined, { defaultProfile: userDataProfilesService.defaultProfile, currentProfile: userDataProfilesService.defaultProfile }, mainProcessService, environmentService);
274
services.set(IStorageService, storageService);
275
this._register(toDisposable(() => storageService.flush()));
276
277
// Initialize config & storage in parallel
278
await Promise.all([
279
configurationService.initialize(),
280
storageService.initialize()
281
]);
282
283
// Request
284
const networkLogger = this._register(loggerService.createLogger(`network-shared`, { name: localize('networkk', "Network"), group: sharedLogGroup }));
285
const requestService = new RequestService(configurationService, environmentService, this._register(new LogService(networkLogger)));
286
services.set(IRequestService, requestService);
287
288
// Checksum
289
services.set(IChecksumService, new SyncDescriptor(ChecksumService, undefined, false /* proxied to other processes */));
290
291
// V8 Inspect profiler
292
services.set(IV8InspectProfilingService, new SyncDescriptor(V8InspectProfilingService, undefined, false /* proxied to other processes */));
293
294
// Native Host
295
const nativeHostService = new NativeHostService(-1 /* we are not running in a browser window context */, mainProcessService) as INativeHostService;
296
services.set(INativeHostService, nativeHostService);
297
298
// Download
299
services.set(IDownloadService, new SyncDescriptor(DownloadService, undefined, true));
300
301
// Extension recommendations
302
const activeWindowManager = this._register(new ActiveWindowManager(nativeHostService));
303
const activeWindowRouter = new StaticRouter(ctx => activeWindowManager.getActiveClientId().then(id => ctx === id));
304
services.set(IExtensionRecommendationNotificationService, new ExtensionRecommendationNotificationServiceChannelClient(this.server.getChannel('extensionRecommendationNotification', activeWindowRouter)));
305
306
// Telemetry
307
let telemetryService: ITelemetryService;
308
const appenders: ITelemetryAppender[] = [];
309
const internalTelemetry = isInternalTelemetry(productService, configurationService);
310
if (supportsTelemetry(productService, environmentService)) {
311
const logAppender = new TelemetryLogAppender('', false, loggerService, environmentService, productService);
312
appenders.push(logAppender);
313
if (!isLoggingOnly(productService, environmentService) && productService.aiConfig?.ariaKey) {
314
const collectorAppender = new OneDataSystemAppender(requestService, internalTelemetry, 'monacoworkbench', null, productService.aiConfig.ariaKey);
315
this._register(toDisposable(() => collectorAppender.flush())); // Ensure the 1DS appender is disposed so that it flushes remaining data
316
appenders.push(collectorAppender);
317
}
318
319
telemetryService = new TelemetryService({
320
appenders,
321
commonProperties: resolveCommonProperties(release(), hostname(), process.arch, productService.commit, productService.version, this.configuration.machineId, this.configuration.sqmId, this.configuration.devDeviceId, internalTelemetry, productService.date),
322
sendErrorTelemetry: true,
323
piiPaths: getPiiPathsFromEnvironment(environmentService),
324
}, configurationService, productService);
325
} else {
326
telemetryService = NullTelemetryService;
327
const nullAppender = NullAppender;
328
appenders.push(nullAppender);
329
}
330
331
this.server.registerChannel('telemetryAppender', new TelemetryAppenderChannel(appenders));
332
services.set(ITelemetryService, telemetryService);
333
334
// Custom Endpoint Telemetry
335
const customEndpointTelemetryService = new CustomEndpointTelemetryService(configurationService, telemetryService, loggerService, environmentService, productService);
336
services.set(ICustomEndpointTelemetryService, customEndpointTelemetryService);
337
338
// Extension Management
339
services.set(IExtensionsProfileScannerService, new SyncDescriptor(ExtensionsProfileScannerService, undefined, true));
340
services.set(IExtensionsScannerService, new SyncDescriptor(ExtensionsScannerService, undefined, true));
341
services.set(IExtensionSignatureVerificationService, new SyncDescriptor(ExtensionSignatureVerificationService, undefined, true));
342
services.set(IAllowedExtensionsService, new SyncDescriptor(AllowedExtensionsService, undefined, true));
343
services.set(INativeServerExtensionManagementService, new SyncDescriptor(ExtensionManagementService, undefined, true));
344
345
// MCP Management
346
services.set(IAllowedMcpServersService, new SyncDescriptor(AllowedMcpServersService, undefined, true));
347
services.set(IMcpGalleryManifestService, new McpGalleryManifestIPCService(this.server));
348
services.set(IMcpGalleryService, new SyncDescriptor(McpGalleryService, undefined, true));
349
services.set(IMcpResourceScannerService, new SyncDescriptor(McpResourceScannerService, undefined, true));
350
services.set(IMcpManagementService, new SyncDescriptor(McpManagementService, undefined, true));
351
352
// Extension Gallery
353
services.set(IExtensionGalleryManifestService, new ExtensionGalleryManifestIPCService(this.server, productService));
354
services.set(IExtensionGalleryService, new SyncDescriptor(ExtensionGalleryService, undefined, true));
355
356
// Extension Tips
357
services.set(IExtensionTipsService, new SyncDescriptor(ExtensionTipsService, undefined, false /* Eagerly scans and computes exe based recommendations */));
358
359
// Localizations
360
services.set(ILanguagePackService, new SyncDescriptor(NativeLanguagePackService, undefined, false /* proxied to other processes */));
361
362
// Diagnostics
363
services.set(IDiagnosticsService, new SyncDescriptor(DiagnosticsService, undefined, false /* proxied to other processes */));
364
365
// Settings Sync
366
services.set(IUserDataSyncAccountService, new SyncDescriptor(UserDataSyncAccountService, undefined, true));
367
services.set(IUserDataSyncLogService, new SyncDescriptor(UserDataSyncLogService, undefined, true));
368
services.set(IUserDataSyncUtilService, ProxyChannel.toService(this.server.getChannel('userDataSyncUtil', client => client.ctx !== 'main')));
369
services.set(IGlobalExtensionEnablementService, new SyncDescriptor(GlobalExtensionEnablementService, undefined, false /* Eagerly resets installed extensions */));
370
services.set(IIgnoredExtensionsManagementService, new SyncDescriptor(IgnoredExtensionsManagementService, undefined, true));
371
services.set(IExtensionStorageService, new SyncDescriptor(ExtensionStorageService));
372
services.set(IUserDataSyncStoreManagementService, new SyncDescriptor(UserDataSyncStoreManagementService, undefined, true));
373
services.set(IUserDataSyncStoreService, new SyncDescriptor(UserDataSyncStoreService, undefined, true));
374
services.set(IUserDataSyncMachinesService, new SyncDescriptor(UserDataSyncMachinesService, undefined, true));
375
services.set(IUserDataSyncLocalStoreService, new SyncDescriptor(UserDataSyncLocalStoreService, undefined, false /* Eagerly cleans up old backups */));
376
services.set(IUserDataSyncEnablementService, new SyncDescriptor(UserDataSyncEnablementService, undefined, true));
377
services.set(IUserDataSyncService, new SyncDescriptor(UserDataSyncService, undefined, false /* Initializes the Sync State */));
378
services.set(IUserDataProfileStorageService, new SyncDescriptor(SharedProcessUserDataProfileStorageService, undefined, true));
379
services.set(IUserDataSyncResourceProviderService, new SyncDescriptor(UserDataSyncResourceProviderService, undefined, true));
380
381
// Signing
382
services.set(ISignService, new SyncDescriptor(SignService, undefined, false /* proxied to other processes */));
383
384
// Tunnel
385
const remoteSocketFactoryService = new RemoteSocketFactoryService();
386
services.set(IRemoteSocketFactoryService, remoteSocketFactoryService);
387
remoteSocketFactoryService.register(RemoteConnectionType.WebSocket, nodeSocketFactory);
388
services.set(ISharedTunnelsService, new SyncDescriptor(SharedTunnelsService));
389
services.set(ISharedProcessTunnelService, new SyncDescriptor(SharedProcessTunnelService));
390
391
// Remote Tunnel
392
services.set(IRemoteTunnelService, new SyncDescriptor(RemoteTunnelService));
393
394
// Web Content Extractor
395
services.set(ISharedWebContentExtractorService, new SyncDescriptor(SharedWebContentExtractorService));
396
397
return new InstantiationService(services);
398
}
399
400
private initChannels(accessor: ServicesAccessor): void {
401
402
// Extensions Management
403
const channel = new ExtensionManagementChannel(accessor.get(IExtensionManagementService), () => null);
404
this.server.registerChannel('extensions', channel);
405
406
// Mcp Management
407
const mcpManagementChannel = new McpManagementChannel(accessor.get(IMcpManagementService), () => null);
408
this.server.registerChannel('mcpManagement', mcpManagementChannel);
409
410
// Language Packs
411
const languagePacksChannel = ProxyChannel.fromService(accessor.get(ILanguagePackService), this._store);
412
this.server.registerChannel('languagePacks', languagePacksChannel);
413
414
// Diagnostics
415
const diagnosticsChannel = ProxyChannel.fromService(accessor.get(IDiagnosticsService), this._store);
416
this.server.registerChannel('diagnostics', diagnosticsChannel);
417
418
// Extension Tips
419
const extensionTipsChannel = new ExtensionTipsChannel(accessor.get(IExtensionTipsService));
420
this.server.registerChannel('extensionTipsService', extensionTipsChannel);
421
422
// Checksum
423
const checksumChannel = ProxyChannel.fromService(accessor.get(IChecksumService), this._store);
424
this.server.registerChannel('checksum', checksumChannel);
425
426
// Profiling
427
const profilingChannel = ProxyChannel.fromService(accessor.get(IV8InspectProfilingService), this._store);
428
this.server.registerChannel('v8InspectProfiling', profilingChannel);
429
430
// Settings Sync
431
const userDataSyncMachineChannel = ProxyChannel.fromService(accessor.get(IUserDataSyncMachinesService), this._store);
432
this.server.registerChannel('userDataSyncMachines', userDataSyncMachineChannel);
433
434
// Custom Endpoint Telemetry
435
const customEndpointTelemetryChannel = ProxyChannel.fromService(accessor.get(ICustomEndpointTelemetryService), this._store);
436
this.server.registerChannel('customEndpointTelemetry', customEndpointTelemetryChannel);
437
438
const userDataSyncAccountChannel = new UserDataSyncAccountServiceChannel(accessor.get(IUserDataSyncAccountService));
439
this.server.registerChannel('userDataSyncAccount', userDataSyncAccountChannel);
440
441
const userDataSyncStoreManagementChannel = new UserDataSyncStoreManagementServiceChannel(accessor.get(IUserDataSyncStoreManagementService));
442
this.server.registerChannel('userDataSyncStoreManagement', userDataSyncStoreManagementChannel);
443
444
const userDataSyncChannel = new UserDataSyncServiceChannel(accessor.get(IUserDataSyncService), accessor.get(IUserDataProfilesService), accessor.get(ILogService));
445
this.server.registerChannel('userDataSync', userDataSyncChannel);
446
447
const userDataAutoSync = this._register(accessor.get(IInstantiationService).createInstance(UserDataAutoSyncService));
448
this.server.registerChannel('userDataAutoSync', ProxyChannel.fromService(userDataAutoSync, this._store));
449
450
this.server.registerChannel('IUserDataSyncResourceProviderService', ProxyChannel.fromService(accessor.get(IUserDataSyncResourceProviderService), this._store));
451
452
// Tunnel
453
const sharedProcessTunnelChannel = ProxyChannel.fromService(accessor.get(ISharedProcessTunnelService), this._store);
454
this.server.registerChannel(ipcSharedProcessTunnelChannelName, sharedProcessTunnelChannel);
455
456
// Remote Tunnel
457
const remoteTunnelChannel = ProxyChannel.fromService(accessor.get(IRemoteTunnelService), this._store);
458
this.server.registerChannel('remoteTunnel', remoteTunnelChannel);
459
460
// Web Content Extractor
461
const webContentExtractorChannel = ProxyChannel.fromService(accessor.get(ISharedWebContentExtractorService), this._store);
462
this.server.registerChannel('sharedWebContentExtractor', webContentExtractorChannel);
463
}
464
465
private registerErrorHandler(logService: ILogService): void {
466
467
// Listen on global error events
468
process.on('uncaughtException', error => onUnexpectedError(error));
469
process.on('unhandledRejection', (reason: unknown) => onUnexpectedError(reason));
470
471
// Install handler for unexpected errors
472
setUnexpectedErrorHandler(error => {
473
const message = toErrorMessage(error, true);
474
if (!message) {
475
return;
476
}
477
478
logService.error(`[uncaught exception in sharedProcess]: ${message}`);
479
});
480
}
481
482
private async reportClientOSInfo(telemetryService: ITelemetryService, logService: ILogService): Promise<void> {
483
if (isLinux) {
484
const [releaseInfo, displayProtocol] = await Promise.all([
485
getOSReleaseInfo(logService.error.bind(logService)),
486
getDisplayProtocol(logService.error.bind(logService))
487
]);
488
const desktopEnvironment = getDesktopEnvironment();
489
const codeSessionType = getCodeDisplayProtocol(displayProtocol, this.configuration.args['ozone-platform']);
490
if (releaseInfo) {
491
type ClientPlatformInfoClassification = {
492
platformId: { classification: 'SystemMetaData'; purpose: 'FeatureInsight'; comment: 'A string identifying the operating system without any version information.' };
493
platformVersionId: { classification: 'SystemMetaData'; purpose: 'FeatureInsight'; comment: 'A string identifying the operating system version excluding any name information or release code.' };
494
platformIdLike: { classification: 'SystemMetaData'; purpose: 'FeatureInsight'; comment: 'A string identifying the operating system the current OS derivate is closely related to.' };
495
desktopEnvironment: { classification: 'SystemMetaData'; purpose: 'FeatureInsight'; comment: 'A string identifying the desktop environment the user is using.' };
496
displayProtocol: { classification: 'SystemMetaData'; purpose: 'FeatureInsight'; comment: 'A string identifying the users display protocol type.' };
497
codeDisplayProtocol: { classification: 'SystemMetaData'; purpose: 'FeatureInsight'; comment: 'A string identifying the vscode display protocol type.' };
498
owner: 'benibenj';
499
comment: 'Provides insight into the distro and desktop environment information on Linux.';
500
};
501
type ClientPlatformInfoEvent = {
502
platformId: string;
503
platformVersionId: string | undefined;
504
platformIdLike: string | undefined;
505
desktopEnvironment: string | undefined;
506
displayProtocol: string | undefined;
507
codeDisplayProtocol: string | undefined;
508
};
509
telemetryService.publicLog2<ClientPlatformInfoEvent, ClientPlatformInfoClassification>('clientPlatformInfo', {
510
platformId: releaseInfo.id,
511
platformVersionId: releaseInfo.version_id,
512
platformIdLike: releaseInfo.id_like,
513
desktopEnvironment: desktopEnvironment,
514
displayProtocol: displayProtocol,
515
codeDisplayProtocol: codeSessionType
516
});
517
}
518
}
519
}
520
521
handledClientConnection(e: MessageEvent): boolean {
522
523
// This filter on message port messages will look for
524
// attempts of a window to connect raw to the shared
525
// process to handle these connections separate from
526
// our IPC based protocol.
527
528
if (e.data !== SharedProcessRawConnection.response) {
529
return false;
530
}
531
532
const port = e.ports.at(0);
533
if (port) {
534
this.onDidWindowConnectRaw.fire(port);
535
536
return true;
537
}
538
539
return false;
540
}
541
}
542
543
export async function main(configuration: ISharedProcessConfiguration): Promise<void> {
544
545
// create shared process and signal back to main that we are
546
// ready to accept message ports as client connections
547
548
try {
549
const sharedProcess = new SharedProcessMain(configuration);
550
process.parentPort.postMessage(SharedProcessLifecycle.ipcReady);
551
552
// await initialization and signal this back to electron-main
553
await sharedProcess.init();
554
555
process.parentPort.postMessage(SharedProcessLifecycle.initDone);
556
} catch (error) {
557
process.parentPort.postMessage({ error: error.toString() });
558
}
559
}
560
561
const handle = setTimeout(() => {
562
process.parentPort.postMessage({ warning: '[SharedProcess] did not receive configuration within 30s...' });
563
}, 30000);
564
565
process.parentPort.once('message', (e: Electron.MessageEvent) => {
566
clearTimeout(handle);
567
main(e.data as ISharedProcessConfiguration);
568
});
569
570