@qontinui/ui-bridge 0.2.0 → 0.3.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/ai/index.d.mts +4 -4
- package/dist/ai/index.d.ts +4 -4
- package/dist/babel-plugin/index.js +515 -0
- package/dist/babel-plugin/index.js.map +1 -0
- package/dist/babel-plugin/index.mjs +499 -0
- package/dist/babel-plugin/index.mjs.map +1 -0
- package/dist/control/index.d.mts +5 -5
- package/dist/control/index.d.ts +5 -5
- package/dist/core/index.d.mts +115 -44
- package/dist/core/index.d.ts +115 -44
- package/dist/core/index.js +0 -1560
- package/dist/core/index.js.map +1 -1
- package/dist/core/index.mjs +1 -1549
- package/dist/core/index.mjs.map +1 -1
- package/dist/debug/index.d.mts +3 -3
- package/dist/debug/index.d.ts +3 -3
- package/dist/index.d.mts +7 -8
- package/dist/index.d.ts +7 -8
- package/dist/index.js +859 -873
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +860 -862
- package/dist/index.mjs.map +1 -1
- package/dist/{metrics-C9XRi_mL.d.ts → metrics-BfiT_rhZ.d.ts} +2 -2
- package/dist/{metrics-NC3csD0R.d.mts → metrics-DTA2bwG7.d.mts} +2 -2
- package/dist/native/control/index.js +453 -0
- package/dist/native/control/index.js.map +1 -0
- package/dist/native/control/index.mjs +450 -0
- package/dist/native/control/index.mjs.map +1 -0
- package/dist/native/core/index.js +486 -0
- package/dist/native/core/index.js.map +1 -0
- package/dist/native/core/index.mjs +475 -0
- package/dist/native/core/index.mjs.map +1 -0
- package/dist/native/debug/index.js +451 -0
- package/dist/native/debug/index.js.map +1 -0
- package/dist/native/debug/index.mjs +449 -0
- package/dist/native/debug/index.mjs.map +1 -0
- package/dist/native/index.js +2274 -0
- package/dist/native/index.js.map +1 -0
- package/dist/native/index.mjs +2246 -0
- package/dist/native/index.mjs.map +1 -0
- package/dist/native/react/index.js +1401 -0
- package/dist/native/react/index.js.map +1 -0
- package/dist/native/react/index.mjs +1389 -0
- package/dist/native/react/index.mjs.map +1 -0
- package/dist/native/server/index.js +415 -0
- package/dist/native/server/index.js.map +1 -0
- package/dist/native/server/index.mjs +410 -0
- package/dist/native/server/index.mjs.map +1 -0
- package/dist/react/index.d.mts +20 -7
- package/dist/react/index.d.ts +20 -7
- package/dist/react/index.js +42 -4
- package/dist/react/index.js.map +1 -1
- package/dist/react/index.mjs +42 -4
- package/dist/react/index.mjs.map +1 -1
- package/dist/{registry-CIEDjbQ9.d.ts → registry-BKLEm-yk.d.ts} +9 -15
- package/dist/{registry-SsSDq46X.d.mts → registry-BmZgyCz8.d.mts} +9 -15
- package/dist/render-log/index.d.mts +1 -1
- package/dist/render-log/index.d.ts +1 -1
- package/dist/server/express.d.mts +36 -0
- package/dist/server/express.d.ts +36 -0
- package/dist/server/express.js +196 -0
- package/dist/server/express.js.map +1 -0
- package/dist/server/express.mjs +192 -0
- package/dist/server/express.mjs.map +1 -0
- package/dist/server/handlers.d.mts +93 -0
- package/dist/server/handlers.d.ts +93 -0
- package/dist/server/handlers.js +4278 -0
- package/dist/server/handlers.js.map +1 -0
- package/dist/server/handlers.mjs +4275 -0
- package/dist/server/handlers.mjs.map +1 -0
- package/dist/server/index.d.mts +10 -0
- package/dist/server/index.d.ts +10 -0
- package/dist/server/index.js +5352 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/index.mjs +5337 -0
- package/dist/server/index.mjs.map +1 -0
- package/dist/server/nextjs.d.mts +126 -0
- package/dist/server/nextjs.d.ts +126 -0
- package/dist/server/nextjs.js +287 -0
- package/dist/server/nextjs.js.map +1 -0
- package/dist/server/nextjs.mjs +282 -0
- package/dist/server/nextjs.mjs.map +1 -0
- package/dist/server/standalone.d.mts +6 -0
- package/dist/server/standalone.d.ts +6 -0
- package/dist/server/standalone.js +719 -0
- package/dist/server/standalone.js.map +1 -0
- package/dist/server/standalone.mjs +715 -0
- package/dist/server/standalone.mjs.map +1 -0
- package/dist/standalone-BURj8J3G.d.ts +212 -0
- package/dist/standalone-Dwmel29d.d.mts +212 -0
- package/dist/swc-plugin/index.d.mts +79 -0
- package/dist/swc-plugin/index.d.ts +79 -0
- package/dist/swc-plugin/index.js +15 -0
- package/dist/swc-plugin/index.js.map +1 -0
- package/dist/swc-plugin/index.mjs +9 -0
- package/dist/swc-plugin/index.mjs.map +1 -0
- package/dist/{types-CFT3Dnx4.d.mts → types-B5Q0GVo0.d.mts} +115 -3
- package/dist/{types-Dr6tH-bm.d.mts → types-B7J7noLK.d.mts} +1 -1
- package/dist/{types-oCTrRxSw.d.ts → types-BkNRILUa.d.ts} +1 -1
- package/dist/types-CEQLnFMv.d.mts +156 -0
- package/dist/types-CHnlwiTK.d.ts +156 -0
- package/dist/{types-BvCfFuEV.d.ts → types-DfPqwU-i.d.ts} +115 -3
- package/dist/{types-CPMbN_Iw.d.mts → types-jKVgTI6_.d.mts} +356 -160
- package/dist/{types-CPMbN_Iw.d.ts → types-jKVgTI6_.d.ts} +356 -160
- package/package.json +106 -3
- package/swc-plugin-wasm/ui_bridge_swc_plugin.wasm +0 -0
- package/dist/websocket-client-CX4QJesI.d.ts +0 -124
- package/dist/websocket-client-C_Na0OSp.d.mts +0 -124
|
@@ -0,0 +1,282 @@
|
|
|
1
|
+
// src/server/types.ts
|
|
2
|
+
var UI_BRIDGE_ROUTES = [
|
|
3
|
+
// Render log
|
|
4
|
+
{ method: "GET", path: "/render-log", handler: "getRenderLog" },
|
|
5
|
+
{ method: "DELETE", path: "/render-log", handler: "clearRenderLog" },
|
|
6
|
+
{ method: "POST", path: "/render-log/snapshot", handler: "captureSnapshot" },
|
|
7
|
+
{ method: "GET", path: "/render-log/path", handler: "getRenderLogPath" },
|
|
8
|
+
// Control - Elements
|
|
9
|
+
{ method: "GET", path: "/control/elements", handler: "getElements" },
|
|
10
|
+
{ method: "GET", path: "/control/element/:id", handler: "getElement", params: ["id"] },
|
|
11
|
+
{ method: "GET", path: "/control/element/:id/state", handler: "getElementState", params: ["id"] },
|
|
12
|
+
{
|
|
13
|
+
method: "POST",
|
|
14
|
+
path: "/control/element/:id/action",
|
|
15
|
+
handler: "executeElementAction",
|
|
16
|
+
params: ["id"],
|
|
17
|
+
bodyRequired: true
|
|
18
|
+
},
|
|
19
|
+
// Control - Components
|
|
20
|
+
{ method: "GET", path: "/control/components", handler: "getComponents" },
|
|
21
|
+
{ method: "GET", path: "/control/component/:id", handler: "getComponent", params: ["id"] },
|
|
22
|
+
{ method: "GET", path: "/control/component/:id/state", handler: "getComponentState", params: ["id"] },
|
|
23
|
+
{
|
|
24
|
+
method: "POST",
|
|
25
|
+
path: "/control/component/:id/action/:actionId",
|
|
26
|
+
handler: "executeComponentAction",
|
|
27
|
+
params: ["id", "actionId"],
|
|
28
|
+
bodyRequired: true
|
|
29
|
+
},
|
|
30
|
+
// Find (formerly Discovery)
|
|
31
|
+
{ method: "POST", path: "/control/find", handler: "find" },
|
|
32
|
+
{ method: "POST", path: "/control/discover", handler: "discover" },
|
|
33
|
+
// @deprecated Use /control/find
|
|
34
|
+
{ method: "GET", path: "/control/snapshot", handler: "getControlSnapshot" },
|
|
35
|
+
// Workflows
|
|
36
|
+
{ method: "GET", path: "/control/workflows", handler: "getWorkflows" },
|
|
37
|
+
{ method: "POST", path: "/control/workflow/:id/run", handler: "runWorkflow", params: ["id"] },
|
|
38
|
+
{
|
|
39
|
+
method: "GET",
|
|
40
|
+
path: "/control/workflow/:runId/status",
|
|
41
|
+
handler: "getWorkflowStatus",
|
|
42
|
+
params: ["runId"]
|
|
43
|
+
},
|
|
44
|
+
// Debug
|
|
45
|
+
{ method: "GET", path: "/debug/action-history", handler: "getActionHistory" },
|
|
46
|
+
{ method: "GET", path: "/debug/metrics", handler: "getMetrics" },
|
|
47
|
+
{ method: "POST", path: "/debug/highlight/:id", handler: "highlightElement", params: ["id"] },
|
|
48
|
+
{ method: "GET", path: "/debug/element-tree", handler: "getElementTree" },
|
|
49
|
+
// AI-native endpoints
|
|
50
|
+
{ method: "POST", path: "/ai/search", handler: "aiSearch", bodyRequired: true },
|
|
51
|
+
{ method: "POST", path: "/ai/execute", handler: "aiExecute", bodyRequired: true },
|
|
52
|
+
{ method: "POST", path: "/ai/assert", handler: "aiAssert", bodyRequired: true },
|
|
53
|
+
{ method: "POST", path: "/ai/assert/batch", handler: "aiAssertBatch", bodyRequired: true },
|
|
54
|
+
{ method: "GET", path: "/ai/snapshot", handler: "getSemanticSnapshot" },
|
|
55
|
+
{ method: "GET", path: "/ai/diff", handler: "getSemanticDiff" },
|
|
56
|
+
{ method: "GET", path: "/ai/summary", handler: "getPageSummary" },
|
|
57
|
+
{ method: "POST", path: "/ai/semantic-search", handler: "aiSemanticSearch", bodyRequired: true }
|
|
58
|
+
];
|
|
59
|
+
|
|
60
|
+
// src/server/nextjs.ts
|
|
61
|
+
function wrapError(error, code) {
|
|
62
|
+
return {
|
|
63
|
+
success: false,
|
|
64
|
+
error: typeof error === "string" ? error : error.message,
|
|
65
|
+
code,
|
|
66
|
+
timestamp: Date.now()
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
function jsonResponse(data, status = 200) {
|
|
70
|
+
return new Response(JSON.stringify(data), {
|
|
71
|
+
status,
|
|
72
|
+
headers: {
|
|
73
|
+
"Content-Type": "application/json"
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
function createNextRouteHandlers(handlers, config = {}) {
|
|
78
|
+
const authenticate = config.authenticate;
|
|
79
|
+
async function handleRequest(request, context) {
|
|
80
|
+
try {
|
|
81
|
+
if (authenticate) {
|
|
82
|
+
const authenticated = await authenticate(request);
|
|
83
|
+
if (!authenticated) {
|
|
84
|
+
return jsonResponse(wrapError("Unauthorized", "UNAUTHORIZED"), 401);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
const pathParam = context.params.path;
|
|
88
|
+
const path = Array.isArray(pathParam) ? "/" + pathParam.join("/") : "/" + pathParam;
|
|
89
|
+
const method = request.method;
|
|
90
|
+
const route = findMatchingRoute(path, method);
|
|
91
|
+
if (!route) {
|
|
92
|
+
return jsonResponse(wrapError("Not found", "NOT_FOUND"), 404);
|
|
93
|
+
}
|
|
94
|
+
const params = extractParams(path, route);
|
|
95
|
+
const handlerName = route.handler;
|
|
96
|
+
const handler = handlers[handlerName];
|
|
97
|
+
if (!handler) {
|
|
98
|
+
return jsonResponse(wrapError("Handler not found", "NOT_IMPLEMENTED"), 501);
|
|
99
|
+
}
|
|
100
|
+
const args = [];
|
|
101
|
+
if (route.params) {
|
|
102
|
+
for (const param of route.params) {
|
|
103
|
+
args.push(params[param]);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
if (method === "POST") {
|
|
107
|
+
try {
|
|
108
|
+
const body = await request.json();
|
|
109
|
+
args.push(body);
|
|
110
|
+
} catch {
|
|
111
|
+
args.push({});
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
if (method === "GET") {
|
|
115
|
+
const searchParams = Object.fromEntries(request.nextUrl.searchParams);
|
|
116
|
+
if (Object.keys(searchParams).length > 0) {
|
|
117
|
+
args.push(searchParams);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
const result = await handler(
|
|
121
|
+
...args
|
|
122
|
+
);
|
|
123
|
+
return jsonResponse(result);
|
|
124
|
+
} catch (error) {
|
|
125
|
+
console.error("UI Bridge error:", error);
|
|
126
|
+
return jsonResponse(wrapError(error, "INTERNAL_ERROR"), 500);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
return {
|
|
130
|
+
GET: handleRequest,
|
|
131
|
+
POST: handleRequest,
|
|
132
|
+
DELETE: handleRequest
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
function findMatchingRoute(path, method) {
|
|
136
|
+
for (const route of UI_BRIDGE_ROUTES) {
|
|
137
|
+
if (route.method !== method) continue;
|
|
138
|
+
const routeRegex = route.path.replace(/:[^/]+/g, "([^/]+)").replace(/\//g, "\\/");
|
|
139
|
+
const regex = new RegExp(`^${routeRegex}$`);
|
|
140
|
+
if (regex.test(path)) {
|
|
141
|
+
return route;
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
return null;
|
|
145
|
+
}
|
|
146
|
+
function extractParams(path, route) {
|
|
147
|
+
const params = {};
|
|
148
|
+
if (!route.params) return params;
|
|
149
|
+
const routeParts = route.path.split("/");
|
|
150
|
+
const pathParts = path.split("/");
|
|
151
|
+
for (let i = 0; i < routeParts.length; i++) {
|
|
152
|
+
const routePart = routeParts[i];
|
|
153
|
+
if (routePart.startsWith(":")) {
|
|
154
|
+
const paramName = routePart.slice(1);
|
|
155
|
+
params[paramName] = pathParts[i];
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
return params;
|
|
159
|
+
}
|
|
160
|
+
function createRenderLogHandlers(handlers) {
|
|
161
|
+
return {
|
|
162
|
+
async GET(request) {
|
|
163
|
+
const searchParams = Object.fromEntries(request.nextUrl.searchParams);
|
|
164
|
+
const query = {
|
|
165
|
+
type: searchParams.type,
|
|
166
|
+
since: searchParams.since ? parseInt(searchParams.since) : void 0,
|
|
167
|
+
until: searchParams.until ? parseInt(searchParams.until) : void 0,
|
|
168
|
+
limit: searchParams.limit ? parseInt(searchParams.limit) : void 0
|
|
169
|
+
};
|
|
170
|
+
const result = await handlers.getRenderLog(query);
|
|
171
|
+
return jsonResponse(result);
|
|
172
|
+
},
|
|
173
|
+
async DELETE() {
|
|
174
|
+
const result = await handlers.clearRenderLog();
|
|
175
|
+
return jsonResponse(result);
|
|
176
|
+
}
|
|
177
|
+
};
|
|
178
|
+
}
|
|
179
|
+
function createControlHandlers(handlers) {
|
|
180
|
+
return {
|
|
181
|
+
elements: {
|
|
182
|
+
async GET() {
|
|
183
|
+
const result = await handlers.getElements();
|
|
184
|
+
return jsonResponse(result);
|
|
185
|
+
}
|
|
186
|
+
},
|
|
187
|
+
element: {
|
|
188
|
+
async GET(_request, context) {
|
|
189
|
+
const result = await handlers.getElement(context.params.id);
|
|
190
|
+
return jsonResponse(result);
|
|
191
|
+
},
|
|
192
|
+
async POST(request, context) {
|
|
193
|
+
const body = await request.json();
|
|
194
|
+
const result = await handlers.executeElementAction(context.params.id, body);
|
|
195
|
+
return jsonResponse(result);
|
|
196
|
+
}
|
|
197
|
+
},
|
|
198
|
+
components: {
|
|
199
|
+
async GET() {
|
|
200
|
+
const result = await handlers.getComponents();
|
|
201
|
+
return jsonResponse(result);
|
|
202
|
+
}
|
|
203
|
+
},
|
|
204
|
+
component: {
|
|
205
|
+
async GET(_request, context) {
|
|
206
|
+
const result = await handlers.getComponent(context.params.id);
|
|
207
|
+
return jsonResponse(result);
|
|
208
|
+
},
|
|
209
|
+
async POST(request, context) {
|
|
210
|
+
const body = await request.json();
|
|
211
|
+
const result = await handlers.executeComponentAction(context.params.id, {
|
|
212
|
+
...body,
|
|
213
|
+
action: context.params.actionId
|
|
214
|
+
});
|
|
215
|
+
return jsonResponse(result);
|
|
216
|
+
}
|
|
217
|
+
},
|
|
218
|
+
find: {
|
|
219
|
+
async POST(request) {
|
|
220
|
+
const body = await request.json();
|
|
221
|
+
const result = await handlers.find(body);
|
|
222
|
+
return jsonResponse(result);
|
|
223
|
+
}
|
|
224
|
+
},
|
|
225
|
+
discover: {
|
|
226
|
+
/**
|
|
227
|
+
* @deprecated Use /control/find instead
|
|
228
|
+
*/
|
|
229
|
+
async POST(request) {
|
|
230
|
+
const body = await request.json();
|
|
231
|
+
const result = await handlers.discover(body);
|
|
232
|
+
return jsonResponse(result);
|
|
233
|
+
}
|
|
234
|
+
},
|
|
235
|
+
snapshot: {
|
|
236
|
+
async GET() {
|
|
237
|
+
const result = await handlers.getControlSnapshot();
|
|
238
|
+
return jsonResponse(result);
|
|
239
|
+
}
|
|
240
|
+
},
|
|
241
|
+
workflows: {
|
|
242
|
+
async GET() {
|
|
243
|
+
const result = await handlers.getWorkflows();
|
|
244
|
+
return jsonResponse(result);
|
|
245
|
+
}
|
|
246
|
+
},
|
|
247
|
+
workflow: {
|
|
248
|
+
async POST(request, context) {
|
|
249
|
+
const body = await request.json();
|
|
250
|
+
const result = await handlers.runWorkflow(context.params.id, body);
|
|
251
|
+
return jsonResponse(result);
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
};
|
|
255
|
+
}
|
|
256
|
+
function createDebugHandlers(handlers) {
|
|
257
|
+
return {
|
|
258
|
+
actionHistory: {
|
|
259
|
+
async GET(request) {
|
|
260
|
+
const limit = request.nextUrl.searchParams.get("limit");
|
|
261
|
+
const result = await handlers.getActionHistory(limit ? parseInt(limit) : void 0);
|
|
262
|
+
return jsonResponse(result);
|
|
263
|
+
}
|
|
264
|
+
},
|
|
265
|
+
metrics: {
|
|
266
|
+
async GET() {
|
|
267
|
+
const result = await handlers.getMetrics();
|
|
268
|
+
return jsonResponse(result);
|
|
269
|
+
}
|
|
270
|
+
},
|
|
271
|
+
highlight: {
|
|
272
|
+
async POST(_request, context) {
|
|
273
|
+
const result = await handlers.highlightElement(context.params.id);
|
|
274
|
+
return jsonResponse(result);
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
};
|
|
278
|
+
}
|
|
279
|
+
|
|
280
|
+
export { createControlHandlers, createDebugHandlers, createNextRouteHandlers, createRenderLogHandlers };
|
|
281
|
+
//# sourceMappingURL=nextjs.mjs.map
|
|
282
|
+
//# sourceMappingURL=nextjs.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/server/types.ts","../../src/server/nextjs.ts"],"names":[],"mappings":"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","file":"nextjs.mjs","sourcesContent":["/**\n * UI Bridge Server Types\n *\n * Shared types for server adapters.\n */\n\nimport type { UIBridgeConfig } from '../core';\nimport type {\n ControlActionRequest,\n ControlActionResponse,\n ComponentActionRequest,\n ComponentActionResponse,\n FindRequest,\n FindResponse,\n ControlSnapshot,\n WorkflowRunRequest,\n WorkflowRunResponse,\n} from '../control';\nimport type { RenderLogEntry, RenderLogEntryType } from '../render-log';\nimport type {\n SearchCriteria,\n SearchResponse,\n NLActionRequest,\n NLActionResponse,\n AssertionRequest,\n AssertionResult,\n BatchAssertionRequest,\n BatchAssertionResult,\n SemanticSnapshot,\n SemanticDiff,\n SemanticSearchCriteria,\n SemanticSearchResponse,\n} from '../ai';\n\n/**\n * Server configuration\n */\nexport interface UIBridgeServerConfig extends UIBridgeConfig {\n /** Base path for API routes */\n basePath?: string;\n /** Enable CORS */\n cors?: boolean | CORSOptions;\n /** Authentication middleware */\n authenticate?: (req: unknown) => boolean | Promise<boolean>;\n /** Rate limiting */\n rateLimit?: RateLimitOptions;\n}\n\n/**\n * CORS options\n */\nexport interface CORSOptions {\n /** Allowed origins */\n origin?: string | string[] | boolean;\n /** Allowed methods */\n methods?: string[];\n /** Allowed headers */\n headers?: string[];\n /** Expose headers */\n exposeHeaders?: string[];\n /** Allow credentials */\n credentials?: boolean;\n /** Max age for preflight cache */\n maxAge?: number;\n}\n\n/**\n * Rate limit options\n */\nexport interface RateLimitOptions {\n /** Time window in milliseconds */\n windowMs?: number;\n /** Max requests per window */\n max?: number;\n /** Message when rate limited */\n message?: string;\n}\n\n/**\n * API response wrapper\n */\nexport interface APIResponse<T = unknown> {\n /** Whether the request succeeded */\n success: boolean;\n /** Response data */\n data?: T;\n /** Error message if failed */\n error?: string;\n /** Error code */\n code?: string;\n /** Request timestamp */\n timestamp: number;\n}\n\n/**\n * Render log query parameters\n */\nexport interface RenderLogQuery {\n /** Filter by entry type */\n type?: RenderLogEntryType;\n /** Filter entries since timestamp */\n since?: number;\n /** Filter entries until timestamp */\n until?: number;\n /** Limit number of results */\n limit?: number;\n}\n\n/**\n * Server handler interface\n *\n * Implementations provide these handlers for different frameworks.\n */\nexport interface UIBridgeServerHandlers {\n // Render log endpoints\n getRenderLog: (query?: RenderLogQuery) => Promise<APIResponse<RenderLogEntry[]>>;\n clearRenderLog: () => Promise<APIResponse<void>>;\n captureSnapshot: () => Promise<APIResponse<unknown>>;\n getRenderLogPath: () => Promise<APIResponse<{ path: string }>>;\n\n // Control endpoints\n getElements: () => Promise<APIResponse<ControlSnapshot['elements']>>;\n getElement: (id: string) => Promise<APIResponse<ControlSnapshot['elements'][0]>>;\n getElementState: (id: string) => Promise<APIResponse<unknown>>;\n executeElementAction: (\n id: string,\n request: ControlActionRequest\n ) => Promise<APIResponse<ControlActionResponse>>;\n\n // Component endpoints\n getComponents: () => Promise<APIResponse<ControlSnapshot['components']>>;\n getComponent: (id: string) => Promise<APIResponse<ControlSnapshot['components'][0]>>;\n getComponentState: (id: string) => Promise<APIResponse<{ state: Record<string, unknown>; computed: Record<string, unknown>; timestamp: number }>>;\n executeComponentAction: (\n id: string,\n request: ComponentActionRequest\n ) => Promise<APIResponse<ComponentActionResponse>>;\n\n // Find endpoints\n find: (request?: FindRequest) => Promise<APIResponse<FindResponse>>;\n /**\n * @deprecated Use find() instead\n */\n discover: (request?: FindRequest) => Promise<APIResponse<FindResponse>>;\n getControlSnapshot: () => Promise<APIResponse<ControlSnapshot>>;\n\n // Workflow endpoints\n getWorkflows: () => Promise<APIResponse<ControlSnapshot['workflows']>>;\n runWorkflow: (\n id: string,\n request?: WorkflowRunRequest\n ) => Promise<APIResponse<WorkflowRunResponse>>;\n getWorkflowStatus: (runId: string) => Promise<APIResponse<WorkflowRunResponse>>;\n\n // Debug endpoints\n getActionHistory: (limit?: number) => Promise<APIResponse<unknown[]>>;\n getMetrics: () => Promise<APIResponse<unknown>>;\n highlightElement: (id: string) => Promise<APIResponse<void>>;\n getElementTree: () => Promise<APIResponse<unknown>>;\n\n // AI-native endpoints\n aiSearch: (criteria: SearchCriteria) => Promise<APIResponse<SearchResponse>>;\n aiExecute: (request: NLActionRequest) => Promise<APIResponse<NLActionResponse>>;\n aiAssert: (request: AssertionRequest) => Promise<APIResponse<AssertionResult>>;\n aiAssertBatch: (request: BatchAssertionRequest) => Promise<APIResponse<BatchAssertionResult>>;\n getSemanticSnapshot: () => Promise<APIResponse<SemanticSnapshot>>;\n getSemanticDiff: (since?: number) => Promise<APIResponse<SemanticDiff | null>>;\n getPageSummary: () => Promise<APIResponse<string>>;\n\n // Semantic search (embedding-based)\n aiSemanticSearch: (criteria: SemanticSearchCriteria) => Promise<APIResponse<SemanticSearchResponse>>;\n}\n\n/**\n * Route definition\n */\nexport interface RouteDefinition {\n method: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH';\n path: string;\n handler: string; // Key in UIBridgeServerHandlers\n params?: string[]; // URL params to extract\n bodyRequired?: boolean;\n}\n\n/**\n * All UI Bridge routes\n */\nexport const UI_BRIDGE_ROUTES: RouteDefinition[] = [\n // Render log\n { method: 'GET', path: '/render-log', handler: 'getRenderLog' },\n { method: 'DELETE', path: '/render-log', handler: 'clearRenderLog' },\n { method: 'POST', path: '/render-log/snapshot', handler: 'captureSnapshot' },\n { method: 'GET', path: '/render-log/path', handler: 'getRenderLogPath' },\n\n // Control - Elements\n { method: 'GET', path: '/control/elements', handler: 'getElements' },\n { method: 'GET', path: '/control/element/:id', handler: 'getElement', params: ['id'] },\n { method: 'GET', path: '/control/element/:id/state', handler: 'getElementState', params: ['id'] },\n {\n method: 'POST',\n path: '/control/element/:id/action',\n handler: 'executeElementAction',\n params: ['id'],\n bodyRequired: true,\n },\n\n // Control - Components\n { method: 'GET', path: '/control/components', handler: 'getComponents' },\n { method: 'GET', path: '/control/component/:id', handler: 'getComponent', params: ['id'] },\n { method: 'GET', path: '/control/component/:id/state', handler: 'getComponentState', params: ['id'] },\n {\n method: 'POST',\n path: '/control/component/:id/action/:actionId',\n handler: 'executeComponentAction',\n params: ['id', 'actionId'],\n bodyRequired: true,\n },\n\n // Find (formerly Discovery)\n { method: 'POST', path: '/control/find', handler: 'find' },\n { method: 'POST', path: '/control/discover', handler: 'discover' }, // @deprecated Use /control/find\n { method: 'GET', path: '/control/snapshot', handler: 'getControlSnapshot' },\n\n // Workflows\n { method: 'GET', path: '/control/workflows', handler: 'getWorkflows' },\n { method: 'POST', path: '/control/workflow/:id/run', handler: 'runWorkflow', params: ['id'] },\n {\n method: 'GET',\n path: '/control/workflow/:runId/status',\n handler: 'getWorkflowStatus',\n params: ['runId'],\n },\n\n // Debug\n { method: 'GET', path: '/debug/action-history', handler: 'getActionHistory' },\n { method: 'GET', path: '/debug/metrics', handler: 'getMetrics' },\n { method: 'POST', path: '/debug/highlight/:id', handler: 'highlightElement', params: ['id'] },\n { method: 'GET', path: '/debug/element-tree', handler: 'getElementTree' },\n\n // AI-native endpoints\n { method: 'POST', path: '/ai/search', handler: 'aiSearch', bodyRequired: true },\n { method: 'POST', path: '/ai/execute', handler: 'aiExecute', bodyRequired: true },\n { method: 'POST', path: '/ai/assert', handler: 'aiAssert', bodyRequired: true },\n { method: 'POST', path: '/ai/assert/batch', handler: 'aiAssertBatch', bodyRequired: true },\n { method: 'GET', path: '/ai/snapshot', handler: 'getSemanticSnapshot' },\n { method: 'GET', path: '/ai/diff', handler: 'getSemanticDiff' },\n { method: 'GET', path: '/ai/summary', handler: 'getPageSummary' },\n { method: 'POST', path: '/ai/semantic-search', handler: 'aiSemanticSearch', bodyRequired: true },\n];\n\n/**\n * WebSocket message types\n */\nexport type WebSocketMessageType =\n | 'subscribe'\n | 'unsubscribe'\n | 'event'\n | 'snapshot'\n | 'action'\n | 'error';\n\n/**\n * WebSocket message\n */\nexport interface WebSocketMessage<T = unknown> {\n type: WebSocketMessageType;\n channel?: string;\n data?: T;\n error?: string;\n timestamp: number;\n}\n","/**\n * Next.js Adapter\n *\n * Next.js API route handlers for UI Bridge server.\n */\n\n// Define NextRequest interface locally to avoid requiring next as a dependency\ninterface NextRequest extends Request {\n nextUrl: URL;\n}\nimport type {\n UIBridgeServerConfig,\n UIBridgeServerHandlers,\n APIResponse,\n RouteDefinition,\n RenderLogQuery,\n} from './types';\nimport { UI_BRIDGE_ROUTES } from './types';\nimport type {\n ControlActionRequest,\n ComponentActionRequest,\n FindRequest,\n WorkflowRunRequest,\n} from '../control';\n\n/**\n * Next.js specific configuration\n */\nexport interface NextJSAdapterConfig extends UIBridgeServerConfig {\n /** Runtime for edge/serverless */\n runtime?: 'edge' | 'nodejs';\n}\n\n/**\n * Wrap error in API format\n */\nfunction wrapError(error: Error | string, code?: string): APIResponse<never> {\n return {\n success: false,\n error: typeof error === 'string' ? error : error.message,\n code,\n timestamp: Date.now(),\n };\n}\n\n/**\n * Create JSON response\n */\nfunction jsonResponse(data: unknown, status = 200): Response {\n return new Response(JSON.stringify(data), {\n status,\n headers: {\n 'Content-Type': 'application/json',\n },\n });\n}\n\n/**\n * Route handler factory for Next.js App Router\n */\nexport type NextRouteHandler = (\n request: NextRequest,\n context: { params: Record<string, string> }\n) => Promise<Response>;\n\n/**\n * Create Next.js route handlers for UI Bridge\n *\n * Use this to create route handlers for the App Router.\n *\n * @example\n * ```ts\n * // app/api/ui-bridge/[...path]/route.ts\n * import { createNextRouteHandlers } from 'ui-bridge-server/nextjs';\n * import { handlers } from '@/lib/ui-bridge';\n *\n * export const { GET, POST, DELETE } = createNextRouteHandlers(handlers);\n * ```\n */\nexport function createNextRouteHandlers(\n handlers: UIBridgeServerHandlers,\n config: NextJSAdapterConfig = {}\n): {\n GET: NextRouteHandler;\n POST: NextRouteHandler;\n DELETE: NextRouteHandler;\n} {\n const authenticate = config.authenticate;\n\n async function handleRequest(\n request: NextRequest,\n context: { params: Record<string, string> }\n ): Promise<Response> {\n try {\n // Authentication\n if (authenticate) {\n const authenticated = await authenticate(request);\n if (!authenticated) {\n return jsonResponse(wrapError('Unauthorized', 'UNAUTHORIZED'), 401);\n }\n }\n\n // Extract path from catch-all route\n const pathParam = context.params.path;\n const path = Array.isArray(pathParam) ? '/' + pathParam.join('/') : '/' + pathParam;\n const method = request.method;\n\n // Find matching route\n const route = findMatchingRoute(path, method);\n if (!route) {\n return jsonResponse(wrapError('Not found', 'NOT_FOUND'), 404);\n }\n\n // Extract URL params\n const params = extractParams(path, route);\n\n // Get handler\n const handlerName = route.handler as keyof UIBridgeServerHandlers;\n const handler = handlers[handlerName];\n\n if (!handler) {\n return jsonResponse(wrapError('Handler not found', 'NOT_IMPLEMENTED'), 501);\n }\n\n // Build arguments\n const args: unknown[] = [];\n\n // Add URL params\n if (route.params) {\n for (const param of route.params) {\n args.push(params[param]);\n }\n }\n\n // Add body for POST requests\n if (method === 'POST') {\n try {\n const body = await request.json();\n args.push(body);\n } catch {\n // No body or invalid JSON\n args.push({});\n }\n }\n\n // Add query params for GET requests\n if (method === 'GET') {\n const searchParams = Object.fromEntries(request.nextUrl.searchParams);\n if (Object.keys(searchParams).length > 0) {\n args.push(searchParams);\n }\n }\n\n // Call handler\n const result = await (handler as (...args: unknown[]) => Promise<APIResponse<unknown>>)(\n ...args\n );\n return jsonResponse(result);\n } catch (error) {\n console.error('UI Bridge error:', error);\n return jsonResponse(wrapError(error as Error, 'INTERNAL_ERROR'), 500);\n }\n }\n\n return {\n GET: handleRequest,\n POST: handleRequest,\n DELETE: handleRequest,\n };\n}\n\n/**\n * Find a matching route definition\n */\nfunction findMatchingRoute(path: string, method: string): RouteDefinition | null {\n for (const route of UI_BRIDGE_ROUTES) {\n if (route.method !== method) continue;\n\n // Convert route path to regex\n const routeRegex = route.path.replace(/:[^/]+/g, '([^/]+)').replace(/\\//g, '\\\\/');\n\n const regex = new RegExp(`^${routeRegex}$`);\n if (regex.test(path)) {\n return route;\n }\n }\n return null;\n}\n\n/**\n * Extract params from URL path based on route definition\n */\nfunction extractParams(path: string, route: RouteDefinition): Record<string, string> {\n const params: Record<string, string> = {};\n if (!route.params) return params;\n\n // Extract param values from path\n const routeParts = route.path.split('/');\n const pathParts = path.split('/');\n\n for (let i = 0; i < routeParts.length; i++) {\n const routePart = routeParts[i];\n if (routePart.startsWith(':')) {\n const paramName = routePart.slice(1);\n params[paramName] = pathParts[i];\n }\n }\n\n return params;\n}\n\n/**\n * Individual route handler creators for more granular control\n */\nexport function createRenderLogHandlers(handlers: UIBridgeServerHandlers) {\n return {\n async GET(request: NextRequest): Promise<Response> {\n const searchParams = Object.fromEntries(request.nextUrl.searchParams);\n const query: RenderLogQuery = {\n type: searchParams.type as RenderLogQuery['type'],\n since: searchParams.since ? parseInt(searchParams.since) : undefined,\n until: searchParams.until ? parseInt(searchParams.until) : undefined,\n limit: searchParams.limit ? parseInt(searchParams.limit) : undefined,\n };\n const result = await handlers.getRenderLog(query);\n return jsonResponse(result);\n },\n async DELETE(): Promise<Response> {\n const result = await handlers.clearRenderLog();\n return jsonResponse(result);\n },\n };\n}\n\nexport function createControlHandlers(handlers: UIBridgeServerHandlers) {\n return {\n elements: {\n async GET(): Promise<Response> {\n const result = await handlers.getElements();\n return jsonResponse(result);\n },\n },\n element: {\n async GET(_request: NextRequest, context: { params: { id: string } }): Promise<Response> {\n const result = await handlers.getElement(context.params.id);\n return jsonResponse(result);\n },\n async POST(request: NextRequest, context: { params: { id: string } }): Promise<Response> {\n const body = (await request.json()) as ControlActionRequest;\n const result = await handlers.executeElementAction(context.params.id, body);\n return jsonResponse(result);\n },\n },\n components: {\n async GET(): Promise<Response> {\n const result = await handlers.getComponents();\n return jsonResponse(result);\n },\n },\n component: {\n async GET(_request: NextRequest, context: { params: { id: string } }): Promise<Response> {\n const result = await handlers.getComponent(context.params.id);\n return jsonResponse(result);\n },\n async POST(\n request: NextRequest,\n context: { params: { id: string; actionId: string } }\n ): Promise<Response> {\n const body = (await request.json()) as Omit<ComponentActionRequest, 'action'>;\n const result = await handlers.executeComponentAction(context.params.id, {\n ...body,\n action: context.params.actionId,\n });\n return jsonResponse(result);\n },\n },\n find: {\n async POST(request: NextRequest): Promise<Response> {\n const body = (await request.json()) as FindRequest;\n const result = await handlers.find(body);\n return jsonResponse(result);\n },\n },\n discover: {\n /**\n * @deprecated Use /control/find instead\n */\n async POST(request: NextRequest): Promise<Response> {\n const body = (await request.json()) as FindRequest;\n const result = await handlers.discover(body);\n return jsonResponse(result);\n },\n },\n snapshot: {\n async GET(): Promise<Response> {\n const result = await handlers.getControlSnapshot();\n return jsonResponse(result);\n },\n },\n workflows: {\n async GET(): Promise<Response> {\n const result = await handlers.getWorkflows();\n return jsonResponse(result);\n },\n },\n workflow: {\n async POST(request: NextRequest, context: { params: { id: string } }): Promise<Response> {\n const body = (await request.json()) as WorkflowRunRequest;\n const result = await handlers.runWorkflow(context.params.id, body);\n return jsonResponse(result);\n },\n },\n };\n}\n\nexport function createDebugHandlers(handlers: UIBridgeServerHandlers) {\n return {\n actionHistory: {\n async GET(request: NextRequest): Promise<Response> {\n const limit = request.nextUrl.searchParams.get('limit');\n const result = await handlers.getActionHistory(limit ? parseInt(limit) : undefined);\n return jsonResponse(result);\n },\n },\n metrics: {\n async GET(): Promise<Response> {\n const result = await handlers.getMetrics();\n return jsonResponse(result);\n },\n },\n highlight: {\n async POST(_request: NextRequest, context: { params: { id: string } }): Promise<Response> {\n const result = await handlers.highlightElement(context.params.id);\n return jsonResponse(result);\n },\n },\n };\n}\n"]}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import '../types-CEQLnFMv.mjs';
|
|
2
|
+
export { S as StandaloneServer, a as StandaloneServerConfig, c as createStandaloneServer, s as startCLI } from '../standalone-Dwmel29d.mjs';
|
|
3
|
+
import '../types-jKVgTI6_.mjs';
|
|
4
|
+
import '../types-B7J7noLK.mjs';
|
|
5
|
+
import '../types-B5Q0GVo0.mjs';
|
|
6
|
+
import '../render-log/index.mjs';
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import '../types-CHnlwiTK.js';
|
|
2
|
+
export { S as StandaloneServer, a as StandaloneServerConfig, c as createStandaloneServer, s as startCLI } from '../standalone-BURj8J3G.js';
|
|
3
|
+
import '../types-jKVgTI6_.js';
|
|
4
|
+
import '../types-BkNRILUa.js';
|
|
5
|
+
import '../types-DfPqwU-i.js';
|
|
6
|
+
import '../render-log/index.js';
|