@alexlikevibe/agent-sdk 0.1.0 → 0.1.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/create-agent.d.ts.map +1 -1
- package/dist/create-agent.js +21 -6
- package/dist/create-agent.js.map +1 -1
- package/dist/environment.d.ts.map +1 -1
- package/dist/environment.js +1 -2
- package/dist/environment.js.map +1 -1
- package/dist/file-sync.d.ts.map +1 -1
- package/dist/file-sync.js +12 -7
- package/dist/file-sync.js.map +1 -1
- package/dist/gateway-llm-adapter.d.ts.map +1 -1
- package/dist/gateway-llm-adapter.js +1 -2
- package/dist/gateway-llm-adapter.js.map +1 -1
- package/dist/harness-server.d.ts.map +1 -1
- package/dist/harness-server.js +9 -2
- package/dist/harness-server.js.map +1 -1
- package/dist/logger.d.ts +3 -0
- package/dist/logger.d.ts.map +1 -0
- package/dist/logger.js +10 -0
- package/dist/logger.js.map +1 -0
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-agent.d.ts","sourceRoot":"","sources":["../src/create-agent.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"create-agent.d.ts","sourceRoot":"","sources":["../src/create-agent.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAA;AAOnE,MAAM,WAAW,kBAAkB;IACjC,kCAAkC;IAClC,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,+BAA+B;IAC/B,KAAK,CAAC,EAAE,cAAc,EAAE,CAAA;IACxB,sCAAsC;IACtC,SAAS,CAAC,EAAE,MAAM,EAAE,CAAA;CACrB;AAED,wBAAsB,WAAW,CAAC,OAAO,GAAE,kBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC,CA8CjF"}
|
package/dist/create-agent.js
CHANGED
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
import { createServer } from 'http';
|
|
2
|
-
import pino from 'pino';
|
|
3
2
|
import { resolveConfig } from './environment.js';
|
|
4
3
|
import { FileSync } from './file-sync.js';
|
|
5
4
|
import { GatewayClient } from './gateway-client.js';
|
|
6
5
|
import { createHarnessApp } from './harness-server.js';
|
|
7
|
-
|
|
6
|
+
import { logger } from './logger.js';
|
|
8
7
|
export async function createAgent(options = {}) {
|
|
9
8
|
const { systemPrompt = 'You are a helpful assistant.', tools, skillDirs } = options;
|
|
10
9
|
const config = resolveConfig();
|
|
@@ -13,19 +12,35 @@ export async function createAgent(options = {}) {
|
|
|
13
12
|
if (config.mode === 'sandbox') {
|
|
14
13
|
gateway = new GatewayClient(config.gatewayUrl, config.sessionToken);
|
|
15
14
|
fileSync = new FileSync(gateway, config.persistentRoot);
|
|
16
|
-
logger.info({ event: 'agent.file_sync_init', mode: 'sandbox' });
|
|
17
|
-
await fileSync.init();
|
|
18
|
-
fileSync.startWatch();
|
|
19
|
-
logger.info({ event: 'agent.file_sync_started' });
|
|
20
15
|
}
|
|
21
16
|
else {
|
|
22
17
|
logger.info({ event: 'agent.start', mode: 'local' });
|
|
23
18
|
}
|
|
19
|
+
// Create the app (registers LLM provider, sets up session, mounts routes)
|
|
20
|
+
// The app is created first so /health is available immediately after listen().
|
|
24
21
|
const app = await createHarnessApp({ systemPrompt, tools, skillDirs, config, gateway });
|
|
25
22
|
const server = createServer(app);
|
|
26
23
|
server.listen(config.port, () => {
|
|
27
24
|
logger.info({ event: 'agent.listening', port: config.port, mode: config.mode });
|
|
28
25
|
});
|
|
26
|
+
// In sandbox mode, run file sync init in the background AFTER the server is
|
|
27
|
+
// already listening. /health returns 200 immediately; /chat returns 503 until
|
|
28
|
+
// init is complete (handled inside createHarnessApp via the readyPromise).
|
|
29
|
+
if (config.mode === 'sandbox' && fileSync) {
|
|
30
|
+
const initStart = Date.now();
|
|
31
|
+
logger.info({ event: 'agent.file_sync_init', mode: 'sandbox' });
|
|
32
|
+
fileSync.init().then(() => {
|
|
33
|
+
fileSync.startWatch();
|
|
34
|
+
logger.info({ event: 'agent.file_sync_started', duration_ms: Date.now() - initStart });
|
|
35
|
+
app.locals.fileSyncReady = true;
|
|
36
|
+
}).catch((err) => {
|
|
37
|
+
logger.error({ event: 'agent.file_sync_failed', error: String(err) });
|
|
38
|
+
app.locals.fileSyncReady = true; // don't block chat on file sync failure
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
app.locals.fileSyncReady = true;
|
|
43
|
+
}
|
|
29
44
|
// Graceful shutdown
|
|
30
45
|
process.on('SIGTERM', () => {
|
|
31
46
|
fileSync?.stopWatch();
|
package/dist/create-agent.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-agent.js","sourceRoot":"","sources":["../src/create-agent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;
|
|
1
|
+
{"version":3,"file":"create-agent.js","sourceRoot":"","sources":["../src/create-agent.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"environment.d.ts","sourceRoot":"","sources":["../src/environment.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"environment.d.ts","sourceRoot":"","sources":["../src/environment.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,WAAW,GAAG,SAAS,GAAG,OAAO,CAAA;AAE7C,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,SAAS,CAAA;IACf,UAAU,EAAE,MAAM,CAAA;IAClB,YAAY,EAAE,MAAM,CAAA;IACpB,SAAS,EAAE,MAAM,CAAA;IACjB,IAAI,EAAE,MAAM,CAAA;IACZ,cAAc,EAAE,MAAM,CAAA;CACvB;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,OAAO,CAAA;IACb,IAAI,EAAE,MAAM,CAAA;CACb;AAED,MAAM,MAAM,cAAc,GAAG,aAAa,GAAG,WAAW,CAAA;AAExD,wBAAgB,iBAAiB,IAAI,WAAW,CAI/C;AAED,wBAAgB,aAAa,IAAI,cAAc,CAe9C"}
|
package/dist/environment.js
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import
|
|
2
|
-
const logger = pino({ transport: { target: 'pino-pretty' } });
|
|
1
|
+
import { logger } from './logger.js';
|
|
3
2
|
export function detectEnvironment() {
|
|
4
3
|
const hasGateway = Boolean(process.env.GATEWAY_URL);
|
|
5
4
|
const hasToken = Boolean(process.env.SESSION_TOKEN);
|
package/dist/environment.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"environment.js","sourceRoot":"","sources":["../src/environment.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"environment.js","sourceRoot":"","sources":["../src/environment.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AAoBpC,MAAM,UAAU,iBAAiB;IAC/B,MAAM,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAA;IACnD,MAAM,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,CAAA;IACnD,OAAO,UAAU,IAAI,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAA;AACrD,CAAC;AAED,MAAM,UAAU,aAAa;IAC3B,MAAM,IAAI,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,MAAM,EAAE,EAAE,CAAC,CAAA;IAErD,IAAI,iBAAiB,EAAE,KAAK,SAAS,EAAE,CAAC;QACtC,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,WAAY,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAA;QAC9D,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,CAAC,aAAc,CAAA;QAC/C,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,EAAE,CAAA;QAC9C,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,MAAM,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,wBAAwB,EAAE,EAAE,uDAAuD,CAAC,CAAA;QAC3G,CAAC;QACD,MAAM,cAAc,GAAG,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,aAAa,CAAA;QACnE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,EAAE,cAAc,EAAE,CAAA;IACvF,CAAC;IAED,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAA;AAChC,CAAC"}
|
package/dist/file-sync.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"file-sync.d.ts","sourceRoot":"","sources":["../src/file-sync.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"file-sync.d.ts","sourceRoot":"","sources":["../src/file-sync.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAA;AAIxD,qBAAa,QAAQ;IAKjB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,cAAc;IANjC,OAAO,CAAC,QAAQ,CAA4B;IAC5C,OAAO,CAAC,KAAK,CAA8C;gBAGxC,OAAO,EAAE,aAAa,EACtB,IAAI,EAAE,MAAM,EACZ,cAAc,GAAE,MAAyB;IAGtD,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAmC3B,UAAU,IAAI,IAAI;IAOlB,SAAS,IAAI,IAAI;IAOjB,OAAO,CAAC,SAAS;IAMjB,OAAO,CAAC,OAAO;YAaD,SAAS;CA+BxB"}
|
package/dist/file-sync.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { existsSync, mkdirSync, readdirSync, readFileSync, statSync, writeFileSync } from 'fs';
|
|
2
2
|
import { join, relative } from 'path';
|
|
3
|
-
import
|
|
4
|
-
const logger = pino({ transport: { target: 'pino-pretty' } });
|
|
3
|
+
import { logger } from './logger.js';
|
|
5
4
|
const POLL_INTERVAL_MS = 10_000;
|
|
6
5
|
export class FileSync {
|
|
7
6
|
gateway;
|
|
@@ -17,11 +16,17 @@ export class FileSync {
|
|
|
17
16
|
async init() {
|
|
18
17
|
mkdirSync(join(this.root, 'shared'), { recursive: true });
|
|
19
18
|
mkdirSync(join(this.root, 'conversation'), { recursive: true });
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
19
|
+
// Fetch both prefixes in parallel
|
|
20
|
+
const [sharedFiles, conversationFiles] = await Promise.all([
|
|
21
|
+
this.gateway.listFiles('shared'),
|
|
22
|
+
this.gateway.listFiles('conversation'),
|
|
23
|
+
]);
|
|
24
|
+
const allFiles = [
|
|
25
|
+
...sharedFiles,
|
|
26
|
+
...conversationFiles,
|
|
27
|
+
];
|
|
28
|
+
if (allFiles.length > 0) {
|
|
29
|
+
const ops = allFiles.map((f) => ({ action: 'download', path: f.path }));
|
|
25
30
|
const urls = await this.gateway.presignUrls(ops);
|
|
26
31
|
for (const { path, url } of urls) {
|
|
27
32
|
const localPath = join(this.root, path);
|
package/dist/file-sync.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"file-sync.js","sourceRoot":"","sources":["../src/file-sync.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,IAAI,CAAA;AAC9F,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAA;
|
|
1
|
+
{"version":3,"file":"file-sync.js","sourceRoot":"","sources":["../src/file-sync.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"gateway-llm-adapter.d.ts","sourceRoot":"","sources":["../src/gateway-llm-adapter.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"gateway-llm-adapter.d.ts","sourceRoot":"","sources":["../src/gateway-llm-adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEV,WAAW,EAKX,mBAAmB,EACpB,MAAM,qBAAqB,CAAA;AAI5B,QAAA,MAAM,eAAe,EAAG,aAAsB,CAAA;AAwB9C,wBAAgB,wBAAwB,CACtC,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,MAAM,GACZ,WAAW,CAAC,OAAO,eAAe,EAAE,mBAAmB,CAAC,CAwD1D"}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import
|
|
2
|
-
const logger = pino({ transport: { target: 'pino-pretty' } });
|
|
1
|
+
import { logger } from './logger.js';
|
|
3
2
|
const GATEWAY_PROVIDER = 'gateway';
|
|
4
3
|
const GATEWAY_LLM_API = 'gateway-llm';
|
|
5
4
|
function makeAssistantMessage(text, modelId, inputTokens, outputTokens, stopReason = 'stop', errorMessage) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"gateway-llm-adapter.js","sourceRoot":"","sources":["../src/gateway-llm-adapter.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"gateway-llm-adapter.js","sourceRoot":"","sources":["../src/gateway-llm-adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"harness-server.d.ts","sourceRoot":"","sources":["../src/harness-server.ts"],"names":[],"mappings":"AAAA,OAAO,EAML,KAAK,cAAc,EACpB,MAAM,+BAA+B,CAAA;AACtC,OAAgB,EAAE,KAAK,WAAW,EAAE,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"harness-server.d.ts","sourceRoot":"","sources":["../src/harness-server.ts"],"names":[],"mappings":"AAAA,OAAO,EAML,KAAK,cAAc,EACpB,MAAM,+BAA+B,CAAA;AACtC,OAAgB,EAAE,KAAK,WAAW,EAAE,MAAM,SAAS,CAAA;AAInD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAA;AACxD,OAAO,KAAK,EAAE,cAAc,EAAiB,MAAM,kBAAkB,CAAA;AAGrE,MAAM,WAAW,oBAAoB;IACnC,YAAY,EAAE,MAAM,CAAA;IACpB,KAAK,CAAC,EAAE,cAAc,EAAE,CAAA;IACxB,SAAS,CAAC,EAAE,MAAM,EAAE,CAAA;IACpB,MAAM,EAAE,cAAc,CAAA;IACtB,OAAO,CAAC,EAAE,aAAa,CAAA;CACxB;AAKD,wBAAsB,gBAAgB,CAAC,OAAO,EAAE,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAAC,CAkI1F"}
|
package/dist/harness-server.js
CHANGED
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import { AuthStorage, createAgentSession, ModelRegistry, SessionManager, } from '@mariozechner/pi-coding-agent';
|
|
2
2
|
import express from 'express';
|
|
3
3
|
import { join } from 'path';
|
|
4
|
-
import pino from 'pino';
|
|
5
4
|
import { createGatewayLlmProvider } from './gateway-llm-adapter.js';
|
|
6
|
-
|
|
5
|
+
import { logger } from './logger.js';
|
|
7
6
|
// Note: /chat requests are processed serially by the pi agent session.
|
|
8
7
|
// Concurrent requests are not supported in MVP — the dispatcher ensures
|
|
9
8
|
// one request at a time per conversation (sandbox-per-conversation model).
|
|
@@ -64,10 +63,18 @@ export async function createHarnessApp(options) {
|
|
|
64
63
|
if (systemPrompt) {
|
|
65
64
|
session.agent.setSystemPrompt(systemPrompt);
|
|
66
65
|
}
|
|
66
|
+
// /health is always 200 — dispatcher polls this to detect agent startup.
|
|
67
|
+
// It returns OK as soon as the HTTP server is listening, before file sync
|
|
68
|
+
// or session init completes, allowing faster sandbox ready detection.
|
|
67
69
|
app.get('/health', (_req, res) => {
|
|
68
70
|
res.json({ ok: true });
|
|
69
71
|
});
|
|
70
72
|
app.post('/chat', async (req, res) => {
|
|
73
|
+
// Return 503 if file sync init is still in progress (typically < 1s)
|
|
74
|
+
if (config.mode === 'sandbox' && !req.app.locals.fileSyncReady) {
|
|
75
|
+
res.status(503).json({ error: 'agent initializing' });
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
71
78
|
const { message } = req.body;
|
|
72
79
|
if (!message) {
|
|
73
80
|
res.status(400).json({ error: 'missing message' });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"harness-server.js","sourceRoot":"","sources":["../src/harness-server.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,kBAAkB,EAElB,aAAa,EACb,cAAc,GAEf,MAAM,+BAA+B,CAAA;AACtC,OAAO,OAA6B,MAAM,SAAS,CAAA;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAA;AAC3B,OAAO,
|
|
1
|
+
{"version":3,"file":"harness-server.js","sourceRoot":"","sources":["../src/harness-server.ts"],"names":[],"mappings":"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"}
|
package/dist/logger.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAA;AAUvB,eAAO,MAAM,MAAM,6BAAkB,CAAA"}
|
package/dist/logger.js
ADDED
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import pino from 'pino';
|
|
2
|
+
// Use pino-pretty only when stdout is a TTY (local dev).
|
|
3
|
+
// In sandbox (non-TTY), fall back to plain JSON to avoid
|
|
4
|
+
// the "unable to determine transport target for pino-pretty" error
|
|
5
|
+
// when pino-pretty is not installed as a production dependency.
|
|
6
|
+
const transport = process.stdout.isTTY
|
|
7
|
+
? { transport: { target: 'pino-pretty' } }
|
|
8
|
+
: {};
|
|
9
|
+
export const logger = pino(transport);
|
|
10
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAA;AAEvB,yDAAyD;AACzD,yDAAyD;AACzD,mEAAmE;AACnE,gEAAgE;AAChE,MAAM,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK;IACpC,CAAC,CAAC,EAAE,SAAS,EAAE,EAAE,MAAM,EAAE,aAAa,EAAE,EAAE;IAC1C,CAAC,CAAC,EAAE,CAAA;AAEN,MAAM,CAAC,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,CAAA"}
|