@ash-ai/server 0.0.3 → 0.0.5
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/__tests__/attachments.test.d.ts +2 -0
- package/dist/__tests__/attachments.test.d.ts.map +1 -0
- package/dist/__tests__/attachments.test.js +57 -0
- package/dist/__tests__/attachments.test.js.map +1 -0
- package/dist/__tests__/bundle.test.d.ts +2 -0
- package/dist/__tests__/bundle.test.d.ts.map +1 -0
- package/dist/__tests__/bundle.test.js +55 -0
- package/dist/__tests__/bundle.test.js.map +1 -0
- package/dist/__tests__/coordinator.test.d.ts +2 -0
- package/dist/__tests__/coordinator.test.d.ts.map +1 -0
- package/dist/__tests__/coordinator.test.js +283 -0
- package/dist/__tests__/coordinator.test.js.map +1 -0
- package/dist/__tests__/crypto.test.d.ts +2 -0
- package/dist/__tests__/crypto.test.d.ts.map +1 -0
- package/dist/__tests__/crypto.test.js +72 -0
- package/dist/__tests__/crypto.test.js.map +1 -0
- package/dist/__tests__/file-store.test.d.ts +2 -0
- package/dist/__tests__/file-store.test.d.ts.map +1 -0
- package/dist/__tests__/file-store.test.js +105 -0
- package/dist/__tests__/file-store.test.js.map +1 -0
- package/dist/__tests__/files.test.js +18 -5
- package/dist/__tests__/files.test.js.map +1 -1
- package/dist/__tests__/multi-tenant.test.js +15 -1
- package/dist/__tests__/multi-tenant.test.js.map +1 -1
- package/dist/__tests__/openapi.test.js +6 -3
- package/dist/__tests__/openapi.test.js.map +1 -1
- package/dist/__tests__/queue.test.d.ts +2 -0
- package/dist/__tests__/queue.test.d.ts.map +1 -0
- package/dist/__tests__/queue.test.js +151 -0
- package/dist/__tests__/queue.test.js.map +1 -0
- package/dist/__tests__/usage.test.d.ts +2 -0
- package/dist/__tests__/usage.test.d.ts.map +1 -0
- package/dist/__tests__/usage.test.js +74 -0
- package/dist/__tests__/usage.test.js.map +1 -0
- package/dist/auth.d.ts +6 -2
- package/dist/auth.d.ts.map +1 -1
- package/dist/auth.js +23 -5
- package/dist/auth.js.map +1 -1
- package/dist/crypto.d.ts +14 -0
- package/dist/crypto.d.ts.map +1 -0
- package/dist/crypto.js +45 -0
- package/dist/crypto.js.map +1 -0
- package/dist/db/drizzle-db.d.ts +129 -0
- package/dist/db/drizzle-db.d.ts.map +1 -0
- package/dist/db/drizzle-db.js +789 -0
- package/dist/db/drizzle-db.js.map +1 -0
- package/dist/db/index.d.ts +129 -3
- package/dist/db/index.d.ts.map +1 -1
- package/dist/db/index.js +147 -8
- package/dist/db/index.js.map +1 -1
- package/dist/db/schema.pg.d.ts +1642 -0
- package/dist/db/schema.pg.d.ts.map +1 -0
- package/dist/db/schema.pg.js +151 -0
- package/dist/db/schema.pg.js.map +1 -0
- package/dist/db/schema.sqlite.d.ts +1800 -0
- package/dist/db/schema.sqlite.d.ts.map +1 -0
- package/dist/db/schema.sqlite.js +151 -0
- package/dist/db/schema.sqlite.js.map +1 -0
- package/dist/index.d.ts +2 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +16 -95
- package/dist/index.js.map +1 -1
- package/dist/queue/processor.d.ts +51 -0
- package/dist/queue/processor.d.ts.map +1 -0
- package/dist/queue/processor.js +98 -0
- package/dist/queue/processor.js.map +1 -0
- package/dist/routes/attachments.d.ts +3 -0
- package/dist/routes/attachments.d.ts.map +1 -0
- package/dist/routes/attachments.js +168 -0
- package/dist/routes/attachments.js.map +1 -0
- package/dist/routes/credentials.d.ts +11 -0
- package/dist/routes/credentials.d.ts.map +1 -0
- package/dist/routes/credentials.js +120 -0
- package/dist/routes/credentials.js.map +1 -0
- package/dist/routes/files.d.ts.map +1 -1
- package/dist/routes/files.js +97 -31
- package/dist/routes/files.js.map +1 -1
- package/dist/routes/health.d.ts.map +1 -1
- package/dist/routes/health.js +9 -1
- package/dist/routes/health.js.map +1 -1
- package/dist/routes/queue.d.ts +3 -0
- package/dist/routes/queue.d.ts.map +1 -0
- package/dist/routes/queue.js +144 -0
- package/dist/routes/queue.js.map +1 -0
- package/dist/routes/runners.d.ts +5 -0
- package/dist/routes/runners.d.ts.map +1 -1
- package/dist/routes/runners.js +42 -5
- package/dist/routes/runners.js.map +1 -1
- package/dist/routes/sessions.d.ts +2 -1
- package/dist/routes/sessions.d.ts.map +1 -1
- package/dist/routes/sessions.js +218 -12
- package/dist/routes/sessions.js.map +1 -1
- package/dist/routes/usage.d.ts +3 -0
- package/dist/routes/usage.d.ts.map +1 -0
- package/dist/routes/usage.js +64 -0
- package/dist/routes/usage.js.map +1 -0
- package/dist/routes/workspace.d.ts +4 -0
- package/dist/routes/workspace.d.ts.map +1 -0
- package/dist/routes/workspace.js +123 -0
- package/dist/routes/workspace.js.map +1 -0
- package/dist/runner/coordinator.d.ts +77 -9
- package/dist/runner/coordinator.d.ts.map +1 -1
- package/dist/runner/coordinator.js +163 -89
- package/dist/runner/coordinator.js.map +1 -1
- package/dist/runner/local-backend.d.ts +1 -0
- package/dist/runner/local-backend.d.ts.map +1 -1
- package/dist/runner/local-backend.js +8 -0
- package/dist/runner/local-backend.js.map +1 -1
- package/dist/runner/remote-backend.d.ts +2 -0
- package/dist/runner/remote-backend.d.ts.map +1 -1
- package/dist/runner/remote-backend.js +9 -0
- package/dist/runner/remote-backend.js.map +1 -1
- package/dist/runner/runner-client.d.ts +6 -0
- package/dist/runner/runner-client.d.ts.map +1 -1
- package/dist/runner/runner-client.js +15 -0
- package/dist/runner/runner-client.js.map +1 -1
- package/dist/runner/types.d.ts +6 -0
- package/dist/runner/types.d.ts.map +1 -1
- package/dist/schemas.d.ts.map +1 -1
- package/dist/schemas.js +85 -1
- package/dist/schemas.js.map +1 -1
- package/dist/server.d.ts +31 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +176 -0
- package/dist/server.js.map +1 -0
- package/dist/telemetry/exporter.d.ts +16 -0
- package/dist/telemetry/exporter.d.ts.map +1 -0
- package/dist/telemetry/exporter.js +89 -0
- package/dist/telemetry/exporter.js.map +1 -0
- package/dist/usage/extractor.d.ts +18 -0
- package/dist/usage/extractor.d.ts.map +1 -0
- package/dist/usage/extractor.js +48 -0
- package/dist/usage/extractor.js.map +1 -0
- package/drizzle/pg/0000_thick_loners.sql +75 -0
- package/drizzle/pg/0001_rare_lester.sql +13 -0
- package/drizzle/pg/0002_short_shinko_yamashiro.sql +1 -0
- package/drizzle/pg/0003_remarkable_mastermind.sql +14 -0
- package/drizzle/pg/0004_warm_reaper.sql +18 -0
- package/drizzle/pg/0005_overconfident_mole_man.sql +14 -0
- package/drizzle/pg/0006_third_shiva.sql +13 -0
- package/drizzle/pg/0007_keen_shockwave.sql +2 -0
- package/drizzle/pg/meta/0000_snapshot.json +648 -0
- package/drizzle/pg/meta/0001_snapshot.json +743 -0
- package/drizzle/pg/meta/0002_snapshot.json +749 -0
- package/drizzle/pg/meta/0003_snapshot.json +841 -0
- package/drizzle/pg/meta/0004_snapshot.json +974 -0
- package/drizzle/pg/meta/0005_snapshot.json +1079 -0
- package/drizzle/pg/meta/0006_snapshot.json +1193 -0
- package/drizzle/pg/meta/0007_snapshot.json +1199 -0
- package/drizzle/pg/meta/_journal.json +62 -0
- package/drizzle/sqlite/0000_massive_kinsey_walden.sql +75 -0
- package/drizzle/sqlite/0001_quiet_phantom_reporter.sql +13 -0
- package/drizzle/sqlite/0002_broad_sheva_callister.sql +1 -0
- package/drizzle/sqlite/0003_thankful_agent_brand.sql +14 -0
- package/drizzle/sqlite/0004_productive_wolverine.sql +18 -0
- package/drizzle/sqlite/0005_chilly_carlie_cooper.sql +14 -0
- package/drizzle/sqlite/0006_workable_starfox.sql +13 -0
- package/drizzle/sqlite/0007_quick_hemingway.sql +19 -0
- package/drizzle/sqlite/meta/0000_snapshot.json +503 -0
- package/drizzle/sqlite/meta/0001_snapshot.json +587 -0
- package/drizzle/sqlite/meta/0002_snapshot.json +594 -0
- package/drizzle/sqlite/meta/0003_snapshot.json +685 -0
- package/drizzle/sqlite/meta/0004_snapshot.json +807 -0
- package/drizzle/sqlite/meta/0005_snapshot.json +897 -0
- package/drizzle/sqlite/meta/0006_snapshot.json +981 -0
- package/drizzle/sqlite/meta/0007_snapshot.json +988 -0
- package/drizzle/sqlite/meta/_journal.json +62 -0
- package/package.json +10 -5
- package/dist/__tests__/schema.test.d.ts +0 -2
- package/dist/__tests__/schema.test.d.ts.map +0 -1
- package/dist/__tests__/schema.test.js +0 -31
- package/dist/__tests__/schema.test.js.map +0 -1
- package/dist/db/dump-schema.d.ts +0 -10
- package/dist/db/dump-schema.d.ts.map +0 -1
- package/dist/db/dump-schema.js +0 -64
- package/dist/db/dump-schema.js.map +0 -1
- package/dist/db/pg.d.ts +0 -52
- package/dist/db/pg.d.ts.map +0 -1
- package/dist/db/pg.js +0 -398
- package/dist/db/pg.js.map +0 -1
- package/dist/db/sqlite.d.ts +0 -51
- package/dist/db/sqlite.d.ts.map +0 -1
- package/dist/db/sqlite.js +0 -412
- package/dist/db/sqlite.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema.sqlite.d.ts","sourceRoot":"","sources":["../../src/db/schema.sqlite.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { sqliteTable, text, integer, real, index, uniqueIndex } from 'drizzle-orm/sqlite-core';
|
|
2
|
+
export const runners = sqliteTable('runners', {
|
|
3
|
+
id: text('id').primaryKey(),
|
|
4
|
+
host: text('host').notNull(),
|
|
5
|
+
port: integer('port').notNull(),
|
|
6
|
+
maxSandboxes: integer('max_sandboxes').notNull().default(100),
|
|
7
|
+
activeCount: integer('active_count').notNull().default(0),
|
|
8
|
+
warmingCount: integer('warming_count').notNull().default(0),
|
|
9
|
+
lastHeartbeatAt: text('last_heartbeat_at').notNull(),
|
|
10
|
+
registeredAt: text('registered_at').notNull(),
|
|
11
|
+
}, (table) => [
|
|
12
|
+
index('idx_runners_heartbeat').on(table.lastHeartbeatAt),
|
|
13
|
+
]);
|
|
14
|
+
export const agents = sqliteTable('agents', {
|
|
15
|
+
id: text('id').primaryKey(),
|
|
16
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
17
|
+
name: text('name').notNull(),
|
|
18
|
+
version: integer('version').notNull().default(1),
|
|
19
|
+
path: text('path').notNull(),
|
|
20
|
+
createdAt: text('created_at').notNull(),
|
|
21
|
+
updatedAt: text('updated_at').notNull(),
|
|
22
|
+
}, (table) => [
|
|
23
|
+
uniqueIndex('idx_agents_tenant_name').on(table.tenantId, table.name),
|
|
24
|
+
index('idx_agents_tenant').on(table.tenantId),
|
|
25
|
+
]);
|
|
26
|
+
export const sessions = sqliteTable('sessions', {
|
|
27
|
+
id: text('id').primaryKey(),
|
|
28
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
29
|
+
agentName: text('agent_name').notNull(),
|
|
30
|
+
sandboxId: text('sandbox_id').notNull(),
|
|
31
|
+
status: text('status').notNull().default('starting'),
|
|
32
|
+
runnerId: text('runner_id'),
|
|
33
|
+
parentSessionId: text('parent_session_id'),
|
|
34
|
+
createdAt: text('created_at').notNull(),
|
|
35
|
+
lastActiveAt: text('last_active_at').notNull(),
|
|
36
|
+
}, (table) => [
|
|
37
|
+
index('idx_sessions_tenant').on(table.tenantId),
|
|
38
|
+
index('idx_sessions_runner').on(table.runnerId),
|
|
39
|
+
]);
|
|
40
|
+
export const sandboxes = sqliteTable('sandboxes', {
|
|
41
|
+
id: text('id').primaryKey(),
|
|
42
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
43
|
+
sessionId: text('session_id'),
|
|
44
|
+
agentName: text('agent_name').notNull(),
|
|
45
|
+
state: text('state').notNull().default('warming'),
|
|
46
|
+
workspaceDir: text('workspace_dir').notNull(),
|
|
47
|
+
createdAt: text('created_at').notNull(),
|
|
48
|
+
lastUsedAt: text('last_used_at').notNull(),
|
|
49
|
+
}, (table) => [
|
|
50
|
+
index('idx_sandboxes_state').on(table.state),
|
|
51
|
+
index('idx_sandboxes_session').on(table.sessionId),
|
|
52
|
+
index('idx_sandboxes_last_used').on(table.lastUsedAt),
|
|
53
|
+
index('idx_sandboxes_tenant').on(table.tenantId),
|
|
54
|
+
]);
|
|
55
|
+
export const apiKeys = sqliteTable('api_keys', {
|
|
56
|
+
id: text('id').primaryKey(),
|
|
57
|
+
tenantId: text('tenant_id').notNull(),
|
|
58
|
+
keyHash: text('key_hash').notNull().unique(),
|
|
59
|
+
label: text('label').notNull().default(''),
|
|
60
|
+
createdAt: text('created_at').notNull(),
|
|
61
|
+
}, (table) => [
|
|
62
|
+
index('idx_api_keys_tenant').on(table.tenantId),
|
|
63
|
+
index('idx_api_keys_hash').on(table.keyHash),
|
|
64
|
+
]);
|
|
65
|
+
export const messages = sqliteTable('messages', {
|
|
66
|
+
id: text('id').primaryKey(),
|
|
67
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
68
|
+
sessionId: text('session_id').notNull(),
|
|
69
|
+
role: text('role').notNull(),
|
|
70
|
+
content: text('content').notNull(),
|
|
71
|
+
sequence: integer('sequence').notNull(),
|
|
72
|
+
createdAt: text('created_at').notNull(),
|
|
73
|
+
}, (table) => [
|
|
74
|
+
uniqueIndex('idx_messages_unique_seq').on(table.tenantId, table.sessionId, table.sequence),
|
|
75
|
+
index('idx_messages_session').on(table.tenantId, table.sessionId, table.sequence),
|
|
76
|
+
]);
|
|
77
|
+
export const sessionEvents = sqliteTable('session_events', {
|
|
78
|
+
id: text('id').primaryKey(),
|
|
79
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
80
|
+
sessionId: text('session_id').notNull(),
|
|
81
|
+
type: text('type').notNull(),
|
|
82
|
+
data: text('data'),
|
|
83
|
+
sequence: integer('sequence').notNull(),
|
|
84
|
+
createdAt: text('created_at').notNull(),
|
|
85
|
+
}, (table) => [
|
|
86
|
+
uniqueIndex('idx_session_events_unique_seq').on(table.tenantId, table.sessionId, table.sequence),
|
|
87
|
+
index('idx_session_events_session').on(table.tenantId, table.sessionId, table.sequence),
|
|
88
|
+
index('idx_session_events_type').on(table.tenantId, table.sessionId, table.type),
|
|
89
|
+
]);
|
|
90
|
+
export const credentials = sqliteTable('credentials', {
|
|
91
|
+
id: text('id').primaryKey(),
|
|
92
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
93
|
+
type: text('type').notNull(),
|
|
94
|
+
encryptedKey: text('encrypted_key').notNull(),
|
|
95
|
+
iv: text('iv').notNull(),
|
|
96
|
+
authTag: text('auth_tag').notNull(),
|
|
97
|
+
salt: text('salt'), // PBKDF2 salt — null for legacy SHA-256 derived credentials
|
|
98
|
+
label: text('label').notNull().default(''),
|
|
99
|
+
active: integer('active').notNull().default(1),
|
|
100
|
+
createdAt: text('created_at').notNull(),
|
|
101
|
+
lastUsedAt: text('last_used_at'),
|
|
102
|
+
}, (table) => [
|
|
103
|
+
index('idx_credentials_tenant').on(table.tenantId),
|
|
104
|
+
]);
|
|
105
|
+
export const usageEvents = sqliteTable('usage_events', {
|
|
106
|
+
id: text('id').primaryKey(),
|
|
107
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
108
|
+
sessionId: text('session_id').notNull(),
|
|
109
|
+
agentName: text('agent_name').notNull(),
|
|
110
|
+
eventType: text('event_type').notNull(),
|
|
111
|
+
value: real('value').notNull(),
|
|
112
|
+
createdAt: text('created_at').notNull(),
|
|
113
|
+
}, (table) => [
|
|
114
|
+
index('idx_usage_session').on(table.tenantId, table.sessionId),
|
|
115
|
+
index('idx_usage_agent').on(table.tenantId, table.agentName),
|
|
116
|
+
index('idx_usage_type').on(table.eventType),
|
|
117
|
+
]);
|
|
118
|
+
export const attachments = sqliteTable('attachments', {
|
|
119
|
+
id: text('id').primaryKey(),
|
|
120
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
121
|
+
messageId: text('message_id').notNull(),
|
|
122
|
+
sessionId: text('session_id').notNull(),
|
|
123
|
+
filename: text('filename').notNull(),
|
|
124
|
+
mimeType: text('mime_type').notNull(),
|
|
125
|
+
size: integer('size').notNull(),
|
|
126
|
+
storagePath: text('storage_path').notNull(),
|
|
127
|
+
createdAt: text('created_at').notNull(),
|
|
128
|
+
}, (table) => [
|
|
129
|
+
index('idx_attachments_session').on(table.tenantId, table.sessionId),
|
|
130
|
+
index('idx_attachments_message').on(table.messageId),
|
|
131
|
+
]);
|
|
132
|
+
export const queueItems = sqliteTable('queue_items', {
|
|
133
|
+
id: text('id').primaryKey(),
|
|
134
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
135
|
+
sessionId: text('session_id'),
|
|
136
|
+
agentName: text('agent_name').notNull(),
|
|
137
|
+
prompt: text('prompt').notNull(),
|
|
138
|
+
status: text('status').notNull().default('pending'),
|
|
139
|
+
priority: integer('priority').notNull().default(0),
|
|
140
|
+
retryCount: integer('retry_count').notNull().default(0),
|
|
141
|
+
maxRetries: integer('max_retries').notNull().default(3),
|
|
142
|
+
error: text('error'),
|
|
143
|
+
retryAfter: text('retry_after'),
|
|
144
|
+
createdAt: text('created_at').notNull(),
|
|
145
|
+
startedAt: text('started_at'),
|
|
146
|
+
completedAt: text('completed_at'),
|
|
147
|
+
}, (table) => [
|
|
148
|
+
index('idx_queue_tenant').on(table.tenantId),
|
|
149
|
+
index('idx_queue_status').on(table.status, table.priority),
|
|
150
|
+
]);
|
|
151
|
+
//# sourceMappingURL=schema.sqlite.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema.sqlite.js","sourceRoot":"","sources":["../../src/db/schema.sqlite.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,YAAY,EAAE,gBAAgB,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,21 +1,9 @@
|
|
|
1
|
-
import
|
|
2
|
-
import swagger from '@fastify/swagger';
|
|
3
|
-
import swaggerUi from '@fastify/swagger-ui';
|
|
4
|
-
import { join, resolve, dirname } from 'node:path';
|
|
1
|
+
import { resolve, join, dirname } from 'node:path';
|
|
5
2
|
import { fileURLToPath } from 'node:url';
|
|
6
3
|
import { DEFAULT_PORT, DEFAULT_HOST, DEFAULT_DATA_DIR, DEFAULT_MAX_SANDBOXES, DEFAULT_IDLE_TIMEOUT_MS } from '@ash-ai/shared';
|
|
7
|
-
import {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
import { RunnerCoordinator } from './runner/coordinator.js';
|
|
11
|
-
import { registerSchemas } from './schemas.js';
|
|
12
|
-
import { registerAuth } from './auth.js';
|
|
13
|
-
import { agentRoutes } from './routes/agents.js';
|
|
14
|
-
import { sessionRoutes } from './routes/sessions.js';
|
|
15
|
-
import { healthRoutes } from './routes/health.js';
|
|
16
|
-
import { runnerRoutes } from './routes/runners.js';
|
|
17
|
-
import { fileRoutes } from './routes/files.js';
|
|
18
|
-
// Config from env
|
|
4
|
+
import { createAshServer } from './server.js';
|
|
5
|
+
export { createAshServer } from './server.js';
|
|
6
|
+
// When run directly (not imported), start the server from env config
|
|
19
7
|
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
20
8
|
const monorepoRoot = resolve(__dirname, '..', '..', '..');
|
|
21
9
|
const port = parseInt(process.env.ASH_PORT || String(DEFAULT_PORT), 10);
|
|
@@ -24,88 +12,21 @@ const dataDir = resolve(process.env.ASH_DATA_DIR || DEFAULT_DATA_DIR);
|
|
|
24
12
|
const bridgeEntry = process.env.ASH_BRIDGE_ENTRY
|
|
25
13
|
? resolve(process.env.ASH_BRIDGE_ENTRY)
|
|
26
14
|
: join(monorepoRoot, 'packages', 'bridge', 'dist', 'index.js');
|
|
27
|
-
// Mode: 'standalone' (default) or 'coordinator'
|
|
28
15
|
const mode = (process.env.ASH_MODE || 'standalone');
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
bridgeEntry,
|
|
40
|
-
});
|
|
41
|
-
const maxCapacity = parseInt(process.env.ASH_MAX_SANDBOXES || String(DEFAULT_MAX_SANDBOXES), 10);
|
|
42
|
-
const idleTimeoutMs = parseInt(process.env.ASH_IDLE_TIMEOUT_MS || String(DEFAULT_IDLE_TIMEOUT_MS), 10);
|
|
43
|
-
pool = new SandboxPool({
|
|
44
|
-
manager: sandboxManager,
|
|
45
|
-
db,
|
|
46
|
-
dataDir,
|
|
47
|
-
maxCapacity,
|
|
48
|
-
idleTimeoutMs,
|
|
49
|
-
onBeforeEvict: async (entry) => {
|
|
50
|
-
if (entry.sessionId) {
|
|
51
|
-
persistSessionState(dataDir, entry.sessionId, entry.sandbox.workspaceDir, entry.agentName);
|
|
52
|
-
syncStateToCloud(dataDir, entry.sessionId).catch((err) => console.error(`[server] Cloud sync failed for ${entry.sessionId}:`, err));
|
|
53
|
-
await updateSessionStatus(entry.sessionId, 'paused');
|
|
54
|
-
}
|
|
55
|
-
},
|
|
56
|
-
});
|
|
57
|
-
await pool.init();
|
|
58
|
-
pool.startIdleSweep();
|
|
59
|
-
const localBackend = new LocalRunnerBackend(pool, dataDir);
|
|
60
|
-
coordinator = new RunnerCoordinator({ localBackend });
|
|
61
|
-
}
|
|
62
|
-
else {
|
|
63
|
-
// Coordinator mode: pure control plane, no local sandbox pool
|
|
64
|
-
// Runners must register and provide sandbox capacity
|
|
65
|
-
coordinator = new RunnerCoordinator({});
|
|
66
|
-
}
|
|
67
|
-
const app = Fastify({ logger: true });
|
|
68
|
-
// OpenAPI / Swagger
|
|
69
|
-
await app.register(swagger, {
|
|
70
|
-
openapi: {
|
|
71
|
-
info: {
|
|
72
|
-
title: 'Ash API',
|
|
73
|
-
description: 'REST API for deploying and orchestrating hosted AI agents',
|
|
74
|
-
version: '0.1.0',
|
|
75
|
-
},
|
|
76
|
-
servers: [{ url: `http://localhost:${port}` }],
|
|
77
|
-
tags: [
|
|
78
|
-
{ name: 'health', description: 'Server health' },
|
|
79
|
-
{ name: 'agents', description: 'Agent deployment and management' },
|
|
80
|
-
{ name: 'sessions', description: 'Session lifecycle and messaging' },
|
|
81
|
-
],
|
|
82
|
-
},
|
|
16
|
+
const { app, shutdown } = await createAshServer({
|
|
17
|
+
dataDir,
|
|
18
|
+
databaseUrl: process.env.ASH_DATABASE_URL,
|
|
19
|
+
mode,
|
|
20
|
+
bridgeEntry,
|
|
21
|
+
port,
|
|
22
|
+
host,
|
|
23
|
+
maxSandboxes: parseInt(process.env.ASH_MAX_SANDBOXES || String(DEFAULT_MAX_SANDBOXES), 10),
|
|
24
|
+
idleTimeoutMs: parseInt(process.env.ASH_IDLE_TIMEOUT_MS || String(DEFAULT_IDLE_TIMEOUT_MS), 10),
|
|
25
|
+
apiKey: process.env.ASH_API_KEY,
|
|
83
26
|
});
|
|
84
|
-
await app.register(swaggerUi, { routePrefix: '/docs' });
|
|
85
|
-
registerSchemas(app);
|
|
86
|
-
// Auth: multi-tenant API key resolution with ASH_API_KEY fallback
|
|
87
|
-
registerAuth(app, process.env.ASH_API_KEY, db);
|
|
88
|
-
// Routes
|
|
89
|
-
agentRoutes(app, dataDir);
|
|
90
|
-
sessionRoutes(app, coordinator, dataDir);
|
|
91
|
-
fileRoutes(app, coordinator, dataDir);
|
|
92
|
-
healthRoutes(app, coordinator, pool);
|
|
93
|
-
runnerRoutes(app, coordinator);
|
|
94
|
-
coordinator.startLivenessSweep();
|
|
95
27
|
// Graceful shutdown
|
|
96
|
-
async
|
|
97
|
-
|
|
98
|
-
coordinator.stopLivenessSweep();
|
|
99
|
-
if (pool) {
|
|
100
|
-
pool.stopIdleSweep();
|
|
101
|
-
await pool.destroyAll();
|
|
102
|
-
}
|
|
103
|
-
await closeDb();
|
|
104
|
-
await app.close();
|
|
105
|
-
process.exit(0);
|
|
106
|
-
}
|
|
107
|
-
process.on('SIGTERM', shutdown);
|
|
108
|
-
process.on('SIGINT', shutdown);
|
|
28
|
+
process.on('SIGTERM', async () => { await shutdown(); process.exit(0); });
|
|
29
|
+
process.on('SIGINT', async () => { await shutdown(); process.exit(0); });
|
|
109
30
|
// Start
|
|
110
31
|
try {
|
|
111
32
|
await app.listen({ port, host });
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import type { QueueItem } from '@ash-ai/shared';
|
|
2
|
+
export interface QueueProcessorConfig {
|
|
3
|
+
/** Milliseconds between poll cycles (default: 1000). */
|
|
4
|
+
pollIntervalMs?: number;
|
|
5
|
+
/** Maximum retry count per item (default: 3). */
|
|
6
|
+
maxRetries?: number;
|
|
7
|
+
/** Base delay between retries in ms — actual delay = base * 2^retryCount (default: 5000). */
|
|
8
|
+
retryDelayMs?: number;
|
|
9
|
+
/** Limit processing to a specific tenantId (omit for all tenants). */
|
|
10
|
+
tenantId?: string;
|
|
11
|
+
}
|
|
12
|
+
export interface QueueProcessorCallbacks {
|
|
13
|
+
/**
|
|
14
|
+
* Called when a queue item is ready to be processed.
|
|
15
|
+
* The implementation should send the prompt to the appropriate session/agent.
|
|
16
|
+
* Throw an error to trigger retry logic.
|
|
17
|
+
*/
|
|
18
|
+
process(item: QueueItem): Promise<void>;
|
|
19
|
+
/** Called when an item has permanently failed after all retries. */
|
|
20
|
+
onFailed?(item: QueueItem, error: string): void;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* QueueProcessor polls the DB for pending queue items and dispatches them
|
|
24
|
+
* via a user-supplied callback. It handles retries with exponential backoff
|
|
25
|
+
* and lifecycle status transitions (pending → processing → completed/failed).
|
|
26
|
+
*
|
|
27
|
+
* Design notes:
|
|
28
|
+
* - Atomic claim: SELECT candidate, then UPDATE ... WHERE status='pending'
|
|
29
|
+
* with affected-row check. If another processor claimed it first, we skip.
|
|
30
|
+
* - Backoff via retryAfter timestamp on the DB row. Items with a future
|
|
31
|
+
* retryAfter are invisible to getNextPendingQueueItem until the time passes.
|
|
32
|
+
* - Backoff is capped at 5 minutes to prevent unbounded delays.
|
|
33
|
+
* - The processor is intentionally single-threaded per instance — horizontal
|
|
34
|
+
* scaling is achieved by running multiple server instances (DB serializes).
|
|
35
|
+
*/
|
|
36
|
+
export declare class QueueProcessor {
|
|
37
|
+
private callbacks;
|
|
38
|
+
private timer;
|
|
39
|
+
private processing;
|
|
40
|
+
private stopped;
|
|
41
|
+
private readonly pollIntervalMs;
|
|
42
|
+
private readonly maxRetries;
|
|
43
|
+
private readonly retryDelayMs;
|
|
44
|
+
private readonly tenantId?;
|
|
45
|
+
constructor(callbacks: QueueProcessorCallbacks, config?: QueueProcessorConfig);
|
|
46
|
+
start(): void;
|
|
47
|
+
stop(): void;
|
|
48
|
+
get isRunning(): boolean;
|
|
49
|
+
private poll;
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=processor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"processor.d.ts","sourceRoot":"","sources":["../../src/queue/processor.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAGhD,MAAM,WAAW,oBAAoB;IACnC,wDAAwD;IACxD,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,iDAAiD;IACjD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,6FAA6F;IAC7F,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,sEAAsE;IACtE,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,uBAAuB;IACtC;;;;OAIG;IACH,OAAO,CAAC,IAAI,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACxC,oEAAoE;IACpE,QAAQ,CAAC,CAAC,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;CACjD;AAED;;;;;;;;;;;;;GAaG;AACH,qBAAa,cAAc;IAWvB,OAAO,CAAC,SAAS;IAVnB,OAAO,CAAC,KAAK,CAA+C;IAC5D,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,OAAO,CAAS;IAExB,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAS;gBAGzB,SAAS,EAAE,uBAAuB,EAC1C,MAAM,GAAE,oBAAyB;IAQnC,KAAK,IAAI,IAAI;IAQb,IAAI,IAAI,IAAI;IAQZ,IAAI,SAAS,IAAI,OAAO,CAEvB;YAEa,IAAI;CA6CnB"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { getNextPendingQueueItem, claimQueueItem, updateQueueItemStatus, incrementQueueItemRetry, getQueueItem } from '../db/index.js';
|
|
2
|
+
/**
|
|
3
|
+
* QueueProcessor polls the DB for pending queue items and dispatches them
|
|
4
|
+
* via a user-supplied callback. It handles retries with exponential backoff
|
|
5
|
+
* and lifecycle status transitions (pending → processing → completed/failed).
|
|
6
|
+
*
|
|
7
|
+
* Design notes:
|
|
8
|
+
* - Atomic claim: SELECT candidate, then UPDATE ... WHERE status='pending'
|
|
9
|
+
* with affected-row check. If another processor claimed it first, we skip.
|
|
10
|
+
* - Backoff via retryAfter timestamp on the DB row. Items with a future
|
|
11
|
+
* retryAfter are invisible to getNextPendingQueueItem until the time passes.
|
|
12
|
+
* - Backoff is capped at 5 minutes to prevent unbounded delays.
|
|
13
|
+
* - The processor is intentionally single-threaded per instance — horizontal
|
|
14
|
+
* scaling is achieved by running multiple server instances (DB serializes).
|
|
15
|
+
*/
|
|
16
|
+
export class QueueProcessor {
|
|
17
|
+
callbacks;
|
|
18
|
+
timer = null;
|
|
19
|
+
processing = false;
|
|
20
|
+
stopped = false;
|
|
21
|
+
pollIntervalMs;
|
|
22
|
+
maxRetries;
|
|
23
|
+
retryDelayMs;
|
|
24
|
+
tenantId;
|
|
25
|
+
constructor(callbacks, config = {}) {
|
|
26
|
+
this.callbacks = callbacks;
|
|
27
|
+
this.pollIntervalMs = config.pollIntervalMs ?? 1000;
|
|
28
|
+
this.maxRetries = config.maxRetries ?? 3;
|
|
29
|
+
this.retryDelayMs = config.retryDelayMs ?? 5000;
|
|
30
|
+
this.tenantId = config.tenantId;
|
|
31
|
+
}
|
|
32
|
+
start() {
|
|
33
|
+
if (this.timer)
|
|
34
|
+
return;
|
|
35
|
+
this.stopped = false;
|
|
36
|
+
this.timer = setInterval(() => this.poll(), this.pollIntervalMs);
|
|
37
|
+
// Immediately attempt a poll on start
|
|
38
|
+
this.poll();
|
|
39
|
+
}
|
|
40
|
+
stop() {
|
|
41
|
+
this.stopped = true;
|
|
42
|
+
if (this.timer) {
|
|
43
|
+
clearInterval(this.timer);
|
|
44
|
+
this.timer = null;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
get isRunning() {
|
|
48
|
+
return this.timer !== null;
|
|
49
|
+
}
|
|
50
|
+
async poll() {
|
|
51
|
+
// Guard against overlapping polls and post-stop execution
|
|
52
|
+
if (this.processing || this.stopped)
|
|
53
|
+
return;
|
|
54
|
+
this.processing = true;
|
|
55
|
+
try {
|
|
56
|
+
const item = await getNextPendingQueueItem(this.tenantId);
|
|
57
|
+
if (!item)
|
|
58
|
+
return;
|
|
59
|
+
// Atomic claim: only one processor can transition pending → processing
|
|
60
|
+
const claimed = await claimQueueItem(item.id);
|
|
61
|
+
if (!claimed)
|
|
62
|
+
return; // Another processor got it first
|
|
63
|
+
try {
|
|
64
|
+
await this.callbacks.process(item);
|
|
65
|
+
await updateQueueItemStatus(item.id, 'completed');
|
|
66
|
+
}
|
|
67
|
+
catch (err) {
|
|
68
|
+
const errorMsg = err instanceof Error ? err.message : String(err);
|
|
69
|
+
// Re-read to get the updated retryCount
|
|
70
|
+
const updated = await getQueueItem(item.id);
|
|
71
|
+
const retryCount = (updated?.retryCount ?? item.retryCount) + 1;
|
|
72
|
+
const maxRetries = item.maxRetries ?? this.maxRetries;
|
|
73
|
+
if (retryCount >= maxRetries) {
|
|
74
|
+
// Permanently failed — increment retry count and mark failed
|
|
75
|
+
await incrementQueueItemRetry(item.id);
|
|
76
|
+
await updateQueueItemStatus(item.id, 'failed', errorMsg);
|
|
77
|
+
this.callbacks.onFailed?.(item, errorMsg);
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
// Compute backoff delay and set retryAfter timestamp on the DB row
|
|
81
|
+
const delay = Math.min(this.retryDelayMs * Math.pow(2, retryCount - 1), 5 * 60 * 1000);
|
|
82
|
+
const retryAfter = new Date(Date.now() + delay).toISOString();
|
|
83
|
+
await incrementQueueItemRetry(item.id, retryAfter);
|
|
84
|
+
// Return to pending — it won't be picked up until retryAfter has passed
|
|
85
|
+
await updateQueueItemStatus(item.id, 'pending', errorMsg);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
catch (err) {
|
|
90
|
+
// DB-level failure — log and continue polling
|
|
91
|
+
console.error('[queue-processor] Poll error:', err);
|
|
92
|
+
}
|
|
93
|
+
finally {
|
|
94
|
+
this.processing = false;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
//# sourceMappingURL=processor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"processor.js","sourceRoot":"","sources":["../../src/queue/processor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"attachments.d.ts","sourceRoot":"","sources":["../../src/routes/attachments.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAqB/C,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,eAAe,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI,CAyK5E"}
|