@agentlensai/server 0.8.0 → 0.10.0
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/db/anonymous-id-manager.d.ts +44 -0
- package/dist/db/anonymous-id-manager.d.ts.map +1 -0
- package/dist/db/anonymous-id-manager.js +90 -0
- package/dist/db/anonymous-id-manager.js.map +1 -0
- package/dist/db/capability-store.d.ts +82 -0
- package/dist/db/capability-store.d.ts.map +1 -0
- package/dist/db/capability-store.js +221 -0
- package/dist/db/capability-store.js.map +1 -0
- package/dist/db/migrate.d.ts.map +1 -1
- package/dist/db/migrate.js +136 -0
- package/dist/db/migrate.js.map +1 -1
- package/dist/db/schema.sqlite.d.ts +1663 -2
- package/dist/db/schema.sqlite.d.ts.map +1 -1
- package/dist/db/schema.sqlite.js +135 -1
- package/dist/db/schema.sqlite.js.map +1 -1
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +48 -0
- package/dist/index.js.map +1 -1
- package/dist/lib/redaction/human-review-layer.d.ts +37 -0
- package/dist/lib/redaction/human-review-layer.d.ts.map +1 -0
- package/dist/lib/redaction/human-review-layer.js +62 -0
- package/dist/lib/redaction/human-review-layer.js.map +1 -0
- package/dist/lib/redaction/index.d.ts +12 -0
- package/dist/lib/redaction/index.d.ts.map +1 -0
- package/dist/lib/redaction/index.js +12 -0
- package/dist/lib/redaction/index.js.map +1 -0
- package/dist/lib/redaction/pii-detection-layer.d.ts +30 -0
- package/dist/lib/redaction/pii-detection-layer.d.ts.map +1 -0
- package/dist/lib/redaction/pii-detection-layer.js +183 -0
- package/dist/lib/redaction/pii-detection-layer.js.map +1 -0
- package/dist/lib/redaction/pipeline.d.ts +26 -0
- package/dist/lib/redaction/pipeline.d.ts.map +1 -0
- package/dist/lib/redaction/pipeline.js +91 -0
- package/dist/lib/redaction/pipeline.js.map +1 -0
- package/dist/lib/redaction/secret-detection-layer.d.ts +10 -0
- package/dist/lib/redaction/secret-detection-layer.d.ts.map +1 -0
- package/dist/lib/redaction/secret-detection-layer.js +79 -0
- package/dist/lib/redaction/secret-detection-layer.js.map +1 -0
- package/dist/lib/redaction/secret-patterns.d.ts +29 -0
- package/dist/lib/redaction/secret-patterns.d.ts.map +1 -0
- package/dist/lib/redaction/secret-patterns.js +133 -0
- package/dist/lib/redaction/secret-patterns.js.map +1 -0
- package/dist/lib/redaction/semantic-denylist-layer.d.ts +10 -0
- package/dist/lib/redaction/semantic-denylist-layer.d.ts.map +1 -0
- package/dist/lib/redaction/semantic-denylist-layer.js +64 -0
- package/dist/lib/redaction/semantic-denylist-layer.js.map +1 -0
- package/dist/lib/redaction/tenant-deidentification-layer.d.ts +10 -0
- package/dist/lib/redaction/tenant-deidentification-layer.d.ts.map +1 -0
- package/dist/lib/redaction/tenant-deidentification-layer.js +64 -0
- package/dist/lib/redaction/tenant-deidentification-layer.js.map +1 -0
- package/dist/lib/redaction/url-path-scrubbing-layer.d.ts +14 -0
- package/dist/lib/redaction/url-path-scrubbing-layer.d.ts.map +1 -0
- package/dist/lib/redaction/url-path-scrubbing-layer.js +156 -0
- package/dist/lib/redaction/url-path-scrubbing-layer.js.map +1 -0
- package/dist/routes/agents.d.ts.map +1 -1
- package/dist/routes/agents.js +3 -9
- package/dist/routes/agents.js.map +1 -1
- package/dist/routes/audit.d.ts +15 -0
- package/dist/routes/audit.d.ts.map +1 -0
- package/dist/routes/audit.js +177 -0
- package/dist/routes/audit.js.map +1 -0
- package/dist/routes/capabilities-top.d.ts +15 -0
- package/dist/routes/capabilities-top.d.ts.map +1 -0
- package/dist/routes/capabilities-top.js +77 -0
- package/dist/routes/capabilities-top.js.map +1 -0
- package/dist/routes/capabilities.d.ts +15 -0
- package/dist/routes/capabilities.d.ts.map +1 -0
- package/dist/routes/capabilities.js +86 -0
- package/dist/routes/capabilities.js.map +1 -0
- package/dist/routes/community.d.ts +24 -0
- package/dist/routes/community.d.ts.map +1 -0
- package/dist/routes/community.js +272 -0
- package/dist/routes/community.js.map +1 -0
- package/dist/routes/delegation.d.ts +20 -0
- package/dist/routes/delegation.d.ts.map +1 -0
- package/dist/routes/delegation.js +108 -0
- package/dist/routes/delegation.js.map +1 -0
- package/dist/routes/delegations-top.d.ts +12 -0
- package/dist/routes/delegations-top.d.ts.map +1 -0
- package/dist/routes/delegations-top.js +43 -0
- package/dist/routes/delegations-top.js.map +1 -0
- package/dist/routes/discovery.d.ts +19 -0
- package/dist/routes/discovery.d.ts.map +1 -0
- package/dist/routes/discovery.js +96 -0
- package/dist/routes/discovery.js.map +1 -0
- package/dist/routes/redaction-test.d.ts +14 -0
- package/dist/routes/redaction-test.d.ts.map +1 -0
- package/dist/routes/redaction-test.js +33 -0
- package/dist/routes/redaction-test.js.map +1 -0
- package/dist/routes/trust.d.ts +16 -0
- package/dist/routes/trust.d.ts.map +1 -0
- package/dist/routes/trust.js +23 -0
- package/dist/routes/trust.js.map +1 -0
- package/dist/services/community-service.d.ts +283 -0
- package/dist/services/community-service.d.ts.map +1 -0
- package/dist/services/community-service.js +816 -0
- package/dist/services/community-service.js.map +1 -0
- package/dist/services/delegation-service.d.ts +149 -0
- package/dist/services/delegation-service.d.ts.map +1 -0
- package/dist/services/delegation-service.js +605 -0
- package/dist/services/delegation-service.js.map +1 -0
- package/dist/services/discovery-service.d.ts +39 -0
- package/dist/services/discovery-service.d.ts.map +1 -0
- package/dist/services/discovery-service.js +186 -0
- package/dist/services/discovery-service.js.map +1 -0
- package/dist/services/trust-service.d.ts +59 -0
- package/dist/services/trust-service.d.ts.map +1 -0
- package/dist/services/trust-service.js +139 -0
- package/dist/services/trust-service.js.map +1 -0
- package/package.json +2 -2
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Delegation REST API (Stories 6.1 + 6.2)
|
|
3
|
+
*
|
|
4
|
+
* POST /api/agents/delegate — send a delegation request (outbound)
|
|
5
|
+
* GET /api/agents/:id/delegations/inbox — poll for pending requests (inbound)
|
|
6
|
+
* POST /api/agents/:id/delegations/:requestId/accept — accept a delegation
|
|
7
|
+
* POST /api/agents/:id/delegations/:requestId/reject — reject a delegation
|
|
8
|
+
* POST /api/agents/:id/delegations/:requestId/complete — complete with result
|
|
9
|
+
*/
|
|
10
|
+
import { Hono } from 'hono';
|
|
11
|
+
import { DelegationService } from '../services/delegation-service.js';
|
|
12
|
+
import { TASK_TYPES } from '@agentlensai/core';
|
|
13
|
+
const VALID_TASK_TYPES = new Set(TASK_TYPES);
|
|
14
|
+
export function delegationRoutes(db, transport) {
|
|
15
|
+
const app = new Hono();
|
|
16
|
+
const service = new DelegationService(db, transport);
|
|
17
|
+
function getTenantId(c) {
|
|
18
|
+
return c.get('apiKey')?.tenantId ?? 'default';
|
|
19
|
+
}
|
|
20
|
+
// POST /delegate — send a delegation request (outbound)
|
|
21
|
+
app.post('/delegate', async (c) => {
|
|
22
|
+
const tenantId = getTenantId(c);
|
|
23
|
+
let body;
|
|
24
|
+
try {
|
|
25
|
+
body = await c.req.json();
|
|
26
|
+
}
|
|
27
|
+
catch {
|
|
28
|
+
return c.json({ error: 'Invalid JSON body', status: 400 }, 400);
|
|
29
|
+
}
|
|
30
|
+
const agentId = body.agentId;
|
|
31
|
+
if (!agentId) {
|
|
32
|
+
return c.json({ error: 'agentId is required', status: 400 }, 400);
|
|
33
|
+
}
|
|
34
|
+
const targetAnonymousId = body.targetAnonymousId;
|
|
35
|
+
if (!targetAnonymousId) {
|
|
36
|
+
return c.json({ error: 'targetAnonymousId is required', status: 400 }, 400);
|
|
37
|
+
}
|
|
38
|
+
const taskType = body.taskType;
|
|
39
|
+
if (!taskType || !VALID_TASK_TYPES.has(taskType)) {
|
|
40
|
+
return c.json({ error: 'taskType is required and must be valid', status: 400 }, 400);
|
|
41
|
+
}
|
|
42
|
+
const result = await service.delegate(tenantId, agentId, {
|
|
43
|
+
targetAnonymousId,
|
|
44
|
+
taskType: taskType,
|
|
45
|
+
input: body.input,
|
|
46
|
+
timeoutMs: body.timeoutMs ?? 30000,
|
|
47
|
+
fallbackEnabled: body.fallbackEnabled,
|
|
48
|
+
maxRetries: body.maxRetries,
|
|
49
|
+
});
|
|
50
|
+
return c.json({ result });
|
|
51
|
+
});
|
|
52
|
+
// GET /:id/delegations/inbox — poll for pending requests
|
|
53
|
+
app.get('/:id/delegations/inbox', async (c) => {
|
|
54
|
+
const tenantId = getTenantId(c);
|
|
55
|
+
const agentId = c.req.param('id');
|
|
56
|
+
const inbox = await service.getInbox(tenantId, agentId);
|
|
57
|
+
return c.json({ requests: inbox, total: inbox.length });
|
|
58
|
+
});
|
|
59
|
+
// POST /:id/delegations/:requestId/accept
|
|
60
|
+
app.post('/:id/delegations/:requestId/accept', async (c) => {
|
|
61
|
+
const tenantId = getTenantId(c);
|
|
62
|
+
const agentId = c.req.param('id');
|
|
63
|
+
const requestId = c.req.param('requestId');
|
|
64
|
+
const result = await service.acceptDelegation(tenantId, agentId, requestId);
|
|
65
|
+
if (!result.ok) {
|
|
66
|
+
return c.json({ error: result.error, status: 400 }, 400);
|
|
67
|
+
}
|
|
68
|
+
return c.json({ accepted: true });
|
|
69
|
+
});
|
|
70
|
+
// POST /:id/delegations/:requestId/reject
|
|
71
|
+
app.post('/:id/delegations/:requestId/reject', async (c) => {
|
|
72
|
+
const tenantId = getTenantId(c);
|
|
73
|
+
const agentId = c.req.param('id');
|
|
74
|
+
const requestId = c.req.param('requestId');
|
|
75
|
+
let body = {};
|
|
76
|
+
try {
|
|
77
|
+
body = await c.req.json();
|
|
78
|
+
}
|
|
79
|
+
catch {
|
|
80
|
+
// Body is optional for reject
|
|
81
|
+
}
|
|
82
|
+
const result = await service.rejectDelegation(tenantId, agentId, requestId, body.reason);
|
|
83
|
+
if (!result.ok) {
|
|
84
|
+
return c.json({ error: result.error, status: 400 }, 400);
|
|
85
|
+
}
|
|
86
|
+
return c.json({ rejected: true });
|
|
87
|
+
});
|
|
88
|
+
// POST /:id/delegations/:requestId/complete
|
|
89
|
+
app.post('/:id/delegations/:requestId/complete', async (c) => {
|
|
90
|
+
const tenantId = getTenantId(c);
|
|
91
|
+
const agentId = c.req.param('id');
|
|
92
|
+
const requestId = c.req.param('requestId');
|
|
93
|
+
let body;
|
|
94
|
+
try {
|
|
95
|
+
body = await c.req.json();
|
|
96
|
+
}
|
|
97
|
+
catch {
|
|
98
|
+
return c.json({ error: 'Invalid JSON body', status: 400 }, 400);
|
|
99
|
+
}
|
|
100
|
+
const result = await service.completeDelegation(tenantId, agentId, requestId, body.output);
|
|
101
|
+
if (!result.ok) {
|
|
102
|
+
return c.json({ error: result.error, status: 400 }, 400);
|
|
103
|
+
}
|
|
104
|
+
return c.json({ completed: true });
|
|
105
|
+
});
|
|
106
|
+
return { app, service };
|
|
107
|
+
}
|
|
108
|
+
//# sourceMappingURL=delegation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delegation.js","sourceRoot":"","sources":["../../src/routes/delegation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Top-level Delegation Log Routes (dashboard-facing)
|
|
3
|
+
*
|
|
4
|
+
* GET /api/delegations — list all delegation log entries with filters
|
|
5
|
+
*/
|
|
6
|
+
import { Hono } from 'hono';
|
|
7
|
+
import type { AuthVariables } from '../middleware/auth.js';
|
|
8
|
+
import type { SqliteDb } from '../db/index.js';
|
|
9
|
+
export declare function delegationTopRoutes(db: SqliteDb): Hono<{
|
|
10
|
+
Variables: AuthVariables;
|
|
11
|
+
}, import("hono/types").BlankSchema, "/">;
|
|
12
|
+
//# sourceMappingURL=delegations-top.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delegations-top.d.ts","sourceRoot":"","sources":["../../src/routes/delegations-top.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAE5B,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAG/C,wBAAgB,mBAAmB,CAAC,EAAE,EAAE,QAAQ;eACZ,aAAa;0CAmChD"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Top-level Delegation Log Routes (dashboard-facing)
|
|
3
|
+
*
|
|
4
|
+
* GET /api/delegations — list all delegation log entries with filters
|
|
5
|
+
*/
|
|
6
|
+
import { Hono } from 'hono';
|
|
7
|
+
import { eq } from 'drizzle-orm';
|
|
8
|
+
import * as schema from '../db/schema.sqlite.js';
|
|
9
|
+
export function delegationTopRoutes(db) {
|
|
10
|
+
const app = new Hono();
|
|
11
|
+
function getTenantId(c) {
|
|
12
|
+
return c.get('apiKey')?.tenantId ?? 'default';
|
|
13
|
+
}
|
|
14
|
+
// GET / — list delegation log entries
|
|
15
|
+
app.get('/', async (c) => {
|
|
16
|
+
const tenantId = getTenantId(c);
|
|
17
|
+
const direction = c.req.query('direction') || undefined;
|
|
18
|
+
const status = c.req.query('status') || undefined;
|
|
19
|
+
const from = c.req.query('from') || undefined;
|
|
20
|
+
const to = c.req.query('to') || undefined;
|
|
21
|
+
const limitStr = c.req.query('limit');
|
|
22
|
+
const limit = limitStr ? Math.min(Math.max(1, parseInt(limitStr, 10) || 100), 500) : 100;
|
|
23
|
+
let rows = db
|
|
24
|
+
.select()
|
|
25
|
+
.from(schema.delegationLog)
|
|
26
|
+
.where(eq(schema.delegationLog.tenantId, tenantId))
|
|
27
|
+
.all();
|
|
28
|
+
if (direction)
|
|
29
|
+
rows = rows.filter((r) => r.direction === direction);
|
|
30
|
+
if (status)
|
|
31
|
+
rows = rows.filter((r) => r.status === status);
|
|
32
|
+
if (from)
|
|
33
|
+
rows = rows.filter((r) => r.createdAt >= from);
|
|
34
|
+
if (to)
|
|
35
|
+
rows = rows.filter((r) => r.createdAt <= to);
|
|
36
|
+
rows.sort((a, b) => b.createdAt.localeCompare(a.createdAt));
|
|
37
|
+
const total = rows.length;
|
|
38
|
+
const paged = rows.slice(0, limit);
|
|
39
|
+
return c.json({ delegations: paged, total });
|
|
40
|
+
});
|
|
41
|
+
return app;
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=delegations-top.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delegations-top.js","sourceRoot":"","sources":["../../src/routes/delegations-top.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAC5B,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AAGjC,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAC;AAEjD,MAAM,UAAU,mBAAmB,CAAC,EAAY;IAC9C,MAAM,GAAG,GAAG,IAAI,IAAI,EAAgC,CAAC;IAErD,SAAS,WAAW,CAAC,CAA4D;QAC/E,OAAO,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,QAAQ,IAAI,SAAS,CAAC;IAChD,CAAC;IAED,sCAAsC;IACtC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;QACvB,MAAM,QAAQ,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;QAChC,MAAM,SAAS,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,SAAS,CAAC;QACxD,MAAM,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,SAAS,CAAC;QAClD,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,SAAS,CAAC;QAC9C,MAAM,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,SAAS,CAAC;QAC1C,MAAM,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACtC,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,QAAQ,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;QAEzF,IAAI,IAAI,GAAG,EAAE;aACV,MAAM,EAAE;aACR,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC;aAC1B,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;aAClD,GAAG,EAAE,CAAC;QAET,IAAI,SAAS;YAAE,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,SAAS,CAAC,CAAC;QACpE,IAAI,MAAM;YAAE,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC;QAC3D,IAAI,IAAI;YAAE,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,IAAI,IAAI,CAAC,CAAC;QACzD,IAAI,EAAE;YAAE,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC;QAErD,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;QAC5D,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;QAEnC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,WAAW,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,OAAO,GAAG,CAAC;AACb,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Discovery REST API (Story 5.3 + 5.4)
|
|
3
|
+
*
|
|
4
|
+
* GET /api/agents/discover — discover capabilities
|
|
5
|
+
* PUT /api/agents/discovery/config — update tenant discovery config
|
|
6
|
+
* GET /api/agents/discovery/config — get tenant discovery config
|
|
7
|
+
* PUT /api/agents/capabilities/:capabilityId/permissions — update per-agent permissions
|
|
8
|
+
*/
|
|
9
|
+
import { Hono } from 'hono';
|
|
10
|
+
import type { AuthVariables } from '../middleware/auth.js';
|
|
11
|
+
import type { SqliteDb } from '../db/index.js';
|
|
12
|
+
import { DiscoveryService } from '../services/discovery-service.js';
|
|
13
|
+
export declare function discoveryRoutes(db: SqliteDb): {
|
|
14
|
+
app: Hono<{
|
|
15
|
+
Variables: AuthVariables;
|
|
16
|
+
}, import("hono/types").BlankSchema, "/">;
|
|
17
|
+
service: DiscoveryService;
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=discovery.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"discovery.d.ts","sourceRoot":"","sources":["../../src/routes/discovery.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAC5B,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AAKpE,wBAAgB,eAAe,CAAC,EAAE,EAAE,QAAQ;;mBACR,aAAa;;;EA0FhD"}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Discovery REST API (Story 5.3 + 5.4)
|
|
3
|
+
*
|
|
4
|
+
* GET /api/agents/discover — discover capabilities
|
|
5
|
+
* PUT /api/agents/discovery/config — update tenant discovery config
|
|
6
|
+
* GET /api/agents/discovery/config — get tenant discovery config
|
|
7
|
+
* PUT /api/agents/capabilities/:capabilityId/permissions — update per-agent permissions
|
|
8
|
+
*/
|
|
9
|
+
import { Hono } from 'hono';
|
|
10
|
+
import { DiscoveryService } from '../services/discovery-service.js';
|
|
11
|
+
import { TASK_TYPES } from '@agentlensai/core';
|
|
12
|
+
const VALID_TASK_TYPES = new Set(TASK_TYPES);
|
|
13
|
+
export function discoveryRoutes(db) {
|
|
14
|
+
const app = new Hono();
|
|
15
|
+
const service = new DiscoveryService(db);
|
|
16
|
+
function getTenantId(c) {
|
|
17
|
+
return c.get('apiKey')?.tenantId ?? 'default';
|
|
18
|
+
}
|
|
19
|
+
// GET /discover — discover capabilities
|
|
20
|
+
app.get('/discover', async (c) => {
|
|
21
|
+
const tenantId = getTenantId(c);
|
|
22
|
+
const taskType = c.req.query('taskType');
|
|
23
|
+
if (!taskType || !VALID_TASK_TYPES.has(taskType)) {
|
|
24
|
+
return c.json({ error: 'taskType is required and must be a valid TaskType', status: 400 }, 400);
|
|
25
|
+
}
|
|
26
|
+
const query = {
|
|
27
|
+
taskType: taskType,
|
|
28
|
+
customType: c.req.query('customType') || undefined,
|
|
29
|
+
minTrustScore: c.req.query('minTrust') ? Number(c.req.query('minTrust')) : undefined,
|
|
30
|
+
maxCostUsd: c.req.query('maxCost') ? Number(c.req.query('maxCost')) : undefined,
|
|
31
|
+
maxLatencyMs: c.req.query('maxLatency') ? Number(c.req.query('maxLatency')) : undefined,
|
|
32
|
+
scope: 'internal', // Only internal for now (B3)
|
|
33
|
+
limit: c.req.query('limit') ? Math.min(Number(c.req.query('limit')), 20) : 20,
|
|
34
|
+
};
|
|
35
|
+
const results = service.discover(tenantId, query);
|
|
36
|
+
return c.json({ results, total: results.length });
|
|
37
|
+
});
|
|
38
|
+
// GET /discovery/config — get tenant discovery config
|
|
39
|
+
app.get('/discovery/config', async (c) => {
|
|
40
|
+
const tenantId = getTenantId(c);
|
|
41
|
+
const config = service.getDiscoveryConfig(tenantId);
|
|
42
|
+
return c.json({ config });
|
|
43
|
+
});
|
|
44
|
+
// PUT /discovery/config — update tenant discovery config
|
|
45
|
+
app.put('/discovery/config', async (c) => {
|
|
46
|
+
const tenantId = getTenantId(c);
|
|
47
|
+
let body;
|
|
48
|
+
try {
|
|
49
|
+
body = await c.req.json();
|
|
50
|
+
}
|
|
51
|
+
catch {
|
|
52
|
+
return c.json({ error: 'Invalid JSON body', status: 400 }, 400);
|
|
53
|
+
}
|
|
54
|
+
const updates = {};
|
|
55
|
+
if (body.minTrustThreshold !== undefined) {
|
|
56
|
+
const val = Number(body.minTrustThreshold);
|
|
57
|
+
if (isNaN(val) || val < 0 || val > 100) {
|
|
58
|
+
return c.json({ error: 'minTrustThreshold must be 0-100', status: 400 }, 400);
|
|
59
|
+
}
|
|
60
|
+
updates.minTrustThreshold = val;
|
|
61
|
+
}
|
|
62
|
+
if (body.delegationEnabled !== undefined) {
|
|
63
|
+
updates.delegationEnabled = Boolean(body.delegationEnabled);
|
|
64
|
+
}
|
|
65
|
+
const config = service.updateDiscoveryConfig(tenantId, updates);
|
|
66
|
+
return c.json({ config });
|
|
67
|
+
});
|
|
68
|
+
// PUT /capabilities/:capabilityId/permissions — update per-agent permissions
|
|
69
|
+
app.put('/capabilities/:capabilityId/permissions', async (c) => {
|
|
70
|
+
const tenantId = getTenantId(c);
|
|
71
|
+
const capabilityId = c.req.param('capabilityId');
|
|
72
|
+
let body;
|
|
73
|
+
try {
|
|
74
|
+
body = await c.req.json();
|
|
75
|
+
}
|
|
76
|
+
catch {
|
|
77
|
+
return c.json({ error: 'Invalid JSON body', status: 400 }, 400);
|
|
78
|
+
}
|
|
79
|
+
const updates = {};
|
|
80
|
+
if (body.enabled !== undefined)
|
|
81
|
+
updates.enabled = Boolean(body.enabled);
|
|
82
|
+
if (body.acceptDelegations !== undefined)
|
|
83
|
+
updates.acceptDelegations = Boolean(body.acceptDelegations);
|
|
84
|
+
if (body.inboundRateLimit !== undefined)
|
|
85
|
+
updates.inboundRateLimit = Number(body.inboundRateLimit);
|
|
86
|
+
if (body.outboundRateLimit !== undefined)
|
|
87
|
+
updates.outboundRateLimit = Number(body.outboundRateLimit);
|
|
88
|
+
const ok = service.updateAgentPermissions(tenantId, capabilityId, updates);
|
|
89
|
+
if (!ok) {
|
|
90
|
+
return c.json({ error: 'Capability not found', status: 404 }, 404);
|
|
91
|
+
}
|
|
92
|
+
return c.json({ updated: true });
|
|
93
|
+
});
|
|
94
|
+
return { app, service };
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=discovery.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"discovery.js","sourceRoot":"","sources":["../../src/routes/discovery.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Redaction Test Endpoint (Story 2.4)
|
|
3
|
+
*
|
|
4
|
+
* POST /api/community/redaction/test
|
|
5
|
+
* Accepts raw content, runs it through the redaction pipeline,
|
|
6
|
+
* and returns the redacted output WITHOUT sharing.
|
|
7
|
+
* For testing/debugging purposes only.
|
|
8
|
+
*/
|
|
9
|
+
import { Hono } from 'hono';
|
|
10
|
+
import type { AuthVariables } from '../middleware/auth.js';
|
|
11
|
+
export declare function redactionTestRoutes(): Hono<{
|
|
12
|
+
Variables: AuthVariables;
|
|
13
|
+
}, import("hono/types").BlankSchema, "/">;
|
|
14
|
+
//# sourceMappingURL=redaction-test.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redaction-test.d.ts","sourceRoot":"","sources":["../../src/routes/redaction-test.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAC5B,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAK3D,wBAAgB,mBAAmB;eACC,aAAa;0CAsChD"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Redaction Test Endpoint (Story 2.4)
|
|
3
|
+
*
|
|
4
|
+
* POST /api/community/redaction/test
|
|
5
|
+
* Accepts raw content, runs it through the redaction pipeline,
|
|
6
|
+
* and returns the redacted output WITHOUT sharing.
|
|
7
|
+
* For testing/debugging purposes only.
|
|
8
|
+
*/
|
|
9
|
+
import { Hono } from 'hono';
|
|
10
|
+
import { RedactionPipeline } from '../lib/redaction/pipeline.js';
|
|
11
|
+
import { createRawLessonContent } from '@agentlensai/core';
|
|
12
|
+
export function redactionTestRoutes() {
|
|
13
|
+
const app = new Hono();
|
|
14
|
+
const pipeline = new RedactionPipeline();
|
|
15
|
+
app.post('/test', async (c) => {
|
|
16
|
+
const body = await c.req.json();
|
|
17
|
+
if (!body.content) {
|
|
18
|
+
return c.json({ error: 'content is required' }, 400);
|
|
19
|
+
}
|
|
20
|
+
const raw = createRawLessonContent(body.title ?? 'Test', body.content, body.context ?? {});
|
|
21
|
+
const redactionCtx = {
|
|
22
|
+
tenantId: body.tenantId ?? 'test',
|
|
23
|
+
agentId: body.agentId,
|
|
24
|
+
category: 'general',
|
|
25
|
+
denyListPatterns: body.denyListPatterns ?? [],
|
|
26
|
+
knownTenantTerms: body.knownTenantTerms ?? [],
|
|
27
|
+
};
|
|
28
|
+
const result = await pipeline.process(raw, redactionCtx);
|
|
29
|
+
return c.json(result);
|
|
30
|
+
});
|
|
31
|
+
return app;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=redaction-test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redaction-test.js","sourceRoot":"","sources":["../../src/routes/redaction-test.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAE5B,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAG3D,MAAM,UAAU,mBAAmB;IACjC,MAAM,GAAG,GAAG,IAAI,IAAI,EAAgC,CAAC;IACrD,MAAM,QAAQ,GAAG,IAAI,iBAAiB,EAAE,CAAC;IAEzC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;QAC5B,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,EAQzB,CAAC;QAEL,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,qBAAqB,EAAE,EAAE,GAAG,CAAC,CAAC;QACvD,CAAC;QAED,MAAM,GAAG,GAAG,sBAAsB,CAChC,IAAI,CAAC,KAAK,IAAI,MAAM,EACpB,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,OAAO,IAAI,EAAE,CACnB,CAAC;QAEF,MAAM,YAAY,GAAqB;YACrC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,MAAM;YACjC,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,QAAQ,EAAE,SAAS;YACnB,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,IAAI,EAAE;YAC7C,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,IAAI,EAAE;SAC9C,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;QAEzD,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACxB,CAAC,CAAC,CAAC;IAEH,OAAO,GAAG,CAAC;AACb,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Trust REST API (Story 6.3)
|
|
3
|
+
*
|
|
4
|
+
* GET /api/agents/:id/trust — get trust score for an agent
|
|
5
|
+
*/
|
|
6
|
+
import { Hono } from 'hono';
|
|
7
|
+
import type { AuthVariables } from '../middleware/auth.js';
|
|
8
|
+
import type { SqliteDb } from '../db/index.js';
|
|
9
|
+
import { TrustService } from '../services/trust-service.js';
|
|
10
|
+
export declare function trustRoutes(db: SqliteDb): {
|
|
11
|
+
app: Hono<{
|
|
12
|
+
Variables: AuthVariables;
|
|
13
|
+
}, import("hono/types").BlankSchema, "/">;
|
|
14
|
+
service: TrustService;
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=trust.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trust.d.ts","sourceRoot":"","sources":["../../src/routes/trust.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAC5B,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAE5D,wBAAgB,WAAW,CAAC,EAAE,EAAE,QAAQ;;mBACJ,aAAa;;;EAiBhD"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Trust REST API (Story 6.3)
|
|
3
|
+
*
|
|
4
|
+
* GET /api/agents/:id/trust — get trust score for an agent
|
|
5
|
+
*/
|
|
6
|
+
import { Hono } from 'hono';
|
|
7
|
+
import { TrustService } from '../services/trust-service.js';
|
|
8
|
+
export function trustRoutes(db) {
|
|
9
|
+
const app = new Hono();
|
|
10
|
+
const service = new TrustService(db);
|
|
11
|
+
function getTenantId(c) {
|
|
12
|
+
return c.get('apiKey')?.tenantId ?? 'default';
|
|
13
|
+
}
|
|
14
|
+
// GET /:id/trust — get trust score
|
|
15
|
+
app.get('/:id/trust', async (c) => {
|
|
16
|
+
const tenantId = getTenantId(c);
|
|
17
|
+
const agentId = c.req.param('id');
|
|
18
|
+
const score = service.getTrustScore(tenantId, agentId);
|
|
19
|
+
return c.json({ trust: score });
|
|
20
|
+
});
|
|
21
|
+
return { app, service };
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=trust.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trust.js","sourceRoot":"","sources":["../../src/routes/trust.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAG5B,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAE5D,MAAM,UAAU,WAAW,CAAC,EAAY;IACtC,MAAM,GAAG,GAAG,IAAI,IAAI,EAAgC,CAAC;IACrD,MAAM,OAAO,GAAG,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC;IAErC,SAAS,WAAW,CAAC,CAA4D;QAC/E,OAAO,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,QAAQ,IAAI,SAAS,CAAC;IAChD,CAAC;IAED,mCAAmC;IACnC,GAAG,CAAC,GAAG,CAAC,YAAY,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;QAChC,MAAM,QAAQ,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;QAChC,MAAM,OAAO,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAElC,MAAM,KAAK,GAAG,OAAO,CAAC,aAAa,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QACvD,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,OAAO,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC;AAC1B,CAAC"}
|