@xyo-network/xl1-cli-lib 3.0.1 → 3.0.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.
- package/dist/node/commands/start/startCommand.d.ts +2 -2
- package/dist/node/commands/start/startCommand.d.ts.map +1 -1
- package/dist/node/configMiddleware.d.ts.map +1 -1
- package/dist/node/index.mjs +109 -72
- package/dist/node/index.mjs.map +3 -3
- package/dist/node/runCli.d.ts.map +1 -1
- package/dist/node/xl1.mjs +109 -72
- package/dist/node/xl1.mjs.map +3 -3
- package/package.json +41 -40
package/dist/node/xl1.mjs
CHANGED
|
@@ -11,25 +11,22 @@ import { finalizerCommand } from "@xyo-network/chain-finalizer";
|
|
|
11
11
|
import { indexerCommand } from "@xyo-network/chain-indexer";
|
|
12
12
|
import { mempoolCommand } from "@xyo-network/chain-mempool";
|
|
13
13
|
import {
|
|
14
|
+
assembleRunConfig,
|
|
14
15
|
contextFromConfigWithoutLocator,
|
|
15
16
|
detectDerivationPathCollisions,
|
|
16
17
|
formatWalletReport,
|
|
18
|
+
getActorSliceFromRun,
|
|
17
19
|
initializeResolvedWalletReport,
|
|
18
|
-
|
|
20
|
+
locatorFromConfig,
|
|
19
21
|
Orchestrator,
|
|
20
|
-
|
|
22
|
+
splitRunConfig
|
|
21
23
|
} from "@xyo-network/chain-orchestration";
|
|
22
|
-
import { initHealthEndpoints } from "@xyo-network/chain-orchestration-express";
|
|
23
24
|
import { producerCommand } from "@xyo-network/chain-producer";
|
|
24
25
|
import { rewardRedemptionCommand } from "@xyo-network/chain-reward-redemption";
|
|
25
|
-
import {
|
|
26
|
-
|
|
27
|
-
ConfigZod as ConfigZod2,
|
|
28
|
-
DefaultMetricsScrapePorts
|
|
29
|
-
} from "@xyo-network/xl1-sdk";
|
|
26
|
+
import { DefaultMetricsScrapePorts } from "@xyo-network/xl1-sdk";
|
|
27
|
+
import { HttpSystemStatusPublisher } from "@xyo-network/xl1-system-status";
|
|
30
28
|
import yargs from "yargs";
|
|
31
29
|
import { hideBin } from "yargs/helpers";
|
|
32
|
-
import { z } from "zod/mini";
|
|
33
30
|
|
|
34
31
|
// src/commands/start/startCommand.ts
|
|
35
32
|
import { getApiActor } from "@xyo-network/chain-api";
|
|
@@ -103,9 +100,9 @@ async function buildActor(name, locator, configuration2) {
|
|
|
103
100
|
}
|
|
104
101
|
}
|
|
105
102
|
}
|
|
106
|
-
async function bootActors(requestedActors,
|
|
103
|
+
async function bootActors(requestedActors, locator, orchestrator, configuration2) {
|
|
107
104
|
const startedAt = Date.now();
|
|
108
|
-
const actors = await Promise.all(requestedActors.map((name) => buildActor(name,
|
|
105
|
+
const actors = await Promise.all(requestedActors.map((name) => buildActor(name, locator, configuration2)));
|
|
109
106
|
for (const actor of actors) {
|
|
110
107
|
await orchestrator.registerActor(actor);
|
|
111
108
|
}
|
|
@@ -114,7 +111,7 @@ async function bootActors(requestedActors, locators, orchestrator, configuration
|
|
|
114
111
|
const ms = Date.now() - startedAt;
|
|
115
112
|
initLogger(configuration2).info(`[xl1] system ready (${requestedActors.join("/")} in ${ms}ms)`);
|
|
116
113
|
}
|
|
117
|
-
function startCommand(getConfiguration2,
|
|
114
|
+
function startCommand(getConfiguration2, getLocatorFromConfig2) {
|
|
118
115
|
return {
|
|
119
116
|
command: ["start [actors..]", "$0"],
|
|
120
117
|
describe: "Run a full XL1 Node",
|
|
@@ -135,8 +132,8 @@ function startCommand(getConfiguration2, getLocatorsFromConfig2) {
|
|
|
135
132
|
handler: async (argv) => {
|
|
136
133
|
const configuration2 = getConfiguration2();
|
|
137
134
|
const requestedActors = argv.actors !== void 0 && argv.actors.length > 0 ? argv.actors : getActorsFromConfig(configuration2) ?? getDefaultActors();
|
|
138
|
-
const {
|
|
139
|
-
await bootActors(requestedActors,
|
|
135
|
+
const { locator, orchestrator } = await getLocatorFromConfig2(requestedActors, configuration2);
|
|
136
|
+
await bootActors(requestedActors, locator, orchestrator, configuration2);
|
|
140
137
|
}
|
|
141
138
|
};
|
|
142
139
|
}
|
|
@@ -168,19 +165,45 @@ import {
|
|
|
168
165
|
stripOrchestrationOnlyConnections,
|
|
169
166
|
tryParseConfig
|
|
170
167
|
} from "@xyo-network/chain-orchestration";
|
|
171
|
-
import {
|
|
172
|
-
ConfigZod,
|
|
173
|
-
isZodError,
|
|
174
|
-
resolveConfig
|
|
175
|
-
} from "@xyo-network/xl1-sdk";
|
|
168
|
+
import { isZodError } from "@xyo-network/xl1-sdk";
|
|
176
169
|
var deepMerge = createDeepMerge({ arrayStrategy: "concat" });
|
|
177
170
|
var REDACTED = "[REDACTED]";
|
|
178
171
|
var REDACTED_KEY_NAMES = /* @__PURE__ */ new Set(["mnemonic", "connectionString"]);
|
|
179
172
|
var REDACTED_KEY_SUFFIX = /(PrivateKey|Secret|Password)$/i;
|
|
173
|
+
var CONNECTION_NAME_ALIASES = {
|
|
174
|
+
chainMongo: "chain-mongo",
|
|
175
|
+
defaultEvmRpc: "default-evm-rpc",
|
|
176
|
+
defaultRpc: "default-rpc",
|
|
177
|
+
localStore: "local-store",
|
|
178
|
+
restChainState: "rest-chain-state",
|
|
179
|
+
restFinalized: "rest-finalized",
|
|
180
|
+
restIndex: "rest-index",
|
|
181
|
+
s3ChainState: "s3-chain-state",
|
|
182
|
+
s3Finalized: "s3-finalized",
|
|
183
|
+
s3Index: "s3-index"
|
|
184
|
+
};
|
|
185
|
+
var CLI_ONLY_ARG_KEYS = /* @__PURE__ */ new Set([
|
|
186
|
+
"$0",
|
|
187
|
+
"_",
|
|
188
|
+
"config",
|
|
189
|
+
"dump-config",
|
|
190
|
+
"dumpConfig",
|
|
191
|
+
"dump-providers",
|
|
192
|
+
"dumpProviders",
|
|
193
|
+
"selected-actors",
|
|
194
|
+
"selectedActors",
|
|
195
|
+
"skip-insecure-confirm",
|
|
196
|
+
"skipInsecureConfirm",
|
|
197
|
+
"with-secrets",
|
|
198
|
+
"withSecrets"
|
|
199
|
+
]);
|
|
180
200
|
function shouldRedactKey(key) {
|
|
181
201
|
if (REDACTED_KEY_NAMES.has(key)) return true;
|
|
182
202
|
return REDACTED_KEY_SUFFIX.test(key);
|
|
183
203
|
}
|
|
204
|
+
function isRecord(value) {
|
|
205
|
+
return typeof value === "object" && value !== null;
|
|
206
|
+
}
|
|
184
207
|
function redactConfig(config2) {
|
|
185
208
|
const cloned = structuredClone(config2);
|
|
186
209
|
redactInPlace(cloned);
|
|
@@ -212,45 +235,67 @@ function coerceActorsArray(argv) {
|
|
|
212
235
|
for (const [key, value] of numericEntries) asArray[key] = value;
|
|
213
236
|
return { ...argv, actors: asArray };
|
|
214
237
|
}
|
|
215
|
-
function
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
238
|
+
function canonicalConnectionName(name) {
|
|
239
|
+
return CONNECTION_NAME_ALIASES[name] ?? name;
|
|
240
|
+
}
|
|
241
|
+
function normalizeConnectionNames(config2) {
|
|
242
|
+
const normalized = { ...config2 };
|
|
243
|
+
const connections = normalized.connections;
|
|
244
|
+
if (isRecord(connections)) {
|
|
245
|
+
const normalizedConnections = {};
|
|
246
|
+
for (const [name, connection] of Object.entries(connections)) {
|
|
247
|
+
normalizedConnections[canonicalConnectionName(name)] = connection;
|
|
248
|
+
}
|
|
249
|
+
normalized.connections = normalizedConnections;
|
|
250
|
+
}
|
|
251
|
+
const providerBindings = normalized.providerBindings;
|
|
252
|
+
if (isRecord(providerBindings)) {
|
|
253
|
+
const normalizedBindings = {};
|
|
254
|
+
for (const [moniker, binding] of Object.entries(providerBindings)) {
|
|
255
|
+
if (!isRecord(binding)) {
|
|
256
|
+
normalizedBindings[moniker] = binding;
|
|
257
|
+
continue;
|
|
258
|
+
}
|
|
259
|
+
normalizedBindings[moniker] = {
|
|
260
|
+
...binding,
|
|
261
|
+
...typeof binding.connection === "string" && { connection: canonicalConnectionName(binding.connection) },
|
|
262
|
+
...typeof binding.transport === "string" && { transport: canonicalConnectionName(binding.transport) }
|
|
263
|
+
};
|
|
264
|
+
}
|
|
265
|
+
normalized.providerBindings = normalizedBindings;
|
|
266
|
+
}
|
|
267
|
+
return normalized;
|
|
268
|
+
}
|
|
269
|
+
function stripCliOnlyArgs(argv) {
|
|
270
|
+
const stripped = {};
|
|
271
|
+
for (const [key, value] of Object.entries(argv)) {
|
|
272
|
+
if (!CLI_ONLY_ARG_KEYS.has(key)) stripped[key] = value;
|
|
273
|
+
}
|
|
274
|
+
return stripped;
|
|
219
275
|
}
|
|
220
276
|
async function buildFinalConfig(argv) {
|
|
221
277
|
const configPath = argv.config;
|
|
222
|
-
const parsedConfigFileRaw = await tryParseConfig({ configPath });
|
|
278
|
+
const parsedConfigFileRaw = normalizeConnectionNames(await tryParseConfig({ configPath, finalize: false }));
|
|
223
279
|
const rootMnemonicFromFile = typeof parsedConfigFileRaw.mnemonic === "string" ? parsedConfigFileRaw.mnemonic : void 0;
|
|
224
|
-
const normalizedArgv = coerceActorsArray(argv);
|
|
225
|
-
const
|
|
226
|
-
const
|
|
280
|
+
const normalizedArgv = normalizeConnectionNames(coerceActorsArray(argv));
|
|
281
|
+
const configArgs = stripCliOnlyArgs(normalizedArgv);
|
|
282
|
+
const argsForSdk = stripOrchestrationOnlyConnections(configArgs);
|
|
283
|
+
const parsedConfigArgs = argsForSdk.actors !== void 0 || argsForSdk.connections !== void 0 || argsForSdk.providerBindings !== void 0 ? argsForSdk : {};
|
|
227
284
|
const rootMnemonicFromArgs = typeof normalizedArgv.mnemonic === "string" ? normalizedArgv.mnemonic : void 0;
|
|
228
285
|
const parsedFileRecord = parsedConfigFileRaw;
|
|
229
286
|
let fileForMerge = parsedFileRecord;
|
|
230
|
-
const argvActors =
|
|
287
|
+
const argvActors = configArgs.actors;
|
|
231
288
|
if (Array.isArray(argvActors) && argvActors.length > 0) {
|
|
232
289
|
const { actors: _dropped, ...rest } = parsedFileRecord;
|
|
233
290
|
fileForMerge = rest;
|
|
234
291
|
}
|
|
235
292
|
const rawMerged = deepMerge(fileForMerge, parsedConfigArgs);
|
|
236
293
|
const mergedForSdk = stripOrchestrationOnlyConnections(rawMerged);
|
|
237
|
-
const mergedConfig = safeParseOrThrow(mergedForSdk);
|
|
238
294
|
const rootMnemonic = rootMnemonicFromArgs ?? rootMnemonicFromFile;
|
|
239
|
-
|
|
240
|
-
...
|
|
295
|
+
return finalizeConfig({
|
|
296
|
+
...mergedForSdk,
|
|
241
297
|
...isDefined2(rootMnemonic) && { mnemonic: rootMnemonic }
|
|
242
298
|
});
|
|
243
|
-
const strippedForResolve = stripOrchestrationOnlyConnections(finalized);
|
|
244
|
-
const preResolve = safeParseOrThrow(strippedForResolve);
|
|
245
|
-
const resolved = resolveConfig(preResolve);
|
|
246
|
-
const strippedResolved = stripOrchestrationOnlyConnections(resolved);
|
|
247
|
-
const validated = safeParseOrThrow(strippedResolved);
|
|
248
|
-
const toFinalize = {
|
|
249
|
-
...validated,
|
|
250
|
-
...isDefined2(rootMnemonic) && { mnemonic: rootMnemonic }
|
|
251
|
-
};
|
|
252
|
-
const finalWithConnections = finalizeConfig(toFinalize);
|
|
253
|
-
return finalWithConnections;
|
|
254
299
|
}
|
|
255
300
|
async function configMiddleware(argv, setConfiguration) {
|
|
256
301
|
try {
|
|
@@ -456,7 +501,7 @@ function defaultScrapePortForActors(actors) {
|
|
|
456
501
|
var configuration;
|
|
457
502
|
var skipInsecureConfirm = false;
|
|
458
503
|
var dumpProviders = false;
|
|
459
|
-
var version = isDefined3("3.0.
|
|
504
|
+
var version = isDefined3("3.0.2") ? "3.0.2" : "unknown";
|
|
460
505
|
function getConfiguration() {
|
|
461
506
|
return configuration;
|
|
462
507
|
}
|
|
@@ -472,49 +517,39 @@ async function promptForInsecureGenesisConfirmation(logger) {
|
|
|
472
517
|
rl.close();
|
|
473
518
|
}
|
|
474
519
|
}
|
|
475
|
-
async function
|
|
476
|
-
const actorConfigs =
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
} else {
|
|
482
|
-
const actorConfig = z.looseObject(ActorConfigZod.shape).parse({ name: actorName });
|
|
483
|
-
actorConfigs.push(actorConfig);
|
|
484
|
-
}
|
|
485
|
-
}
|
|
486
|
-
const fullConfig = { ...configuration2, actors: actorConfigs };
|
|
487
|
-
const configForSdk = stripOrchestrationOnlyConnections2(fullConfig);
|
|
488
|
-
const config2 = ConfigZod2.parse(configForSdk);
|
|
520
|
+
async function getLocatorFromConfig(actors, configuration2) {
|
|
521
|
+
const actorConfigs = actors.map((actorName) => {
|
|
522
|
+
return getActorSliceFromRun(configuration2, actorName);
|
|
523
|
+
});
|
|
524
|
+
const { process: processConfig } = splitRunConfig(configuration2);
|
|
525
|
+
const fullConfig = assembleRunConfig(processConfig, actorConfigs, configuration2.mnemonic);
|
|
489
526
|
const logger = initLogger(configuration2);
|
|
490
527
|
const orchestrator = await Orchestrator.create({ logger });
|
|
491
|
-
const collision = detectDerivationPathCollisions(actors,
|
|
528
|
+
const collision = detectDerivationPathCollisions(actors, fullConfig);
|
|
492
529
|
if (collision) throw collision;
|
|
493
|
-
const walletReport = await initializeResolvedWalletReport(actors,
|
|
530
|
+
const walletReport = await initializeResolvedWalletReport(actors, fullConfig);
|
|
494
531
|
logger.info(formatWalletReport(walletReport));
|
|
495
532
|
const serviceName = actors.length === 1 ? `xl1-${actors[0]}` : "xl1-cli";
|
|
496
|
-
const context = await contextFromConfigWithoutLocator(
|
|
533
|
+
const context = await contextFromConfigWithoutLocator(fullConfig, logger, serviceName, version, defaultScrapePortForActors(actors));
|
|
497
534
|
if (skipInsecureConfirm) {
|
|
498
535
|
logger.warn("Insecure genesis reward wallet is active. Interactive confirmation skipped via --skip-insecure-confirm.");
|
|
499
536
|
}
|
|
500
537
|
const onInsecureGenesisConfirm = skipInsecureConfirm ? void 0 : async () => await promptForInsecureGenesisConfirmation(logger);
|
|
501
|
-
const
|
|
538
|
+
const locator = await locatorFromConfig(context, fullConfig, onInsecureGenesisConfirm);
|
|
502
539
|
if (dumpProviders) {
|
|
503
|
-
console.log(formatProviderTree(
|
|
540
|
+
console.log(formatProviderTree(Object.fromEntries(actors.map((name) => [name, locator]))));
|
|
504
541
|
process.exit(0);
|
|
505
542
|
}
|
|
506
543
|
const healthCheckPort = configuration2.healthCheckPort ?? DEFAULT_HEALTH_CHECK_PORT;
|
|
507
|
-
const
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
readiness: orchestrator,
|
|
511
|
-
statusMonitor: context.statusReporter
|
|
512
|
-
}) : void 0;
|
|
544
|
+
const statusReporter = context.statusReporter;
|
|
545
|
+
const statusHttpPublisher = healthCheckPort > 0 && statusReporter !== void 0 ? new HttpSystemStatusPublisher(statusReporter, { logger, port: healthCheckPort }) : void 0;
|
|
546
|
+
await statusHttpPublisher?.start();
|
|
513
547
|
process.on("SIGINT", () => {
|
|
514
548
|
void (async () => {
|
|
515
549
|
try {
|
|
516
550
|
logger.log("\nSIGINT received. Attempting graceful shutdown...");
|
|
517
|
-
|
|
551
|
+
statusReporter?.setShuttingDown(true);
|
|
552
|
+
await statusHttpPublisher?.stop();
|
|
518
553
|
await orchestrator?.stop();
|
|
519
554
|
logger.log("Orchestrator stopped, exiting now.");
|
|
520
555
|
process.exit(0);
|
|
@@ -524,7 +559,7 @@ async function getLocatorsFromConfig(actors, configuration2) {
|
|
|
524
559
|
}
|
|
525
560
|
})();
|
|
526
561
|
});
|
|
527
|
-
return {
|
|
562
|
+
return { locator, orchestrator };
|
|
528
563
|
}
|
|
529
564
|
async function runCLI() {
|
|
530
565
|
const y = yargs(hideBin(process.argv));
|
|
@@ -539,15 +574,17 @@ $0 <command> [options]`).parserConfiguration({
|
|
|
539
574
|
// foo.bar → { foo: { bar } }
|
|
540
575
|
"parse-numbers": false,
|
|
541
576
|
// Don't auto-parse numbers to allow strings like "0x1"
|
|
542
|
-
"populate--": true
|
|
577
|
+
"populate--": true,
|
|
543
578
|
// Populate -- with all options so we can detected user-supplied vs defaults
|
|
579
|
+
"strip-aliased": true
|
|
580
|
+
// drop alias keys (c, h, …) so only canonical names reach argv and the config merge
|
|
544
581
|
}).env("XL1").scriptName("xl1").middleware(async (argv2) => {
|
|
545
582
|
await configMiddleware(argv2, (config2) => {
|
|
546
583
|
configuration = config2;
|
|
547
584
|
});
|
|
548
585
|
skipInsecureConfirm = Boolean(argv2["skip-insecure-confirm"]);
|
|
549
586
|
dumpProviders = Boolean(argv2["dump-providers"]);
|
|
550
|
-
}).options(optionsFromGlobalZodRegistry()).wrap(y.terminalWidth()).command(withDeprecationWarning(apiCommand(getConfiguration,
|
|
587
|
+
}).options(optionsFromGlobalZodRegistry()).wrap(y.terminalWidth()).command(withDeprecationWarning(apiCommand(getConfiguration, getLocatorFromConfig))).command(withDeprecationWarning(bridgeCommand(getConfiguration, getLocatorFromConfig))).command(withDeprecationWarning(finalizerCommand(getConfiguration, getLocatorFromConfig))).command(withDeprecationWarning(indexerCommand(getConfiguration, getLocatorFromConfig))).command(withDeprecationWarning(mempoolCommand(getConfiguration, getLocatorFromConfig))).command(withDeprecationWarning(producerCommand(getConfiguration, getLocatorFromConfig))).command(withDeprecationWarning(rewardRedemptionCommand(getConfiguration, getLocatorFromConfig))).command(startCommand(getConfiguration, getLocatorFromConfig)).options({
|
|
551
588
|
"config": {
|
|
552
589
|
type: "string",
|
|
553
590
|
description: "Path to a config file to use instead of the default search.",
|
package/dist/node/xl1.mjs.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/start.ts", "../../src/runCli.ts", "../../src/commands/start/startCommand.ts", "../../src/initLogger.ts", "../../src/commands/withDeprecationWarning.ts", "../../src/configMiddleware.ts", "../../src/dumpProviders.ts", "../../src/images.ts", "../../src/optionsFromGlobalZodRegistry.ts", "../../src/xl1.ts"],
|
|
4
|
-
"sourcesContent": ["import { config } from 'dotenv'\n\nimport { runCLI } from './runCli.ts'\n\nexport const start = async () => {\n config({ quiet: true })\n await runCLI()\n}\n", "import { stdin as input, stdout as output } from 'node:process'\nimport { createInterface } from 'node:readline/promises'\n\nimport { isDefined } from '@xylabs/sdk-js'\nimport { apiCommand } from '@xyo-network/chain-api'\nimport { bridgeCommand } from '@xyo-network/chain-bridge'\nimport { finalizerCommand } from '@xyo-network/chain-finalizer'\nimport { indexerCommand } from '@xyo-network/chain-indexer'\nimport { mempoolCommand } from '@xyo-network/chain-mempool'\nimport {\n type ConfigWithMnemonic,\n contextFromConfigWithoutLocator, detectDerivationPathCollisions, formatWalletReport, initializeResolvedWalletReport,\n locatorsFromConfig, Orchestrator, stripOrchestrationOnlyConnections,\n} from '@xyo-network/chain-orchestration'\nimport { initHealthEndpoints } from '@xyo-network/chain-orchestration-express'\nimport { producerCommand } from '@xyo-network/chain-producer'\nimport { rewardRedemptionCommand } from '@xyo-network/chain-reward-redemption'\nimport type { ActorConfig, Config } from '@xyo-network/xl1-sdk'\nimport {\n ActorConfigZod, ConfigZod, DefaultMetricsScrapePorts,\n} from '@xyo-network/xl1-sdk'\nimport type { Argv } from 'yargs'\nimport yargs from 'yargs'\nimport { hideBin } from 'yargs/helpers'\nimport { z } from 'zod/mini'\n\nimport { startCommand, withDeprecationWarning } from './commands/index.ts'\nimport { configMiddleware } from './configMiddleware.ts'\nimport { formatProviderTree } from './dumpProviders.ts'\nimport { XL1LogoColorizedAscii } from './images.ts'\nimport { initLogger } from './initLogger.ts'\nimport { optionsFromGlobalZodRegistry } from './optionsFromGlobalZodRegistry.ts'\n\n/** Version string injected by Rolldown at build time. */\ndeclare const __VERSION__: string\n\nconst DEFAULT_HEALTH_CHECK_PORT = 9099\n\n/**\n * Maps a CLI actor name to its registered Prometheus scrape port. The CLI-level\n * exporter (one per process) defaults to the port of the first requested actor\n * so that running, e.g., `xl1 start producer` and `xl1 start api` side-by-side\n * doesn't fight over a single shared default.\n */\nfunction defaultScrapePortForActors(actors: readonly string[]): number {\n const primary = actors[0]\n const key = primary === 'rewardRedemption' ? 'rewardRedemptionApi' : primary\n return (DefaultMetricsScrapePorts as Record<string, number>)[key] ?? DefaultMetricsScrapePorts.producer\n}\n\n/**\n * The configuration that will be used throughout the CLI.\n * This is materialized after parsing the command-line arguments,\n * environment variables, and defaults.\n */\nlet configuration: ConfigWithMnemonic\nlet skipInsecureConfirm = false\nlet dumpProviders = false\n\nconst version = isDefined(__VERSION__) ? __VERSION__ : 'unknown'\n\nfunction getConfiguration(): ConfigWithMnemonic {\n return configuration\n}\n\nasync function promptForInsecureGenesisConfirmation(logger: ReturnType<typeof initLogger>) {\n if (!input.isTTY || !output.isTTY) {\n logger.warn('Insecure genesis reward wallet is active. Interactive confirmation skipped because this session is not a TTY.')\n return\n }\n const rl = createInterface({ input, output })\n try {\n await rl.question('Insecure genesis reward wallet is active. Hit RETURN to continue.')\n } finally {\n rl.close()\n }\n}\n\nasync function getLocatorsFromConfig(actors: string[], configuration: ConfigWithMnemonic) {\n const actorConfigs: ActorConfig[] = []\n for (const actorName of actors) {\n const existingConfig = configuration.actors.find(actor => actor.name === actorName)\n if (existingConfig) {\n actorConfigs.push(existingConfig)\n } else {\n const actorConfig = z.looseObject(ActorConfigZod.shape).parse({ name: actorName })\n actorConfigs.push(actorConfig)\n }\n }\n\n const fullConfig = { ...configuration, actors: actorConfigs }\n // Strip only for SDK Zod parse / context (wallets/memory are orchestration-only).\n // Pass the full config (with synthesized wallets) to locators so that\n // ensureSigningActorWalletConnections sees producer-wallet etc. before\n // descriptor builds that require them (e.g. SimpleBlockRunner).\n const configForSdk = stripOrchestrationOnlyConnections(fullConfig)\n const config = ConfigZod.parse(configForSdk)\n\n const logger = initLogger(configuration)\n const orchestrator = await Orchestrator.create({ logger })\n const collision = detectDerivationPathCollisions(actors, configuration)\n if (collision) throw collision\n const walletReport = await initializeResolvedWalletReport(actors, configuration)\n logger.info(formatWalletReport(walletReport))\n const serviceName = actors.length === 1 ? `xl1-${actors[0]}` : 'xl1-cli'\n const context = await contextFromConfigWithoutLocator(config, logger, serviceName, version, defaultScrapePortForActors(actors))\n if (skipInsecureConfirm) {\n logger.warn('Insecure genesis reward wallet is active. Interactive confirmation skipped via --skip-insecure-confirm.')\n }\n const onInsecureGenesisConfirm = skipInsecureConfirm\n ? undefined\n : async () => await promptForInsecureGenesisConfirmation(logger)\n const locators = await locatorsFromConfig(context, fullConfig, onInsecureGenesisConfirm)\n\n // `--dump-providers`: render the locator map and halt before the actor's\n // runner starts. Health endpoints and the SIGINT handler below are skipped.\n if (dumpProviders) {\n console.log(formatProviderTree(locators))\n // eslint-disable-next-line unicorn/no-process-exit\n process.exit(0)\n }\n\n const healthCheckPort = configuration.healthCheckPort ?? DEFAULT_HEALTH_CHECK_PORT\n const healthServer = healthCheckPort > 0 && context.statusReporter !== undefined\n ? await initHealthEndpoints({\n logger,\n port: healthCheckPort,\n readiness: orchestrator,\n statusMonitor: context.statusReporter,\n })\n : undefined\n\n // Handle cancellation (Ctrl+C)\n process.on('SIGINT', () => {\n void (async () => {\n try {\n logger.log('\\nSIGINT received. Attempting graceful shutdown...')\n healthServer?.close()\n await orchestrator?.stop()\n logger.log('Orchestrator stopped, exiting now.')\n process.exit(0)\n } catch (err) {\n logger.error('Error stopping orchestrator:', err)\n process.exit(1)\n }\n })()\n })\n return { locators, orchestrator }\n}\n\n// Main entry point\nexport async function runCLI() {\n // Parse command-line arguments using Yargs\n const y = yargs(hideBin(process.argv)) as Argv<Config>\n const argv = y\n .usage(`\n\uD83D\uDE80 XL1 Node CLI (${version})\n${XL1LogoColorizedAscii}\nRun various components of the XL1 ecosystem.\n\nUsage:\n$0 <command> [options]`)\n .parserConfiguration({\n 'dot-notation': true, // foo.bar \u2192 { foo: { bar } }\n 'parse-numbers': false, // Don't auto-parse numbers to allow strings like \"0x1\"\n 'populate--': true, // Populate -- with all options so we can detected user-supplied vs defaults\n })\n .env('XL1')\n .scriptName('xl1')\n .middleware(async (argv) => {\n await configMiddleware(argv, (config) => {\n configuration = config\n })\n skipInsecureConfirm = Boolean(argv['skip-insecure-confirm'])\n dumpProviders = Boolean(argv['dump-providers'])\n })\n .options(optionsFromGlobalZodRegistry())\n .wrap(y.terminalWidth())\n .command(withDeprecationWarning(apiCommand(getConfiguration, getLocatorsFromConfig)))\n .command(withDeprecationWarning(bridgeCommand(getConfiguration, getLocatorsFromConfig)))\n .command(withDeprecationWarning(finalizerCommand(getConfiguration, getLocatorsFromConfig)))\n .command(withDeprecationWarning(indexerCommand(getConfiguration, getLocatorsFromConfig)))\n .command(withDeprecationWarning(mempoolCommand(getConfiguration, getLocatorsFromConfig)))\n .command(withDeprecationWarning(producerCommand(getConfiguration, getLocatorsFromConfig)))\n .command(withDeprecationWarning(rewardRedemptionCommand(getConfiguration, getLocatorsFromConfig)))\n .command(startCommand(getConfiguration, getLocatorsFromConfig))\n .options({\n 'config': {\n type: 'string',\n description: 'Path to a config file to use instead of the default search.',\n alias: 'c',\n },\n 'mnemonic': {\n type: 'string',\n description: 'Shared root mnemonic used by actors that do not define their own mnemonic.',\n },\n 'dump-config': {\n type: 'boolean',\n description: 'Just process the configuration and print the resolved config to stdout, then exit. Secrets are redacted unless --with-secrets is also passed.',\n default: false,\n },\n 'with-secrets': {\n type: 'boolean',\n description: 'When used with --dump-config, print raw secret values (mnemonic, private keys, passwords) instead of \"[REDACTED]\". Use only on a developer machine.',\n default: false,\n },\n 'dump-providers': {\n type: 'boolean',\n description: 'Run the normal command flow up to provider locator construction, print the per-actor provider tree (with duplicate detection), then exit.',\n default: false,\n },\n 'skip-insecure-confirm': {\n type: 'boolean',\n description: 'Skip the interactive RETURN confirmation when the built-in dev mnemonic / insecure genesis reward wallet is active.',\n default: false,\n },\n })\n .help()\n .alias('help', 'h')\n .version(version)\n .argv\n\n await argv\n}\n", "import { getApiActor } from '@xyo-network/chain-api'\nimport { getBridgeActor } from '@xyo-network/chain-bridge'\nimport { getFinalizerActor } from '@xyo-network/chain-finalizer'\nimport { getIndexerActor } from '@xyo-network/chain-indexer'\nimport { getMempoolActor } from '@xyo-network/chain-mempool'\nimport type {\n ActorInstanceV3, ConfigWithMnemonic, GetLocatorsFromConfig, OrchestratorInstance,\n} from '@xyo-network/chain-orchestration'\nimport { buildActorFromConfiguration } from '@xyo-network/chain-orchestration'\nimport { getProducerActor } from '@xyo-network/chain-producer'\nimport { getRewardRedemptionActor } from '@xyo-network/chain-reward-redemption'\nimport type { ProviderFactoryLocatorInstance } from '@xyo-network/xl1-sdk'\nimport type {\n ArgumentsCamelCase, Argv, CommandModule,\n} from 'yargs'\n\nimport { initLogger } from '../../initLogger.ts'\n\ninterface StartArgs {\n actors?: string[]\n}\n\nconst KNOWN_ACTORS = ['api', 'bridge', 'finalizer', 'indexer', 'mempool', 'producer', 'rewardRedemption'] as const\n\nconst BOOT_TIMEOUT_MS = 60_000\n\nfunction getActorsFromConfig(configuration: ConfigWithMnemonic): string[] | undefined {\n const enabledActors = configuration.actors\n .filter(actor => actor.enabled !== false)\n .map(actor => actor.name)\n return enabledActors.length > 0 ? enabledActors : undefined\n}\n\nfunction getDefaultActors(): string[] {\n return ['api', 'producer', 'finalizer']\n}\n\nasync function buildActor(\n name: string,\n locator: ProviderFactoryLocatorInstance,\n configuration: ConfigWithMnemonic,\n): Promise<ActorInstanceV3> {\n switch (name) {\n case 'api': {\n return await buildActorFromConfiguration(name, configuration, locator, getApiActor)\n }\n case 'bridge': {\n return await buildActorFromConfiguration(name, configuration, locator, getBridgeActor)\n }\n case 'mempool': {\n return await buildActorFromConfiguration(name, configuration, locator, getMempoolActor)\n }\n case 'producer': {\n return await buildActorFromConfiguration(name, configuration, locator, getProducerActor)\n }\n case 'rewardRedemption': {\n return await buildActorFromConfiguration(name, configuration, locator, getRewardRedemptionActor)\n }\n case 'finalizer': {\n return await buildActorFromConfiguration(name, configuration, locator, getFinalizerActor)\n }\n case 'indexer': {\n return await buildActorFromConfiguration(name, configuration, locator, getIndexerActor)\n }\n default: {\n throw new Error(`Unknown actor: ${name}`)\n }\n }\n}\n\nasync function bootActors(\n requestedActors: string[],\n locators: Record<string, ProviderFactoryLocatorInstance>,\n orchestrator: OrchestratorInstance,\n configuration: ConfigWithMnemonic,\n): Promise<void> {\n const startedAt = Date.now()\n const actors = await Promise.all(requestedActors.map(name => buildActor(name, locators[name], configuration)))\n for (const actor of actors) {\n await orchestrator.registerActor(actor)\n }\n await orchestrator.start()\n await orchestrator.whenReady(BOOT_TIMEOUT_MS)\n const ms = Date.now() - startedAt\n initLogger(configuration).info(`[xl1] system ready (${requestedActors.join('/')} in ${ms}ms)`)\n}\n\nexport function startCommand(getConfiguration: () => ConfigWithMnemonic, getLocatorsFromConfig: GetLocatorsFromConfig): CommandModule {\n return {\n command: ['start [actors..]', '$0'],\n describe: 'Run a full XL1 Node',\n builder: (yargs: Argv) => {\n return yargs\n .positional('actors', {\n type: 'string',\n array: true,\n choices: KNOWN_ACTORS,\n description: 'Actors to start (e.g. xl1 start api producer or xl1 start api,producer)',\n coerce: (values: string[]) => values.flatMap(v => v.split(',')),\n })\n .option('actors', {\n type: 'array',\n string: true,\n choices: KNOWN_ACTORS,\n description: 'List of actors to start (e.g. --actors api producer finalizer). Defaults to api, producer, and finalizer.',\n })\n },\n handler: async (argv: ArgumentsCamelCase<StartArgs>) => {\n const configuration = getConfiguration()\n const requestedActors = argv.actors !== undefined && argv.actors.length > 0\n ? argv.actors\n : getActorsFromConfig(configuration) ?? getDefaultActors()\n const { locators, orchestrator } = await getLocatorsFromConfig(requestedActors, configuration)\n await bootActors(requestedActors, locators, orchestrator, configuration)\n },\n }\n}\n", "import type { Logger, LogLevelValue } from '@xylabs/sdk-js'\nimport {\n Base,\n ConsoleLogger, isDefined,\n LogLevel, SilentLogger,\n} from '@xylabs/sdk-js'\nimport type { ConfigWithMnemonic } from '@xyo-network/chain-orchestration'\n\nexport const initLogger = (config: Pick<ConfigWithMnemonic, 'log'>): Logger => {\n let logger: Logger\n if (config.log.silent) {\n logger = new SilentLogger()\n } else {\n let level: LogLevelValue | undefined\n if (isDefined(config.log.logLevel)) {\n const parsed = LogLevel[config.log.logLevel.toLowerCase() as keyof typeof LogLevel]\n if (isDefined(parsed)) level = parsed\n }\n logger = new ConsoleLogger(level)\n }\n Base.defaultLogger = logger\n return logger\n}\n", "import { delay } from '@xylabs/sdk-js'\nimport type { CommandModule } from 'yargs'\n\nexport function withDeprecationWarning(module: CommandModule): CommandModule {\n const { deprecated, handler } = module\n if (typeof deprecated === 'string') {\n return {\n ...module,\n handler: async (argv) => {\n console.warn(`[deprecated] ${deprecated}`)\n await delay(3000)\n return handler(argv)\n },\n }\n }\n return module\n}\n", "import { createDeepMerge, isDefined } from '@xylabs/sdk-js'\nimport {\n ActorMnemonicNotAllowedError,\n assertNoActorMnemonics,\n ConfigFileNotFoundError,\n type ConfigWithMnemonic,\n finalizeConfig,\n stripOrchestrationOnlyConnections,\n tryParseConfig,\n} from '@xyo-network/chain-orchestration'\nimport type { Config } from '@xyo-network/xl1-sdk'\nimport {\n ConfigZod, isZodError, resolveConfig,\n} from '@xyo-network/xl1-sdk'\n\nconst deepMerge = createDeepMerge({ arrayStrategy: 'concat' })\n\nconst REDACTED = '[REDACTED]'\n\n/**\n * Names that always redact, regardless of nesting level. `connectionString` is\n * included because Mongo connection URIs commonly embed `user:password@host`.\n */\nconst REDACTED_KEY_NAMES = new Set<string>(['mnemonic', 'connectionString'])\n\n/**\n * Suffix-matched key names that redact. Catches any future `*PrivateKey`,\n * `*Secret`, or `*Password` field without us having to enumerate them here.\n */\nconst REDACTED_KEY_SUFFIX = /(PrivateKey|Secret|Password)$/i\n\nfunction shouldRedactKey(key: string): boolean {\n if (REDACTED_KEY_NAMES.has(key)) return true\n return REDACTED_KEY_SUFFIX.test(key)\n}\n\n/**\n * Returns a deep clone of `config` with secret-bearing leaf values replaced by\n * `'[REDACTED]'`. Walks plain objects and arrays. Leaves primitives, dates,\n * and other non-plain values untouched (other than via `structuredClone`).\n */\nexport function redactConfig<T>(config: T): T {\n const cloned = structuredClone(config) as unknown\n redactInPlace(cloned)\n return cloned as T\n}\n\nfunction redactInPlace(node: unknown): void {\n if (Array.isArray(node)) {\n for (const item of node) redactInPlace(item)\n return\n }\n if (node === null || typeof node !== 'object') return\n const obj = node as Record<string, unknown>\n for (const key of Object.keys(obj)) {\n if (shouldRedactKey(key) && obj[key] !== undefined && obj[key] !== null) {\n obj[key] = REDACTED\n } else {\n redactInPlace(obj[key])\n }\n }\n}\n\n/**\n * Yargs `.env()` with `dot-notation` turns `XL1_ACTORS__0__NAME=foo` into\n * `{ actors: { '0': { name: 'foo' } } }` \u2014 an object keyed by string indices\n * rather than an array. Normalize that back into an array so ConfigZod's\n * `actors` array schema accepts it.\n */\nfunction coerceActorsArray(argv: Record<string, unknown>): Record<string, unknown> {\n const actors = argv.actors\n if (actors === undefined || Array.isArray(actors)) return argv\n if (typeof actors !== 'object' || actors === null) return argv\n const entries = Object.entries(actors as Record<string, unknown>)\n const numericEntries = entries\n .map(([key, value]) => [Number(key), value] as const)\n .filter(([key]) => Number.isSafeInteger(key) && key >= 0)\n if (numericEntries.length !== entries.length) return argv\n const asArray: unknown[] = []\n for (const [key, value] of numericEntries) asArray[key] = value\n return { ...argv, actors: asArray }\n}\n\nfunction safeParseOrThrow(input: unknown): Config {\n const result = ConfigZod.safeParse(input)\n if (!result.success) throw result.error\n return result.data\n}\n\nasync function buildFinalConfig(argv: Record<string, unknown>): Promise<ConfigWithMnemonic> {\n // Parse the various config sources\n const configPath = argv.config as string | undefined\n const parsedConfigFileRaw = await tryParseConfig({ configPath }) // Config file (may contain orchestration extensions like wallet connections)\n const rootMnemonicFromFile = typeof parsedConfigFileRaw.mnemonic === 'string' ? parsedConfigFileRaw.mnemonic : undefined\n const normalizedArgv = coerceActorsArray(argv)\n const argsForSdk = stripOrchestrationOnlyConnections(normalizedArgv)\n const parsedConfigArgs = ConfigZod.safeParse(argsForSdk).data ?? {} // Command-line arguments & ENV VARs\n const rootMnemonicFromArgs = typeof normalizedArgv.mnemonic === 'string' ? normalizedArgv.mnemonic : undefined\n // Deep merge with precedence\n // TODO: Would like precedence to be defaults < file < ENV < CLI Args\n // but there is currently no way to determine which are defaults vs\n // user-supplied CLI Args since we set the CLI args to the defaults\n // and receive a flattened object. We might need to manually invoke\n // the parser without the defaults to achieve this.\n // If argv/env provides an actors list, prefer it over default/file actors to avoid concat\n // (deepMerge uses array concat; providing explicit actors should replace rather than append defaults)\n const parsedFileRecord = parsedConfigFileRaw as Record<string, unknown>\n let fileForMerge: Record<string, unknown> = parsedFileRecord\n const argvActors = normalizedArgv.actors\n if (Array.isArray(argvActors) && argvActors.length > 0) {\n const { actors: _dropped, ...rest } = parsedFileRecord\n fileForMerge = rest\n }\n const rawMerged = deepMerge(fileForMerge, parsedConfigArgs)\n const mergedForSdk = stripOrchestrationOnlyConnections(rawMerged)\n const mergedConfig = safeParseOrThrow(mergedForSdk)\n const rootMnemonic = rootMnemonicFromArgs ?? rootMnemonicFromFile\n const finalized = finalizeConfig({\n ...mergedConfig,\n ...(isDefined(rootMnemonic) && { mnemonic: rootMnemonic }),\n })\n // Strip orchestration-only connection types (wallet, memory) before passing to SDK's ConfigZod/resolveConfig,\n // which do not yet include them in TransportConfigZod. Re-finalize afterwards to re-synthesize them.\n const strippedForResolve = stripOrchestrationOnlyConnections(finalized)\n const preResolve = safeParseOrThrow(strippedForResolve)\n const resolved = resolveConfig(preResolve)\n const strippedResolved = stripOrchestrationOnlyConnections(resolved)\n const validated = safeParseOrThrow(strippedResolved)\n // Re-apply finalize to ensure wallet/memory connections + providerBindings are present in the returned config\n const toFinalize = {\n ...validated,\n ...(isDefined(rootMnemonic) && { mnemonic: rootMnemonic }),\n }\n const finalWithConnections = finalizeConfig(toFinalize)\n return finalWithConnections\n}\n\nexport async function configMiddleware(argv: Record<string, unknown>, setConfiguration: (config: ConfigWithMnemonic) => void): Promise<void> {\n try {\n const finalConfig = await buildFinalConfig(argv)\n // Hard-fail if any actor was configured with its own mnemonic. Mnemonics\n // must live at the root; actors pick their wallet via accountPath.\n assertNoActorMnemonics(finalConfig)\n setConfiguration(finalConfig)\n\n // Check if user wants to dump config and exit. Default behavior redacts\n // secrets (mnemonics, private keys, passwords, connection strings). Pass\n // `--with-secrets` to see the raw values \u2014 useful only on a developer box.\n if (argv['dump-config'] === true) {\n const withSecrets = Boolean(argv['with-secrets'])\n const output = withSecrets ? finalConfig : redactConfig(finalConfig)\n console.log(JSON.stringify(output, null, 2))\n // eslint-disable-next-line unicorn/no-process-exit\n process.exit(0)\n }\n } catch (err) {\n if (err instanceof ConfigFileNotFoundError) {\n console.error(`${err.message}. Check the path passed to --config/-c and try again.`)\n } else if (err instanceof ActorMnemonicNotAllowedError) {\n console.error(err.message)\n } else if (isZodError(err)) {\n console.error(`Zod error: ${err.message}`)\n } else {\n console.error(`Error parsing configuration: ${String(err)}`)\n }\n if (!(err instanceof ConfigFileNotFoundError) && !(err instanceof ActorMnemonicNotAllowedError)) {\n console.error(`Stack: ${err instanceof Error ? err.stack : 'N/A'}`)\n }\n throw new Error('Invalid configuration', { cause: err })\n }\n}\n", "import type { ProviderFactoryLocatorInstance } from '@xyo-network/xl1-sdk'\n\n/**\n * One row in the per-actor provider tree. Captures the moniker (registry key),\n * the implementation class, the dependency monikers the factory declared, the\n * factory scope, and a `count` of how many times an identical fingerprint\n * appeared in the same moniker bucket. The registry can hold the same factory\n * more than once (e.g. via merges or multi-moniker registrations); collapsing\n * keeps the tree readable while still surfacing the multiplicity.\n */\ninterface ProviderEntry {\n count: number\n dependencies: readonly string[]\n moniker: string\n providerName: string\n scope: string\n}\n\nconst CANONICAL_ACTOR_ORDER: readonly string[] = [\n 'producer', 'finalizer', 'api', 'mempool', 'bridge', 'rewardRedemption',\n]\n\n/**\n * Enumerates the providers registered directly on a single locator. Does not\n * walk the parent chain \u2014 each locator is reported on its own so that a reader\n * can see exactly which providers a given actor contributed.\n */\nfunction enumerateLocator(locator: ProviderFactoryLocatorInstance): ProviderEntry[] {\n const collapsed = new Map<string, ProviderEntry>()\n const registry = locator.registry as Record<string, unknown[] | undefined>\n for (const [moniker, factories] of Object.entries(registry)) {\n if (!factories) continue\n for (const factory of factories) {\n const f = factory as { dependencies?: readonly string[]; providerName?: string; scope?: string }\n const providerName = f.providerName ?? '<unknown>'\n const scope = f.scope ?? '<unknown>'\n const dependencies = f.dependencies ?? []\n const fingerprint = `${moniker}|${providerName}|${scope}|${dependencies.join(',')}`\n const existing = collapsed.get(fingerprint)\n if (existing) {\n existing.count += 1\n } else {\n collapsed.set(fingerprint, {\n count: 1, dependencies, moniker, providerName, scope,\n })\n }\n }\n }\n return collapsed.values().toArray().toSorted((a, b) => a.moniker.localeCompare(b.moniker) || a.providerName.localeCompare(b.providerName))\n}\n\nfunction buildOwnerIndex(perActor: ReadonlyMap<string, readonly ProviderEntry[]>): Map<string, Set<string>> {\n const monikerOwners = new Map<string, Set<string>>()\n for (const [actorName, entries] of perActor) {\n for (const entry of entries) {\n let owners = monikerOwners.get(entry.moniker)\n if (!owners) {\n owners = new Set()\n monikerOwners.set(entry.moniker, owners)\n }\n owners.add(actorName)\n }\n }\n return monikerOwners\n}\n\nfunction renderDuplicatesSummary(monikerOwners: ReadonlyMap<string, ReadonlySet<string>>): string[] {\n const duplicates = [...monikerOwners]\n .filter(([, owners]) => owners.size > 1)\n .map(([moniker, owners]) => ({ moniker, owners: [...owners].toSorted((a, b) => a.localeCompare(b)).map(formatGroupForDisplay) }))\n .toSorted((a, b) => a.moniker.localeCompare(b.moniker))\n if (duplicates.length === 0) return []\n const lines = ['Duplicate monikers (registered by more than one locator):']\n for (const { moniker, owners } of duplicates) {\n lines.push(` - ${moniker}: ${owners.join(', ')}`)\n }\n lines.push('')\n return lines\n}\n\n/**\n * Groups actor names whose locators share the same `registry` object reference.\n * Under the shared-locator architecture, API/mempool/finalizer etc. may\n * point to view locators that share one underlying registry \u2014 without this\n * grouping, the dump would print the same factory set N times and falsely\n * report every moniker as \"duplicate across actors.\"\n */\nfunction groupActorsBySharedRegistry(\n locators: Record<string, ProviderFactoryLocatorInstance>,\n): { actorNames: readonly string[]; locator: ProviderFactoryLocatorInstance }[] {\n const groups: { actorNames: string[]; locator: ProviderFactoryLocatorInstance; registry: unknown }[] = []\n for (const [actorName, locator] of Object.entries(locators)) {\n const existing = groups.find(g => g.registry === locator.registry)\n if (existing) {\n existing.actorNames.push(actorName)\n } else {\n groups.push({\n actorNames: [actorName], locator, registry: locator.registry,\n })\n }\n }\n return groups\n}\n\n/**\n * Stable id for a registry-sharing group: sorted, comma-joined actor names.\n * Used as the key in `monikerOwners`. Multi-actor group ids contain commas;\n * we display them parenthesized in the `also in:` annotation.\n */\nfunction groupId(actorNames: readonly string[]): string {\n return actorNames.toSorted((a, b) => a.localeCompare(b)).join(',')\n}\n\nfunction formatGroupForDisplay(groupKey: string): string {\n const members = groupKey.split(',')\n return members.length === 1 ? members[0] : `(${members.join(', ')})`\n}\n\nfunction renderGroupSection(\n actorNames: readonly string[],\n entries: readonly ProviderEntry[],\n monikerOwners: ReadonlyMap<string, ReadonlySet<string>>,\n): string[] {\n const sortedActors = actorNames.toSorted((a, b) => a.localeCompare(b))\n const ownGroupKey = groupId(sortedActors)\n const heading = sortedActors.length === 1\n ? `Providers for actor: ${sortedActors[0]} (${entries.length} registered)`\n : `Providers shared by actors: ${sortedActors.join(', ')} (${entries.length} registered)`\n const lines: string[] = [heading]\n if (entries.length === 0) {\n lines.push(' (none)', '')\n return lines\n }\n for (let i = 0; i < entries.length; i++) {\n const entry = entries[i]\n const isLast = i === entries.length - 1\n const branch = isLast ? '\u2514\u2500\u2500' : '\u251C\u2500\u2500'\n const owners = monikerOwners.get(entry.moniker) ?? new Set<string>()\n const otherOwners = [...owners]\n .filter(o => o !== ownGroupKey)\n .toSorted((a, b) => a.localeCompare(b))\n .map(formatGroupForDisplay)\n const dupNote = otherOwners.length > 0 ? ` \u26A0 also in: ${otherOwners.join(', ')}` : ''\n const depsNote = entry.dependencies.length > 0 ? `, deps: [${entry.dependencies.join(', ')}]` : ''\n const countNote = entry.count > 1 ? ` (\u00D7${entry.count})` : ''\n lines.push(` ${branch} ${entry.moniker}${countNote} [impl: ${entry.providerName}, scope: ${entry.scope}${depsNote}]${dupNote}`)\n }\n lines.push('')\n return lines\n}\n\n/**\n * Renders the locator map as a tree grouped by registry identity, annotating\n * any moniker that appears in more than one *registry* with `\u26A0 also in: ...`.\n *\n * - When all input locators share one registry (shared-locator path), a single\n * \"Providers shared by actors: \u2026\" section is rendered.\n * - When some actors have distinct registries (legacy `_root` + per-actor\n * child architecture), each registry is rendered separately. `_root` is\n * ordered first.\n *\n * The \"Duplicate monikers\" summary at the bottom only flags monikers\n * registered by *different* registries \u2014 duplicates within one registry are\n * already collapsed into per-entry `(\u00D7N)` counts by `enumerateLocator`.\n */\nexport function formatProviderTree(locators: Record<string, ProviderFactoryLocatorInstance>): string {\n const groups = groupActorsBySharedRegistry(locators)\n\n // Per-actor moniker ownership (used for the \"also in:\" annotation), but\n // attribute each moniker to the GROUP it belongs to \u2014 the \"actor name\" the\n // index uses is the joined group key, so two actors that share a registry\n // never appear as duplicates of each other.\n const groupKeys = groups.map(g => ({ ...g, key: groupId(g.actorNames) }))\n const perGroup = new Map<string, ProviderEntry[]>()\n for (const g of groupKeys) perGroup.set(g.key, enumerateLocator(g.locator))\n const monikerOwners = buildOwnerIndex(perGroup)\n\n // Order: legacy `_root` first when present; otherwise alphabetical by sorted\n // actor names within the group, with the canonical actor order applied to\n // the *primary* (sorted-first) actor name in each group.\n const orderedGroups = [...groupKeys].toSorted((a, b) => {\n const aHasRoot = a.actorNames.includes('_root')\n const bHasRoot = b.actorNames.includes('_root')\n if (aHasRoot !== bHasRoot) return aHasRoot ? -1 : 1\n const ai = CANONICAL_ACTOR_ORDER.indexOf(a.actorNames[0])\n const bi = CANONICAL_ACTOR_ORDER.indexOf(b.actorNames[0])\n if (ai !== bi) return (ai === -1 ? Number.MAX_SAFE_INTEGER : ai) - (bi === -1 ? Number.MAX_SAFE_INTEGER : bi)\n return a.key.localeCompare(b.key)\n })\n\n const lines: string[] = ['XL1 Provider Dump', '=================', '']\n for (const g of orderedGroups) {\n lines.push(...renderGroupSection(g.actorNames.toSorted((a, b) => a.localeCompare(b)), perGroup.get(g.key) ?? [], monikerOwners))\n }\n lines.push(...renderDuplicatesSummary(monikerOwners))\n return lines.join('\\n')\n}\n", "/* eslint-disable no-irregular-whitespace, @stylistic/max-len */\nexport const XL1LogoColorizedAscii = `\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;118;111;144m_\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;72;32;223m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u2560\u2560\u001B[0m\u001B[38;2;103;85;170m_\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;79;121;152m\u2566\u001B[0m\u001B[38;2;82;121;151m\u2566\u001B[0m\u001B[38;2;112;125;136m_\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;88;59;196m[\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;73;34;221m\u2592\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;121;121;127m_\u001B[0m\u001B[38;2;100;101;128m\u2554\u001B[0m\u001B[38;2;93;94;127m\u2566\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;82;121;151m\u00B2\u001B[0m\u001B[38;2;44;116;170m\u2560\u001B[0m\u001B[38;2;44;116;171m\u2592\u001B[0m\u001B[38;2;51;117;167mD\u001B[0m\u001B[38;2;80;121;152m\u2566\u001B[0m\u001B[38;2;111;125;136m_\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;67;23;232m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;120;121;128m_\u001B[0m\u001B[38;2;100;101;127m\u2554\u001B[0m\u001B[38;2;79;81;127mR\u001B[0m\u001B[38;2;71;73;128m\u2592\u001B[0m\u001B[38;2;71;73;128m\u2592\u001B[0m\u001B[38;2;88;90;127m\u2559\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;55;117;165m\u255A\u001B[0m\u001B[38;2;44;116;171m\u2592\u001B[0m\u001B[38;2;44;116;171m\u2592\u2592\u001B[0m\u001B[38;2;50;116;167mD\u001B[0m\u001B[38;2;80;121;152m\u2566\u00A0\u001B[0m\u001B[38;2;106;90;165mj\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u001B[0m\u001B[38;2;89;61;194mH\u00A0\u001B[0m\u001B[38;2;99;100;127m\u2554\u001B[0m\u001B[38;2;79;80;127mD\u001B[0m\u001B[38;2;71;73;128m\u2592\u001B[0m\u001B[38;2;71;73;128m\u2592\u2592\u2560\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;83;121;150m\u00B2\u001B[0m\u001B[38;2;44;116;170m\u2592\u001B[0m\u001B[38;2;44;116;171m\u2592\u2592\u2592\u00A0\u001B[0m\u001B[38;2;76;38;217m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u2560\u00A0\u001B[0m\u001B[38;2;74;76;128m\u2560\u001B[0m\u001B[38;2;71;73;128m\u2592\u2592\u2592\u001B[0m\u001B[38;2;89;90;128m\u2559\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;90;118;148m\\`\u001B[0m\u001B[38;2;89;107;153m_\u001B[0m\u001B[38;2;93;97;154m,\u001B[0m\u001B[38;2;105;89;166m\u2553\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u2560\u2560\u001B[0m\u001B[38;2;95;72;183m\u2553\u001B[0m\u001B[38;2;106;96;152m_\u001B[0m\u001B[38;2;100;94;143m\\`\u001B[0m\u001B[38;2;101;100;133m\\`\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u001B[0m\u001B[38;2;122;118;137m_\u001B[0m\u001B[38;2;113;102;153m,\u001B[0m\u001B[38;2;108;94;161m\u2553\u001B[0m\u001B[38;2;104;86;169m\u2553\u001B[0m\u001B[38;2;98;77;178m\u2554\u001B[0m\u001B[38;2;93;67;188m\u2557\u001B[0m\u001B[38;2;88;59;196m\u03C6\u001B[0m\u001B[38;2;83;51;204m@\u001B[0m\u001B[38;2;78;42;213mD\u001B[0m\u001B[38;2;72;32;223m\u2592\u001B[0m\u001B[38;2;68;24;231m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u001B[0m\u001B[38;2;71;30;225m\u2592\u001B[0m\u001B[38;2;77;40;215m\u2592\u001B[0m\u001B[38;2;82;49;206mK\u001B[0m\u001B[38;2;87;57;198m\u03C6\u001B[0m\u001B[38;2;91;65;190m\u2557\u001B[0m\u001B[38;2;97;75;180m\u2566\u001B[0m\u001B[38;2;103;84;171m\u2556\u001B[0m\u001B[38;2;107;92;163m\u00B2\u001B[0m\u001B[38;2;112;101;154m_\u001B[0m\u001B[38;2;119;112;143m_\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u001B[0m\u001B[38;2;106;91;164m\\`\u001B[0m\u001B[38;2;94;70;185m^\u001B[0m\u001B[38;2;89;62;193m\u2559\u001B[0m\u001B[38;2;85;54;201m\u2559\u001B[0m\u001B[38;2;80;45;210m\u255A\u001B[0m\u001B[38;2;74;35;220m\u255D\u001B[0m\u001B[38;2;69;26;229m\u2560\u001B[0m\u001B[38;2;66;22;233m\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u001B[0m\u001B[38;2;73;33;222m\u255D\u001B[0m\u001B[38;2;79;43;212m\u2569\u001B[0m\u001B[38;2;84;52;203m\u255C\u001B[0m\u001B[38;2;88;60;195m\u2559\u001B[0m\u001B[38;2;93;68;187m^\u001B[0m\u001B[38;2;100;80;175m\\`\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;113;84;152m\\`\u001B[0m\u001B[38;2;103;79;169m'\u001B[0m\u001B[38;2;95;72;183m\"\u001B[0m\u001B[38;2;87;57;198m\u2559\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u2560\u2560\u001B[0m\u001B[38;2;80;46;209m\u255C\u001B[0m\u001B[38;2;94;70;185m^\u001B[0m\u001B[38;2;102;77;175m^\u001B[0m\u001B[38;2;112;81;162m\\`\u001B[0m\u001B[38;2;115;92;155m\\`\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;145;116;107m,\u001B[0m\u001B[38;2;199;82;45m\u2560\u001B[0m\u001B[38;2;207;77;35m\u2592\u001B[0m\u001B[38;2;207;77;35m\u2592\u2560\u00A0\u001B[0m\u001B[38;2;70;28;227m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u2560\u00A0\u001B[0m\u001B[38;2;189;49;97m\u00E5\u001B[0m\u001B[38;2;203;32;90m\u2560\u001B[0m\u001B[38;2;203;32;90m\u2560\u2560\u001B[0m\u001B[38;2;155;92;114m,\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;175;98;73m\u2554\u001B[0m\u001B[38;2;207;77;35m\u2592\u001B[0m\u001B[38;2;207;77;35m\u2592\u2592\u2592\u001B[0m\u001B[38;2;197;83;47m\u2569\u00A0\u001B[0m\u001B[38;2;98;76;179m[\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u001B[0m\u001B[38;2;81;48;207mH\u00A0\u001B[0m\u001B[38;2;188;51;98m\u255A\u001B[0m\u001B[38;2;203;32;90m\u2560\u001B[0m\u001B[38;2;203;32;90m\u2560\u2560\u2560\u001B[0m\u001B[38;2;183;57;100mH\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;146;116;106m,\u001B[0m\u001B[38;2;199;82;44m\u2560\u001B[0m\u001B[38;2;207;77;35m\u2592\u001B[0m\u001B[38;2;207;77;35m\u2592\u001B[0m\u001B[38;2;196;84;48m\u2569\u001B[0m\u001B[38;2;168;102;81m^\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;160;87;111m'\u001B[0m\u001B[38;2;187;52;98m\u255A\u001B[0m\u001B[38;2;203;32;90m\u2560\u001B[0m\u001B[38;2;203;32;90m\u2560\u2560\u001B[0m\u001B[38;2;156;91;113m,\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;198;83;46m\u2569\u001B[0m\u001B[38;2;194;85;50m\u2569\u001B[0m\u001B[38;2;167;102;82m^\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;81;46;209m\u255A\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;159;88;112m'\u001B[0m\u001B[38;2;186;53;98m\u255A\u001B[0m\u001B[38;2;197;40;93m\u2569\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;110;97;158m'\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;94;69;186mH\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;68;25;230m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;108;93;162m\u00B2\u001B[0m\u001B[38;2;99;79;176m^\u001B[0m`\n", "import type { UsageMeta } from '@xyo-network/xl1-sdk'\nimport { isUsageMeta } from '@xyo-network/xl1-sdk'\nimport type { Options } from 'yargs'\nimport { globalRegistry } from 'zod/mini'\n\nconst usageMetaToOptions = (meta: UsageMeta): Options => {\n return meta\n}\n\nexport const optionsFromGlobalZodRegistry = (): Record<string, Options> => {\n const opts: Record<string, Options> = {}\n for (const schema of Object.values(globalRegistry._map)) {\n if (isUsageMeta(schema)) {\n if (schema.hidden === true) continue // skip hidden options\n opts[schema.title] = usageMetaToOptions(schema)\n }\n }\n return opts\n}\n", "import { start } from './start.ts'\n\ntry {\n await start()\n} catch (err) {\n // If we're in development mode, log the stack trace to the console\n if (process.env.NODE_ENV === 'development') console.error('An error occurred during startup:', err)\n // eslint-disable-next-line unicorn/no-process-exit\n process.exit(1)\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["isDefined", "
|
|
4
|
+
"sourcesContent": ["import { config } from 'dotenv'\n\nimport { runCLI } from './runCli.ts'\n\nexport const start = async () => {\n config({ quiet: true })\n await runCLI()\n}\n", "import { stdin as input, stdout as output } from 'node:process'\nimport { createInterface } from 'node:readline/promises'\n\nimport { isDefined } from '@xylabs/sdk-js'\nimport { apiCommand } from '@xyo-network/chain-api'\nimport { bridgeCommand } from '@xyo-network/chain-bridge'\nimport { finalizerCommand } from '@xyo-network/chain-finalizer'\nimport { indexerCommand } from '@xyo-network/chain-indexer'\nimport { mempoolCommand } from '@xyo-network/chain-mempool'\nimport type {\n ActorSlice,\n ConfigWithMnemonic,\n} from '@xyo-network/chain-orchestration'\nimport {\n assembleRunConfig,\n contextFromConfigWithoutLocator,\n detectDerivationPathCollisions,\n formatWalletReport,\n getActorSliceFromRun,\n initializeResolvedWalletReport,\n locatorFromConfig,\n Orchestrator,\n splitRunConfig,\n} from '@xyo-network/chain-orchestration'\nimport { producerCommand } from '@xyo-network/chain-producer'\nimport { rewardRedemptionCommand } from '@xyo-network/chain-reward-redemption'\nimport type { Config } from '@xyo-network/xl1-sdk'\nimport { DefaultMetricsScrapePorts } from '@xyo-network/xl1-sdk'\nimport { HttpSystemStatusPublisher } from '@xyo-network/xl1-system-status'\nimport type { Argv } from 'yargs'\nimport yargs from 'yargs'\nimport { hideBin } from 'yargs/helpers'\n\nimport { startCommand, withDeprecationWarning } from './commands/index.ts'\nimport { configMiddleware } from './configMiddleware.ts'\nimport { formatProviderTree } from './dumpProviders.ts'\nimport { XL1LogoColorizedAscii } from './images.ts'\nimport { initLogger } from './initLogger.ts'\nimport { optionsFromGlobalZodRegistry } from './optionsFromGlobalZodRegistry.ts'\n\n/** Version string injected by Rolldown at build time. */\ndeclare const __VERSION__: string\n\nconst DEFAULT_HEALTH_CHECK_PORT = 9099\n\n/**\n * Maps a CLI actor name to its registered Prometheus scrape port. The CLI-level\n * exporter (one per process) defaults to the port of the first requested actor\n * so that running, e.g., `xl1 start producer` and `xl1 start api` side-by-side\n * doesn't fight over a single shared default.\n */\nfunction defaultScrapePortForActors(actors: readonly string[]): number {\n const primary = actors[0]\n const key = primary === 'rewardRedemption' ? 'rewardRedemptionApi' : primary\n return (DefaultMetricsScrapePorts as Record<string, number>)[key] ?? DefaultMetricsScrapePorts.producer\n}\n\n/**\n * The configuration that will be used throughout the CLI.\n * This is materialized after parsing the command-line arguments,\n * environment variables, and defaults.\n */\nlet configuration: ConfigWithMnemonic\nlet skipInsecureConfirm = false\nlet dumpProviders = false\n\nconst version = isDefined(__VERSION__) ? __VERSION__ : 'unknown'\n\nfunction getConfiguration(): ConfigWithMnemonic {\n return configuration\n}\n\nasync function promptForInsecureGenesisConfirmation(logger: ReturnType<typeof initLogger>) {\n if (!input.isTTY || !output.isTTY) {\n logger.warn('Insecure genesis reward wallet is active. Interactive confirmation skipped because this session is not a TTY.')\n return\n }\n const rl = createInterface({ input, output })\n try {\n await rl.question('Insecure genesis reward wallet is active. Hit RETURN to continue.')\n } finally {\n rl.close()\n }\n}\n\nasync function getLocatorFromConfig(actors: string[], configuration: ConfigWithMnemonic) {\n const actorConfigs: ActorSlice[] = actors.map((actorName) => {\n return getActorSliceFromRun(configuration, actorName)\n })\n const { process: processConfig } = splitRunConfig(configuration)\n const fullConfig = assembleRunConfig(processConfig, actorConfigs, configuration.mnemonic)\n\n const logger = initLogger(configuration)\n const orchestrator = await Orchestrator.create({ logger })\n const collision = detectDerivationPathCollisions(actors, fullConfig)\n if (collision) throw collision\n const walletReport = await initializeResolvedWalletReport(actors, fullConfig)\n logger.info(formatWalletReport(walletReport))\n const serviceName = actors.length === 1 ? `xl1-${actors[0]}` : 'xl1-cli'\n const context = await contextFromConfigWithoutLocator(fullConfig, logger, serviceName, version, defaultScrapePortForActors(actors))\n if (skipInsecureConfirm) {\n logger.warn('Insecure genesis reward wallet is active. Interactive confirmation skipped via --skip-insecure-confirm.')\n }\n const onInsecureGenesisConfirm = skipInsecureConfirm\n ? undefined\n : async () => await promptForInsecureGenesisConfirmation(logger)\n const locator = await locatorFromConfig(context, fullConfig, onInsecureGenesisConfirm)\n\n // `--dump-providers`: render the provider tree and halt before the actor's\n // runner starts. Health endpoints and the SIGINT handler below are skipped.\n // Every actor shares the one process locator, so the dump groups them under a\n // single \"shared by actors\" section.\n if (dumpProviders) {\n console.log(formatProviderTree(Object.fromEntries(actors.map(name => [name, locator]))))\n // eslint-disable-next-line unicorn/no-process-exit\n process.exit(0)\n }\n\n const healthCheckPort = configuration.healthCheckPort ?? DEFAULT_HEALTH_CHECK_PORT\n const statusReporter = context.statusReporter\n // The HTTP status publisher reads the process-wide SystemStatusRunner\n // (context.statusReporter) and serves the k8s probes + /status snapshot. It\n // is a plain observer, so it never reports its own lifecycle into the Runner.\n const statusHttpPublisher = healthCheckPort > 0 && statusReporter !== undefined\n ? new HttpSystemStatusPublisher(statusReporter, { logger, port: healthCheckPort })\n : undefined\n await statusHttpPublisher?.start()\n\n // Handle cancellation (Ctrl+C)\n process.on('SIGINT', () => {\n void (async () => {\n try {\n logger.log('\\nSIGINT received. Attempting graceful shutdown...')\n statusReporter?.setShuttingDown(true)\n await statusHttpPublisher?.stop()\n await orchestrator?.stop()\n logger.log('Orchestrator stopped, exiting now.')\n process.exit(0)\n } catch (err) {\n logger.error('Error stopping orchestrator:', err)\n process.exit(1)\n }\n })()\n })\n return { locator, orchestrator }\n}\n\n// Main entry point\nexport async function runCLI() {\n // Parse command-line arguments using Yargs\n const y = yargs(hideBin(process.argv)) as Argv<Config>\n const argv = y\n .usage(`\n\uD83D\uDE80 XL1 Node CLI (${version})\n${XL1LogoColorizedAscii}\nRun various components of the XL1 ecosystem.\n\nUsage:\n$0 <command> [options]`)\n .parserConfiguration({\n 'dot-notation': true, // foo.bar \u2192 { foo: { bar } }\n 'parse-numbers': false, // Don't auto-parse numbers to allow strings like \"0x1\"\n 'populate--': true, // Populate -- with all options so we can detected user-supplied vs defaults\n 'strip-aliased': true, // drop alias keys (c, h, \u2026) so only canonical names reach argv and the config merge\n })\n .env('XL1')\n .scriptName('xl1')\n .middleware(async (argv) => {\n await configMiddleware(argv, (config) => {\n configuration = config\n })\n skipInsecureConfirm = Boolean(argv['skip-insecure-confirm'])\n dumpProviders = Boolean(argv['dump-providers'])\n })\n .options(optionsFromGlobalZodRegistry())\n .wrap(y.terminalWidth())\n .command(withDeprecationWarning(apiCommand(getConfiguration, getLocatorFromConfig)))\n .command(withDeprecationWarning(bridgeCommand(getConfiguration, getLocatorFromConfig)))\n .command(withDeprecationWarning(finalizerCommand(getConfiguration, getLocatorFromConfig)))\n .command(withDeprecationWarning(indexerCommand(getConfiguration, getLocatorFromConfig)))\n .command(withDeprecationWarning(mempoolCommand(getConfiguration, getLocatorFromConfig)))\n .command(withDeprecationWarning(producerCommand(getConfiguration, getLocatorFromConfig)))\n .command(withDeprecationWarning(rewardRedemptionCommand(getConfiguration, getLocatorFromConfig)))\n .command(startCommand(getConfiguration, getLocatorFromConfig))\n .options({\n 'config': {\n type: 'string',\n description: 'Path to a config file to use instead of the default search.',\n alias: 'c',\n },\n 'mnemonic': {\n type: 'string',\n description: 'Shared root mnemonic used by actors that do not define their own mnemonic.',\n },\n 'dump-config': {\n type: 'boolean',\n description: 'Just process the configuration and print the resolved config to stdout, then exit. Secrets are redacted unless --with-secrets is also passed.',\n default: false,\n },\n 'with-secrets': {\n type: 'boolean',\n description: 'When used with --dump-config, print raw secret values (mnemonic, private keys, passwords) instead of \"[REDACTED]\". Use only on a developer machine.',\n default: false,\n },\n 'dump-providers': {\n type: 'boolean',\n description: 'Run the normal command flow up to provider locator construction, print the per-actor provider tree (with duplicate detection), then exit.',\n default: false,\n },\n 'skip-insecure-confirm': {\n type: 'boolean',\n description: 'Skip the interactive RETURN confirmation when the built-in dev mnemonic / insecure genesis reward wallet is active.',\n default: false,\n },\n })\n .help()\n .alias('help', 'h')\n .version(version)\n .argv\n\n await argv\n}\n", "import { getApiActor } from '@xyo-network/chain-api'\nimport { getBridgeActor } from '@xyo-network/chain-bridge'\nimport { getFinalizerActor } from '@xyo-network/chain-finalizer'\nimport { getIndexerActor } from '@xyo-network/chain-indexer'\nimport { getMempoolActor } from '@xyo-network/chain-mempool'\nimport type {\n ActorInstanceV3, ConfigWithMnemonic, GetLocatorFromConfig, OrchestratorInstance,\n} from '@xyo-network/chain-orchestration'\nimport { buildActorFromConfiguration } from '@xyo-network/chain-orchestration'\nimport { getProducerActor } from '@xyo-network/chain-producer'\nimport { getRewardRedemptionActor } from '@xyo-network/chain-reward-redemption'\nimport type { ProviderFactoryLocatorInstance } from '@xyo-network/xl1-sdk'\nimport type {\n ArgumentsCamelCase, Argv, CommandModule,\n} from 'yargs'\n\nimport { initLogger } from '../../initLogger.ts'\n\ninterface StartArgs {\n actors?: string[]\n}\n\nconst KNOWN_ACTORS = ['api', 'bridge', 'finalizer', 'indexer', 'mempool', 'producer', 'rewardRedemption'] as const\n\nconst BOOT_TIMEOUT_MS = 60_000\n\nfunction getActorsFromConfig(configuration: ConfigWithMnemonic): string[] | undefined {\n const enabledActors = configuration.actors\n .filter(actor => actor.enabled !== false)\n .map(actor => actor.name)\n return enabledActors.length > 0 ? enabledActors : undefined\n}\n\nfunction getDefaultActors(): string[] {\n return ['api', 'producer', 'finalizer']\n}\n\nasync function buildActor(\n name: string,\n locator: ProviderFactoryLocatorInstance,\n configuration: ConfigWithMnemonic,\n): Promise<ActorInstanceV3> {\n switch (name) {\n case 'api': {\n return await buildActorFromConfiguration(name, configuration, locator, getApiActor)\n }\n case 'bridge': {\n return await buildActorFromConfiguration(name, configuration, locator, getBridgeActor)\n }\n case 'mempool': {\n return await buildActorFromConfiguration(name, configuration, locator, getMempoolActor)\n }\n case 'producer': {\n return await buildActorFromConfiguration(name, configuration, locator, getProducerActor)\n }\n case 'rewardRedemption': {\n return await buildActorFromConfiguration(name, configuration, locator, getRewardRedemptionActor)\n }\n case 'finalizer': {\n return await buildActorFromConfiguration(name, configuration, locator, getFinalizerActor)\n }\n case 'indexer': {\n return await buildActorFromConfiguration(name, configuration, locator, getIndexerActor)\n }\n default: {\n throw new Error(`Unknown actor: ${name}`)\n }\n }\n}\n\nasync function bootActors(\n requestedActors: string[],\n locator: ProviderFactoryLocatorInstance,\n orchestrator: OrchestratorInstance,\n configuration: ConfigWithMnemonic,\n): Promise<void> {\n const startedAt = Date.now()\n const actors = await Promise.all(requestedActors.map(name => buildActor(name, locator, configuration)))\n for (const actor of actors) {\n await orchestrator.registerActor(actor)\n }\n await orchestrator.start()\n await orchestrator.whenReady(BOOT_TIMEOUT_MS)\n const ms = Date.now() - startedAt\n initLogger(configuration).info(`[xl1] system ready (${requestedActors.join('/')} in ${ms}ms)`)\n}\n\nexport function startCommand(getConfiguration: () => ConfigWithMnemonic, getLocatorFromConfig: GetLocatorFromConfig): CommandModule {\n return {\n command: ['start [actors..]', '$0'],\n describe: 'Run a full XL1 Node',\n builder: (yargs: Argv) => {\n return yargs\n .positional('actors', {\n type: 'string',\n array: true,\n choices: KNOWN_ACTORS,\n description: 'Actors to start (e.g. xl1 start api producer or xl1 start api,producer)',\n coerce: (values: string[]) => values.flatMap(v => v.split(',')),\n })\n .option('actors', {\n type: 'array',\n string: true,\n choices: KNOWN_ACTORS,\n description: 'List of actors to start (e.g. --actors api producer finalizer). Defaults to api, producer, and finalizer.',\n })\n },\n handler: async (argv: ArgumentsCamelCase<StartArgs>) => {\n const configuration = getConfiguration()\n const requestedActors = argv.actors !== undefined && argv.actors.length > 0\n ? argv.actors\n : getActorsFromConfig(configuration) ?? getDefaultActors()\n const { locator, orchestrator } = await getLocatorFromConfig(requestedActors, configuration)\n await bootActors(requestedActors, locator, orchestrator, configuration)\n },\n }\n}\n", "import type { Logger, LogLevelValue } from '@xylabs/sdk-js'\nimport {\n Base,\n ConsoleLogger, isDefined,\n LogLevel, SilentLogger,\n} from '@xylabs/sdk-js'\nimport type { ConfigWithMnemonic } from '@xyo-network/chain-orchestration'\n\nexport const initLogger = (config: Pick<ConfigWithMnemonic, 'log'>): Logger => {\n let logger: Logger\n if (config.log.silent) {\n logger = new SilentLogger()\n } else {\n let level: LogLevelValue | undefined\n if (isDefined(config.log.logLevel)) {\n const parsed = LogLevel[config.log.logLevel.toLowerCase() as keyof typeof LogLevel]\n if (isDefined(parsed)) level = parsed\n }\n logger = new ConsoleLogger(level)\n }\n Base.defaultLogger = logger\n return logger\n}\n", "import { delay } from '@xylabs/sdk-js'\nimport type { CommandModule } from 'yargs'\n\nexport function withDeprecationWarning(module: CommandModule): CommandModule {\n const { deprecated, handler } = module\n if (typeof deprecated === 'string') {\n return {\n ...module,\n handler: async (argv) => {\n console.warn(`[deprecated] ${deprecated}`)\n await delay(3000)\n return handler(argv)\n },\n }\n }\n return module\n}\n", "import { createDeepMerge, isDefined } from '@xylabs/sdk-js'\nimport {\n ActorMnemonicNotAllowedError,\n assertNoActorMnemonics,\n ConfigFileNotFoundError,\n type ConfigWithMnemonic,\n finalizeConfig,\n stripOrchestrationOnlyConnections,\n tryParseConfig,\n} from '@xyo-network/chain-orchestration'\nimport { isZodError } from '@xyo-network/xl1-sdk'\n\nconst deepMerge = createDeepMerge({ arrayStrategy: 'concat' })\n\nconst REDACTED = '[REDACTED]'\n\n/**\n * Names that always redact, regardless of nesting level. `connectionString` is\n * included because Mongo connection URIs commonly embed `user:password@host`.\n */\nconst REDACTED_KEY_NAMES = new Set<string>(['mnemonic', 'connectionString'])\n\n/**\n * Suffix-matched key names that redact. Catches any future `*PrivateKey`,\n * `*Secret`, or `*Password` field without us having to enumerate them here.\n */\nconst REDACTED_KEY_SUFFIX = /(PrivateKey|Secret|Password)$/i\n\nconst CONNECTION_NAME_ALIASES: Readonly<Record<string, string>> = {\n chainMongo: 'chain-mongo',\n defaultEvmRpc: 'default-evm-rpc',\n defaultRpc: 'default-rpc',\n localStore: 'local-store',\n restChainState: 'rest-chain-state',\n restFinalized: 'rest-finalized',\n restIndex: 'rest-index',\n s3ChainState: 's3-chain-state',\n s3Finalized: 's3-finalized',\n s3Index: 's3-index',\n}\n\nconst CLI_ONLY_ARG_KEYS = new Set([\n '$0',\n '_',\n 'config',\n 'dump-config',\n 'dumpConfig',\n 'dump-providers',\n 'dumpProviders',\n 'selected-actors',\n 'selectedActors',\n 'skip-insecure-confirm',\n 'skipInsecureConfirm',\n 'with-secrets',\n 'withSecrets',\n])\n\nfunction shouldRedactKey(key: string): boolean {\n if (REDACTED_KEY_NAMES.has(key)) return true\n return REDACTED_KEY_SUFFIX.test(key)\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return typeof value === 'object' && value !== null\n}\n\n/**\n * Returns a deep clone of `config` with secret-bearing leaf values replaced by\n * `'[REDACTED]'`. Walks plain objects and arrays. Leaves primitives, dates,\n * and other non-plain values untouched (other than via `structuredClone`).\n */\nexport function redactConfig<T>(config: T): T {\n const cloned = structuredClone(config) as unknown\n redactInPlace(cloned)\n return cloned as T\n}\n\nfunction redactInPlace(node: unknown): void {\n if (Array.isArray(node)) {\n for (const item of node) redactInPlace(item)\n return\n }\n if (node === null || typeof node !== 'object') return\n const obj = node as Record<string, unknown>\n for (const key of Object.keys(obj)) {\n if (shouldRedactKey(key) && obj[key] !== undefined && obj[key] !== null) {\n obj[key] = REDACTED\n } else {\n redactInPlace(obj[key])\n }\n }\n}\n\n/**\n * Yargs `.env()` with `dot-notation` turns `XL1_ACTORS__0__NAME=foo` into\n * `{ actors: { '0': { name: 'foo' } } }` \u2014 an object keyed by string indices\n * rather than an array. Normalize that back into an array so ConfigZod's\n * `actors` array schema accepts it.\n */\nfunction coerceActorsArray(argv: Record<string, unknown>): Record<string, unknown> {\n const actors = argv.actors\n if (actors === undefined || Array.isArray(actors)) return argv\n if (typeof actors !== 'object' || actors === null) return argv\n const entries = Object.entries(actors as Record<string, unknown>)\n const numericEntries = entries\n .map(([key, value]) => [Number(key), value] as const)\n .filter(([key]) => Number.isSafeInteger(key) && key >= 0)\n if (numericEntries.length !== entries.length) return argv\n const asArray: unknown[] = []\n for (const [key, value] of numericEntries) asArray[key] = value\n return { ...argv, actors: asArray }\n}\n\nfunction canonicalConnectionName(name: string): string {\n return CONNECTION_NAME_ALIASES[name] ?? name\n}\n\nfunction normalizeConnectionNames<T extends Record<string, unknown>>(config: T): T {\n const normalized: Record<string, unknown> = { ...config }\n const connections = normalized.connections\n if (isRecord(connections)) {\n const normalizedConnections: Record<string, unknown> = {}\n for (const [name, connection] of Object.entries(connections)) {\n normalizedConnections[canonicalConnectionName(name)] = connection\n }\n normalized.connections = normalizedConnections\n }\n\n const providerBindings = normalized.providerBindings\n if (isRecord(providerBindings)) {\n const normalizedBindings: Record<string, unknown> = {}\n for (const [moniker, binding] of Object.entries(providerBindings)) {\n if (!isRecord(binding)) {\n normalizedBindings[moniker] = binding\n continue\n }\n normalizedBindings[moniker] = {\n ...binding,\n ...(typeof binding.connection === 'string' && { connection: canonicalConnectionName(binding.connection) }),\n ...(typeof binding.transport === 'string' && { transport: canonicalConnectionName(binding.transport) }),\n }\n }\n normalized.providerBindings = normalizedBindings\n }\n\n return normalized as T\n}\n\nfunction stripCliOnlyArgs(argv: Record<string, unknown>): Record<string, unknown> {\n const stripped: Record<string, unknown> = {}\n for (const [key, value] of Object.entries(argv)) {\n if (!CLI_ONLY_ARG_KEYS.has(key)) stripped[key] = value\n }\n return stripped\n}\n\nasync function buildFinalConfig(argv: Record<string, unknown>): Promise<ConfigWithMnemonic> {\n const configPath = argv.config as string | undefined\n const parsedConfigFileRaw = normalizeConnectionNames(await tryParseConfig({ configPath, finalize: false }))\n const rootMnemonicFromFile = typeof parsedConfigFileRaw.mnemonic === 'string' ? parsedConfigFileRaw.mnemonic : undefined\n const normalizedArgv = normalizeConnectionNames(coerceActorsArray(argv))\n const configArgs = stripCliOnlyArgs(normalizedArgv)\n const argsForSdk = stripOrchestrationOnlyConnections(configArgs)\n const parsedConfigArgs = (argsForSdk.actors !== undefined || argsForSdk.connections !== undefined || argsForSdk.providerBindings !== undefined)\n ? argsForSdk\n : {}\n const rootMnemonicFromArgs = typeof normalizedArgv.mnemonic === 'string' ? normalizedArgv.mnemonic : undefined\n const parsedFileRecord = parsedConfigFileRaw as Record<string, unknown>\n let fileForMerge: Record<string, unknown> = parsedFileRecord\n const argvActors = configArgs.actors\n if (Array.isArray(argvActors) && argvActors.length > 0) {\n const { actors: _dropped, ...rest } = parsedFileRecord\n fileForMerge = rest\n }\n const rawMerged = deepMerge(fileForMerge, parsedConfigArgs)\n const mergedForSdk = stripOrchestrationOnlyConnections(rawMerged)\n const rootMnemonic = rootMnemonicFromArgs ?? rootMnemonicFromFile\n return finalizeConfig({\n ...mergedForSdk,\n ...(isDefined(rootMnemonic) && { mnemonic: rootMnemonic }),\n })\n}\n\nexport async function configMiddleware(argv: Record<string, unknown>, setConfiguration: (config: ConfigWithMnemonic) => void): Promise<void> {\n try {\n const finalConfig = await buildFinalConfig(argv)\n assertNoActorMnemonics(finalConfig)\n setConfiguration(finalConfig)\n\n if (argv['dump-config'] === true) {\n const withSecrets = Boolean(argv['with-secrets'])\n const output = withSecrets ? finalConfig : redactConfig(finalConfig)\n console.log(JSON.stringify(output, null, 2))\n // eslint-disable-next-line unicorn/no-process-exit\n process.exit(0)\n }\n } catch (err) {\n if (err instanceof ConfigFileNotFoundError) {\n console.error(`${err.message}. Check the path passed to --config/-c and try again.`)\n } else if (err instanceof ActorMnemonicNotAllowedError) {\n console.error(err.message)\n } else if (isZodError(err)) {\n console.error(`Zod error: ${err.message}`)\n } else {\n console.error(`Error parsing configuration: ${String(err)}`)\n }\n if (!(err instanceof ConfigFileNotFoundError) && !(err instanceof ActorMnemonicNotAllowedError)) {\n console.error(`Stack: ${err instanceof Error ? err.stack : 'N/A'}`)\n }\n throw new Error('Invalid configuration', { cause: err })\n }\n}\n", "import type { ProviderFactoryLocatorInstance } from '@xyo-network/xl1-sdk'\n\n/**\n * One row in the per-actor provider tree. Captures the moniker (registry key),\n * the implementation class, the dependency monikers the factory declared, the\n * factory scope, and a `count` of how many times an identical fingerprint\n * appeared in the same moniker bucket. The registry can hold the same factory\n * more than once (e.g. via merges or multi-moniker registrations); collapsing\n * keeps the tree readable while still surfacing the multiplicity.\n */\ninterface ProviderEntry {\n count: number\n dependencies: readonly string[]\n moniker: string\n providerName: string\n scope: string\n}\n\nconst CANONICAL_ACTOR_ORDER: readonly string[] = [\n 'producer', 'finalizer', 'api', 'mempool', 'bridge', 'rewardRedemption',\n]\n\n/**\n * Enumerates the providers registered directly on a single locator. Does not\n * walk the parent chain \u2014 each locator is reported on its own so that a reader\n * can see exactly which providers a given actor contributed.\n */\nfunction enumerateLocator(locator: ProviderFactoryLocatorInstance): ProviderEntry[] {\n const collapsed = new Map<string, ProviderEntry>()\n const registry = locator.registry as Record<string, unknown[] | undefined>\n for (const [moniker, factories] of Object.entries(registry)) {\n if (!factories) continue\n for (const factory of factories) {\n const f = factory as { dependencies?: readonly string[]; providerName?: string; scope?: string }\n const providerName = f.providerName ?? '<unknown>'\n const scope = f.scope ?? '<unknown>'\n const dependencies = f.dependencies ?? []\n const fingerprint = `${moniker}|${providerName}|${scope}|${dependencies.join(',')}`\n const existing = collapsed.get(fingerprint)\n if (existing) {\n existing.count += 1\n } else {\n collapsed.set(fingerprint, {\n count: 1, dependencies, moniker, providerName, scope,\n })\n }\n }\n }\n return collapsed.values().toArray().toSorted((a, b) => a.moniker.localeCompare(b.moniker) || a.providerName.localeCompare(b.providerName))\n}\n\nfunction buildOwnerIndex(perActor: ReadonlyMap<string, readonly ProviderEntry[]>): Map<string, Set<string>> {\n const monikerOwners = new Map<string, Set<string>>()\n for (const [actorName, entries] of perActor) {\n for (const entry of entries) {\n let owners = monikerOwners.get(entry.moniker)\n if (!owners) {\n owners = new Set()\n monikerOwners.set(entry.moniker, owners)\n }\n owners.add(actorName)\n }\n }\n return monikerOwners\n}\n\nfunction renderDuplicatesSummary(monikerOwners: ReadonlyMap<string, ReadonlySet<string>>): string[] {\n const duplicates = [...monikerOwners]\n .filter(([, owners]) => owners.size > 1)\n .map(([moniker, owners]) => ({ moniker, owners: [...owners].toSorted((a, b) => a.localeCompare(b)).map(formatGroupForDisplay) }))\n .toSorted((a, b) => a.moniker.localeCompare(b.moniker))\n if (duplicates.length === 0) return []\n const lines = ['Duplicate monikers (registered by more than one locator):']\n for (const { moniker, owners } of duplicates) {\n lines.push(` - ${moniker}: ${owners.join(', ')}`)\n }\n lines.push('')\n return lines\n}\n\n/**\n * Groups actor names whose locators share the same `registry` object reference.\n * Under the shared-locator architecture, API/mempool/finalizer etc. may\n * point to view locators that share one underlying registry \u2014 without this\n * grouping, the dump would print the same factory set N times and falsely\n * report every moniker as \"duplicate across actors.\"\n */\nfunction groupActorsBySharedRegistry(\n locators: Record<string, ProviderFactoryLocatorInstance>,\n): { actorNames: readonly string[]; locator: ProviderFactoryLocatorInstance }[] {\n const groups: { actorNames: string[]; locator: ProviderFactoryLocatorInstance; registry: unknown }[] = []\n for (const [actorName, locator] of Object.entries(locators)) {\n const existing = groups.find(g => g.registry === locator.registry)\n if (existing) {\n existing.actorNames.push(actorName)\n } else {\n groups.push({\n actorNames: [actorName], locator, registry: locator.registry,\n })\n }\n }\n return groups\n}\n\n/**\n * Stable id for a registry-sharing group: sorted, comma-joined actor names.\n * Used as the key in `monikerOwners`. Multi-actor group ids contain commas;\n * we display them parenthesized in the `also in:` annotation.\n */\nfunction groupId(actorNames: readonly string[]): string {\n return actorNames.toSorted((a, b) => a.localeCompare(b)).join(',')\n}\n\nfunction formatGroupForDisplay(groupKey: string): string {\n const members = groupKey.split(',')\n return members.length === 1 ? members[0] : `(${members.join(', ')})`\n}\n\nfunction renderGroupSection(\n actorNames: readonly string[],\n entries: readonly ProviderEntry[],\n monikerOwners: ReadonlyMap<string, ReadonlySet<string>>,\n): string[] {\n const sortedActors = actorNames.toSorted((a, b) => a.localeCompare(b))\n const ownGroupKey = groupId(sortedActors)\n const heading = sortedActors.length === 1\n ? `Providers for actor: ${sortedActors[0]} (${entries.length} registered)`\n : `Providers shared by actors: ${sortedActors.join(', ')} (${entries.length} registered)`\n const lines: string[] = [heading]\n if (entries.length === 0) {\n lines.push(' (none)', '')\n return lines\n }\n for (let i = 0; i < entries.length; i++) {\n const entry = entries[i]\n const isLast = i === entries.length - 1\n const branch = isLast ? '\u2514\u2500\u2500' : '\u251C\u2500\u2500'\n const owners = monikerOwners.get(entry.moniker) ?? new Set<string>()\n const otherOwners = [...owners]\n .filter(o => o !== ownGroupKey)\n .toSorted((a, b) => a.localeCompare(b))\n .map(formatGroupForDisplay)\n const dupNote = otherOwners.length > 0 ? ` \u26A0 also in: ${otherOwners.join(', ')}` : ''\n const depsNote = entry.dependencies.length > 0 ? `, deps: [${entry.dependencies.join(', ')}]` : ''\n const countNote = entry.count > 1 ? ` (\u00D7${entry.count})` : ''\n lines.push(` ${branch} ${entry.moniker}${countNote} [impl: ${entry.providerName}, scope: ${entry.scope}${depsNote}]${dupNote}`)\n }\n lines.push('')\n return lines\n}\n\n/**\n * Renders the locator map as a tree grouped by registry identity, annotating\n * any moniker that appears in more than one *registry* with `\u26A0 also in: ...`.\n *\n * - When all input locators share one registry (shared-locator path), a single\n * \"Providers shared by actors: \u2026\" section is rendered.\n * - When some actors have distinct registries (legacy `_root` + per-actor\n * child architecture), each registry is rendered separately. `_root` is\n * ordered first.\n *\n * The \"Duplicate monikers\" summary at the bottom only flags monikers\n * registered by *different* registries \u2014 duplicates within one registry are\n * already collapsed into per-entry `(\u00D7N)` counts by `enumerateLocator`.\n */\nexport function formatProviderTree(locators: Record<string, ProviderFactoryLocatorInstance>): string {\n const groups = groupActorsBySharedRegistry(locators)\n\n // Per-actor moniker ownership (used for the \"also in:\" annotation), but\n // attribute each moniker to the GROUP it belongs to \u2014 the \"actor name\" the\n // index uses is the joined group key, so two actors that share a registry\n // never appear as duplicates of each other.\n const groupKeys = groups.map(g => ({ ...g, key: groupId(g.actorNames) }))\n const perGroup = new Map<string, ProviderEntry[]>()\n for (const g of groupKeys) perGroup.set(g.key, enumerateLocator(g.locator))\n const monikerOwners = buildOwnerIndex(perGroup)\n\n // Order: legacy `_root` first when present; otherwise alphabetical by sorted\n // actor names within the group, with the canonical actor order applied to\n // the *primary* (sorted-first) actor name in each group.\n const orderedGroups = [...groupKeys].toSorted((a, b) => {\n const aHasRoot = a.actorNames.includes('_root')\n const bHasRoot = b.actorNames.includes('_root')\n if (aHasRoot !== bHasRoot) return aHasRoot ? -1 : 1\n const ai = CANONICAL_ACTOR_ORDER.indexOf(a.actorNames[0])\n const bi = CANONICAL_ACTOR_ORDER.indexOf(b.actorNames[0])\n if (ai !== bi) return (ai === -1 ? Number.MAX_SAFE_INTEGER : ai) - (bi === -1 ? Number.MAX_SAFE_INTEGER : bi)\n return a.key.localeCompare(b.key)\n })\n\n const lines: string[] = ['XL1 Provider Dump', '=================', '']\n for (const g of orderedGroups) {\n lines.push(...renderGroupSection(g.actorNames.toSorted((a, b) => a.localeCompare(b)), perGroup.get(g.key) ?? [], monikerOwners))\n }\n lines.push(...renderDuplicatesSummary(monikerOwners))\n return lines.join('\\n')\n}\n", "/* eslint-disable no-irregular-whitespace, @stylistic/max-len */\nexport const XL1LogoColorizedAscii = `\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;118;111;144m_\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;72;32;223m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u2560\u2560\u001B[0m\u001B[38;2;103;85;170m_\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;79;121;152m\u2566\u001B[0m\u001B[38;2;82;121;151m\u2566\u001B[0m\u001B[38;2;112;125;136m_\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;88;59;196m[\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;73;34;221m\u2592\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;121;121;127m_\u001B[0m\u001B[38;2;100;101;128m\u2554\u001B[0m\u001B[38;2;93;94;127m\u2566\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;82;121;151m\u00B2\u001B[0m\u001B[38;2;44;116;170m\u2560\u001B[0m\u001B[38;2;44;116;171m\u2592\u001B[0m\u001B[38;2;51;117;167mD\u001B[0m\u001B[38;2;80;121;152m\u2566\u001B[0m\u001B[38;2;111;125;136m_\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;67;23;232m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;120;121;128m_\u001B[0m\u001B[38;2;100;101;127m\u2554\u001B[0m\u001B[38;2;79;81;127mR\u001B[0m\u001B[38;2;71;73;128m\u2592\u001B[0m\u001B[38;2;71;73;128m\u2592\u001B[0m\u001B[38;2;88;90;127m\u2559\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;55;117;165m\u255A\u001B[0m\u001B[38;2;44;116;171m\u2592\u001B[0m\u001B[38;2;44;116;171m\u2592\u2592\u001B[0m\u001B[38;2;50;116;167mD\u001B[0m\u001B[38;2;80;121;152m\u2566\u00A0\u001B[0m\u001B[38;2;106;90;165mj\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u001B[0m\u001B[38;2;89;61;194mH\u00A0\u001B[0m\u001B[38;2;99;100;127m\u2554\u001B[0m\u001B[38;2;79;80;127mD\u001B[0m\u001B[38;2;71;73;128m\u2592\u001B[0m\u001B[38;2;71;73;128m\u2592\u2592\u2560\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;83;121;150m\u00B2\u001B[0m\u001B[38;2;44;116;170m\u2592\u001B[0m\u001B[38;2;44;116;171m\u2592\u2592\u2592\u00A0\u001B[0m\u001B[38;2;76;38;217m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u2560\u00A0\u001B[0m\u001B[38;2;74;76;128m\u2560\u001B[0m\u001B[38;2;71;73;128m\u2592\u2592\u2592\u001B[0m\u001B[38;2;89;90;128m\u2559\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;90;118;148m\\`\u001B[0m\u001B[38;2;89;107;153m_\u001B[0m\u001B[38;2;93;97;154m,\u001B[0m\u001B[38;2;105;89;166m\u2553\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u2560\u2560\u001B[0m\u001B[38;2;95;72;183m\u2553\u001B[0m\u001B[38;2;106;96;152m_\u001B[0m\u001B[38;2;100;94;143m\\`\u001B[0m\u001B[38;2;101;100;133m\\`\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u001B[0m\u001B[38;2;122;118;137m_\u001B[0m\u001B[38;2;113;102;153m,\u001B[0m\u001B[38;2;108;94;161m\u2553\u001B[0m\u001B[38;2;104;86;169m\u2553\u001B[0m\u001B[38;2;98;77;178m\u2554\u001B[0m\u001B[38;2;93;67;188m\u2557\u001B[0m\u001B[38;2;88;59;196m\u03C6\u001B[0m\u001B[38;2;83;51;204m@\u001B[0m\u001B[38;2;78;42;213mD\u001B[0m\u001B[38;2;72;32;223m\u2592\u001B[0m\u001B[38;2;68;24;231m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u001B[0m\u001B[38;2;71;30;225m\u2592\u001B[0m\u001B[38;2;77;40;215m\u2592\u001B[0m\u001B[38;2;82;49;206mK\u001B[0m\u001B[38;2;87;57;198m\u03C6\u001B[0m\u001B[38;2;91;65;190m\u2557\u001B[0m\u001B[38;2;97;75;180m\u2566\u001B[0m\u001B[38;2;103;84;171m\u2556\u001B[0m\u001B[38;2;107;92;163m\u00B2\u001B[0m\u001B[38;2;112;101;154m_\u001B[0m\u001B[38;2;119;112;143m_\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u001B[0m\u001B[38;2;106;91;164m\\`\u001B[0m\u001B[38;2;94;70;185m^\u001B[0m\u001B[38;2;89;62;193m\u2559\u001B[0m\u001B[38;2;85;54;201m\u2559\u001B[0m\u001B[38;2;80;45;210m\u255A\u001B[0m\u001B[38;2;74;35;220m\u255D\u001B[0m\u001B[38;2;69;26;229m\u2560\u001B[0m\u001B[38;2;66;22;233m\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u2560\u001B[0m\u001B[38;2;73;33;222m\u255D\u001B[0m\u001B[38;2;79;43;212m\u2569\u001B[0m\u001B[38;2;84;52;203m\u255C\u001B[0m\u001B[38;2;88;60;195m\u2559\u001B[0m\u001B[38;2;93;68;187m^\u001B[0m\u001B[38;2;100;80;175m\\`\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;113;84;152m\\`\u001B[0m\u001B[38;2;103;79;169m'\u001B[0m\u001B[38;2;95;72;183m\"\u001B[0m\u001B[38;2;87;57;198m\u2559\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u2560\u2560\u001B[0m\u001B[38;2;80;46;209m\u255C\u001B[0m\u001B[38;2;94;70;185m^\u001B[0m\u001B[38;2;102;77;175m^\u001B[0m\u001B[38;2;112;81;162m\\`\u001B[0m\u001B[38;2;115;92;155m\\`\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;145;116;107m,\u001B[0m\u001B[38;2;199;82;45m\u2560\u001B[0m\u001B[38;2;207;77;35m\u2592\u001B[0m\u001B[38;2;207;77;35m\u2592\u2560\u00A0\u001B[0m\u001B[38;2;70;28;227m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u2560\u00A0\u001B[0m\u001B[38;2;189;49;97m\u00E5\u001B[0m\u001B[38;2;203;32;90m\u2560\u001B[0m\u001B[38;2;203;32;90m\u2560\u2560\u001B[0m\u001B[38;2;155;92;114m,\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;175;98;73m\u2554\u001B[0m\u001B[38;2;207;77;35m\u2592\u001B[0m\u001B[38;2;207;77;35m\u2592\u2592\u2592\u001B[0m\u001B[38;2;197;83;47m\u2569\u00A0\u001B[0m\u001B[38;2;98;76;179m[\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u001B[0m\u001B[38;2;81;48;207mH\u00A0\u001B[0m\u001B[38;2;188;51;98m\u255A\u001B[0m\u001B[38;2;203;32;90m\u2560\u001B[0m\u001B[38;2;203;32;90m\u2560\u2560\u2560\u001B[0m\u001B[38;2;183;57;100mH\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;146;116;106m,\u001B[0m\u001B[38;2;199;82;44m\u2560\u001B[0m\u001B[38;2;207;77;35m\u2592\u001B[0m\u001B[38;2;207;77;35m\u2592\u001B[0m\u001B[38;2;196;84;48m\u2569\u001B[0m\u001B[38;2;168;102;81m^\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u2560\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;160;87;111m'\u001B[0m\u001B[38;2;187;52;98m\u255A\u001B[0m\u001B[38;2;203;32;90m\u2560\u001B[0m\u001B[38;2;203;32;90m\u2560\u2560\u001B[0m\u001B[38;2;156;91;113m,\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;198;83;46m\u2569\u001B[0m\u001B[38;2;194;85;50m\u2569\u001B[0m\u001B[38;2;167;102;82m^\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;81;46;209m\u255A\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u2560\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;159;88;112m'\u001B[0m\u001B[38;2;186;53;98m\u255A\u001B[0m\u001B[38;2;197;40;93m\u2569\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;110;97;158m'\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\u001B[38;2;94;69;186mH\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;68;25;230m\u2560\u001B[0m\u001B[38;2;66;21;234m\u2560\u001B[0m\n\u001B[38;2;128;128;128m\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u001B[0m\u001B[38;2;108;93;162m\u00B2\u001B[0m\u001B[38;2;99;79;176m^\u001B[0m`\n", "import type { UsageMeta } from '@xyo-network/xl1-sdk'\nimport { isUsageMeta } from '@xyo-network/xl1-sdk'\nimport type { Options } from 'yargs'\nimport { globalRegistry } from 'zod/mini'\n\nconst usageMetaToOptions = (meta: UsageMeta): Options => {\n return meta\n}\n\nexport const optionsFromGlobalZodRegistry = (): Record<string, Options> => {\n const opts: Record<string, Options> = {}\n for (const schema of Object.values(globalRegistry._map)) {\n if (isUsageMeta(schema)) {\n if (schema.hidden === true) continue // skip hidden options\n opts[schema.title] = usageMetaToOptions(schema)\n }\n }\n return opts\n}\n", "import { start } from './start.ts'\n\ntry {\n await start()\n} catch (err) {\n // If we're in development mode, log the stack trace to the console\n if (process.env.NODE_ENV === 'development') console.error('An error occurred during startup:', err)\n // eslint-disable-next-line unicorn/no-process-exit\n process.exit(1)\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["isDefined", "config", "configuration", "getConfiguration", "getLocatorFromConfig", "yargs", "isDefined", "config", "output", "isDefined", "configuration", "argv", "config"]
|
|
7
7
|
}
|