@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.
Files changed (152) hide show
  1. package/.claude/settings.local.json +5 -2
  2. package/dist/cjs/src/adapters/hono-adapter.js +11 -11
  3. package/dist/cjs/src/adapters/hono-adapter.js.map +1 -1
  4. package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
  5. package/dist/esm/src/adapters/hono-adapter.js +11 -11
  6. package/dist/esm/src/adapters/hono-adapter.js.map +1 -1
  7. package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
  8. package/package.json +14 -13
  9. package/src/adapters/hono-adapter.ts +24 -29
  10. package/src/interfaces/nest-hono-application.interface.ts +3 -2
  11. package/dist/build.d.ts +0 -1
  12. package/dist/build.js +0 -28
  13. package/dist/build.js.map +0 -1
  14. package/dist/cjs/src/multer/crypto/index.d.ts +0 -1
  15. package/dist/cjs/src/multer/crypto/index.js +0 -7
  16. package/dist/cjs/src/multer/crypto/index.js.map +0 -1
  17. package/dist/cjs/src/multer/stream/index.d.ts +0 -2
  18. package/dist/cjs/src/multer/stream/index.js +0 -7
  19. package/dist/cjs/src/multer/stream/index.js.map +0 -1
  20. package/dist/esm/build.d.ts +0 -1
  21. package/dist/esm/build.js +0 -28
  22. package/dist/esm/build.js.map +0 -1
  23. package/dist/esm/src/multer/crypto/index.d.ts +0 -1
  24. package/dist/esm/src/multer/crypto/index.js +0 -4
  25. package/dist/esm/src/multer/crypto/index.js.map +0 -1
  26. package/dist/esm/src/multer/stream/index.d.ts +0 -2
  27. package/dist/esm/src/multer/stream/index.js +0 -4
  28. package/dist/esm/src/multer/stream/index.js.map +0 -1
  29. package/dist/index.d.ts +0 -4
  30. package/dist/index.js +0 -5
  31. package/dist/index.js.map +0 -1
  32. package/dist/src/adapters/hono-adapter.d.ts +0 -66
  33. package/dist/src/adapters/hono-adapter.js +0 -270
  34. package/dist/src/adapters/hono-adapter.js.map +0 -1
  35. package/dist/src/adapters/index.d.ts +0 -1
  36. package/dist/src/adapters/index.js +0 -2
  37. package/dist/src/adapters/index.js.map +0 -1
  38. package/dist/src/drivers/constants/apollo.constants.d.ts +0 -1
  39. package/dist/src/drivers/constants/apollo.constants.js +0 -2
  40. package/dist/src/drivers/constants/apollo.constants.js.map +0 -1
  41. package/dist/src/drivers/constants/index.d.ts +0 -1
  42. package/dist/src/drivers/constants/index.js +0 -2
  43. package/dist/src/drivers/constants/index.js.map +0 -1
  44. package/dist/src/drivers/graphQLUpload/GraphQLUpload.d.ts +0 -3
  45. package/dist/src/drivers/graphQLUpload/GraphQLUpload.js +0 -18
  46. package/dist/src/drivers/graphQLUpload/GraphQLUpload.js.map +0 -1
  47. package/dist/src/drivers/graphQLUpload/Upload.d.ts +0 -16
  48. package/dist/src/drivers/graphQLUpload/Upload.js +0 -17
  49. package/dist/src/drivers/graphQLUpload/Upload.js.map +0 -1
  50. package/dist/src/drivers/graphQLUpload/fs-capacitor.d.ts +0 -42
  51. package/dist/src/drivers/graphQLUpload/fs-capacitor.js +0 -185
  52. package/dist/src/drivers/graphQLUpload/fs-capacitor.js.map +0 -1
  53. package/dist/src/drivers/graphQLUpload/index.d.ts +0 -4
  54. package/dist/src/drivers/graphQLUpload/index.js +0 -5
  55. package/dist/src/drivers/graphQLUpload/index.js.map +0 -1
  56. package/dist/src/drivers/graphQLUpload/processRequest.d.ts +0 -2
  57. package/dist/src/drivers/graphQLUpload/processRequest.js +0 -47
  58. package/dist/src/drivers/graphQLUpload/processRequest.js.map +0 -1
  59. package/dist/src/drivers/graphql.driver.d.ts +0 -20
  60. package/dist/src/drivers/graphql.driver.js +0 -125
  61. package/dist/src/drivers/graphql.driver.js.map +0 -1
  62. package/dist/src/drivers/index.d.ts +0 -2
  63. package/dist/src/drivers/index.js +0 -3
  64. package/dist/src/drivers/index.js.map +0 -1
  65. package/dist/src/drivers/services/plugins-explorer.service.d.ts +0 -9
  66. package/dist/src/drivers/services/plugins-explorer.service.js +0 -22
  67. package/dist/src/drivers/services/plugins-explorer.service.js.map +0 -1
  68. package/dist/src/interfaces/hono.interface.d.ts +0 -4
  69. package/dist/src/interfaces/hono.interface.js +0 -2
  70. package/dist/src/interfaces/hono.interface.js.map +0 -1
  71. package/dist/src/interfaces/index.d.ts +0 -2
  72. package/dist/src/interfaces/index.js +0 -3
  73. package/dist/src/interfaces/index.js.map +0 -1
  74. package/dist/src/interfaces/nest-hono-application.interface.d.ts +0 -18
  75. package/dist/src/interfaces/nest-hono-application.interface.js +0 -2
  76. package/dist/src/interfaces/nest-hono-application.interface.js.map +0 -1
  77. package/dist/src/multer/decorators/index.d.ts +0 -2
  78. package/dist/src/multer/decorators/index.js +0 -3
  79. package/dist/src/multer/decorators/index.js.map +0 -1
  80. package/dist/src/multer/decorators/uploaded-file-decorator.d.ts +0 -1
  81. package/dist/src/multer/decorators/uploaded-file-decorator.js +0 -7
  82. package/dist/src/multer/decorators/uploaded-file-decorator.js.map +0 -1
  83. package/dist/src/multer/decorators/uploaded-files-decorator.d.ts +0 -1
  84. package/dist/src/multer/decorators/uploaded-files-decorator.js +0 -7
  85. package/dist/src/multer/decorators/uploaded-files-decorator.js.map +0 -1
  86. package/dist/src/multer/fs/index.d.ts +0 -2
  87. package/dist/src/multer/fs/index.js +0 -18
  88. package/dist/src/multer/fs/index.js.map +0 -1
  89. package/dist/src/multer/index.d.ts +0 -4
  90. package/dist/src/multer/index.js +0 -5
  91. package/dist/src/multer/index.js.map +0 -1
  92. package/dist/src/multer/interceptors/any-files-interceptor.d.ts +0 -3
  93. package/dist/src/multer/interceptors/any-files-interceptor.js +0 -27
  94. package/dist/src/multer/interceptors/any-files-interceptor.js.map +0 -1
  95. package/dist/src/multer/interceptors/file-fields-interceptor.d.ts +0 -4
  96. package/dist/src/multer/interceptors/file-fields-interceptor.js +0 -29
  97. package/dist/src/multer/interceptors/file-fields-interceptor.js.map +0 -1
  98. package/dist/src/multer/interceptors/file-interceptor.d.ts +0 -3
  99. package/dist/src/multer/interceptors/file-interceptor.js +0 -27
  100. package/dist/src/multer/interceptors/file-interceptor.js.map +0 -1
  101. package/dist/src/multer/interceptors/files-interceptor.d.ts +0 -3
  102. package/dist/src/multer/interceptors/files-interceptor.js +0 -27
  103. package/dist/src/multer/interceptors/files-interceptor.js.map +0 -1
  104. package/dist/src/multer/interceptors/index.d.ts +0 -4
  105. package/dist/src/multer/interceptors/index.js +0 -5
  106. package/dist/src/multer/interceptors/index.js.map +0 -1
  107. package/dist/src/multer/multipart/exceptions.d.ts +0 -1
  108. package/dist/src/multer/multipart/exceptions.js +0 -18
  109. package/dist/src/multer/multipart/exceptions.js.map +0 -1
  110. package/dist/src/multer/multipart/file.d.ts +0 -9
  111. package/dist/src/multer/multipart/file.js +0 -6
  112. package/dist/src/multer/multipart/file.js.map +0 -1
  113. package/dist/src/multer/multipart/filter.d.ts +0 -6
  114. package/dist/src/multer/multipart/filter.js +0 -18
  115. package/dist/src/multer/multipart/filter.js.map +0 -1
  116. package/dist/src/multer/multipart/handlers/any-files.d.ts +0 -10
  117. package/dist/src/multer/multipart/handlers/any-files.js +0 -29
  118. package/dist/src/multer/multipart/handlers/any-files.js.map +0 -1
  119. package/dist/src/multer/multipart/handlers/file-fields.d.ts +0 -17
  120. package/dist/src/multer/multipart/handlers/file-fields.js +0 -40
  121. package/dist/src/multer/multipart/handlers/file-fields.js.map +0 -1
  122. package/dist/src/multer/multipart/handlers/index.d.ts +0 -1
  123. package/dist/src/multer/multipart/handlers/index.js +0 -2
  124. package/dist/src/multer/multipart/handlers/index.js.map +0 -1
  125. package/dist/src/multer/multipart/handlers/multiple-files.d.ts +0 -10
  126. package/dist/src/multer/multipart/handlers/multiple-files.js +0 -36
  127. package/dist/src/multer/multipart/handlers/multiple-files.js.map +0 -1
  128. package/dist/src/multer/multipart/handlers/single-file.d.ts +0 -10
  129. package/dist/src/multer/multipart/handlers/single-file.js +0 -41
  130. package/dist/src/multer/multipart/handlers/single-file.js.map +0 -1
  131. package/dist/src/multer/multipart/index.d.ts +0 -3
  132. package/dist/src/multer/multipart/index.js +0 -3
  133. package/dist/src/multer/multipart/index.js.map +0 -1
  134. package/dist/src/multer/multipart/options.d.ts +0 -21
  135. package/dist/src/multer/multipart/options.js +0 -19
  136. package/dist/src/multer/multipart/options.js.map +0 -1
  137. package/dist/src/multer/multipart/request.d.ts +0 -15
  138. package/dist/src/multer/multipart/request.js +0 -17
  139. package/dist/src/multer/multipart/request.js.map +0 -1
  140. package/dist/src/multer/storage/disk-storage.d.ts +0 -31
  141. package/dist/src/multer/storage/disk-storage.js +0 -59
  142. package/dist/src/multer/storage/disk-storage.js.map +0 -1
  143. package/dist/src/multer/storage/index.d.ts +0 -3
  144. package/dist/src/multer/storage/index.js +0 -4
  145. package/dist/src/multer/storage/index.js.map +0 -1
  146. package/dist/src/multer/storage/memory-storage.d.ts +0 -19
  147. package/dist/src/multer/storage/memory-storage.js +0 -23
  148. package/dist/src/multer/storage/memory-storage.js.map +0 -1
  149. package/dist/src/multer/storage/storage.d.ts +0 -13
  150. package/dist/src/multer/storage/storage.js +0 -2
  151. package/dist/src/multer/storage/storage.js.map +0 -1
  152. 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,4 +0,0 @@
