@mostok/codexes 0.1.0 → 0.3.2

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.
Files changed (32) hide show
  1. package/README.md +10 -4
  2. package/dist/cli.js +2072 -1385
  3. package/dist/cli.js.map +4 -4
  4. package/dist/commands/account-list/run-account-list-command.js +36 -18
  5. package/dist/commands/account-list/run-account-list-command.js.map +1 -1
  6. package/dist/commands/root/run-root-command.js +54 -6
  7. package/dist/commands/root/run-root-command.js.map +1 -1
  8. package/dist/config/wrapper-config.d.ts +2 -1
  9. package/dist/config/wrapper-config.js +66 -17
  10. package/dist/config/wrapper-config.js.map +1 -1
  11. package/dist/core/context.d.ts +3 -0
  12. package/dist/core/context.js +3 -0
  13. package/dist/core/context.js.map +1 -1
  14. package/dist/selection/format-selection-summary.d.ts +12 -0
  15. package/dist/selection/format-selection-summary.js +182 -0
  16. package/dist/selection/format-selection-summary.js.map +1 -0
  17. package/dist/selection/select-account.js +7 -163
  18. package/dist/selection/select-account.js.map +1 -1
  19. package/dist/selection/selection-summary.d.ts +38 -0
  20. package/dist/selection/selection-summary.js +405 -0
  21. package/dist/selection/selection-summary.js.map +1 -0
  22. package/dist/selection/usage-cache.js +23 -0
  23. package/dist/selection/usage-cache.js.map +1 -1
  24. package/dist/selection/usage-normalize.js +182 -19
  25. package/dist/selection/usage-normalize.js.map +1 -1
  26. package/dist/selection/usage-probe-coordinator.js +13 -0
  27. package/dist/selection/usage-probe-coordinator.js.map +1 -1
  28. package/dist/selection/usage-types.d.ts +18 -2
  29. package/package.json +1 -1
  30. package/dist/accounts/resolve-active-account.d.ts +0 -6
  31. package/dist/accounts/resolve-active-account.js +0 -32
  32. package/dist/accounts/resolve-active-account.js.map +0 -1
@@ -1,6 +1,7 @@
1
1
  import { createLogger } from "../../logging/logger.js";
2
2
  import { createAccountRegistry } from "../../accounts/account-registry.js";
