poe-code 2.0.20 → 2.0.22
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 +18 -39
- package/dist/bin/poe-claude.js +16 -0
- package/dist/bin/poe-codex.js +16 -0
- package/dist/bin/poe-opencode.js +16 -0
- package/dist/cli/binary-aliases.d.ts +7 -0
- package/dist/cli/binary-aliases.js +26 -0
- package/dist/cli/binary-aliases.js.map +1 -0
- package/dist/cli/command-runner.js +7 -1
- package/dist/cli/command-runner.js.map +1 -1
- package/dist/cli/commands/configure-payload.d.ts +13 -0
- package/dist/cli/commands/configure-payload.js +33 -0
- package/dist/cli/commands/configure-payload.js.map +1 -0
- package/dist/cli/commands/configure.js +16 -107
- package/dist/cli/commands/configure.js.map +1 -1
- package/dist/cli/commands/doctor.js +8 -1
- package/dist/cli/commands/doctor.js.map +1 -1
- package/dist/cli/commands/ensure-isolated-config.d.ts +11 -0
- package/dist/cli/commands/ensure-isolated-config.js +48 -0
- package/dist/cli/commands/ensure-isolated-config.js.map +1 -0
- package/dist/cli/commands/remove.js +20 -1
- package/dist/cli/commands/remove.js.map +1 -1
- package/dist/cli/commands/shared.d.ts +12 -1
- package/dist/cli/commands/shared.js +26 -6
- package/dist/cli/commands/shared.js.map +1 -1
- package/dist/cli/commands/test.d.ts +4 -1
- package/dist/cli/commands/test.js +37 -6
- package/dist/cli/commands/test.js.map +1 -1
- package/dist/cli/commands/wrap.d.ts +3 -0
- package/dist/cli/commands/wrap.js +54 -0
- package/dist/cli/commands/wrap.js.map +1 -0
- package/dist/cli/container.js +9 -2
- package/dist/cli/container.js.map +1 -1
- package/dist/cli/context.d.ts +5 -1
- package/dist/cli/context.js +12 -0
- package/dist/cli/context.js.map +1 -1
- package/dist/cli/isolated-env-runner.d.ts +10 -0
- package/dist/cli/isolated-env-runner.js +44 -0
- package/dist/cli/isolated-env-runner.js.map +1 -0
- package/dist/cli/isolated-env.d.ts +22 -0
- package/dist/cli/isolated-env.js +128 -0
- package/dist/cli/isolated-env.js.map +1 -0
- package/dist/cli/poe-code-command-runner.d.ts +6 -0
- package/dist/cli/poe-code-command-runner.js +54 -0
- package/dist/cli/poe-code-command-runner.js.map +1 -0
- package/dist/cli/program.js +4 -1
- package/dist/cli/program.js.map +1 -1
- package/dist/cli/service-registry.d.ts +30 -11
- package/dist/cli/service-registry.js.map +1 -1
- package/dist/providers/claude-code.d.ts +2 -2
- package/dist/providers/claude-code.js +59 -21
- package/dist/providers/claude-code.js.map +1 -1
- package/dist/providers/codex.d.ts +1 -1
- package/dist/providers/codex.js +21 -8
- package/dist/providers/codex.js.map +1 -1
- package/dist/providers/create-provider.d.ts +7 -8
- package/dist/providers/create-provider.js +2 -3
- package/dist/providers/create-provider.js.map +1 -1
- package/dist/providers/kimi.d.ts +2 -2
- package/dist/providers/kimi.js +7 -5
- package/dist/providers/kimi.js.map +1 -1
- package/dist/providers/opencode.d.ts +1 -1
- package/dist/providers/opencode.js +23 -8
- package/dist/providers/opencode.js.map +1 -1
- package/dist/providers/provider-helpers.js +12 -1
- package/dist/providers/provider-helpers.js.map +1 -1
- package/dist/providers/spawn-options.d.ts +2 -2
- package/dist/providers/versioned-provider.d.ts +2 -2
- package/dist/services/mutation-events.js +1 -1
- package/dist/services/mutation-events.js.map +1 -1
- package/dist/services/service-manifest.d.ts +65 -16
- package/dist/services/service-manifest.js +163 -19
- package/dist/services/service-manifest.js.map +1 -1
- package/dist/templates/claude-code/anthropic_key.sh.hbs +1 -1
- package/dist/utils/command-checks.d.ts +1 -0
- package/dist/utils/command-checks.js.map +1 -1
- package/package.json +6 -3
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
import type { Command } from "commander";
|
|
2
2
|
import type { CliContainer } from "../container.js";
|
|
3
|
-
import type { ProviderService, ProviderContext } from "../service-registry.js";
|
|
3
|
+
import type { ProviderService, ProviderContext, ProviderIsolatedEnv } from "../service-registry.js";
|
|
4
4
|
import { type CommandContext } from "../context.js";
|
|
5
5
|
import type { ScopedLogger } from "../logger.js";
|
|
6
|
+
import type { ServiceMutationObservers } from "../../services/service-manifest.js";
|
|
6
7
|
export interface CommandFlags {
|
|
7
8
|
dryRun: boolean;
|
|
8
9
|
assumeYes: boolean;
|
|
10
|
+
verbose: boolean;
|
|
9
11
|
}
|
|
10
12
|
export interface ExecutionResources {
|
|
11
13
|
logger: ScopedLogger;
|
|
@@ -21,5 +23,14 @@ export interface ProviderResolution {
|
|
|
21
23
|
export interface ResolveProviderOptions {
|
|
22
24
|
useResolver?: boolean;
|
|
23
25
|
}
|
|
26
|
+
export declare function listIsolatedServiceIds(container: CliContainer): string[];
|
|
24
27
|
export declare function resolveProviderHandler(adapter: ProviderService, context: ProviderContext, options?: ResolveProviderOptions): Promise<ProviderResolution>;
|
|
25
28
|
export declare function resolveServiceAdapter(container: CliContainer, service: string): ProviderService;
|
|
29
|
+
export declare function applyIsolatedConfiguration(input: {
|
|
30
|
+
resolution: ProviderResolution;
|
|
31
|
+
providerContext: ProviderContext;
|
|
32
|
+
payload: unknown;
|
|
33
|
+
isolated: ProviderIsolatedEnv;
|
|
34
|
+
providerName: string;
|
|
35
|
+
observers?: ServiceMutationObservers;
|
|
36
|
+
}): Promise<void>;
|
|
@@ -1,15 +1,17 @@
|
|
|
1
1
|
import { createLoggingCommandRunner } from "../context.js";
|
|
2
|
+
import { resolveIsolatedTargetDirectory } from "../isolated-env.js";
|
|
2
3
|
export function resolveCommandFlags(program) {
|
|
3
4
|
const opts = program.optsWithGlobals();
|
|
4
5
|
return {
|
|
5
6
|
dryRun: Boolean(opts.dryRun),
|
|
6
|
-
assumeYes: Boolean(opts.yes)
|
|
7
|
+
assumeYes: Boolean(opts.yes),
|
|
8
|
+
verbose: Boolean(opts.verbose)
|
|
7
9
|
};
|
|
8
10
|
}
|
|
9
11
|
export function createExecutionResources(container, flags, scope) {
|
|
10
12
|
const baseLogger = container.loggerFactory.create({
|
|
11
13
|
dryRun: flags.dryRun,
|
|
12
|
-
verbose:
|
|
14
|
+
verbose: flags.verbose,
|
|
13
15
|
scope
|
|
14
16
|
});
|
|
15
17
|
const runner = createLoggingCommandRunner(container.commandRunner, baseLogger);
|
|
@@ -24,13 +26,9 @@ export function createExecutionResources(container, flags, scope) {
|
|
|
24
26
|
};
|
|
25
27
|
}
|
|
26
28
|
export function buildProviderContext(container, adapter, resources) {
|
|
27
|
-
const paths = adapter.resolvePaths
|
|
28
|
-
? adapter.resolvePaths(container.env)
|
|
29
|
-
: {};
|
|
30
29
|
const runCheck = createCheckRunner(resources);
|
|
31
30
|
return {
|
|
32
31
|
env: container.env,
|
|
33
|
-
paths,
|
|
34
32
|
command: resources.context,
|
|
35
33
|
logger: resources.logger,
|
|
36
34
|
runCheck
|
|
@@ -45,6 +43,12 @@ function createCheckRunner(resources) {
|
|
|
45
43
|
});
|
|
46
44
|
};
|
|
47
45
|
}
|
|
46
|
+
export function listIsolatedServiceIds(container) {
|
|
47
|
+
return container.registry
|
|
48
|
+
.list()
|
|
49
|
+
.filter((provider) => Boolean(provider.isolatedEnv))
|
|
50
|
+
.map((provider) => provider.name);
|
|
51
|
+
}
|
|
48
52
|
export async function resolveProviderHandler(adapter, context, options = {}) {
|
|
49
53
|
const shouldResolve = options.useResolver ?? true;
|
|
50
54
|
if (shouldResolve && adapter.resolveVersion) {
|
|
@@ -59,4 +63,20 @@ export function resolveServiceAdapter(container, service) {
|
|
|
59
63
|
}
|
|
60
64
|
return adapter;
|
|
61
65
|
}
|
|
66
|
+
export async function applyIsolatedConfiguration(input) {
|
|
67
|
+
await input.resolution.adapter.configure({
|
|
68
|
+
fs: input.providerContext.command.fs,
|
|
69
|
+
env: input.providerContext.env,
|
|
70
|
+
command: input.providerContext.command,
|
|
71
|
+
options: input.payload,
|
|
72
|
+
pathMapper: {
|
|
73
|
+
mapTargetDirectory: ({ targetDirectory }) => resolveIsolatedTargetDirectory({
|
|
74
|
+
targetDirectory,
|
|
75
|
+
isolated: input.isolated,
|
|
76
|
+
env: input.providerContext.env,
|
|
77
|
+
providerName: input.providerName
|
|
78
|
+
})
|
|
79
|
+
}
|
|
80
|
+
}, input.observers ? { observers: input.observers } : undefined);
|
|
81
|
+
}
|
|
62
82
|
//# sourceMappingURL=shared.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shared.js","sourceRoot":"","sources":["../../../src/cli/commands/shared.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"shared.js","sourceRoot":"","sources":["../../../src/cli/commands/shared.ts"],"names":[],"mappings":"AAOA,OAAO,EACL,0BAA0B,EAE3B,MAAM,eAAe,CAAC;AAIvB,OAAO,EAAE,8BAA8B,EAAE,MAAM,oBAAoB,CAAC;AAapE,MAAM,UAAU,mBAAmB,CAAC,OAAgB;IAClD,MAAM,IAAI,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;IACvC,OAAO;QACL,MAAM,EAAE,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC;QAC5B,SAAS,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC;QAC5B,OAAO,EAAE,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC;KAC/B,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,wBAAwB,CACtC,SAAuB,EACvB,KAAmB,EACnB,KAAa;IAEb,MAAM,UAAU,GAAG,SAAS,CAAC,aAAa,CAAC,MAAM,CAAC;QAChD,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,KAAK;KACN,CAAC,CAAC;IACH,MAAM,MAAM,GAAG,0BAA0B,CAAC,SAAS,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;IAC/E,MAAM,OAAO,GAAG,SAAS,CAAC,cAAc,CAAC,MAAM,CAAC;QAC9C,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,MAAM,EAAE,UAAU;QAClB,MAAM;KACP,CAAC,CAAC;IAEH,OAAO;QACL,MAAM,EAAE,UAAU;QAClB,OAAO;KACR,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,oBAAoB,CAClC,SAAuB,EACvB,OAAwB,EACxB,SAA6B;IAE7B,MAAM,QAAQ,GAAG,iBAAiB,CAAC,SAAS,CAAC,CAAC;IAC9C,OAAO;QACL,GAAG,EAAE,SAAS,CAAC,GAAG;QAClB,OAAO,EAAE,SAAS,CAAC,OAAO;QAC1B,MAAM,EAAE,SAAS,CAAC,MAAM;QACxB,QAAQ;KACT,CAAC;AACJ,CAAC;AAED,SAAS,iBAAiB,CACxB,SAA6B;IAE7B,OAAO,KAAK,EAAE,KAAK,EAAE,EAAE;QACrB,MAAM,KAAK,CAAC,GAAG,CAAC;YACd,QAAQ,EAAE,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM;YACzC,UAAU,EAAE,SAAS,CAAC,OAAO,CAAC,UAAU;YACxC,SAAS,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC;SACzD,CAAC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC;AAWD,MAAM,UAAU,sBAAsB,CAAC,SAAuB;IAC5D,OAAO,SAAS,CAAC,QAAQ;SACtB,IAAI,EAAE;SACN,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;SACnD,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;AACtC,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAC1C,OAAwB,EACxB,OAAwB,EACxB,UAAkC,EAAE;IAEpC,MAAM,aAAa,GAAG,OAAO,CAAC,WAAW,IAAI,IAAI,CAAC;IAClD,IAAI,aAAa,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;QAC5C,OAAO,OAAO,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACzC,CAAC;IACD,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;AACpC,CAAC;AAED,MAAM,UAAU,qBAAqB,CACnC,SAAuB,EACvB,OAAe;IAEf,MAAM,OAAO,GAAG,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAChD,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,oBAAoB,OAAO,IAAI,CAAC,CAAC;IACnD,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,0BAA0B,CAAC,KAOhD;IACC,MAAM,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,SAAS,CACtC;QACE,EAAE,EAAE,KAAK,CAAC,eAAe,CAAC,OAAO,CAAC,EAAE;QACpC,GAAG,EAAE,KAAK,CAAC,eAAe,CAAC,GAAG;QAC9B,OAAO,EAAE,KAAK,CAAC,eAAe,CAAC,OAAO;QACtC,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,UAAU,EAAE;YACV,kBAAkB,EAAE,CAAC,EAAE,eAAe,EAAE,EAAE,EAAE,CAC1C,8BAA8B,CAAC;gBAC7B,eAAe;gBACf,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,GAAG,EAAE,KAAK,CAAC,eAAe,CAAC,GAAG;gBAC9B,YAAY,EAAE,KAAK,CAAC,YAAY;aACjC,CAAC;SACL;KACF,EACD,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,SAAS,CAC7D,CAAC;AACJ,CAAC"}
|
|
@@ -1,4 +1,7 @@
|
|
|
1
1
|
import type { Command } from "commander";
|
|
2
2
|
import type { CliContainer } from "../container.js";
|
|
3
3
|
export declare function registerTestCommand(program: Command, container: CliContainer): Command;
|
|
4
|
-
export declare function executeTest(program: Command, container: CliContainer, service: string
|
|
4
|
+
export declare function executeTest(program: Command, container: CliContainer, service: string, options?: {
|
|
5
|
+
isolated?: boolean;
|
|
6
|
+
stdin?: boolean;
|
|
7
|
+
}): Promise<void>;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { buildProviderContext, createExecutionResources, resolveCommandFlags, resolveProviderHandler, resolveServiceAdapter } from "./shared.js";
|
|
2
2
|
import { resolveServiceArgument } from "./configure.js";
|
|
3
|
+
import { resolveIsolatedEnvDetails } from "../isolated-env.js";
|
|
3
4
|
import { formatCommandRunnerResult, stdoutMatchesExpected } from "../../utils/command-checks.js";
|
|
4
5
|
export function registerTestCommand(program, container) {
|
|
5
6
|
return program
|
|
@@ -7,18 +8,34 @@ export function registerTestCommand(program, container) {
|
|
|
7
8
|
.description("Run service health checks.")
|
|
8
9
|
.option("--stdin", "Verify stdin prompt support via spawn")
|
|
9
10
|
.argument("[service]", "Service to test (claude-code | codex | opencode)")
|
|
11
|
+
.option("--isolated", "Run the health check using isolated configuration.")
|
|
10
12
|
.action(async function (service) {
|
|
11
13
|
const resolved = await resolveServiceArgument(program, container, service);
|
|
12
|
-
|
|
14
|
+
const opts = this.opts();
|
|
15
|
+
await executeTest(this, container, resolved, {
|
|
16
|
+
isolated: Boolean(opts.isolated),
|
|
17
|
+
stdin: Boolean(opts.stdin)
|
|
18
|
+
});
|
|
13
19
|
});
|
|
14
20
|
}
|
|
15
|
-
export async function executeTest(program, container, service) {
|
|
21
|
+
export async function executeTest(program, container, service, options = {}) {
|
|
16
22
|
const adapter = resolveServiceAdapter(container, service);
|
|
17
23
|
const flags = resolveCommandFlags(program);
|
|
18
24
|
const resources = createExecutionResources(container, flags, `test:${service}`);
|
|
19
25
|
const providerContext = buildProviderContext(container, adapter, resources);
|
|
20
|
-
const
|
|
21
|
-
|
|
26
|
+
const isolatedDetails = options.isolated && adapter.isolatedEnv
|
|
27
|
+
? resolveIsolatedEnvDetails(container.env, adapter.isolatedEnv, adapter.name)
|
|
28
|
+
: null;
|
|
29
|
+
if (options.isolated && adapter.isolatedEnv) {
|
|
30
|
+
const { ensureIsolatedConfigForService } = await import("./ensure-isolated-config.js");
|
|
31
|
+
await ensureIsolatedConfigForService({
|
|
32
|
+
container,
|
|
33
|
+
adapter,
|
|
34
|
+
service,
|
|
35
|
+
flags
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
if (options.stdin) {
|
|
22
39
|
if (!adapter.supportsStdinPrompt) {
|
|
23
40
|
throw new Error(`${adapter.label} does not support stdin prompts.`);
|
|
24
41
|
}
|
|
@@ -68,13 +85,27 @@ export async function executeTest(program, container, service) {
|
|
|
68
85
|
if (!entry.test) {
|
|
69
86
|
throw new Error(`Service "${service}" does not support test.`);
|
|
70
87
|
}
|
|
71
|
-
const
|
|
88
|
+
const activeContext = isolatedDetails
|
|
89
|
+
? {
|
|
90
|
+
...providerContext,
|
|
91
|
+
runCheck: async (check) => {
|
|
92
|
+
await check.run({
|
|
93
|
+
isDryRun: providerContext.logger.context.dryRun,
|
|
94
|
+
runCommand: (command, args) => resources.context.runCommandWithEnv(command, args, {
|
|
95
|
+
env: isolatedDetails.env
|
|
96
|
+
}),
|
|
97
|
+
logDryRun: (message) => providerContext.logger.dryRun(message)
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
: providerContext;
|
|
102
|
+
const resolution = await resolveProviderHandler(entry, activeContext, {
|
|
72
103
|
useResolver: false
|
|
73
104
|
});
|
|
74
105
|
if (!resolution.adapter.test) {
|
|
75
106
|
throw new Error(`Service "${service}" does not support test.`);
|
|
76
107
|
}
|
|
77
|
-
await resolution.adapter.test(
|
|
108
|
+
await resolution.adapter.test(activeContext);
|
|
78
109
|
});
|
|
79
110
|
}
|
|
80
111
|
const dryMessage = service === "claude-code"
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"test.js","sourceRoot":"","sources":["../../../src/cli/commands/test.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,oBAAoB,EACpB,wBAAwB,EACxB,mBAAmB,EACnB,sBAAsB,EACtB,qBAAqB,EACtB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,sBAAsB,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"test.js","sourceRoot":"","sources":["../../../src/cli/commands/test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { resolveCommandFlags, resolveServiceAdapter } from "./shared.js";
|
|
2
|
+
import { isolatedEnvRunner } from "../isolated-env-runner.js";
|
|
3
|
+
import { ensureIsolatedConfigForService } from "./ensure-isolated-config.js";
|
|
4
|
+
import { applyIsolatedEnvRepairs } from "../isolated-env.js";
|
|
5
|
+
export function registerWrapCommand(program, container) {
|
|
6
|
+
return program
|
|
7
|
+
.command("wrap")
|
|
8
|
+
.description("Run an agent CLI with Poe isolated configuration.")
|
|
9
|
+
.allowUnknownOption(true)
|
|
10
|
+
.allowExcessArguments(true)
|
|
11
|
+
.argument("<service>", "Service to wrap")
|
|
12
|
+
.argument("[agentArgs...]", "Arguments forwarded to the agent")
|
|
13
|
+
.action(async (service, agentArgs = []) => {
|
|
14
|
+
const flags = resolveCommandFlags(program);
|
|
15
|
+
const adapter = resolveServiceAdapter(container, service);
|
|
16
|
+
const isolated = adapter.isolatedEnv;
|
|
17
|
+
if (!isolated) {
|
|
18
|
+
throw new Error(`Service "${service}" does not support isolated configuration wrappers.`);
|
|
19
|
+
}
|
|
20
|
+
const argv = process.argv;
|
|
21
|
+
const wrapIndex = argv.indexOf("wrap");
|
|
22
|
+
const serviceIndex = wrapIndex >= 0 && argv[wrapIndex + 1] === service
|
|
23
|
+
? wrapIndex + 1
|
|
24
|
+
: argv.indexOf(service);
|
|
25
|
+
const startIndex = serviceIndex >= 0 ? serviceIndex + 1 : argv.length;
|
|
26
|
+
let forwarded = argv.slice(startIndex);
|
|
27
|
+
if (forwarded[0] === "--") {
|
|
28
|
+
forwarded = forwarded.slice(1);
|
|
29
|
+
}
|
|
30
|
+
if (forwarded.length === 0) {
|
|
31
|
+
forwarded = agentArgs;
|
|
32
|
+
}
|
|
33
|
+
await ensureIsolatedConfigForService({
|
|
34
|
+
container,
|
|
35
|
+
adapter,
|
|
36
|
+
service,
|
|
37
|
+
flags
|
|
38
|
+
});
|
|
39
|
+
await applyIsolatedEnvRepairs({
|
|
40
|
+
fs: container.fs,
|
|
41
|
+
env: container.env,
|
|
42
|
+
providerName: adapter.name,
|
|
43
|
+
isolated
|
|
44
|
+
});
|
|
45
|
+
await isolatedEnvRunner({
|
|
46
|
+
env: container.env,
|
|
47
|
+
fs: container.fs,
|
|
48
|
+
providerName: adapter.name,
|
|
49
|
+
isolated,
|
|
50
|
+
argv: ["node", "poe-code", ...forwarded]
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=wrap.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wrap.js","sourceRoot":"","sources":["../../../src/cli/commands/wrap.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,mBAAmB,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AACzE,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,8BAA8B,EAAE,MAAM,6BAA6B,CAAC;AAC7E,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAC;AAE7D,MAAM,UAAU,mBAAmB,CACjC,OAAgB,EAChB,SAAuB;IAEvB,OAAO,OAAO;SACX,OAAO,CAAC,MAAM,CAAC;SACf,WAAW,CAAC,mDAAmD,CAAC;SAChE,kBAAkB,CAAC,IAAI,CAAC;SACxB,oBAAoB,CAAC,IAAI,CAAC;SAC1B,QAAQ,CAAC,WAAW,EAAE,iBAAiB,CAAC;SACxC,QAAQ,CAAC,gBAAgB,EAAE,kCAAkC,CAAC;SAC9D,MAAM,CAAC,KAAK,EAAE,OAAe,EAAE,YAAsB,EAAE,EAAE,EAAE;QAC1D,MAAM,KAAK,GAAG,mBAAmB,CAAC,OAAO,CAAC,CAAC;QAC3C,MAAM,OAAO,GAAG,qBAAqB,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAC1D,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,IAAI,KAAK,CACb,YAAY,OAAO,qDAAqD,CACzE,CAAC;QACJ,CAAC;QAED,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;QAC1B,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACvC,MAAM,YAAY,GAChB,SAAS,IAAI,CAAC,IAAI,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,KAAK,OAAO;YAC/C,CAAC,CAAC,SAAS,GAAG,CAAC;YACf,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAC5B,MAAM,UAAU,GAAG,YAAY,IAAI,CAAC,CAAC,CAAC,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;QACtE,IAAI,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QACvC,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;YAC1B,SAAS,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACjC,CAAC;QACD,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC3B,SAAS,GAAG,SAAS,CAAC;QACxB,CAAC;QAED,MAAM,8BAA8B,CAAC;YACnC,SAAS;YACT,OAAO;YACP,OAAO;YACP,KAAK;SACN,CAAC,CAAC;QACH,MAAM,uBAAuB,CAAC;YAC5B,EAAE,EAAE,SAAS,CAAC,EAAE;YAChB,GAAG,EAAE,SAAS,CAAC,GAAG;YAClB,YAAY,EAAE,OAAO,CAAC,IAAI;YAC1B,QAAQ;SACT,CAAC,CAAC;QACH,MAAM,iBAAiB,CAAC;YACtB,GAAG,EAAE,SAAS,CAAC,GAAG;YAClB,EAAE,EAAE,SAAS,CAAC,EAAE;YAChB,YAAY,EAAE,OAAO,CAAC,IAAI;YAC1B,QAAQ;YACR,IAAI,EAAE,CAAC,MAAM,EAAE,UAAU,EAAE,GAAG,SAAS,CAAC;SACzC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACP,CAAC"}
|
package/dist/cli/container.js
CHANGED
|
@@ -9,6 +9,7 @@ import { createLoggerFactory } from "./logger.js";
|
|
|
9
9
|
import { ErrorLogger } from "./error-logger.js";
|
|
10
10
|
import { createDefaultCommandRunner } from "./command-runner.js";
|
|
11
11
|
import { getDefaultProviders } from "../providers/index.js";
|
|
12
|
+
import { createPoeCodeCommandRunner } from "./poe-code-command-runner.js";
|
|
12
13
|
export function createCliContainer(dependencies) {
|
|
13
14
|
const environment = createCliEnvironment({
|
|
14
15
|
cwd: dependencies.env.cwd,
|
|
@@ -59,7 +60,12 @@ export function createCliContainer(dependencies) {
|
|
|
59
60
|
for (const adapter of providers) {
|
|
60
61
|
registry.register(adapter);
|
|
61
62
|
}
|
|
62
|
-
|
|
63
|
+
let container = null;
|
|
64
|
+
const wrappedRunner = createPoeCodeCommandRunner({
|
|
65
|
+
getContainer: () => container,
|
|
66
|
+
baseRunner: commandRunner
|
|
67
|
+
});
|
|
68
|
+
container = {
|
|
63
69
|
env: environment,
|
|
64
70
|
fs: dependencies.fs,
|
|
65
71
|
prompts: dependencies.prompts,
|
|
@@ -70,9 +76,10 @@ export function createCliContainer(dependencies) {
|
|
|
70
76
|
contextFactory,
|
|
71
77
|
registry,
|
|
72
78
|
httpClient,
|
|
73
|
-
commandRunner,
|
|
79
|
+
commandRunner: wrappedRunner,
|
|
74
80
|
providers,
|
|
75
81
|
dependencies
|
|
76
82
|
};
|
|
83
|
+
return container;
|
|
77
84
|
}
|
|
78
85
|
//# sourceMappingURL=container.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"container.js","sourceRoot":"","sources":["../../src/cli/container.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,UAAU,MAAM,SAAS,CAAC;AAEtC,OAAO,EACL,eAAe,EACf,eAAe,EAChB,MAAM,4BAA4B,CAAC;AACpC,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AACxD,OAAO,EACL,qBAAqB,EAEtB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EACL,2BAA2B,EAE5B,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,EACL,qBAAqB,EAEtB,MAAM,cAAc,CAAC;AACtB,OAAO,EACL,mBAAmB,EAEpB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,0BAA0B,EAAE,MAAM,qBAAqB,CAAC;AAIjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"container.js","sourceRoot":"","sources":["../../src/cli/container.ts"],"names":[],"mappings":"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"}
|
package/dist/cli/context.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { FileSystem } from "../utils/file-system.js";
|
|
2
|
-
import type { CommandRunner } from "../utils/command-checks.js";
|
|
2
|
+
import type { CommandRunner, CommandRunnerResult } from "../utils/command-checks.js";
|
|
3
3
|
import type { ScopedLogger } from "./logger.js";
|
|
4
4
|
export interface CommandContextOptions {
|
|
5
5
|
dryRun: boolean;
|
|
@@ -13,6 +13,10 @@ export interface CommandContextComplete {
|
|
|
13
13
|
export interface CommandContext {
|
|
14
14
|
fs: FileSystem;
|
|
15
15
|
runCommand: CommandRunner;
|
|
16
|
+
runCommandWithEnv(command: string, args: string[], options?: {
|
|
17
|
+
cwd?: string;
|
|
18
|
+
env?: Record<string, string | undefined>;
|
|
19
|
+
}): Promise<CommandRunnerResult>;
|
|
16
20
|
flushDryRun(options?: {
|
|
17
21
|
emitIfEmpty?: boolean;
|
|
18
22
|
}): void;
|
package/dist/cli/context.js
CHANGED
|
@@ -6,6 +6,12 @@ export function createCommandContextFactory(init) {
|
|
|
6
6
|
return {
|
|
7
7
|
fs,
|
|
8
8
|
runCommand: options.runner,
|
|
9
|
+
runCommandWithEnv(command, args, runOptions) {
|
|
10
|
+
return options.runner(command, args, {
|
|
11
|
+
cwd: runOptions?.cwd,
|
|
12
|
+
env: runOptions?.env
|
|
13
|
+
});
|
|
14
|
+
},
|
|
9
15
|
flushDryRun() { },
|
|
10
16
|
complete(messages) {
|
|
11
17
|
options.logger.info(messages.success);
|
|
@@ -39,6 +45,12 @@ export function createCommandContextFactory(init) {
|
|
|
39
45
|
return {
|
|
40
46
|
fs: proxyFs,
|
|
41
47
|
runCommand: options.runner,
|
|
48
|
+
runCommandWithEnv(command, args, runOptions) {
|
|
49
|
+
return options.runner(command, args, {
|
|
50
|
+
cwd: runOptions?.cwd,
|
|
51
|
+
env: runOptions?.env
|
|
52
|
+
});
|
|
53
|
+
},
|
|
42
54
|
flushDryRun({ emitIfEmpty } = {}) {
|
|
43
55
|
flush(Boolean(emitIfEmpty));
|
|
44
56
|
},
|
package/dist/cli/context.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../src/cli/context.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EACd,sBAAsB,EACtB,sBAAsB,EACvB,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../src/cli/context.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { ProviderIsolatedEnv } from "./service-registry.js";
|
|
2
|
+
import type { CliEnvironment } from "./environment.js";
|
|
3
|
+
import type { FileSystem } from "../utils/file-system.js";
|
|
4
|
+
export declare function isolatedEnvRunner(input: {
|
|
5
|
+
env: CliEnvironment;
|
|
6
|
+
providerName: string;
|
|
7
|
+
isolated: ProviderIsolatedEnv;
|
|
8
|
+
argv: string[];
|
|
9
|
+
fs?: FileSystem;
|
|
10
|
+
}): Promise<never>;
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { spawn } from "node:child_process";
|
|
2
|
+
import { resolveIsolatedEnvDetails } from "./isolated-env.js";
|
|
3
|
+
export async function isolatedEnvRunner(input) {
|
|
4
|
+
const details = resolveIsolatedEnvDetails(input.env, input.isolated, input.providerName);
|
|
5
|
+
const [, , ...args] = input.argv;
|
|
6
|
+
const hasConfig = await configExists(input.fs, details.configProbePath);
|
|
7
|
+
if (!hasConfig) {
|
|
8
|
+
throw new Error(`${input.providerName} is not configured. Run 'poe-code login' or 'poe-code configure ${input.providerName}'.`);
|
|
9
|
+
}
|
|
10
|
+
const child = spawn(details.agentBinary, args, {
|
|
11
|
+
stdio: "inherit",
|
|
12
|
+
env: {
|
|
13
|
+
...process.env,
|
|
14
|
+
...details.env
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
return await new Promise((_, reject) => {
|
|
18
|
+
child.on("error", (error) => {
|
|
19
|
+
reject(error);
|
|
20
|
+
});
|
|
21
|
+
child.on("close", (code) => {
|
|
22
|
+
process.exit(code ?? 0);
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
async function configExists(fs, filePath) {
|
|
27
|
+
if (!fs) {
|
|
28
|
+
return true;
|
|
29
|
+
}
|
|
30
|
+
try {
|
|
31
|
+
await fs.stat(filePath);
|
|
32
|
+
return true;
|
|
33
|
+
}
|
|
34
|
+
catch (error) {
|
|
35
|
+
if (typeof error === "object" &&
|
|
36
|
+
error !== null &&
|
|
37
|
+
"code" in error &&
|
|
38
|
+
error.code === "ENOENT") {
|
|
39
|
+
return false;
|
|
40
|
+
}
|
|
41
|
+
throw error;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=isolated-env-runner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isolated-env-runner.js","sourceRoot":"","sources":["../../src/cli/isolated-env-runner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAG3C,OAAO,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAG9D,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,KAMvC;IACC,MAAM,OAAO,GAAG,yBAAyB,CACvC,KAAK,CAAC,GAAG,EACT,KAAK,CAAC,QAAQ,EACd,KAAK,CAAC,YAAY,CACnB,CAAC;IACF,MAAM,CAAC,EAAE,AAAD,EAAG,GAAG,IAAI,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC;IAEjC,MAAM,SAAS,GAAG,MAAM,YAAY,CAClC,KAAK,CAAC,EAAE,EACR,OAAO,CAAC,eAAe,CACxB,CAAC;IAEF,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CACb,GAAG,KAAK,CAAC,YAAY,mEAAmE,KAAK,CAAC,YAAY,IAAI,CAC/G,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,EAAE;QAC7C,KAAK,EAAE,SAAS;QAChB,GAAG,EAAE;YACH,GAAI,OAAO,CAAC,GAA0C;YACtD,GAAG,OAAO,CAAC,GAAG;SACf;KACF,CAAC,CAAC;IAEH,OAAO,MAAM,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE;QACrC,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;YAC1B,MAAM,CAAC,KAAK,CAAC,CAAC;QAChB,CAAC,CAAC,CAAC;QACH,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,EAAE;YACzB,OAAO,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED,KAAK,UAAU,YAAY,CACzB,EAA0B,EAC1B,QAAgB;IAEhB,IAAI,CAAC,EAAE,EAAE,CAAC;QACR,OAAO,IAAI,CAAC;IACd,CAAC;IACD,IAAI,CAAC;QACH,MAAM,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACxB,OAAO,IAAI,CAAC;IACd,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IACE,OAAO,KAAK,KAAK,QAAQ;YACzB,KAAK,KAAK,IAAI;YACd,MAAM,IAAI,KAAK;YACd,KAA2B,CAAC,IAAI,KAAK,QAAQ,EAC9C,CAAC;YACD,OAAO,KAAK,CAAC;QACf,CAAC;QACD,MAAM,KAAK,CAAC;IACd,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { CliEnvironment } from "./environment.js";
|
|
2
|
+
import type { FileSystem } from "../utils/file-system.js";
|
|
3
|
+
import type { ProviderIsolatedEnv } from "./service-registry.js";
|
|
4
|
+
export interface IsolatedEnvDetails {
|
|
5
|
+
agentBinary: string;
|
|
6
|
+
env: Record<string, string>;
|
|
7
|
+
configProbePath: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function resolveIsolatedEnvDetails(env: CliEnvironment, isolated: ProviderIsolatedEnv, providerName?: string): IsolatedEnvDetails;
|
|
10
|
+
export declare function resolveIsolatedTargetDirectory(input: {
|
|
11
|
+
targetDirectory: string;
|
|
12
|
+
isolated: ProviderIsolatedEnv;
|
|
13
|
+
env: CliEnvironment;
|
|
14
|
+
providerName: string;
|
|
15
|
+
}): string;
|
|
16
|
+
export declare function isolatedConfigExists(fs: FileSystem, configProbePath: string): Promise<boolean>;
|
|
17
|
+
export declare function applyIsolatedEnvRepairs(input: {
|
|
18
|
+
fs: FileSystem;
|
|
19
|
+
env: CliEnvironment;
|
|
20
|
+
providerName: string;
|
|
21
|
+
isolated: ProviderIsolatedEnv;
|
|
22
|
+
}): Promise<void>;
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
export function resolveIsolatedEnvDetails(env, isolated, providerName) {
|
|
3
|
+
if (!providerName) {
|
|
4
|
+
throw new Error("resolveIsolatedEnvDetails requires providerName.");
|
|
5
|
+
}
|
|
6
|
+
const baseDir = resolveIsolatedBaseDir(env, providerName);
|
|
7
|
+
return {
|
|
8
|
+
agentBinary: isolated.agentBinary,
|
|
9
|
+
env: resolveIsolatedEnvVars(env, baseDir, isolated.env),
|
|
10
|
+
configProbePath: resolveIsolatedEnvPath(env, baseDir, isolated.configProbe)
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
export function resolveIsolatedTargetDirectory(input) {
|
|
14
|
+
const expanded = expandHomeShortcut(input.env, input.targetDirectory);
|
|
15
|
+
const baseDir = resolveIsolatedBaseDir(input.env, input.providerName);
|
|
16
|
+
const homeDir = input.env.homeDir;
|
|
17
|
+
if (expanded !== homeDir && !expanded.startsWith(`${homeDir}/`)) {
|
|
18
|
+
throw new Error(`Isolated config targets must live under the user's home directory (received "${input.targetDirectory}").`);
|
|
19
|
+
}
|
|
20
|
+
if (expanded === baseDir) {
|
|
21
|
+
return baseDir;
|
|
22
|
+
}
|
|
23
|
+
if (expanded === homeDir) {
|
|
24
|
+
return baseDir;
|
|
25
|
+
}
|
|
26
|
+
if (!expanded.startsWith(`${homeDir}/`)) {
|
|
27
|
+
return expanded;
|
|
28
|
+
}
|
|
29
|
+
const mapped = path.join(baseDir, expanded.slice(homeDir.length + 1));
|
|
30
|
+
return stripAgentHome(mapped, baseDir, input.isolated.agentBinary);
|
|
31
|
+
}
|
|
32
|
+
function resolveIsolatedBaseDir(env, providerName) {
|
|
33
|
+
return env.resolveHomePath(".poe-code", providerName);
|
|
34
|
+
}
|
|
35
|
+
function resolveIsolatedEnvVars(env, baseDir, vars) {
|
|
36
|
+
const out = {};
|
|
37
|
+
for (const [key, value] of Object.entries(vars)) {
|
|
38
|
+
out[key] = resolveIsolatedEnvValue(env, baseDir, value);
|
|
39
|
+
}
|
|
40
|
+
return out;
|
|
41
|
+
}
|
|
42
|
+
function resolveIsolatedEnvValue(env, baseDir, value) {
|
|
43
|
+
if (typeof value === "string") {
|
|
44
|
+
return expandHomeShortcut(env, value);
|
|
45
|
+
}
|
|
46
|
+
return resolveIsolatedEnvPath(env, baseDir, value);
|
|
47
|
+
}
|
|
48
|
+
function resolveIsolatedEnvPath(env, baseDir, value) {
|
|
49
|
+
switch (value.kind) {
|
|
50
|
+
case "isolatedDir":
|
|
51
|
+
return value.relativePath
|
|
52
|
+
? path.join(baseDir, value.relativePath)
|
|
53
|
+
: baseDir;
|
|
54
|
+
case "isolatedFile":
|
|
55
|
+
return path.join(baseDir, value.relativePath);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
export async function isolatedConfigExists(fs, configProbePath) {
|
|
59
|
+
try {
|
|
60
|
+
await fs.stat(configProbePath);
|
|
61
|
+
return true;
|
|
62
|
+
}
|
|
63
|
+
catch (error) {
|
|
64
|
+
if (isNotFound(error)) {
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
throw error;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
export async function applyIsolatedEnvRepairs(input) {
|
|
71
|
+
const repairs = input.isolated.repairs ?? [];
|
|
72
|
+
if (repairs.length === 0 || typeof input.fs.chmod !== "function") {
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
const baseDir = input.env.resolveHomePath(".poe-code", input.providerName);
|
|
76
|
+
for (const repair of repairs) {
|
|
77
|
+
if (repair.kind !== "chmod") {
|
|
78
|
+
continue;
|
|
79
|
+
}
|
|
80
|
+
if (path.isAbsolute(repair.relativePath)) {
|
|
81
|
+
continue;
|
|
82
|
+
}
|
|
83
|
+
const repairPath = path.join(baseDir, repair.relativePath);
|
|
84
|
+
try {
|
|
85
|
+
await input.fs.chmod(repairPath, repair.mode);
|
|
86
|
+
}
|
|
87
|
+
catch (error) {
|
|
88
|
+
if (isNotFound(error)) {
|
|
89
|
+
continue;
|
|
90
|
+
}
|
|
91
|
+
throw error;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
function stripAgentHome(mapped, baseDir, agentBinary) {
|
|
96
|
+
const agentDir = `.${agentBinary}`;
|
|
97
|
+
const prefix = path.join(baseDir, agentDir);
|
|
98
|
+
if (mapped === prefix) {
|
|
99
|
+
return baseDir;
|
|
100
|
+
}
|
|
101
|
+
const withSep = `${prefix}${path.sep}`;
|
|
102
|
+
if (mapped.startsWith(withSep)) {
|
|
103
|
+
return path.join(baseDir, mapped.slice(withSep.length));
|
|
104
|
+
}
|
|
105
|
+
return mapped;
|
|
106
|
+
}
|
|
107
|
+
function expandHomeShortcut(env, input) {
|
|
108
|
+
if (!input.startsWith("~")) {
|
|
109
|
+
return input;
|
|
110
|
+
}
|
|
111
|
+
if (input === "~") {
|
|
112
|
+
return env.homeDir;
|
|
113
|
+
}
|
|
114
|
+
if (input.startsWith("~/")) {
|
|
115
|
+
return path.join(env.homeDir, input.slice(2));
|
|
116
|
+
}
|
|
117
|
+
if (input.startsWith("~./")) {
|
|
118
|
+
return path.join(env.homeDir, `.${input.slice(3)}`);
|
|
119
|
+
}
|
|
120
|
+
return input;
|
|
121
|
+
}
|
|
122
|
+
function isNotFound(error) {
|
|
123
|
+
return (typeof error === "object" &&
|
|
124
|
+
error !== null &&
|
|
125
|
+
"code" in error &&
|
|
126
|
+
error.code === "ENOENT");
|
|
127
|
+
}
|
|
128
|
+
//# sourceMappingURL=isolated-env.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isolated-env.js","sourceRoot":"","sources":["../../src/cli/isolated-env.ts"],"names":[],"mappings":"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"}
|