agent-relay 6.0.16 → 6.0.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (63) hide show
  1. package/dist/index.cjs +111 -32
  2. package/dist/packages/cloud/src/api-client.d.ts +33 -0
  3. package/dist/packages/cloud/src/api-client.d.ts.map +1 -0
  4. package/dist/packages/cloud/src/api-client.js +123 -0
  5. package/dist/packages/cloud/src/api-client.js.map +1 -0
  6. package/dist/packages/cloud/src/auth.d.ts +13 -0
  7. package/dist/packages/cloud/src/auth.d.ts.map +1 -0
  8. package/dist/packages/cloud/src/auth.js +299 -0
  9. package/dist/packages/cloud/src/auth.js.map +1 -0
  10. package/dist/packages/cloud/src/connect.d.ts +45 -0
  11. package/dist/packages/cloud/src/connect.d.ts.map +1 -0
  12. package/dist/packages/cloud/src/connect.js +166 -0
  13. package/dist/packages/cloud/src/connect.js.map +1 -0
  14. package/dist/packages/cloud/src/index.d.ts +10 -0
  15. package/dist/packages/cloud/src/index.d.ts.map +1 -0
  16. package/dist/packages/cloud/src/index.js +10 -0
  17. package/dist/packages/cloud/src/index.js.map +1 -0
  18. package/dist/packages/cloud/src/lib/ssh-interactive.d.ts +70 -0
  19. package/dist/packages/cloud/src/lib/ssh-interactive.d.ts.map +1 -0
  20. package/dist/packages/cloud/src/lib/ssh-interactive.js +440 -0
  21. package/dist/packages/cloud/src/lib/ssh-interactive.js.map +1 -0
  22. package/dist/packages/cloud/src/lib/ssh-runtime.d.ts +35 -0
  23. package/dist/packages/cloud/src/lib/ssh-runtime.d.ts.map +1 -0
  24. package/dist/packages/cloud/src/lib/ssh-runtime.js +52 -0
  25. package/dist/packages/cloud/src/lib/ssh-runtime.js.map +1 -0
  26. package/dist/packages/cloud/src/proactive-runtime.d.ts +24 -0
  27. package/dist/packages/cloud/src/proactive-runtime.d.ts.map +1 -0
  28. package/dist/packages/cloud/src/proactive-runtime.js +315 -0
  29. package/dist/packages/cloud/src/proactive-runtime.js.map +1 -0
  30. package/dist/packages/cloud/src/types.d.ts +200 -0
  31. package/dist/packages/cloud/src/types.d.ts.map +1 -0
  32. package/dist/packages/cloud/src/types.js +12 -0
  33. package/dist/packages/cloud/src/types.js.map +1 -0
  34. package/dist/packages/cloud/src/workflows.d.ts +65 -0
  35. package/dist/packages/cloud/src/workflows.d.ts.map +1 -0
  36. package/dist/packages/cloud/src/workflows.js +892 -0
  37. package/dist/packages/cloud/src/workflows.js.map +1 -0
  38. package/dist/packages/cloud/src/workspaces.d.ts +11 -0
  39. package/dist/packages/cloud/src/workspaces.d.ts.map +1 -0
  40. package/dist/packages/cloud/src/workspaces.js +146 -0
  41. package/dist/packages/cloud/src/workspaces.js.map +1 -0
  42. package/dist/src/cli/bootstrap.d.ts +3 -1
  43. package/dist/src/cli/bootstrap.d.ts.map +1 -1
  44. package/dist/src/cli/bootstrap.js +17 -3
  45. package/dist/src/cli/bootstrap.js.map +1 -1
  46. package/dist/src/cli/commands/cloud.js +1 -1
  47. package/dist/src/cli/commands/cloud.js.map +1 -1
  48. package/dist/src/cli/commands/dlq.d.ts +20 -0
  49. package/dist/src/cli/commands/dlq.d.ts.map +1 -0
  50. package/dist/src/cli/commands/dlq.js +456 -0
  51. package/dist/src/cli/commands/dlq.js.map +1 -0
  52. package/dist/src/cli/commands/proactive-bootstrap.d.ts +10 -0
  53. package/dist/src/cli/commands/proactive-bootstrap.d.ts.map +1 -0
  54. package/dist/src/cli/commands/proactive-bootstrap.js +133 -0
  55. package/dist/src/cli/commands/proactive-bootstrap.js.map +1 -0
  56. package/dist/src/cli/commands/relay-runtime.d.ts +58 -0
  57. package/dist/src/cli/commands/relay-runtime.d.ts.map +1 -0
  58. package/dist/src/cli/commands/relay-runtime.js +484 -0
  59. package/dist/src/cli/commands/relay-runtime.js.map +1 -0
  60. package/dist/src/cli/commands/setup.d.ts.map +1 -1
  61. package/dist/src/cli/commands/setup.js +11 -9
  62. package/dist/src/cli/commands/setup.js.map +1 -1
  63. package/package.json +11 -10
