@kiyasov/platform-hono 1.3.20 → 1.4.1
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/.yarn/install-state.gz +0 -0
- package/dist/cjs/src/multer/interceptors/any-files-interceptor.js +1 -1
- package/dist/cjs/src/multer/interceptors/any-files-interceptor.js.map +1 -1
- package/dist/cjs/src/multer/interceptors/file-fields-interceptor.js +1 -1
- package/dist/cjs/src/multer/interceptors/file-fields-interceptor.js.map +1 -1
- package/dist/cjs/src/multer/interceptors/file-interceptor.js +1 -1
- package/dist/cjs/src/multer/interceptors/file-interceptor.js.map +1 -1
- package/dist/cjs/src/multer/interceptors/files-interceptor.js +1 -1
- package/dist/cjs/src/multer/interceptors/files-interceptor.js.map +1 -1
- package/dist/cjs/src/multer/storage/disk-storage.d.ts +2 -2
- package/dist/cjs/src/multer/storage/disk-storage.js +4 -4
- package/dist/cjs/src/multer/storage/disk-storage.js.map +1 -1
- package/dist/cjs/src/multer/storage/memory-storage.d.ts +5 -2
- package/dist/cjs/src/multer/storage/memory-storage.js +8 -2
- package/dist/cjs/src/multer/storage/memory-storage.js.map +1 -1
- package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
- package/dist/esm/src/multer/interceptors/any-files-interceptor.js +2 -2
- package/dist/esm/src/multer/interceptors/any-files-interceptor.js.map +1 -1
- package/dist/esm/src/multer/interceptors/file-fields-interceptor.js +2 -2
- package/dist/esm/src/multer/interceptors/file-fields-interceptor.js.map +1 -1
- package/dist/esm/src/multer/interceptors/file-interceptor.js +2 -2
- package/dist/esm/src/multer/interceptors/file-interceptor.js.map +1 -1
- package/dist/esm/src/multer/interceptors/files-interceptor.js +2 -2
- package/dist/esm/src/multer/interceptors/files-interceptor.js.map +1 -1
- package/dist/esm/src/multer/storage/disk-storage.d.ts +2 -2
- package/dist/esm/src/multer/storage/disk-storage.js +10 -10
- package/dist/esm/src/multer/storage/disk-storage.js.map +1 -1
- package/dist/esm/src/multer/storage/memory-storage.d.ts +5 -2
- package/dist/esm/src/multer/storage/memory-storage.js +8 -2
- package/dist/esm/src/multer/storage/memory-storage.js.map +1 -1
- package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
- package/package.json +5 -5
- package/src/multer/interceptors/any-files-interceptor.ts +2 -2
- package/src/multer/interceptors/file-fields-interceptor.ts +2 -2
- package/src/multer/interceptors/file-interceptor.ts +2 -2
- package/src/multer/interceptors/files-interceptor.ts +2 -2
- package/src/multer/storage/disk-storage.ts +15 -15
- package/src/multer/storage/memory-storage.ts +11 -4
- package/bun.lockb +0 -0
- package/src/multer/stream/index.ts +0 -4
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { finalize } from "rxjs";
|
|
2
2
|
import { mixin, } from "@nestjs/common";
|
|
3
3
|
import { getMultipartRequest } from "../multipart/request";
|
|
4
4
|
import { transformUploadOptions } from "../multipart/options";
|
|
@@ -17,7 +17,7 @@ export function AnyFilesInterceptor(options) {
|
|
|
17
17
|
const { body, files, remove } = await handleMultipartAnyFiles(req, this.options);
|
|
18
18
|
req.body = body;
|
|
19
19
|
req.storageFiles = files;
|
|
20
|
-
return next.handle().pipe(
|
|
20
|
+
return next.handle().pipe(finalize(remove));
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
23
|
const Interceptor = mixin(MixinInterceptor);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"any-files-interceptor.js","sourceRoot":"","sources":["../../../../../src/multer/interceptors/any-files-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"any-files-interceptor.js","sourceRoot":"","sources":["../../../../../src/multer/interceptors/any-files-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAc,MAAM,MAAM,CAAC;AAC5C,OAAO,EAGL,KAAK,GAGN,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,sBAAsB,EAAiB,MAAM,sBAAsB,CAAC;AAC7E,OAAO,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC;AAE1E,MAAM,UAAU,mBAAmB,CACjC,OAAuB;IAEvB,MAAM,gBAAgB;QAGpB;YACE,IAAI,CAAC,OAAO,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAC;QACjD,CAAC;QAED,KAAK,CAAC,SAAS,CACb,OAAyB,EACzB,IAAiB;YAEjB,MAAM,GAAG,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;YACnC,MAAM,GAAG,GAAG,mBAAmB,CAAC,GAAG,CAAC,CAAC;YAErC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,cAAc,CAAC,EAAE,UAAU,CAAC,qBAAqB,CAAC,EAAE,CAAC;gBACnE,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;YACvB,CAAC;YAED,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,MAAM,uBAAuB,CAC3D,GAAG,EACH,IAAI,CAAC,OAAO,CACb,CAAC;YAEF,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC;YAChB,GAAG,CAAC,YAAY,GAAG,KAAK,CAAC;YAEzB,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;QAC9C,CAAC;KACF;IAED,MAAM,WAAW,GAAG,KAAK,CAAC,gBAAgB,CAAC,CAAC;IAE5C,OAAO,WAAW,CAAC;AACrB,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { finalize } from "rxjs";
|
|
2
2
|
import { mixin, } from "@nestjs/common";
|
|
3
3
|
import { getMultipartRequest } from "../multipart/request";
|
|
4
4
|
import { transformUploadOptions } from "../multipart/options";
|
|
@@ -18,7 +18,7 @@ export function FileFieldsInterceptor(uploadFields, options) {
|
|
|
18
18
|
const { body, files, remove } = await handleMultipartFileFields(req, this.fieldsMap, this.options);
|
|
19
19
|
req.body = body;
|
|
20
20
|
req.storageFiles = files;
|
|
21
|
-
return next.handle().pipe(
|
|
21
|
+
return next.handle().pipe(finalize(remove));
|
|
22
22
|
}
|
|
23
23
|
}
|
|
24
24
|
const Interceptor = mixin(MixinInterceptor);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"file-fields-interceptor.js","sourceRoot":"","sources":["../../../../../src/multer/interceptors/file-fields-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"file-fields-interceptor.js","sourceRoot":"","sources":["../../../../../src/multer/interceptors/file-fields-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAc,MAAM,MAAM,CAAC;AAC5C,OAAO,EAGL,KAAK,GAGN,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,sBAAsB,EAAiB,MAAM,sBAAsB,CAAC;AAC7E,OAAO,EACL,yBAAyB,EAGzB,iBAAiB,GAClB,MAAM,mCAAmC,CAAC;AAE3C,MAAM,UAAU,qBAAqB,CACnC,YAA2B,EAC3B,OAAuB;IAEvB,MAAM,gBAAgB;QAKpB;YACE,IAAI,CAAC,OAAO,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAC;YAC/C,IAAI,CAAC,SAAS,GAAG,iBAAiB,CAAC,YAAY,CAAC,CAAC;QACnD,CAAC;QAED,KAAK,CAAC,SAAS,CACb,OAAyB,EACzB,IAAiB;YAEjB,MAAM,GAAG,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;YACnC,MAAM,GAAG,GAAG,mBAAmB,CAAC,GAAG,CAAC,CAAC;YAErC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,cAAc,CAAC,EAAE,UAAU,CAAC,qBAAqB,CAAC,EAAE,CAAC;gBACnE,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;YACvB,CAAC;YAED,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,MAAM,yBAAyB,CAC7D,GAAG,EACH,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,OAAO,CACb,CAAC;YAEF,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC;YAChB,GAAG,CAAC,YAAY,GAAG,KAAK,CAAC;YAEzB,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;QAC9C,CAAC;KACF;IAED,MAAM,WAAW,GAAG,KAAK,CAAC,gBAAgB,CAAC,CAAC;IAE5C,OAAO,WAAW,CAAC;AACrB,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { finalize } from "rxjs";
|
|
2
2
|
import { mixin, } from "@nestjs/common";
|
|
3
3
|
import { getMultipartRequest } from "../multipart/request";
|
|
4
4
|
import { transformUploadOptions } from "../multipart/options";
|
|
@@ -17,7 +17,7 @@ export function FileInterceptor(fieldname, options) {
|
|
|
17
17
|
const { file, body, remove } = await handleMultipartSingleFile(req, fieldname, this.options);
|
|
18
18
|
req.body = body;
|
|
19
19
|
req.storageFile = file;
|
|
20
|
-
return next.handle().pipe(
|
|
20
|
+
return next.handle().pipe(finalize(remove));
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
23
|
const Interceptor = mixin(MixinInterceptor);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"file-interceptor.js","sourceRoot":"","sources":["../../../../../src/multer/interceptors/file-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"file-interceptor.js","sourceRoot":"","sources":["../../../../../src/multer/interceptors/file-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAc,MAAM,MAAM,CAAC;AAC5C,OAAO,EAGL,KAAK,GAGN,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,sBAAsB,EAAiB,MAAM,sBAAsB,CAAC;AAC7E,OAAO,EAAE,yBAAyB,EAAE,MAAM,mCAAmC,CAAC;AAE9E,MAAM,UAAU,eAAe,CAC7B,SAAiB,EACjB,OAAuB;IAEvB,MAAM,gBAAgB;QAGpB;YACE,IAAI,CAAC,OAAO,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAC;QACjD,CAAC;QAED,KAAK,CAAC,SAAS,CACb,OAAyB,EACzB,IAAiB;YAEjB,MAAM,GAAG,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;YACnC,MAAM,GAAG,GAAG,mBAAmB,CAAC,GAAG,CAAC,CAAC;YAErC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,cAAc,CAAC,EAAE,UAAU,CAAC,qBAAqB,CAAC,EAAE,CAAC;gBACnE,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;YACvB,CAAC;YAED,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,yBAAyB,CAC5D,GAAG,EACH,SAAS,EACT,IAAI,CAAC,OAAO,CACb,CAAC;YAEF,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC;YAChB,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC;YAEvB,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;QAC9C,CAAC;KACF;IAED,MAAM,WAAW,GAAG,KAAK,CAAC,gBAAgB,CAAC,CAAC;IAE5C,OAAO,WAAW,CAAC;AACrB,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { finalize } from "rxjs";
|
|
2
2
|
import { mixin, } from "@nestjs/common";
|
|
3
3
|
import { getMultipartRequest } from "../multipart/request";
|
|
4
4
|
import { transformUploadOptions } from "../multipart/options";
|
|
@@ -17,7 +17,7 @@ export function FilesInterceptor(fieldname, maxCount = 1, options) {
|
|
|
17
17
|
const { body, files, remove } = await handleMultipartMultipleFiles(req, fieldname, maxCount, this.options);
|
|
18
18
|
req.body = body;
|
|
19
19
|
req.storageFiles = files;
|
|
20
|
-
return next.handle().pipe(
|
|
20
|
+
return next.handle().pipe(finalize(remove));
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
23
|
const Interceptor = mixin(MixinInterceptor);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"files-interceptor.js","sourceRoot":"","sources":["../../../../../src/multer/interceptors/files-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"files-interceptor.js","sourceRoot":"","sources":["../../../../../src/multer/interceptors/files-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAc,MAAM,MAAM,CAAC;AAC5C,OAAO,EAGL,KAAK,GAGN,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,sBAAsB,EAAiB,MAAM,sBAAsB,CAAC;AAC7E,OAAO,EAAE,4BAA4B,EAAE,MAAM,sCAAsC,CAAC;AAEpF,MAAM,UAAU,gBAAgB,CAC9B,SAAiB,EACjB,QAAQ,GAAG,CAAC,EACZ,OAAuB;IAEvB,MAAM,gBAAgB;QAGpB;YACE,IAAI,CAAC,OAAO,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAC;QACjD,CAAC;QAED,KAAK,CAAC,SAAS,CACb,OAAyB,EACzB,IAAiB;YAEjB,MAAM,GAAG,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;YACnC,MAAM,GAAG,GAAG,mBAAmB,CAAC,GAAG,CAAC,CAAC;YAErC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,cAAc,CAAC,EAAE,UAAU,CAAC,qBAAqB,CAAC,EAAE,CAAC;gBACnE,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;YACvB,CAAC;YAED,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,MAAM,4BAA4B,CAChE,GAAG,EACH,SAAS,EACT,QAAQ,EACR,IAAI,CAAC,OAAO,CACb,CAAC;YAEF,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC;YAChB,GAAG,CAAC,YAAY,GAAG,KAAK,CAAC;YAEzB,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;QAC9C,CAAC;KACF;IAED,MAAM,WAAW,GAAG,KAAK,CAAC,gBAAgB,CAAC,CAAC;IAE5C,OAAO,WAAW,CAAC;AACrB,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { StorageFile, Storage } from
|
|
2
|
-
import { HonoRequest } from
|
|
1
|
+
import { StorageFile, Storage } from "./storage";
|
|
2
|
+
import { HonoRequest } from "hono";
|
|
3
3
|
export interface DiskStorageFile extends StorageFile {
|
|
4
4
|
dest: string;
|
|
5
5
|
filename: string;
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { tmpdir } from
|
|
2
|
-
import { createWriteStream } from
|
|
3
|
-
import { mkdir, unlink } from
|
|
4
|
-
import { join } from
|
|
5
|
-
import { getUniqueFilename, pathExists } from
|
|
6
|
-
import {
|
|
7
|
-
import { Readable } from
|
|
1
|
+
import { tmpdir } from "os";
|
|
2
|
+
import { createWriteStream } from "fs";
|
|
3
|
+
import { mkdir, unlink } from "fs/promises";
|
|
4
|
+
import { join } from "path";
|
|
5
|
+
import { getUniqueFilename, pathExists } from "../fs";
|
|
6
|
+
import { pipeline } from "node:stream/promises";
|
|
7
|
+
import { Readable } from "node:stream";
|
|
8
8
|
const excecuteStorageHandler = (file, req, obj) => {
|
|
9
|
-
if (typeof obj ===
|
|
9
|
+
if (typeof obj === "function") {
|
|
10
10
|
return obj(file, req);
|
|
11
11
|
}
|
|
12
12
|
if (obj != null)
|
|
@@ -31,7 +31,7 @@ export class DiskStorage {
|
|
|
31
31
|
const stream = createWriteStream(path);
|
|
32
32
|
const buffer = await file.arrayBuffer();
|
|
33
33
|
const readableStream = Readable.from(Buffer.from(buffer));
|
|
34
|
-
await
|
|
34
|
+
await pipeline(readableStream, stream);
|
|
35
35
|
return {
|
|
36
36
|
size: stream.bytesWritten,
|
|
37
37
|
dest,
|
|
@@ -39,7 +39,7 @@ export class DiskStorage {
|
|
|
39
39
|
originalFilename: file.name,
|
|
40
40
|
path,
|
|
41
41
|
mimetype: file.type,
|
|
42
|
-
encoding:
|
|
42
|
+
encoding: "utf-8",
|
|
43
43
|
fieldname: fieldName,
|
|
44
44
|
};
|
|
45
45
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"disk-storage.js","sourceRoot":"","sources":["../../../../../src/multer/storage/disk-storage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,IAAI,CAAC;AAC5B,OAAO,EAAE,iBAAiB,EAAE,MAAM,IAAI,CAAC;AACvC,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAG5B,OAAO,EAAE,iBAAiB,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AACtD,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"disk-storage.js","sourceRoot":"","sources":["../../../../../src/multer/storage/disk-storage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,IAAI,CAAC;AAC5B,OAAO,EAAE,iBAAiB,EAAE,MAAM,IAAI,CAAC;AACvC,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAG5B,OAAO,EAAE,iBAAiB,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAEhD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAkBvC,MAAM,sBAAsB,GAAG,CAC7B,IAAU,EACV,GAAgB,EAChB,GAA8B,EAC9B,EAAE;IACF,IAAI,OAAO,GAAG,KAAK,UAAU,EAAE,CAAC;QAC9B,OAAO,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IACxB,CAAC;IAED,IAAI,GAAG,IAAI,IAAI;QAAE,OAAO,GAAG,CAAC;IAE5B,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,MAAM,0BAA0B,GAAG,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC;AAClE,MAAM,OAAO,WAAW;IAKtB,YAAY,OAA4B;QACtC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QAEvB,IAAI,0BAA0B,IAAI,IAAI,EAAE,CAAC;YACvC,IAAI,CAAC,OAAO,GAAG,EAAE,GAAG,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,0BAA0B,EAAE,CAAC;QACvE,CAAC;IACH,CAAC;IAEM,KAAK,CAAC,UAAU,CAAC,IAAU,EAAE,GAAgB,EAAE,SAAiB;QACrE,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,GAAG,EAAE,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QAC3E,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,GAAG,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QAE1E,IAAI,CAAC,CAAC,MAAM,UAAU,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;YAC9B,MAAM,KAAK,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QACzC,CAAC;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QAClC,MAAM,MAAM,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAEvC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC;QACxC,MAAM,cAAc,GAAG,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;QAE1D,MAAM,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC;QAEvC,OAAO;YACL,IAAI,EAAE,MAAM,CAAC,YAAY;YACzB,IAAI;YACJ,QAAQ;YACR,gBAAgB,EAAE,IAAI,CAAC,IAAI;YAC3B,IAAI;YACJ,QAAQ,EAAE,IAAI,CAAC,IAAI;YACnB,QAAQ,EAAE,OAAO;YACjB,SAAS,EAAE,SAAS;SACrB,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,UAAU,CAAC,IAAqB,EAAE,KAAe;QAC5D,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,WAAW,IAAI,CAAC,KAAK;YAAE,OAAO;QAEjD,MAAM,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAES,KAAK,CAAC,WAAW,CACzB,IAAU,EACV,GAAgB,EAChB,GAA8B;QAE9B,OAAO,CACL,sBAAsB,CAAC,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,IAAI,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CACvE,CAAC;IACJ,CAAC;IAES,KAAK,CAAC,kBAAkB,CAChC,IAAU,EACV,GAAgB,EAChB,GAA8B;QAE9B,OAAO,sBAAsB,CAAC,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,IAAI,MAAM,EAAE,CAAC;IAC5D,CAAC;CACF"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import { StorageFile, Storage } from
|
|
2
|
-
import { HonoRequest } from
|
|
1
|
+
import { StorageFile, Storage } from "./storage";
|
|
2
|
+
import { HonoRequest } from "hono";
|
|
3
3
|
export interface MemoryStorageFile extends StorageFile {
|
|
4
4
|
buffer: Buffer;
|
|
5
|
+
stream: () => ReadableStream<Uint8Array>;
|
|
5
6
|
}
|
|
6
7
|
export declare class MemoryStorage implements Storage<MemoryStorageFile> {
|
|
7
8
|
handleFile(file: File, _req: HonoRequest, fieldName: string): Promise<{
|
|
@@ -11,6 +12,8 @@ export declare class MemoryStorage implements Storage<MemoryStorageFile> {
|
|
|
11
12
|
mimetype: string;
|
|
12
13
|
fieldname: string;
|
|
13
14
|
originalFilename: string;
|
|
15
|
+
stream: () => ReadableStream<Uint8Array<ArrayBufferLike>>;
|
|
16
|
+
lastModified: number;
|
|
14
17
|
}>;
|
|
15
18
|
removeFile(file: MemoryStorageFile): Promise<void>;
|
|
16
19
|
}
|
|
@@ -1,13 +1,19 @@
|
|
|
1
1
|
export class MemoryStorage {
|
|
2
2
|
async handleFile(file, _req, fieldName) {
|
|
3
|
-
const buffer = await file
|
|
3
|
+
const buffer = await file
|
|
4
|
+
.stream()
|
|
5
|
+
.pipeTo(new WritableStream())
|
|
6
|
+
.then(() => file.arrayBuffer())
|
|
7
|
+
.then((buffer) => Buffer.from(buffer));
|
|
4
8
|
return {
|
|
5
9
|
buffer,
|
|
6
10
|
size: buffer.length,
|
|
7
|
-
encoding:
|
|
11
|
+
encoding: "utf-8",
|
|
8
12
|
mimetype: file.type,
|
|
9
13
|
fieldname: fieldName,
|
|
10
14
|
originalFilename: file.name,
|
|
15
|
+
stream: () => file.stream(),
|
|
16
|
+
lastModified: file.lastModified,
|
|
11
17
|
};
|
|
12
18
|
}
|
|
13
19
|
async removeFile(file) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"memory-storage.js","sourceRoot":"","sources":["../../../../../src/multer/storage/memory-storage.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"memory-storage.js","sourceRoot":"","sources":["../../../../../src/multer/storage/memory-storage.ts"],"names":[],"mappings":"AAQA,MAAM,OAAO,aAAa;IACjB,KAAK,CAAC,UAAU,CAAC,IAAU,EAAE,IAAiB,EAAE,SAAiB;QACtE,MAAM,MAAM,GAAG,MAAM,IAAI;aACtB,MAAM,EAAE;aACR,MAAM,CAAC,IAAI,cAAc,EAAE,CAAC;aAC5B,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;aAC9B,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;QAEzC,OAAO;YACL,MAAM;YACN,IAAI,EAAE,MAAM,CAAC,MAAM;YACnB,QAAQ,EAAE,OAAO;YACjB,QAAQ,EAAE,IAAI,CAAC,IAAI;YACnB,SAAS,EAAE,SAAS;YACpB,gBAAgB,EAAE,IAAI,CAAC,IAAI;YAC3B,MAAM,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE;YAC3B,YAAY,EAAE,IAAI,CAAC,YAAY;SAChC,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,UAAU,CAAC,IAAuB;QAC7C,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;CACF"}
|