appflare 0.2.41 → 0.2.43

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 (145) hide show
  1. package/Documentation.md +898 -758
  2. package/cli/commands/index.ts +247 -247
  3. package/cli/generate.ts +360 -360
  4. package/cli/index.ts +120 -120
  5. package/cli/load-config.ts +184 -184
  6. package/cli/schema-compiler.ts +1363 -1361
  7. package/cli/templates/auth/README.md +156 -156
  8. package/cli/templates/auth/config.ts +61 -61
  9. package/cli/templates/auth/route-config.ts +1 -1
  10. package/cli/templates/auth/route-handler.ts +1 -1
  11. package/cli/templates/auth/route-request-utils.ts +5 -5
  12. package/cli/templates/auth/route.config.ts +18 -18
  13. package/cli/templates/auth/route.handler.ts +18 -18
  14. package/cli/templates/auth/route.request-utils.ts +55 -55
  15. package/cli/templates/auth/route.ts +14 -14
  16. package/cli/templates/core/README.md +266 -266
  17. package/cli/templates/core/app-creation.ts +19 -19
  18. package/cli/templates/core/client/appflare.ts +112 -112
  19. package/cli/templates/core/client/handlers/index.ts +763 -755
  20. package/cli/templates/core/client/handlers.ts +1 -1
  21. package/cli/templates/core/client/index.ts +7 -7
  22. package/cli/templates/core/client/storage.ts +195 -195
  23. package/cli/templates/core/client/types.ts +187 -186
  24. package/cli/templates/core/client-modules/appflare.ts +1 -1
  25. package/cli/templates/core/client-modules/handlers.ts +1 -1
  26. package/cli/templates/core/client-modules/index.ts +1 -1
  27. package/cli/templates/core/client-modules/storage.ts +1 -1
  28. package/cli/templates/core/client-modules/types.ts +1 -1
  29. package/cli/templates/core/client.artifacts.ts +39 -39
  30. package/cli/templates/core/client.ts +4 -4
  31. package/cli/templates/core/drizzle.ts +15 -15
  32. package/cli/templates/core/export.ts +14 -14
  33. package/cli/templates/core/handlers.route.ts +24 -24
  34. package/cli/templates/core/handlers.ts +1 -1
  35. package/cli/templates/core/imports.ts +9 -9
  36. package/cli/templates/core/server.ts +38 -38
  37. package/cli/templates/core/types.ts +6 -6
  38. package/cli/templates/core/wrangler.ts +109 -109
  39. package/cli/templates/dashboard/builders/functions/index.ts +17 -17
  40. package/cli/templates/dashboard/builders/functions/render-page/header.ts +20 -20
  41. package/cli/templates/dashboard/builders/functions/render-page/index.ts +33 -33
  42. package/cli/templates/dashboard/builders/functions/render-page/request-panel.ts +171 -171
  43. package/cli/templates/dashboard/builders/functions/render-page/result-panel.ts +85 -85
  44. package/cli/templates/dashboard/builders/functions/render-page/scripts.ts +554 -554
  45. package/cli/templates/dashboard/builders/functions/tree-builder.ts +47 -47
  46. package/cli/templates/dashboard/builders/navigation.ts +155 -155
  47. package/cli/templates/dashboard/builders/storage/index.ts +13 -13
  48. package/cli/templates/dashboard/builders/storage/routes/create-directory-route.ts +29 -29
  49. package/cli/templates/dashboard/builders/storage/routes/delete-route.ts +18 -18
  50. package/cli/templates/dashboard/builders/storage/routes/download-route.ts +23 -23
  51. package/cli/templates/dashboard/builders/storage/routes/index.ts +22 -22
  52. package/cli/templates/dashboard/builders/storage/routes/list-route.ts +25 -25
  53. package/cli/templates/dashboard/builders/storage/routes/preview-route.ts +21 -21
  54. package/cli/templates/dashboard/builders/storage/routes/upload-route.ts +21 -21
  55. package/cli/templates/dashboard/builders/storage/runtime/helpers.ts +72 -72
  56. package/cli/templates/dashboard/builders/storage/runtime/storage-page.ts +130 -130
  57. package/cli/templates/dashboard/builders/table-routes/common/drawer-panel.ts +27 -27
  58. package/cli/templates/dashboard/builders/table-routes/common/pagination.ts +30 -30
  59. package/cli/templates/dashboard/builders/table-routes/common/search-bar.ts +23 -23
  60. package/cli/templates/dashboard/builders/table-routes/fragments.ts +217 -217
  61. package/cli/templates/dashboard/builders/table-routes/helpers.ts +45 -45
  62. package/cli/templates/dashboard/builders/table-routes/index.ts +8 -8
  63. package/cli/templates/dashboard/builders/table-routes/table/actions-cell.ts +71 -71
  64. package/cli/templates/dashboard/builders/table-routes/table/get-route.ts +291 -291
  65. package/cli/templates/dashboard/builders/table-routes/table/index.ts +80 -80
  66. package/cli/templates/dashboard/builders/table-routes/table/post-routes.ts +163 -163
  67. package/cli/templates/dashboard/builders/table-routes/table-route.ts +7 -7
  68. package/cli/templates/dashboard/builders/table-routes/users/get-route.ts +69 -69
  69. package/cli/templates/dashboard/builders/table-routes/users/html/modals.ts +57 -57
  70. package/cli/templates/dashboard/builders/table-routes/users/html/page.ts +27 -27
  71. package/cli/templates/dashboard/builders/table-routes/users/html/table.ts +128 -128
  72. package/cli/templates/dashboard/builders/table-routes/users/index.ts +32 -32
  73. package/cli/templates/dashboard/builders/table-routes/users/post-routes.ts +150 -150
  74. package/cli/templates/dashboard/builders/table-routes/users/redirect.ts +14 -14
  75. package/cli/templates/dashboard/builders/table-routes/users-route.ts +10 -10
  76. package/cli/templates/dashboard/components/dashboard-home.ts +23 -23
  77. package/cli/templates/dashboard/components/layout.ts +420 -420
  78. package/cli/templates/dashboard/components/login-page.ts +65 -65
  79. package/cli/templates/dashboard/index.ts +61 -61
  80. package/cli/templates/dashboard/types.ts +9 -9
  81. package/cli/templates/handlers/README.md +353 -353
  82. package/cli/templates/handlers/auth.ts +37 -37
  83. package/cli/templates/handlers/execution.ts +42 -42
  84. package/cli/templates/handlers/generators/context/context-creation.ts +101 -101
  85. package/cli/templates/handlers/generators/context/error-helpers.ts +11 -11
  86. package/cli/templates/handlers/generators/context/scheduler.ts +24 -24
  87. package/cli/templates/handlers/generators/context/storage-api.ts +82 -82
  88. package/cli/templates/handlers/generators/context/storage-helpers.ts +59 -59
  89. package/cli/templates/handlers/generators/context/types.ts +40 -40
  90. package/cli/templates/handlers/generators/context.ts +43 -43
  91. package/cli/templates/handlers/generators/execution.ts +15 -15
  92. package/cli/templates/handlers/generators/handlers.ts +14 -14
  93. package/cli/templates/handlers/generators/registration/modules/cron.ts +26 -26
  94. package/cli/templates/handlers/generators/registration/modules/realtime/auth.ts +75 -75
  95. package/cli/templates/handlers/generators/registration/modules/realtime/durable-object.ts +144 -144
  96. package/cli/templates/handlers/generators/registration/modules/realtime/index.ts +14 -14
  97. package/cli/templates/handlers/generators/registration/modules/realtime/publisher.ts +102 -102
  98. package/cli/templates/handlers/generators/registration/modules/realtime/routes.ts +164 -164
  99. package/cli/templates/handlers/generators/registration/modules/realtime/types.ts +30 -30
  100. package/cli/templates/handlers/generators/registration/modules/realtime/utils.ts +510 -510
  101. package/cli/templates/handlers/generators/registration/modules/scheduler.ts +56 -56
  102. package/cli/templates/handlers/generators/registration/modules/storage.ts +199 -199
  103. package/cli/templates/handlers/generators/registration/sections.ts +210 -210
  104. package/cli/templates/handlers/generators/types/context.ts +121 -121
  105. package/cli/templates/handlers/generators/types/core.ts +106 -106
  106. package/cli/templates/handlers/generators/types/operations.ts +135 -135
  107. package/cli/templates/handlers/generators/types/query-definitions/filter-and-where-types.ts +291 -271
  108. package/cli/templates/handlers/generators/types/query-definitions/query-api-types.ts +135 -135
  109. package/cli/templates/handlers/generators/types/query-definitions/query-helper-functions.ts +1382 -1382
  110. package/cli/templates/handlers/generators/types/query-definitions/schema-and-table-types.ts +278 -278
  111. package/cli/templates/handlers/generators/types/query-definitions.ts +13 -13
  112. package/cli/templates/handlers/generators/types/query-runtime/handled-error.ts +13 -13
  113. package/cli/templates/handlers/generators/types/query-runtime/runtime-aggregate-and-footer.ts +174 -174
  114. package/cli/templates/handlers/generators/types/query-runtime/runtime-read.ts +157 -157
  115. package/cli/templates/handlers/generators/types/query-runtime/runtime-setup.ts +45 -45
  116. package/cli/templates/handlers/generators/types/query-runtime/runtime-write.ts +958 -697
  117. package/cli/templates/handlers/generators/types/query-runtime.ts +15 -15
  118. package/cli/templates/handlers/index.ts +47 -47
  119. package/cli/templates/handlers/operations.ts +116 -116
  120. package/cli/templates/handlers/registration.ts +91 -91
  121. package/cli/templates/handlers/types.ts +17 -17
  122. package/cli/templates/handlers/utils.ts +48 -48
  123. package/cli/types.ts +110 -110
  124. package/cli/utils/handler-discovery.ts +466 -466
  125. package/cli/utils/json-utils.ts +24 -24
  126. package/cli/utils/path-utils.ts +19 -19
  127. package/cli/utils/schema-discovery.ts +399 -399
  128. package/dist/cli/index.js +320 -31
  129. package/dist/cli/index.mjs +320 -31
  130. package/dist/index.js +1 -1
  131. package/dist/index.mjs +1 -1
  132. package/dist/react/index.d.mts +2 -0
  133. package/dist/react/index.d.ts +2 -0
  134. package/dist/react/index.js +1 -1
  135. package/dist/react/index.mjs +1 -1
  136. package/index.ts +18 -18
  137. package/package.json +58 -58
  138. package/react/index.ts +5 -5
  139. package/react/use-infinite-query.ts +255 -252
  140. package/react/use-mutation.ts +89 -89
  141. package/react/use-query.ts +210 -207
  142. package/schema.ts +641 -641
  143. package/test-better-auth-hash.ts +2 -2
  144. package/tsconfig.json +6 -6
  145. package/tsup.config.ts +82 -82