@@ -0,0 +1,299 @@
1
+ import fs from 'node:fs/promises';
2
+ import http from 'node:http';
3
+ import os from 'node:os';
4
+ import path from 'node:path';
5
+ import { spawn } from 'node:child_process';
6
+ import { buildApiUrl } from './api-client.js';
7
+ import { AUTH_FILE_PATH, REFRESH_WINDOW_MS } from './types.js';
8
+ const envBackedAuth = new WeakSet();
9
+ function markEnvBackedAuth(auth) {
10
+ envBackedAuth.add(auth);
11
+ return auth;
12
+ }
13
+ function isEnvBackedAuth(auth) {
14
+ return envBackedAuth.has(auth);
15
+ }
16
+ function readEnvAuth(env = process.env) {
17
+ const apiUrl = env.CLOUD_API_URL?.trim();
18
+ const accessToken = env.CLOUD_API_ACCESS_TOKEN?.trim();
19
+ const refreshToken = env.CLOUD_API_REFRESH_TOKEN?.trim();
20
+ const accessTokenExpiresAt = env.CLOUD_API_ACCESS_TOKEN_EXPIRES_AT?.trim();
21
+ if (!apiUrl || !accessToken || !refreshToken || !accessTokenExpiresAt) {
22
+ return null;
23
+ }
24
+ try {
25
+ new URL(apiUrl);
26
+ }
27
+ catch {
28
+ return null;
29
+ }
30
+ if (Number.isNaN(Date.parse(accessTokenExpiresAt))) {
31
+ return null;
32
+ }
33
+ return markEnvBackedAuth({
34
+ apiUrl,
35
+ accessToken,
36
+ refreshToken,
37
+ accessTokenExpiresAt,
38
+ });
39
+ }
40
+ function toEnvAuthRefreshError(error) {
41
+ const message = error instanceof Error && error.message ? `${error.message}. ` : '';
42
+ return new Error(`${message}Env-backed cloud auth could not be refreshed interactively; re-provision CLOUD_API_URL, CLOUD_API_ACCESS_TOKEN, CLOUD_API_REFRESH_TOKEN, and CLOUD_API_ACCESS_TOKEN_EXPIRES_AT.`, error instanceof Error ? { cause: error } : undefined);
43
+ }
44
+ function isValidStoredAuth(value) {
45
+ if (!value || typeof value !== 'object') {
46
+ return false;
47
+ }
48
+ const auth = value;
49
+ return (typeof auth.accessToken === 'string' &&
50
+ typeof auth.refreshToken === 'string' &&
51
+ typeof auth.accessTokenExpiresAt === 'string' &&
52
+ typeof auth.apiUrl === 'string');
53
+ }
54
+ export async function readStoredAuth(env = process.env) {
55
+ const envAuth = readEnvAuth(env);
56
+ if (envAuth) {
57
+ return envAuth;
58
+ }
59
+ try {
60
+ const file = await fs.readFile(AUTH_FILE_PATH, 'utf8');
61
+ const parsed = JSON.parse(file);
62
+ return isValidStoredAuth(parsed) ? parsed : null;
63
+ }
64
+ catch {
65
+ return null;
66
+ }
67
+ }
68
+ export async function writeStoredAuth(auth) {
69
+ await fs.mkdir(path.dirname(AUTH_FILE_PATH), {
70
+ recursive: true,
71
+ mode: 0o700,
72
+ });
73
+ await fs.writeFile(AUTH_FILE_PATH, `${JSON.stringify(auth, null, 2)}\n`, {
74
+ encoding: 'utf8',
75
+ mode: 0o600,
76
+ });
77
+ }
78
+ export async function clearStoredAuth() {
79
+ await fs.rm(AUTH_FILE_PATH, { force: true });
80
+ }
81
+ function shouldRefresh(accessTokenExpiresAt) {
82
+ const expiresAt = Date.parse(accessTokenExpiresAt);
83
+ if (Number.isNaN(expiresAt)) {
84
+ return true;
85
+ }
86
+ return expiresAt - Date.now() <= REFRESH_WINDOW_MS;
87
+ }
88
+ function openBrowser(url) {
89
+ const platform = os.platform();
90
+ if (platform === 'darwin') {
91
+ return spawn('open', [url], { stdio: 'ignore', detached: true });
92
+ }
93
+ if (platform === 'win32') {
94
+ return spawn('cmd', ['/c', 'start', '', url], { stdio: 'ignore', detached: true });
95
+ }
96
+ return spawn('xdg-open', [url], { stdio: 'ignore', detached: true });
97
+ }
98
+ function redirectToHostedCliAuthPage(response, apiUrl, options) {
99
+ const resultUrl = buildApiUrl(apiUrl, '/cli/auth-result');
100
+ resultUrl.searchParams.set('status', options.status);
101
+ if (options.detail) {
102
+ resultUrl.searchParams.set('detail', options.detail);
103
+ }
104
+ response.statusCode = 302;
105
+ response.setHeader('location', resultUrl.toString());
106
+ response.end();
107
+ }
108
+ async function beginBrowserLogin(apiUrl) {
109
+ const state = crypto.randomUUID();
110
+ return new Promise((resolve, reject) => {
111
+ let settled = false;
112
+ const server = http.createServer((request, response) => {
113
+ const requestUrl = new URL(request.url || '/', 'http://127.0.0.1');
114
+ if (requestUrl.pathname !== '/callback') {
115
+ response.statusCode = 404;
116
+ response.end('Not found');
117
+ return;
118
+ }
119
+ const returnedState = requestUrl.searchParams.get('state');
120
+ // Validate state parameter first (CSRF protection) — this check
121
+ // must run unconditionally, before any user-controlled values.
122
+ if (returnedState !== state) {
123
+ redirectToHostedCliAuthPage(response, apiUrl, {
124
+ status: 'error',
125
+ detail: 'Invalid state parameter',
126
+ });
127
+ if (!settled) {
128
+ settled = true;
129
+ server.close();
130
+ reject(new Error('Invalid state parameter in CLI login callback'));
131
+ }
132
+ return;
133
+ }
134
+ const error = requestUrl.searchParams.get('error');
135
+ if (error) {
136
+ redirectToHostedCliAuthPage(response, apiUrl, {
137
+ status: 'error',
138
+ detail: error,
139
+ });
140
+ if (!settled) {
141
+ settled = true;
142
+ server.close();
143
+ reject(new Error(error));
144
+ }
145
+ return;
146
+ }
147
+ const accessToken = requestUrl.searchParams.get('access_token');
148
+ const refreshToken = requestUrl.searchParams.get('refresh_token');
149
+ const accessTokenExpiresAt = requestUrl.searchParams.get('access_token_expires_at');
150
+ const returnedApiUrl = requestUrl.searchParams.get('api_url');
151
+ if (!accessToken || !refreshToken || !accessTokenExpiresAt || !returnedApiUrl) {
152
+ redirectToHostedCliAuthPage(response, apiUrl, {
153
+ status: 'error',
154
+ detail: 'Expected access token, refresh token, API URL, and expiration timestamp.',
155
+ });
156
+ if (!settled) {
157
+ settled = true;
158
+ server.close();
159
+ reject(new Error('CLI login callback was missing required fields'));
160
+ }
161
+ return;
162
+ }
163
+ redirectToHostedCliAuthPage(response, returnedApiUrl, {
164
+ status: 'success',
165
+ detail: `API endpoint: ${returnedApiUrl}`,
166
+ });
167
+ if (!settled) {
168
+ settled = true;
169
+ server.close();
170
+ resolve({
171
+ accessToken,
172
+ refreshToken,
173
+ accessTokenExpiresAt,
174
+ apiUrl: returnedApiUrl,
175
+ });
176
+ }
177
+ });
178
+ server.listen(0, '127.0.0.1', () => {
179
+ const address = server.address();
180
+ if (!address || typeof address === 'string') {
181
+ if (!settled) {
182
+ settled = true;
183
+ server.close();
184
+ reject(new Error('Failed to start local callback server'));
185
+ }
186
+ return;
187
+ }
188
+ const callbackUrl = new URL('/callback', `http://127.0.0.1:${address.port}`);
189
+ const loginUrl = buildApiUrl(apiUrl, '/api/v1/cli/login');
190
+ loginUrl.searchParams.set('redirect_uri', callbackUrl.toString());
191
+ loginUrl.searchParams.set('state', state);
192
+ console.log(`Opening browser for cloud login: ${loginUrl.toString()}`);
193
+ console.log('If the browser does not open, paste this URL into your browser.');
194
+ try {
195
+ const child = openBrowser(loginUrl.toString());
196
+ child.unref();
197
+ }
198
+ catch {
199
+ // Browser open failure is non-fatal; user still has the URL.
200
+ }
201
+ });
202
+ server.on('error', (error) => {
203
+ if (!settled) {
204
+ settled = true;
205
+ reject(error);
206
+ }
207
+ });
208
+ setTimeout(() => {
209
+ if (!settled) {
210
+ settled = true;
211
+ server.close();
212
+ reject(new Error('Timed out waiting for browser login'));
213
+ }
214
+ }, 5 * 60_000).unref();
215
+ });
216
+ }
217
+ export async function refreshStoredAuth(auth) {
218
+ const response = await fetch(buildApiUrl(auth.apiUrl, '/api/v1/auth/token/refresh'), {
219
+ method: 'POST',
220
+ headers: {
221
+ 'content-type': 'application/json',
222
+ },
223
+ body: JSON.stringify({ refreshToken: auth.refreshToken }),
224
+ });
225
+ const payload = (await response.json().catch(() => null));
226
+ if (!response.ok || !payload?.accessToken || !payload?.refreshToken || !payload?.accessTokenExpiresAt) {
227
+ throw new Error('Stored cloud login has expired');
228
+ }
229
+ const nextAuth = {
230
+ apiUrl: auth.apiUrl,
231
+ accessToken: payload.accessToken,
232
+ refreshToken: payload.refreshToken,
233
+ accessTokenExpiresAt: payload.accessTokenExpiresAt,
234
+ };
235
+ if (isEnvBackedAuth(auth)) {
236
+ return markEnvBackedAuth(nextAuth);
237
+ }
238
+ await writeStoredAuth(nextAuth);
239
+ return nextAuth;
240
+ }
241
+ async function loginWithBrowser(apiUrl) {
242
+ const auth = await beginBrowserLogin(apiUrl);
243
+ await writeStoredAuth(auth);
244
+ console.log(`Logged in to ${auth.apiUrl}`);
245
+ return auth;
246
+ }
247
+ export async function ensureAuthenticated(apiUrl, options) {
248
+ const force = options?.force === true;
249
+ const stored = !force ? await readStoredAuth() : null;
250
+ // Stored auth is authoritative on its own host. A host mismatch between
251
+ // `apiUrl` (typically defaultApiUrl()) and `stored.apiUrl` is NOT a reason
252
+ // to force a fresh browser login — the user already linked, and the default
253
+ // may have drifted (e.g. CLOUD_API_URL env set/unset between sessions).
254
+ // Only `--force` re-links to a different host.
255
+ if (!stored) {
256
+ return loginWithBrowser(apiUrl);
257
+ }
258
+ if (!shouldRefresh(stored.accessTokenExpiresAt)) {
259
+ return stored;
260
+ }
261
+ try {
262
+ return await refreshStoredAuth(stored);
263
+ }
264
+ catch (error) {
265
+ if (isEnvBackedAuth(stored)) {
266
+ throw toEnvAuthRefreshError(error);
267
+ }
268
+ return loginWithBrowser(stored.apiUrl);
269
+ }
270
+ }
271
+ function apiFetch(apiUrl, accessToken, requestPath, init) {
272
+ return fetch(buildApiUrl(apiUrl, requestPath), {
273
+ ...init,
274
+ headers: {
275
+ 'content-type': 'application/json',
276
+ authorization: `Bearer ${accessToken}`,
277
+ ...(init.headers ?? {}),
278
+ },
279
+ });
280
+ }
281
+ export async function authorizedApiFetch(auth, requestPath, init) {
282
+ let activeAuth = auth;
283
+ let response = await apiFetch(activeAuth.apiUrl, activeAuth.accessToken, requestPath, init);
284
+ if (response.status !== 401) {
285
+ return { response, auth: activeAuth };
286
+ }
287
+ try {
288
+ activeAuth = await refreshStoredAuth(activeAuth);
289
+ }
290
+ catch (error) {
291
+ if (isEnvBackedAuth(activeAuth)) {
292
+ throw toEnvAuthRefreshError(error);
293
+ }
294
+ activeAuth = await loginWithBrowser(activeAuth.apiUrl);
295
+ }
296
+ response = await apiFetch(activeAuth.apiUrl, activeAuth.accessToken, requestPath, init);
297
+ return { response, auth: activeAuth };
298
+ }
299
+ //# sourceMappingURL=auth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.js","sourceRoot":"","sources":["../../../../packages/cloud/src/auth.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,45 @@
1
+ /**
2
+ * Provider connect orchestration — provisions a Daytona sandbox via the
3
+ * Cloud API, opens an interactive SSH session that runs the provider CLI,
4
+ * and finalizes the auth state with Cloud.
5
+ *
6
+ * The CLI command in `agent-relay cloud connect <provider>` is a thin wrapper
7
+ * around this function; other tools (e.g. `ricky connect <provider>`) can
8
+ * import it directly and drive the same flow.
9
+ */
10
+ import type { AuthSshRuntime } from './lib/ssh-runtime.js';
11
+ export declare function getProviderHelpText(): string;
12
+ export declare function normalizeProvider(providerArg: string): string;
13
+ export interface ConnectProviderIo {
14
+ log: (...args: unknown[]) => void;
15
+ error: (...args: unknown[]) => void;
16
+ }
17
+ export interface ConnectProviderOptions {
18
+ /** Provider id or alias (`anthropic`/`claude`, `openai`/`codex`, `google`/`gemini`, …). */
19
+ provider: string;
20
+ /** Override the Cloud API URL. Defaults to `defaultApiUrl()`. */
21
+ apiUrl?: string;
22
+ /** Sandbox language/image. Defaults to `'typescript'`. */
23
+ language?: string;
24
+ /** Auth timeout in milliseconds. Defaults to 5 minutes. */
25
+ timeoutMs?: number;
26
+ /** Logger sink. Defaults to `console.log` / `console.error`. */
27
+ io?: ConnectProviderIo;
28
+ /** Override SSH/network runtime hooks (used in tests). */
29
+ runtime?: Partial<AuthSshRuntime>;
30
+ }
31
+ export interface ConnectProviderResult {
32
+ /** Normalized provider id used for the request. */
33
+ provider: string;
34
+ /** Whether the interactive session reported a positive auth pattern match. */
35
+ success: boolean;
36
+ }
37
+ /**
38
+ * Connect a provider via interactive SSH session.
39
+ *
40
+ * Throws on any failure. Returns `{ provider, success }` when the auth flow
41
+ * completed successfully — `success` is always `true` on resolved promises;
42
+ * an unsuccessful auth attempt rejects with a descriptive Error.
43
+ */
44
+ export declare function connectProvider(options: ConnectProviderOptions): Promise<ConnectProviderResult>;
45
+ //# sourceMappingURL=connect.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connect.d.ts","sourceRoot":"","sources":["../../../../packages/cloud/src/connect.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAOH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAQ3D,wBAAgB,mBAAmB,IAAI,MAAM,CAQ5C;AAED,wBAAgB,iBAAiB,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAG7D;AAED,MAAM,WAAW,iBAAiB;IAChC,GAAG,EAAE,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;IAClC,KAAK,EAAE,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;CACrC;AAED,MAAM,WAAW,sBAAsB;IACrC,2FAA2F;IAC3F,QAAQ,EAAE,MAAM,CAAC;IACjB,iEAAiE;IACjE,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,0DAA0D;IAC1D,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,2DAA2D;IAC3D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gEAAgE;IAChE,EAAE,CAAC,EAAE,iBAAiB,CAAC;IACvB,0DAA0D;IAC1D,OAAO,CAAC,EAAE,OAAO,CAAC,cAAc,CAAC,CAAC;CACnC;AAED,MAAM,WAAW,qBAAqB;IACpC,mDAAmD;IACnD,QAAQ,EAAE,MAAM,CAAC;IACjB,8EAA8E;IAC9E,OAAO,EAAE,OAAO,CAAC;CAClB;AA+BD;;;;;;GAMG;AACH,wBAAsB,eAAe,CAAC,OAAO,EAAE,sBAAsB,GAAG,OAAO,CAAC,qBAAqB,CAAC,CA4HrG"}
@@ -0,0 +1,166 @@
1
+ /**
2
+ * Provider connect orchestration — provisions a Daytona sandbox via the
3
+ * Cloud API, opens an interactive SSH session that runs the provider CLI,
4
+ * and finalizes the auth state with Cloud.
5
+ *
6
+ * The CLI command in `agent-relay cloud connect <provider>` is a thin wrapper
7
+ * around this function; other tools (e.g. `ricky connect <provider>`) can
8
+ * import it directly and drive the same flow.
9
+ */
10
+ import { CLI_AUTH_CONFIG } from '@agent-relay/config/cli-auth-config';
11
+ import { ensureAuthenticated, authorizedApiFetch } from './auth.js';
12
+ import { defaultApiUrl } from './types.js';
13
+ import { runInteractiveSession } from './lib/ssh-interactive.js';
14
+ const PROVIDER_ALIASES = {
15
+ claude: 'anthropic',
16
+ codex: 'openai',
17
+ gemini: 'google',
18
+ };
19
+ export function getProviderHelpText() {
20
+ return Object.keys(CLI_AUTH_CONFIG)
21
+ .sort()
22
+ .map((id) => {
23
+ const alias = Object.entries(PROVIDER_ALIASES).find(([, target]) => target === id);
24
+ return alias ? `${id} (alias: ${alias[0]})` : id;
25
+ })
26
+ .join(', ');
27
+ }
28
+ export function normalizeProvider(providerArg) {
29
+ const providerInput = providerArg.toLowerCase().trim();
30
+ return PROVIDER_ALIASES[providerInput] || providerInput;
31
+ }
32
+ const color = {
33
+ cyan: (s) => `\x1b[36m${s}\x1b[0m`,
34
+ green: (s) => `\x1b[32m${s}\x1b[0m`,
35
+ yellow: (s) => `\x1b[33m${s}\x1b[0m`,
36
+ red: (s) => `\x1b[31m${s}\x1b[0m`,
37
+ dim: (s) => `\x1b[2m${s}\x1b[0m`,
38
+ };
39
+ const DEFAULT_IO = {
40
+ log: (...args) => console.log(...args),
41
+ error: (...args) => console.error(...args),
42
+ };
43
+ async function getErrorDetails(response) {
44
+ let body;
45
+ try {
46
+ body = await response.text();
47
+ }
48
+ catch {
49
+ return response.statusText;
50
+ }
51
+ if (!body)
52
+ return response.statusText;
53
+ try {
54
+ const json = JSON.parse(body);
55
+ return json.error || json.message || response.statusText;
56
+ }
57
+ catch {
58
+ return body;
59
+ }
60
+ }
61
+ /**
62
+ * Connect a provider via interactive SSH session.
63
+ *
64
+ * Throws on any failure. Returns `{ provider, success }` when the auth flow
65
+ * completed successfully — `success` is always `true` on resolved promises;
66
+ * an unsuccessful auth attempt rejects with a descriptive Error.
67
+ */
68
+ export async function connectProvider(options) {
69
+ const io = options.io ?? DEFAULT_IO;
70
+ const language = options.language ?? 'typescript';
71
+ const timeoutMs = options.timeoutMs ?? 300_000;
72
+ if (!process.stdin.isTTY || !process.stdout.isTTY) {
73
+ throw new Error('connectProvider requires an interactive terminal (TTY).');
74
+ }
75
+ const provider = normalizeProvider(options.provider);
76
+ const providerConfig = CLI_AUTH_CONFIG[provider];
77
+ if (!providerConfig) {
78
+ const known = Object.keys(CLI_AUTH_CONFIG).sort();
79
+ throw new Error(`Unknown provider: ${options.provider}. Supported providers: ${known.join(', ')}`);
80
+ }
81
+ const apiUrl = options.apiUrl || defaultApiUrl();
82
+ io.log('');
83
+ io.log(color.cyan('═══════════════════════════════════════════════════'));
84
+ io.log(color.cyan(' Provider Authentication (Daytona Connect)'));
85
+ io.log(color.cyan('═══════════════════════════════════════════════════'));
86
+ io.log('');
87
+ io.log(`Provider: ${providerConfig.displayName} (${provider})`);
88
+ io.log(`Language: ${color.dim(language)}`);
89
+ io.log(color.dim(`Cloud: ${apiUrl}`));
90
+ io.log('');
91
+ io.log('Requesting sandbox from cloud...');
92
+ let auth = await ensureAuthenticated(apiUrl);
93
+ const { response: createResponse, auth: refreshedAuth } = await authorizedApiFetch(auth, '/api/v1/cli/auth', {
94
+ method: 'POST',
95
+ body: JSON.stringify({ provider, language }),
96
+ });
97
+ auth = refreshedAuth;
98
+ const start = (await createResponse.json().catch(() => null));
99
+ if (!createResponse.ok || !start?.sessionId) {
100
+ const detail = start?.error || start?.message || `${createResponse.status} ${createResponse.statusText}`;
101
+ throw new Error(detail);
102
+ }
103
+ const sshPort = typeof start.ssh?.port === 'string'
104
+ ? Number.parseInt(start.ssh.port, 10)
105
+ : start.ssh?.port;
106
+ if (!start.ssh?.host || !sshPort || !start.ssh.user || !start.ssh.password) {
107
+ throw new Error('Cloud returned invalid SSH session details.');
108
+ }
109
+ io.log(color.green('✓ Sandbox ready'));
110
+ io.log(color.dim(` SSH: ${start.ssh.user}@${start.ssh.host}:${sshPort}`));
111
+ io.log('');
112
+ io.log(color.yellow('Connecting via SSH...'));
113
+ io.log(color.dim(` Running: ${start.remoteCommand}`));
114
+ io.log('');
115
+ let sessionResult;
116
+ try {
117
+ sessionResult = await runInteractiveSession({
118
+ ssh: {
119
+ host: start.ssh.host,
120
+ port: sshPort,
121
+ user: start.ssh.user,
122
+ password: start.ssh.password,
123
+ },
124
+ remoteCommand: start.remoteCommand,
125
+ successPatterns: providerConfig.successPatterns || [],
126
+ errorPatterns: providerConfig.errorPatterns || [],
127
+ timeoutMs,
128
+ io,
129
+ runtime: options.runtime,
130
+ });
131
+ }
132
+ catch (error) {
133
+ throw new Error(`Failed to connect via SSH: ${error instanceof Error ? error.message : String(error)}`);
134
+ }
135
+ io.log('');
136
+ const authSuccess = sessionResult.authDetected;
137
+ io.log('Finalizing authentication with cloud...');
138
+ const { response: completeResponse } = await authorizedApiFetch(auth, '/api/v1/cli/auth/complete', {
139
+ method: 'POST',
140
+ body: JSON.stringify({ sessionId: start.sessionId, success: authSuccess }),
141
+ });
142
+ if (!completeResponse.ok) {
143
+ throw new Error(await getErrorDetails(completeResponse));
144
+ }
145
+ if (!authSuccess) {
146
+ const exitCode = sessionResult.exitCode;
147
+ if (typeof exitCode === 'number' && exitCode !== 0) {
148
+ io.error(color.red(`Remote auth command exited with code ${exitCode}.`));
149
+ }
150
+ if (sessionResult.exitCode === 127) {
151
+ io.log(color.yellow(`The ${providerConfig.displayName} CLI ("${providerConfig.command}") is not installed on the sandbox.`));
152
+ io.log(color.dim('Check the sandbox snapshot includes the required CLI tools.'));
153
+ }
154
+ throw new Error(`Provider auth for ${provider} did not complete successfully`);
155
+ }
156
+ io.log('');
157
+ io.log(color.green('═══════════════════════════════════════════════════'));
158
+ io.log(color.green(' Authentication Complete!'));
159
+ io.log(color.green('═══════════════════════════════════════════════════'));
160
+ io.log('');
161
+ io.log(`${providerConfig.displayName} credentials are now stored and encrypted.`);
162
+ io.log(color.dim('Your workflows will automatically use these credentials.'));
163
+ io.log('');
164
+ return { provider, success: true };
165
+ }
166
+ //# sourceMappingURL=connect.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connect.js","sourceRoot":"","sources":["../../../../packages/cloud/src/connect.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ export { readStoredAuth, writeStoredAuth, clearStoredAuth, refreshStoredAuth, ensureAuthenticated, authorizedApiFetch, } from './auth.js';
2
+ export { CloudApiClient, buildApiUrl, type CloudApiClientOptions, type CloudApiClientSnapshot, } from './api-client.js';
3
+ export { runWorkflow, scheduleWorkflow, listWorkflowSchedules, getRunStatus, getRunLogs, cancelWorkflow, syncWorkflowPatch, resolveWorkflowInput, inferWorkflowFileType, shouldSyncCodeByDefault, } from './workflows.js';
4
+ export { connectProvider, getProviderHelpText, normalizeProvider, type ConnectProviderIo, type ConnectProviderOptions, type ConnectProviderResult, } from './connect.js';
5
+ export { createWorkspace, issueWorkspaceToken } from './workspaces.js';
6
+ export { deployProactiveAgent, listProactiveAgents, inspectProactiveAgent, undeployProactiveAgent, createWorkspaceSecret, getWorkspaceSecret, deleteWorkspaceSecret, } from './proactive-runtime.js';
7
+ export { runInteractiveSession, formatShellInvocation, wrapWithLaunchCheckpoint, type SshConnectionInfo, type InteractiveSessionOptions, type InteractiveSessionResult, } from './lib/ssh-interactive.js';
8
+ export { loadSSH2, createAskpassScript, buildSystemSshArgs, DEFAULT_SSH_RUNTIME, type AuthSshRuntime, } from './lib/ssh-runtime.js';
9
+ export { type StoredAuth, type WhoAmIResponse, type AuthSessionResponse, type WorkspaceCreateResponse, type WorkspaceTokenIssueResponse, type WorkspaceTokenRecord, type ProactiveDeploymentResponse, type ProactiveAgentRecord, type WorkspaceSecretRecord, type WorkflowFileType, type RunWorkflowResponse, type WorkflowSchedule, type ScheduleWorkflowOptions, type WorkflowLogsResponse, type SyncPatchResponse, SUPPORTED_PROVIDERS, REFRESH_WINDOW_MS, AUTH_FILE_PATH, defaultApiUrl, isSupportedProvider, } from './types.js';
10
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../packages/cloud/src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EACd,eAAe,EACf,eAAe,EACf,iBAAiB,EACjB,mBAAmB,EACnB,kBAAkB,GACnB,MAAM,WAAW,CAAC;AAEnB,OAAO,EACL,cAAc,EACd,WAAW,EACX,KAAK,qBAAqB,EAC1B,KAAK,sBAAsB,GAC5B,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EACL,WAAW,EACX,gBAAgB,EAChB,qBAAqB,EACrB,YAAY,EACZ,UAAU,EACV,cAAc,EACd,iBAAiB,EACjB,oBAAoB,EACpB,qBAAqB,EACrB,uBAAuB,GACxB,MAAM,gBAAgB,CAAC;AAExB,OAAO,EACL,eAAe,EACf,mBAAmB,EACnB,iBAAiB,EACjB,KAAK,iBAAiB,EACtB,KAAK,sBAAsB,EAC3B,KAAK,qBAAqB,GAC3B,MAAM,cAAc,CAAC;AAEtB,OAAO,EAAE,eAAe,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAEvE,OAAO,EACL,oBAAoB,EACpB,mBAAmB,EACnB,qBAAqB,EACrB,sBAAsB,EACtB,qBAAqB,EACrB,kBAAkB,EAClB,qBAAqB,GACtB,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,qBAAqB,EACrB,qBAAqB,EACrB,wBAAwB,EACxB,KAAK,iBAAiB,EACtB,KAAK,yBAAyB,EAC9B,KAAK,wBAAwB,GAC9B,MAAM,0BAA0B,CAAC;AAElC,OAAO,EACL,QAAQ,EACR,mBAAmB,EACnB,kBAAkB,EAClB,mBAAmB,EACnB,KAAK,cAAc,GACpB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EACL,KAAK,UAAU,EACf,KAAK,cAAc,EACnB,KAAK,mBAAmB,EACxB,KAAK,uBAAuB,EAC5B,KAAK,2BAA2B,EAChC,KAAK,oBAAoB,EACzB,KAAK,2BAA2B,EAChC,KAAK,oBAAoB,EACzB,KAAK,qBAAqB,EAC1B,KAAK,gBAAgB,EACrB,KAAK,mBAAmB,EACxB,KAAK,gBAAgB,EACrB,KAAK,uBAAuB,EAC5B,KAAK,oBAAoB,EACzB,KAAK,iBAAiB,EACtB,mBAAmB,EACnB,iBAAiB,EACjB,cAAc,EACd,aAAa,EACb,mBAAmB,GACpB,MAAM,YAAY,CAAC"}
@@ -0,0 +1,10 @@
1
+ export { readStoredAuth, writeStoredAuth, clearStoredAuth, refreshStoredAuth, ensureAuthenticated, authorizedApiFetch, } from './auth.js';
2
+ export { CloudApiClient, buildApiUrl, } from './api-client.js';
3
+ export { runWorkflow, scheduleWorkflow, listWorkflowSchedules, getRunStatus, getRunLogs, cancelWorkflow, syncWorkflowPatch, resolveWorkflowInput, inferWorkflowFileType, shouldSyncCodeByDefault, } from './workflows.js';
4
+ export { connectProvider, getProviderHelpText, normalizeProvider, } from './connect.js';
5
+ export { createWorkspace, issueWorkspaceToken } from './workspaces.js';
6
+ export { deployProactiveAgent, listProactiveAgents, inspectProactiveAgent, undeployProactiveAgent, createWorkspaceSecret, getWorkspaceSecret, deleteWorkspaceSecret, } from './proactive-runtime.js';
7
+ export { runInteractiveSession, formatShellInvocation, wrapWithLaunchCheckpoint, } from './lib/ssh-interactive.js';
8
+ export { loadSSH2, createAskpassScript, buildSystemSshArgs, DEFAULT_SSH_RUNTIME, } from './lib/ssh-runtime.js';
9
+ export { SUPPORTED_PROVIDERS, REFRESH_WINDOW_MS, AUTH_FILE_PATH, defaultApiUrl, isSupportedProvider, } from './types.js';
10
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../packages/cloud/src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EACd,eAAe,EACf,eAAe,EACf,iBAAiB,EACjB,mBAAmB,EACnB,kBAAkB,GACnB,MAAM,WAAW,CAAC;AAEnB,OAAO,EACL,cAAc,EACd,WAAW,GAGZ,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EACL,WAAW,EACX,gBAAgB,EAChB,qBAAqB,EACrB,YAAY,EACZ,UAAU,EACV,cAAc,EACd,iBAAiB,EACjB,oBAAoB,EACpB,qBAAqB,EACrB,uBAAuB,GACxB,MAAM,gBAAgB,CAAC;AAExB,OAAO,EACL,eAAe,EACf,mBAAmB,EACnB,iBAAiB,GAIlB,MAAM,cAAc,CAAC;AAEtB,OAAO,EAAE,eAAe,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAEvE,OAAO,EACL,oBAAoB,EACpB,mBAAmB,EACnB,qBAAqB,EACrB,sBAAsB,EACtB,qBAAqB,EACrB,kBAAkB,EAClB,qBAAqB,GACtB,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,qBAAqB,EACrB,qBAAqB,EACrB,wBAAwB,GAIzB,MAAM,0BAA0B,CAAC;AAElC,OAAO,EACL,QAAQ,EACR,mBAAmB,EACnB,kBAAkB,EAClB,mBAAmB,GAEpB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAgBL,mBAAmB,EACnB,iBAAiB,EACjB,cAAc,EACd,aAAa,EACb,mBAAmB,GACpB,MAAM,YAAY,CAAC"}
@@ -0,0 +1,70 @@
1
+ /**
2
+ * SSH Interactive Session — reusable SSH+PTY runner.
3
+ *
4
+ * Powers both `agent-relay auth <provider>` and `agent-relay cloud connect <provider>`,
5
+ * and is published from `@agent-relay/cloud` so other CLIs can drive the same flow.
6
+ */
7
+ import { type ErrorPattern } from '@agent-relay/config/cli-auth-config';
8
+ import { type AuthSshRuntime } from './ssh-runtime.js';
9
+ export interface SshConnectionInfo {
10
+ host: string;
11
+ port: number;
12
+ user: string;
13
+ password: string;
14
+ }
15
+ export interface InteractiveSessionOptions {
16
+ ssh: SshConnectionInfo;
17
+ remoteCommand: string;
18
+ successPatterns: RegExp[];
19
+ errorPatterns: ErrorPattern[];
20
+ timeoutMs: number;
21
+ io: {
22
+ log: (...args: unknown[]) => void;
23
+ error: (...args: unknown[]) => void;
24
+ };
25
+ tunnelPort?: number;
26
+ runtime?: Partial<AuthSshRuntime>;
27
+ }
28
+ export interface InteractiveSessionResult {
29
+ exitCode: number | null;
30
+ exitSignal: string | null;
31
+ authDetected: boolean;
32
+ }
33
+ /**
34
+ * Format a remote command for execution inside an ssh2 shell() PTY.
35
+ *
36
+ * Wraps the command in `exec sh -c '…'` so the PTY closes cleanly when the
37
+ * target CLI exits (no shell-teardown race with a TUI's alt-screen flush)
38
+ * while still letting `sh` parse leading prefix assignments like
39
+ * `PATH=/foo/bin claude`. A bare `exec PATH=… claude` does not work in zsh
40
+ * because zsh's exec builtin treats `PATH=…` as the command name instead of
41
+ * a prefix assignment.
42
+ *
43
+ * We intentionally use `shell()` rather than `exec(cmd, { pty })` because
44
+ * Daytona's sandbox sshd only populates the full login-shell environment
45
+ * (including nvm-managed PATH entries where `claude` / `codex` actually live)
46
+ * for interactive shell sessions. An `exec` channel with a PTY gets a
47
+ * stripped-down environment and the target CLI fails to start silently.
48
+ */
49
+ export declare function formatShellInvocation(command: string): string;
50
+ /**
51
+ * Wrap the remote command with a visible checkpoint so the user sees proof
52
+ * the ssh pipeline reached the sandbox before the provider CLI takes over
53
+ * the terminal. Without this, claude/codex enter alt-screen immediately and
54
+ * the user sees zero output — indistinguishable from a hang.
55
+ *
56
+ * The printf runs before the exec that launches the provider CLI, so the
57
+ * user gets one visible line ("launching provider CLI…") right before
58
+ * alt-screen engages. When the provider CLI later exits and the alt-screen
59
+ * tears down, this line remains in scrollback as a breadcrumb.
60
+ */
61
+ export declare function wrapWithLaunchCheckpoint(command: string): string;
62
+ /**
63
+ * Run an interactive SSH session with PTY.
64
+ *
65
+ * Connects via ssh2 (if available) or falls back to system ssh,
66
+ * sets up a local port tunnel, and runs the remote command in a PTY.
67
+ * Monitors output for success/error patterns.
68
+ */
69
+ export declare function runInteractiveSession(options: InteractiveSessionOptions): Promise<InteractiveSessionResult>;
70
+ //# sourceMappingURL=ssh-interactive.d.ts.map