@kiyasov/platform-hono 1.5.6 → 1.5.8
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/.claude/settings.local.json +5 -2
- package/dist/cjs/src/adapters/hono-adapter.js +11 -11
- package/dist/cjs/src/adapters/hono-adapter.js.map +1 -1
- package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
- package/dist/esm/src/adapters/hono-adapter.js +11 -11
- package/dist/esm/src/adapters/hono-adapter.js.map +1 -1
- package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
- package/package.json +14 -13
- package/src/adapters/hono-adapter.ts +24 -29
- package/src/interfaces/nest-hono-application.interface.ts +3 -2
- package/dist/build.d.ts +0 -1
- package/dist/build.js +0 -28
- package/dist/build.js.map +0 -1
- package/dist/cjs/src/multer/crypto/index.d.ts +0 -1
- package/dist/cjs/src/multer/crypto/index.js +0 -7
- package/dist/cjs/src/multer/crypto/index.js.map +0 -1
- package/dist/cjs/src/multer/stream/index.d.ts +0 -2
- package/dist/cjs/src/multer/stream/index.js +0 -7
- package/dist/cjs/src/multer/stream/index.js.map +0 -1
- package/dist/esm/build.d.ts +0 -1
- package/dist/esm/build.js +0 -28
- package/dist/esm/build.js.map +0 -1
- package/dist/esm/src/multer/crypto/index.d.ts +0 -1
- package/dist/esm/src/multer/crypto/index.js +0 -4
- package/dist/esm/src/multer/crypto/index.js.map +0 -1
- package/dist/esm/src/multer/stream/index.d.ts +0 -2
- package/dist/esm/src/multer/stream/index.js +0 -4
- package/dist/esm/src/multer/stream/index.js.map +0 -1
- package/dist/index.d.ts +0 -4
- package/dist/index.js +0 -5
- package/dist/index.js.map +0 -1
- package/dist/src/adapters/hono-adapter.d.ts +0 -66
- package/dist/src/adapters/hono-adapter.js +0 -270
- package/dist/src/adapters/hono-adapter.js.map +0 -1
- package/dist/src/adapters/index.d.ts +0 -1
- package/dist/src/adapters/index.js +0 -2
- package/dist/src/adapters/index.js.map +0 -1
- package/dist/src/drivers/constants/apollo.constants.d.ts +0 -1
- package/dist/src/drivers/constants/apollo.constants.js +0 -2
- package/dist/src/drivers/constants/apollo.constants.js.map +0 -1
- package/dist/src/drivers/constants/index.d.ts +0 -1
- package/dist/src/drivers/constants/index.js +0 -2
- package/dist/src/drivers/constants/index.js.map +0 -1
- package/dist/src/drivers/graphQLUpload/GraphQLUpload.d.ts +0 -3
- package/dist/src/drivers/graphQLUpload/GraphQLUpload.js +0 -18
- package/dist/src/drivers/graphQLUpload/GraphQLUpload.js.map +0 -1
- package/dist/src/drivers/graphQLUpload/Upload.d.ts +0 -16
- package/dist/src/drivers/graphQLUpload/Upload.js +0 -17
- package/dist/src/drivers/graphQLUpload/Upload.js.map +0 -1
- package/dist/src/drivers/graphQLUpload/fs-capacitor.d.ts +0 -42
- package/dist/src/drivers/graphQLUpload/fs-capacitor.js +0 -185
- package/dist/src/drivers/graphQLUpload/fs-capacitor.js.map +0 -1
- package/dist/src/drivers/graphQLUpload/index.d.ts +0 -4
- package/dist/src/drivers/graphQLUpload/index.js +0 -5
- package/dist/src/drivers/graphQLUpload/index.js.map +0 -1
- package/dist/src/drivers/graphQLUpload/processRequest.d.ts +0 -2
- package/dist/src/drivers/graphQLUpload/processRequest.js +0 -47
- package/dist/src/drivers/graphQLUpload/processRequest.js.map +0 -1
- package/dist/src/drivers/graphql.driver.d.ts +0 -20
- package/dist/src/drivers/graphql.driver.js +0 -125
- package/dist/src/drivers/graphql.driver.js.map +0 -1
- package/dist/src/drivers/index.d.ts +0 -2
- package/dist/src/drivers/index.js +0 -3
- package/dist/src/drivers/index.js.map +0 -1
- package/dist/src/drivers/services/plugins-explorer.service.d.ts +0 -9
- package/dist/src/drivers/services/plugins-explorer.service.js +0 -22
- package/dist/src/drivers/services/plugins-explorer.service.js.map +0 -1
- package/dist/src/interfaces/hono.interface.d.ts +0 -4
- package/dist/src/interfaces/hono.interface.js +0 -2
- package/dist/src/interfaces/hono.interface.js.map +0 -1
- package/dist/src/interfaces/index.d.ts +0 -2
- package/dist/src/interfaces/index.js +0 -3
- package/dist/src/interfaces/index.js.map +0 -1
- package/dist/src/interfaces/nest-hono-application.interface.d.ts +0 -18
- package/dist/src/interfaces/nest-hono-application.interface.js +0 -2
- package/dist/src/interfaces/nest-hono-application.interface.js.map +0 -1
- package/dist/src/multer/decorators/index.d.ts +0 -2
- package/dist/src/multer/decorators/index.js +0 -3
- package/dist/src/multer/decorators/index.js.map +0 -1
- package/dist/src/multer/decorators/uploaded-file-decorator.d.ts +0 -1
- package/dist/src/multer/decorators/uploaded-file-decorator.js +0 -7
- package/dist/src/multer/decorators/uploaded-file-decorator.js.map +0 -1
- package/dist/src/multer/decorators/uploaded-files-decorator.d.ts +0 -1
- package/dist/src/multer/decorators/uploaded-files-decorator.js +0 -7
- package/dist/src/multer/decorators/uploaded-files-decorator.js.map +0 -1
- package/dist/src/multer/fs/index.d.ts +0 -2
- package/dist/src/multer/fs/index.js +0 -18
- package/dist/src/multer/fs/index.js.map +0 -1
- package/dist/src/multer/index.d.ts +0 -4
- package/dist/src/multer/index.js +0 -5
- package/dist/src/multer/index.js.map +0 -1
- package/dist/src/multer/interceptors/any-files-interceptor.d.ts +0 -3
- package/dist/src/multer/interceptors/any-files-interceptor.js +0 -27
- package/dist/src/multer/interceptors/any-files-interceptor.js.map +0 -1
- package/dist/src/multer/interceptors/file-fields-interceptor.d.ts +0 -4
- package/dist/src/multer/interceptors/file-fields-interceptor.js +0 -29
- package/dist/src/multer/interceptors/file-fields-interceptor.js.map +0 -1
- package/dist/src/multer/interceptors/file-interceptor.d.ts +0 -3
- package/dist/src/multer/interceptors/file-interceptor.js +0 -27
- package/dist/src/multer/interceptors/file-interceptor.js.map +0 -1
- package/dist/src/multer/interceptors/files-interceptor.d.ts +0 -3
- package/dist/src/multer/interceptors/files-interceptor.js +0 -27
- package/dist/src/multer/interceptors/files-interceptor.js.map +0 -1
- package/dist/src/multer/interceptors/index.d.ts +0 -4
- package/dist/src/multer/interceptors/index.js +0 -5
- package/dist/src/multer/interceptors/index.js.map +0 -1
- package/dist/src/multer/multipart/exceptions.d.ts +0 -1
- package/dist/src/multer/multipart/exceptions.js +0 -18
- package/dist/src/multer/multipart/exceptions.js.map +0 -1
- package/dist/src/multer/multipart/file.d.ts +0 -9
- package/dist/src/multer/multipart/file.js +0 -6
- package/dist/src/multer/multipart/file.js.map +0 -1
- package/dist/src/multer/multipart/filter.d.ts +0 -6
- package/dist/src/multer/multipart/filter.js +0 -18
- package/dist/src/multer/multipart/filter.js.map +0 -1
- package/dist/src/multer/multipart/handlers/any-files.d.ts +0 -10
- package/dist/src/multer/multipart/handlers/any-files.js +0 -29
- package/dist/src/multer/multipart/handlers/any-files.js.map +0 -1
- package/dist/src/multer/multipart/handlers/file-fields.d.ts +0 -17
- package/dist/src/multer/multipart/handlers/file-fields.js +0 -40
- package/dist/src/multer/multipart/handlers/file-fields.js.map +0 -1
- package/dist/src/multer/multipart/handlers/index.d.ts +0 -1
- package/dist/src/multer/multipart/handlers/index.js +0 -2
- package/dist/src/multer/multipart/handlers/index.js.map +0 -1
- package/dist/src/multer/multipart/handlers/multiple-files.d.ts +0 -10
- package/dist/src/multer/multipart/handlers/multiple-files.js +0 -36
- package/dist/src/multer/multipart/handlers/multiple-files.js.map +0 -1
- package/dist/src/multer/multipart/handlers/single-file.d.ts +0 -10
- package/dist/src/multer/multipart/handlers/single-file.js +0 -41
- package/dist/src/multer/multipart/handlers/single-file.js.map +0 -1
- package/dist/src/multer/multipart/index.d.ts +0 -3
- package/dist/src/multer/multipart/index.js +0 -3
- package/dist/src/multer/multipart/index.js.map +0 -1
- package/dist/src/multer/multipart/options.d.ts +0 -21
- package/dist/src/multer/multipart/options.js +0 -19
- package/dist/src/multer/multipart/options.js.map +0 -1
- package/dist/src/multer/multipart/request.d.ts +0 -15
- package/dist/src/multer/multipart/request.js +0 -17
- package/dist/src/multer/multipart/request.js.map +0 -1
- package/dist/src/multer/storage/disk-storage.d.ts +0 -31
- package/dist/src/multer/storage/disk-storage.js +0 -59
- package/dist/src/multer/storage/disk-storage.js.map +0 -1
- package/dist/src/multer/storage/index.d.ts +0 -3
- package/dist/src/multer/storage/index.js +0 -4
- package/dist/src/multer/storage/index.js.map +0 -1
- package/dist/src/multer/storage/memory-storage.d.ts +0 -19
- package/dist/src/multer/storage/memory-storage.js +0 -23
- package/dist/src/multer/storage/memory-storage.js.map +0 -1
- package/dist/src/multer/storage/storage.d.ts +0 -13
- package/dist/src/multer/storage/storage.js +0 -2
- package/dist/src/multer/storage/storage.js.map +0 -1
- package/dist/tsconfig.tsbuildinfo +0 -1
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { BaseExplorerService } from '@nestjs/graphql';
|
|
2
|
-
import { PLUGIN_METADATA } from '../constants';
|
|
3
|
-
export class PluginsExplorerService extends BaseExplorerService {
|
|
4
|
-
modulesContainer;
|
|
5
|
-
constructor(modulesContainer) {
|
|
6
|
-
super();
|
|
7
|
-
this.modulesContainer = modulesContainer;
|
|
8
|
-
}
|
|
9
|
-
explore(options) {
|
|
10
|
-
const modules = this.getModules(this.modulesContainer, options.include || []);
|
|
11
|
-
return this.flatMap(modules, (instance) => this.filterPlugins(instance));
|
|
12
|
-
}
|
|
13
|
-
filterPlugins(wrapper) {
|
|
14
|
-
const { instance } = wrapper;
|
|
15
|
-
if (!instance) {
|
|
16
|
-
return undefined;
|
|
17
|
-
}
|
|
18
|
-
const metadata = Reflect.getMetadata(PLUGIN_METADATA, instance.constructor);
|
|
19
|
-
return metadata ? instance : undefined;
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
//# sourceMappingURL=plugins-explorer.service.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"plugins-explorer.service.js","sourceRoot":"","sources":["../../../../src/drivers/services/plugins-explorer.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,mBAAmB,EAAoB,MAAM,iBAAiB,CAAC;AAExE,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAE/C,MAAM,OAAO,sBAAuB,SAAQ,mBAAmB;IAChC;IAA7B,YAA6B,gBAAkC;QAC7D,KAAK,EAAE,CAAC;QADmB,qBAAgB,GAAhB,gBAAgB,CAAkB;IAE/D,CAAC;IAED,OAAO,CAAC,OAAyB;QAC/B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAC7B,IAAI,CAAC,gBAAgB,EACrB,OAAO,CAAC,OAAO,IAAI,EAAE,CACtB,CAAC;QACF,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC3E,CAAC;IAED,aAAa,CAAc,OAA2B;QACpD,MAAM,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC;QAC7B,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC,eAAe,EAAE,QAAQ,CAAC,WAAW,CAAC,CAAC;QAC5E,OAAO,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;IACzC,CAAC;CACF"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hono.interface.js","sourceRoot":"","sources":["../../../src/interfaces/hono.interface.ts"],"names":[],"mappings":""}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/interfaces/index.ts"],"names":[],"mappings":"AAAA,cAAc,mCAAmC,CAAC;AAClD,cAAc,kBAAkB,CAAC"}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { ServeStaticOptions } from '@hono/node-server/serve-static';
|
|
2
|
-
import { HttpServer, INestApplication } from '@nestjs/common';
|
|
3
|
-
import { Context, Hono, MiddlewareHandler } from 'hono';
|
|
4
|
-
export type TypeBodyParser = 'application/json' | 'text/plain' | 'application/x-www-form-urlencoded';
|
|
5
|
-
interface HonoViewOptions {
|
|
6
|
-
engine: string;
|
|
7
|
-
templates: string;
|
|
8
|
-
}
|
|
9
|
-
export interface NestHonoApplication<TServer extends Hono = Hono> extends INestApplication<TServer> {
|
|
10
|
-
getHttpAdapter(): HttpServer<Context, MiddlewareHandler, Hono>;
|
|
11
|
-
useBodyParser(type: TypeBodyParser, bodyLimit?: number): this;
|
|
12
|
-
useStaticAssets(path: string, options: ServeStaticOptions): this;
|
|
13
|
-
setViewEngine(options: HonoViewOptions | string): this;
|
|
14
|
-
listen(port: number | string, callback?: (err: Error, address: string) => void): Promise<TServer>;
|
|
15
|
-
listen(port: number | string, address: string, callback?: (err: Error, address: string) => void): Promise<TServer>;
|
|
16
|
-
listen(port: number | string, address: string, backlog: number, callback?: (err: Error, address: string) => void): Promise<TServer>;
|
|
17
|
-
}
|
|
18
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"nest-hono-application.interface.js","sourceRoot":"","sources":["../../../src/interfaces/nest-hono-application.interface.ts"],"names":[],"mappings":""}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/multer/decorators/index.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAC;AAC3C,cAAc,2BAA2B,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const UploadedFile: (...dataOrPipes: any[]) => ParameterDecorator;
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { createParamDecorator } from '@nestjs/common';
|
|
2
|
-
import { getMultipartRequest } from '../multipart/request';
|
|
3
|
-
export const UploadedFile = createParamDecorator(async (_data, ctx) => {
|
|
4
|
-
const req = getMultipartRequest(ctx.switchToHttp());
|
|
5
|
-
return req?.storageFile;
|
|
6
|
-
});
|
|
7
|
-
//# sourceMappingURL=uploaded-file-decorator.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"uploaded-file-decorator.js","sourceRoot":"","sources":["../../../../src/multer/decorators/uploaded-file-decorator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAoB,MAAM,gBAAgB,CAAC;AAExE,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAG3D,MAAM,CAAC,MAAM,YAAY,GAAG,oBAAoB,CAC9C,KAAK,EAAE,KAAK,EAAE,GAAqB,EAAoC,EAAE;IACvE,MAAM,GAAG,GAAG,mBAAmB,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC,CAAC;IAEpD,OAAO,GAAG,EAAE,WAAW,CAAC;AAC1B,CAAC,CACF,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const UploadedFiles: (...dataOrPipes: unknown[]) => ParameterDecorator;
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { createParamDecorator } from '@nestjs/common';
|
|
2
|
-
import { getMultipartRequest } from '../multipart/request';
|
|
3
|
-
export const UploadedFiles = createParamDecorator(async (_data, ctx) => {
|
|
4
|
-
const req = getMultipartRequest(ctx.switchToHttp());
|
|
5
|
-
return req?.storageFiles;
|
|
6
|
-
});
|
|
7
|
-
//# sourceMappingURL=uploaded-files-decorator.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"uploaded-files-decorator.js","sourceRoot":"","sources":["../../../../src/multer/decorators/uploaded-files-decorator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAoB,MAAM,gBAAgB,CAAC;AAExE,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAG3D,MAAM,CAAC,MAAM,aAAa,GAAG,oBAAoB,CAC/C,KAAK,EACH,KAAc,EACd,GAAqB,EAC+C,EAAE;IACtE,MAAM,GAAG,GAAG,mBAAmB,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC,CAAC;IAEpD,OAAO,GAAG,EAAE,YAAY,CAAC;AAC3B,CAAC,CACF,CAAC"}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { randomBytes } from 'crypto';
|
|
2
|
-
import { stat } from 'fs/promises';
|
|
3
|
-
import { extname } from 'path';
|
|
4
|
-
export const pathExists = async (path) => {
|
|
5
|
-
try {
|
|
6
|
-
await stat(path);
|
|
7
|
-
return true;
|
|
8
|
-
}
|
|
9
|
-
catch {
|
|
10
|
-
return false;
|
|
11
|
-
}
|
|
12
|
-
};
|
|
13
|
-
export const getUniqueFilename = async (filename) => {
|
|
14
|
-
const buffer = randomBytes(16);
|
|
15
|
-
const ext = extname(filename);
|
|
16
|
-
return buffer.toString('hex') + ext;
|
|
17
|
-
};
|
|
18
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/multer/fs/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,QAAQ,CAAC;AACrC,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AACnC,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAE/B,MAAM,CAAC,MAAM,UAAU,GAAG,KAAK,EAAE,IAAY,EAAE,EAAE;IAC/C,IAAI,CAAC;QACH,MAAM,IAAI,CAAC,IAAI,CAAC,CAAC;QACjB,OAAO,IAAI,CAAC;IACd,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,iBAAiB,GAAG,KAAK,EAAE,QAAgB,EAAE,EAAE;IAC1D,MAAM,MAAM,GAAG,WAAW,CAAC,EAAE,CAAC,CAAC;IAC/B,MAAM,GAAG,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC9B,OAAO,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC;AACtC,CAAC,CAAC"}
|
package/dist/src/multer/index.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/multer/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC;AAC1B,cAAc,aAAa,CAAC"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { mixin, } from '@nestjs/common';
|
|
2
|
-
import { finalize } from 'rxjs';
|
|
3
|
-
import { handleMultipartAnyFiles } from '../multipart/handlers/any-files';
|
|
4
|
-
import { transformUploadOptions } from '../multipart/options';
|
|
5
|
-
import { getMultipartRequest } from '../multipart/request';
|
|
6
|
-
export function AnyFilesInterceptor(options) {
|
|
7
|
-
class MixinInterceptor {
|
|
8
|
-
options;
|
|
9
|
-
constructor() {
|
|
10
|
-
this.options = transformUploadOptions(options);
|
|
11
|
-
}
|
|
12
|
-
async intercept(context, next) {
|
|
13
|
-
const ctx = context.switchToHttp();
|
|
14
|
-
const req = getMultipartRequest(ctx);
|
|
15
|
-
if (!req.header('content-type')?.startsWith('multipart/form-data')) {
|
|
16
|
-
return next.handle();
|
|
17
|
-
}
|
|
18
|
-
const { body, files, remove } = await handleMultipartAnyFiles(req, this.options);
|
|
19
|
-
req.body = body;
|
|
20
|
-
req.storageFiles = files;
|
|
21
|
-
return next.handle().pipe(finalize(remove));
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
const Interceptor = mixin(MixinInterceptor);
|
|
25
|
-
return Interceptor;
|
|
26
|
-
}
|
|
27
|
-
//# sourceMappingURL=any-files-interceptor.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"any-files-interceptor.js","sourceRoot":"","sources":["../../../../src/multer/interceptors/any-files-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,GAGN,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAEhC,OAAO,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC;AAC1E,OAAO,EAAE,sBAAsB,EAAiB,MAAM,sBAAsB,CAAC;AAC7E,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAE3D,MAAM,UAAU,mBAAmB,CACjC,OAAuB;IAEvB,MAAM,gBAAgB;QACH,OAAO,CAAgB;QAExC;YACE,IAAI,CAAC,OAAO,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAC;QACjD,CAAC;QAED,KAAK,CAAC,SAAS,CAAC,OAAyB,EAAE,IAAiB;YAC1D,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 +0,0 @@
|
|
|
1
|
-
import { NestInterceptor, Type } from '@nestjs/common';
|
|
2
|
-
import { UploadField } from '../multipart/handlers/file-fields';
|
|
3
|
-
import { UploadOptions } from '../multipart/options';
|
|
4
|
-
export declare function FileFieldsInterceptor(uploadFields: UploadField[], options?: UploadOptions): Type<NestInterceptor>;
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { mixin, } from '@nestjs/common';
|
|
2
|
-
import { finalize } from 'rxjs';
|
|
3
|
-
import { handleMultipartFileFields, uploadFieldsToMap, } from '../multipart/handlers/file-fields';
|
|
4
|
-
import { transformUploadOptions } from '../multipart/options';
|
|
5
|
-
import { getMultipartRequest } from '../multipart/request';
|
|
6
|
-
export function FileFieldsInterceptor(uploadFields, options) {
|
|
7
|
-
class MixinInterceptor {
|
|
8
|
-
options;
|
|
9
|
-
fieldsMap;
|
|
10
|
-
constructor() {
|
|
11
|
-
this.options = transformUploadOptions(options);
|
|
12
|
-
this.fieldsMap = uploadFieldsToMap(uploadFields);
|
|
13
|
-
}
|
|
14
|
-
async intercept(context, next) {
|
|
15
|
-
const ctx = context.switchToHttp();
|
|
16
|
-
const req = getMultipartRequest(ctx);
|
|
17
|
-
if (!req.header('content-type')?.startsWith('multipart/form-data')) {
|
|
18
|
-
return next.handle();
|
|
19
|
-
}
|
|
20
|
-
const { body, files, remove } = await handleMultipartFileFields(req, this.fieldsMap, this.options);
|
|
21
|
-
req.body = body;
|
|
22
|
-
req.storageFiles = files;
|
|
23
|
-
return next.handle().pipe(finalize(remove));
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
const Interceptor = mixin(MixinInterceptor);
|
|
27
|
-
return Interceptor;
|
|
28
|
-
}
|
|
29
|
-
//# sourceMappingURL=file-fields-interceptor.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"file-fields-interceptor.js","sourceRoot":"","sources":["../../../../src/multer/interceptors/file-fields-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,GAGN,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAEhC,OAAO,EACL,yBAAyB,EAGzB,iBAAiB,GAClB,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAE,sBAAsB,EAAiB,MAAM,sBAAsB,CAAC;AAC7E,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAE3D,MAAM,UAAU,qBAAqB,CACnC,YAA2B,EAC3B,OAAuB;IAEvB,MAAM,gBAAgB;QACH,OAAO,CAAgB;QAEvB,SAAS,CAAmC;QAE7D;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,CAAC,OAAyB,EAAE,IAAiB;YAC1D,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,27 +0,0 @@
|
|
|
1
|
-
import { mixin, } from '@nestjs/common';
|
|
2
|
-
import { finalize } from 'rxjs';
|
|
3
|
-
import { handleMultipartSingleFile } from '../multipart/handlers/single-file';
|
|
4
|
-
import { transformUploadOptions } from '../multipart/options';
|
|
5
|
-
import { getMultipartRequest } from '../multipart/request';
|
|
6
|
-
export function FileInterceptor(fieldname, options) {
|
|
7
|
-
class MixinInterceptor {
|
|
8
|
-
options;
|
|
9
|
-
constructor() {
|
|
10
|
-
this.options = transformUploadOptions(options);
|
|
11
|
-
}
|
|
12
|
-
async intercept(context, next) {
|
|
13
|
-
const ctx = context.switchToHttp();
|
|
14
|
-
const req = getMultipartRequest(ctx);
|
|
15
|
-
if (!req.header('content-type')?.startsWith('multipart/form-data')) {
|
|
16
|
-
return next.handle();
|
|
17
|
-
}
|
|
18
|
-
const { file, body, remove } = await handleMultipartSingleFile(req, fieldname, this.options);
|
|
19
|
-
req.body = body;
|
|
20
|
-
req.storageFile = file;
|
|
21
|
-
return next.handle().pipe(finalize(remove));
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
const Interceptor = mixin(MixinInterceptor);
|
|
25
|
-
return Interceptor;
|
|
26
|
-
}
|
|
27
|
-
//# sourceMappingURL=file-interceptor.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"file-interceptor.js","sourceRoot":"","sources":["../../../../src/multer/interceptors/file-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,GAGN,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAEhC,OAAO,EAAE,yBAAyB,EAAE,MAAM,mCAAmC,CAAC;AAC9E,OAAO,EAAE,sBAAsB,EAAiB,MAAM,sBAAsB,CAAC;AAC7E,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAE3D,MAAM,UAAU,eAAe,CAC7B,SAAiB,EACjB,OAAuB;IAEvB,MAAM,gBAAgB;QACH,OAAO,CAAgB;QAExC;YACE,IAAI,CAAC,OAAO,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAC;QACjD,CAAC;QAED,KAAK,CAAC,SAAS,CAAC,OAAyB,EAAE,IAAiB;YAC1D,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,27 +0,0 @@
|
|
|
1
|
-
import { mixin, } from '@nestjs/common';
|
|
2
|
-
import { finalize } from 'rxjs';
|
|
3
|
-
import { handleMultipartMultipleFiles } from '../multipart/handlers/multiple-files';
|
|
4
|
-
import { transformUploadOptions } from '../multipart/options';
|
|
5
|
-
import { getMultipartRequest } from '../multipart/request';
|
|
6
|
-
export function FilesInterceptor(fieldname, maxCount = 1, options) {
|
|
7
|
-
class MixinInterceptor {
|
|
8
|
-
options;
|
|
9
|
-
constructor() {
|
|
10
|
-
this.options = transformUploadOptions(options);
|
|
11
|
-
}
|
|
12
|
-
async intercept(context, next) {
|
|
13
|
-
const ctx = context.switchToHttp();
|
|
14
|
-
const req = getMultipartRequest(ctx);
|
|
15
|
-
if (!req.header('content-type')?.startsWith('multipart/form-data')) {
|
|
16
|
-
return next.handle();
|
|
17
|
-
}
|
|
18
|
-
const { body, files, remove } = await handleMultipartMultipleFiles(req, fieldname, maxCount, this.options);
|
|
19
|
-
req.body = body;
|
|
20
|
-
req.storageFiles = files;
|
|
21
|
-
return next.handle().pipe(finalize(remove));
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
const Interceptor = mixin(MixinInterceptor);
|
|
25
|
-
return Interceptor;
|
|
26
|
-
}
|
|
27
|
-
//# sourceMappingURL=files-interceptor.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"files-interceptor.js","sourceRoot":"","sources":["../../../../src/multer/interceptors/files-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,GAGN,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAEhC,OAAO,EAAE,4BAA4B,EAAE,MAAM,sCAAsC,CAAC;AACpF,OAAO,EAAE,sBAAsB,EAAiB,MAAM,sBAAsB,CAAC;AAC7E,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAE3D,MAAM,UAAU,gBAAgB,CAC9B,SAAiB,EACjB,QAAQ,GAAG,CAAC,EACZ,OAAuB;IAEvB,MAAM,gBAAgB;QACH,OAAO,CAAgB;QAExC;YACE,IAAI,CAAC,OAAO,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAC;QACjD,CAAC;QAED,KAAK,CAAC,SAAS,CAAC,OAAyB,EAAE,IAAiB;YAC1D,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 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/multer/interceptors/index.ts"],"names":[],"mappings":"AAAA,cAAc,2BAA2B,CAAC;AAC1C,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AACxC,cAAc,qBAAqB,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const transformException: (err: Error | undefined) => Error;
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { BadRequestException, HttpException, PayloadTooLargeException, } from '@nestjs/common';
|
|
2
|
-
export const transformException = (err) => {
|
|
3
|
-
if (!err || err instanceof HttpException) {
|
|
4
|
-
return err;
|
|
5
|
-
}
|
|
6
|
-
const code = err.code;
|
|
7
|
-
switch (code) {
|
|
8
|
-
case 'REQ_FILE_TOO_LARGE':
|
|
9
|
-
return new PayloadTooLargeException();
|
|
10
|
-
case 'PARTS_LIMIT':
|
|
11
|
-
case 'FILES_LIMIT':
|
|
12
|
-
case 'PROTO_VIOLATION':
|
|
13
|
-
case 'INVALID_MULTIPART_CONTENT_TYPE':
|
|
14
|
-
return new BadRequestException(err.message);
|
|
15
|
-
}
|
|
16
|
-
return err;
|
|
17
|
-
};
|
|
18
|
-
//# sourceMappingURL=exceptions.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"exceptions.js","sourceRoot":"","sources":["../../../../src/multer/multipart/exceptions.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EACnB,aAAa,EACb,wBAAwB,GACzB,MAAM,gBAAgB,CAAC;AAExB,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,GAAsB,EAAE,EAAE;IAC3D,IAAI,CAAC,GAAG,IAAI,GAAG,YAAY,aAAa,EAAE,CAAC;QACzC,OAAO,GAAG,CAAC;IACb,CAAC;IAGD,MAAM,IAAI,GAAY,GAAW,CAAC,IAAI,CAAC;IAEvC,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,oBAAoB;YACvB,OAAO,IAAI,wBAAwB,EAAE,CAAC;QACxC,KAAK,aAAa,CAAC;QACnB,KAAK,aAAa,CAAC;QACnB,KAAK,iBAAiB,CAAC;QACvB,KAAK,gCAAgC;YACnC,OAAO,IAAI,mBAAmB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAChD,CAAC;IAED,OAAO,GAAG,CAAC;AACb,CAAC,CAAC"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { Readable } from 'stream';
|
|
2
|
-
import { Storage, StorageFile } from '../storage';
|
|
3
|
-
export type MultipartFile = Omit<File[], 'file'> & {
|
|
4
|
-
value?: unknown;
|
|
5
|
-
file: Readable & {
|
|
6
|
-
truncated?: boolean;
|
|
7
|
-
};
|
|
8
|
-
};
|
|
9
|
-
export declare const removeStorageFiles: (storage: Storage, files?: (StorageFile | undefined)[], force?: boolean) => Promise<void>;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"file.js","sourceRoot":"","sources":["../../../../src/multer/multipart/file.ts"],"names":[],"mappings":"AASA,MAAM,CAAC,MAAM,kBAAkB,GAAG,KAAK,EACrC,OAAgB,EAChB,KAAmC,EACnC,KAAe,EACf,EAAE;IACF,IAAI,KAAK,IAAI,IAAI;QAAE,OAAO;IAC1B,MAAM,OAAO,CAAC,GAAG,CACf,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,IAAI,OAAO,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAC7D,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import { HonoRequest } from 'hono';
|
|
2
|
-
import { UploadOptions } from '.';
|
|
3
|
-
import { DiskStorageFile, MemoryStorageFile, StorageFile } from '../storage';
|
|
4
|
-
export type UploadFilterFile = DiskStorageFile | MemoryStorageFile | StorageFile;
|
|
5
|
-
export type UploadFilterHandler = (req: HonoRequest, file: UploadFilterFile) => Promise<boolean | string> | boolean | string;
|
|
6
|
-
export declare const filterUpload: (uploadOptions: UploadOptions, req: HonoRequest, file: UploadFilterFile) => Promise<boolean>;
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { BadRequestException } from '@nestjs/common';
|
|
2
|
-
export const filterUpload = async (uploadOptions, req, file) => {
|
|
3
|
-
if (uploadOptions.filter == null) {
|
|
4
|
-
return true;
|
|
5
|
-
}
|
|
6
|
-
try {
|
|
7
|
-
const res = await uploadOptions.filter(req, file);
|
|
8
|
-
if (typeof res === 'string') {
|
|
9
|
-
throw new BadRequestException(res);
|
|
10
|
-
}
|
|
11
|
-
return res;
|
|
12
|
-
}
|
|
13
|
-
catch (error) {
|
|
14
|
-
await uploadOptions.storage.removeFile(file, true);
|
|
15
|
-
throw error;
|
|
16
|
-
}
|
|
17
|
-
};
|
|
18
|
-
//# sourceMappingURL=filter.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"filter.js","sourceRoot":"","sources":["../../../../src/multer/multipart/filter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAgBrD,MAAM,CAAC,MAAM,YAAY,GAAG,KAAK,EAC/B,aAA4B,EAC5B,GAAgB,EAChB,IAAsB,EACJ,EAAE;IACpB,IAAI,aAAa,CAAC,MAAM,IAAI,IAAI,EAAE,CAAC;QACjC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,aAAa,CAAC,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;QAElD,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;YAC5B,MAAM,IAAI,mBAAmB,CAAC,GAAG,CAAC,CAAC;QACrC,CAAC;QAED,OAAO,GAAG,CAAC;IACb,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,aAAa,CAAC,OAAQ,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QACpD,MAAM,KAAK,CAAC;IACd,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { StorageFile } from '../../storage';
|
|
2
|
-
import { UploadOptions } from '../options';
|
|
3
|
-
import { THonoRequest } from '../request';
|
|
4
|
-
export declare const handleMultipartAnyFiles: (req: THonoRequest, options: UploadOptions) => Promise<{
|
|
5
|
-
body: {
|
|
6
|
-
[x: string]: string | File;
|
|
7
|
-
};
|
|
8
|
-
files: StorageFile[];
|
|
9
|
-
remove: () => Promise<void>;
|
|
10
|
-
}>;
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { removeStorageFiles } from '../file';
|
|
2
|
-
import { filterUpload } from '../filter';
|
|
3
|
-
import { getParts } from '../request';
|
|
4
|
-
export const handleMultipartAnyFiles = async (req, options) => {
|
|
5
|
-
const parts = getParts(req, options);
|
|
6
|
-
const body = {};
|
|
7
|
-
const files = [];
|
|
8
|
-
const removeFiles = async (error) => {
|
|
9
|
-
return await removeStorageFiles(options.storage, files, error);
|
|
10
|
-
};
|
|
11
|
-
try {
|
|
12
|
-
for await (const [partFieldName, part] of Object.entries(parts)) {
|
|
13
|
-
if (!(part instanceof File)) {
|
|
14
|
-
body[partFieldName] = part;
|
|
15
|
-
continue;
|
|
16
|
-
}
|
|
17
|
-
const file = await options.storage.handleFile(part, req, partFieldName);
|
|
18
|
-
if (await filterUpload(options, req, file)) {
|
|
19
|
-
files.push(file);
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
catch (error) {
|
|
24
|
-
await removeFiles(true);
|
|
25
|
-
throw error;
|
|
26
|
-
}
|
|
27
|
-
return { body, files, remove: () => removeFiles() };
|
|
28
|
-
};
|
|
29
|
-
//# sourceMappingURL=any-files.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"any-files.js","sourceRoot":"","sources":["../../../../../src/multer/multipart/handlers/any-files.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAEzC,OAAO,EAAgB,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEpD,MAAM,CAAC,MAAM,uBAAuB,GAAG,KAAK,EAC1C,GAAiB,EACjB,OAAsB,EACtB,EAAE;IACF,MAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;IAErC,MAAM,IAAI,GAAa,EAAE,CAAC;IAE1B,MAAM,KAAK,GAAkB,EAAE,CAAC;IAEhC,MAAM,WAAW,GAAG,KAAK,EAAE,KAAe,EAAE,EAAE;QAC5C,OAAO,MAAM,kBAAkB,CAAC,OAAO,CAAC,OAAQ,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IAClE,CAAC,CAAC;IAEF,IAAI,CAAC;QACH,IAAI,KAAK,EAAE,MAAM,CAAC,aAAa,EAAE,IAAI,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YAChE,IAAI,CAAC,CAAC,IAAI,YAAY,IAAI,CAAC,EAAE,CAAC;gBAC5B,IAAI,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC;gBAC3B,SAAS;YACX,CAAC;YACD,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC,OAAQ,CAAC,UAAU,CAAC,IAAI,EAAE,GAAG,EAAE,aAAa,CAAC,CAAC;YAEzE,IAAI,MAAM,YAAY,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC;gBAC3C,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACnB,CAAC;QACH,CAAC;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,WAAW,CAAC,IAAI,CAAC,CAAC;QACxB,MAAM,KAAK,CAAC;IACd,CAAC;IAED,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,WAAW,EAAE,EAAE,CAAC;AACtD,CAAC,CAAC"}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { BodyData } from 'hono/utils/body';
|
|
2
|
-
import { StorageFile } from '../../storage/storage';
|
|
3
|
-
import { UploadOptions } from '../options';
|
|
4
|
-
import { THonoRequest } from '../request';
|
|
5
|
-
export interface UploadField {
|
|
6
|
-
name: string;
|
|
7
|
-
maxCount?: number;
|
|
8
|
-
}
|
|
9
|
-
export type UploadFieldMapEntry = Required<Pick<UploadField, 'maxCount'>>;
|
|
10
|
-
export declare const uploadFieldsToMap: (uploadFields: UploadField[]) => Map<string, {
|
|
11
|
-
maxCount: number;
|
|
12
|
-
}>;
|
|
13
|
-
export declare const handleMultipartFileFields: (req: THonoRequest, fieldsMap: Map<string, UploadFieldMapEntry>, options: UploadOptions) => Promise<{
|
|
14
|
-
body: BodyData;
|
|
15
|
-
files: Record<string, StorageFile[]>;
|
|
16
|
-
remove: () => Promise<void>;
|
|
17
|
-
}>;
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import { BadRequestException } from '@nestjs/common';
|
|
2
|
-
import { removeStorageFiles } from '../file';
|
|
3
|
-
import { filterUpload } from '../filter';
|
|
4
|
-
import { getParts } from '../request';
|
|
5
|
-
export const uploadFieldsToMap = (uploadFields) => new Map(uploadFields.map(({ name, ...opts }) => [name, { maxCount: 1, ...opts }]));
|
|
6
|
-
export const handleMultipartFileFields = async (req, fieldsMap, options) => {
|
|
7
|
-
const parts = getParts(req, options);
|
|
8
|
-
const body = {};
|
|
9
|
-
const files = {};
|
|
10
|
-
const removeFiles = async (error) => {
|
|
11
|
-
const allFiles = Object.values(files).flat();
|
|
12
|
-
return removeStorageFiles(options.storage, allFiles, error);
|
|
13
|
-
};
|
|
14
|
-
try {
|
|
15
|
-
for await (const [fieldName, part] of Object.entries(parts)) {
|
|
16
|
-
if (!(part instanceof File)) {
|
|
17
|
-
body[fieldName] = part;
|
|
18
|
-
continue;
|
|
19
|
-
}
|
|
20
|
-
const fieldOptions = fieldsMap.get(fieldName);
|
|
21
|
-
if (!fieldOptions) {
|
|
22
|
-
throw new BadRequestException(`Field ${fieldName} doesn't accept files`);
|
|
23
|
-
}
|
|
24
|
-
files[fieldName] = files[fieldName] || [];
|
|
25
|
-
if (files[fieldName].length >= fieldOptions.maxCount) {
|
|
26
|
-
throw new BadRequestException(`Field ${fieldName} accepts max ${fieldOptions.maxCount} files`);
|
|
27
|
-
}
|
|
28
|
-
const file = await options.storage.handleFile(part, req, fieldName);
|
|
29
|
-
if (await filterUpload(options, req, file)) {
|
|
30
|
-
files[fieldName].push(file);
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
catch (error) {
|
|
35
|
-
await removeFiles(true);
|
|
36
|
-
throw error;
|
|
37
|
-
}
|
|
38
|
-
return { body, files, remove: removeFiles };
|
|
39
|
-
};
|
|
40
|
-
//# sourceMappingURL=file-fields.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"file-fields.js","sourceRoot":"","sources":["../../../../../src/multer/multipart/handlers/file-fields.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAIrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAEzC,OAAO,EAAgB,QAAQ,EAAE,MAAM,YAAY,CAAC;AAcpD,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,YAA2B,EAAE,EAAE,CAC/D,IAAI,GAAG,CACL,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC,CAC1E,CAAC;AASJ,MAAM,CAAC,MAAM,yBAAyB,GAAG,KAAK,EAC5C,GAAiB,EACjB,SAA2C,EAC3C,OAAsB,EAKrB,EAAE;IACH,MAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;IACrC,MAAM,IAAI,GAAa,EAAE,CAAC;IAC1B,MAAM,KAAK,GAAkC,EAAE,CAAC;IAOhD,MAAM,WAAW,GAAG,KAAK,EAAE,KAAe,EAAiB,EAAE;QAC3D,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,CAAC;QAC7C,OAAO,kBAAkB,CAAC,OAAO,CAAC,OAAQ,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;IAC/D,CAAC,CAAC;IAEF,IAAI,CAAC;QACH,IAAI,KAAK,EAAE,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YAC5D,IAAI,CAAC,CAAC,IAAI,YAAY,IAAI,CAAC,EAAE,CAAC;gBAC5B,IAAI,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC;gBACvB,SAAS;YACX,CAAC;YAED,MAAM,YAAY,GAAG,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YAC9C,IAAI,CAAC,YAAY,EAAE,CAAC;gBAClB,MAAM,IAAI,mBAAmB,CAC3B,SAAS,SAAS,uBAAuB,CAC1C,CAAC;YACJ,CAAC;YAED,KAAK,CAAC,SAAS,CAAC,GAAG,KAAK,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;YAC1C,IAAI,KAAK,CAAC,SAAS,CAAC,CAAC,MAAM,IAAI,YAAY,CAAC,QAAQ,EAAE,CAAC;gBACrD,MAAM,IAAI,mBAAmB,CAC3B,SAAS,SAAS,gBAAgB,YAAY,CAAC,QAAQ,QAAQ,CAChE,CAAC;YACJ,CAAC;YAED,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC,OAAQ,CAAC,UAAU,CAAC,IAAI,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;YACrE,IAAI,MAAM,YAAY,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC;gBAC3C,KAAK,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC9B,CAAC;QACH,CAAC;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,WAAW,CAAC,IAAI,CAAC,CAAC;QACxB,MAAM,KAAK,CAAC;IACd,CAAC;IAED,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC;AAC9C,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { UploadField } from './file-fields';
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/multer/multipart/handlers/index.ts"],"names":[],"mappings":""}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { StorageFile } from '../../storage';
|
|
2
|
-
import { UploadOptions } from '../options';
|
|
3
|
-
import { THonoRequest } from '../request';
|
|
4
|
-
export declare const handleMultipartMultipleFiles: (req: THonoRequest, fieldname: string, maxCount: number, options: UploadOptions) => Promise<{
|
|
5
|
-
body: {
|
|
6
|
-
[x: string]: string | File;
|
|
7
|
-
};
|
|
8
|
-
files: StorageFile[];
|
|
9
|
-
remove: () => Promise<void>;
|
|
10
|
-
}>;
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { BadRequestException } from '@nestjs/common';
|
|
2
|
-
import { removeStorageFiles } from '../file';
|
|
3
|
-
import { filterUpload } from '../filter';
|
|
4
|
-
import { getParts } from '../request';
|
|
5
|
-
export const handleMultipartMultipleFiles = async (req, fieldname, maxCount, options) => {
|
|
6
|
-
const parts = getParts(req, options);
|
|
7
|
-
const body = {};
|
|
8
|
-
const files = [];
|
|
9
|
-
const removeFiles = async (error) => {
|
|
10
|
-
return await removeStorageFiles(options.storage, files, error);
|
|
11
|
-
};
|
|
12
|
-
try {
|
|
13
|
-
for await (const [partFieldName, part] of Object.entries(parts)) {
|
|
14
|
-
if (!(part instanceof File)) {
|
|
15
|
-
body[partFieldName] = part;
|
|
16
|
-
continue;
|
|
17
|
-
}
|
|
18
|
-
if (partFieldName !== fieldname) {
|
|
19
|
-
throw new BadRequestException(`Field ${partFieldName} doesn't accept files`);
|
|
20
|
-
}
|
|
21
|
-
if (files.length + 1 > maxCount) {
|
|
22
|
-
throw new BadRequestException(`Field ${partFieldName} accepts max ${maxCount} files`);
|
|
23
|
-
}
|
|
24
|
-
const file = await options.storage.handleFile(part, req, partFieldName);
|
|
25
|
-
if (await filterUpload(options, req, file)) {
|
|
26
|
-
files.push(file);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
catch (error) {
|
|
31
|
-
await removeFiles(error);
|
|
32
|
-
throw error;
|
|
33
|
-
}
|
|
34
|
-
return { body, files, remove: () => removeFiles() };
|
|
35
|
-
};
|
|
36
|
-
//# sourceMappingURL=multiple-files.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"multiple-files.js","sourceRoot":"","sources":["../../../../../src/multer/multipart/handlers/multiple-files.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAIrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAEzC,OAAO,EAAgB,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEpD,MAAM,CAAC,MAAM,4BAA4B,GAAG,KAAK,EAC/C,GAAiB,EACjB,SAAiB,EACjB,QAAgB,EAChB,OAAsB,EACtB,EAAE;IACF,MAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;IACrC,MAAM,IAAI,GAAa,EAAE,CAAC;IAE1B,MAAM,KAAK,GAAkB,EAAE,CAAC;IAEhC,MAAM,WAAW,GAAG,KAAK,EAAE,KAAe,EAAE,EAAE;QAC5C,OAAO,MAAM,kBAAkB,CAAC,OAAO,CAAC,OAAQ,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IAClE,CAAC,CAAC;IAEF,IAAI,CAAC;QACH,IAAI,KAAK,EAAE,MAAM,CAAC,aAAa,EAAE,IAAI,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YAChE,IAAI,CAAC,CAAC,IAAI,YAAY,IAAI,CAAC,EAAE,CAAC;gBAC5B,IAAI,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC;gBAC3B,SAAS;YACX,CAAC;YAED,IAAI,aAAa,KAAK,SAAS,EAAE,CAAC;gBAChC,MAAM,IAAI,mBAAmB,CAC3B,SAAS,aAAa,uBAAuB,CAC9C,CAAC;YACJ,CAAC;YAED,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,GAAG,QAAQ,EAAE,CAAC;gBAChC,MAAM,IAAI,mBAAmB,CAC3B,SAAS,aAAa,gBAAgB,QAAQ,QAAQ,CACvD,CAAC;YACJ,CAAC;YAED,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC,OAAQ,CAAC,UAAU,CAAC,IAAI,EAAE,GAAG,EAAE,aAAa,CAAC,CAAC;YAEzE,IAAI,MAAM,YAAY,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC;gBAC3C,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACnB,CAAC;QACH,CAAC;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,WAAW,CAAC,KAAK,CAAC,CAAC;QACzB,MAAM,KAAK,CAAC;IACd,CAAC;IAED,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,WAAW,EAAE,EAAE,CAAC;AACtD,CAAC,CAAC"}
|