@mdsnai/sdk 0.3.3 → 0.4.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/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2026 MDSN
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md CHANGED
@@ -2,6 +2,8 @@
2
2
 
3
3
  `@mdsnai/sdk` is the reference SDK for building apps with MDSN.
4
4
 
5
+ It officially supports Node and Bun through a shared server runtime plus runtime-specific host adapters.
6
+
5
7
  MDSN is a Markdown-first page and interaction format. `@mdsnai/sdk` gives you the parser, server runtime, browser runtime, and default UI for working with it.
6
8
 
7
9
  ## Why MDSN
@@ -31,9 +33,9 @@ The same Markdown source can carry:
31
33
 
32
34
  ## Syntax
33
35
 
34
- The starter uses this minimal page shape:
36
+ The starter page keeps Markdown content and the interaction block in the same file:
35
37
 
36
- ````md
38
+ ```text
37
39
  ---
38
40
  title: "Agent App"
39
41
  ---
@@ -44,17 +46,17 @@ Use this starter as the smallest end-to-end MDSN app.
44
46
 
45
47
  <!-- mdsn:block main -->
46
48
 
47
- ```mdsn
48
49
  BLOCK main {
49
50
  INPUT text required -> message
50
51
  GET "/list" -> refresh label:"Refresh"
51
52
  POST "/post" (message) -> submit label:"Submit"
52
53
  }
53
54
  ```
54
- ````
55
55
 
56
56
  ## Quick Start
57
57
 
58
+ Node starter:
59
+
58
60
  ```bash
59
61
  npm create mdsn@latest agent-app
60
62
  cd agent-app
@@ -62,6 +64,35 @@ npm install
62
64
  npm start
