@theia/filesystem 1.48.1 → 1.48.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +30 -30
- package/lib/browser/breadcrumbs/filepath-breadcrumb.d.ts +15 -15
- package/lib/browser/breadcrumbs/filepath-breadcrumb.js +41 -41
- package/lib/browser/breadcrumbs/filepath-breadcrumbs-container.d.ts +13 -13
- package/lib/browser/breadcrumbs/filepath-breadcrumbs-container.js +70 -70
- package/lib/browser/breadcrumbs/filepath-breadcrumbs-contribution.d.ts +27 -27
- package/lib/browser/breadcrumbs/filepath-breadcrumbs-contribution.js +118 -118
- package/lib/browser/download/file-download-command-contribution.d.ts +18 -18
- package/lib/browser/download/file-download-command-contribution.js +75 -75
- package/lib/browser/download/file-download-frontend-module.d.ts +3 -3
- package/lib/browser/download/file-download-frontend-module.js +25 -25
- package/lib/browser/download/file-download-service.d.ts +28 -28
- package/lib/browser/download/file-download-service.js +167 -167
- package/lib/browser/file-dialog/file-dialog-container.d.ts +5 -5
- package/lib/browser/file-dialog/file-dialog-container.js +60 -60
- package/lib/browser/file-dialog/file-dialog-hidden-files-renderer.d.ts +15 -15
- package/lib/browser/file-dialog/file-dialog-hidden-files-renderer.js +59 -59
- package/lib/browser/file-dialog/file-dialog-model.d.ts +25 -25
- package/lib/browser/file-dialog/file-dialog-model.js +100 -100
- package/lib/browser/file-dialog/file-dialog-module.d.ts +3 -3
- package/lib/browser/file-dialog/file-dialog-module.js +45 -45
- package/lib/browser/file-dialog/file-dialog-service.d.ts +32 -32
- package/lib/browser/file-dialog/file-dialog-service.js +101 -101
- package/lib/browser/file-dialog/file-dialog-tree-filters-renderer.d.ts +39 -39
- package/lib/browser/file-dialog/file-dialog-tree-filters-renderer.js +81 -81
- package/lib/browser/file-dialog/file-dialog-tree.d.ts +26 -26
- package/lib/browser/file-dialog/file-dialog-tree.js +83 -83
- package/lib/browser/file-dialog/file-dialog-widget.d.ts +15 -15
- package/lib/browser/file-dialog/file-dialog-widget.js +75 -75
- package/lib/browser/file-dialog/file-dialog.d.ts +129 -129
- package/lib/browser/file-dialog/file-dialog.js +351 -351
- package/lib/browser/file-dialog/index.d.ts +4 -4
- package/lib/browser/file-dialog/index.js +22 -22
- package/lib/browser/file-resource.d.ts +67 -67
- package/lib/browser/file-resource.js +369 -369
- package/lib/browser/file-selection.d.ts +14 -14
- package/lib/browser/file-selection.js +36 -36
- package/lib/browser/file-service.d.ts +425 -425
- package/lib/browser/file-service.js +1366 -1366
- package/lib/browser/file-tree/file-tree-container.d.ts +3 -3
- package/lib/browser/file-tree/file-tree-container.js +35 -35
- package/lib/browser/file-tree/file-tree-decorator-adapter.d.ts +30 -30
- package/lib/browser/file-tree/file-tree-decorator-adapter.js +169 -169
- package/lib/browser/file-tree/file-tree-label-provider.d.ts +12 -12
- package/lib/browser/file-tree/file-tree-label-provider.js +54 -54
- package/lib/browser/file-tree/file-tree-model.d.ts +37 -37
- package/lib/browser/file-tree/file-tree-model.js +217 -217
- package/lib/browser/file-tree/file-tree-widget.d.ts +44 -44
- package/lib/browser/file-tree/file-tree-widget.js +317 -317
- package/lib/browser/file-tree/file-tree.d.ts +46 -46
- package/lib/browser/file-tree/file-tree.js +176 -176
- package/lib/browser/file-tree/index.d.ts +6 -6
- package/lib/browser/file-tree/index.js +24 -24
- package/lib/browser/file-upload-service.d.ts +109 -109
- package/lib/browser/file-upload-service.js +434 -434
- package/lib/browser/filesystem-frontend-contribution.d.ts +74 -74
- package/lib/browser/filesystem-frontend-contribution.js +356 -356
- package/lib/browser/filesystem-frontend-module.d.ts +5 -5
- package/lib/browser/filesystem-frontend-module.js +64 -64
- package/lib/browser/filesystem-preferences.d.ts +29 -29
- package/lib/browser/filesystem-preferences.js +110 -110
- package/lib/browser/filesystem-save-resource-service.d.ts +29 -29
- package/lib/browser/filesystem-save-resource-service.js +135 -135
- package/lib/browser/filesystem-watcher-error-handler.d.ts +10 -10
- package/lib/browser/filesystem-watcher-error-handler.js +61 -61
- package/lib/browser/index.d.ts +5 -5
- package/lib/browser/index.js +23 -23
- package/lib/browser/location/index.d.ts +2 -2
- package/lib/browser/location/index.js +20 -20
- package/lib/browser/location/location-renderer.d.ts +100 -100
- package/lib/browser/location/location-renderer.js +343 -343
- package/lib/browser/location/location-service.d.ts +5 -5
- package/lib/browser/location/location-service.js +17 -17
- package/lib/browser/remote-file-service-contribution.d.ts +6 -6
- package/lib/browser/remote-file-service-contribution.js +39 -39
- package/lib/browser-only/browser-only-filesystem-frontend-module.d.ts +3 -3
- package/lib/browser-only/browser-only-filesystem-frontend-module.js +40 -40
- package/lib/browser-only/browser-only-filesystem-provider-server.d.ts +11 -11
- package/lib/browser-only/browser-only-filesystem-provider-server.js +39 -39
- package/lib/browser-only/browserfs-filesystem-initialization.d.ts +12 -12
- package/lib/browser-only/browserfs-filesystem-initialization.js +54 -54
- package/lib/browser-only/browserfs-filesystem-provider.d.ts +45 -45
- package/lib/browser-only/browserfs-filesystem-provider.js +439 -439
- package/lib/common/delegating-file-system-provider.d.ts +76 -76
- package/lib/common/delegating-file-system-provider.js +168 -168
- package/lib/common/download/file-download-data.d.ts +6 -6
- package/lib/common/download/file-download-data.js +26 -26
- package/lib/common/file-upload.d.ts +1 -1
- package/lib/common/file-upload.js +19 -19
- package/lib/common/files.d.ts +659 -659
- package/lib/common/files.js +355 -355
- package/lib/common/files.spec.d.ts +1 -1
- package/lib/common/files.spec.js +51 -51
- package/lib/common/filesystem-utils.d.ts +14 -14
- package/lib/common/filesystem-utils.js +63 -63
- package/lib/common/filesystem-utils.spec.d.ts +1 -1
- package/lib/common/filesystem-utils.spec.js +378 -378
- package/lib/common/filesystem-watcher-protocol.d.ts +71 -71
- package/lib/common/filesystem-watcher-protocol.js +20 -20
- package/lib/common/filesystem.d.ts +22 -22
- package/lib/common/filesystem.js +42 -42
- package/lib/common/index.d.ts +2 -2
- package/lib/common/index.js +20 -20
- package/lib/common/io.d.ts +19 -19
- package/lib/common/io.js +110 -110
- package/lib/common/remote-file-system-provider.d.ts +173 -173
- package/lib/common/remote-file-system-provider.js +435 -435
- package/lib/electron-browser/file-dialog/electron-file-dialog-module.d.ts +3 -3
- package/lib/electron-browser/file-dialog/electron-file-dialog-module.js +24 -24
- package/lib/electron-browser/file-dialog/electron-file-dialog-service.d.ts +19 -19
- package/lib/electron-browser/file-dialog/electron-file-dialog-service.js +148 -148
- package/lib/electron-browser/preload.d.ts +1 -1
- package/lib/electron-browser/preload.js +30 -30
- package/lib/electron-common/electron-api.d.ts +34 -34
- package/lib/electron-common/electron-api.js +20 -20
- package/lib/electron-main/electron-api-main.d.ts +5 -5
- package/lib/electron-main/electron-api-main.js +73 -73
- package/lib/electron-main/electron-main-module.d.ts +3 -3
- package/lib/electron-main/electron-main-module.js +24 -24
- package/lib/node/disk-file-system-provider.d.ts +72 -72
- package/lib/node/disk-file-system-provider.js +787 -787
- package/lib/node/disk-file-system-provider.spec.d.ts +1 -1
- package/lib/node/disk-file-system-provider.spec.js +122 -122
- package/lib/node/download/directory-archiver.d.ts +9 -9
- package/lib/node/download/directory-archiver.js +127 -127
- package/lib/node/download/directory-archiver.spec.d.ts +1 -1
- package/lib/node/download/directory-archiver.spec.js +97 -97
- package/lib/node/download/file-download-backend-module.d.ts +3 -3
- package/lib/node/download/file-download-backend-module.js +32 -32
- package/lib/node/download/file-download-cache.d.ts +21 -21
- package/lib/node/download/file-download-cache.js +82 -82
- package/lib/node/download/file-download-endpoint.d.ts +11 -11
- package/lib/node/download/file-download-endpoint.js +67 -67
- package/lib/node/download/file-download-handler.d.ts +50 -50
- package/lib/node/download/file-download-handler.js +307 -307
- package/lib/node/download/test/mock-directory-archiver.d.ts +7 -7
- package/lib/node/download/test/mock-directory-archiver.js +29 -29
- package/lib/node/file-change-collection.d.ts +22 -22
- package/lib/node/file-change-collection.js +77 -77
- package/lib/node/file-change-collection.spec.d.ts +1 -1
- package/lib/node/file-change-collection.spec.js +90 -90
- package/lib/node/filesystem-backend-module.d.ts +26 -26
- package/lib/node/filesystem-backend-module.js +120 -120
- package/lib/node/filesystem-watcher-client.d.ts +23 -23
- package/lib/node/filesystem-watcher-client.js +75 -75
- package/lib/node/filesystem-watcher-dispatcher.d.ts +23 -23
- package/lib/node/filesystem-watcher-dispatcher.js +80 -80
- package/lib/node/node-file-upload-service.d.ts +16 -16
- package/lib/node/node-file-upload-service.js +79 -79
- package/lib/node/nsfw-watcher/index.d.ts +3 -3
- package/lib/node/nsfw-watcher/index.js +39 -39
- package/lib/node/nsfw-watcher/nsfw-filesystem-service.d.ts +191 -191
- package/lib/node/nsfw-watcher/nsfw-filesystem-service.js +405 -405
- package/lib/node/nsfw-watcher/nsfw-filesystem-watcher.spec.d.ts +1 -1
- package/lib/node/nsfw-watcher/nsfw-filesystem-watcher.spec.js +151 -151
- package/lib/node/nsfw-watcher/nsfw-options.d.ts +6 -6
- package/lib/node/nsfw-watcher/nsfw-options.js +22 -22
- package/package.json +4 -4
- package/src/browser/breadcrumbs/filepath-breadcrumb.ts +43 -43
- package/src/browser/breadcrumbs/filepath-breadcrumbs-container.ts +65 -65
- package/src/browser/breadcrumbs/filepath-breadcrumbs-contribution.ts +129 -129
- package/src/browser/download/file-download-command-contribution.ts +83 -83
- package/src/browser/download/file-download-frontend-module.ts +25 -25
- package/src/browser/download/file-download-service.ts +179 -179
- package/src/browser/file-dialog/file-dialog-container.ts +67 -67
- package/src/browser/file-dialog/file-dialog-hidden-files-renderer.tsx +59 -59
- package/src/browser/file-dialog/file-dialog-model.ts +96 -96
- package/src/browser/file-dialog/file-dialog-module.ts +44 -44
- package/src/browser/file-dialog/file-dialog-service.ts +99 -99
- package/src/browser/file-dialog/file-dialog-tree-filters-renderer.tsx +100 -100
- package/src/browser/file-dialog/file-dialog-tree.ts +89 -89
- package/src/browser/file-dialog/file-dialog-widget.ts +75 -75
- package/src/browser/file-dialog/file-dialog.ts +434 -434
- package/src/browser/file-dialog/index.ts +20 -20
- package/src/browser/file-resource.ts +390 -390
- package/src/browser/file-selection.ts +44 -44
- package/src/browser/file-service.ts +1841 -1841
- package/src/browser/file-tree/file-tree-container.ts +36 -36
- package/src/browser/file-tree/file-tree-decorator-adapter.ts +159 -159
- package/src/browser/file-tree/file-tree-label-provider.ts +53 -53
- package/src/browser/file-tree/file-tree-model.ts +212 -212
- package/src/browser/file-tree/file-tree-widget.tsx +327 -327
- package/src/browser/file-tree/file-tree.ts +183 -183
- package/src/browser/file-tree/index.ts +22 -22
- package/src/browser/file-upload-service.ts +539 -539
- package/src/browser/filesystem-frontend-contribution.ts +381 -381
- package/src/browser/filesystem-frontend-module.ts +77 -77
- package/src/browser/filesystem-preferences.ts +139 -139
- package/src/browser/filesystem-save-resource-service.ts +125 -125
- package/src/browser/filesystem-watcher-error-handler.ts +60 -60
- package/src/browser/index.ts +21 -21
- package/src/browser/location/index.ts +18 -18
- package/src/browser/location/location-renderer.tsx +404 -404
- package/src/browser/location/location-service.ts +22 -22
- package/src/browser/remote-file-service-contribution.ts +38 -38
- package/src/browser/style/file-dialog.css +208 -208
- package/src/browser/style/file-icons.css +64 -64
- package/src/browser/style/filepath-breadcrumbs.css +20 -20
- package/src/browser/style/index.css +36 -36
- package/src/browser-only/browser-only-filesystem-frontend-module.ts +38 -38
- package/src/browser-only/browser-only-filesystem-provider-server.ts +32 -32
- package/src/browser-only/browserfs-filesystem-initialization.ts +61 -61
- package/src/browser-only/browserfs-filesystem-provider.ts +462 -462
- package/src/common/delegating-file-system-provider.ts +226 -226
- package/src/common/download/README.md +30 -30
- package/src/common/download/file-download-data.ts +27 -27
- package/src/common/file-upload.ts +17 -17
- package/src/common/files.spec.ts +51 -51
- package/src/common/files.ts +996 -996
- package/src/common/filesystem-utils.spec.ts +411 -411
- package/src/common/filesystem-utils.ts +64 -64
- package/src/common/filesystem-watcher-protocol.ts +96 -96
- package/src/common/filesystem.ts +43 -43
- package/src/common/index.ts +18 -18
- package/src/common/io.ts +150 -150
- package/src/common/remote-file-system-provider.ts +549 -549
- package/src/electron-browser/file-dialog/electron-file-dialog-module.ts +24 -24
- package/src/electron-browser/file-dialog/electron-file-dialog-service.ts +165 -165
- package/src/electron-browser/preload.ts +31 -31
- package/src/electron-common/electron-api.ts +55 -55
- package/src/electron-main/electron-api-main.ts +78 -78
- package/src/electron-main/electron-main-module.ts +23 -23
- package/src/node/disk-file-system-provider.spec.ts +142 -142
- package/src/node/disk-file-system-provider.ts +915 -915
- package/src/node/download/directory-archiver.spec.ts +104 -104
- package/src/node/download/directory-archiver.ts +126 -126
- package/src/node/download/file-download-backend-module.ts +32 -32
- package/src/node/download/file-download-cache.ts +88 -88
- package/src/node/download/file-download-endpoint.ts +63 -63
- package/src/node/download/file-download-handler.ts +304 -304
- package/src/node/download/test/mock-directory-archiver.ts +30 -30
- package/src/node/file-change-collection.spec.ts +110 -110
- package/src/node/file-change-collection.ts +78 -78
- package/src/node/filesystem-backend-module.ts +140 -140
- package/src/node/filesystem-watcher-client.ts +72 -72
- package/src/node/filesystem-watcher-dispatcher.ts +82 -82
- package/src/node/node-file-upload-service.ts +80 -80
- package/src/node/nsfw-watcher/index.ts +45 -45
- package/src/node/nsfw-watcher/nsfw-filesystem-service.ts +481 -481
- package/src/node/nsfw-watcher/nsfw-filesystem-watcher.spec.ts +182 -182
- package/src/node/nsfw-watcher/nsfw-options.ts +23 -23
- package/src/typings/dom.webkit.d.ts +77 -77
- package/src/typings/mv/index.d.ts +21 -21
- package/src/typings/nsfw/index.d.ts +18 -18
- package/src/typings/trash/index.d.ts +20 -20
|
@@ -1,98 +1,98 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// *****************************************************************************
|
|
3
|
-
// Copyright (C) 2018 TypeFox and others.
|
|
4
|
-
//
|
|
5
|
-
// This program and the accompanying materials are made available under the
|
|
6
|
-
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
7
|
-
// http://www.eclipse.org/legal/epl-2.0.
|
|
8
|
-
//
|
|
9
|
-
// This Source Code may also be made available under the following Secondary
|
|
10
|
-
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
11
|
-
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
12
|
-
// with the GNU Classpath Exception which is available at
|
|
13
|
-
// https://www.gnu.org/software/classpath/license.html.
|
|
14
|
-
//
|
|
15
|
-
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
16
|
-
// *****************************************************************************
|
|
17
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
-
const fs = require("@theia/core/shared/fs-extra");
|
|
19
|
-
const path = require("path");
|
|
20
|
-
const temp = require("temp");
|
|
21
|
-
const tar_fs_1 = require("tar-fs");
|
|
22
|
-
const chai_1 = require("chai");
|
|
23
|
-
const uri_1 = require("@theia/core/lib/common/uri");
|
|
24
|
-
const mock_directory_archiver_1 = require("./test/mock-directory-archiver");
|
|
25
|
-
const file_uri_1 = require("@theia/core/lib/common/file-uri");
|
|
26
|
-
const track = temp.track();
|
|
27
|
-
describe('directory-archiver', () => {
|
|
28
|
-
after(() => {
|
|
29
|
-
track.cleanupSync();
|
|
30
|
-
});
|
|
31
|
-
it('should archive a directory', async function () {
|
|
32
|
-
this.timeout(20000);
|
|
33
|
-
const fromPath = track.mkdirSync('from');
|
|
34
|
-
fs.writeFileSync(path.join(fromPath, 'A.txt'), 'A');
|
|
35
|
-
fs.writeFileSync(path.join(fromPath, 'B.txt'), 'B');
|
|
36
|
-
(0, chai_1.expect)(fs.readFileSync(path.join(fromPath, 'A.txt'), { encoding: 'utf8' })).to.be.equal('A');
|
|
37
|
-
(0, chai_1.expect)(fs.readFileSync(path.join(fromPath, 'B.txt'), { encoding: 'utf8' })).to.be.equal('B');
|
|
38
|
-
const toPath = track.mkdirSync('to');
|
|
39
|
-
const archiver = new mock_directory_archiver_1.MockDirectoryArchiver();
|
|
40
|
-
await archiver.archive(fromPath, path.join(toPath, 'output.tar'));
|
|
41
|
-
(0, chai_1.expect)(fs.existsSync(path.join(toPath, 'output.tar'))).to.be.true;
|
|
42
|
-
const assertPath = track.mkdirSync('assertPath');
|
|
43
|
-
return new Promise(resolve => {
|
|
44
|
-
fs.createReadStream(path.join(toPath, 'output.tar')).pipe((0, tar_fs_1.extract)(assertPath)).on('finish', () => {
|
|
45
|
-
(0, chai_1.expect)(fs.readdirSync(assertPath).sort()).to.be.deep.equal(['A.txt', 'B.txt']);
|
|
46
|
-
(0, chai_1.expect)(fs.readFileSync(path.join(assertPath, 'A.txt'), { encoding: 'utf8' })).to.be.equal(fs.readFileSync(path.join(fromPath, 'A.txt'), { encoding: 'utf8' }));
|
|
47
|
-
(0, chai_1.expect)(fs.readFileSync(path.join(assertPath, 'B.txt'), { encoding: 'utf8' })).to.be.equal(fs.readFileSync(path.join(fromPath, 'B.txt'), { encoding: 'utf8' }));
|
|
48
|
-
resolve();
|
|
49
|
-
});
|
|
50
|
-
});
|
|
51
|
-
});
|
|
52
|
-
describe('findCommonParents', () => {
|
|
53
|
-
[
|
|
54
|
-
{
|
|
55
|
-
input: ['/A/B/C/D.txt', '/X/Y/Z.txt'],
|
|
56
|
-
expected: new Map([['/A/B/C', ['/A/B/C/D.txt']], ['/X/Y', ['/X/Y/Z.txt']]]),
|
|
57
|
-
folders: ['/A', '/A/B', '/A/B/C', '/X', '/X/Y']
|
|
58
|
-
},
|
|
59
|
-
{
|
|
60
|
-
input: ['/A/B/C/D.txt', '/A/B/C/E.txt'],
|
|
61
|
-
expected: new Map([['/A/B/C', ['/A/B/C/D.txt', '/A/B/C/E.txt']]]),
|
|
62
|
-
folders: ['/A', '/A/B', '/A/B/C']
|
|
63
|
-
},
|
|
64
|
-
{
|
|
65
|
-
input: ['/A', '/A/B/C/D.txt', '/A/B/C/E.txt'],
|
|
66
|
-
expected: new Map([['/A', ['/A', '/A/B/C/D.txt', '/A/B/C/E.txt']]]),
|
|
67
|
-
folders: ['/A', '/A/B', '/A/B/C']
|
|
68
|
-
},
|
|
69
|
-
{
|
|
70
|
-
input: ['/A/B/C/D.txt', '/A/B/C/E.txt', '/A'],
|
|
71
|
-
expected: new Map([['/A', ['/A', '/A/B/C/D.txt', '/A/B/C/E.txt']]]),
|
|
72
|
-
folders: ['/A', '/A/B', '/A/B/C']
|
|
73
|
-
},
|
|
74
|
-
{
|
|
75
|
-
input: ['/A/B/C/D.txt', '/A/B/X/E.txt'],
|
|
76
|
-
expected: new Map([['/A/B', ['/A/B/C/D.txt', '/A/B/X/E.txt']]]),
|
|
77
|
-
folders: ['/A', '/A/B', '/A/B/C', '/A/B/X']
|
|
78
|
-
}
|
|
79
|
-
].forEach(test => {
|
|
80
|
-
const { input, expected, folders } = test;
|
|
81
|
-
it(`should find the common parent URIs among [${input.join(', ')}] => [${Array.from(expected.keys()).join(', ')}]`, async () => {
|
|
82
|
-
const archiver = new mock_directory_archiver_1.MockDirectoryArchiver(folders ? folders.map(file_uri_1.FileUri.create) : []);
|
|
83
|
-
const actual = await archiver.findCommonParents(input.map(file_uri_1.FileUri.create));
|
|
84
|
-
(0, chai_1.expect)(asString(actual)).to.be.equal(asString(expected));
|
|
85
|
-
});
|
|
86
|
-
});
|
|
87
|
-
function asString(map) {
|
|
88
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
89
|
-
const obj = {};
|
|
90
|
-
for (const key of Array.from(map.keys()).sort()) {
|
|
91
|
-
const values = (map.get(key) || []).sort();
|
|
92
|
-
obj[new uri_1.default(key).withScheme('file').toString()] = `[${values.map(v => new uri_1.default(v).withScheme('file').toString()).join(', ')}]`;
|
|
93
|
-
}
|
|
94
|
-
return JSON.stringify(obj);
|
|
95
|
-
}
|
|
96
|
-
});
|
|
97
|
-
});
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2018 TypeFox and others.
|
|
4
|
+
//
|
|
5
|
+
// This program and the accompanying materials are made available under the
|
|
6
|
+
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
7
|
+
// http://www.eclipse.org/legal/epl-2.0.
|
|
8
|
+
//
|
|
9
|
+
// This Source Code may also be made available under the following Secondary
|
|
10
|
+
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
11
|
+
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
12
|
+
// with the GNU Classpath Exception which is available at
|
|
13
|
+
// https://www.gnu.org/software/classpath/license.html.
|
|
14
|
+
//
|
|
15
|
+
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
16
|
+
// *****************************************************************************
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const fs = require("@theia/core/shared/fs-extra");
|
|
19
|
+
const path = require("path");
|
|
20
|
+
const temp = require("temp");
|
|
21
|
+
const tar_fs_1 = require("tar-fs");
|
|
22
|
+
const chai_1 = require("chai");
|
|
23
|
+
const uri_1 = require("@theia/core/lib/common/uri");
|
|
24
|
+
const mock_directory_archiver_1 = require("./test/mock-directory-archiver");
|
|
25
|
+
const file_uri_1 = require("@theia/core/lib/common/file-uri");
|
|
26
|
+
const track = temp.track();
|
|
27
|
+
describe('directory-archiver', () => {
|
|
28
|
+
after(() => {
|
|
29
|
+
track.cleanupSync();
|
|
30
|
+
});
|
|
31
|
+
it('should archive a directory', async function () {
|
|
32
|
+
this.timeout(20000);
|
|
33
|
+
const fromPath = track.mkdirSync('from');
|
|
34
|
+
fs.writeFileSync(path.join(fromPath, 'A.txt'), 'A');
|
|
35
|
+
fs.writeFileSync(path.join(fromPath, 'B.txt'), 'B');
|
|
36
|
+
(0, chai_1.expect)(fs.readFileSync(path.join(fromPath, 'A.txt'), { encoding: 'utf8' })).to.be.equal('A');
|
|
37
|
+
(0, chai_1.expect)(fs.readFileSync(path.join(fromPath, 'B.txt'), { encoding: 'utf8' })).to.be.equal('B');
|
|
38
|
+
const toPath = track.mkdirSync('to');
|
|
39
|
+
const archiver = new mock_directory_archiver_1.MockDirectoryArchiver();
|
|
40
|
+
await archiver.archive(fromPath, path.join(toPath, 'output.tar'));
|
|
41
|
+
(0, chai_1.expect)(fs.existsSync(path.join(toPath, 'output.tar'))).to.be.true;
|
|
42
|
+
const assertPath = track.mkdirSync('assertPath');
|
|
43
|
+
return new Promise(resolve => {
|
|
44
|
+
fs.createReadStream(path.join(toPath, 'output.tar')).pipe((0, tar_fs_1.extract)(assertPath)).on('finish', () => {
|
|
45
|
+
(0, chai_1.expect)(fs.readdirSync(assertPath).sort()).to.be.deep.equal(['A.txt', 'B.txt']);
|
|
46
|
+
(0, chai_1.expect)(fs.readFileSync(path.join(assertPath, 'A.txt'), { encoding: 'utf8' })).to.be.equal(fs.readFileSync(path.join(fromPath, 'A.txt'), { encoding: 'utf8' }));
|
|
47
|
+
(0, chai_1.expect)(fs.readFileSync(path.join(assertPath, 'B.txt'), { encoding: 'utf8' })).to.be.equal(fs.readFileSync(path.join(fromPath, 'B.txt'), { encoding: 'utf8' }));
|
|
48
|
+
resolve();
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
describe('findCommonParents', () => {
|
|
53
|
+
[
|
|
54
|
+
{
|
|
55
|
+
input: ['/A/B/C/D.txt', '/X/Y/Z.txt'],
|
|
56
|
+
expected: new Map([['/A/B/C', ['/A/B/C/D.txt']], ['/X/Y', ['/X/Y/Z.txt']]]),
|
|
57
|
+
folders: ['/A', '/A/B', '/A/B/C', '/X', '/X/Y']
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
input: ['/A/B/C/D.txt', '/A/B/C/E.txt'],
|
|
61
|
+
expected: new Map([['/A/B/C', ['/A/B/C/D.txt', '/A/B/C/E.txt']]]),
|
|
62
|
+
folders: ['/A', '/A/B', '/A/B/C']
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
input: ['/A', '/A/B/C/D.txt', '/A/B/C/E.txt'],
|
|
66
|
+
expected: new Map([['/A', ['/A', '/A/B/C/D.txt', '/A/B/C/E.txt']]]),
|
|
67
|
+
folders: ['/A', '/A/B', '/A/B/C']
|
|
68
|
+
},
|
|
69
|
+
{
|
|
70
|
+
input: ['/A/B/C/D.txt', '/A/B/C/E.txt', '/A'],
|
|
71
|
+
expected: new Map([['/A', ['/A', '/A/B/C/D.txt', '/A/B/C/E.txt']]]),
|
|
72
|
+
folders: ['/A', '/A/B', '/A/B/C']
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
input: ['/A/B/C/D.txt', '/A/B/X/E.txt'],
|
|
76
|
+
expected: new Map([['/A/B', ['/A/B/C/D.txt', '/A/B/X/E.txt']]]),
|
|
77
|
+
folders: ['/A', '/A/B', '/A/B/C', '/A/B/X']
|
|
78
|
+
}
|
|
79
|
+
].forEach(test => {
|
|
80
|
+
const { input, expected, folders } = test;
|
|
81
|
+
it(`should find the common parent URIs among [${input.join(', ')}] => [${Array.from(expected.keys()).join(', ')}]`, async () => {
|
|
82
|
+
const archiver = new mock_directory_archiver_1.MockDirectoryArchiver(folders ? folders.map(file_uri_1.FileUri.create) : []);
|
|
83
|
+
const actual = await archiver.findCommonParents(input.map(file_uri_1.FileUri.create));
|
|
84
|
+
(0, chai_1.expect)(asString(actual)).to.be.equal(asString(expected));
|
|
85
|
+
});
|
|
86
|
+
});
|
|
87
|
+
function asString(map) {
|
|
88
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
89
|
+
const obj = {};
|
|
90
|
+
for (const key of Array.from(map.keys()).sort()) {
|
|
91
|
+
const values = (map.get(key) || []).sort();
|
|
92
|
+
obj[new uri_1.default(key).withScheme('file').toString()] = `[${values.map(v => new uri_1.default(v).withScheme('file').toString()).join(', ')}]`;
|
|
93
|
+
}
|
|
94
|
+
return JSON.stringify(obj);
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
98
|
//# sourceMappingURL=directory-archiver.spec.js.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ContainerModule } from '@theia/core/shared/inversify';
|
|
2
|
-
declare const _default: ContainerModule;
|
|
3
|
-
export default _default;
|
|
1
|
+
import { ContainerModule } from '@theia/core/shared/inversify';
|
|
2
|
+
declare const _default: ContainerModule;
|
|
3
|
+
export default _default;
|
|
4
4
|
//# sourceMappingURL=file-download-backend-module.d.ts.map
|
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// *****************************************************************************
|
|
3
|
-
// Copyright (C) 2018 TypeFox and others.
|
|
4
|
-
//
|
|
5
|
-
// This program and the accompanying materials are made available under the
|
|
6
|
-
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
7
|
-
// http://www.eclipse.org/legal/epl-2.0.
|
|
8
|
-
//
|
|
9
|
-
// This Source Code may also be made available under the following Secondary
|
|
10
|
-
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
11
|
-
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
12
|
-
// with the GNU Classpath Exception which is available at
|
|
13
|
-
// https://www.gnu.org/software/classpath/license.html.
|
|
14
|
-
//
|
|
15
|
-
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
16
|
-
// *****************************************************************************
|
|
17
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
-
const inversify_1 = require("@theia/core/shared/inversify");
|
|
19
|
-
const backend_application_1 = require("@theia/core/lib/node/backend-application");
|
|
20
|
-
const file_download_endpoint_1 = require("./file-download-endpoint");
|
|
21
|
-
const file_download_handler_1 = require("./file-download-handler");
|
|
22
|
-
const directory_archiver_1 = require("./directory-archiver");
|
|
23
|
-
const file_download_cache_1 = require("./file-download-cache");
|
|
24
|
-
exports.default = new inversify_1.ContainerModule(bind => {
|
|
25
|
-
bind(file_download_endpoint_1.FileDownloadEndpoint).toSelf().inSingletonScope();
|
|
26
|
-
bind(backend_application_1.BackendApplicationContribution).toService(file_download_endpoint_1.FileDownloadEndpoint);
|
|
27
|
-
bind(file_download_cache_1.FileDownloadCache).toSelf().inSingletonScope();
|
|
28
|
-
bind(file_download_handler_1.FileDownloadHandler).to(file_download_handler_1.SingleFileDownloadHandler).inSingletonScope().whenTargetNamed(file_download_handler_1.FileDownloadHandler.SINGLE);
|
|
29
|
-
bind(file_download_handler_1.FileDownloadHandler).to(file_download_handler_1.MultiFileDownloadHandler).inSingletonScope().whenTargetNamed(file_download_handler_1.FileDownloadHandler.MULTI);
|
|
30
|
-
bind(file_download_handler_1.FileDownloadHandler).to(file_download_handler_1.DownloadLinkHandler).inSingletonScope().whenTargetNamed(file_download_handler_1.FileDownloadHandler.DOWNLOAD_LINK);
|
|
31
|
-
bind(directory_archiver_1.DirectoryArchiver).toSelf().inSingletonScope();
|
|
32
|
-
});
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2018 TypeFox and others.
|
|
4
|
+
//
|
|
5
|
+
// This program and the accompanying materials are made available under the
|
|
6
|
+
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
7
|
+
// http://www.eclipse.org/legal/epl-2.0.
|
|
8
|
+
//
|
|
9
|
+
// This Source Code may also be made available under the following Secondary
|
|
10
|
+
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
11
|
+
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
12
|
+
// with the GNU Classpath Exception which is available at
|
|
13
|
+
// https://www.gnu.org/software/classpath/license.html.
|
|
14
|
+
//
|
|
15
|
+
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
16
|
+
// *****************************************************************************
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const inversify_1 = require("@theia/core/shared/inversify");
|
|
19
|
+
const backend_application_1 = require("@theia/core/lib/node/backend-application");
|
|
20
|
+
const file_download_endpoint_1 = require("./file-download-endpoint");
|
|
21
|
+
const file_download_handler_1 = require("./file-download-handler");
|
|
22
|
+
const directory_archiver_1 = require("./directory-archiver");
|
|
23
|
+
const file_download_cache_1 = require("./file-download-cache");
|
|
24
|
+
exports.default = new inversify_1.ContainerModule(bind => {
|
|
25
|
+
bind(file_download_endpoint_1.FileDownloadEndpoint).toSelf().inSingletonScope();
|
|
26
|
+
bind(backend_application_1.BackendApplicationContribution).toService(file_download_endpoint_1.FileDownloadEndpoint);
|
|
27
|
+
bind(file_download_cache_1.FileDownloadCache).toSelf().inSingletonScope();
|
|
28
|
+
bind(file_download_handler_1.FileDownloadHandler).to(file_download_handler_1.SingleFileDownloadHandler).inSingletonScope().whenTargetNamed(file_download_handler_1.FileDownloadHandler.SINGLE);
|
|
29
|
+
bind(file_download_handler_1.FileDownloadHandler).to(file_download_handler_1.MultiFileDownloadHandler).inSingletonScope().whenTargetNamed(file_download_handler_1.FileDownloadHandler.MULTI);
|
|
30
|
+
bind(file_download_handler_1.FileDownloadHandler).to(file_download_handler_1.DownloadLinkHandler).inSingletonScope().whenTargetNamed(file_download_handler_1.FileDownloadHandler.DOWNLOAD_LINK);
|
|
31
|
+
bind(directory_archiver_1.DirectoryArchiver).toSelf().inSingletonScope();
|
|
32
|
+
});
|
|
33
33
|
//# sourceMappingURL=file-download-backend-module.js.map
|
|
@@ -1,22 +1,22 @@
|
|
|
1
|
-
import { ILogger } from '@theia/core/lib/common/logger';
|
|
2
|
-
export interface DownloadStorageItem {
|
|
3
|
-
file: string;
|
|
4
|
-
root?: string;
|
|
5
|
-
size: number;
|
|
6
|
-
remove: boolean;
|
|
7
|
-
expire?: number;
|
|
8
|
-
}
|
|
9
|
-
export declare class FileDownloadCache {
|
|
10
|
-
protected readonly logger: ILogger;
|
|
11
|
-
protected readonly downloads: Map<string, DownloadStorageItem>;
|
|
12
|
-
protected readonly expireTimeInMinutes: number;
|
|
13
|
-
addDownload(id: string, downloadInfo: DownloadStorageItem): void;
|
|
14
|
-
getDownload(id: string): DownloadStorageItem | undefined;
|
|
15
|
-
deleteDownload(id: string): void;
|
|
16
|
-
values(): {
|
|
17
|
-
[key: string]: DownloadStorageItem;
|
|
18
|
-
};
|
|
19
|
-
protected deleteRecursively(pathToDelete: string): void;
|
|
20
|
-
protected expireDownloads(): void;
|
|
21
|
-
}
|
|
1
|
+
import { ILogger } from '@theia/core/lib/common/logger';
|
|
2
|
+
export interface DownloadStorageItem {
|
|
3
|
+
file: string;
|
|
4
|
+
root?: string;
|
|
5
|
+
size: number;
|
|
6
|
+
remove: boolean;
|
|
7
|
+
expire?: number;
|
|
8
|
+
}
|
|
9
|
+
export declare class FileDownloadCache {
|
|
10
|
+
protected readonly logger: ILogger;
|
|
11
|
+
protected readonly downloads: Map<string, DownloadStorageItem>;
|
|
12
|
+
protected readonly expireTimeInMinutes: number;
|
|
13
|
+
addDownload(id: string, downloadInfo: DownloadStorageItem): void;
|
|
14
|
+
getDownload(id: string): DownloadStorageItem | undefined;
|
|
15
|
+
deleteDownload(id: string): void;
|
|
16
|
+
values(): {
|
|
17
|
+
[key: string]: DownloadStorageItem;
|
|
18
|
+
};
|
|
19
|
+
protected deleteRecursively(pathToDelete: string): void;
|
|
20
|
+
protected expireDownloads(): void;
|
|
21
|
+
}
|
|
22
22
|
//# sourceMappingURL=file-download-cache.d.ts.map
|
|
@@ -1,83 +1,83 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.FileDownloadCache = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
|
-
// *****************************************************************************
|
|
6
|
-
// Copyright (C) 2019 Bitsler and others.
|
|
7
|
-
//
|
|
8
|
-
// This program and the accompanying materials are made available under the
|
|
9
|
-
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
10
|
-
// http://www.eclipse.org/legal/epl-2.0.
|
|
11
|
-
//
|
|
12
|
-
// This Source Code may also be made available under the following Secondary
|
|
13
|
-
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
14
|
-
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
15
|
-
// with the GNU Classpath Exception which is available at
|
|
16
|
-
// https://www.gnu.org/software/classpath/license.html.
|
|
17
|
-
//
|
|
18
|
-
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
19
|
-
// *****************************************************************************
|
|
20
|
-
const inversify_1 = require("@theia/core/shared/inversify");
|
|
21
|
-
const logger_1 = require("@theia/core/lib/common/logger");
|
|
22
|
-
const rimraf = require("rimraf");
|
|
23
|
-
let FileDownloadCache = class FileDownloadCache {
|
|
24
|
-
constructor() {
|
|
25
|
-
this.downloads = new Map();
|
|
26
|
-
this.expireTimeInMinutes = 1;
|
|
27
|
-
}
|
|
28
|
-
addDownload(id, downloadInfo) {
|
|
29
|
-
downloadInfo.file = encodeURIComponent(downloadInfo.file);
|
|
30
|
-
if (downloadInfo.root) {
|
|
31
|
-
downloadInfo.root = encodeURIComponent(downloadInfo.root);
|
|
32
|
-
}
|
|
33
|
-
// expires in 1 minute enough for parallel connections to be connected.
|
|
34
|
-
downloadInfo.expire = Date.now() + (this.expireTimeInMinutes * 600000);
|
|
35
|
-
this.downloads.set(id, downloadInfo);
|
|
36
|
-
}
|
|
37
|
-
getDownload(id) {
|
|
38
|
-
this.expireDownloads();
|
|
39
|
-
const downloadInfo = this.downloads.get(id);
|
|
40
|
-
if (downloadInfo) {
|
|
41
|
-
downloadInfo.file = decodeURIComponent(downloadInfo.file);
|
|
42
|
-
if (downloadInfo.root) {
|
|
43
|
-
downloadInfo.root = decodeURIComponent(downloadInfo.root);
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
return downloadInfo;
|
|
47
|
-
}
|
|
48
|
-
deleteDownload(id) {
|
|
49
|
-
const downloadInfo = this.downloads.get(id);
|
|
50
|
-
if (downloadInfo && downloadInfo.remove) {
|
|
51
|
-
this.deleteRecursively(downloadInfo.root || downloadInfo.file);
|
|
52
|
-
}
|
|
53
|
-
this.downloads.delete(id);
|
|
54
|
-
}
|
|
55
|
-
values() {
|
|
56
|
-
this.expireDownloads();
|
|
57
|
-
return [...this.downloads.entries()].reduce((downloads, [key, value]) => ({ ...downloads, [key]: value }), {});
|
|
58
|
-
}
|
|
59
|
-
deleteRecursively(pathToDelete) {
|
|
60
|
-
rimraf(pathToDelete, error => {
|
|
61
|
-
if (error) {
|
|
62
|
-
this.logger.warn(`An error occurred while deleting the temporary data from the disk. Cannot clean up: ${pathToDelete}.`, error);
|
|
63
|
-
}
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
expireDownloads() {
|
|
67
|
-
const time = Date.now();
|
|
68
|
-
for (const [id, download] of this.downloads.entries()) {
|
|
69
|
-
if (download.expire && download.expire <= time) {
|
|
70
|
-
this.deleteDownload(id);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
};
|
|
75
|
-
(0, tslib_1.__decorate)([
|
|
76
|
-
(0, inversify_1.inject)(logger_1.ILogger),
|
|
77
|
-
(0, tslib_1.__metadata)("design:type", Object)
|
|
78
|
-
], FileDownloadCache.prototype, "logger", void 0);
|
|
79
|
-
FileDownloadCache = (0, tslib_1.__decorate)([
|
|
80
|
-
(0, inversify_1.injectable)()
|
|
81
|
-
], FileDownloadCache);
|
|
82
|
-
exports.FileDownloadCache = FileDownloadCache;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FileDownloadCache = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
// *****************************************************************************
|
|
6
|
+
// Copyright (C) 2019 Bitsler and others.
|
|
7
|
+
//
|
|
8
|
+
// This program and the accompanying materials are made available under the
|
|
9
|
+
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
10
|
+
// http://www.eclipse.org/legal/epl-2.0.
|
|
11
|
+
//
|
|
12
|
+
// This Source Code may also be made available under the following Secondary
|
|
13
|
+
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
14
|
+
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
15
|
+
// with the GNU Classpath Exception which is available at
|
|
16
|
+
// https://www.gnu.org/software/classpath/license.html.
|
|
17
|
+
//
|
|
18
|
+
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
19
|
+
// *****************************************************************************
|
|
20
|
+
const inversify_1 = require("@theia/core/shared/inversify");
|
|
21
|
+
const logger_1 = require("@theia/core/lib/common/logger");
|
|
22
|
+
const rimraf = require("rimraf");
|
|
23
|
+
let FileDownloadCache = class FileDownloadCache {
|
|
24
|
+
constructor() {
|
|
25
|
+
this.downloads = new Map();
|
|
26
|
+
this.expireTimeInMinutes = 1;
|
|
27
|
+
}
|
|
28
|
+
addDownload(id, downloadInfo) {
|
|
29
|
+
downloadInfo.file = encodeURIComponent(downloadInfo.file);
|
|
30
|
+
if (downloadInfo.root) {
|
|
31
|
+
downloadInfo.root = encodeURIComponent(downloadInfo.root);
|
|
32
|
+
}
|
|
33
|
+
// expires in 1 minute enough for parallel connections to be connected.
|
|
34
|
+
downloadInfo.expire = Date.now() + (this.expireTimeInMinutes * 600000);
|
|
35
|
+
this.downloads.set(id, downloadInfo);
|
|
36
|
+
}
|
|
37
|
+
getDownload(id) {
|
|
38
|
+
this.expireDownloads();
|
|
39
|
+
const downloadInfo = this.downloads.get(id);
|
|
40
|
+
if (downloadInfo) {
|
|
41
|
+
downloadInfo.file = decodeURIComponent(downloadInfo.file);
|
|
42
|
+
if (downloadInfo.root) {
|
|
43
|
+
downloadInfo.root = decodeURIComponent(downloadInfo.root);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
return downloadInfo;
|
|
47
|
+
}
|
|
48
|
+
deleteDownload(id) {
|
|
49
|
+
const downloadInfo = this.downloads.get(id);
|
|
50
|
+
if (downloadInfo && downloadInfo.remove) {
|
|
51
|
+
this.deleteRecursively(downloadInfo.root || downloadInfo.file);
|
|
52
|
+
}
|
|
53
|
+
this.downloads.delete(id);
|
|
54
|
+
}
|
|
55
|
+
values() {
|
|
56
|
+
this.expireDownloads();
|
|
57
|
+
return [...this.downloads.entries()].reduce((downloads, [key, value]) => ({ ...downloads, [key]: value }), {});
|
|
58
|
+
}
|
|
59
|
+
deleteRecursively(pathToDelete) {
|
|
60
|
+
rimraf(pathToDelete, error => {
|
|
61
|
+
if (error) {
|
|
62
|
+
this.logger.warn(`An error occurred while deleting the temporary data from the disk. Cannot clean up: ${pathToDelete}.`, error);
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
expireDownloads() {
|
|
67
|
+
const time = Date.now();
|
|
68
|
+
for (const [id, download] of this.downloads.entries()) {
|
|
69
|
+
if (download.expire && download.expire <= time) {
|
|
70
|
+
this.deleteDownload(id);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
(0, tslib_1.__decorate)([
|
|
76
|
+
(0, inversify_1.inject)(logger_1.ILogger),
|
|
77
|
+
(0, tslib_1.__metadata)("design:type", Object)
|
|
78
|
+
], FileDownloadCache.prototype, "logger", void 0);
|
|
79
|
+
FileDownloadCache = (0, tslib_1.__decorate)([
|
|
80
|
+
(0, inversify_1.injectable)()
|
|
81
|
+
], FileDownloadCache);
|
|
82
|
+
exports.FileDownloadCache = FileDownloadCache;
|
|
83
83
|
//# sourceMappingURL=file-download-cache.js.map
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
/// <reference types="express" />
|
|
2
|
-
import { Application } from '@theia/core/shared/express';
|
|
3
|
-
import { BackendApplicationContribution } from '@theia/core/lib/node/backend-application';
|
|
4
|
-
import { FileDownloadHandler } from './file-download-handler';
|
|
5
|
-
export declare class FileDownloadEndpoint implements BackendApplicationContribution {
|
|
6
|
-
protected static PATH: string;
|
|
7
|
-
protected readonly singleFileDownloadHandler: FileDownloadHandler;
|
|
8
|
-
protected readonly multiFileDownloadHandler: FileDownloadHandler;
|
|
9
|
-
protected readonly downloadLinkHandler: FileDownloadHandler;
|
|
10
|
-
configure(app: Application): void;
|
|
11
|
-
}
|
|
1
|
+
/// <reference types="express" />
|
|
2
|
+
import { Application } from '@theia/core/shared/express';
|
|
3
|
+
import { BackendApplicationContribution } from '@theia/core/lib/node/backend-application';
|
|
4
|
+
import { FileDownloadHandler } from './file-download-handler';
|
|
5
|
+
export declare class FileDownloadEndpoint implements BackendApplicationContribution {
|
|
6
|
+
protected static PATH: string;
|
|
7
|
+
protected readonly singleFileDownloadHandler: FileDownloadHandler;
|
|
8
|
+
protected readonly multiFileDownloadHandler: FileDownloadHandler;
|
|
9
|
+
protected readonly downloadLinkHandler: FileDownloadHandler;
|
|
10
|
+
configure(app: Application): void;
|
|
11
|
+
}
|
|
12
12
|
//# sourceMappingURL=file-download-endpoint.d.ts.map
|