3
- import { buildAccountPresentations } from "../../accounts/account-resolution.js";
3
+ import { formatSelectionSummary } from "../../selection/format-selection-summary.js";
4
+ import { resolveSelectionSummary } from "../../selection/selection-summary.js";
4
5
  export async function runAccountListCommand(context) {
5
6
  const logger = createLogger({
6
7
  level: context.logging.level,
@@ -12,13 +13,9 @@ export async function runAccountListCommand(context) {
12
13
  logger,
13
14
  registryFile: context.paths.registryFile,
14
15
  });
15
- const [accounts, defaultAccount] = await Promise.all([
16
- registry.listAccounts(),
17
- registry.getDefaultAccount(),
18
- ]);
16
+ const accounts = await registry.listAccounts();
19
17
  logger.info("command.start", {
20
18
  accountCount: accounts.length,
21
- defaultAccountId: defaultAccount?.id ?? null,
22
19
  });
23
20
  if (accounts.length === 0) {
24
21
  context.io.stdout.write([
@@ -28,20 +25,41 @@ export async function runAccountListCommand(context) {
28
25
  logger.info("command.empty");
29
26
  return 0;
30
27
  }
31
- const presentations = await buildAccountPresentations({ accounts, logger });
32
- const lines = presentations.map(({ account, authAccountId, authMode }) => {
33
- const markers = [
34
- defaultAccount?.id === account.id ? "default" : null,
35
- authMode ? `auth=${authMode}` : null,
36
- authAccountId ? `authAccountId=${authAccountId}` : null,
37
- ]
38
- .filter((value) => Boolean(value))
39
- .join(", ");
40
- return `${defaultAccount?.id === account.id ? "*" : " "} ${account.label} (${account.id})${markers ? ` [${markers}]` : ""}`;
28
+ const summary = await resolveSelectionSummary({
29
+ experimentalSelection: context.wrapperConfig.experimentalSelection,
30
+ fetchImpl: fetch,
31
+ logger,
32
+ mode: "display-only",
33
+ registry,
34
+ selectionCacheFilePath: context.paths.selectionCacheFile,
35
+ strategy: context.wrapperConfig.accountSelectionStrategy,
36
+ });
37
+ const formattedSummary = formatSelectionSummary({
38
+ capabilities: {
39
+ stdoutIsTTY: context.output.stdoutIsTTY,
40
+ useColor: context.output.stdoutIsTTY,
41
+ },
42
+ logger,
43
+ summary,
41
44
  });
42
- context.io.stdout.write(`${lines.join("\n")}\n`);
45
+ context.io.stdout.write(formattedSummary);
46
+ logger.info("summary_rendered", {
47
+ mode: summary.mode,
48
+ strategy: summary.strategy,
49
+ useColor: context.output.stdoutIsTTY,
50
+ selectedAccountId: summary.selectedAccount?.id ?? null,
51
+ fallbackReason: summary.fallbackReason,
52
+ executionBlockedReason: summary.executionBlockedReason,
53
+ });
54
+ if (summary.fallbackReason || summary.executionBlockedReason) {
55
+ logger.warn("fallback_announced", {
56
+ fallbackReason: summary.fallbackReason,
57
+ selectedAccountId: summary.selectedAccount?.id ?? null,
58
+ executionBlockedReason: summary.executionBlockedReason,
59
+ });
60
+ }
43
61
  logger.info("command.complete", {
44
- accountIds: presentations.map(({ account }) => account.id),
62
+ accountIds: summary.entries.map(({ account }) => account.id),
45
63
  });
46
64
  return 0;
47
65
  }
@@ -1 +1 @@
1
- {"version":3,"file":"run-account-list-command.js","sourceRoot":"","sources":["../../../src/commands/account-list/run-account-list-command.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAEvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,oCAAoC,CAAC;AAC3E,OAAO,EAAE,yBAAyB,EAAE,MAAM,sCAAsC,CAAC;AAEjF,MAAM,CAAC,KAAK,UAAU,qBAAqB,CAAC,OAAmB;IAC7D,MAAM,MAAM,GAAG,YAAY,CAAC;QAC1B,KAAK,EAAE,OAAO,CAAC,OAAO,CAAC,KAAK;QAC5B,IAAI,EAAE,cAAc;QACpB,IAAI,EAAE,OAAO,CAAC,OAAO,CAAC,IAAI;KAC3B,CAAC,CAAC;IACH,MAAM,QAAQ,GAAG,qBAAqB,CAAC;QACrC,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,WAAW;QACtC,MAAM;QACN,YAAY,EAAE,OAAO,CAAC,KAAK,CAAC,YAAY;KACzC,CAAC,CAAC;IACH,MAAM,CAAC,QAAQ,EAAE,cAAc,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QACnD,QAAQ,CAAC,YAAY,EAAE;QACvB,QAAQ,CAAC,iBAAiB,EAAE;KAC7B,CAAC,CAAC;IAEH,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE;QAC3B,YAAY,EAAE,QAAQ,CAAC,MAAM;QAC7B,gBAAgB,EAAE,cAAc,EAAE,EAAE,IAAI,IAAI;KAC7C,CAAC,CAAC;IAEH,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC1B,OAAO,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CACrB;YACE,yBAAyB;YACzB,2CAA2C;SAC5C,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CACpB,CAAC;QACF,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAC7B,OAAO,CAAC,CAAC;IACX,CAAC;IAED,MAAM,aAAa,GAAG,MAAM,yBAAyB,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAC;IAC5E,MAAM,KAAK,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,EAAE,EAAE;QACvE,MAAM,OAAO,GAAG;YACd,cAAc,EAAE,EAAE,KAAK,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI;YACpD,QAAQ,CAAC,CAAC,CAAC,QAAQ,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI;YACpC,aAAa,CAAC,CAAC,CAAC,iBAAiB,aAAa,EAAE,CAAC,CAAC,CAAC,IAAI;SACxD;aACE,MAAM,CAAC,CAAC,KAAK,EAAmB,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;aAClD,IAAI,CAAC,IAAI,CAAC,CAAC;QAEd,OAAO,GAAG,cAAc,EAAE,EAAE,KAAK,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,OAAO,CAAC,KAAK,KAAK,OAAO,CAAC,EAAE,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,OAAO,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;IAC9H,CAAC,CAAC,CAAC;IAEH,OAAO,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjD,MAAM,CAAC,IAAI,CAAC,kBAAkB,EAAE;QAC9B,UAAU,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;KAC3D,CAAC,CAAC;IAEH,OAAO,CAAC,CAAC;AACX,CAAC"}
1
+ {"version":3,"file":"run-account-list-command.js","sourceRoot":"","sources":["../../../src/commands/account-list/run-account-list-command.ts"],"names":[],"mappings":"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"}
@@ -8,7 +8,8 @@ import { runAccountUseCommand } from "../account-use/run-account-use-command.js"
8
8
  import { acquireRuntimeLock } from "../../runtime/lock/runtime-lock.js";
9
9
  import { activateAccountIntoSharedRuntime, restoreSharedRuntimeFromBackup, syncSharedRuntimeBackToAccount, } from "../../runtime/activate-account/activate-account.js";
10
10
  import { spawnCodexCommand } from "../../process/spawn-codex-command.js";
11
- import { selectAccountForExecution } from "../../selection/select-account.js";
11
+ import { formatSelectionSummary } from "../../selection/format-selection-summary.js";
12
+ import { resolveSelectionSummary } from "../../selection/selection-summary.js";
12
13
  export async function runRootCommand(context) {
13
14
  const logger = createLogger({
14
15
  level: context.logging.level,
@@ -28,6 +29,7 @@ export async function runRootCommand(context) {
28
29
  createdRuntimeFiles: context.runtimeInitialization.createdFiles,
29
30
  credentialStoreMode: context.wrapperConfig.credentialStoreMode,
30
31
  accountSelectionStrategy: context.wrapperConfig.accountSelectionStrategy,
32
+ accountSelectionStrategySource: context.wrapperConfig.accountSelectionStrategySource,
31
33
  experimentalSelection: context.wrapperConfig.experimentalSelection,
32
34
  codexBinaryPath: context.codexBinary.path,
33
35
  recursionGuardSource: context.executablePath,
@@ -93,23 +95,67 @@ export async function runRootCommand(context) {
93
95
  logger,
94
96
  registryFile: context.paths.registryFile,
95
97
  });
96
- if (context.wrapperConfig.accountSelectionStrategy === "remaining-limit-experimental") {
97
- logger.warn("selection.experimental_enabled", {
98
+ logger.info("selection.strategy_active", {
99
+ strategy: context.wrapperConfig.accountSelectionStrategy,
100
+ source: context.wrapperConfig.accountSelectionStrategySource,
101
+ });
102
+ if (context.wrapperConfig.accountSelectionStrategy === "remaining-limit" ||
103
+ context.wrapperConfig.accountSelectionStrategy === "remaining-limit-experimental") {
104
+ logger.info("selection.experimental_enabled", {
98
105
  endpoint: "https://chatgpt.com/backend-api/wham/usage",
99
106
  fallbackStrategy: "manual-default",
100
107
  timeoutMs: context.wrapperConfig.experimentalSelection.probeTimeoutMs,
101
108
  cacheTtlMs: context.wrapperConfig.experimentalSelection.cacheTtlMs,
102
109
  useAccountIdHeader: context.wrapperConfig.experimentalSelection.useAccountIdHeader,
110
+ source: context.wrapperConfig.accountSelectionStrategySource,
103
111
  });
104
112
  }
105
- const activeAccount = await selectAccountForExecution({
113
+ const selectionSummary = await resolveSelectionSummary({
106
114
  experimentalSelection: context.wrapperConfig.experimentalSelection,
107
115
  fetchImpl: fetch,
108
116
  logger,
117
+ mode: "execution",
109
118
  registry,
110
119
  selectionCacheFilePath: context.paths.selectionCacheFile,
111
120
  strategy: context.wrapperConfig.accountSelectionStrategy,
112
121
  });
122
+ const activeAccount = selectionSummary.selectedAccount;
123
+ if (!activeAccount || !selectionSummary.selectedBy) {
124
+ logger.error("selection.execution_summary_incomplete", {
125
+ strategy: selectionSummary.strategy,
126
+ fallbackReason: selectionSummary.fallbackReason,
127
+ executionBlockedReason: selectionSummary.executionBlockedReason,
128
+ });
129
+ throw new Error(selectionSummary.executionBlockedReason ?? "Execution selection did not resolve an account.");
130
+ }
131
+ const formattedSummary = formatSelectionSummary({
132
+ capabilities: {
133
+ stdoutIsTTY: context.output.stdoutIsTTY,
134
+ useColor: context.output.stdoutIsTTY,
135
+ },
136
+ logger,
137
+ summary: selectionSummary,
138
+ });
139
+ context.io.stdout.write(formattedSummary);
140
+ logger.info("summary_rendered", {
141
+ mode: selectionSummary.mode,
142
+ strategy: selectionSummary.strategy,
143
+ useColor: context.output.stdoutIsTTY,
144
+ selectedAccountId: activeAccount.id,
145
+ fallbackReason: selectionSummary.fallbackReason,
146
+ executionBlockedReason: selectionSummary.executionBlockedReason,
147
+ });
148
+ logger.info("selected_account_announced", {
149
+ accountId: activeAccount.id,
150
+ label: activeAccount.label,
151
+ selectedBy: selectionSummary.selectedBy,
152
+ });
153
+ if (selectionSummary.fallbackReason) {
154
+ logger.warn("fallback_announced", {
155
+ fallbackReason: selectionSummary.fallbackReason,
156
+ selectedAccountId: activeAccount.id,
157
+ });
158
+ }
113
159
  const lock = await acquireRuntimeLock({
114
160
  logger,
115
161
  runtimeRoot: context.paths.runtimeRoot,
@@ -168,8 +214,10 @@ function buildHelpText() {
168
214
  "",
169
215
  "Current status:",
170
216
  " Account management and default Codex passthrough are implemented.",
171
- " Selection strategies: manual-default, single-account, remaining-limit-experimental.",
172
- " Experimental mode probes https://chatgpt.com/backend-api/wham/usage and falls back to manual-default when ranking is unreliable.",
217
+ " Default selection strategy: remaining-limit.",
218
+ " Available overrides: manual-default, single-account, remaining-limit.",
219
+ " Legacy compatibility override: remaining-limit-experimental.",
220
+ " Remaining-limit mode probes https://chatgpt.com/backend-api/wham/usage and falls back to manual-default when ranking is unreliable.",
173
221
  ].join("\n");
174
222
  }
175
223
  //# sourceMappingURL=run-root-command.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"run-root-command.js","sourceRoot":"","sources":["../../../src/commands/root/run-root-command.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"run-root-command.js","sourceRoot":"","sources":["../../../src/commands/root/run-root-command.ts"],"names":[],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import type { Logger } from "../logging/logger.js";
2
2
  import type { ResolvedPaths } from "../core/paths.js";
3
3
  export type CredentialStoreMode = "file" | "keyring" | "auto" | "missing" | "unknown";
4
- export type AccountSelectionStrategy = "manual-default" | "single-account" | "remaining-limit-experimental";
4
+ export type AccountSelectionStrategy = "manual-default" | "single-account" | "remaining-limit" | "remaining-limit-experimental";
5
5
  export interface WrapperConfig {
6
6
  configFilePath: string;
7
7
  codexConfigFilePath: string;
@@ -9,6 +9,7 @@ export interface WrapperConfig {
9
9
  credentialStoreMode: CredentialStoreMode;
10
10
  credentialStorePolicyReason: string;
11
11
  accountSelectionStrategy: AccountSelectionStrategy;
12
+ accountSelectionStrategySource: "default" | "env-override" | "invalid-env-fallback";
12
13
  experimentalSelection: ExperimentalSelectionConfig;
13
14
  }
14
15
  export interface ExperimentalSelectionConfig {
@@ -4,6 +4,7 @@ const DEFAULT_EXPERIMENTAL_CACHE_TTL_MS = 60_000;
4
4
  export async function resolveWrapperConfig(input) {
5
5
  await mkdir(input.paths.dataRoot, { recursive: true });
6
6
  const credentialStoreMode = await detectCredentialStoreMode(input.paths.codexConfigFile, input.logger);
7
+ const selectionStrategy = resolveAccountSelectionStrategy(input.env, input.logger);
7
8
  const resolved = {
8
9
  configFilePath: input.paths.wrapperConfigFile,
9
10
  codexConfigFilePath: input.paths.codexConfigFile,
@@ -12,8 +13,13 @@ export async function resolveWrapperConfig(input) {
12
13
  credentialStorePolicyReason: credentialStoreMode === "file"
13
14
  ? "file mode detected in Codex config"
14
15
  : "codexes currently supports only file-backed auth storage",
15
- accountSelectionStrategy: resolveAccountSelectionStrategy(input.env),
16
- experimentalSelection: resolveExperimentalSelectionConfig(input.env, input.logger),
16
+ accountSelectionStrategy: selectionStrategy.strategy,
17
+ accountSelectionStrategySource: selectionStrategy.source,
18
+ experimentalSelection: resolveExperimentalSelectionConfig({
19
+ env: input.env,
20
+ logger: input.logger,
21
+ strategy: selectionStrategy.strategy,
22
+ }),
17
23
  };
18
24
  input.logger.info("wrapper_config.resolved", {
19
25
  configFilePath: resolved.configFilePath,
@@ -21,26 +27,28 @@ export async function resolveWrapperConfig(input) {
21
27
  selectionCacheFilePath: resolved.selectionCacheFilePath,
22
28
  credentialStoreMode: resolved.credentialStoreMode,
23
29
  accountSelectionStrategy: resolved.accountSelectionStrategy,
30
+ accountSelectionStrategySource: resolved.accountSelectionStrategySource,
24
31
  experimentalSelection: resolved.experimentalSelection,
25
32
  });
26
33
  return resolved;
27
34
  }
28
- function resolveExperimentalSelectionConfig(env, logger) {
35
+ function resolveExperimentalSelectionConfig(input) {
29
36
  const probeTimeoutMs = resolvePositiveIntegerEnv({
30
37
  defaultValue: DEFAULT_EXPERIMENTAL_PROBE_TIMEOUT_MS,
31
- env,
38
+ env: input.env,
32
39
  envKey: "CODEXES_EXPERIMENTAL_SELECTION_TIMEOUT_MS",
33
- logger,
40
+ logger: input.logger,
34
41
  });
35
42
  const cacheTtlMs = resolvePositiveIntegerEnv({
36
43
  defaultValue: DEFAULT_EXPERIMENTAL_CACHE_TTL_MS,
37
- env,
44
+ env: input.env,
38
45
  envKey: "CODEXES_EXPERIMENTAL_SELECTION_CACHE_TTL_MS",
39
- logger,
46
+ logger: input.logger,
40
47
  });
41
- const useAccountIdHeader = resolveBooleanEnv(env.CODEXES_EXPERIMENTAL_SELECTION_USE_ACCOUNT_ID_HEADER);
42
- const enabled = resolveAccountSelectionStrategy(env) === "remaining-limit-experimental";
43
- logger.debug("wrapper_config.experimental_selection_resolved", {
48
+ const useAccountIdHeader = resolveBooleanEnv(input.env.CODEXES_EXPERIMENTAL_SELECTION_USE_ACCOUNT_ID_HEADER);
49
+ const enabled = input.strategy === "remaining-limit" ||
50
+ input.strategy === "remaining-limit-experimental";
51
+ input.logger.debug("wrapper_config.experimental_selection_resolved", {
44
52
  enabled,
45
53
  probeTimeoutMs,
46
54
  cacheTtlMs,
@@ -53,18 +61,59 @@ function resolveExperimentalSelectionConfig(env, logger) {
53
61
  useAccountIdHeader,
54
62
  };
55
63
  }
56
- function resolveAccountSelectionStrategy(env) {
57
- switch (env.CODEXES_ACCOUNT_SELECTION_STRATEGY?.trim().toLowerCase()) {
64
+ function resolveAccountSelectionStrategy(env, logger) {
65
+ const rawOverride = env.CODEXES_ACCOUNT_SELECTION_STRATEGY?.trim().toLowerCase();
66
+ switch (rawOverride) {
58
67
  case "single-account":
59
- return "single-account";
68
+ logger.info("wrapper_config.selection_strategy_override_applied", {
69
+ envKey: "CODEXES_ACCOUNT_SELECTION_STRATEGY",
70
+ requestedStrategy: rawOverride,
71
+ resolvedStrategy: "single-account",
72
+ });
73
+ return {
74
+ source: "env-override",
75
+ strategy: "single-account",
76
+ };
77
+ case "remaining-limit":
60
78
  case "remaining-limit-experimental":
61
- return "remaining-limit-experimental";
62
- case "manual-default":
79
+ logger.info("wrapper_config.selection_strategy_override_applied", {
80
+ envKey: "CODEXES_ACCOUNT_SELECTION_STRATEGY",
81
+ requestedStrategy: rawOverride,
82
+ resolvedStrategy: "remaining-limit",
83
+ });
84
+ return {
85
+ source: "env-override",
86
+ strategy: "remaining-limit",
87
+ };
63
88
  case undefined:
64
89
  case "":
65
- return "manual-default";
90
+ logger.info("wrapper_config.selection_strategy_default_applied", {
91
+ defaultStrategy: "remaining-limit",
92
+ });
93
+ return {
94
+ source: "default",
95
+ strategy: "remaining-limit",
96
+ };
97
+ case "manual-default":
98
+ logger.info("wrapper_config.selection_strategy_override_applied", {
99
+ envKey: "CODEXES_ACCOUNT_SELECTION_STRATEGY",
100
+ requestedStrategy: rawOverride,
101
+ resolvedStrategy: "manual-default",
102
+ });
103
+ return {
104
+ source: "env-override",
105
+ strategy: "manual-default",
106
+ };
66
107
  default:
67
- return "manual-default";
108
+ logger.warn("wrapper_config.selection_strategy_invalid_override", {
109
+ envKey: "CODEXES_ACCOUNT_SELECTION_STRATEGY",
110
+ rawValue: rawOverride,
111
+ fallbackStrategy: "remaining-limit",
112
+ });
113
+ return {
114
+ source: "invalid-env-fallback",
115
+ strategy: "remaining-limit",
116
+ };
68
117
  }
69
118
  }
70
119
  async function detectCredentialStoreMode(configFile, logger) {
@@ -1 +1 @@
1
- {"version":3,"file":"wrapper-config.js","sourceRoot":"","sources":["../../src/config/wrapper-config.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"wrapper-config.js","sourceRoot":"","sources":["../../src/config/wrapper-config.ts"],"names":[],"mappings":"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"}
@@ -15,6 +15,9 @@ export interface AppContext {
15
15
  stdout: NodeJS.WriteStream;
16
16
  stderr: NodeJS.WriteStream;
17
17
  };
18
+ output: {
19
+ stdoutIsTTY: boolean;
20
+ };
18
21
  logging: {
19
22
  level: string;
20
23
  sink: ReturnType<typeof createLogSink>;
@@ -59,6 +59,9 @@ export async function buildAppContext(argv, io) {
59
59
  stdout: io.stdout,
60
60
  stderr: io.stderr,
61
61
  },
62
+ output: {
63
+ stdoutIsTTY: io.stdout.isTTY === true,
64
+ },
62
65
  logging: {
63
66
  level: logLevel,
64
67
  sink,
@@ -1 +1 @@
1
- {"version":3,"file":"context.js","sourceRoot":"","sources":["../../src/core/context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACpF,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,4BAA4B,EAAE,MAAM,uCAAuC,CAAC;AAwBrF,MAAM,CAAC,KAAK,UAAU,eAAe,CACnC,IAAc,EACd,EAMC;IAED,MAAM,QAAQ,GAAG,eAAe,CAAC,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACnD,MAAM,IAAI,GAAG,aAAa,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC;IACtC,MAAM,KAAK,GAAG,YAAY,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC;IAC3C,MAAM,qBAAqB,GAAG,MAAM,4BAA4B,CAAC;QAC/D,GAAG,EAAE,EAAE,CAAC,GAAG;QACX,MAAM,EAAE,YAAY,CAAC;YACnB,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,SAAS;YACf,IAAI;SACL,CAAC;QACF,KAAK;KACN,CAAC,CAAC;IACH,MAAM,aAAa,GAAG,MAAM,oBAAoB,CAAC;QAC/C,GAAG,EAAE,EAAE,CAAC,GAAG;QACX,MAAM,EAAE,YAAY,CAAC;YACnB,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,QAAQ;YACd,IAAI;SACL,CAAC;QACF,KAAK;KACN,CAAC,CAAC;IACH,MAAM,WAAW,GAAG,MAAM,eAAe,CAAC;QACxC,GAAG,EAAE,EAAE,CAAC,GAAG;QACX,MAAM,EAAE,YAAY,CAAC;YACnB,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,SAAS;YACf,IAAI;SACL,CAAC;QACF,qBAAqB,EAAE,EAAE,CAAC,cAAc;KACzC,CAAC,CAAC;IAEH,YAAY,CAAC;QACX,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS;QACf,IAAI;KACL,CAAC,CAAC,KAAK,CAAC,aAAa,EAAE;QACtB,IAAI;QACJ,GAAG,EAAE,EAAE,CAAC,GAAG;QACX,QAAQ;QACR,KAAK;QACL,qBAAqB;QACrB,aAAa;QACb,WAAW;KACZ,CAAC,CAAC;IAEH,OAAO;QACL,IAAI;QACJ,cAAc,EAAE,EAAE,CAAC,cAAc;QACjC,WAAW,EAAE;YACX,GAAG,EAAE,EAAE,CAAC,GAAG;YACX,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,OAAO,EAAE,OAAO,CAAC,OAAO;SACzB;QACD,EAAE,EAAE;YACF,MAAM,EAAE,EAAE,CAAC,MAAM;YACjB,MAAM,EAAE,EAAE,CAAC,MAAM;SAClB;QACD,OAAO,EAAE;YACP,KAAK,EAAE,QAAQ;YACf,IAAI;SACL;QACD,KAAK;QACL,qBAAqB;QACrB,aAAa;QACb,WAAW;KACZ,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"context.js","sourceRoot":"","sources":["../../src/core/context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACpF,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,4BAA4B,EAAE,MAAM,uCAAuC,CAAC;AA2BrF,MAAM,CAAC,KAAK,UAAU,eAAe,CACnC,IAAc,EACd,EAMC;IAED,MAAM,QAAQ,GAAG,eAAe,CAAC,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACnD,MAAM,IAAI,GAAG,aAAa,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC;IACtC,MAAM,KAAK,GAAG,YAAY,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC;IAC3C,MAAM,qBAAqB,GAAG,MAAM,4BAA4B,CAAC;QAC/D,GAAG,EAAE,EAAE,CAAC,GAAG;QACX,MAAM,EAAE,YAAY,CAAC;YACnB,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,SAAS;YACf,IAAI;SACL,CAAC;QACF,KAAK;KACN,CAAC,CAAC;IACH,MAAM,aAAa,GAAG,MAAM,oBAAoB,CAAC;QAC/C,GAAG,EAAE,EAAE,CAAC,GAAG;QACX,MAAM,EAAE,YAAY,CAAC;YACnB,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,QAAQ;YACd,IAAI;SACL,CAAC;QACF,KAAK;KACN,CAAC,CAAC;IACH,MAAM,WAAW,GAAG,MAAM,eAAe,CAAC;QACxC,GAAG,EAAE,EAAE,CAAC,GAAG;QACX,MAAM,EAAE,YAAY,CAAC;YACnB,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,SAAS;YACf,IAAI;SACL,CAAC;QACF,qBAAqB,EAAE,EAAE,CAAC,cAAc;KACzC,CAAC,CAAC;IAEH,YAAY,CAAC;QACX,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS;QACf,IAAI;KACL,CAAC,CAAC,KAAK,CAAC,aAAa,EAAE;QACtB,IAAI;QACJ,GAAG,EAAE,EAAE,CAAC,GAAG;QACX,QAAQ;QACR,KAAK;QACL,qBAAqB;QACrB,aAAa;QACb,WAAW;KACZ,CAAC,CAAC;IAEH,OAAO;QACL,IAAI;QACJ,cAAc,EAAE,EAAE,CAAC,cAAc;QACjC,WAAW,EAAE;YACX,GAAG,EAAE,EAAE,CAAC,GAAG;YACX,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,OAAO,EAAE,OAAO,CAAC,OAAO;SACzB;QACD,EAAE,EAAE;YACF,MAAM,EAAE,EAAE,CAAC,MAAM;YACjB,MAAM,EAAE,EAAE,CAAC,MAAM;SAClB;QACD,MAAM,EAAE;YACN,WAAW,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,KAAK,IAAI;SACtC;QACD,OAAO,EAAE;YACP,KAAK,EAAE,QAAQ;YACf,IAAI;SACL;QACD,KAAK;QACL,qBAAqB;QACrB,aAAa;QACb,WAAW;KACZ,CAAC;AACJ,CAAC"}
@@ -0,0 +1,12 @@
1
+ import type { Logger } from "../logging/logger.js";
2
+ import type { SelectionSummary } from "./selection-summary.js";
3
+ interface SummaryRenderCapabilities {
4
+ stdoutIsTTY: boolean;
5
+ useColor: boolean;
6
+ }
7
+ export declare function formatSelectionSummary(input: {
8
+ capabilities: SummaryRenderCapabilities;
9
+ logger: Logger;
10
+ summary: SelectionSummary;
11
+ }): string;
12
+ export {};
@@ -0,0 +1,182 @@
1
+ export function formatSelectionSummary(input) {
2
+ const renderMode = input.capabilities.useColor ? "color" : "plain";
3
+ input.logger.debug("selection.format_summary.start", {
4
+ mode: input.summary.mode,
5
+ strategy: input.summary.strategy,
6
+ entryCount: input.summary.entries.length,
7
+ stdoutIsTTY: input.capabilities.stdoutIsTTY,
8
+ useColor: input.capabilities.useColor,
9
+ renderMode,
10
+ fallbackReason: input.summary.fallbackReason,
11
+ selectedAccountId: input.summary.selectedAccount?.id ?? null,
12
+ executionBlockedReason: input.summary.executionBlockedReason,
13
+ });
14
+ const lines = [
15
+ "Account selection summary:",
16
+ ...input.summary.entries.map((entry) => formatSelectionEntry(entry, input.capabilities)),
17
+ ];
18
+ if (input.summary.selectedAccount && input.summary.selectedBy) {
19
+ lines.push(`Selected account: ${input.summary.selectedAccount.label} (${input.summary.selectedAccount.id}) via ${describeSelectionMode(input.summary)}.`);
20
+ }
21
+ else {
22
+ lines.push("Selected account: unavailable for execution.");
23
+ }
24
+ if (input.summary.fallbackReason) {
25
+ lines.push(`Fallback: ${describeFallback(input.summary.fallbackReason)}.`);
26
+ }
27
+ if (input.summary.executionBlockedReason) {
28
+ lines.push(`Execution note: ${input.summary.executionBlockedReason}`);
29
+ }
30
+ input.logger.debug("selection.format_summary.complete", {
31
+ mode: input.summary.mode,
32
+ strategy: input.summary.strategy,
33
+ renderMode,
34
+ lineCount: lines.length,
35
+ fallbackIncluded: input.summary.fallbackReason !== null,
36
+ selectedAccountId: input.summary.selectedAccount?.id ?? null,
37
+ executionBlockedReason: input.summary.executionBlockedReason,
38
+ });
39
+ return `${lines.join("\n")}\n`;
40
+ }
41
+ function formatSelectionEntry(entry, capabilities) {
42
+ const tags = [
43
+ entry.isSelected ? "selected" : null,
44
+ entry.isDefault ? "default" : null,
45
+ entry.rankingPosition !== null ? `rank #${entry.rankingPosition}` : null,
46
+ ]
47
+ .filter((value) => value !== null)
48
+ .join(", ");
49
+ const status = entry.snapshot?.status ?? (entry.failureCategory ? "probe-failed" : "not-probed");
50
+ const detail = entry.failureMessage ??
51
+ entry.snapshot?.statusReason ??
52
+ "usage probing was not required for this strategy";
53
+ return [
54
+ "-",
55
+ `${entry.account.label} (${entry.account.id})`,
56
+ tags ? colorize(capabilities, "tag", `[${tags}]`) : null,
57
+ colorize(capabilities, mapStatusTone(status), `status=${status}`),
58
+ formatWindowMetric(capabilities, "5h", entry.snapshot?.dailyRemaining ?? null),
59
+ formatWindowMetric(capabilities, "weekly", entry.snapshot?.weeklyRemaining ?? null),
60
+ entry.snapshot?.plan
61
+ ? `${colorize(capabilities, "plan", "plan")}=${colorize(capabilities, "planValue", entry.snapshot.plan)}`
62
+ : null,
63
+ colorize(capabilities, "source", `source=${entry.source}`),
64
+ `detail=${describeDetailMarker(entry, detail)}`,
65
+ ]
66
+ .filter((value) => value !== null)
67
+ .join(" ");
68
+ }
69
+ function formatPercent(value) {
70
+ return value === null ? "unknown" : `${trimTrailingZeroes(value)}%`;
71
+ }
72
+ function formatWindowMetric(capabilities, label, value) {
73
+ const renderedPercent = colorize(capabilities, mapRemainingTone(value), formatPercent(value));
74
+ return `${colorize(capabilities, "windowLabel", label)}=${renderedPercent}`;
75
+ }
76
+ function describeSelectionMode(summary) {
77
+ if (summary.selectedBy === null) {
78
+ return "no execution selection";
79
+ }
80
+ switch (summary.selectedBy) {
81
+ case "experimental-ranked":
82
+ return "remaining-limit";
83
+ case "single-account":
84
+ return "single-account";
85
+ case "manual-default":
86
+ return "manual-default";
87
+ case "manual-default-fallback-single":
88
+ return summary.fallbackReason
89
+ ? "manual-default fallback because only one account was available"
90
+ : "manual-default because only one account is configured";
91
+ }
92
+ }
93
+ function describeFallback(reason) {
94
+ switch (reason) {
95
+ case "experimental-config-missing":
96
+ return "remaining-limit probing was unavailable, so codexes fell back to manual-default";
97
+ case "all-probes-failed":
98
+ return "every account probe failed, so codexes could not establish a reliable execution winner";
99
+ case "mixed-probe-outcomes":
100
+ return "some account probes failed, so codexes could not establish a reliable execution winner";
101
+ case "all-accounts-exhausted":
102
+ return "all probed accounts were exhausted, so codexes could not establish a reliable execution winner";
103
+ case "ambiguous-usage":
104
+ return "the usage data was incomplete or ambiguous, so codexes could not establish a reliable execution winner";
105
+ case null:
106
+ return "no fallback was required";
107
+ }
108
+ }
109
+ function describeDetailMarker(entry, detail) {
110
+ if (entry.failureCategory === "timeout") {
111
+ return "probe-timeout";
112
+ }
113
+ if (entry.failureCategory === "http-error") {
114
+ return "http-error";
115
+ }
116
+ if (entry.failureCategory === "auth-missing") {
117
+ return "auth-missing";
118
+ }
119
+ if (entry.failureCategory === "invalid-response") {
120
+ return "invalid-response";
121
+ }
122
+ switch (entry.snapshot?.status) {
123
+ case "usable":
124
+ return "rankable";
125
+ case "limit-reached":
126
+ return "exhausted";
127
+ case "not-allowed":
128
+ return "blocked";
129
+ case "missing-usage-data":
130
+ return "incomplete";
131
+ default:
132
+ return detail.includes("not required") ? "not-probed" : "diagnostic";
133
+ }
134
+ }
135
+ function mapStatusTone(status) {
136
+ switch (status) {
137
+ case "usable":
138
+ return "success";
139
+ case "limit-reached":
140
+ return "warning";
141
+ case "probe-failed":
142
+ case "not-allowed":
143
+ return "error";
144
+ default:
145
+ return "muted";
146
+ }
147
+ }
148
+ function colorize(capabilities, tone, value) {
149
+ if (!capabilities.useColor) {
150
+ return value;
151
+ }
152
+ const open = ANSI_CODES[tone];
153
+ return `${open}${value}${ANSI_RESET}`;
154
+ }
155
+ function mapRemainingTone(value) {
156
+ if (value === null) {
157
+ return "muted";
158
+ }
159
+ if (value <= 20) {
160
+ return "error";
161
+ }
162
+ if (value <= 50) {
163
+ return "warning";
164
+ }
165
+ return "success";
166
+ }
167
+ function trimTrailingZeroes(value) {
168
+ return value.toFixed(2).replace(/\.00$/, "").replace(/(\.\d)0$/, "$1");
169
+ }
170
+ const ANSI_RESET = "\u001b[0m";
171
+ const ANSI_CODES = {
172
+ source: "\u001b[36m",
173
+ success: "\u001b[32m",
174
+ muted: "\u001b[90m",
175
+ warning: "\u001b[33m",
176
+ error: "\u001b[31m",
177
+ tag: "\u001b[1m",
178
+ windowLabel: "\u001b[94m",
179
+ plan: "\u001b[95m",
180
+ planValue: "\u001b[1;95m",
181
+ };
182
+ //# sourceMappingURL=format-selection-summary.js.map