63
65
  ```
64
66
 
67
+ Bun starter:
68
+
69
+ ```bash
70
+ bunx create-mdsn agent-app
71
+ cd agent-app
72
+ bun install
73
+ bun start
74
+ ```
75
+
76
+ You can also force either runtime with `--runtime node` or `--runtime bun`.
77
+
78
+ ## Runtime Adapters
79
+
80
+ Shared server modeling stays on `@mdsnai/sdk/server`:
81
+
82
+ ```ts
83
+ import { createHostedApp } from "@mdsnai/sdk/server";
84
+ ```
85
+
86
+ Then choose the host adapter for your runtime:
87
+
88
+ ```ts
89
+ import { createHost } from "@mdsnai/sdk/server/node";
90
+ ```
91
+
92
+ ```ts
93
+ import { createHost } from "@mdsnai/sdk/server/bun";
94
+ ```
95
+
65
96
  ## Docs
66
97
 
67
98
  - [Getting Started](https://docs.mdsn.ai/getting-started)
@@ -0,0 +1,19 @@
1
+ import type { MdsnRequest, MdsnResponse } from "./types.js";
2
+ interface MdsnRequestHandler {
3
+ handle(request: MdsnRequest): Promise<MdsnResponse>;
4
+ }
5
+ export interface CreateBunHostOptions {
6
+ rootRedirect?: string;
7
+ ignoreFavicon?: boolean;
8
+ staticFiles?: Record<string, string>;
9
+ staticMounts?: BunStaticMount[];
10
+ transformHtml?: (html: string) => string;
11
+ maxBodyBytes?: number;
12
+ }
13
+ export interface BunStaticMount {
14
+ urlPrefix: string;
15
+ directory: string;
16
+ }
17
+ export declare function createHost(handler: MdsnRequestHandler, options?: CreateBunHostOptions): (request: Request) => Promise<Response>;
18
+ export {};
19
+ //# sourceMappingURL=bun.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bun.d.ts","sourceRoot":"","sources":["../../src/server/bun.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAE5D,UAAU,kBAAkB;IAC1B,MAAM,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;CACrD;AAED,MAAM,WAAW,oBAAoB;IACnC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACrC,YAAY,CAAC,EAAE,cAAc,EAAE,CAAC;IAChC,aAAa,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,MAAM,CAAC;IACzC,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB;AA0KD,wBAAgB,UAAU,CAAC,OAAO,EAAE,kBAAkB,EAAE,OAAO,GAAE,oBAAyB,IAC1E,SAAS,OAAO,KAAG,OAAO,CAAC,QAAQ,CAAC,CAsDnD"}
@@ -0,0 +1,204 @@
1
+ import { readFile, stat } from "node:fs/promises";
2
+ import { extname, resolve } from "node:path";
3
+ import { serializeMarkdownBody } from "../core/index.js";
4
+ const DEFAULT_MAX_BODY_BYTES = 1024 * 1024;
5
+ class PayloadTooLargeError extends Error {
6
+ constructor() {
7
+ super("Payload Too Large");
8
+ }
9
+ }
10
+ function parseCookies(header) {
11
+ if (!header?.trim()) {
12
+ return {};
13
+ }
14
+ const cookies = {};
15
+ for (const pair of header.split(";")) {
16
+ const [rawName, ...rawValue] = pair.split("=");
17
+ const name = rawName?.trim();
18
+ if (!name) {
19
+ continue;
20
+ }
21
+ const serializedValue = rawValue.join("=").trim();
22
+ try {
23
+ cookies[name] = decodeURIComponent(serializedValue);
24
+ }
25
+ catch {
26
+ cookies[name] = serializedValue;
27
+ }
28
+ }
29
+ return cookies;
30
+ }
31
+ function normalizeBody(body, contentType) {
32
+ if (!body) {
33
+ return undefined;
34
+ }
35
+ if (!contentType?.includes("application/x-www-form-urlencoded")) {
36
+ return body;
37
+ }
38
+ const params = new URLSearchParams(body);
39
+ return serializeMarkdownBody(Object.fromEntries(params.entries()));
40
+ }
41
+ async function readBody(request, maxBodyBytes) {
42
+ const contentLengthHeader = request.headers.get("content-length");
43
+ const contentLength = contentLengthHeader ? Number(contentLengthHeader) : Number.NaN;
44
+ if (Number.isFinite(contentLength) && contentLength > maxBodyBytes) {
45
+ throw new PayloadTooLargeError();
46
+ }
47
+ const text = await request.text();
48
+ if (!text) {
49
+ return undefined;
50
+ }
51
+ if (Buffer.byteLength(text) > maxBodyBytes) {
52
+ throw new PayloadTooLargeError();
53
+ }
54
+ return text;
55
+ }
56
+ function getContentType(filePath) {
57
+ const extension = extname(filePath);
58
+ return extension === ".js" || extension === ".mjs"
59
+ ? "text/javascript"
60
+ : extension === ".css"
61
+ ? "text/css"
62
+ : extension === ".map" || extension === ".json"
63
+ ? "application/json"
64
+ : extension === ".html"
65
+ ? "text/html"
66
+ : extension === ".svg"
67
+ ? "image/svg+xml"
68
+ : extension === ".txt"
69
+ ? "text/plain"
70
+ : "application/octet-stream";
71
+ }
72
+ function resolveMountedFile(directory, urlPrefix, pathname) {
73
+ if (!pathname.startsWith(urlPrefix)) {
74
+ return null;
75
+ }
76
+ const relativePath = pathname.slice(urlPrefix.length);
77
+ const baseDirectory = resolve(directory);
78
+ const target = resolve(baseDirectory, relativePath);
79
+ if (target !== baseDirectory && !target.startsWith(`${baseDirectory}/`)) {
80
+ return null;
81
+ }
82
+ return target;
83
+ }
84
+ async function tryServeStaticFile(filePath) {
85
+ try {
86
+ const fileStat = await stat(filePath);
87
+ if (!fileStat.isFile()) {
88
+ return null;
89
+ }
90
+ const body = await readFile(filePath);
91
+ return new Response(body, {
92
+ status: 200,
93
+ headers: {
94
+ "content-type": getContentType(filePath),
95
+ "cache-control": "public, max-age=0, must-revalidate"
96
+ }
97
+ });
98
+ }
99
+ catch {
100
+ return null;
101
+ }
102
+ }
103
+ function toMdsnRequest(request, body) {
104
+ const headers = {};
105
+ request.headers.forEach((value, key) => {
106
+ headers[key] = value;
107
+ });
108
+ headers.accept ??= "text/html";
109
+ if (body && headers["content-type"]?.includes("application/x-www-form-urlencoded")) {
110
+ headers["content-type"] = "text/markdown";
111
+ }
112
+ return {
113
+ method: request.method === "POST" ? "POST" : "GET",
114
+ url: request.url,
115
+ headers,
116
+ ...(body ? { body } : {}),
117
+ cookies: parseCookies(request.headers.get("cookie"))
118
+ };
119
+ }
120
+ function toReadableStream(body) {
121
+ const encoder = new TextEncoder();
122
+ const iterator = body[Symbol.asyncIterator]();
123
+ return new ReadableStream({
124
+ async pull(controller) {
125
+ const chunk = await iterator.next();
126
+ if (chunk.done) {
127
+ controller.close();
128
+ return;
129
+ }
130
+ controller.enqueue(encoder.encode(chunk.value));
131
+ },
132
+ async cancel() {
133
+ if (typeof iterator.return === "function") {
134
+ await iterator.return();
135
+ }
136
+ }
137
+ });
138
+ }
139
+ function toResponse(result, transformHtml) {
140
+ const headers = new Headers(result.headers);
141
+ const contentType = headers.get("content-type") ?? "";
142
+ if (typeof result.body === "string") {
143
+ return new Response(contentType.includes("text/html") && transformHtml ? transformHtml(result.body) : result.body, {
144
+ status: result.status,
145
+ headers
146
+ });
147
+ }
148
+ return new Response(toReadableStream(result.body), {
149
+ status: result.status,
150
+ headers
151
+ });
152
+ }
153
+ export function createHost(handler, options = {}) {
154
+ return async (request) => {
155
+ const url = new URL(request.url);
156
+ if (options.rootRedirect && url.pathname === "/") {
157
+ return new Response(null, {
158
+ status: 302,
159
+ headers: {
160
+ location: options.rootRedirect
161
+ }
162
+ });
163
+ }
164
+ if (options.ignoreFavicon !== false && url.pathname === "/favicon.ico") {
165
+ return new Response(null, { status: 204 });
166
+ }
167
+ const staticFile = options.staticFiles?.[url.pathname];
168
+ if (staticFile) {
169
+ const response = await tryServeStaticFile(staticFile);
170
+ if (response) {
171
+ return response;
172
+ }
173
+ }
174
+ for (const mount of options.staticMounts ?? []) {
175
+ const target = resolveMountedFile(mount.directory, mount.urlPrefix, url.pathname);
176
+ if (!target) {
177
+ continue;
178
+ }
179
+ const response = await tryServeStaticFile(target);
180
+ if (response) {
181
+ return response;
182
+ }
183
+ }
184
+ const maxBodyBytes = options.maxBodyBytes ?? DEFAULT_MAX_BODY_BYTES;
185
+ let normalizedBody;
186
+ try {
187
+ normalizedBody = normalizeBody(await readBody(request, maxBodyBytes), request.headers.get("content-type"));
188
+ }
189
+ catch (error) {
190
+ if (error instanceof PayloadTooLargeError) {
191
+ return new Response("## Payload Too Large\n\nRequest body exceeded maxBodyBytes.", {
192
+ status: 413,
193
+ headers: {
194
+ "content-type": "text/markdown"
195
+ }
196
+ });
197
+ }
198
+ throw error;
199
+ }
200
+ const result = await handler.handle(toMdsnRequest(request, normalizedBody));
201
+ return toResponse(result, options.transformHtml);
202
+ };
203
+ }
204
+ //# sourceMappingURL=bun.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bun.js","sourceRoot":"","sources":["../../src/server/bun.ts"],"names":[],"mappings":"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"}
@@ -1,5 +1,4 @@
1
1
  export { createHostedApp } from "./hosted-app.js";
2
- export { createNodeHost } from "./node.js";
3
2
  export { block, fail, navigate, ok, stream } from "./result.js";
4
3
  export { createMdsnServer, type CreateMdsnServerOptions } from "./runtime.js";
5
4
  export { refreshSession, signIn, signOut } from "./session.js";
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/server/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAC3C,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAChE,OAAO,EAAE,gBAAgB,EAAE,KAAK,uBAAuB,EAAE,MAAM,cAAc,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAC/D,YAAY,EACV,sBAAsB,EACtB,YAAY,EACZ,sBAAsB,EACtB,mBAAmB,EACnB,iBAAiB,EAClB,MAAM,iBAAiB,CAAC;AACzB,YAAY,EACV,gBAAgB,EAChB,WAAW,EACX,kBAAkB,EAClB,iBAAiB,EACjB,eAAe,EACf,sBAAsB,EACtB,WAAW,EACX,YAAY,EACZ,mBAAmB,EACnB,mBAAmB,EACnB,mBAAmB,EACnB,eAAe,EACf,gBAAgB,EACjB,MAAM,YAAY,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/server/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAChE,OAAO,EAAE,gBAAgB,EAAE,KAAK,uBAAuB,EAAE,MAAM,cAAc,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAC/D,YAAY,EACV,sBAAsB,EACtB,YAAY,EACZ,sBAAsB,EACtB,mBAAmB,EACnB,iBAAiB,EAClB,MAAM,iBAAiB,CAAC;AACzB,YAAY,EACV,gBAAgB,EAChB,WAAW,EACX,kBAAkB,EAClB,iBAAiB,EACjB,eAAe,EACf,sBAAsB,EACtB,WAAW,EACX,YAAY,EACZ,mBAAmB,EACnB,mBAAmB,EACnB,mBAAmB,EACnB,eAAe,EACf,gBAAgB,EACjB,MAAM,YAAY,CAAC"}
@@ -1,5 +1,4 @@
1
1
  export { createHostedApp } from "./hosted-app.js";
2
- export { createNodeHost } from "./node.js";
3
2
  export { block, fail, navigate, ok, stream } from "./result.js";
4
3
  export { createMdsnServer } from "./runtime.js";
5
4
  export { refreshSession, signIn, signOut } from "./session.js";
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/server/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAC3C,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAChE,OAAO,EAAE,gBAAgB,EAAgC,MAAM,cAAc,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/server/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAChE,OAAO,EAAE,gBAAgB,EAAgC,MAAM,cAAc,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { createNodeHost as createHost, createNodeHost, createNodeRequestListener, type CreateNodeHostOptions, type CreateNodeRequestListenerOptions, type NodeStaticMount } from "./node.js";
2
+ //# sourceMappingURL=node-runtime.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node-runtime.d.ts","sourceRoot":"","sources":["../../src/server/node-runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,IAAI,UAAU,EAC5B,cAAc,EACd,yBAAyB,EACzB,KAAK,qBAAqB,EAC1B,KAAK,gCAAgC,EACrC,KAAK,eAAe,EACrB,MAAM,WAAW,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { createNodeHost as createHost, createNodeHost, createNodeRequestListener } from "./node.js";
2
+ //# sourceMappingURL=node-runtime.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node-runtime.js","sourceRoot":"","sources":["../../src/server/node-runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,IAAI,UAAU,EAC5B,cAAc,EACd,yBAAyB,EAI1B,MAAM,WAAW,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mdsnai/sdk",
3
- "version": "0.3.3",
3
+ "version": "0.4.0",
4
4
  "private": false,
5
5
  "description": "Reference SDK for building MDSN apps with Markdown-first pages, actions, and browser runtimes.",
6
6
  "license": "MIT",
@@ -24,7 +24,8 @@
24
24
  "skills-app",
25
25
  "agent-app",
26
26
  "server",
27
- "web-components"
27
+ "web-components",
28
+ "bun"
28
29
  ],
29
30
  "type": "module",
30
31
  "main": "./dist/index.js",
@@ -34,11 +35,16 @@
34
35
  },
35
36
  "files": [
36
37
  "dist",
37
- "README.md"
38
+ "README.md",
39
+ "LICENSE"
38
40
  ],
39
41
  "publishConfig": {
40
42
  "access": "public"
41
43
  },
44
+ "scripts": {
45
+ "prepack": "node ../scripts/sync-package-license.mjs",
46
+ "postpack": "node ../scripts/sync-package-license.mjs --cleanup"
47
+ },
42
48
  "exports": {
43
49
  ".": {
44
50
  "types": "./dist/index.d.ts",
@@ -52,6 +58,14 @@
52
58
  "types": "./dist/server/index.d.ts",
53
59
  "default": "./dist/server/index.js"
54
60
  },
61
+ "./server/node": {
62
+ "types": "./dist/server/node-runtime.d.ts",
63
+ "default": "./dist/server/node-runtime.js"
64
+ },
65
+ "./server/bun": {
66
+ "types": "./dist/server/bun.d.ts",
67
+ "default": "./dist/server/bun.js"
68
+ },
55
69
  "./web": {
56
70
  "types": "./dist/web/index.d.ts",
57
71
  "default": "./dist/web/index.js"