@aria-cli/cli 1.0.57 → 1.0.58
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/bin/aria.mjs +2 -2
- package/package.json +17 -76
- package/dist/.tsbuildinfo +0 -1
- package/dist/attached-local-control-client.js +0 -826
- package/dist/bootstrap-local-control-client.js +0 -2
- package/dist/capability-aware-method-proxy.js +0 -42
- package/dist/cli-context.js +0 -160
- package/dist/commands/arions.js +0 -174
- package/dist/commands/auth.js +0 -123
- package/dist/commands/daemon.js +0 -367
- package/dist/commands/definitions.js +0 -176
- package/dist/commands/index.js +0 -80
- package/dist/commands/login-handler.js +0 -1108
- package/dist/commands/logout-handler.js +0 -92
- package/dist/commands/memory-handlers.js +0 -89
- package/dist/commands/pairing.js +0 -60
- package/dist/commands/runtime-cutover-reset-command.js +0 -12
- package/dist/commands/runtime-cutover-reset.js +0 -265
- package/dist/commands/terminal-setup.js +0 -84
- package/dist/config/aria-config.js +0 -238
- package/dist/config/index.js +0 -3
- package/dist/config/loader.js +0 -97
- package/dist/config.js +0 -142
- package/dist/daemon-info.js +0 -10
- package/dist/ensure-daemon.js +0 -128
- package/dist/entrypoints/command-mode.js +0 -5
- package/dist/entrypoints/daemon.js +0 -50
- package/dist/entrypoints/headless-stdio.js +0 -25
- package/dist/entrypoints/interactive.js +0 -80
- package/dist/event-loop-watchdog.js +0 -73
- package/dist/headless/auth-orchestrator.js +0 -508
- package/dist/headless/auth-service.js +0 -43
- package/dist/headless/bootstrap-fast-path.js +0 -112
- package/dist/headless/call-command.js +0 -143
- package/dist/headless/daemon-service.js +0 -318
- package/dist/headless/hook-actions.js +0 -235
- package/dist/headless/hook-service.js +0 -42
- package/dist/headless/kernel-services.js +0 -216
- package/dist/headless/kernel.js +0 -785
- package/dist/headless/operations/arion.js +0 -119
- package/dist/headless/operations/auth.js +0 -45
- package/dist/headless/operations/client.js +0 -31
- package/dist/headless/operations/config.js +0 -69
- package/dist/headless/operations/daemon.js +0 -47
- package/dist/headless/operations/hook.js +0 -56
- package/dist/headless/operations/index.js +0 -11
- package/dist/headless/operations/memory.js +0 -102
- package/dist/headless/operations/message.js +0 -279
- package/dist/headless/operations/model.js +0 -100
- package/dist/headless/operations/peer.js +0 -56
- package/dist/headless/operations/run.js +0 -24
- package/dist/headless/operations/session.js +0 -90
- package/dist/headless/operations/system.js +0 -19
- package/dist/headless/operations/utils.js +0 -35
- package/dist/headless/run-orchestrator.js +0 -703
- package/dist/headless/stdio-server.js +0 -439
- package/dist/history/SessionHistory.js +0 -8
- package/dist/history/SessionHistoryClient.js +0 -186
- package/dist/history/conversation-message.js +0 -112
- package/dist/history/index.js +0 -8
- package/dist/history/jsonl-replay.js +0 -154
- package/dist/history/repair-tool-pairing.js +0 -84
- package/dist/history/stall-phase-bridge.js +0 -11
- package/dist/history/turn-accumulator.js +0 -427
- package/dist/index.js +0 -7
- package/dist/ink-repl.js +0 -4183
- package/dist/local-control-bootstrap.js +0 -26
- package/dist/local-control-client.js +0 -2
- package/dist/local-control-error-reporting.js +0 -34
- package/dist/local-control-http-client.js +0 -362
- package/dist/local-control-lazy-wrapper.js +0 -363
- package/dist/local-control-manager.js +0 -146
- package/dist/main.js +0 -62
- package/dist/network-security.js +0 -62
- package/dist/networking-server.js +0 -38
- package/dist/peer-identity.js +0 -23
- package/dist/polling-subscription.js +0 -34
- package/dist/relaunch.js +0 -617
- package/dist/release-notes.js +0 -35
- package/dist/repl-cleanup.js +0 -47
- package/dist/runtime/configure-bun-sqlite.js +0 -3
- package/dist/runtime/crash-handlers.js +0 -111
- package/dist/runtime/interactive-invocation.js +0 -39
- package/dist/runtime/internal-mode.js +0 -14
- package/dist/runtime/launch-spec.js +0 -64
- package/dist/runtime/owner-lease.js +0 -44
- package/dist/runtime/public-mode.js +0 -20
- package/dist/runtime/run-internal-mode.js +0 -18
- package/dist/runtime/runtime-kind.js +0 -32
- package/dist/runtime/spawn-aria.js +0 -38
- package/dist/selectable-client.js +0 -2
- package/dist/selectable-peer.js +0 -2
- package/dist/session.js +0 -203
- package/dist/slash-commands.js +0 -80
- package/dist/sounds.js +0 -210
- package/dist/ui/App.js +0 -526
- package/dist/ui/components/AnthropicMethodPicker.js +0 -6
- package/dist/ui/components/ArionPrompt.js +0 -15
- package/dist/ui/components/AutocompleteDropdown.js +0 -23
- package/dist/ui/components/AutonomySelector.js +0 -55
- package/dist/ui/components/Banner.js +0 -98
- package/dist/ui/components/ConversationHistory.js +0 -175
- package/dist/ui/components/CopilotDeviceLoginFlow.js +0 -88
- package/dist/ui/components/CopilotSourcePicker.js +0 -50
- package/dist/ui/components/Cost.js +0 -10
- package/dist/ui/components/CustomSelect/option-map.js +0 -30
- package/dist/ui/components/CustomSelect/select-option.js +0 -13
- package/dist/ui/components/CustomSelect/select.js +0 -42
- package/dist/ui/components/CustomSelect/use-select-state.js +0 -179
- package/dist/ui/components/CustomSelect/use-select.js +0 -15
- package/dist/ui/components/ErrorDisplay.js +0 -35
- package/dist/ui/components/FallbackToolUseRejectedMessage.js +0 -7
- package/dist/ui/components/FileEditToolUpdatedMessage.js +0 -57
- package/dist/ui/components/HandoffMarker.js +0 -18
- package/dist/ui/components/HighlightedCode.js +0 -21
- package/dist/ui/components/InputArea.js +0 -187
- package/dist/ui/components/Message.js +0 -25
- package/dist/ui/components/OAuthLoginFlow.js +0 -113
- package/dist/ui/components/OutputTruncation.js +0 -35
- package/dist/ui/components/PermissionPrompt.js +0 -79
- package/dist/ui/components/PipelineTimingPanel.js +0 -15
- package/dist/ui/components/ProviderMethodPicker.js +0 -61
- package/dist/ui/components/ProviderPicker.js +0 -63
- package/dist/ui/components/RenderItemView.js +0 -71
- package/dist/ui/components/Spinner.js +0 -46
- package/dist/ui/components/StatusBar.js +0 -95
- package/dist/ui/components/StreamingIndicator.js +0 -55
- package/dist/ui/components/StructuredDiff.js +0 -168
- package/dist/ui/components/TextInputOverlay.js +0 -43
- package/dist/ui/components/ThinkingBlock.js +0 -82
- package/dist/ui/components/ToolCost.js +0 -17
- package/dist/ui/components/ToolExecution.js +0 -61
- package/dist/ui/components/ToolHeader.js +0 -51
- package/dist/ui/components/ToolRenderLayoutContext.js +0 -14
- package/dist/ui/components/ToolResultWrapper.js +0 -6
- package/dist/ui/components/ToolUseLoader.js +0 -35
- package/dist/ui/components/TraceWaterfall.js +0 -91
- package/dist/ui/components/index.js +0 -33
- package/dist/ui/components/messages/AssistantTextMessage.js +0 -25
- package/dist/ui/components/messages/UserImageMessage.js +0 -12
- package/dist/ui/components/messages/UserTextMessage.js +0 -12
- package/dist/ui/components/overlays/ArionSelector.js +0 -68
- package/dist/ui/components/overlays/ClientSelector.js +0 -62
- package/dist/ui/components/overlays/CommandPalette.js +0 -67
- package/dist/ui/components/overlays/DaemonControl.js +0 -87
- package/dist/ui/components/overlays/InviteShareOverlay.js +0 -15
- package/dist/ui/components/overlays/JoinInviteOverlay.js +0 -32
- package/dist/ui/components/overlays/MemoryBrowser.js +0 -100
- package/dist/ui/components/overlays/MessageSelector.js +0 -123
- package/dist/ui/components/overlays/ModelSelector.js +0 -211
- package/dist/ui/components/overlays/PairRequestOverlay.js +0 -42
- package/dist/ui/components/overlays/PeerSelector.js +0 -84
- package/dist/ui/components/overlays/SessionSelector.js +0 -102
- package/dist/ui/components/overlays/SoundSelector.js +0 -86
- package/dist/ui/components/overlays/ThemeSelector.js +0 -139
- package/dist/ui/components/overlays/index.js +0 -15
- package/dist/ui/components/permissions/BashPermissionRequest/BashPermissionRequest.js +0 -53
- package/dist/ui/components/permissions/FallbackPermissionRequest.js +0 -56
- package/dist/ui/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +0 -76
- package/dist/ui/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js +0 -18
- package/dist/ui/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +0 -64
- package/dist/ui/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +0 -26
- package/dist/ui/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +0 -141
- package/dist/ui/components/permissions/PermissionRequest.js +0 -70
- package/dist/ui/components/permissions/PermissionRequestTitle.js +0 -41
- package/dist/ui/components/permissions/hooks.js +0 -10
- package/dist/ui/components/permissions/toolUseOptions.js +0 -68
- package/dist/ui/components/permissions/utils.js +0 -10
- package/dist/ui/components/text-input/Cursor.js +0 -326
- package/dist/ui/components/text-input/TextInput.js +0 -231
- package/dist/ui/components/text-input/imagePaste.js +0 -28
- package/dist/ui/components/text-input/index.js +0 -6
- package/dist/ui/components/text-input/useDoublePress.js +0 -30
- package/dist/ui/components/text-input/useTextInput.js +0 -245
- package/dist/ui/components/tool-types.js +0 -9
- package/dist/ui/constants/figures.js +0 -4
- package/dist/ui/constants/index.js +0 -3
- package/dist/ui/display-mode.js +0 -93
- package/dist/ui/display-policy.js +0 -19
- package/dist/ui/hooks/index.js +0 -6
- package/dist/ui/hooks/useCommandAutocomplete.js +0 -93
- package/dist/ui/hooks/useDoublePress.js +0 -37
- package/dist/ui/hooks/useIndicatorState.js +0 -55
- package/dist/ui/hooks/useInterval.js +0 -23
- package/dist/ui/hooks/useKeyboardShortcuts.js +0 -127
- package/dist/ui/hooks/useTerminalSize.js +0 -55
- package/dist/ui/hooks/useUnifiedMessages.js +0 -117
- package/dist/ui/indicator-state.js +0 -44
- package/dist/ui/markdown/highlight.js +0 -44
- package/dist/ui/markdown/index.js +0 -1460
- package/dist/ui/markdown/tokenizer.js +0 -24
- package/dist/ui/render-item.js +0 -5
- package/dist/ui/screens/REPL.js +0 -119
- package/dist/ui/screens/approval-lifecycle.js +0 -38
- package/dist/ui/status-line.js +0 -72
- package/dist/ui/theme/index.js +0 -51
- package/dist/ui/theme/themes/claude-dark-daltonized.js +0 -51
- package/dist/ui/theme/themes/claude-dark.js +0 -50
- package/dist/ui/theme/themes/claude-light-daltonized.js +0 -51
- package/dist/ui/theme/themes/claude-light.js +0 -50
- package/dist/ui/theme/themes/dark-accessible.js +0 -18
- package/dist/ui/theme/themes/dark.js +0 -49
- package/dist/ui/theme/themes/light-accessible.js +0 -18
- package/dist/ui/theme/themes/light.js +0 -49
- package/dist/ui/theme/types.js +0 -3
- package/dist/ui/theme.js +0 -142
- package/dist/ui/to-render-items.js +0 -145
- package/dist/ui/tools/AgentTool/index.js +0 -30
- package/dist/ui/tools/ArchitectTool/index.js +0 -31
- package/dist/ui/tools/AskUserTool/index.js +0 -46
- package/dist/ui/tools/BashTool/BashToolResultMessage.js +0 -11
- package/dist/ui/tools/BashTool/OutputLine.js +0 -21
- package/dist/ui/tools/BashTool/index.js +0 -91
- package/dist/ui/tools/BrowseTool/index.js +0 -43
- package/dist/ui/tools/BrowserTool/index.js +0 -47
- package/dist/ui/tools/CbmTool/index.js +0 -188
- package/dist/ui/tools/CheckDelegationTool/index.js +0 -46
- package/dist/ui/tools/CheckMessagesTool/index.js +0 -85
- package/dist/ui/tools/CreateQuipTool/index.js +0 -30
- package/dist/ui/tools/CreateSkillTool/index.js +0 -22
- package/dist/ui/tools/CreateToolTool/index.js +0 -31
- package/dist/ui/tools/DelegateRemoteTool/index.js +0 -42
- package/dist/ui/tools/DeployTool/index.js +0 -47
- package/dist/ui/tools/FffTool/index.js +0 -103
- package/dist/ui/tools/FileEditTool/index.js +0 -67
- package/dist/ui/tools/FileReadTool/index.js +0 -68
- package/dist/ui/tools/FileWriteTool/index.js +0 -61
- package/dist/ui/tools/ForkTool/index.js +0 -47
- package/dist/ui/tools/FrgTool/index.js +0 -96
- package/dist/ui/tools/GetThreadTool/index.js +0 -39
- package/dist/ui/tools/GlobTool/index.js +0 -50
- package/dist/ui/tools/GrepTool/index.js +0 -84
- package/dist/ui/tools/HatchArionTool/index.js +0 -36
- package/dist/ui/tools/LearnSkillTool/index.js +0 -22
- package/dist/ui/tools/LearnTool/index.js +0 -43
- package/dist/ui/tools/LearnToolTool/index.js +0 -22
- package/dist/ui/tools/ListClientsTool/index.js +0 -39
- package/dist/ui/tools/LspTool/index.js +0 -261
- package/dist/ui/tools/MCPTool/index.js +0 -33
- package/dist/ui/tools/ManageNetworkTool/index.js +0 -53
- package/dist/ui/tools/MemoryReadTool/index.js +0 -64
- package/dist/ui/tools/MemoryWriteTool/index.js +0 -20
- package/dist/ui/tools/NotebookEditTool/index.js +0 -33
- package/dist/ui/tools/NotebookReadTool/index.js +0 -25
- package/dist/ui/tools/OutlookReadTool/index.js +0 -66
- package/dist/ui/tools/OutlookReplyTool/index.js +0 -49
- package/dist/ui/tools/OutlookSendTool/index.js +0 -49
- package/dist/ui/tools/PauseDelegationTool/index.js +0 -35
- package/dist/ui/tools/ProbeTool/index.js +0 -121
- package/dist/ui/tools/ProcessTool/index.js +0 -66
- package/dist/ui/tools/QuestListTool/index.js +0 -46
- package/dist/ui/tools/QuestReportTool/index.js +0 -49
- package/dist/ui/tools/QuestUpdateTool/index.js +0 -87
- package/dist/ui/tools/QuipCommentTool/index.js +0 -69
- package/dist/ui/tools/QuipReadTool/index.js +0 -71
- package/dist/ui/tools/RestArionTool/index.js +0 -32
- package/dist/ui/tools/RestartTool/index.js +0 -35
- package/dist/ui/tools/ResumeDelegationTool/index.js +0 -35
- package/dist/ui/tools/RetireArionTool/index.js +0 -32
- package/dist/ui/tools/RgTool/index.js +0 -73
- package/dist/ui/tools/SearchKnowledgeTool/index.js +0 -43
- package/dist/ui/tools/SearchMessagesTool/index.js +0 -43
- package/dist/ui/tools/SelfDiagnoseTool/index.js +0 -61
- package/dist/ui/tools/SendMessageTool/index.js +0 -45
- package/dist/ui/tools/SerenaTool/index.js +0 -124
- package/dist/ui/tools/SessionHistoryTool/index.js +0 -52
- package/dist/ui/tools/SgTool/index.js +0 -80
- package/dist/ui/tools/SlackReactTool/index.js +0 -41
- package/dist/ui/tools/SlackReadTool/index.js +0 -48
- package/dist/ui/tools/SlackSendTool/index.js +0 -45
- package/dist/ui/tools/SpawnWorkerTool/index.js +0 -33
- package/dist/ui/tools/StickerRequestTool/index.js +0 -19
- package/dist/ui/tools/ThinkTool/index.js +0 -17
- package/dist/ui/tools/UgTool/index.js +0 -108
- package/dist/ui/tools/UseSkillTool/index.js +0 -22
- package/dist/ui/tools/WakeArionTool/index.js +0 -32
- package/dist/ui/tools/WebFetchTool/index.js +0 -56
- package/dist/ui/tools/WebSearchTool/index.js +0 -44
- package/dist/ui/tools/lsTool/index.js +0 -58
- package/dist/ui/tools/registry.js +0 -197
- package/dist/ui/tools/tool-renderer.js +0 -11
- package/dist/ui/tools/truncation.js +0 -35
- package/dist/ui/types/anthropic.js +0 -4
- package/dist/ui/types/index.js +0 -2
- package/dist/ui/types/message.js +0 -3
- package/dist/ui/types/tool.js +0 -4
- package/dist/ui/utils/array.js +0 -4
- package/dist/ui/utils/cursor.js +0 -131
- package/dist/ui/utils/diff.js +0 -120
- package/dist/ui/utils/format.js +0 -42
- package/dist/ui/utils/fuzzy.js +0 -59
- package/dist/ui/utils/index.js +0 -11
- package/dist/ui/utils/keys.js +0 -8
- package/dist/ui/utils/patch.js +0 -17
- package/dist/ui/utils/risk.js +0 -114
- package/dist/ui/utils/terminal-image.js +0 -70
- package/dist/ui/utils/validation.js +0 -48
- package/dist/ui/verb-pairs.js +0 -248
- package/dist/ui.js +0 -131
- package/src/entrypoints/command-mode.ts +0 -5
- package/src/entrypoints/daemon.ts +0 -54
- package/src/entrypoints/headless-stdio.ts +0 -27
- package/src/entrypoints/interactive.ts +0 -112
- package/src/main.ts +0 -72
- package/src/runtime/configure-bun-sqlite.ts +0 -3
- package/src/runtime/crash-handlers.ts +0 -128
- package/src/runtime/interactive-invocation.test.ts +0 -42
- package/src/runtime/interactive-invocation.ts +0 -51
- package/src/runtime/internal-mode.test.ts +0 -19
- package/src/runtime/internal-mode.ts +0 -24
- package/src/runtime/launch-spec.test.ts +0 -26
- package/src/runtime/launch-spec.ts +0 -84
- package/src/runtime/owner-lease.ts +0 -52
- package/src/runtime/public-mode.test.ts +0 -18
- package/src/runtime/public-mode.ts +0 -19
- package/src/runtime/run-internal-mode.ts +0 -19
- package/src/runtime/runtime-kind.test.ts +0 -23
- package/src/runtime/runtime-kind.ts +0 -41
- package/src/runtime/spawn-aria.ts +0 -62
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { startHeadlessStdioServer } from "../headless/stdio-server.js";
|
|
2
|
-
|
|
3
|
-
function parseHeadlessArgs(argv: string[]): { arionName?: string } {
|
|
4
|
-
let arionName: string | undefined;
|
|
5
|
-
|
|
6
|
-
for (let i = 0; i < argv.length; i += 1) {
|
|
7
|
-
const arg = argv[i];
|
|
8
|
-
if (arg === "--arion") {
|
|
9
|
-
const next = argv[i + 1];
|
|
10
|
-
if (!next) throw new Error("--arion requires a value");
|
|
11
|
-
arionName = next;
|
|
12
|
-
i += 1;
|
|
13
|
-
continue;
|
|
14
|
-
}
|
|
15
|
-
throw new Error(`[aria] Unknown internal headless-stdio arg: ${arg}`);
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
return { arionName };
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
export async function runHeadlessStdioEntrypoint(argv: string[]): Promise<void> {
|
|
22
|
-
const parsed = parseHeadlessArgs(argv);
|
|
23
|
-
await startHeadlessStdioServer({
|
|
24
|
-
cwd: process.cwd(),
|
|
25
|
-
arionName: parsed.arionName,
|
|
26
|
-
});
|
|
27
|
-
}
|
|
@@ -1,112 +0,0 @@
|
|
|
1
|
-
import { ArionManager, ArionStorage } from "@aria-cli/aria";
|
|
2
|
-
import { Memoria } from "@aria-cli/memoria";
|
|
3
|
-
import { getCliModels } from "@aria-cli/models";
|
|
4
|
-
import type { InteractiveInvocation } from "../runtime/interactive-invocation.js";
|
|
5
|
-
import { createAttachedCliContext } from "../cli-context.js";
|
|
6
|
-
import { getAriaDir } from "../config.js";
|
|
7
|
-
import { ensureDaemon } from "../ensure-daemon.js";
|
|
8
|
-
import { startInkRepl } from "../ink-repl.js";
|
|
9
|
-
import { attachExistingLocalControlClient } from "../local-control-client.js";
|
|
10
|
-
import { SessionHistory } from "../history/index.js";
|
|
11
|
-
import { ArionSession } from "../session.js";
|
|
12
|
-
|
|
13
|
-
async function recallUserName(memoria: Memoria): Promise<string | null> {
|
|
14
|
-
try {
|
|
15
|
-
const raw = memoria.storage?.getConfigValue?.("user_profile");
|
|
16
|
-
return raw ? (JSON.parse(raw).name ?? null) : null;
|
|
17
|
-
} catch {
|
|
18
|
-
return null;
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export async function runInteractiveEntrypoint(invocation: InteractiveInvocation): Promise<void> {
|
|
23
|
-
const ariaHome = getAriaDir();
|
|
24
|
-
const cli = await createAttachedCliContext();
|
|
25
|
-
|
|
26
|
-
await ensureDaemon(cli);
|
|
27
|
-
|
|
28
|
-
const attached = await attachExistingLocalControlClient({
|
|
29
|
-
ariaHome,
|
|
30
|
-
clientKind: "tui",
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
if (!attached) {
|
|
34
|
-
throw new Error("[aria] Attached REPL requires an existing local-control runtime");
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
const memoriaPath = process.env.ARIA_MEMORY_PATH || `${cli.ariaDir}/arions/ARIA/memory.db`;
|
|
38
|
-
const memoria = new Memoria({ path: memoriaPath, router: cli.router });
|
|
39
|
-
memoria.initialize().catch((error) => {
|
|
40
|
-
console.debug(
|
|
41
|
-
`[aria] Memoria background init failed (will retry on use): ${error?.message ?? error}`,
|
|
42
|
-
);
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
const aria = {
|
|
46
|
-
components: { memoria },
|
|
47
|
-
recallUserName: () => recallUserName(memoria),
|
|
48
|
-
shutdown: async () => {
|
|
49
|
-
await memoria.close();
|
|
50
|
-
await cli.pool.closeAll();
|
|
51
|
-
},
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
const storage = new ArionStorage(cli.ariaDir);
|
|
55
|
-
const manager = new ArionManager(storage, cli.memoriaFactory);
|
|
56
|
-
await manager.initialize();
|
|
57
|
-
manager.setRouter(cli.router);
|
|
58
|
-
|
|
59
|
-
const activeArion = cli.config.activeArion?.trim() || "ARIA";
|
|
60
|
-
const historyPath = SessionHistory.resolvePerArionPath(cli.ariaDir, activeArion);
|
|
61
|
-
SessionHistory.migrateJsonlLogs(cli.ariaDir, activeArion);
|
|
62
|
-
const history = new SessionHistory(historyPath);
|
|
63
|
-
const inputHistory = history.getInputHistory(100);
|
|
64
|
-
const appendInputHistory = (value: string) => history.addInputHistory(value);
|
|
65
|
-
|
|
66
|
-
let resolvedSessionId: string | undefined;
|
|
67
|
-
if (invocation.resumeSessionId) {
|
|
68
|
-
const found = history.findSessionByPrefix(invocation.resumeSessionId);
|
|
69
|
-
if (!found) {
|
|
70
|
-
throw new Error(`Error: No session found matching \"${invocation.resumeSessionId}\"`);
|
|
71
|
-
}
|
|
72
|
-
resolvedSessionId = found;
|
|
73
|
-
} else if (invocation.continueLatest) {
|
|
74
|
-
const latest = history.listSessions(1);
|
|
75
|
-
if (latest.length === 0) {
|
|
76
|
-
throw new Error("Error: No recent sessions to continue");
|
|
77
|
-
}
|
|
78
|
-
resolvedSessionId = latest[0]?.id;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
const session = new ArionSession({
|
|
82
|
-
manager,
|
|
83
|
-
router: cli.router,
|
|
84
|
-
memoria,
|
|
85
|
-
onArionRest: async () => {},
|
|
86
|
-
});
|
|
87
|
-
await session.initialize(cli.config.activeArion);
|
|
88
|
-
|
|
89
|
-
const cachedUserName = await recallUserName(memoria);
|
|
90
|
-
const initialModelSnapshot = await attached.control.getModelSnapshot?.().catch(() => undefined);
|
|
91
|
-
|
|
92
|
-
await startInkRepl(
|
|
93
|
-
session,
|
|
94
|
-
manager,
|
|
95
|
-
cli.router,
|
|
96
|
-
aria,
|
|
97
|
-
attached,
|
|
98
|
-
cli,
|
|
99
|
-
inputHistory,
|
|
100
|
-
appendInputHistory,
|
|
101
|
-
history,
|
|
102
|
-
invocation.prompt,
|
|
103
|
-
cachedUserName,
|
|
104
|
-
resolvedSessionId,
|
|
105
|
-
(initialModelSnapshot?.models as
|
|
106
|
-
| readonly import("@aria-cli/models").ReadonlyModelDefinition[]
|
|
107
|
-
| undefined) ?? getCliModels(),
|
|
108
|
-
undefined,
|
|
109
|
-
cli.credentialHints,
|
|
110
|
-
cli.authResolver,
|
|
111
|
-
);
|
|
112
|
-
}
|
package/src/main.ts
DELETED
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
import "./runtime/configure-bun-sqlite.js";
|
|
2
|
-
import { installProcessCrashHandlers } from "./runtime/crash-handlers.js";
|
|
3
|
-
import { installOwnerLeaseIfNeeded } from "./runtime/owner-lease.js";
|
|
4
|
-
import { parseInternalInvocation } from "./runtime/internal-mode.js";
|
|
5
|
-
import { isPublicCommandInvocation } from "./runtime/public-mode.js";
|
|
6
|
-
import { parseInteractiveInvocation } from "./runtime/interactive-invocation.js";
|
|
7
|
-
import { isChildProcess, superviseInteractiveSession } from "./relaunch.js";
|
|
8
|
-
import { isCompiledRuntime } from "./runtime/runtime-kind.js";
|
|
9
|
-
|
|
10
|
-
export async function main(argv = process.argv): Promise<void> {
|
|
11
|
-
installProcessCrashHandlers();
|
|
12
|
-
installOwnerLeaseIfNeeded();
|
|
13
|
-
|
|
14
|
-
const userArgs = argv.slice(2);
|
|
15
|
-
|
|
16
|
-
const internal = parseInternalInvocation(userArgs);
|
|
17
|
-
if (internal) {
|
|
18
|
-
const { runInternalMode } = await import("./runtime/run-internal-mode.js");
|
|
19
|
-
await runInternalMode(internal);
|
|
20
|
-
return;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
if (isPublicCommandInvocation(userArgs)) {
|
|
24
|
-
const { runCommandMode } = await import("./entrypoints/command-mode.js");
|
|
25
|
-
await runCommandMode(argv);
|
|
26
|
-
return;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
const interactive = parseInteractiveInvocation(userArgs);
|
|
30
|
-
if (isChildProcess()) {
|
|
31
|
-
const { runInteractiveEntrypoint } = await import("./entrypoints/interactive.js");
|
|
32
|
-
await runInteractiveEntrypoint(interactive);
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
// Compiled binary: run REPL directly in this process instead of spawning
|
|
37
|
-
// a supervisor + child (which loads the 82MB binary twice). Saves ~3-13s
|
|
38
|
-
// on cold start. Relaunch (rare) spawns a new process in supervisor mode.
|
|
39
|
-
// ARIA_USE_SUPERVISOR is set by requestRelaunch() to force the supervisor
|
|
40
|
-
// path on respawned processes, preventing waiter process accumulation.
|
|
41
|
-
if (isCompiledRuntime() && !process.env.ARIA_USE_SUPERVISOR) {
|
|
42
|
-
await runCompiledDirect(interactive);
|
|
43
|
-
return;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
await superviseInteractiveSession(interactive);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
/**
|
|
50
|
-
* Compiled-binary direct mode: run the REPL in-process (single binary load).
|
|
51
|
-
*
|
|
52
|
-
* The normal supervisor pattern loads the 82MB binary twice (parent + child).
|
|
53
|
-
* In compiled mode, we skip the supervisor and run the REPL directly. If the
|
|
54
|
-
* user requests a relaunch (rare), requestRelaunch() spawns a new process
|
|
55
|
-
* with resume env vars — the current process waits and propagates exit code.
|
|
56
|
-
*/
|
|
57
|
-
async function runCompiledDirect(
|
|
58
|
-
interactive: import("./runtime/interactive-invocation.js").InteractiveInvocation,
|
|
59
|
-
): Promise<void> {
|
|
60
|
-
const { NO_RELAUNCH_ENV } = await import("@aria-cli/types");
|
|
61
|
-
process.env[NO_RELAUNCH_ENV] = "true";
|
|
62
|
-
const { runInteractiveEntrypoint } = await import("./entrypoints/interactive.js");
|
|
63
|
-
await runInteractiveEntrypoint(interactive);
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
if ((import.meta as ImportMeta & { main?: boolean }).main) {
|
|
67
|
-
main(process.argv).catch((error) => {
|
|
68
|
-
const message = error instanceof Error ? (error.stack ?? error.message) : String(error);
|
|
69
|
-
process.stderr.write(`${message}\n`);
|
|
70
|
-
process.exit(1);
|
|
71
|
-
});
|
|
72
|
-
}
|
|
@@ -1,128 +0,0 @@
|
|
|
1
|
-
import { createHash } from "node:crypto";
|
|
2
|
-
import { appendFileSync, mkdirSync, writeFileSync } from "node:fs";
|
|
3
|
-
import { homedir } from "node:os";
|
|
4
|
-
import { join } from "node:path";
|
|
5
|
-
import v8 from "node:v8";
|
|
6
|
-
import { RESUME_SESSION_ENV } from "@aria-cli/types";
|
|
7
|
-
|
|
8
|
-
function getAriaHome(): string {
|
|
9
|
-
return process.env.ARIA_HOME?.trim() || join(homedir(), ".aria");
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
function writeCrashReport(type: string, error: unknown): void {
|
|
13
|
-
try {
|
|
14
|
-
const crashDir = join(getAriaHome(), "crash-reports");
|
|
15
|
-
mkdirSync(crashDir, { recursive: true });
|
|
16
|
-
|
|
17
|
-
const err = error instanceof Error ? error : new Error(String(error));
|
|
18
|
-
const memory = process.memoryUsage();
|
|
19
|
-
const timestamp = new Date().toISOString();
|
|
20
|
-
const sessionId = process.env[RESUME_SESSION_ENV] || "unknown";
|
|
21
|
-
const payload = {
|
|
22
|
-
timestamp,
|
|
23
|
-
sessionId,
|
|
24
|
-
type,
|
|
25
|
-
error: {
|
|
26
|
-
message: err.message,
|
|
27
|
-
stack: err.stack,
|
|
28
|
-
name: err.name,
|
|
29
|
-
},
|
|
30
|
-
process: {
|
|
31
|
-
pid: process.pid,
|
|
32
|
-
heapUsedMb: Math.round((memory.heapUsed / 1024 / 1024) * 100) / 100,
|
|
33
|
-
rssMb: Math.round((memory.rss / 1024 / 1024) * 100) / 100,
|
|
34
|
-
uptime: Math.round(process.uptime()),
|
|
35
|
-
},
|
|
36
|
-
};
|
|
37
|
-
|
|
38
|
-
writeFileSync(join(crashDir, "latest.json"), JSON.stringify(payload, null, 2));
|
|
39
|
-
|
|
40
|
-
const stackFirst = err.stack?.split("\n")[1]?.trim() ?? "";
|
|
41
|
-
const bucket = Math.floor(Date.now() / 10000);
|
|
42
|
-
const fingerprint = createHash("sha256")
|
|
43
|
-
.update(`${err.message}|${stackFirst}|${bucket}`)
|
|
44
|
-
.digest("hex")
|
|
45
|
-
.slice(0, 12);
|
|
46
|
-
|
|
47
|
-
appendFileSync(
|
|
48
|
-
join(getAriaHome(), "error-events.jsonl"),
|
|
49
|
-
`${JSON.stringify({
|
|
50
|
-
id: `crash-${fingerprint}`,
|
|
51
|
-
timestamp,
|
|
52
|
-
severity: 0,
|
|
53
|
-
category: "crash",
|
|
54
|
-
domain: "cli",
|
|
55
|
-
name: err.name,
|
|
56
|
-
message: err.message,
|
|
57
|
-
stackTrace: err.stack,
|
|
58
|
-
recoverable: false,
|
|
59
|
-
status: "new",
|
|
60
|
-
})}\n`,
|
|
61
|
-
"utf-8",
|
|
62
|
-
);
|
|
63
|
-
} catch {
|
|
64
|
-
// Best effort only.
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
let installed = false;
|
|
69
|
-
|
|
70
|
-
/**
|
|
71
|
-
* Install V8 heap diagnostics for OOM investigation.
|
|
72
|
-
*
|
|
73
|
-
* - `setHeapSnapshotNearHeapLimit(3)`: Auto-captures up to 3 progressive heap
|
|
74
|
-
* snapshots as the heap approaches the V8 limit. Snapshots land in the
|
|
75
|
-
* diagnostic directory and survive the crash — load in Chrome DevTools
|
|
76
|
-
* Memory tab for retainer trace analysis.
|
|
77
|
-
*
|
|
78
|
-
* - `process.report.reportOnFatalError`: Generates a diagnostic JSON report
|
|
79
|
-
* on fatal errors (including OOM) with native stack, heap space breakdown,
|
|
80
|
-
* libuv handles, and resource usage.
|
|
81
|
-
*
|
|
82
|
-
* Both are lightweight and production-safe — zero overhead until triggered.
|
|
83
|
-
*/
|
|
84
|
-
function installHeapDiagnostics(): void {
|
|
85
|
-
const crashDir = join(getAriaHome(), "crash-reports");
|
|
86
|
-
mkdirSync(crashDir, { recursive: true });
|
|
87
|
-
|
|
88
|
-
// Auto-capture heap snapshots as V8 approaches the heap limit.
|
|
89
|
-
// Writes .heapsnapshot files to crashDir before OOM kills the process.
|
|
90
|
-
try {
|
|
91
|
-
v8.setHeapSnapshotNearHeapLimit(3);
|
|
92
|
-
} catch {
|
|
93
|
-
// Bun or older Node without this API — non-fatal.
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
// Generate a diagnostic report JSON on fatal errors (OOM, segfault).
|
|
97
|
-
try {
|
|
98
|
-
process.report.reportOnFatalError = true;
|
|
99
|
-
process.report.directory = crashDir;
|
|
100
|
-
} catch {
|
|
101
|
-
// Non-fatal if report API is unavailable.
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
export function installProcessCrashHandlers(): void {
|
|
106
|
-
if (installed) return;
|
|
107
|
-
installed = true;
|
|
108
|
-
|
|
109
|
-
installHeapDiagnostics();
|
|
110
|
-
|
|
111
|
-
process.on("uncaughtException", (error, origin) => {
|
|
112
|
-
writeCrashReport("uncaughtException", error);
|
|
113
|
-
process.stderr.write(`[aria] FATAL uncaughtException (origin: ${origin}):\n`);
|
|
114
|
-
process.stderr.write(
|
|
115
|
-
`${error instanceof Error ? (error.stack ?? error.message) : String(error)}\n`,
|
|
116
|
-
);
|
|
117
|
-
process.exit(1);
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
process.on("unhandledRejection", (error) => {
|
|
121
|
-
writeCrashReport("unhandledRejection", error);
|
|
122
|
-
process.stderr.write("[aria] FATAL unhandledRejection:\n");
|
|
123
|
-
process.stderr.write(
|
|
124
|
-
`${error instanceof Error ? (error.stack ?? error.message) : String(error)}\n`,
|
|
125
|
-
);
|
|
126
|
-
process.exit(1);
|
|
127
|
-
});
|
|
128
|
-
}
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import { afterEach, describe, expect, it } from "vitest";
|
|
2
|
-
import { parseInteractiveInvocation } from "./interactive-invocation.js";
|
|
3
|
-
|
|
4
|
-
describe("parseInteractiveInvocation", () => {
|
|
5
|
-
const originalResume = process.env.ARIA_RESUME_SESSION_ID;
|
|
6
|
-
const originalRestartKind = process.env.ARIA_RESTART_KIND;
|
|
7
|
-
|
|
8
|
-
afterEach(() => {
|
|
9
|
-
if (originalResume === undefined) delete process.env.ARIA_RESUME_SESSION_ID;
|
|
10
|
-
else process.env.ARIA_RESUME_SESSION_ID = originalResume;
|
|
11
|
-
|
|
12
|
-
if (originalRestartKind === undefined) delete process.env.ARIA_RESTART_KIND;
|
|
13
|
-
else process.env.ARIA_RESTART_KIND = originalRestartKind;
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
it("parses a prompt", () => {
|
|
17
|
-
expect(parseInteractiveInvocation(["hello", "world"]).prompt).toBe("hello world");
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
it("parses resume flag", () => {
|
|
21
|
-
expect(parseInteractiveInvocation(["--resume", "sess-1"]).resumeSessionId).toBe("sess-1");
|
|
22
|
-
});
|
|
23
|
-
|
|
24
|
-
it("parses continue flag", () => {
|
|
25
|
-
expect(parseInteractiveInvocation(["--continue"]).continueLatest).toBe(true);
|
|
26
|
-
});
|
|
27
|
-
|
|
28
|
-
it("consumes resume env when explicit args are absent", () => {
|
|
29
|
-
process.env.ARIA_RESUME_SESSION_ID = "sess-env";
|
|
30
|
-
process.env.ARIA_RESTART_KIND = "explicit";
|
|
31
|
-
const parsed = parseInteractiveInvocation([]);
|
|
32
|
-
expect(parsed.resumeSessionId).toBe("sess-env");
|
|
33
|
-
expect(process.env.ARIA_RESUME_SESSION_ID).toBeUndefined();
|
|
34
|
-
expect(process.env.ARIA_RESTART_KIND).toBeUndefined();
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
it("rejects resume + continue together", () => {
|
|
38
|
-
expect(() => parseInteractiveInvocation(["--resume", "sess-1", "--continue"])).toThrow(
|
|
39
|
-
/mutually exclusive/i,
|
|
40
|
-
);
|
|
41
|
-
});
|
|
42
|
-
});
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import { RESUME_SESSION_ENV, RESTART_KIND_ENV } from "@aria-cli/types";
|
|
2
|
-
|
|
3
|
-
export interface InteractiveInvocation {
|
|
4
|
-
prompt?: string;
|
|
5
|
-
resumeSessionId?: string | null;
|
|
6
|
-
continueLatest?: boolean;
|
|
7
|
-
rawArgs: string[];
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
export function parseInteractiveInvocation(argv: string[]): InteractiveInvocation {
|
|
11
|
-
let resumeSessionId: string | null = null;
|
|
12
|
-
let continueLatest = false;
|
|
13
|
-
const promptParts: string[] = [];
|
|
14
|
-
|
|
15
|
-
for (let i = 0; i < argv.length; i += 1) {
|
|
16
|
-
const arg = argv[i];
|
|
17
|
-
if (arg === undefined) continue;
|
|
18
|
-
|
|
19
|
-
if (arg === "-r" || arg === "--resume") {
|
|
20
|
-
const next = argv[i + 1];
|
|
21
|
-
if (!next) throw new Error("Error: -r/--resume requires a session ID");
|
|
22
|
-
resumeSessionId = next;
|
|
23
|
-
i += 1;
|
|
24
|
-
continue;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
if (arg === "-c" || arg === "--continue") {
|
|
28
|
-
continueLatest = true;
|
|
29
|
-
continue;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
promptParts.push(arg);
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
if (resumeSessionId && continueLatest) {
|
|
36
|
-
throw new Error("Error: -r/--resume and -c/--continue are mutually exclusive");
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
if (!resumeSessionId && !continueLatest && process.env[RESUME_SESSION_ENV]) {
|
|
40
|
-
resumeSessionId = process.env[RESUME_SESSION_ENV] ?? null;
|
|
41
|
-
delete process.env[RESUME_SESSION_ENV];
|
|
42
|
-
delete process.env[RESTART_KIND_ENV];
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
return {
|
|
46
|
-
prompt: promptParts.length > 0 ? promptParts.join(" ") : undefined,
|
|
47
|
-
resumeSessionId,
|
|
48
|
-
continueLatest,
|
|
49
|
-
rawArgs: [...argv],
|
|
50
|
-
};
|
|
51
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from "vitest";
|
|
2
|
-
import { parseInternalInvocation } from "./internal-mode.js";
|
|
3
|
-
|
|
4
|
-
describe("parseInternalInvocation", () => {
|
|
5
|
-
it("returns null for public args", () => {
|
|
6
|
-
expect(parseInternalInvocation(["auth"])).toBeNull();
|
|
7
|
-
});
|
|
8
|
-
|
|
9
|
-
it("parses valid internal mode", () => {
|
|
10
|
-
expect(parseInternalInvocation(["__internal", "daemon", "--port", "0"])).toEqual({
|
|
11
|
-
mode: "daemon",
|
|
12
|
-
args: ["--port", "0"],
|
|
13
|
-
});
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
it("throws on unknown internal mode", () => {
|
|
17
|
-
expect(() => parseInternalInvocation(["__internal", "wat"])).toThrow(/Unknown internal mode/i);
|
|
18
|
-
});
|
|
19
|
-
});
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
export type InternalMode = "repl" | "daemon" | "headless-stdio";
|
|
2
|
-
|
|
3
|
-
export interface InternalInvocation {
|
|
4
|
-
mode: InternalMode;
|
|
5
|
-
args: string[];
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
export const INTERNAL_SENTINEL = "__internal";
|
|
9
|
-
|
|
10
|
-
export function parseInternalInvocation(argv: string[]): InternalInvocation | null {
|
|
11
|
-
if (argv[0] !== INTERNAL_SENTINEL) return null;
|
|
12
|
-
|
|
13
|
-
const mode = argv[1];
|
|
14
|
-
if (mode !== "repl" && mode !== "daemon" && mode !== "headless-stdio") {
|
|
15
|
-
throw new Error(
|
|
16
|
-
`[aria] Unknown internal mode \"${String(mode)}\". Expected repl | daemon | headless-stdio.`,
|
|
17
|
-
);
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
return {
|
|
21
|
-
mode,
|
|
22
|
-
args: argv.slice(2),
|
|
23
|
-
};
|
|
24
|
-
}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { afterEach, describe, expect, it } from "vitest";
|
|
2
|
-
import { resolveAriaLaunchSpec } from "./launch-spec.js";
|
|
3
|
-
|
|
4
|
-
describe("resolveAriaLaunchSpec", () => {
|
|
5
|
-
const originalOverride = process.env.ARIA_RUNTIME_KIND;
|
|
6
|
-
|
|
7
|
-
afterEach(() => {
|
|
8
|
-
if (originalOverride === undefined) delete process.env.ARIA_RUNTIME_KIND;
|
|
9
|
-
else process.env.ARIA_RUNTIME_KIND = originalOverride;
|
|
10
|
-
});
|
|
11
|
-
|
|
12
|
-
it("resolves source-bun launch spec", () => {
|
|
13
|
-
process.env.ARIA_RUNTIME_KIND = "source-bun";
|
|
14
|
-
const spec = resolveAriaLaunchSpec({ mode: "daemon", args: ["--port", "0"] });
|
|
15
|
-
expect(spec.command === "bun" || spec.command === "bun.exe").toBe(true);
|
|
16
|
-
expect(spec.args).toContain("__internal");
|
|
17
|
-
expect(spec.args).toContain("daemon");
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
it("resolves compiled-bun launch spec", () => {
|
|
21
|
-
process.env.ARIA_RUNTIME_KIND = "compiled-bun";
|
|
22
|
-
const spec = resolveAriaLaunchSpec({ mode: "repl", args: ["--continue"] });
|
|
23
|
-
expect(spec.command).toBe(process.execPath);
|
|
24
|
-
expect(spec.args.slice(0, 2)).toEqual(["__internal", "repl"]);
|
|
25
|
-
});
|
|
26
|
-
});
|
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
import { existsSync } from "node:fs";
|
|
2
|
-
import { fileURLToPath } from "node:url";
|
|
3
|
-
import { getRuntimeKind } from "./runtime-kind.js";
|
|
4
|
-
|
|
5
|
-
export type AriaLaunchMode = "repl" | "daemon" | "headless-stdio";
|
|
6
|
-
|
|
7
|
-
export interface AriaLaunchSpecInput {
|
|
8
|
-
mode: AriaLaunchMode;
|
|
9
|
-
args?: string[];
|
|
10
|
-
env?: NodeJS.ProcessEnv;
|
|
11
|
-
cwd?: string;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
export interface LaunchSpec {
|
|
15
|
-
command: string;
|
|
16
|
-
args: string[];
|
|
17
|
-
env: NodeJS.ProcessEnv;
|
|
18
|
-
cwd: string;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
function getBunCommand(): string {
|
|
22
|
-
return process.platform === "win32" ? "bun.exe" : "bun";
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
function resolveSourceEntrypoint(): string {
|
|
26
|
-
const candidates = [
|
|
27
|
-
fileURLToPath(new URL("../main.ts", import.meta.url)),
|
|
28
|
-
fileURLToPath(new URL("../main.js", import.meta.url)),
|
|
29
|
-
];
|
|
30
|
-
|
|
31
|
-
for (const candidate of candidates) {
|
|
32
|
-
if (existsSync(candidate)) {
|
|
33
|
-
return candidate;
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
throw new Error("[aria] Could not resolve Bun source entrypoint for internal relaunch");
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
function resolveBundledEntrypoint(): string {
|
|
41
|
-
// In npm-installed bundle, argv[1] is the aria.mjs file itself
|
|
42
|
-
const argv1 = process.argv[1] ?? "";
|
|
43
|
-
if (existsSync(argv1)) return argv1;
|
|
44
|
-
// Fallback: look relative to import.meta.url
|
|
45
|
-
const candidates = [
|
|
46
|
-
fileURLToPath(new URL("../../bin/aria.mjs", import.meta.url)),
|
|
47
|
-
fileURLToPath(new URL("../bin/aria.mjs", import.meta.url)),
|
|
48
|
-
];
|
|
49
|
-
for (const c of candidates) {
|
|
50
|
-
if (existsSync(c)) return c;
|
|
51
|
-
}
|
|
52
|
-
throw new Error("[aria] Could not resolve bundled entrypoint for internal relaunch");
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
export function resolveAriaLaunchSpec(input: AriaLaunchSpecInput): LaunchSpec {
|
|
56
|
-
const runtimeKind = getRuntimeKind();
|
|
57
|
-
const forwardedArgs = input.args ?? [];
|
|
58
|
-
const env = { ...process.env, ...(input.env ?? {}) };
|
|
59
|
-
const cwd = input.cwd ?? process.cwd();
|
|
60
|
-
|
|
61
|
-
switch (runtimeKind) {
|
|
62
|
-
case "source-bun":
|
|
63
|
-
return {
|
|
64
|
-
command: getBunCommand(),
|
|
65
|
-
args: [resolveSourceEntrypoint(), "__internal", input.mode, ...forwardedArgs],
|
|
66
|
-
env,
|
|
67
|
-
cwd,
|
|
68
|
-
};
|
|
69
|
-
case "bundled-bun":
|
|
70
|
-
return {
|
|
71
|
-
command: getBunCommand(),
|
|
72
|
-
args: [resolveBundledEntrypoint(), "__internal", input.mode, ...forwardedArgs],
|
|
73
|
-
env,
|
|
74
|
-
cwd,
|
|
75
|
-
};
|
|
76
|
-
case "compiled-bun":
|
|
77
|
-
return {
|
|
78
|
-
command: process.execPath,
|
|
79
|
-
args: ["__internal", input.mode, ...forwardedArgs],
|
|
80
|
-
env,
|
|
81
|
-
cwd,
|
|
82
|
-
};
|
|
83
|
-
}
|
|
84
|
-
}
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
export function installOwnerLeaseIfNeeded(
|
|
2
|
-
options: {
|
|
3
|
-
env?: NodeJS.ProcessEnv;
|
|
4
|
-
processRef?: Pick<NodeJS.Process, "env" | "kill" | "pid" | "once">;
|
|
5
|
-
pollMs?: number;
|
|
6
|
-
onOwnerGone?: (ownerPid: number) => void;
|
|
7
|
-
} = {},
|
|
8
|
-
): () => void {
|
|
9
|
-
const env = options.env ?? process.env;
|
|
10
|
-
const processRef = options.processRef ?? process;
|
|
11
|
-
const pollMs = options.pollMs ?? 1000;
|
|
12
|
-
|
|
13
|
-
const ownerPidRaw = env.ARIA_HARNESS_OWNER_PID;
|
|
14
|
-
if (!ownerPidRaw) return () => {};
|
|
15
|
-
|
|
16
|
-
const ownerPid = Number.parseInt(ownerPidRaw, 10);
|
|
17
|
-
if (!Number.isFinite(ownerPid) || ownerPid <= 0) {
|
|
18
|
-
throw new Error(`ARIA_HARNESS_OWNER_PID must be a positive integer, got: ${ownerPidRaw}`);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
let released = false;
|
|
22
|
-
const interval = setInterval(() => {
|
|
23
|
-
if (released) return;
|
|
24
|
-
try {
|
|
25
|
-
processRef.kill(ownerPid, 0);
|
|
26
|
-
} catch (error) {
|
|
27
|
-
const code =
|
|
28
|
-
error && typeof error === "object" && "code" in error
|
|
29
|
-
? (error as { code?: string }).code
|
|
30
|
-
: undefined;
|
|
31
|
-
if (code && code !== "ESRCH") return;
|
|
32
|
-
released = true;
|
|
33
|
-
clearInterval(interval);
|
|
34
|
-
if (options.onOwnerGone) {
|
|
35
|
-
options.onOwnerGone(ownerPid);
|
|
36
|
-
return;
|
|
37
|
-
}
|
|
38
|
-
processRef.kill(processRef.pid, "SIGTERM");
|
|
39
|
-
}
|
|
40
|
-
}, pollMs);
|
|
41
|
-
|
|
42
|
-
interval.unref?.();
|
|
43
|
-
|
|
44
|
-
const dispose = () => {
|
|
45
|
-
if (released) return;
|
|
46
|
-
released = true;
|
|
47
|
-
clearInterval(interval);
|
|
48
|
-
};
|
|
49
|
-
|
|
50
|
-
processRef.once("exit", dispose);
|
|
51
|
-
return dispose;
|
|
52
|
-
}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from "vitest";
|
|
2
|
-
import { isPublicCommandInvocation } from "./public-mode.js";
|
|
3
|
-
|
|
4
|
-
describe("isPublicCommandInvocation", () => {
|
|
5
|
-
it("detects explicit commands", () => {
|
|
6
|
-
expect(isPublicCommandInvocation(["auth"])).toBe(true);
|
|
7
|
-
expect(isPublicCommandInvocation(["daemon"])).toBe(true);
|
|
8
|
-
});
|
|
9
|
-
|
|
10
|
-
it("detects top-level flags", () => {
|
|
11
|
-
expect(isPublicCommandInvocation(["--version"])).toBe(true);
|
|
12
|
-
expect(isPublicCommandInvocation(["--help"])).toBe(true);
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
it("does not treat prompt text as public command", () => {
|
|
16
|
-
expect(isPublicCommandInvocation(["hello", "world"])).toBe(false);
|
|
17
|
-
});
|
|
18
|
-
});
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
const PUBLIC_TOP_LEVELS = new Set([
|
|
2
|
-
"daemon",
|
|
3
|
-
"auth",
|
|
4
|
-
"arions",
|
|
5
|
-
"headless",
|
|
6
|
-
"call",
|
|
7
|
-
"pairing",
|
|
8
|
-
"runtime-cutover-reset",
|
|
9
|
-
"--help",
|
|
10
|
-
"-h",
|
|
11
|
-
"--version",
|
|
12
|
-
"-v",
|
|
13
|
-
]);
|
|
14
|
-
|
|
15
|
-
export function isPublicCommandInvocation(argv: string[]): boolean {
|
|
16
|
-
const first = argv[0];
|
|
17
|
-
if (!first) return false;
|
|
18
|
-
return PUBLIC_TOP_LEVELS.has(first) || first.startsWith("--");
|
|
19
|
-
}
|