@forge/cli 12.0.0-next.7 → 12.0.0
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/CHANGELOG.md +163 -0
- package/npm-shrinkwrap.json +1298 -1279
- package/out/analytics-client/analytics-client.d.ts +2 -3
- package/out/analytics-client/analytics-client.d.ts.map +1 -1
- package/out/analytics-client/analytics-client.js +2 -9
- package/out/analytics-client/analytics-client.js.map +1 -1
- package/out/bin/postinstall.js +1 -1
- package/out/bin/postinstall.js.map +1 -1
- package/out/command-line/controller/tunnel-controller.d.ts +3 -7
- package/out/command-line/controller/tunnel-controller.d.ts.map +1 -1
- package/out/command-line/controller/tunnel-controller.js +2 -22
- package/out/command-line/controller/tunnel-controller.js.map +1 -1
- package/out/command-line/dependency-injection.d.ts +1 -1
- package/out/command-line/dependency-injection.d.ts.map +1 -1
- package/out/command-line/dependency-injection.js +10 -12
- package/out/command-line/dependency-injection.js.map +1 -1
- package/out/command-line/register-log-commands.d.ts.map +1 -1
- package/out/command-line/register-log-commands.js +2 -1
- package/out/command-line/register-log-commands.js.map +1 -1
- package/out/command-line/register-version-commands.js +2 -2
- package/out/command-line/register-version-commands.js.map +1 -1
- package/out/command-line/version-info.js +1 -1
- package/out/command-line/version-info.js.map +1 -1
- package/out/command-line/view/tunnel-view.d.ts +2 -16
- package/out/command-line/view/tunnel-view.d.ts.map +1 -1
- package/out/command-line/view/tunnel-view.js +2 -90
- package/out/command-line/view/tunnel-view.js.map +1 -1
- package/out/deploy/deployer/deploy-monitor-graphql-client.d.ts.map +1 -1
- package/out/deploy/deployer/deploy-monitor-graphql-client.js +0 -4
- package/out/deploy/deployer/deploy-monitor-graphql-client.js.map +1 -1
- package/out/deploy/deployer/deployer.d.ts +0 -5
- package/out/deploy/deployer/deployer.d.ts.map +1 -1
- package/out/deploy/deployer/deployer.js +1 -33
- package/out/deploy/deployer/deployer.js.map +1 -1
- package/out/deploy/packager/archiver.d.ts +1 -0
- package/out/deploy/packager/archiver.d.ts.map +1 -1
- package/out/deploy/packager/runtime-bundler.d.ts +0 -3
- package/out/deploy/packager/runtime-bundler.d.ts.map +1 -1
- package/out/deploy/packager/runtime-bundler.js +5 -12
- package/out/deploy/packager/runtime-bundler.js.map +1 -1
- package/out/service/docker-service.d.ts +0 -4
- package/out/service/docker-service.d.ts.map +1 -1
- package/out/service/docker-service.js +0 -26
- package/out/service/docker-service.js.map +1 -1
- package/out/service/tunnel-analytics-service.d.ts +0 -4
- package/out/service/tunnel-analytics-service.d.ts.map +1 -1
- package/out/service/tunnel-analytics-service.js +0 -15
- package/out/service/tunnel-analytics-service.js.map +1 -1
- package/out/service/tunnel-service.d.ts +1 -36
- package/out/service/tunnel-service.d.ts.map +1 -1
- package/out/service/tunnel-service.js +1 -197
- package/out/service/tunnel-service.js.map +1 -1
- package/package.json +11 -10
- package/out/workers/tunnel-clean-up-worker.d.ts +0 -8
- package/out/workers/tunnel-clean-up-worker.d.ts.map +0 -1
- package/out/workers/tunnel-clean-up-worker.js +0 -32
- package/out/workers/tunnel-clean-up-worker.js.map +0 -1
|
@@ -1,33 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
|
-
const cross_spawn_1 = require("cross-spawn");
|
|
6
|
-
const os_1 = tslib_1.__importDefault(require("os"));
|
|
7
|
-
const path_1 = require("path");
|
|
8
|
-
const portfinder_1 = require("portfinder");
|
|
9
|
-
const semver_1 = require("semver");
|
|
3
|
+
exports.InProcessTunnelService = exports.InvalidDebugStartingPortNumber = exports.DebugArgumentNameMismatch = exports.FunctionHandlersMustBeDefinedInDebugMode = void 0;
|
|
10
4
|
const manifest_1 = require("@forge/manifest");
|
|
11
5
|
const cli_shared_1 = require("@forge/cli-shared");
|
|
12
|
-
const version_info_1 = require("../command-line/version-info");
|
|
13
|
-
const DISABLE_TTY = process.env.DISABLE_TTY === 'true';
|
|
14
|
-
exports.CONTAINER_NAME = `forge-tunnel-docker-${process.pid}`;
|
|
15
|
-
const cliDetails = (0, version_info_1.getCLIDetails)();
|
|
16
|
-
let versionTags;
|
|
17
|
-
if (cliDetails?.version !== undefined) {
|
|
18
|
-
if (process.env.FORGE_IN_LOCAL_E2E === 'true') {
|
|
19
|
-
versionTags = ['e2e'];
|
|
20
|
-
}
|
|
21
|
-
else {
|
|
22
|
-
versionTags = (0, semver_1.prerelease)(cliDetails.version) || ['latest'];
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
else {
|
|
26
|
-
versionTags = ['latest'];
|
|
27
|
-
}
|
|
28
|
-
exports.IMAGE_NAME = process.env.FORGE_DEV_DOCKER_TUNNEL
|
|
29
|
-
? 'local/forge-tunnel:test'
|
|
30
|
-
: `atlassian/forge-tunnel:${versionTags[0]}`;
|
|
31
6
|
class FunctionHandlersMustBeDefinedInDebugMode extends cli_shared_1.UserError {
|
|
32
7
|
constructor() {
|
|
33
8
|
super(cli_shared_1.Text.tunnel.functionHandlersMustBeDefined);
|
|
@@ -90,175 +65,4 @@ class InProcessTunnelService extends TunnelServiceBase {
|
|
|
90
65
|
}
|
|
91
66
|
}
|
|
92
67
|
exports.InProcessTunnelService = InProcessTunnelService;
|
|
93
|
-
class SandboxTunnelServiceBase extends TunnelServiceBase {
|
|
94
|
-
configFilePortFindingService;
|
|
95
|
-
cachedConfigService;
|
|
96
|
-
constructor(configFilePortFindingService, cachedConfigService) {
|
|
97
|
-
super(cachedConfigService);
|
|
98
|
-
this.configFilePortFindingService = configFilePortFindingService;
|
|
99
|
-
this.cachedConfigService = cachedConfigService;
|
|
100
|
-
}
|
|
101
|
-
async getTunnelProcessEnvironment(tunnelOptions, debugEnabled, { email, token }, port, cspReporterPort, resourcePorts) {
|
|
102
|
-
const graphqlGateway = (0, cli_shared_1.getGraphqlGateway)();
|
|
103
|
-
return [
|
|
104
|
-
{ key: 'APP_FOLDER', value: '/app' },
|
|
105
|
-
{ key: 'FORGE_EMAIL', value: email },
|
|
106
|
-
{ key: 'FORGE_API_TOKEN', value: token },
|
|
107
|
-
{ key: 'ENVIRONMENT_KEY', value: tunnelOptions.environment ?? 'default' },
|
|
108
|
-
{ key: 'TUNNEL_INSPECTOR_ENABLED', value: (!!tunnelOptions.debug).toString() },
|
|
109
|
-
{ key: 'FORGE_GRAPHQL_GATEWAY', value: graphqlGateway },
|
|
110
|
-
{ key: 'VERBOSE_MODE', value: `${debugEnabled}` },
|
|
111
|
-
{ key: 'CLI_DETAILS', value: JSON.stringify(cliDetails) },
|
|
112
|
-
...this.getInspectorPortEnvironment(port),
|
|
113
|
-
...this.getCspReporterPortEnvironment(cspReporterPort),
|
|
114
|
-
...this.getResourcePortEnvironment(resourcePorts),
|
|
115
|
-
...this.getUserEnvironmentVariables()
|
|
116
|
-
];
|
|
117
|
-
}
|
|
118
|
-
getInspectorPortEnvironment(port) {
|
|
119
|
-
return [{ key: 'TUNNEL_INSPECTOR_PORT', value: port.toString() }];
|
|
120
|
-
}
|
|
121
|
-
getCspReporterPortEnvironment(cspReporterPort) {
|
|
122
|
-
if (cspReporterPort) {
|
|
123
|
-
return [{ key: 'CSP_REPORTER_PORT', value: cspReporterPort.toString() }];
|
|
124
|
-
}
|
|
125
|
-
return [];
|
|
126
|
-
}
|
|
127
|
-
getResourcePortEnvironment(resourcePorts) {
|
|
128
|
-
return [{ key: `RESOURCE_PORT_MAP`, value: JSON.stringify(resourcePorts) }];
|
|
129
|
-
}
|
|
130
|
-
getUserEnvironmentVariables() {
|
|
131
|
-
const vars = [];
|
|
132
|
-
Object.keys(process.env)
|
|
133
|
-
.filter((variable) => variable.startsWith('FORGE_USER_VAR_'))
|
|
134
|
-
.forEach((name) => {
|
|
135
|
-
vars.push({ key: name, value: process.env[name] ?? 'undefined' });
|
|
136
|
-
});
|
|
137
|
-
return vars;
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
class LocalTunnelService extends SandboxTunnelServiceBase {
|
|
141
|
-
async run(tunnelOptions, creds, debugEnabled, onError) {
|
|
142
|
-
const port = await (0, portfinder_1.getPortPromise)();
|
|
143
|
-
const resourcePorts = await this.configFilePortFindingService.findPorts();
|
|
144
|
-
const cspReporterPort = await this.configFilePortFindingService.findPortAfter(Object.values(resourcePorts));
|
|
145
|
-
const environment = await this.getTunnelProcessEnvironment(tunnelOptions, debugEnabled, creds, port, cspReporterPort, resourcePorts);
|
|
146
|
-
const env = this.formatEnvForLocalTunnel(environment);
|
|
147
|
-
const process = (0, cross_spawn_1.spawn)('forge-tunnel', [], {
|
|
148
|
-
stdio: 'inherit',
|
|
149
|
-
env: {
|
|
150
|
-
...env,
|
|
151
|
-
FORGE_DEV_TUNNEL: 'true'
|
|
152
|
-
}
|
|
153
|
-
});
|
|
154
|
-
if (onError) {
|
|
155
|
-
process.on('error', onError);
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
formatEnvForLocalTunnel(environment) {
|
|
159
|
-
return Object.assign({}, {
|
|
160
|
-
PATH: process.env.PATH || '',
|
|
161
|
-
FORCE_COLOR: '1'
|
|
162
|
-
}, ...environment.map(({ key, value }) => ({ [key]: value })));
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
exports.LocalTunnelService = LocalTunnelService;
|
|
166
|
-
class DockerTunnelService extends SandboxTunnelServiceBase {
|
|
167
|
-
dockerService;
|
|
168
|
-
analyticsService;
|
|
169
|
-
constructor(configFilePortFindingService, cachedConfigService, dockerService, analyticsService) {
|
|
170
|
-
super(configFilePortFindingService, cachedConfigService);
|
|
171
|
-
this.dockerService = dockerService;
|
|
172
|
-
this.analyticsService = analyticsService;
|
|
173
|
-
}
|
|
174
|
-
async run(tunnelOptions, creds, debugEnabled) {
|
|
175
|
-
await this.validateDockerVersion(creds, debugEnabled);
|
|
176
|
-
const startPort = 8000 + Math.round(Math.random() * 100);
|
|
177
|
-
const port = await (0, portfinder_1.getPortPromise)({ port: startPort });
|
|
178
|
-
const dockerOptions = await this.getCommonOptions();
|
|
179
|
-
const resourcePorts = await this.configFilePortFindingService.findPorts(port);
|
|
180
|
-
const cspReporterPort = await this.configFilePortFindingService.findPortAfter(Object.values(resourcePorts));
|
|
181
|
-
const environment = await this.getTunnelProcessEnvironment(tunnelOptions, debugEnabled, creds, port, cspReporterPort, resourcePorts);
|
|
182
|
-
const portOptions = this.getDockerPortOptions(port, resourcePorts, cspReporterPort);
|
|
183
|
-
const interactiveOptions = this.getInteractiveOptions();
|
|
184
|
-
const volumeOptions = await this.getVolumeOptions();
|
|
185
|
-
const env = this.formatEnvForDocker(environment);
|
|
186
|
-
const docker = this.dockerService.runContainer([
|
|
187
|
-
...interactiveOptions,
|
|
188
|
-
...volumeOptions,
|
|
189
|
-
...portOptions,
|
|
190
|
-
...dockerOptions,
|
|
191
|
-
...env,
|
|
192
|
-
exports.IMAGE_NAME
|
|
193
|
-
]);
|
|
194
|
-
docker.on('exit', () => this.analyticsService.reportTunnelClosed(creds));
|
|
195
|
-
docker.stderr?.on('data', async (error) => {
|
|
196
|
-
const errorMessage = error;
|
|
197
|
-
let errorJson;
|
|
198
|
-
try {
|
|
199
|
-
errorJson = JSON.parse(errorMessage);
|
|
200
|
-
}
|
|
201
|
-
catch (e) {
|
|
202
|
-
}
|
|
203
|
-
if (errorJson && errorJson.__tunnel_error__) {
|
|
204
|
-
const tunnelErrorDetails = errorJson;
|
|
205
|
-
await this.analyticsService.reportTunnelFailure(creds, tunnelErrorDetails.name, tunnelErrorDetails.attributes);
|
|
206
|
-
}
|
|
207
|
-
else {
|
|
208
|
-
process.stderr?.write(errorMessage);
|
|
209
|
-
}
|
|
210
|
-
});
|
|
211
|
-
this.dockerService.startCleanupWorker([docker.pid], exports.CONTAINER_NAME);
|
|
212
|
-
}
|
|
213
|
-
async bootstrapDocker() {
|
|
214
|
-
await this.dockerService.removeContainer(exports.CONTAINER_NAME);
|
|
215
|
-
if (!process.env.FORGE_DEV_DOCKER_TUNNEL) {
|
|
216
|
-
return this.dockerService.downloadImage(exports.IMAGE_NAME);
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
async validateDockerVersion(creds, debugEnabled) {
|
|
220
|
-
const version = await this.dockerService.getDockerVersion(debugEnabled);
|
|
221
|
-
this.analyticsService.reportDockerVersion(creds, version);
|
|
222
|
-
}
|
|
223
|
-
getDockerPortOptions(port, resourcePorts, cspReporterPort) {
|
|
224
|
-
const resourcePortOptions = (0, cli_shared_1.flatMap)(Object.values(resourcePorts), (resourcePort) => [
|
|
225
|
-
'-p',
|
|
226
|
-
`${resourcePort}:${resourcePort}`
|
|
227
|
-
]);
|
|
228
|
-
const cspReporterPortOption = [];
|
|
229
|
-
if (cspReporterPort) {
|
|
230
|
-
cspReporterPortOption.push('-p', `${cspReporterPort}:${cspReporterPort}`);
|
|
231
|
-
}
|
|
232
|
-
const addHostOption = os_1.default.platform() === 'linux' ? ['--add-host', 'host.docker.internal:host-gateway'] : [];
|
|
233
|
-
return [`-p`, `${port}:${port}`, ...resourcePortOptions, ...addHostOption, ...cspReporterPortOption];
|
|
234
|
-
}
|
|
235
|
-
formatEnvForDocker(environment) {
|
|
236
|
-
return (0, cli_shared_1.flatMap)(environment, ({ key, value }) => ['--env', `${key}=${value}`]);
|
|
237
|
-
}
|
|
238
|
-
getInteractiveOptions() {
|
|
239
|
-
if (DISABLE_TTY) {
|
|
240
|
-
return [`-i`];
|
|
241
|
-
}
|
|
242
|
-
return [`-it`];
|
|
243
|
-
}
|
|
244
|
-
async getVolumeOptions() {
|
|
245
|
-
const options = [`-v=${process.cwd()}:/app:cached`];
|
|
246
|
-
if (process.env.FORGE_DEV_DOCKER_TUNNEL) {
|
|
247
|
-
const monorepoRoot = (0, path_1.join)(__dirname, '../../../..');
|
|
248
|
-
options.push(`-v=${monorepoRoot}:/monorepo:cached`);
|
|
249
|
-
options.push(`-v=${monorepoRoot}/node_modules/cloudflared/docker-bin:/monorepo/node_modules/cloudflared/bin`);
|
|
250
|
-
}
|
|
251
|
-
if (process.env.FORGE_TUNNEL_MOUNT_DIRECTORIES) {
|
|
252
|
-
const mounts = process.env.FORGE_TUNNEL_MOUNT_DIRECTORIES.split(',');
|
|
253
|
-
mounts.forEach((mount) => {
|
|
254
|
-
options.push(`-v=${mount}:cached`);
|
|
255
|
-
});
|
|
256
|
-
}
|
|
257
|
-
return options;
|
|
258
|
-
}
|
|
259
|
-
async getCommonOptions() {
|
|
260
|
-
return ['--rm', `--name`, exports.CONTAINER_NAME, '--platform', 'linux/amd64'];
|
|
261
|
-
}
|
|
262
|
-
}
|
|
263
|
-
exports.DockerTunnelService = DockerTunnelService;
|
|
264
68
|
//# sourceMappingURL=tunnel-service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tunnel-service.js","sourceRoot":"","sources":["../../src/service/tunnel-service.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"tunnel-service.js","sourceRoot":"","sources":["../../src/service/tunnel-service.ts"],"names":[],"mappings":";;;AAAA,8CAAgD;AAEhD,kDAQ2B;AAgB3B,MAAa,wCAAyC,SAAQ,sBAAS;IACrE;QACE,KAAK,CAAC,iBAAI,CAAC,MAAM,CAAC,6BAA6B,CAAC,CAAC;IACnD,CAAC;CACF;AAJD,4FAIC;AAED,MAAa,yBAA0B,SAAQ,sBAAS;IACtD,YAAY,eAAuB;QACjC,KAAK,CAAC,iBAAI,CAAC,MAAM,CAAC,yBAAyB,CAAC,eAAe,CAAC,CAAC,CAAC;IAChE,CAAC;CACF;AAJD,8DAIC;AAED,MAAa,8BAA+B,SAAQ,sBAAS;IAC3D,YAAY,IAAY;QACtB,KAAK,CAAC,iBAAI,CAAC,MAAM,CAAC,8BAA8B,CAAC,IAAI,CAAC,CAAC,CAAC;IAC1D,CAAC;CACF;AAJD,wEAIC;AAED,MAAe,iBAAiB;IACC;IAA/B,YAA+B,mBAAwC;QAAxC,wBAAmB,GAAnB,mBAAmB,CAAqB;IAAG,CAAC;CAQ5E;AAaD,MAAa,sBAAuB,SAAQ,iBAAiB;IAExC;IACA;IACA;IACA;IAEA;IANnB,YACmB,EAAM,EACN,kBAAsC,EACtC,gBAAkC,EAClC,4BAA0D,EAC3E,mBAAwC,EACvB,gBAAwC;QAEzD,KAAK,CAAC,mBAAmB,CAAC,CAAC;QAPV,OAAE,GAAF,EAAE,CAAI;QACN,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,iCAA4B,GAA5B,4BAA4B,CAA8B;QAE1D,qBAAgB,GAAhB,gBAAgB,CAAwB;IAG3D,CAAC;IAEM,KAAK,CAAC,GAAG,CACd,aAA4B,EAC5B,KAAsC,EACtC,YAAqB,EACrB,OAAuC;QAEvC,IAAI;YACF,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,4BAA4B,CAAC,SAAS,EAAE,CAAC;YAE5E,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC;gBACnD,cAAc,EAAE,aAAa,CAAC,WAAW,IAAI,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,SAAS;gBACrF,eAAe;gBACf,IAAI,EAAE,WAAW;aAClB,CAAC,CAAC;YAEH,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;YAC5E,MAAM,mBAAmB,GAAG,IAAI,CAAC,gBAAgB,CAAC,6BAA6B,CAAC,wBAAa,CAAC,CAAC;YAC/F,MAAM,IAAI,CAAC,gBAAgB,CAAC,mBAAmB,CAAC,MAAM,CAAC,YAAY,EAAE,OAAO,EAAE,mBAAmB,CAAC,CAAC;SACpG;QAAC,OAAO,CAAC,EAAE;YACV,MAAM,IAAI,CAAC,gBAAgB,CAAC,mBAAmB,CAAC,KAAK,EAAE,CAAC,CAAC,WAAW,CAAC,IAAI,EAAE,IAAA,+BAAkB,EAAC,CAAC,CAAC,CAAC,CAAC;YAClG,IAAI,OAAO,EAAE;gBACX,MAAM,OAAO,CAAC,CAAC,CAAC,CAAC;aAClB;iBAAM;gBACL,MAAM,IAAA,wBAAW,EAAC,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;aAC/B;SACF;IACH,CAAC;CACF;AAvCD,wDAuCC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@forge/cli",
|
|
3
|
-
"version": "12.0.0
|
|
3
|
+
"version": "12.0.0",
|
|
4
4
|
"description": "A command line interface for managing Atlassian-hosted apps",
|
|
5
5
|
"author": "Atlassian",
|
|
6
6
|
"license": "SEE LICENSE IN LICENSE.txt",
|
|
@@ -18,13 +18,13 @@
|
|
|
18
18
|
"postinstall": "node -e \"fs.existsSync('./out/bin/postinstall.js') && require('./out/bin/postinstall.js')\""
|
|
19
19
|
},
|
|
20
20
|
"dependencies": {
|
|
21
|
-
"@forge/bundler": "
|
|
22
|
-
"@forge/cli-shared": "
|
|
23
|
-
"@forge/egress": "
|
|
24
|
-
"@forge/lint": "5.9.0
|
|
25
|
-
"@forge/manifest": "
|
|
26
|
-
"@forge/runtime": "
|
|
27
|
-
"@forge/tunnel": "
|
|
21
|
+
"@forge/bundler": "6.0.0",
|
|
22
|
+
"@forge/cli-shared": "8.0.0",
|
|
23
|
+
"@forge/egress": "2.0.0",
|
|
24
|
+
"@forge/lint": "5.9.0",
|
|
25
|
+
"@forge/manifest": "10.0.0",
|
|
26
|
+
"@forge/runtime": "6.0.0",
|
|
27
|
+
"@forge/tunnel": "6.0.0",
|
|
28
28
|
"@forge/util": "1.4.9",
|
|
29
29
|
"@sentry/node": "7.106.0",
|
|
30
30
|
"@forge/i18n": "0.0.6",
|
|
@@ -70,13 +70,14 @@
|
|
|
70
70
|
"@types/hidefile": "^3.0.3",
|
|
71
71
|
"@types/inquirer": "^8.2.10",
|
|
72
72
|
"@types/jest": "^29.5.12",
|
|
73
|
-
"@types/node": "
|
|
73
|
+
"@types/node": "20.19.0",
|
|
74
74
|
"@types/node-fetch": "^2.6.11",
|
|
75
75
|
"@types/omelette": "^0.4.4",
|
|
76
76
|
"@types/semver": "^7.5.8",
|
|
77
77
|
"@types/tmp": "^0.2.6",
|
|
78
78
|
"@types/uuid": "^9.0.8",
|
|
79
79
|
"@types/jws": "^3.2.10",
|
|
80
|
+
"chokidar": "^3.6.0",
|
|
80
81
|
"jws": "^4.0.0",
|
|
81
82
|
"jest": "^29.7.0",
|
|
82
83
|
"jest-fixtures": "^0.6.0",
|
|
@@ -87,7 +88,7 @@
|
|
|
87
88
|
"type-fest": "4.10.2"
|
|
88
89
|
},
|
|
89
90
|
"engines": {
|
|
90
|
-
"node": ">=
|
|
91
|
+
"node": ">=20.0.0"
|
|
91
92
|
},
|
|
92
93
|
"publishConfig": {
|
|
93
94
|
"registry": "https://packages.atlassian.com/api/npm/npm-public/"
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"tunnel-clean-up-worker.d.ts","sourceRoot":"","sources":["../../src/workers/tunnel-clean-up-worker.ts"],"names":[],"mappings":"AAGA,oBAAY,oBAAoB,GAAG;IACjC,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,UAAU,EAAE,MAAM,EAAE,CAAC;CACtB,CAAC;AAEF,qBAAa,mBAAmB;IACvB,MAAM,IAAI,IAAI;CAwBtB"}
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.TunnelCleanUpWorker = void 0;
|
|
4
|
-
const os_1 = require("os");
|
|
5
|
-
const cross_spawn_1 = require("cross-spawn");
|
|
6
|
-
class TunnelCleanUpWorker {
|
|
7
|
-
doWork() {
|
|
8
|
-
let pids;
|
|
9
|
-
let containers;
|
|
10
|
-
const messageHandler = ({ pids: passedPids, containers: passedContainers }) => {
|
|
11
|
-
pids = passedPids;
|
|
12
|
-
containers = passedContainers;
|
|
13
|
-
};
|
|
14
|
-
const disconnectHandler = ({ pids, containers }) => {
|
|
15
|
-
pids.forEach((pid) => {
|
|
16
|
-
process.kill(pid, os_1.constants.signals.SIGINT);
|
|
17
|
-
});
|
|
18
|
-
(0, cross_spawn_1.spawn)('docker', ['rm', '-f', ...containers]);
|
|
19
|
-
process.exit(0);
|
|
20
|
-
};
|
|
21
|
-
process.on('message', messageHandler);
|
|
22
|
-
process.on('disconnect', () => {
|
|
23
|
-
disconnectHandler({ pids, containers });
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
exports.TunnelCleanUpWorker = TunnelCleanUpWorker;
|
|
28
|
-
if (require.main === module) {
|
|
29
|
-
const worker = new TunnelCleanUpWorker();
|
|
30
|
-
worker.doWork();
|
|
31
|
-
}
|
|
32
|
-
//# sourceMappingURL=tunnel-clean-up-worker.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"tunnel-clean-up-worker.js","sourceRoot":"","sources":["../../src/workers/tunnel-clean-up-worker.ts"],"names":[],"mappings":";;;AAAA,2BAA+B;AAC/B,6CAAoC;AAOpC,MAAa,mBAAmB;IACvB,MAAM;QAEX,IAAI,IAAc,CAAC;QACnB,IAAI,UAAoB,CAAC;QAEzB,MAAM,cAAc,GAAG,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,UAAU,EAAE,gBAAgB,EAAwB,EAAQ,EAAE;YACxG,IAAI,GAAG,UAAU,CAAC;YAClB,UAAU,GAAG,gBAAgB,CAAC;QAChC,CAAC,CAAC;QAEF,MAAM,iBAAiB,GAAG,CAAC,EAAE,IAAI,EAAE,UAAU,EAAwB,EAAQ,EAAE;YAC7E,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;gBACnB,OAAO,CAAC,IAAI,CAAC,GAAG,EAAE,cAAS,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;YAC9C,CAAC,CAAC,CAAC;YAEH,IAAA,mBAAK,EAAC,QAAQ,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,UAAU,CAAC,CAAC,CAAC;YAC7C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC,CAAC;QAEF,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,cAAc,CAAC,CAAC;QACtC,OAAO,CAAC,EAAE,CAAC,YAAY,EAAE,GAAG,EAAE;YAC5B,iBAAiB,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AAzBD,kDAyBC;AAED,IAAI,OAAO,CAAC,IAAI,KAAK,MAAM,EAAE;IAE3B,MAAM,MAAM,GAAG,IAAI,mBAAmB,EAAE,CAAC;IACzC,MAAM,CAAC,MAAM,EAAE,CAAC;CACjB"}
|