appflare 0.2.25 → 0.2.26
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/Documentation.md +758 -758
- package/cli/commands/index.ts +238 -238
- package/cli/generate.ts +178 -178
- package/cli/index.ts +120 -120
- package/cli/load-config.ts +184 -184
- package/cli/schema-compiler.ts +1183 -1183
- package/cli/templates/auth/README.md +156 -156
- package/cli/templates/auth/config.ts +61 -61
- package/cli/templates/auth/route-config.ts +1 -1
- package/cli/templates/auth/route-handler.ts +1 -1
- package/cli/templates/auth/route-request-utils.ts +5 -5
- package/cli/templates/auth/route.config.ts +18 -18
- package/cli/templates/auth/route.handler.ts +18 -18
- package/cli/templates/auth/route.request-utils.ts +55 -55
- package/cli/templates/auth/route.ts +14 -14
- package/cli/templates/core/README.md +266 -266
- package/cli/templates/core/app-creation.ts +19 -19
- package/cli/templates/core/client/appflare.ts +112 -112
- package/cli/templates/core/client/handlers/index.ts +748 -748
- package/cli/templates/core/client/handlers.ts +1 -1
- package/cli/templates/core/client/index.ts +7 -7
- package/cli/templates/core/client/storage.ts +180 -180
- package/cli/templates/core/client/types.ts +184 -184
- package/cli/templates/core/client-modules/appflare.ts +1 -1
- package/cli/templates/core/client-modules/handlers.ts +1 -1
- package/cli/templates/core/client-modules/index.ts +1 -1
- package/cli/templates/core/client-modules/storage.ts +1 -1
- package/cli/templates/core/client-modules/types.ts +1 -1
- package/cli/templates/core/client.artifacts.ts +39 -39
- package/cli/templates/core/client.ts +4 -4
- package/cli/templates/core/drizzle.ts +15 -15
- package/cli/templates/core/export.ts +14 -14
- package/cli/templates/core/handlers.route.ts +24 -24
- package/cli/templates/core/handlers.ts +1 -1
- package/cli/templates/core/imports.ts +9 -9
- package/cli/templates/core/server.ts +38 -38
- package/cli/templates/core/types.ts +6 -6
- package/cli/templates/core/wrangler.ts +109 -109
- package/cli/templates/dashboard/builders/functions/index.ts +17 -17
- package/cli/templates/dashboard/builders/functions/render-page/header.ts +20 -20
- package/cli/templates/dashboard/builders/functions/render-page/index.ts +33 -33
- package/cli/templates/dashboard/builders/functions/render-page/request-panel.ts +171 -171
- package/cli/templates/dashboard/builders/functions/render-page/result-panel.ts +85 -85
- package/cli/templates/dashboard/builders/functions/render-page/scripts.ts +554 -554
- package/cli/templates/dashboard/builders/navigation.ts +122 -122
- package/cli/templates/dashboard/builders/storage/index.ts +13 -13
- package/cli/templates/dashboard/builders/storage/routes/create-directory-route.ts +29 -29
- package/cli/templates/dashboard/builders/storage/routes/delete-route.ts +18 -18
- package/cli/templates/dashboard/builders/storage/routes/download-route.ts +23 -23
- package/cli/templates/dashboard/builders/storage/routes/index.ts +22 -22
- package/cli/templates/dashboard/builders/storage/routes/list-route.ts +25 -25
- package/cli/templates/dashboard/builders/storage/routes/preview-route.ts +21 -21
- package/cli/templates/dashboard/builders/storage/routes/upload-route.ts +21 -21
- package/cli/templates/dashboard/builders/storage/runtime/helpers.ts +72 -72
- package/cli/templates/dashboard/builders/storage/runtime/storage-page.ts +130 -130
- package/cli/templates/dashboard/builders/table-routes/common/drawer-panel.ts +27 -27
- package/cli/templates/dashboard/builders/table-routes/common/pagination.ts +30 -30
- package/cli/templates/dashboard/builders/table-routes/common/search-bar.ts +23 -23
- package/cli/templates/dashboard/builders/table-routes/fragments.ts +217 -217
- package/cli/templates/dashboard/builders/table-routes/helpers.ts +45 -45
- package/cli/templates/dashboard/builders/table-routes/index.ts +8 -8
- package/cli/templates/dashboard/builders/table-routes/table/actions-cell.ts +71 -71
- package/cli/templates/dashboard/builders/table-routes/table/get-route.ts +291 -291
- package/cli/templates/dashboard/builders/table-routes/table/index.ts +80 -80
- package/cli/templates/dashboard/builders/table-routes/table/post-routes.ts +163 -163
- package/cli/templates/dashboard/builders/table-routes/table-route.ts +7 -7
- package/cli/templates/dashboard/builders/table-routes/users/get-route.ts +69 -69
- package/cli/templates/dashboard/builders/table-routes/users/html/modals.ts +57 -57
- package/cli/templates/dashboard/builders/table-routes/users/html/page.ts +27 -27
- package/cli/templates/dashboard/builders/table-routes/users/html/table.ts +128 -128
- package/cli/templates/dashboard/builders/table-routes/users/index.ts +32 -32
- package/cli/templates/dashboard/builders/table-routes/users/post-routes.ts +150 -150
- package/cli/templates/dashboard/builders/table-routes/users/redirect.ts +14 -14
- package/cli/templates/dashboard/builders/table-routes/users-route.ts +10 -10
- package/cli/templates/dashboard/components/dashboard-home.ts +23 -23
- package/cli/templates/dashboard/components/layout.ts +388 -388
- package/cli/templates/dashboard/components/login-page.ts +65 -65
- package/cli/templates/dashboard/index.ts +61 -61
- package/cli/templates/dashboard/types.ts +9 -9
- package/cli/templates/handlers/README.md +353 -353
- package/cli/templates/handlers/auth.ts +37 -37
- package/cli/templates/handlers/execution.ts +42 -42
- package/cli/templates/handlers/generators/context/context-creation.ts +101 -101
- package/cli/templates/handlers/generators/context/error-helpers.ts +11 -11
- package/cli/templates/handlers/generators/context/scheduler.ts +24 -24
- package/cli/templates/handlers/generators/context/storage-api.ts +134 -112
- package/cli/templates/handlers/generators/context/storage-helpers.ts +59 -59
- package/cli/templates/handlers/generators/context/types.ts +18 -18
- package/cli/templates/handlers/generators/context.ts +43 -43
- package/cli/templates/handlers/generators/execution.ts +15 -15
- package/cli/templates/handlers/generators/handlers.ts +13 -13
- package/cli/templates/handlers/generators/registration/modules/cron.ts +26 -26
- package/cli/templates/handlers/generators/registration/modules/realtime/auth.ts +75 -75
- package/cli/templates/handlers/generators/registration/modules/realtime/durable-object.ts +144 -144
- package/cli/templates/handlers/generators/registration/modules/realtime/index.ts +14 -14
- package/cli/templates/handlers/generators/registration/modules/realtime/publisher.ts +102 -102
- package/cli/templates/handlers/generators/registration/modules/realtime/routes.ts +164 -164
- package/cli/templates/handlers/generators/registration/modules/realtime/types.ts +30 -30
- package/cli/templates/handlers/generators/registration/modules/realtime/utils.ts +516 -516
- package/cli/templates/handlers/generators/registration/modules/scheduler.ts +56 -56
- package/cli/templates/handlers/generators/registration/modules/storage.ts +196 -194
- package/cli/templates/handlers/generators/registration/sections.ts +210 -210
- package/cli/templates/handlers/generators/types/context.ts +68 -66
- package/cli/templates/handlers/generators/types/core.ts +106 -106
- package/cli/templates/handlers/generators/types/operations.ts +135 -135
- package/cli/templates/handlers/generators/types/query-definitions/filter-and-where-types.ts +259 -259
- package/cli/templates/handlers/generators/types/query-definitions/query-api-types.ts +135 -135
- package/cli/templates/handlers/generators/types/query-definitions/query-helper-functions.ts +1031 -1031
- package/cli/templates/handlers/generators/types/query-definitions/schema-and-table-types.ts +246 -246
- package/cli/templates/handlers/generators/types/query-definitions.ts +13 -13
- package/cli/templates/handlers/generators/types/query-runtime/handled-error.ts +13 -13
- package/cli/templates/handlers/generators/types/query-runtime/runtime-aggregate-and-footer.ts +174 -174
- package/cli/templates/handlers/generators/types/query-runtime/runtime-read.ts +121 -121
- package/cli/templates/handlers/generators/types/query-runtime/runtime-setup.ts +45 -45
- package/cli/templates/handlers/generators/types/query-runtime/runtime-write.ts +676 -676
- package/cli/templates/handlers/generators/types/query-runtime.ts +15 -15
- package/cli/templates/handlers/index.ts +43 -43
- package/cli/templates/handlers/operations.ts +116 -116
- package/cli/templates/handlers/registration.ts +91 -91
- package/cli/templates/handlers/types.ts +15 -15
- package/cli/templates/handlers/utils.ts +48 -48
- package/cli/types.ts +110 -110
- package/cli/utils/handler-discovery.ts +466 -466
- package/cli/utils/json-utils.ts +24 -24
- package/cli/utils/path-utils.ts +19 -19
- package/cli/utils/schema-discovery.ts +399 -399
- package/dist/cli/index.js +43 -17
- package/dist/cli/index.mjs +43 -17
- package/index.ts +18 -18
- package/package.json +58 -58
- package/react/index.ts +5 -5
- package/react/use-infinite-query.ts +252 -252
- package/react/use-mutation.ts +89 -89
- package/react/use-query.ts +207 -207
- package/schema.ts +415 -415
- package/test-better-auth-hash.ts +2 -2
- package/tsconfig.json +6 -6
- package/tsup.config.ts +82 -82
- package/dist/cli/index.d.mts +0 -2
- package/dist/cli/index.d.ts +0 -2
|
@@ -1,112 +1,134 @@
|
|
|
1
|
-
export function generateStorageApi(): string {
|
|
2
|
-
return `
|
|
3
|
-
function createStorageApi(
|
|
4
|
-
ctx: AppflareContext,
|
|
5
|
-
bucket: R2BucketBinding | undefined,
|
|
6
|
-
): AppflareStorage {
|
|
7
|
-
const assertAuthorized = async (args: StorageAuthorizationArgs): Promise<void> => {
|
|
8
|
-
const allowed = await isStorageAllowed(ctx, args);
|
|
9
|
-
if (!allowed) {
|
|
10
|
-
ctx.error(403, "Storage access denied", {
|
|
11
|
-
path: args.path,
|
|
12
|
-
method: args.method,
|
|
13
|
-
});
|
|
14
|
-
}
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
-
const requireBucket = (): R2BucketBinding => {
|
|
18
|
-
if (!bucket) {
|
|
19
|
-
throw new Error(
|
|
20
|
-
"R2 binding is not configured. Set r2 in appflare.config.ts and regenerate artifacts.",
|
|
21
|
-
);
|
|
22
|
-
}
|
|
23
|
-
return bucket;
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
return {
|
|
27
|
-
put: async (args) => {
|
|
28
|
-
const path = normalizeStoragePath(args.path);
|
|
29
|
-
await assertAuthorized({
|
|
30
|
-
path: "/" + path,
|
|
31
|
-
method: "put",
|
|
32
|
-
contentType: args.contentType,
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
},
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
const
|
|
103
|
-
const
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
1
|
+
export function generateStorageApi(): string {
|
|
2
|
+
return `
|
|
3
|
+
function createStorageApi(
|
|
4
|
+
ctx: AppflareContext,
|
|
5
|
+
bucket: R2BucketBinding | undefined,
|
|
6
|
+
): AppflareStorage {
|
|
7
|
+
const assertAuthorized = async (args: StorageAuthorizationArgs): Promise<void> => {
|
|
8
|
+
const allowed = await isStorageAllowed(ctx, args);
|
|
9
|
+
if (!allowed) {
|
|
10
|
+
ctx.error(403, "Storage access denied", {
|
|
11
|
+
path: args.path,
|
|
12
|
+
method: args.method,
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
const requireBucket = (): R2BucketBinding => {
|
|
18
|
+
if (!bucket) {
|
|
19
|
+
throw new Error(
|
|
20
|
+
"R2 binding is not configured. Set r2 in appflare.config.ts and regenerate artifacts.",
|
|
21
|
+
);
|
|
22
|
+
}
|
|
23
|
+
return bucket;
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
return {
|
|
27
|
+
put: async (args) => {
|
|
28
|
+
const path = normalizeStoragePath(args.path);
|
|
29
|
+
await assertAuthorized({
|
|
30
|
+
path: "/" + path,
|
|
31
|
+
method: "put",
|
|
32
|
+
contentType: args.contentType,
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
if (args.returnSignedUrlOnly) {
|
|
36
|
+
const currentBucket = requireBucket();
|
|
37
|
+
if (typeof currentBucket.createPresignedUrl !== "function") {
|
|
38
|
+
throw new Error("R2 createPresignedUrl is unavailable for this runtime binding");
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
const signedRequest = buildSignedRequest(
|
|
42
|
+
{
|
|
43
|
+
path,
|
|
44
|
+
method: "PUT",
|
|
45
|
+
contentType: args.contentType,
|
|
46
|
+
expiresIn: args.expiresIn,
|
|
47
|
+
},
|
|
48
|
+
path,
|
|
49
|
+
);
|
|
50
|
+
const signedUrl = await currentBucket.createPresignedUrl(signedRequest, {
|
|
51
|
+
expiresIn: args.expiresIn ?? 60 * 5,
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
return signedUrl.toString();
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
return requireBucket().put(path, args.body, {
|
|
58
|
+
httpMetadata: {
|
|
59
|
+
...(args.httpMetadata ?? {}),
|
|
60
|
+
...(args.contentType ? { contentType: args.contentType } : {}),
|
|
61
|
+
},
|
|
62
|
+
customMetadata: args.customMetadata,
|
|
63
|
+
});
|
|
64
|
+
},
|
|
65
|
+
get: async (args) => {
|
|
66
|
+
const path = normalizeStoragePath(args.path);
|
|
67
|
+
const method = normalizeStorageMethod(args.method);
|
|
68
|
+
await assertAuthorized({
|
|
69
|
+
path: "/" + path,
|
|
70
|
+
method,
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
return requireBucket().get(path, {
|
|
74
|
+
onlyIf: args.onlyIf,
|
|
75
|
+
range: args.range,
|
|
76
|
+
});
|
|
77
|
+
},
|
|
78
|
+
delete: async (args) => {
|
|
79
|
+
const path = normalizeStoragePath(args.path);
|
|
80
|
+
await assertAuthorized({
|
|
81
|
+
path: "/" + path,
|
|
82
|
+
method: "delete",
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
await requireBucket().delete(path);
|
|
86
|
+
},
|
|
87
|
+
list: async (args = {}) => {
|
|
88
|
+
await assertAuthorized({
|
|
89
|
+
path: "/" + (args.prefix ?? ""),
|
|
90
|
+
method: args.method ?? "list",
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
return requireBucket().list({
|
|
94
|
+
prefix: args.prefix,
|
|
95
|
+
cursor: args.cursor,
|
|
96
|
+
limit: args.limit,
|
|
97
|
+
delimiter: args.delimiter,
|
|
98
|
+
include: args.include,
|
|
99
|
+
});
|
|
100
|
+
},
|
|
101
|
+
signedUrl: async (args) => {
|
|
102
|
+
const path = normalizeStoragePath(args.path);
|
|
103
|
+
const requestMethod = args.method ?? "GET";
|
|
104
|
+
const method: StorageMethod =
|
|
105
|
+
requestMethod === "PUT"
|
|
106
|
+
? "put"
|
|
107
|
+
: requestMethod === "DELETE"
|
|
108
|
+
? "delete"
|
|
109
|
+
: args.downloadAsAttachment === false
|
|
110
|
+
? "preview"
|
|
111
|
+
: "download";
|
|
112
|
+
|
|
113
|
+
await assertAuthorized({
|
|
114
|
+
path: "/" + path,
|
|
115
|
+
method,
|
|
116
|
+
contentType: args.contentType,
|
|
117
|
+
});
|
|
118
|
+
|
|
119
|
+
const currentBucket = requireBucket();
|
|
120
|
+
if (typeof currentBucket.createPresignedUrl !== "function") {
|
|
121
|
+
throw new Error("R2 createPresignedUrl is unavailable for this runtime binding");
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
const signedRequest = buildSignedRequest(args, path);
|
|
125
|
+
const signedUrl = await currentBucket.createPresignedUrl(signedRequest, {
|
|
126
|
+
expiresIn: args.expiresIn ?? 60 * 5,
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
return signedUrl.toString();
|
|
130
|
+
},
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
`;
|
|
134
|
+
}
|
|
@@ -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,18 +1,18 @@
|
|
|
1
|
-
export function generateContextTypes(): string {
|
|
2
|
-
return `
|
|
3
|
-
type SchedulerQueueBinding = {
|
|
4
|
-
send: (body: unknown, options?: SchedulerEnqueueOptions) => Promise<void>;
|
|
5
|
-
};
|
|
6
|
-
|
|
7
|
-
type R2BucketBinding = {
|
|
8
|
-
put: (key: string, value: unknown, options?: Record<string, unknown>) => Promise<unknown>;
|
|
9
|
-
get: (key: string, options?: Record<string, unknown>) => Promise<unknown | null>;
|
|
10
|
-
delete: (key: string | string[]) => Promise<void>;
|
|
11
|
-
list: (options?: Record<string, unknown>) => Promise<unknown>;
|
|
12
|
-
createPresignedUrl?: (
|
|
13
|
-
request: Request,
|
|
14
|
-
options?: { expiresIn?: number },
|
|
15
|
-
) => Promise<URL>;
|
|
16
|
-
};
|
|
17
|
-
`;
|
|
18
|
-
}
|
|
1
|
+
export function generateContextTypes(): string {
|
|
2
|
+
return `
|
|
3
|
+
type SchedulerQueueBinding = {
|
|
4
|
+
send: (body: unknown, options?: SchedulerEnqueueOptions) => Promise<void>;
|
|
5
|
+
};
|
|
6
|
+
|
|
7
|
+
type R2BucketBinding = {
|
|
8
|
+
put: (key: string, value: unknown, options?: Record<string, unknown>) => Promise<unknown>;
|
|
9
|
+
get: (key: string, options?: Record<string, unknown>) => Promise<unknown | null>;
|
|
10
|
+
delete: (key: string | string[]) => Promise<void>;
|
|
11
|
+
list: (options?: Record<string, unknown>) => Promise<unknown>;
|
|
12
|
+
createPresignedUrl?: (
|
|
13
|
+
request: Request,
|
|
14
|
+
options?: { expiresIn?: number },
|
|
15
|
+
) => Promise<URL>;
|
|
16
|
+
};
|
|
17
|
+
`;
|
|
18
|
+
}
|
|
@@ -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,13 +1,13 @@
|
|
|
1
|
-
import { generateTypes } from "../types";
|
|
2
|
-
|
|
3
|
-
export function generateHandlersSource(schemaImportPath: string): string {
|
|
4
|
-
return `import type { Context } from "hono";
|
|
5
|
-
import type { D1Database } from "@cloudflare/workers-types";
|
|
6
|
-
import { drizzle } from "drizzle-orm/d1";
|
|
7
|
-
import { z, type ZodRawShape } from "zod";
|
|
8
|
-
import * as authSchema from "./auth.schema";
|
|
9
|
-
import * as schema from "${schemaImportPath}";
|
|
10
|
-
|
|
11
|
-
${generateTypes()}
|
|
12
|
-
`;
|
|
13
|
-
}
|
|
1
|
+
import { generateTypes } from "../types";
|
|
2
|
+
|
|
3
|
+
export function generateHandlersSource(schemaImportPath: string): string {
|
|
4
|
+
return `import type { Context } from "hono";
|
|
5
|
+
import type { D1Database } from "@cloudflare/workers-types";
|
|
6
|
+
import { drizzle } from "drizzle-orm/d1";
|
|
7
|
+
import { z, type ZodRawShape } from "zod";
|
|
8
|
+
import * as authSchema from "./auth.schema";
|
|
9
|
+
import * as schema from "${schemaImportPath}";
|
|
10
|
+
|
|
11
|
+
${generateTypes()}
|
|
12
|
+
`;
|
|
13
|
+
}
|
|
@@ -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
|
+
`;
|