1
- import { HonoRequest as Request } from 'hono';
2
- export type HonoRequest = Request & {
3
- headers?: Record<string, string>;
4
- };
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=hono.interface.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hono.interface.js","sourceRoot":"","sources":["../../../src/interfaces/hono.interface.ts"],"names":[],"mappings":""}
@@ -1,2 +0,0 @@
1
- export * from './nest-hono-application.interface';
2
- export * from './hono.interface';
@@ -1,3 +0,0 @@
1
- export * from './nest-hono-application.interface';
2
- export * from './hono.interface';
3
- //# sourceMappingURL=index.js.map
@@ -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,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=nest-hono-application.interface.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"nest-hono-application.interface.js","sourceRoot":"","sources":["../../../src/interfaces/nest-hono-application.interface.ts"],"names":[],"mappings":""}
@@ -1,2 +0,0 @@
1
- export * from './uploaded-files-decorator';
2
- export * from './uploaded-file-decorator';
@@ -1,3 +0,0 @@
1
- export * from './uploaded-files-decorator';
2
- export * from './uploaded-file-decorator';
3
- //# sourceMappingURL=index.js.map
@@ -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,2 +0,0 @@
1
- export declare const pathExists: (path: string) => Promise<boolean>;
2
- export declare const getUniqueFilename: (filename: string) => Promise<string>;
@@ -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"}
@@ -1,4 +0,0 @@
1
- export * from './interceptors';
2
- export * from './decorators';
3
- export * from './storage';
4
- export * from './multipart';
@@ -1,5 +0,0 @@
1
- export * from './interceptors';
2
- export * from './decorators';
3
- export * from './storage';
4
- export * from './multipart';
5
- //# sourceMappingURL=index.js.map
@@ -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,3 +0,0 @@
1
- import { NestInterceptor, Type } from '@nestjs/common';
2
- import { UploadOptions } from '../multipart/options';
3
- export declare function AnyFilesInterceptor(options?: UploadOptions): Type<NestInterceptor>;
@@ -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,3 +0,0 @@
1
- import { NestInterceptor, Type } from '@nestjs/common';
2
- import { UploadOptions } from '../multipart/options';
3
- export declare function FileInterceptor(fieldname: string, options?: UploadOptions): Type<NestInterceptor>;
@@ -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,3 +0,0 @@
1
- import { NestInterceptor, Type } from '@nestjs/common';
2
- import { UploadOptions } from '../multipart/options';
3
- export declare function FilesInterceptor(fieldname: string, maxCount?: number, options?: UploadOptions): Type<NestInterceptor>;
@@ -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,4 +0,0 @@
1
- export * from './file-fields-interceptor';
2
- export * from './file-interceptor';
3
- export * from './any-files-interceptor';
4
- export * from './files-interceptor';
@@ -1,5 +0,0 @@
1
- export * from './file-fields-interceptor';
2
- export * from './file-interceptor';
3
- export * from './any-files-interceptor';
4
- export * from './files-interceptor';
5
- //# sourceMappingURL=index.js.map
@@ -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,6 +0,0 @@
1
- export const removeStorageFiles = async (storage, files, force) => {
2
- if (files == null)
3
- return;
4
- await Promise.all(files.map((file) => file && storage.removeFile(file, force)));
5
- };
6
- //# sourceMappingURL=file.js.map
@@ -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,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=index.js.map
@@ -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"}