@@ -1,59 +1,59 @@
1
- export function generateStorageHelpers(): string {
2
- return `
3
- function normalizeStoragePath(path: string): string {
4
- const trimmed = path.trim();
5
- if (trimmed.length === 0) {
6
- throw new Error("Storage path is required");
7
- }
8
-
9
- const withoutLeadingSlash = trimmed.replace(/^\\/+/, "");
10
- if (withoutLeadingSlash.length === 0) {
11
- throw new Error("Storage path is required");
12
- }
13
-
14
- return withoutLeadingSlash;
15
- }
16
-
17
- function normalizeStorageMethod(method: StorageMethod | undefined): StorageMethod {
18
- return method ?? "get";
19
- }
20
-
21
- function sanitizeSignedFileName(fileName: string | undefined): string | null {
22
- if (!fileName) {
23
- return null;
24
- }
25
-
26
- const normalized = fileName.replace(/[\\r\\n\\"]/g, "").trim();
27
- return normalized.length > 0 ? normalized : null;
28
- }
29
-
30
- function buildSignedRequest(
31
- args: StorageSignedUrlArgs,
32
- path: string,
33
- ): Request {
34
- const method = args.method ?? "GET";
35
- const endpoint = new URL("https://r2.appflare.local/" + encodeURI(path));
36
- const headers = new Headers();
37
-
38
- if (args.contentType) {
39
- headers.set("content-type", args.contentType);
40
- }
41
-
42
- if (method === "GET") {
43
- const disposition = args.downloadAsAttachment === false ? "inline" : "attachment";
44
- const fileName = sanitizeSignedFileName(args.fileName);
45
- headers.set(
46
- "response-content-disposition",
47
- fileName
48
- ? disposition + '; filename="' + fileName + '"'
49
- : disposition,
50
- );
51
- }
52
-
53
- return new Request(endpoint.toString(), {
54
- method,
55
- headers,
56
- });
57
- }
58
- `;
59
- }
1
+ export function generateStorageHelpers(): string {
2
+ return `
3
+ function normalizeStoragePath(path: string): string {
4
+ const trimmed = path.trim();
5
+ if (trimmed.length === 0) {
6
+ throw new Error("Storage path is required");
7
+ }
8
+
9
+ const withoutLeadingSlash = trimmed.replace(/^\\/+/, "");
10
+ if (withoutLeadingSlash.length === 0) {
11
+ throw new Error("Storage path is required");
12
+ }
13
+
14
+ return withoutLeadingSlash;
15
+ }
16
+
17
+ function normalizeStorageMethod(method: StorageMethod | undefined): StorageMethod {
18
+ return method ?? "get";
19
+ }
20
+
21
+ function sanitizeSignedFileName(fileName: string | undefined): string | null {
22
+ if (!fileName) {
23
+ return null;
24
+ }
25
+
26
+ const normalized = fileName.replace(/[\\r\\n\\"]/g, "").trim();
27
+ return normalized.length > 0 ? normalized : null;
28
+ }
29
+
30
+ function buildSignedRequest(
31
+ args: StorageSignedUrlArgs,
32
+ path: string,
33
+ ): Request {
34
+ const method = args.method ?? "GET";
35
+ const endpoint = new URL("https://r2.appflare.local/" + encodeURI(path));
36
+ const headers = new Headers();
37
+
38
+ if (args.contentType) {
39
+ headers.set("content-type", args.contentType);
40
+ }
41
+
42
+ if (method === "GET") {
43
+ const disposition = args.downloadAsAttachment === false ? "inline" : "attachment";
44
+ const fileName = sanitizeSignedFileName(args.fileName);
45
+ headers.set(
46
+ "response-content-disposition",
47
+ fileName
48
+ ? disposition + '; filename="' + fileName + '"'
49
+ : disposition,
50
+ );
51
+ }
52
+
53
+ return new Request(endpoint.toString(), {
54
+ method,
55
+ headers,
56
+ });
57
+ }
58
+ `;
59
+ }
@@ -1,40 +1,40 @@
1
- export function generateContextTypes(): string {
2
- return `
3
- type SchedulerQueueBinding = {
4
- send: (body: unknown, options?: SchedulerEnqueueOptions) => Promise<void>;
5
- };
6
-
7
- type R2ObjectBody = {
8
- body: ReadableStream;
9
- bodyUsed: boolean;
10
- writeHttpResponse: (response: Response) => void;
11
- httpMetadata?: Record<string, string | undefined>;
12
- customMetadata?: Record<string, string>;
13
- range?: { offset: number; length: number };
14
- size: number;
15
- etag: string;
16
- httpEtag: string;
17
- checksums: {
18
- md5?: ArrayBuffer;
19
- sha1?: ArrayBuffer;
20
- sha256?: ArrayBuffer;
21
- sha384?: ArrayBuffer;
22
- sha512?: ArrayBuffer;
23
- };
24
- uploaded: Date;
25
- key: string;
26
- contentType?: string;
27
- };
28
-
29
- type R2BucketBinding = {
30
- put: (key: string, value: unknown, options?: Record<string, unknown>) => Promise<unknown>;
31
- get: (key: string, options?: Record<string, unknown>) => Promise<R2ObjectBody | null>;
32
- delete: (key: string | string[]) => Promise<void>;
33
- list: (options?: Record<string, unknown>) => Promise<unknown>;
34
- createPresignedUrl?: (
35
- request: Request,
36
- options?: { expiresIn?: number },
37
- ) => Promise<URL>;
38
- };
39
- `;
40
- }
1
+ export function generateContextTypes(): string {
2
+ return `
3
+ type SchedulerQueueBinding = {
4
+ send: (body: unknown, options?: SchedulerEnqueueOptions) => Promise<void>;
5
+ };
6
+
7
+ type R2ObjectBody = {
8
+ body: ReadableStream;
9
+ bodyUsed: boolean;
10
+ writeHttpResponse: (response: Response) => void;
11
+ httpMetadata?: Record<string, string | undefined>;
12
+ customMetadata?: Record<string, string>;
13
+ range?: { offset: number; length: number };
14
+ size: number;
15
+ etag: string;
16
+ httpEtag: string;
17
+ checksums: {
18
+ md5?: ArrayBuffer;
19
+ sha1?: ArrayBuffer;
20
+ sha256?: ArrayBuffer;
21
+ sha384?: ArrayBuffer;
22
+ sha512?: ArrayBuffer;
23
+ };
24
+ uploaded: Date;
25
+ key: string;
26
+ contentType?: string;
27
+ };
28
+
29
+ type R2BucketBinding = {
30
+ put: (key: string, value: unknown, options?: Record<string, unknown>) => Promise<unknown>;
31
+ get: (key: string, options?: Record<string, unknown>) => Promise<R2ObjectBody | null>;
32
+ delete: (key: string | string[]) => Promise<void>;
33
+ list: (options?: Record<string, unknown>) => Promise<unknown>;
34
+ createPresignedUrl?: (
35
+ request: Request,
36
+ options?: { expiresIn?: number },
37
+ ) => Promise<URL>;
38
+ };
39
+ `;
40
+ }
@@ -1,43 +1,43 @@
1
- import { generateAuth } from "../auth";
2
- import { generateContextTypes } from "./context/types";
3
- import { generateSchedulerFunctions } from "./context/scheduler";
4
- import { generateErrorHelpers } from "./context/error-helpers";
5
- import { generateStorageHelpers } from "./context/storage-helpers";
6
- import { generateStorageApi } from "./context/storage-api";
7
- import { generateContextCreation } from "./context/context-creation";
8
-
9
- export function generateContextSource(defaultR2Binding?: string): string {
10
- return `import type { Context } from "hono";
11
- import type { D1Database, IncomingRequestCfProperties, KVNamespace } from "@cloudflare/workers-types";
12
- import { createAuth } from "./auth.config";
13
- import {
14
- type AppflareContext,
15
- type AppflareStorage,
16
- AppflareHandledError,
17
- type Scheduler,
18
- type SchedulerEnqueueOptions,
19
- type RegisterHandlersOptions,
20
- type StorageAuthorizationArgs,
21
- type StorageMethod,
22
- type StorageSignedUrlArgs,
23
- type WorkerEnv,
24
- isStorageAllowed,
25
- createDb,
26
- createQueryDb,
27
- } from "./handlers";
28
-
29
- ${generateContextTypes()}
30
-
31
- ${generateAuth()}
32
-
33
- ${generateSchedulerFunctions()}
34
-
35
- ${generateErrorHelpers()}
36
-
37
- ${generateStorageHelpers()}
38
-
39
- ${generateStorageApi()}
40
-
41
- ${generateContextCreation(defaultR2Binding)}
42
- `;
43
- }
1
+ import { generateAuth } from "../auth";
2
+ import { generateContextTypes } from "./context/types";
3
+ import { generateSchedulerFunctions } from "./context/scheduler";
4
+ import { generateErrorHelpers } from "./context/error-helpers";
5
+ import { generateStorageHelpers } from "./context/storage-helpers";
6
+ import { generateStorageApi } from "./context/storage-api";
7
+ import { generateContextCreation } from "./context/context-creation";
8
+
9
+ export function generateContextSource(defaultR2Binding?: string): string {
10
+ return `import type { Context } from "hono";
11
+ import type { D1Database, IncomingRequestCfProperties, KVNamespace } from "@cloudflare/workers-types";
12
+ import { createAuth } from "./auth.config";
13
+ import {
14
+ type AppflareContext,
15
+ type AppflareStorage,
16
+ AppflareHandledError,
17
+ type Scheduler,
18
+ type SchedulerEnqueueOptions,
19
+ type RegisterHandlersOptions,
20
+ type StorageAuthorizationArgs,
21
+ type StorageMethod,
22
+ type StorageSignedUrlArgs,
23
+ type WorkerEnv,
24
+ isStorageAllowed,
25
+ createDb,
26
+ createQueryDb,
27
+ } from "./handlers";
28
+
29
+ ${generateContextTypes()}
30
+
31
+ ${generateAuth()}
32
+
33
+ ${generateSchedulerFunctions()}
34
+
35
+ ${generateErrorHelpers()}
36
+
37
+ ${generateStorageHelpers()}
38
+
39
+ ${generateStorageApi()}
40
+
41
+ ${generateContextCreation(defaultR2Binding)}
42
+ `;
43
+ }
@@ -1,15 +1,15 @@
1
- import { generateExecution } from "../execution";
2
-
3
- export function generateExecutionSource(): string {
4
- return `import type { Context } from "hono";
5
- import { ZodError, type ZodRawShape } from "zod";
6
- import {
7
- type AppflareContext,
8
- AppflareHandledError,
9
- type RegisteredOperation,
10
- type WorkerEnv,
11
- } from "./handlers";
12
-
13
- ${generateExecution()}
14
- `;
15
- }
1
+ import { generateExecution } from "../execution";
2
+
3
+ export function generateExecutionSource(): string {
4
+ return `import type { Context } from "hono";
5
+ import { ZodError, type ZodRawShape } from "zod";
6
+ import {
7
+ type AppflareContext,
8
+ AppflareHandledError,
9
+ type RegisteredOperation,
10
+ type WorkerEnv,
11
+ } from "./handlers";
12
+
13
+ ${generateExecution()}
14
+ `;
15
+ }
@@ -1,14 +1,14 @@
1
- import { generateTypes } from "../types";
2
- import type { AdditionalField } from "../types";
3
-
4
- export function generateHandlersSource(schemaImportPath: string, roles: string[] = [], additionalFields: AdditionalField[] = []): string {
5
- return `import type { Context } from "hono";
6
- import type { D1Database } from "@cloudflare/workers-types";
7
- import { drizzle } from "drizzle-orm/d1";
8
- import { z, type ZodRawShape } from "zod";
9
- import * as authSchema from "./auth.schema";
10
- import * as schema from "${schemaImportPath}";
11
-
12
- ${generateTypes(roles, additionalFields)}
13
- `;
14
- }
1
+ import { generateTypes } from "../types";
2
+ import type { AdditionalField } from "../types";
3
+
4
+ export function generateHandlersSource(schemaImportPath: string, roles: string[] = [], additionalFields: AdditionalField[] = []): string {
5
+ return `import type { Context } from "hono";
6
+ import type { D1Database } from "@cloudflare/workers-types";
7
+ import { drizzle } from "drizzle-orm/d1";
8
+ import { z, type ZodRawShape } from "zod";
9
+ import * as authSchema from "./auth.schema";
10
+ import * as schema from "${schemaImportPath}";
11
+
12
+ ${generateTypes(roles, additionalFields)}
13
+ `;
14
+ }
@@ -1,26 +1,26 @@
1
- export const cronModule = `
2
- export async function executeCronTriggers(
3
- controller: { cron: string },
4
- env: Record<string, unknown>,
5
- options: RegisterHandlersOptions,
6
- ): Promise<void> {
7
- const cronValue = controller?.cron;
8
- if (!cronValue) {
9
- return;
10
- }
11
-
12
- const ctx = await createSchedulerExecutionContext(env, options);
13
-
14
- for (const cronEntry of cronHandlers) {
15
- if (!cronEntry.cronTriggers.includes(cronValue)) {
16
- continue;
17
- }
18
-
19
- try {
20
- await cronEntry.definition.handler(ctx);
21
- } catch (error) {
22
- console.error("Cron task failed", cronEntry.taskName, error);
23
- }
24
- }
25
- }
26
- `;
1
+ export const cronModule = `
2
+ export async function executeCronTriggers(
3
+ controller: { cron: string },
4
+ env: Record<string, unknown>,
5
+ options: RegisterHandlersOptions,
6
+ ): Promise<void> {
7
+ const cronValue = controller?.cron;
8
+ if (!cronValue) {
9
+ return;
10
+ }
11
+
12
+ const ctx = await createSchedulerExecutionContext(env, options);
13
+
14
+ for (const cronEntry of cronHandlers) {
15
+ if (!cronEntry.cronTriggers.includes(cronValue)) {
16
+ continue;
17
+ }
18
+
19
+ try {
20
+ await cronEntry.definition.handler(ctx);
21
+ } catch (error) {
22
+ console.error("Cron task failed", cronEntry.taskName, error);
23
+ }
24
+ }
25
+ }
26
+ `;
@@ -1,75 +1,75 @@
1
- export const realtimeAuthModule = `
2
- function getRealtimeStub(
3
- env: Record<string, unknown>,
4
- options: RegisterHandlersOptions,
5
- ): RealtimeStub | null {
6
- const binding = options.realtimeBinding ?? "APPFLARE_REALTIME";
7
- const namespace = env[binding] as RealtimeDurableObjectNamespace | undefined;
8
- if (!namespace) {
9
- return null;
10
- }
11
-
12
- const objectName = options.realtimeObjectName ?? "global";
13
- const objectId = namespace.idFromName(objectName);
14
- return namespace.get(objectId);
15
- }
16
-
17
- async function validateAuthToken(
18
- request: Request,
19
- env: Record<string, unknown>,
20
- options: RegisterHandlersOptions,
21
- authToken: string,
22
- ): Promise<{ user: unknown; session: unknown } | null> {
23
- const database = env[options.databaseBinding] as D1Database | undefined;
24
- if (!database) {
25
- return null;
26
- }
27
-
28
- const kvNamespace = options.kvBinding
29
- ? (env[options.kvBinding] as KVNamespace | undefined)
30
- : undefined;
31
- const headers = new Headers(request.headers);
32
- headers.set("authorization", "Bearer " + authToken);
33
- headers.delete("upgrade");
34
- headers.delete("connection");
35
- for (const key of [...headers.keys()]) {
36
- if (key.toLowerCase().startsWith("sec-websocket")) {
37
- headers.delete(key);
38
- }
39
- }
40
- const tokenRequest = new Request(request.url, {
41
- method: "GET",
42
- headers,
43
- });
44
-
45
- const session = await resolveSession(
46
- tokenRequest,
47
- database,
48
- kvNamespace,
49
- request.cf as IncomingRequestCfProperties | undefined,
50
- );
51
-
52
- if (!session?.user) {
53
- return null;
54
- }
55
-
56
- return session;
57
- }
58
-
59
- function extractUserId(user: unknown): string {
60
- if (!isRecord(user)) {
61
- return "unknown";
62
- }
63
-
64
- const id = user.id;
65
- return typeof id === "string" && id.length > 0 ? id : "unknown";
66
- }
67
-
68
- function buildRealtimeWsUrl(requestUrl: string, websocketPath: string): string {
69
- const url = new URL(requestUrl);
70
- url.pathname = websocketPath;
71
- url.search = "";
72
- url.protocol = url.protocol === "https:" ? "wss:" : "ws:";
73
- return url.toString();
74
- }
75
- `;
1
+ export const realtimeAuthModule = `
2
+ function getRealtimeStub(
3
+ env: Record<string, unknown>,
4
+ options: RegisterHandlersOptions,
5
+ ): RealtimeStub | null {
6
+ const binding = options.realtimeBinding ?? "APPFLARE_REALTIME";
7
+ const namespace = env[binding] as RealtimeDurableObjectNamespace | undefined;
8
+ if (!namespace) {
9
+ return null;
10
+ }
11
+
12
+ const objectName = options.realtimeObjectName ?? "global";
13
+ const objectId = namespace.idFromName(objectName);
14
+ return namespace.get(objectId);
15
+ }
16
+
17
+ async function validateAuthToken(
18
+ request: Request,
19
+ env: Record<string, unknown>,
20
+ options: RegisterHandlersOptions,
21
+ authToken: string,
22
+ ): Promise<{ user: unknown; session: unknown } | null> {
23
+ const database = env[options.databaseBinding] as D1Database | undefined;
24
+ if (!database) {
25
+ return null;
26
+ }
27
+
28
+ const kvNamespace = options.kvBinding
29
+ ? (env[options.kvBinding] as KVNamespace | undefined)
30
+ : undefined;
31
+ const headers = new Headers(request.headers);
32
+ headers.set("authorization", "Bearer " + authToken);
33
+ headers.delete("upgrade");
34
+ headers.delete("connection");
35
+ for (const key of [...headers.keys()]) {
36
+ if (key.toLowerCase().startsWith("sec-websocket")) {
37
+ headers.delete(key);
38
+ }
39
+ }
40
+ const tokenRequest = new Request(request.url, {
41
+ method: "GET",
42
+ headers,
43
+ });
44
+
45
+ const session = await resolveSession(
46
+ tokenRequest,
47
+ database,
48
+ kvNamespace,
49
+ request.cf as IncomingRequestCfProperties | undefined,
50
+ );
51
+
52
+ if (!session?.user) {
53
+ return null;
54
+ }
55
+
56
+ return session;
57
+ }
58
+
59
+ function extractUserId(user: unknown): string {
60
+ if (!isRecord(user)) {
61
+ return "unknown";
62
+ }
63
+
64
+ const id = user.id;
65
+ return typeof id === "string" && id.length > 0 ? id : "unknown";
66
+ }
67
+
68
+ function buildRealtimeWsUrl(requestUrl: string, websocketPath: string): string {
69
+ const url = new URL(requestUrl);
70
+ url.pathname = websocketPath;
71
+ url.search = "";
72
+ url.protocol = url.protocol === "https:" ? "wss:" : "ws:";
73
+ return url.toString();
74
+ }
75
+ `;