@theia/dev-container 1.46.0-next.241
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 +44 -0
- package/lib/dev-container-server/dev-container-server.d.ts +2 -0
- package/lib/dev-container-server/dev-container-server.d.ts.map +1 -0
- package/lib/dev-container-server/dev-container-server.js +48 -0
- package/lib/dev-container-server/dev-container-server.js.map +1 -0
- package/lib/electron-browser/container-connection-contribution.d.ts +28 -0
- package/lib/electron-browser/container-connection-contribution.d.ts.map +1 -0
- package/lib/electron-browser/container-connection-contribution.js +147 -0
- package/lib/electron-browser/container-connection-contribution.js.map +1 -0
- package/lib/electron-browser/container-info-contribution.d.ts +11 -0
- package/lib/electron-browser/container-info-contribution.d.ts.map +1 -0
- package/lib/electron-browser/container-info-contribution.js +51 -0
- package/lib/electron-browser/container-info-contribution.js.map +1 -0
- package/lib/electron-browser/container-output-provider.d.ts +8 -0
- package/lib/electron-browser/container-output-provider.d.ts.map +1 -0
- package/lib/electron-browser/container-output-provider.js +41 -0
- package/lib/electron-browser/container-output-provider.js.map +1 -0
- package/lib/electron-browser/dev-container-frontend-module.d.ts +4 -0
- package/lib/electron-browser/dev-container-frontend-module.d.ts.map +1 -0
- package/lib/electron-browser/dev-container-frontend-module.js +39 -0
- package/lib/electron-browser/dev-container-frontend-module.js.map +1 -0
- package/lib/electron-common/container-output-provider.d.ts +4 -0
- package/lib/electron-common/container-output-provider.d.ts.map +1 -0
- package/lib/electron-common/container-output-provider.js +18 -0
- package/lib/electron-common/container-output-provider.js.map +1 -0
- package/lib/electron-common/dev-container-workspaces.d.ts +3 -0
- package/lib/electron-common/dev-container-workspaces.d.ts.map +1 -0
- package/lib/electron-common/dev-container-workspaces.js +21 -0
- package/lib/electron-common/dev-container-workspaces.js.map +1 -0
- package/lib/electron-common/remote-container-connection-provider.d.ts +30 -0
- package/lib/electron-common/remote-container-connection-provider.d.ts.map +1 -0
- package/lib/electron-common/remote-container-connection-provider.js +21 -0
- package/lib/electron-common/remote-container-connection-provider.js.map +1 -0
- package/lib/electron-node/dev-container-backend-module.d.ts +5 -0
- package/lib/electron-node/dev-container-backend-module.d.ts.map +1 -0
- package/lib/electron-node/dev-container-backend-module.js +58 -0
- package/lib/electron-node/dev-container-backend-module.js.map +1 -0
- package/lib/electron-node/dev-container-file-service.d.ts +10 -0
- package/lib/electron-node/dev-container-file-service.d.ts.map +1 -0
- package/lib/electron-node/dev-container-file-service.js +69 -0
- package/lib/electron-node/dev-container-file-service.js.map +1 -0
- package/lib/electron-node/dev-container-workspace-handler.d.ts +7 -0
- package/lib/electron-node/dev-container-workspace-handler.d.ts.map +1 -0
- package/lib/electron-node/dev-container-workspace-handler.js +21 -0
- package/lib/electron-node/dev-container-workspace-handler.js.map +1 -0
- package/lib/electron-node/devcontainer-contributions/cli-enhancing-creation-contributions.d.ts +17 -0
- package/lib/electron-node/devcontainer-contributions/cli-enhancing-creation-contributions.d.ts.map +1 -0
- package/lib/electron-node/devcontainer-contributions/cli-enhancing-creation-contributions.js +69 -0
- package/lib/electron-node/devcontainer-contributions/cli-enhancing-creation-contributions.js.map +1 -0
- package/lib/electron-node/devcontainer-contributions/main-container-creation-contributions.d.ts +38 -0
- package/lib/electron-node/devcontainer-contributions/main-container-creation-contributions.d.ts.map +1 -0
- package/lib/electron-node/devcontainer-contributions/main-container-creation-contributions.js +192 -0
- package/lib/electron-node/devcontainer-contributions/main-container-creation-contributions.js.map +1 -0
- package/lib/electron-node/devcontainer-contributions/profile-file-modification-contribution.d.ts +11 -0
- package/lib/electron-node/devcontainer-contributions/profile-file-modification-contribution.d.ts.map +1 -0
- package/lib/electron-node/devcontainer-contributions/profile-file-modification-contribution.js +37 -0
- package/lib/electron-node/devcontainer-contributions/profile-file-modification-contribution.js.map +1 -0
- package/lib/electron-node/devcontainer-file.d.ts +350 -0
- package/lib/electron-node/devcontainer-file.d.ts.map +1 -0
- package/lib/electron-node/devcontainer-file.js +18 -0
- package/lib/electron-node/devcontainer-file.js.map +1 -0
- package/lib/electron-node/docker-container-service.d.ts +29 -0
- package/lib/electron-node/docker-container-service.d.ts.map +1 -0
- package/lib/electron-node/docker-container-service.js +106 -0
- package/lib/electron-node/docker-container-service.js.map +1 -0
- package/lib/electron-node/remote-container-connection-provider.d.ts +79 -0
- package/lib/electron-node/remote-container-connection-provider.d.ts.map +1 -0
- package/lib/electron-node/remote-container-connection-provider.js +260 -0
- package/lib/electron-node/remote-container-connection-provider.js.map +1 -0
- package/lib/package.spec.d.ts +1 -0
- package/lib/package.spec.d.ts.map +1 -0
- package/lib/package.spec.js +26 -0
- package/lib/package.spec.js.map +1 -0
- package/package.json +55 -0
- package/src/dev-container-server/dev-container-server.ts +53 -0
- package/src/electron-browser/container-connection-contribution.ts +151 -0
- package/src/electron-browser/container-info-contribution.ts +47 -0
- package/src/electron-browser/container-output-provider.ts +36 -0
- package/src/electron-browser/dev-container-frontend-module.ts +40 -0
- package/src/electron-common/container-output-provider.ts +19 -0
- package/src/electron-common/dev-container-workspaces.ts +18 -0
- package/src/electron-common/remote-container-connection-provider.ts +52 -0
- package/src/electron-node/dev-container-backend-module.ts +63 -0
- package/src/electron-node/dev-container-file-service.ts +67 -0
- package/src/electron-node/dev-container-workspace-handler.ts +33 -0
- package/src/electron-node/devcontainer-contributions/cli-enhancing-creation-contributions.ts +68 -0
- package/src/electron-node/devcontainer-contributions/main-container-creation-contributions.ts +196 -0
- package/src/electron-node/devcontainer-contributions/profile-file-modification-contribution.ts +35 -0
- package/src/electron-node/devcontainer-file.ts +411 -0
- package/src/electron-node/docker-container-service.ts +131 -0
- package/src/electron-node/remote-container-connection-provider.ts +315 -0
- package/src/package.spec.ts +28 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dev-container-backend-module.d.ts","sourceRoot":"","sources":["../../src/electron-node/dev-container-backend-module.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAe/D,eAAO,MAAM,sBAAsB,iBAgBjC,CAAC;;AAEH,wBAaG"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2024 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
|
+
exports.remoteConnectionModule = void 0;
|
|
19
|
+
const inversify_1 = require("@theia/core/shared/inversify");
|
|
20
|
+
const connection_container_module_1 = require("@theia/core/lib/node/messaging/connection-container-module");
|
|
21
|
+
const remote_container_connection_provider_1 = require("./remote-container-connection-provider");
|
|
22
|
+
const remote_container_connection_provider_2 = require("../electron-common/remote-container-connection-provider");
|
|
23
|
+
const docker_container_service_1 = require("./docker-container-service");
|
|
24
|
+
const core_1 = require("@theia/core");
|
|
25
|
+
const main_container_creation_contributions_1 = require("./devcontainer-contributions/main-container-creation-contributions");
|
|
26
|
+
const dev_container_file_service_1 = require("./dev-container-file-service");
|
|
27
|
+
const cli_enhancing_creation_contributions_1 = require("./devcontainer-contributions/cli-enhancing-creation-contributions");
|
|
28
|
+
const remote_cli_contribution_1 = require("@theia/core/lib/node/remote/remote-cli-contribution");
|
|
29
|
+
const profile_file_modification_contribution_1 = require("./devcontainer-contributions/profile-file-modification-contribution");
|
|
30
|
+
const dev_container_workspace_handler_1 = require("./dev-container-workspace-handler");
|
|
31
|
+
const default_workspace_server_1 = require("@theia/workspace/lib/node/default-workspace-server");
|
|
32
|
+
exports.remoteConnectionModule = connection_container_module_1.ConnectionContainerModule.create(({ bind, bindBackendService }) => {
|
|
33
|
+
(0, core_1.bindContributionProvider)(bind, docker_container_service_1.ContainerCreationContribution);
|
|
34
|
+
(0, main_container_creation_contributions_1.registerContainerCreationContributions)(bind);
|
|
35
|
+
(0, cli_enhancing_creation_contributions_1.registerTheiaStartOptionsContributions)(bind);
|
|
36
|
+
bind(profile_file_modification_contribution_1.ProfileFileModificationContribution).toSelf().inSingletonScope();
|
|
37
|
+
bind(docker_container_service_1.ContainerCreationContribution).toService(profile_file_modification_contribution_1.ProfileFileModificationContribution);
|
|
38
|
+
bind(remote_container_connection_provider_1.DevContainerConnectionProvider).toSelf().inSingletonScope();
|
|
39
|
+
bind(remote_container_connection_provider_2.RemoteContainerConnectionProvider).toService(remote_container_connection_provider_1.DevContainerConnectionProvider);
|
|
40
|
+
bind(core_1.ConnectionHandler).toDynamicValue(ctx => new core_1.RpcConnectionHandler(remote_container_connection_provider_2.RemoteContainerConnectionProviderPath, client => {
|
|
41
|
+
const server = ctx.container.get(remote_container_connection_provider_2.RemoteContainerConnectionProvider);
|
|
42
|
+
server.setClient(client);
|
|
43
|
+
client.onDidCloseConnection(() => server.dispose());
|
|
44
|
+
return server;
|
|
45
|
+
}));
|
|
46
|
+
});
|
|
47
|
+
exports.default = new inversify_1.ContainerModule((bind, unbind, isBound, rebind) => {
|
|
48
|
+
bind(docker_container_service_1.DockerContainerService).toSelf().inSingletonScope();
|
|
49
|
+
bind(connection_container_module_1.ConnectionContainerModule).toConstantValue(exports.remoteConnectionModule);
|
|
50
|
+
bind(dev_container_file_service_1.DevContainerFileService).toSelf().inSingletonScope();
|
|
51
|
+
bind(cli_enhancing_creation_contributions_1.ExtensionsContribution).toSelf().inSingletonScope();
|
|
52
|
+
bind(cli_enhancing_creation_contributions_1.SettingsContribution).toSelf().inSingletonScope();
|
|
53
|
+
bind(remote_cli_contribution_1.RemoteCliContribution).toService(cli_enhancing_creation_contributions_1.ExtensionsContribution);
|
|
54
|
+
bind(remote_cli_contribution_1.RemoteCliContribution).toService(cli_enhancing_creation_contributions_1.SettingsContribution);
|
|
55
|
+
bind(dev_container_workspace_handler_1.DevContainerWorkspaceHandler).toSelf().inSingletonScope();
|
|
56
|
+
bind(default_workspace_server_1.WorkspaceHandlerContribution).toService(dev_container_workspace_handler_1.DevContainerWorkspaceHandler);
|
|
57
|
+
});
|
|
58
|
+
//# sourceMappingURL=dev-container-backend-module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dev-container-backend-module.js","sourceRoot":"","sources":["../../src/electron-node/dev-container-backend-module.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,yCAAyC;AACzC,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;;AAEhF,4DAA+D;AAC/D,4GAAuG;AACvG,iGAAwF;AACxF,kHAAmJ;AACnJ,yEAAmG;AACnG,sCAAgG;AAChG,8HAA4H;AAC5H,6EAAuE;AAEvE,4HAAyK;AACzK,iGAA4F;AAC5F,gIAA0H;AAC1H,uFAAiF;AACjF,iGAAkG;AAErF,QAAA,sBAAsB,GAAG,uDAAyB,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,EAAE,kBAAkB,EAAE,EAAE,EAAE;IACpG,IAAA,+BAAwB,EAAC,IAAI,EAAE,wDAA6B,CAAC,CAAC;IAC9D,IAAA,8EAAsC,EAAC,IAAI,CAAC,CAAC;IAC7C,IAAA,6EAAsC,EAAC,IAAI,CAAC,CAAC;IAC7C,IAAI,CAAC,4EAAmC,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IACtE,IAAI,CAAC,wDAA6B,CAAC,CAAC,SAAS,CAAC,4EAAmC,CAAC,CAAC;IAEnF,IAAI,CAAC,qEAA8B,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IACjE,IAAI,CAAC,wEAAiC,CAAC,CAAC,SAAS,CAAC,qEAA8B,CAAC,CAAC;IAClF,IAAI,CAAC,wBAAiB,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CACzC,IAAI,2BAAoB,CAA0B,4EAAqC,EAAE,MAAM,CAAC,EAAE;QAC9F,MAAM,MAAM,GAAG,GAAG,CAAC,SAAS,CAAC,GAAG,CAAoC,wEAAiC,CAAC,CAAC;QACvG,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACzB,MAAM,CAAC,oBAAoB,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC;QACpD,OAAO,MAAM,CAAC;IAClB,CAAC,CAAC,CAAC,CAAC;AACZ,CAAC,CAAC,CAAC;AAEH,kBAAe,IAAI,2BAAe,CAAC,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE;IACjE,IAAI,CAAC,iDAAsB,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IACzD,IAAI,CAAC,uDAAyB,CAAC,CAAC,eAAe,CAAC,8BAAsB,CAAC,CAAC;IAExE,IAAI,CAAC,oDAAuB,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IAE1D,IAAI,CAAC,6DAAsB,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IACzD,IAAI,CAAC,2DAAoB,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IACvD,IAAI,CAAC,+CAAqB,CAAC,CAAC,SAAS,CAAC,6DAAsB,CAAC,CAAC;IAC9D,IAAI,CAAC,+CAAqB,CAAC,CAAC,SAAS,CAAC,2DAAoB,CAAC,CAAC;IAE5D,IAAI,CAAC,8DAA4B,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IAC/D,IAAI,CAAC,uDAA4B,CAAC,CAAC,SAAS,CAAC,8DAA4B,CAAC,CAAC;AAC/E,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { WorkspaceServer } from '@theia/workspace/lib/common';
|
|
2
|
+
import { DevContainerFile } from '../electron-common/remote-container-connection-provider';
|
|
3
|
+
import { DevContainerConfiguration } from './devcontainer-file';
|
|
4
|
+
export declare class DevContainerFileService {
|
|
5
|
+
protected readonly workspaceServer: WorkspaceServer;
|
|
6
|
+
getConfiguration(path: string): Promise<DevContainerConfiguration>;
|
|
7
|
+
getAvailableFiles(workspace: string): Promise<DevContainerFile[]>;
|
|
8
|
+
protected searchForDevontainerJsonFiles(directory: string, depth: number): Promise<string[]>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=dev-container-file-service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dev-container-file-service.d.ts","sourceRoot":"","sources":["../../src/electron-node/dev-container-file-service.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,yDAAyD,CAAC;AAC3F,OAAO,EAAE,yBAAyB,EAAE,MAAM,qBAAqB,CAAC;AAKhE,qBACa,uBAAuB;IAGhC,SAAS,CAAC,QAAQ,CAAC,eAAe,EAAE,eAAe,CAAC;IAE9C,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,yBAAyB,CAAC;IAUlE,iBAAiB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;cAUvD,6BAA6B,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;CAgBrG"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2024 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
|
+
exports.DevContainerFileService = void 0;
|
|
19
|
+
const tslib_1 = require("tslib");
|
|
20
|
+
const inversify_1 = require("@theia/core/shared/inversify");
|
|
21
|
+
const common_1 = require("@theia/workspace/lib/common");
|
|
22
|
+
const jsonc_parser_1 = require("jsonc-parser");
|
|
23
|
+
const fs = require("@theia/core/shared/fs-extra");
|
|
24
|
+
const core_1 = require("@theia/core");
|
|
25
|
+
let DevContainerFileService = class DevContainerFileService {
|
|
26
|
+
async getConfiguration(path) {
|
|
27
|
+
const configuration = (0, jsonc_parser_1.parse)(await fs.readFile(path, 'utf-8').catch(() => '0'));
|
|
28
|
+
if (!configuration) {
|
|
29
|
+
throw new Error(`devcontainer file ${path} could not be parsed`);
|
|
30
|
+
}
|
|
31
|
+
configuration.location = path;
|
|
32
|
+
return configuration;
|
|
33
|
+
}
|
|
34
|
+
async getAvailableFiles(workspace) {
|
|
35
|
+
const devcontainerPath = new core_1.URI(workspace).path.join('.devcontainer').fsPath();
|
|
36
|
+
return (await this.searchForDevontainerJsonFiles(devcontainerPath, 1)).map(file => {
|
|
37
|
+
var _a;
|
|
38
|
+
return ({
|
|
39
|
+
name: (_a = (0, jsonc_parser_1.parse)(fs.readFileSync(file, 'utf-8')).name) !== null && _a !== void 0 ? _a : 'devcontainer',
|
|
40
|
+
path: file
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
async searchForDevontainerJsonFiles(directory, depth) {
|
|
45
|
+
if (depth < 0 || !await fs.pathExists(directory)) {
|
|
46
|
+
return [];
|
|
47
|
+
}
|
|
48
|
+
const filesPaths = (await fs.readdir(directory)).map(file => new core_1.Path(directory).join(file).fsPath());
|
|
49
|
+
const devcontainerFiles = [];
|
|
50
|
+
for (const file of filesPaths) {
|
|
51
|
+
if (file.endsWith('devcontainer.json')) {
|
|
52
|
+
devcontainerFiles.push(file);
|
|
53
|
+
}
|
|
54
|
+
else if ((await fs.stat(file)).isDirectory()) {
|
|
55
|
+
devcontainerFiles.push(...await this.searchForDevontainerJsonFiles(file, depth - 1));
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
return devcontainerFiles;
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
exports.DevContainerFileService = DevContainerFileService;
|
|
62
|
+
tslib_1.__decorate([
|
|
63
|
+
(0, inversify_1.inject)(common_1.WorkspaceServer),
|
|
64
|
+
tslib_1.__metadata("design:type", Object)
|
|
65
|
+
], DevContainerFileService.prototype, "workspaceServer", void 0);
|
|
66
|
+
exports.DevContainerFileService = DevContainerFileService = tslib_1.__decorate([
|
|
67
|
+
(0, inversify_1.injectable)()
|
|
68
|
+
], DevContainerFileService);
|
|
69
|
+
//# sourceMappingURL=dev-container-file-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dev-container-file-service.js","sourceRoot":"","sources":["../../src/electron-node/dev-container-file-service.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,yCAAyC;AACzC,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;;;AAEhF,4DAAkE;AAClE,wDAA8D;AAG9D,+CAAqC;AACrC,kDAAkD;AAClD,sCAAwC;AAGjC,IAAM,uBAAuB,GAA7B,MAAM,uBAAuB;IAKhC,KAAK,CAAC,gBAAgB,CAAC,IAAY;QAC/B,MAAM,aAAa,GAA8B,IAAA,oBAAK,EAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAA8B,CAAC;QACvI,IAAI,CAAC,aAAa,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,qBAAqB,IAAI,sBAAsB,CAAC,CAAC;QACrE,CAAC;QAED,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;QAC9B,OAAO,aAAa,CAAC;IACzB,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,SAAiB;QACrC,MAAM,gBAAgB,GAAG,IAAI,UAAG,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,MAAM,EAAE,CAAC;QAEhF,OAAO,CAAC,MAAM,IAAI,CAAC,6BAA6B,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;;YAAC,OAAA,CAAC;gBAChF,IAAI,EAAE,MAAA,IAAA,oBAAK,EAAC,EAAE,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,IAAI,mCAAI,cAAc;gBAClE,IAAI,EAAE,IAAI;aACb,CAAC,CAAA;SAAA,CAAC,CAAC;IAER,CAAC;IAES,KAAK,CAAC,6BAA6B,CAAC,SAAiB,EAAE,KAAa;QAC1E,IAAI,KAAK,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YAC/C,OAAO,EAAE,CAAC;QACd,CAAC;QACD,MAAM,UAAU,GAAG,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,WAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;QAEtG,MAAM,iBAAiB,GAAG,EAAE,CAAC;QAC7B,KAAK,MAAM,IAAI,IAAI,UAAU,EAAE,CAAC;YAC5B,IAAI,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,EAAE,CAAC;gBACrC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACjC,CAAC;iBAAM,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC;gBAC7C,iBAAiB,CAAC,IAAI,CAAC,GAAG,MAAM,IAAI,CAAC,6BAA6B,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;YACzF,CAAC;QACL,CAAC;QACD,OAAO,iBAAiB,CAAC;IAC7B,CAAC;CACJ,CAAA;AAzCY,0DAAuB;AAGb;IADlB,IAAA,kBAAM,EAAC,wBAAe,CAAC;;gEAC4B;kCAH3C,uBAAuB;IADnC,IAAA,sBAAU,GAAE;GACA,uBAAuB,CAyCnC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { URI } from '@theia/core';
|
|
2
|
+
import { WorkspaceHandlerContribution } from '@theia/workspace/lib/node/default-workspace-server';
|
|
3
|
+
export declare class DevContainerWorkspaceHandler implements WorkspaceHandlerContribution {
|
|
4
|
+
canHandle(uri: URI): boolean;
|
|
5
|
+
workspaceStillExists(uri: URI): Promise<boolean>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=dev-container-workspace-handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dev-container-workspace-handler.d.ts","sourceRoot":"","sources":["../../src/electron-node/dev-container-workspace-handler.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAC;AAGlC,OAAO,EAAE,4BAA4B,EAAE,MAAM,oDAAoD,CAAC;AAGlG,qBACa,4BAA6B,YAAW,4BAA4B;IAE7E,SAAS,CAAC,GAAG,EAAE,GAAG,GAAG,OAAO;IAItB,oBAAoB,CAAC,GAAG,EAAE,GAAG,GAAG,OAAO,CAAC,OAAO,CAAC;CAIzD"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DevContainerWorkspaceHandler = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const fs = require("@theia/core/shared/fs-extra");
|
|
6
|
+
const inversify_1 = require("@theia/core/shared/inversify");
|
|
7
|
+
const dev_container_workspaces_1 = require("../electron-common/dev-container-workspaces");
|
|
8
|
+
let DevContainerWorkspaceHandler = class DevContainerWorkspaceHandler {
|
|
9
|
+
canHandle(uri) {
|
|
10
|
+
return uri.scheme === dev_container_workspaces_1.DEV_CONTAINER_WORKSPACE_SCHEME;
|
|
11
|
+
}
|
|
12
|
+
async workspaceStillExists(uri) {
|
|
13
|
+
const devcontainerFile = new URLSearchParams(uri.query).get(dev_container_workspaces_1.DEV_CONTAINER_PATH_QUERY);
|
|
14
|
+
return await fs.pathExists(uri.path.fsPath()) && !!devcontainerFile && fs.pathExists(devcontainerFile);
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
exports.DevContainerWorkspaceHandler = DevContainerWorkspaceHandler;
|
|
18
|
+
exports.DevContainerWorkspaceHandler = DevContainerWorkspaceHandler = tslib_1.__decorate([
|
|
19
|
+
(0, inversify_1.injectable)()
|
|
20
|
+
], DevContainerWorkspaceHandler);
|
|
21
|
+
//# sourceMappingURL=dev-container-workspace-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dev-container-workspace-handler.js","sourceRoot":"","sources":["../../src/electron-node/dev-container-workspace-handler.ts"],"names":[],"mappings":";;;;AAgBA,kDAAkD;AAClD,4DAA0D;AAE1D,0FAAuH;AAGhH,IAAM,4BAA4B,GAAlC,MAAM,4BAA4B;IAErC,SAAS,CAAC,GAAQ;QACd,OAAO,GAAG,CAAC,MAAM,KAAK,yDAA8B,CAAC;IACzD,CAAC;IAED,KAAK,CAAC,oBAAoB,CAAC,GAAQ;QAC/B,MAAM,gBAAgB,GAAG,IAAI,eAAe,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,mDAAwB,CAAC,CAAC;QACtF,OAAO,MAAM,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,CAAC,gBAAgB,IAAI,EAAE,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;IAC3G,CAAC;CACJ,CAAA;AAVY,oEAA4B;uCAA5B,4BAA4B;IADxC,IAAA,sBAAU,GAAE;GACA,4BAA4B,CAUxC"}
|
package/lib/electron-node/devcontainer-contributions/cli-enhancing-creation-contributions.d.ts
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { RemoteCliContext, RemoteCliContribution } from '@theia/core/lib/node/remote/remote-cli-contribution';
|
|
2
|
+
import { ContainerCreationContribution } from '../docker-container-service';
|
|
3
|
+
import * as Docker from 'dockerode';
|
|
4
|
+
import { DevContainerConfiguration } from '../devcontainer-file';
|
|
5
|
+
import { interfaces } from '@theia/core/shared/inversify';
|
|
6
|
+
export declare function registerTheiaStartOptionsContributions(bind: interfaces.Bind): void;
|
|
7
|
+
export declare class ExtensionsContribution implements RemoteCliContribution, ContainerCreationContribution {
|
|
8
|
+
protected currentConfig: DevContainerConfiguration | undefined;
|
|
9
|
+
enhanceArgs(context: RemoteCliContext): string[];
|
|
10
|
+
handleContainerCreation(createOptions: Docker.ContainerCreateOptions, containerConfig: DevContainerConfiguration): Promise<void>;
|
|
11
|
+
}
|
|
12
|
+
export declare class SettingsContribution implements RemoteCliContribution, ContainerCreationContribution {
|
|
13
|
+
protected currentConfig: DevContainerConfiguration | undefined;
|
|
14
|
+
enhanceArgs(context: RemoteCliContext): string[];
|
|
15
|
+
handleContainerCreation(createOptions: Docker.ContainerCreateOptions, containerConfig: DevContainerConfiguration): Promise<void>;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=cli-enhancing-creation-contributions.d.ts.map
|
package/lib/electron-node/devcontainer-contributions/cli-enhancing-creation-contributions.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli-enhancing-creation-contributions.d.ts","sourceRoot":"","sources":["../../../src/electron-node/devcontainer-contributions/cli-enhancing-creation-contributions.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,qDAAqD,CAAC;AAC9G,OAAO,EAAE,6BAA6B,EAAE,MAAM,6BAA6B,CAAC;AAC5E,OAAO,KAAK,MAAM,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,yBAAyB,EAAG,MAAM,sBAAsB,CAAC;AAClE,OAAO,EAAc,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAEtE,wBAAgB,sCAAsC,CAAC,IAAI,EAAE,UAAU,CAAC,IAAI,GAAG,IAAI,CAGlF;AAED,qBACa,sBAAuB,YAAW,qBAAqB,EAAE,6BAA6B;IAC/F,SAAS,CAAC,aAAa,EAAE,yBAAyB,GAAG,SAAS,CAAC;IAE/D,WAAW,CAAC,OAAO,EAAE,gBAAgB,GAAG,MAAM,EAAE;IAY1C,uBAAuB,CAAC,aAAa,EAAE,MAAM,CAAC,sBAAsB,EAAE,eAAe,EAAE,yBAAyB,GAAG,OAAO,CAAC,IAAI,CAAC;CAGzI;AAED,qBACa,oBAAqB,YAAW,qBAAqB,EAAE,6BAA6B;IAC7F,SAAS,CAAC,aAAa,EAAE,yBAAyB,GAAG,SAAS,CAAC;IAE/D,WAAW,CAAC,OAAO,EAAE,gBAAgB,GAAG,MAAM,EAAE;IAY1C,uBAAuB,CAAC,aAAa,EAAE,MAAM,CAAC,sBAAsB,EAAE,eAAe,EAAE,yBAAyB,GAAG,OAAO,CAAC,IAAI,CAAC;CAGzI"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2024 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
|
+
exports.SettingsContribution = exports.ExtensionsContribution = exports.registerTheiaStartOptionsContributions = void 0;
|
|
19
|
+
const tslib_1 = require("tslib");
|
|
20
|
+
const docker_container_service_1 = require("../docker-container-service");
|
|
21
|
+
const inversify_1 = require("@theia/core/shared/inversify");
|
|
22
|
+
function registerTheiaStartOptionsContributions(bind) {
|
|
23
|
+
bind(docker_container_service_1.ContainerCreationContribution).toService(ExtensionsContribution);
|
|
24
|
+
bind(docker_container_service_1.ContainerCreationContribution).toService(SettingsContribution);
|
|
25
|
+
}
|
|
26
|
+
exports.registerTheiaStartOptionsContributions = registerTheiaStartOptionsContributions;
|
|
27
|
+
let ExtensionsContribution = class ExtensionsContribution {
|
|
28
|
+
enhanceArgs(context) {
|
|
29
|
+
var _a, _b, _c, _d;
|
|
30
|
+
if (!this.currentConfig) {
|
|
31
|
+
return [];
|
|
32
|
+
}
|
|
33
|
+
const extensions = [
|
|
34
|
+
...((_a = this.currentConfig.extensions) !== null && _a !== void 0 ? _a : []),
|
|
35
|
+
...((_d = (_c = (_b = this.currentConfig.customizations) === null || _b === void 0 ? void 0 : _b.vscode) === null || _c === void 0 ? void 0 : _c.extensions) !== null && _d !== void 0 ? _d : [])
|
|
36
|
+
];
|
|
37
|
+
this.currentConfig = undefined;
|
|
38
|
+
return extensions === null || extensions === void 0 ? void 0 : extensions.map(extension => `--install-plugin=${extension}`);
|
|
39
|
+
}
|
|
40
|
+
async handleContainerCreation(createOptions, containerConfig) {
|
|
41
|
+
this.currentConfig = containerConfig;
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
exports.ExtensionsContribution = ExtensionsContribution;
|
|
45
|
+
exports.ExtensionsContribution = ExtensionsContribution = tslib_1.__decorate([
|
|
46
|
+
(0, inversify_1.injectable)()
|
|
47
|
+
], ExtensionsContribution);
|
|
48
|
+
let SettingsContribution = class SettingsContribution {
|
|
49
|
+
enhanceArgs(context) {
|
|
50
|
+
var _a, _b, _c, _d, _e;
|
|
51
|
+
if (!this.currentConfig) {
|
|
52
|
+
return [];
|
|
53
|
+
}
|
|
54
|
+
const settings = {
|
|
55
|
+
...((_a = this.currentConfig.settings) !== null && _a !== void 0 ? _a : {}),
|
|
56
|
+
...((_d = (_c = (_b = this.currentConfig.customizations) === null || _b === void 0 ? void 0 : _b.vscode) === null || _c === void 0 ? void 0 : _c.settings) !== null && _d !== void 0 ? _d : [])
|
|
57
|
+
};
|
|
58
|
+
this.currentConfig = undefined;
|
|
59
|
+
return (_e = Object.entries(settings).map(([key, value]) => `--set-preference=${key}=${JSON.stringify(value)}`)) !== null && _e !== void 0 ? _e : [];
|
|
60
|
+
}
|
|
61
|
+
async handleContainerCreation(createOptions, containerConfig) {
|
|
62
|
+
this.currentConfig = containerConfig;
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
exports.SettingsContribution = SettingsContribution;
|
|
66
|
+
exports.SettingsContribution = SettingsContribution = tslib_1.__decorate([
|
|
67
|
+
(0, inversify_1.injectable)()
|
|
68
|
+
], SettingsContribution);
|
|
69
|
+
//# sourceMappingURL=cli-enhancing-creation-contributions.js.map
|
package/lib/electron-node/devcontainer-contributions/cli-enhancing-creation-contributions.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli-enhancing-creation-contributions.js","sourceRoot":"","sources":["../../../src/electron-node/devcontainer-contributions/cli-enhancing-creation-contributions.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,yCAAyC;AACzC,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;;;AAGhF,0EAA4E;AAG5E,4DAAsE;AAEtE,SAAgB,sCAAsC,CAAC,IAAqB;IACxE,IAAI,CAAC,wDAA6B,CAAC,CAAC,SAAS,CAAC,sBAAsB,CAAC,CAAC;IACtE,IAAI,CAAC,wDAA6B,CAAC,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC;AACxE,CAAC;AAHD,wFAGC;AAGM,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IAG/B,WAAW,CAAC,OAAyB;;QACjC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YACtB,OAAO,EAAE,CAAC;QACd,CAAC;QACD,MAAM,UAAU,GAAG;YACf,GAAG,CAAC,MAAA,IAAI,CAAC,aAAa,CAAC,UAAU,mCAAI,EAAE,CAAC;YACxC,GAAG,CAAC,MAAA,MAAA,MAAA,IAAI,CAAC,aAAa,CAAC,cAAc,0CAAE,MAAM,0CAAE,UAAU,mCAAI,EAAE,CAAC;SACnE,CAAC;QACF,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;QAC/B,OAAO,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,oBAAoB,SAAS,EAAE,CAAC,CAAC;IACzE,CAAC;IAED,KAAK,CAAC,uBAAuB,CAAC,aAA4C,EAAE,eAA0C;QAClH,IAAI,CAAC,aAAa,GAAG,eAAe,CAAC;IACzC,CAAC;CACJ,CAAA;AAlBY,wDAAsB;iCAAtB,sBAAsB;IADlC,IAAA,sBAAU,GAAE;GACA,sBAAsB,CAkBlC;AAGM,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;IAG7B,WAAW,CAAC,OAAyB;;QACjC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YACtB,OAAO,EAAE,CAAC;QACd,CAAC;QACD,MAAM,QAAQ,GAAG;YACb,GAAG,CAAC,MAAA,IAAI,CAAC,aAAa,CAAC,QAAQ,mCAAI,EAAE,CAAC;YACtC,GAAG,CAAC,MAAA,MAAA,MAAA,IAAI,CAAC,aAAa,CAAC,cAAc,0CAAE,MAAM,0CAAE,QAAQ,mCAAI,EAAE,CAAC;SACjE,CAAC;QACF,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;QAC/B,OAAO,MAAA,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,oBAAoB,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,mCAAI,EAAE,CAAC;IACpH,CAAC;IAED,KAAK,CAAC,uBAAuB,CAAC,aAA4C,EAAE,eAA0C;QAClH,IAAI,CAAC,aAAa,GAAG,eAAe,CAAC;IACzC,CAAC;CACJ,CAAA;AAlBY,oDAAoB;+BAApB,oBAAoB;IADhC,IAAA,sBAAU,GAAE;GACA,oBAAoB,CAkBhC"}
|
package/lib/electron-node/devcontainer-contributions/main-container-creation-contributions.d.ts
ADDED
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import * as Docker from 'dockerode';
|
|
2
|
+
import { interfaces } from '@theia/core/shared/inversify';
|
|
3
|
+
import { ContainerCreationContribution } from '../docker-container-service';
|
|
4
|
+
import { DevContainerConfiguration, DockerfileContainer, ImageContainer } from '../devcontainer-file';
|
|
5
|
+
import { ContainerOutputProvider } from '../../electron-common/container-output-provider';
|
|
6
|
+
import { RemotePortForwardingProvider } from '@theia/remote/lib/electron-common/remote-port-forwarding-provider';
|
|
7
|
+
import { RemoteDockerContainerConnection } from '../remote-container-connection-provider';
|
|
8
|
+
export declare function registerContainerCreationContributions(bind: interfaces.Bind): void;
|
|
9
|
+
export declare class ImageFileContribution implements ContainerCreationContribution {
|
|
10
|
+
handleContainerCreation(createOptions: Docker.ContainerCreateOptions, containerConfig: ImageContainer, api: Docker, outputprovider: ContainerOutputProvider): Promise<void>;
|
|
11
|
+
}
|
|
12
|
+
export declare class DockerFileContribution implements ContainerCreationContribution {
|
|
13
|
+
handleContainerCreation(createOptions: Docker.ContainerCreateOptions, containerConfig: DockerfileContainer, api: Docker, outputprovider: ContainerOutputProvider): Promise<void>;
|
|
14
|
+
}
|
|
15
|
+
export declare class ForwardPortsContribution implements ContainerCreationContribution {
|
|
16
|
+
protected readonly portForwardingProvider: RemotePortForwardingProvider;
|
|
17
|
+
handlePostConnect(containerConfig: DevContainerConfiguration, connection: RemoteDockerContainerConnection): Promise<void>;
|
|
18
|
+
}
|
|
19
|
+
export declare class MountsContribution implements ContainerCreationContribution {
|
|
20
|
+
handleContainerCreation(createOptions: Docker.ContainerCreateOptions, containerConfig: DevContainerConfiguration, api: Docker): Promise<void>;
|
|
21
|
+
parseMountString(mount: string): Docker.MountSettings;
|
|
22
|
+
}
|
|
23
|
+
export declare class RemoteUserContribution implements ContainerCreationContribution {
|
|
24
|
+
handleContainerCreation(createOptions: Docker.ContainerCreateOptions, containerConfig: DevContainerConfiguration, api: Docker): Promise<void>;
|
|
25
|
+
}
|
|
26
|
+
export declare class PostCreateCommandContribution implements ContainerCreationContribution {
|
|
27
|
+
handlePostCreate?(containerConfig: DevContainerConfiguration, container: Docker.Container, api: Docker, outputprovider: ContainerOutputProvider): Promise<void>;
|
|
28
|
+
}
|
|
29
|
+
export declare namespace OutputHelper {
|
|
30
|
+
interface Progress {
|
|
31
|
+
id?: string;
|
|
32
|
+
stream: string;
|
|
33
|
+
status?: string;
|
|
34
|
+
progress?: string;
|
|
35
|
+
}
|
|
36
|
+
function parseProgress(progress: Progress): string;
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=main-container-creation-contributions.d.ts.map
|
package/lib/electron-node/devcontainer-contributions/main-container-creation-contributions.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main-container-creation-contributions.d.ts","sourceRoot":"","sources":["../../../src/electron-node/devcontainer-contributions/main-container-creation-contributions.ts"],"names":[],"mappings":"AAeA,OAAO,KAAK,MAAM,MAAM,WAAW,CAAC;AACpC,OAAO,EAAsB,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC9E,OAAO,EAAE,6BAA6B,EAAE,MAAM,6BAA6B,CAAC;AAC5E,OAAO,EAAE,yBAAyB,EAAE,mBAAmB,EAAE,cAAc,EAA2B,MAAM,sBAAsB,CAAC;AAE/H,OAAO,EAAE,uBAAuB,EAAE,MAAM,iDAAiD,CAAC;AAE1F,OAAO,EAAE,4BAA4B,EAAE,MAAM,mEAAmE,CAAC;AACjH,OAAO,EAAE,+BAA+B,EAAE,MAAM,yCAAyC,CAAC;AAE1F,wBAAgB,sCAAsC,CAAC,IAAI,EAAE,UAAU,CAAC,IAAI,GAAG,IAAI,CAOlF;AAED,qBACa,qBAAsB,YAAW,6BAA6B;IACjE,uBAAuB,CAAC,aAAa,EAAE,MAAM,CAAC,sBAAsB,EAAE,eAAe,EAAE,cAAc,EACvG,GAAG,EAAE,MAAM,EAAE,cAAc,EAAE,uBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC;CAmB3E;AAED,qBACa,sBAAuB,YAAW,6BAA6B;IAClE,uBAAuB,CAAC,aAAa,EAAE,MAAM,CAAC,sBAAsB,EAAE,eAAe,EAAE,mBAAmB,EAC5G,GAAG,EAAE,MAAM,EAAE,cAAc,EAAE,uBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC;CAmC3E;AAED,qBACa,wBAAyB,YAAW,6BAA6B;IAG1E,SAAS,CAAC,QAAQ,CAAC,sBAAsB,EAAE,4BAA4B,CAAC;IAElE,iBAAiB,CAAC,eAAe,EAAE,yBAAyB,EAAE,UAAU,EAAE,+BAA+B,GAAG,OAAO,CAAC,IAAI,CAAC;CAqBlI;AAED,qBACa,kBAAmB,YAAW,6BAA6B;IAC9D,uBAAuB,CAAC,aAAa,EAAE,MAAM,CAAC,sBAAsB,EAAE,eAAe,EAAE,yBAAyB,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAWnJ,gBAAgB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC,aAAa;CAQxD;AAED,qBACa,sBAAuB,YAAW,6BAA6B;IAClE,uBAAuB,CAAC,aAAa,EAAE,MAAM,CAAC,sBAAsB,EAAE,eAAe,EAAE,yBAAyB,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAKtJ;AAED,qBACa,6BAA8B,YAAW,6BAA6B;IACzE,gBAAgB,CAAC,CAAC,eAAe,EAAE,yBAAyB,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,EAAE,GAAG,EAAE,MAAM,EAAE,cAAc,EAAE,uBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC;CAqBxK;AAED,yBAAiB,YAAY,CAAC;IAC1B,UAAiB,QAAQ;QACrB,EAAE,CAAC,EAAE,MAAM,CAAC;QACZ,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACrB;IAED,SAAgB,aAAa,CAAC,QAAQ,EAAE,QAAQ,GAAG,MAAM,CAExD;CACJ"}
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.OutputHelper = exports.PostCreateCommandContribution = exports.RemoteUserContribution = exports.MountsContribution = exports.ForwardPortsContribution = exports.DockerFileContribution = exports.ImageFileContribution = exports.registerContainerCreationContributions = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const inversify_1 = require("@theia/core/shared/inversify");
|
|
6
|
+
const docker_container_service_1 = require("../docker-container-service");
|
|
7
|
+
const core_1 = require("@theia/core");
|
|
8
|
+
const fs = require("@theia/core/shared/fs-extra");
|
|
9
|
+
const remote_port_forwarding_provider_1 = require("@theia/remote/lib/electron-common/remote-port-forwarding-provider");
|
|
10
|
+
function registerContainerCreationContributions(bind) {
|
|
11
|
+
bind(docker_container_service_1.ContainerCreationContribution).to(ImageFileContribution).inSingletonScope();
|
|
12
|
+
bind(docker_container_service_1.ContainerCreationContribution).to(DockerFileContribution).inSingletonScope();
|
|
13
|
+
bind(docker_container_service_1.ContainerCreationContribution).to(ForwardPortsContribution).inSingletonScope();
|
|
14
|
+
bind(docker_container_service_1.ContainerCreationContribution).to(MountsContribution).inSingletonScope();
|
|
15
|
+
bind(docker_container_service_1.ContainerCreationContribution).to(RemoteUserContribution).inSingletonScope();
|
|
16
|
+
bind(docker_container_service_1.ContainerCreationContribution).to(PostCreateCommandContribution).inSingletonScope();
|
|
17
|
+
}
|
|
18
|
+
exports.registerContainerCreationContributions = registerContainerCreationContributions;
|
|
19
|
+
let ImageFileContribution = class ImageFileContribution {
|
|
20
|
+
async handleContainerCreation(createOptions, containerConfig, api, outputprovider) {
|
|
21
|
+
if (containerConfig.image) {
|
|
22
|
+
const platform = process.platform;
|
|
23
|
+
const arch = process.arch;
|
|
24
|
+
const options = platform === 'darwin' && arch === 'arm64' ? { platform: 'amd64' } : {};
|
|
25
|
+
await new Promise((res, rej) => api.pull(containerConfig.image, options, (err, stream) => {
|
|
26
|
+
if (err) {
|
|
27
|
+
rej(err);
|
|
28
|
+
}
|
|
29
|
+
else if (stream === undefined) {
|
|
30
|
+
rej('Stream is undefined');
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
api.modem.followProgress(stream, (error, output) => error ?
|
|
34
|
+
rej(error) :
|
|
35
|
+
res(), progress => outputprovider.onRemoteOutput(OutputHelper.parseProgress(progress)));
|
|
36
|
+
}
|
|
37
|
+
}));
|
|
38
|
+
createOptions.Image = containerConfig.image;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
exports.ImageFileContribution = ImageFileContribution;
|
|
43
|
+
exports.ImageFileContribution = ImageFileContribution = tslib_1.__decorate([
|
|
44
|
+
(0, inversify_1.injectable)()
|
|
45
|
+
], ImageFileContribution);
|
|
46
|
+
let DockerFileContribution = class DockerFileContribution {
|
|
47
|
+
async handleContainerCreation(createOptions, containerConfig, api, outputprovider) {
|
|
48
|
+
var _a, _b, _c, _d, _e;
|
|
49
|
+
// check if dockerfile container
|
|
50
|
+
if (containerConfig.dockerFile || ((_a = containerConfig.build) === null || _a === void 0 ? void 0 : _a.dockerfile)) {
|
|
51
|
+
const dockerfile = ((_b = containerConfig.dockerFile) !== null && _b !== void 0 ? _b : (_c = containerConfig.build) === null || _c === void 0 ? void 0 : _c.dockerfile);
|
|
52
|
+
const context = (_d = containerConfig.context) !== null && _d !== void 0 ? _d : new core_1.Path(containerConfig.location).dir.fsPath();
|
|
53
|
+
try {
|
|
54
|
+
// ensure dockerfile exists
|
|
55
|
+
await fs.lstat(new core_1.Path(context).join(dockerfile).fsPath());
|
|
56
|
+
const buildStream = await api.buildImage({
|
|
57
|
+
context,
|
|
58
|
+
src: [dockerfile],
|
|
59
|
+
}, {
|
|
60
|
+
buildargs: (_e = containerConfig.build) === null || _e === void 0 ? void 0 : _e.args
|
|
61
|
+
});
|
|
62
|
+
// TODO probably have some console windows showing the output of the build
|
|
63
|
+
const imageId = await new Promise((res, rej) => api.modem.followProgress(buildStream, (err, outputs) => {
|
|
64
|
+
var _a;
|
|
65
|
+
if (err) {
|
|
66
|
+
rej(err);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
for (let i = outputs.length - 1; i >= 0; i--) {
|
|
70
|
+
if ((_a = outputs[i].aux) === null || _a === void 0 ? void 0 : _a.ID) {
|
|
71
|
+
res(outputs[i].aux.ID);
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}, progress => outputprovider.onRemoteOutput(OutputHelper.parseProgress(progress))));
|
|
77
|
+
createOptions.Image = imageId;
|
|
78
|
+
}
|
|
79
|
+
catch (error) {
|
|
80
|
+
outputprovider.onRemoteOutput(`could not build dockerfile "${dockerfile}" reason: ${error.message}`);
|
|
81
|
+
throw error;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
exports.DockerFileContribution = DockerFileContribution;
|
|
87
|
+
exports.DockerFileContribution = DockerFileContribution = tslib_1.__decorate([
|
|
88
|
+
(0, inversify_1.injectable)()
|
|
89
|
+
], DockerFileContribution);
|
|
90
|
+
let ForwardPortsContribution = class ForwardPortsContribution {
|
|
91
|
+
async handlePostConnect(containerConfig, connection) {
|
|
92
|
+
if (!containerConfig.forwardPorts) {
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
for (const forward of containerConfig.forwardPorts) {
|
|
96
|
+
let port;
|
|
97
|
+
let address;
|
|
98
|
+
if (typeof forward === 'string') {
|
|
99
|
+
const parts = forward.split(':');
|
|
100
|
+
address = parts[0];
|
|
101
|
+
port = parseInt(parts[1]);
|
|
102
|
+
}
|
|
103
|
+
else {
|
|
104
|
+
port = forward;
|
|
105
|
+
}
|
|
106
|
+
this.portForwardingProvider.forwardPort(connection.localPort, { port, address });
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
};
|
|
110
|
+
exports.ForwardPortsContribution = ForwardPortsContribution;
|
|
111
|
+
tslib_1.__decorate([
|
|
112
|
+
(0, inversify_1.inject)(remote_port_forwarding_provider_1.RemotePortForwardingProvider),
|
|
113
|
+
tslib_1.__metadata("design:type", Object)
|
|
114
|
+
], ForwardPortsContribution.prototype, "portForwardingProvider", void 0);
|
|
115
|
+
exports.ForwardPortsContribution = ForwardPortsContribution = tslib_1.__decorate([
|
|
116
|
+
(0, inversify_1.injectable)()
|
|
117
|
+
], ForwardPortsContribution);
|
|
118
|
+
let MountsContribution = class MountsContribution {
|
|
119
|
+
async handleContainerCreation(createOptions, containerConfig, api) {
|
|
120
|
+
var _a, _b;
|
|
121
|
+
if (!containerConfig.mounts) {
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
createOptions.HostConfig.Mounts.push(...(_b = (_a = containerConfig === null || containerConfig === void 0 ? void 0 : containerConfig.mounts) === null || _a === void 0 ? void 0 : _a.map(mount => {
|
|
125
|
+
var _a;
|
|
126
|
+
return typeof mount === 'string' ?
|
|
127
|
+
this.parseMountString(mount) :
|
|
128
|
+
{ Source: mount.source, Target: mount.target, Type: (_a = mount.type) !== null && _a !== void 0 ? _a : 'bind' };
|
|
129
|
+
})) !== null && _b !== void 0 ? _b : []);
|
|
130
|
+
}
|
|
131
|
+
parseMountString(mount) {
|
|
132
|
+
var _a, _b, _c, _d;
|
|
133
|
+
const parts = mount.split(',');
|
|
134
|
+
return {
|
|
135
|
+
Source: (_a = parts.find(part => part.startsWith('source=') || part.startsWith('src='))) === null || _a === void 0 ? void 0 : _a.split('=')[1],
|
|
136
|
+
Target: (_b = parts.find(part => part.startsWith('target=') || part.startsWith('dst='))) === null || _b === void 0 ? void 0 : _b.split('=')[1],
|
|
137
|
+
Type: ((_d = (_c = parts.find(part => part.startsWith('type='))) === null || _c === void 0 ? void 0 : _c.split('=')[1]) !== null && _d !== void 0 ? _d : 'bind')
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
};
|
|
141
|
+
exports.MountsContribution = MountsContribution;
|
|
142
|
+
exports.MountsContribution = MountsContribution = tslib_1.__decorate([
|
|
143
|
+
(0, inversify_1.injectable)()
|
|
144
|
+
], MountsContribution);
|
|
145
|
+
let RemoteUserContribution = class RemoteUserContribution {
|
|
146
|
+
async handleContainerCreation(createOptions, containerConfig, api) {
|
|
147
|
+
if (containerConfig.remoteUser) {
|
|
148
|
+
createOptions.User = containerConfig.remoteUser;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
};
|
|
152
|
+
exports.RemoteUserContribution = RemoteUserContribution;
|
|
153
|
+
exports.RemoteUserContribution = RemoteUserContribution = tslib_1.__decorate([
|
|
154
|
+
(0, inversify_1.injectable)()
|
|
155
|
+
], RemoteUserContribution);
|
|
156
|
+
let PostCreateCommandContribution = class PostCreateCommandContribution {
|
|
157
|
+
async handlePostCreate(containerConfig, container, api, outputprovider) {
|
|
158
|
+
if (containerConfig.postCreateCommand) {
|
|
159
|
+
const commands = typeof containerConfig.postCreateCommand === 'object' && !(containerConfig.postCreateCommand instanceof Array) ?
|
|
160
|
+
Object.values(containerConfig.postCreateCommand) : [containerConfig.postCreateCommand];
|
|
161
|
+
for (const command of commands) {
|
|
162
|
+
try {
|
|
163
|
+
let exec;
|
|
164
|
+
if (command instanceof Array) {
|
|
165
|
+
exec = await container.exec({ Cmd: command, AttachStderr: true, AttachStdout: true });
|
|
166
|
+
}
|
|
167
|
+
else {
|
|
168
|
+
exec = await container.exec({ Cmd: ['sh', '-c', command], AttachStderr: true, AttachStdout: true });
|
|
169
|
+
}
|
|
170
|
+
const stream = await exec.start({ Tty: true });
|
|
171
|
+
stream.on('data', chunk => outputprovider.onRemoteOutput(chunk.toString()));
|
|
172
|
+
}
|
|
173
|
+
catch (error) {
|
|
174
|
+
outputprovider.onRemoteOutput('could not execute postCreateCommand ' + JSON.stringify(command) + ' reason:' + error.message);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
};
|
|
180
|
+
exports.PostCreateCommandContribution = PostCreateCommandContribution;
|
|
181
|
+
exports.PostCreateCommandContribution = PostCreateCommandContribution = tslib_1.__decorate([
|
|
182
|
+
(0, inversify_1.injectable)()
|
|
183
|
+
], PostCreateCommandContribution);
|
|
184
|
+
var OutputHelper;
|
|
185
|
+
(function (OutputHelper) {
|
|
186
|
+
function parseProgress(progress) {
|
|
187
|
+
var _a, _b, _c;
|
|
188
|
+
return (_c = (_b = (_a = progress.stream) !== null && _a !== void 0 ? _a : progress.progress) !== null && _b !== void 0 ? _b : progress.status) !== null && _c !== void 0 ? _c : '';
|
|
189
|
+
}
|
|
190
|
+
OutputHelper.parseProgress = parseProgress;
|
|
191
|
+
})(OutputHelper || (exports.OutputHelper = OutputHelper = {}));
|
|
192
|
+
//# sourceMappingURL=main-container-creation-contributions.js.map
|
package/lib/electron-node/devcontainer-contributions/main-container-creation-contributions.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main-container-creation-contributions.js","sourceRoot":"","sources":["../../../src/electron-node/devcontainer-contributions/main-container-creation-contributions.ts"],"names":[],"mappings":"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"}
|
package/lib/electron-node/devcontainer-contributions/profile-file-modification-contribution.d.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { DevContainerConfiguration } from '../devcontainer-file';
|
|
2
|
+
import { ContainerCreationContribution } from '../docker-container-service';
|
|
3
|
+
import * as Docker from 'dockerode';
|
|
4
|
+
import { ContainerOutputProvider } from '../../electron-common/container-output-provider';
|
|
5
|
+
/**
|
|
6
|
+
* this contribution changes the /etc/profile file so that it won't overwrite the PATH variable set by docker
|
|
7
|
+
*/
|
|
8
|
+
export declare class ProfileFileModificationContribution implements ContainerCreationContribution {
|
|
9
|
+
handlePostCreate(containerConfig: DevContainerConfiguration, container: Docker.Container, api: Docker, outputprovider: ContainerOutputProvider): Promise<void>;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=profile-file-modification-contribution.d.ts.map
|
package/lib/electron-node/devcontainer-contributions/profile-file-modification-contribution.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"profile-file-modification-contribution.d.ts","sourceRoot":"","sources":["../../../src/electron-node/devcontainer-contributions/profile-file-modification-contribution.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AACjE,OAAO,EAAE,6BAA6B,EAAE,MAAM,6BAA6B,CAAC;AAC5E,OAAO,KAAK,MAAM,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,uBAAuB,EAAE,MAAM,iDAAiD,CAAC;AAE1F;;GAEG;AACH,qBACa,mCAAoC,YAAW,6BAA6B;IAC/E,gBAAgB,CAAC,eAAe,EAAE,yBAAyB,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,EAAE,GAAG,EAAE,MAAM,EAAE,cAAc,EAAE,uBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC;CAOvK"}
|
package/lib/electron-node/devcontainer-contributions/profile-file-modification-contribution.js
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2024 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
|
+
exports.ProfileFileModificationContribution = void 0;
|
|
19
|
+
const tslib_1 = require("tslib");
|
|
20
|
+
const inversify_1 = require("@theia/core/shared/inversify");
|
|
21
|
+
/**
|
|
22
|
+
* this contribution changes the /etc/profile file so that it won't overwrite the PATH variable set by docker
|
|
23
|
+
*/
|
|
24
|
+
let ProfileFileModificationContribution = class ProfileFileModificationContribution {
|
|
25
|
+
async handlePostCreate(containerConfig, container, api, outputprovider) {
|
|
26
|
+
const stream = await (await container.exec({
|
|
27
|
+
Cmd: ['sh', '-c', 'sed -i \'s|PATH="\\([^"]*\\)"|PATH=${PATH:-"\\1"}|g\' /etc/profile'], User: 'root',
|
|
28
|
+
AttachStderr: true, AttachStdout: true
|
|
29
|
+
})).start({});
|
|
30
|
+
stream.on('data', data => outputprovider.onRemoteOutput(data.toString()));
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
exports.ProfileFileModificationContribution = ProfileFileModificationContribution;
|
|
34
|
+
exports.ProfileFileModificationContribution = ProfileFileModificationContribution = tslib_1.__decorate([
|
|
35
|
+
(0, inversify_1.injectable)()
|
|
36
|
+
], ProfileFileModificationContribution);
|
|
37
|
+
//# sourceMappingURL=profile-file-modification-contribution.js.map
|
package/lib/electron-node/devcontainer-contributions/profile-file-modification-contribution.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"profile-file-modification-contribution.js","sourceRoot":"","sources":["../../../src/electron-node/devcontainer-contributions/profile-file-modification-contribution.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,yCAAyC;AACzC,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;;;AAKhF,4DAA0D;AAG1D;;GAEG;AAEI,IAAM,mCAAmC,GAAzC,MAAM,mCAAmC;IAC5C,KAAK,CAAC,gBAAgB,CAAC,eAA0C,EAAE,SAA2B,EAAE,GAAW,EAAE,cAAuC;QAChJ,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,SAAS,CAAC,IAAI,CAAC;YACvC,GAAG,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,oEAAoE,CAAC,EAAE,IAAI,EAAE,MAAM;YACrG,YAAY,EAAE,IAAI,EAAE,YAAY,EAAE,IAAI;SACzC,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACd,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;IAC9E,CAAC;CACJ,CAAA;AARY,kFAAmC;8CAAnC,mCAAmC;IAD/C,IAAA,sBAAU,GAAE;GACA,mCAAmC,CAQ/C"}
|