@canmi/seam-adapter-bun 0.4.3 → 0.4.10
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/index.d.ts +8 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +36 -2
- package/dist/index.js.map +1 -1
- package/package.json +8 -7
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { DefinitionMap, HttpHandler, Router, RpcHashMap } from "@canmi/seam-server";
|
|
1
|
+
import { ChannelWsOptions, ChannelWsSession, DefinitionMap, HttpHandler, Router, RpcHashMap } from "@canmi/seam-server";
|
|
2
2
|
|
|
3
3
|
//#region src/index.d.ts
|
|
4
4
|
interface ServeBunOptions {
|
|
@@ -6,8 +6,14 @@ interface ServeBunOptions {
|
|
|
6
6
|
staticDir?: string;
|
|
7
7
|
fallback?: HttpHandler;
|
|
8
8
|
rpcHashMap?: RpcHashMap;
|
|
9
|
+
wsOptions?: ChannelWsOptions;
|
|
9
10
|
}
|
|
10
|
-
|
|
11
|
+
interface WsData {
|
|
12
|
+
channelName: string;
|
|
13
|
+
channelInput: unknown;
|
|
14
|
+
session?: ChannelWsSession;
|
|
15
|
+
}
|
|
16
|
+
declare function serveBun<T extends DefinitionMap>(router: Router<T>, opts?: ServeBunOptions): Bun.Server<WsData>;
|
|
11
17
|
//#endregion
|
|
12
18
|
export { ServeBunOptions, serveBun };
|
|
13
19
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","names":[],"sources":["../src/index.ts"],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"index.d.ts","names":[],"sources":["../src/index.ts"],"mappings":";;;UAYiB,eAAA;EACf,IAAA;EACA,SAAA;EACA,QAAA,GAAW,WAAA;EACX,UAAA,GAAa,UAAA;EACb,SAAA,GAAY,gBAAA;AAAA;AAAA,UAMJ,MAAA;EACR,WAAA;EACA,YAAA;EACA,OAAA,GAAU,gBAAA;AAAA;AAAA,iBAGI,QAAA,WAAmB,aAAA,CAAA,CAAe,MAAA,EAAQ,MAAA,CAAO,CAAA,GAAI,IAAA,GAAO,eAAA,GAAe,GAAA,CAAA,MAAA,CAAA,MAAA"}
|
package/dist/index.js
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
|
-
import { createHttpHandler, toWebResponse } from "@canmi/seam-server";
|
|
1
|
+
import { createHttpHandler, startChannelWs, toWebResponse } from "@canmi/seam-server";
|
|
2
2
|
|
|
3
3
|
//#region src/index.ts
|
|
4
|
+
const PROCEDURE_PREFIX = "/_seam/procedure/";
|
|
5
|
+
const EVENTS_SUFFIX = ".events";
|
|
4
6
|
function serveBun(router, opts) {
|
|
5
7
|
const handler = createHttpHandler(router, {
|
|
6
8
|
staticDir: opts?.staticDir,
|
|
@@ -9,13 +11,45 @@ function serveBun(router, opts) {
|
|
|
9
11
|
});
|
|
10
12
|
return Bun.serve({
|
|
11
13
|
port: opts?.port ?? 3e3,
|
|
12
|
-
async fetch(req) {
|
|
14
|
+
async fetch(req, server) {
|
|
15
|
+
if (req.method === "GET" && req.headers.get("upgrade") === "websocket") {
|
|
16
|
+
const url = new URL(req.url);
|
|
17
|
+
const { pathname } = url;
|
|
18
|
+
if (pathname.startsWith(PROCEDURE_PREFIX) && pathname.endsWith(EVENTS_SUFFIX)) {
|
|
19
|
+
const channelName = pathname.slice(17, -7);
|
|
20
|
+
const rawInput = url.searchParams.get("input");
|
|
21
|
+
let channelInput;
|
|
22
|
+
try {
|
|
23
|
+
channelInput = rawInput ? JSON.parse(rawInput) : {};
|
|
24
|
+
} catch {
|
|
25
|
+
return new Response("Invalid input query parameter", { status: 400 });
|
|
26
|
+
}
|
|
27
|
+
if (server.upgrade(req, { data: {
|
|
28
|
+
channelName,
|
|
29
|
+
channelInput
|
|
30
|
+
} })) return void 0;
|
|
31
|
+
return new Response("WebSocket upgrade failed", { status: 500 });
|
|
32
|
+
}
|
|
33
|
+
}
|
|
13
34
|
return toWebResponse(await handler({
|
|
14
35
|
method: req.method,
|
|
15
36
|
url: req.url,
|
|
16
37
|
body: () => req.json(),
|
|
17
38
|
header: (name) => req.headers.get(name)
|
|
18
39
|
}));
|
|
40
|
+
},
|
|
41
|
+
websocket: {
|
|
42
|
+
open(ws) {
|
|
43
|
+
const { channelName, channelInput } = ws.data;
|
|
44
|
+
ws.data.session = startChannelWs(router, channelName, channelInput, { send: (data) => ws.send(data) }, opts?.wsOptions);
|
|
45
|
+
},
|
|
46
|
+
message(ws, message) {
|
|
47
|
+
const text = typeof message === "string" ? message : new TextDecoder().decode(message);
|
|
48
|
+
ws.data.session?.onMessage(text);
|
|
49
|
+
},
|
|
50
|
+
close(ws) {
|
|
51
|
+
ws.data.session?.close();
|
|
52
|
+
}
|
|
19
53
|
}
|
|
20
54
|
});
|
|
21
55
|
}
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":[],"sources":["../src/index.ts"],"sourcesContent":["/*
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../src/index.ts"],"sourcesContent":["/* src/server/adapter/bun/src/index.ts */\n\nimport { createHttpHandler, toWebResponse, startChannelWs } from \"@canmi/seam-server\";\nimport type {\n DefinitionMap,\n Router,\n HttpHandler,\n RpcHashMap,\n ChannelWsSession,\n ChannelWsOptions,\n} from \"@canmi/seam-server\";\n\nexport interface ServeBunOptions {\n port?: number;\n staticDir?: string;\n fallback?: HttpHandler;\n rpcHashMap?: RpcHashMap;\n wsOptions?: ChannelWsOptions;\n}\n\nconst PROCEDURE_PREFIX = \"/_seam/procedure/\";\nconst EVENTS_SUFFIX = \".events\";\n\ninterface WsData {\n channelName: string;\n channelInput: unknown;\n session?: ChannelWsSession;\n}\n\nexport function serveBun<T extends DefinitionMap>(router: Router<T>, opts?: ServeBunOptions) {\n const handler = createHttpHandler(router, {\n staticDir: opts?.staticDir,\n fallback: opts?.fallback,\n rpcHashMap: opts?.rpcHashMap,\n });\n\n return Bun.serve<WsData>({\n port: opts?.port ?? 3000,\n\n async fetch(req, server) {\n // WebSocket upgrade for channel paths\n if (req.method === \"GET\" && req.headers.get(\"upgrade\") === \"websocket\") {\n const url = new URL(req.url);\n const { pathname } = url;\n if (pathname.startsWith(PROCEDURE_PREFIX) && pathname.endsWith(EVENTS_SUFFIX)) {\n const channelName = pathname.slice(PROCEDURE_PREFIX.length, -EVENTS_SUFFIX.length);\n const rawInput = url.searchParams.get(\"input\");\n let channelInput: unknown;\n try {\n channelInput = rawInput ? JSON.parse(rawInput) : {};\n } catch {\n return new Response(\"Invalid input query parameter\", { status: 400 });\n }\n const upgraded = server.upgrade(req, {\n data: { channelName, channelInput },\n });\n if (upgraded) return undefined;\n return new Response(\"WebSocket upgrade failed\", { status: 500 });\n }\n }\n\n const result = await handler({\n method: req.method,\n url: req.url,\n body: () => req.json(),\n header: (name) => req.headers.get(name),\n });\n return toWebResponse(result);\n },\n\n websocket: {\n open(ws) {\n const { channelName, channelInput } = ws.data;\n ws.data.session = startChannelWs(\n router,\n channelName,\n channelInput,\n {\n send: (data) => ws.send(data),\n },\n opts?.wsOptions,\n );\n },\n message(ws, message) {\n const text = typeof message === \"string\" ? message : new TextDecoder().decode(message);\n ws.data.session?.onMessage(text);\n },\n close(ws) {\n ws.data.session?.close();\n },\n },\n });\n}\n"],"mappings":";;;AAoBA,MAAM,mBAAmB;AACzB,MAAM,gBAAgB;AAQtB,SAAgB,SAAkC,QAAmB,MAAwB;CAC3F,MAAM,UAAU,kBAAkB,QAAQ;EACxC,WAAW,MAAM;EACjB,UAAU,MAAM;EAChB,YAAY,MAAM;EACnB,CAAC;AAEF,QAAO,IAAI,MAAc;EACvB,MAAM,MAAM,QAAQ;EAEpB,MAAM,MAAM,KAAK,QAAQ;AAEvB,OAAI,IAAI,WAAW,SAAS,IAAI,QAAQ,IAAI,UAAU,KAAK,aAAa;IACtE,MAAM,MAAM,IAAI,IAAI,IAAI,IAAI;IAC5B,MAAM,EAAE,aAAa;AACrB,QAAI,SAAS,WAAW,iBAAiB,IAAI,SAAS,SAAS,cAAc,EAAE;KAC7E,MAAM,cAAc,SAAS,MAAM,IAAyB,GAAsB;KAClF,MAAM,WAAW,IAAI,aAAa,IAAI,QAAQ;KAC9C,IAAI;AACJ,SAAI;AACF,qBAAe,WAAW,KAAK,MAAM,SAAS,GAAG,EAAE;aAC7C;AACN,aAAO,IAAI,SAAS,iCAAiC,EAAE,QAAQ,KAAK,CAAC;;AAKvE,SAHiB,OAAO,QAAQ,KAAK,EACnC,MAAM;MAAE;MAAa;MAAc,EACpC,CAAC,CACY,QAAO;AACrB,YAAO,IAAI,SAAS,4BAA4B,EAAE,QAAQ,KAAK,CAAC;;;AAUpE,UAAO,cANQ,MAAM,QAAQ;IAC3B,QAAQ,IAAI;IACZ,KAAK,IAAI;IACT,YAAY,IAAI,MAAM;IACtB,SAAS,SAAS,IAAI,QAAQ,IAAI,KAAK;IACxC,CAAC,CAC0B;;EAG9B,WAAW;GACT,KAAK,IAAI;IACP,MAAM,EAAE,aAAa,iBAAiB,GAAG;AACzC,OAAG,KAAK,UAAU,eAChB,QACA,aACA,cACA,EACE,OAAO,SAAS,GAAG,KAAK,KAAK,EAC9B,EACD,MAAM,UACP;;GAEH,QAAQ,IAAI,SAAS;IACnB,MAAM,OAAO,OAAO,YAAY,WAAW,UAAU,IAAI,aAAa,CAAC,OAAO,QAAQ;AACtF,OAAG,KAAK,SAAS,UAAU,KAAK;;GAElC,MAAM,IAAI;AACR,OAAG,KAAK,SAAS,OAAO;;GAE3B;EACF,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@canmi/seam-adapter-bun",
|
|
3
|
-
"version": "0.4.
|
|
3
|
+
"version": "0.4.10",
|
|
4
|
+
"license": "MIT",
|
|
4
5
|
"files": [
|
|
5
6
|
"dist"
|
|
6
7
|
],
|
|
@@ -16,13 +17,13 @@
|
|
|
16
17
|
"test": "bun test"
|
|
17
18
|
},
|
|
18
19
|
"devDependencies": {
|
|
19
|
-
"@canmi/seam-server": "
|
|
20
|
-
"@types/bun": "^1.
|
|
21
|
-
"bun-types": "^1.3.
|
|
22
|
-
"tsdown": "^0.20.
|
|
23
|
-
"typescript": "^5.
|
|
20
|
+
"@canmi/seam-server": "0.4.10",
|
|
21
|
+
"@types/bun": "^1.3.9",
|
|
22
|
+
"bun-types": "^1.3.10",
|
|
23
|
+
"tsdown": "^0.20.3",
|
|
24
|
+
"typescript": "^5.9.3"
|
|
24
25
|
},
|
|
25
26
|
"peerDependencies": {
|
|
26
|
-
"@canmi/seam-server": "
|
|
27
|
+
"@canmi/seam-server": "0.4.10"
|
|
27
28
|
}
|
|
28
29
|
}
|