From bf524a9c2c54bb142bae5d3b4602b2957cc236ed Mon Sep 17 00:00:00 2001
From: Baptiste Augrain <daiyam@zokugun.org>
Date: Mon, 6 Sep 2021 12:01:31 +0200
Subject: [PATCH] fix(1.60): add patch to disable CORS (#822)

---
 patches/disable-cors.patch | 158 +++++++++++++++++++++++++++++++++++++
 patches/fix-cors.patch     |  13 ---
 2 files changed, 158 insertions(+), 13 deletions(-)
 create mode 100644 patches/disable-cors.patch
 delete mode 100644 patches/fix-cors.patch

diff --git a/patches/disable-cors.patch b/patches/disable-cors.patch
new file mode 100644
index 0000000..fefdc77
--- /dev/null
+++ b/patches/disable-cors.patch
@@ -0,0 +1,158 @@
+diff --git a/src/bootstrap-window.js b/src/bootstrap-window.js
+index 0cc92ec..43042d5 100644
+--- a/src/bootstrap-window.js
++++ b/src/bootstrap-window.js
+@@ -24,6 +24,7 @@
+ 	const bootstrapLib = bootstrap();
+ 	const preloadGlobals = sandboxGlobals();
+ 	const safeProcess = preloadGlobals.process;
++	const useCustomProtocol = safeProcess.sandboxed;
+ 
+ 	/**
+ 	 * @typedef {import('./vs/base/parts/sandbox/common/sandboxTypes').ISandboxConfiguration} ISandboxConfiguration
+@@ -99,6 +100,11 @@
+ 
+ 		window.document.documentElement.setAttribute('lang', locale);
+ 
++		// Do not advertise AMD to avoid confusing UMD modules loaded with nodejs
++		if (!useCustomProtocol) {
++			window['define'] = undefined;
++		}
++
+ 		// Replace the patched electron fs with the original node fs for all AMD code (TODO@sandbox non-sandboxed only)
+ 		if (!safeProcess.sandboxed) {
+ 			require.define('fs', [], function () { return require.__$__nodeRequire('original-fs'); });
+@@ -107,9 +113,11 @@
+ 		window['MonacoEnvironment'] = {};
+ 
+ 		const loaderConfig = {
+-			baseUrl: `${bootstrapLib.fileUriFromPath(configuration.appRoot, { isWindows: safeProcess.platform === 'win32', scheme: 'vscode-file', fallbackAuthority: 'vscode-app' })}/out`,
++			baseUrl: useCustomProtocol ?
++				`${bootstrapLib.fileUriFromPath(configuration.appRoot, { isWindows: safeProcess.platform === 'win32', scheme: 'vscode-file', fallbackAuthority: 'vscode-app' })}/out` :
++				`${bootstrapLib.fileUriFromPath(configuration.appRoot, { isWindows: safeProcess.platform === 'win32' })}/out`,
+ 			'vs/nls': nlsConfig,
+-			preferScriptTags: true
++			preferScriptTags: useCustomProtocol
+ 		};
+ 
+ 		// use a trusted types policy when loading via script tags
+@@ -143,6 +151,14 @@
+ 			loaderConfig.amdModulesPattern = /^vs\//;
+ 		}
+ 
++		// Cached data config (node.js loading only)
++		if (!useCustomProtocol && configuration.codeCachePath) {
++			loaderConfig.nodeCachedData = {
++				path: configuration.codeCachePath,
++				seed: modulePaths.join('')
++			};
++		}
++
+ 		// Signal before require.config()
+ 		if (typeof options?.beforeLoaderConfig === 'function') {
+ 			options.beforeLoaderConfig(loaderConfig);
+diff --git a/src/vs/base/common/network.ts b/src/vs/base/common/network.ts
+index 41a3fe9..bbb06e3 100644
+--- a/src/vs/base/common/network.ts
++++ b/src/vs/base/common/network.ts
+@@ -166,16 +166,7 @@ class FileAccessImpl {
+ 		}
+ 
+ 		// Convert to `vscode-file` resource..
+-		if (
+-			// ...only ever for `file` resources
+-			uri.scheme === Schemas.file &&
+-			(
+-				// ...and we run in native environments
+-				platform.isNative ||
+-				// ...or web worker extensions on desktop
+-				(typeof platform.globals.importScripts === 'function' && platform.globals.origin === `${Schemas.vscodeFileResource}://${FileAccessImpl.FALLBACK_AUTHORITY}`)
+-			)
+-		) {
++		if (uri.scheme === Schemas.file && typeof platform.globals.importScripts === 'function' && platform.globals.origin === `${Schemas.vscodeFileResource}://${FileAccessImpl.FALLBACK_AUTHORITY}`) {
+ 			return uri.with({
+ 				scheme: Schemas.vscodeFileResource,
+ 				// We need to provide an authority here so that it can serve
+diff --git a/src/vs/platform/protocol/electron-main/protocolMainService.ts b/src/vs/platform/protocol/electron-main/protocolMainService.ts
+index bde08d8..3f09ad1 100644
+--- a/src/vs/platform/protocol/electron-main/protocolMainService.ts
++++ b/src/vs/platform/protocol/electron-main/protocolMainService.ts
+@@ -72,9 +72,24 @@ export class ProtocolMainService extends Disposable implements IProtocolMainServ
+ 	//#region file://
+ 
+ 	private handleFileRequest(request: Electron.ProtocolRequest, callback: ProtocolCallback) {
+-		const uri = URI.parse(request.url);
++		const fileUri = URI.parse(request.url);
++
++		// first check by validRoots
++		if (this.validRoots.findSubstr(fileUri)) {
++			return callback({
++				path: fileUri.fsPath
++			});
++		}
+ 
+-		this.logService.error(`Refused to load resource ${uri.fsPath} from ${Schemas.file}: protocol (original URL: ${request.url})`);
++		// then check by validExtensions
++		if (this.validExtensions.has(extname(fileUri))) {
++			return callback({
++				path: fileUri.fsPath
++			});
++		}
++
++		// finally block to load the resource
++		this.logService.error(`${Schemas.file}: Refused to load resource ${fileUri.fsPath} from ${Schemas.file}: protocol (original URL: ${request.url})`);
+ 
+ 		return callback({ error: -3 /* ABORTED */ });
+ 	}
+diff --git a/src/vs/workbench/services/timer/electron-sandbox/timerService.ts b/src/vs/workbench/services/timer/electron-sandbox/timerService.ts
+index 7cae207..1c54ac9 100644
+--- a/src/vs/workbench/services/timer/electron-sandbox/timerService.ts
++++ b/src/vs/workbench/services/timer/electron-sandbox/timerService.ts
+@@ -19,7 +19,7 @@ import { process } from 'vs/base/parts/sandbox/electron-sandbox/globals';
+ import { registerSingleton } from 'vs/platform/instantiation/common/extensions';
+ import { IWorkbenchLayoutService } from 'vs/workbench/services/layout/browser/layoutService';
+ import { IProductService } from 'vs/platform/product/common/productService';
+-import { IStorageService, StorageScope, StorageTarget } from 'vs/platform/storage/common/storage';
++import { IStorageService } from 'vs/platform/storage/common/storage';
+ 
+ export class TimerService extends AbstractTimerService {
+ 
+@@ -91,24 +91,23 @@ registerSingleton(ITimerService, TimerService);
+ 
+ //#region cached data logic
+ 
+-const lastRunningCommitStorageKey = 'perf/lastRunningCommit';
+-let _didUseCachedData: boolean | undefined = undefined;
+-
+ export function didUseCachedData(productService: IProductService, storageService: IStorageService, environmentService: INativeWorkbenchEnvironmentService): boolean {
+-	// browser code loading: only a guess based on
+-	// this being the first start with the commit
+-	// or subsequent
+-	if (typeof _didUseCachedData !== 'boolean') {
+-		if (!environmentService.configuration.codeCachePath || !productService.commit) {
+-			_didUseCachedData = false; // we only produce cached data whith commit and code cache path
+-		} else if (storageService.get(lastRunningCommitStorageKey, StorageScope.GLOBAL) === productService.commit) {
+-			_didUseCachedData = true; // subsequent start on same commit, assume cached data is there
+-		} else {
+-			storageService.store(lastRunningCommitStorageKey, productService.commit, StorageScope.GLOBAL, StorageTarget.MACHINE);
+-			_didUseCachedData = false; // first time start on commit, assume cached data is not yet there
++	if (!Boolean((<any>window).require.getConfig().nodeCachedData)) {
++		return false;
++	}
++	// There are loader events that signal if cached data was missing, rejected,
++	// or used. The former two mean no cached data.
++	let cachedDataFound = 0;
++	for (const event of require.getStats()) {
++		switch (event.type) {
++			case LoaderEventType.CachedDataRejected:
++				return false;
++			case LoaderEventType.CachedDataFound:
++				cachedDataFound += 1;
++				break;
+ 		}
+ 	}
+-	return _didUseCachedData;
++	return cachedDataFound > 0;
+ }
+ 
+ //#endregion
diff --git a/patches/fix-cors.patch b/patches/fix-cors.patch
deleted file mode 100644
index b15e2b9..0000000
--- a/patches/fix-cors.patch
+++ /dev/null
@@ -1,13 +0,0 @@
-diff --git a/src/main.js b/src/main.js
-index f91f7b7..0ec4b6f 100644
---- a/src/main.js
-+++ b/src/main.js
-@@ -174,7 +174,7 @@ function configureCommandlineSwitchesSync(cliArgs) {
- 	// Read argv config
- 	const argvConfig = readArgvConfigSync();
- 
--	let browserCodeLoadingStrategy = typeof codeCachePath === 'string' ? 'bypassHeatCheck' : 'none';
-+	let browserCodeLoadingStrategy = undefined;
- 
- 	Object.keys(argvConfig).forEach(argvKey => {
- 		const argvValue = argvConfig[argvKey];