@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.
Files changed (111) hide show
  1. package/dist/db/anonymous-id-manager.d.ts +44 -0
  2. package/dist/db/anonymous-id-manager.d.ts.map +1 -0
  3. package/dist/db/anonymous-id-manager.js +90 -0
  4. package/dist/db/anonymous-id-manager.js.map +1 -0
  5. package/dist/db/capability-store.d.ts +82 -0
  6. package/dist/db/capability-store.d.ts.map +1 -0
  7. package/dist/db/capability-store.js +221 -0
  8. package/dist/db/capability-store.js.map +1 -0
  9. package/dist/db/migrate.d.ts.map +1 -1
  10. package/dist/db/migrate.js +136 -0
  11. package/dist/db/migrate.js.map +1 -1
  12. package/dist/db/schema.sqlite.d.ts +1663 -2
  13. package/dist/db/schema.sqlite.d.ts.map +1 -1
  14. package/dist/db/schema.sqlite.js +135 -1
  15. package/dist/db/schema.sqlite.js.map +1 -1
  16. package/dist/index.d.ts +5 -0
  17. package/dist/index.d.ts.map +1 -1
  18. package/dist/index.js +48 -0
  19. package/dist/index.js.map +1 -1
  20. package/dist/lib/redaction/human-review-layer.d.ts +37 -0
  21. package/dist/lib/redaction/human-review-layer.d.ts.map +1 -0
  22. package/dist/lib/redaction/human-review-layer.js +62 -0
  23. package/dist/lib/redaction/human-review-layer.js.map +1 -0
  24. package/dist/lib/redaction/index.d.ts +12 -0
  25. package/dist/lib/redaction/index.d.ts.map +1 -0
  26. package/dist/lib/redaction/index.js +12 -0
  27. package/dist/lib/redaction/index.js.map +1 -0
  28. package/dist/lib/redaction/pii-detection-layer.d.ts +30 -0
  29. package/dist/lib/redaction/pii-detection-layer.d.ts.map +1 -0
  30. package/dist/lib/redaction/pii-detection-layer.js +183 -0
  31. package/dist/lib/redaction/pii-detection-layer.js.map +1 -0
  32. package/dist/lib/redaction/pipeline.d.ts +26 -0
  33. package/dist/lib/redaction/pipeline.d.ts.map +1 -0
  34. package/dist/lib/redaction/pipeline.js +91 -0
  35. package/dist/lib/redaction/pipeline.js.map +1 -0
  36. package/dist/lib/redaction/secret-detection-layer.d.ts +10 -0
  37. package/dist/lib/redaction/secret-detection-layer.d.ts.map +1 -0
  38. package/dist/lib/redaction/secret-detection-layer.js +79 -0
  39. package/dist/lib/redaction/secret-detection-layer.js.map +1 -0
  40. package/dist/lib/redaction/secret-patterns.d.ts +29 -0
  41. package/dist/lib/redaction/secret-patterns.d.ts.map +1 -0
  42. package/dist/lib/redaction/secret-patterns.js +133 -0
  43. package/dist/lib/redaction/secret-patterns.js.map +1 -0
  44. package/dist/lib/redaction/semantic-denylist-layer.d.ts +10 -0
  45. package/dist/lib/redaction/semantic-denylist-layer.d.ts.map +1 -0
  46. package/dist/lib/redaction/semantic-denylist-layer.js +64 -0
  47. package/dist/lib/redaction/semantic-denylist-layer.js.map +1 -0
  48. package/dist/lib/redaction/tenant-deidentification-layer.d.ts +10 -0
  49. package/dist/lib/redaction/tenant-deidentification-layer.d.ts.map +1 -0
  50. package/dist/lib/redaction/tenant-deidentification-layer.js +64 -0
  51. package/dist/lib/redaction/tenant-deidentification-layer.js.map +1 -0
  52. package/dist/lib/redaction/url-path-scrubbing-layer.d.ts +14 -0
  53. package/dist/lib/redaction/url-path-scrubbing-layer.d.ts.map +1 -0
  54. package/dist/lib/redaction/url-path-scrubbing-layer.js +156 -0
  55. package/dist/lib/redaction/url-path-scrubbing-layer.js.map +1 -0
  56. package/dist/routes/agents.d.ts.map +1 -1
  57. package/dist/routes/agents.js +3 -9
  58. package/dist/routes/agents.js.map +1 -1
  59. package/dist/routes/audit.d.ts +15 -0
  60. package/dist/routes/audit.d.ts.map +1 -0
  61. package/dist/routes/audit.js +177 -0
  62. package/dist/routes/audit.js.map +1 -0
  63. package/dist/routes/capabilities-top.d.ts +15 -0
  64. package/dist/routes/capabilities-top.d.ts.map +1 -0
  65. package/dist/routes/capabilities-top.js +77 -0
  66. package/dist/routes/capabilities-top.js.map +1 -0
  67. package/dist/routes/capabilities.d.ts +15 -0
  68. package/dist/routes/capabilities.d.ts.map +1 -0
  69. package/dist/routes/capabilities.js +86 -0
  70. package/dist/routes/capabilities.js.map +1 -0
  71. package/dist/routes/community.d.ts +24 -0
  72. package/dist/routes/community.d.ts.map +1 -0
  73. package/dist/routes/community.js +272 -0
  74. package/dist/routes/community.js.map +1 -0
  75. package/dist/routes/delegation.d.ts +20 -0
  76. package/dist/routes/delegation.d.ts.map +1 -0
  77. package/dist/routes/delegation.js +108 -0
  78. package/dist/routes/delegation.js.map +1 -0
  79. package/dist/routes/delegations-top.d.ts +12 -0
  80. package/dist/routes/delegations-top.d.ts.map +1 -0
  81. package/dist/routes/delegations-top.js +43 -0
  82. package/dist/routes/delegations-top.js.map +1 -0
  83. package/dist/routes/discovery.d.ts +19 -0
  84. package/dist/routes/discovery.d.ts.map +1 -0
  85. package/dist/routes/discovery.js +96 -0
  86. package/dist/routes/discovery.js.map +1 -0
  87. package/dist/routes/redaction-test.d.ts +14 -0
  88. package/dist/routes/redaction-test.d.ts.map +1 -0
  89. package/dist/routes/redaction-test.js +33 -0
  90. package/dist/routes/redaction-test.js.map +1 -0
  91. package/dist/routes/trust.d.ts +16 -0
  92. package/dist/routes/trust.d.ts.map +1 -0
  93. package/dist/routes/trust.js +23 -0
  94. package/dist/routes/trust.js.map +1 -0
  95. package/dist/services/community-service.d.ts +283 -0
  96. package/dist/services/community-service.d.ts.map +1 -0
  97. package/dist/services/community-service.js +816 -0
  98. package/dist/services/community-service.js.map +1 -0
  99. package/dist/services/delegation-service.d.ts +149 -0
  100. package/dist/services/delegation-service.d.ts.map +1 -0
  101. package/dist/services/delegation-service.js +605 -0
  102. package/dist/services/delegation-service.js.map +1 -0
  103. package/dist/services/discovery-service.d.ts +39 -0
  104. package/dist/services/discovery-service.d.ts.map +1 -0
  105. package/dist/services/discovery-service.js +186 -0
  106. package/dist/services/discovery-service.js.map +1 -0
  107. package/dist/services/trust-service.d.ts +59 -0
  108. package/dist/services/trust-service.d.ts.map +1 -0
  109. package/dist/services/trust-service.js +139 -0
  110. package/dist/services/trust-service.js.map +1 -0
  111. 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"}