Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
microsoft
GitHub Repository: microsoft/vscode
Path: blob/main/build/lib/builtInExtensionsCG.js
3520 views
1
"use strict";
2
var __importDefault = (this && this.__importDefault) || function (mod) {
3
return (mod && mod.__esModule) ? mod : { "default": mod };
4
};
5
Object.defineProperty(exports, "__esModule", { value: true });
6
/*---------------------------------------------------------------------------------------------
7
* Copyright (c) Microsoft Corporation. All rights reserved.
8
* Licensed under the MIT License. See License.txt in the project root for license information.
9
*--------------------------------------------------------------------------------------------*/
10
const fs_1 = __importDefault(require("fs"));
11
const path_1 = __importDefault(require("path"));
12
const url_1 = __importDefault(require("url"));
13
const ansi_colors_1 = __importDefault(require("ansi-colors"));
14
const root = path_1.default.dirname(path_1.default.dirname(__dirname));
15
const rootCG = path_1.default.join(root, 'extensionsCG');
16
const productjson = JSON.parse(fs_1.default.readFileSync(path_1.default.join(__dirname, '../../product.json'), 'utf8'));
17
const builtInExtensions = productjson.builtInExtensions || [];
18
const webBuiltInExtensions = productjson.webBuiltInExtensions || [];
19
const token = process.env['GITHUB_TOKEN'];
20
const contentBasePath = 'raw.githubusercontent.com';
21
const contentFileNames = ['package.json', 'package-lock.json'];
22
async function downloadExtensionDetails(extension) {
23
const extensionLabel = `${extension.name}@${extension.version}`;
24
const repository = url_1.default.parse(extension.repo).path.substr(1);
25
const repositoryContentBaseUrl = `https://${token ? `${token}@` : ''}${contentBasePath}/${repository}/v${extension.version}`;
26
async function getContent(fileName) {
27
try {
28
const response = await fetch(`${repositoryContentBaseUrl}/${fileName}`);
29
if (response.ok) {
30
return { fileName, body: Buffer.from(await response.arrayBuffer()) };
31
}
32
else if (response.status === 404) {
33
return { fileName, body: undefined };
34
}
35
else {
36
return { fileName, body: null };
37
}
38
}
39
catch (e) {
40
return { fileName, body: null };
41
}
42
}
43
const promises = contentFileNames.map(getContent);
44
console.log(extensionLabel);
45
const results = await Promise.all(promises);
46
for (const result of results) {
47
if (result.body) {
48
const extensionFolder = path_1.default.join(rootCG, extension.name);
49
fs_1.default.mkdirSync(extensionFolder, { recursive: true });
50
fs_1.default.writeFileSync(path_1.default.join(extensionFolder, result.fileName), result.body);
51
console.log(` - ${result.fileName} ${ansi_colors_1.default.green('✔︎')}`);
52
}
53
else if (result.body === undefined) {
54
console.log(` - ${result.fileName} ${ansi_colors_1.default.yellow('⚠️')}`);
55
}
56
else {
57
console.log(` - ${result.fileName} ${ansi_colors_1.default.red('🛑')}`);
58
}
59
}
60
// Validation
61
if (!results.find(r => r.fileName === 'package.json')?.body) {
62
// throw new Error(`The "package.json" file could not be found for the built-in extension - ${extensionLabel}`);
63
}
64
if (!results.find(r => r.fileName === 'package-lock.json')?.body) {
65
// throw new Error(`The "package-lock.json" could not be found for the built-in extension - ${extensionLabel}`);
66
}
67
}
68
async function main() {
69
for (const extension of [...builtInExtensions, ...webBuiltInExtensions]) {
70
await downloadExtensionDetails(extension);
71
}
72
}
73
main().then(() => {
74
console.log(`Built-in extensions component data downloaded ${ansi_colors_1.default.green('✔︎')}`);
75
process.exit(0);
76
}, err => {
77
console.log(`Built-in extensions component data could not be downloaded ${ansi_colors_1.default.red('🛑')}`);
78
console.error(err);
79
process.exit(1);
80
});
81
//# sourceMappingURL=builtInExtensionsCG.js.map
82