@payloadcms/next 3.0.0-alpha.14 → 3.0.0-alpha.16

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 (192) hide show
  1. package/dist/bin/index.js +5 -14
  2. package/dist/bin/install.js +16 -31
  3. package/dist/config.js +2 -12
  4. package/dist/elements/LeaveWithoutSaving/index.js +26 -76
  5. package/dist/elements/LeaveWithoutSaving/usePreventLeave.js +11 -29
  6. package/dist/exports/index.js +2 -17
  7. package/dist/graphql/registerSchema.js +0 -1
  8. package/dist/index.js +6 -33
  9. package/dist/layouts/Admin/index.js +9 -32
  10. package/dist/layouts/Root/index.js +29 -52
  11. package/dist/next-fileupload/fileFactory.js +9 -19
  12. package/dist/next-fileupload/handlers.js +25 -89
  13. package/dist/next-fileupload/index.js +10 -25
  14. package/dist/next-fileupload/isEligibleRequest.js +2 -12
  15. package/dist/next-fileupload/processMultipart.js +30 -45
  16. package/dist/next-fileupload/processNested.js +4 -14
  17. package/dist/next-fileupload/uploadTimer.js +2 -12
  18. package/dist/next-fileupload/utilities.js +31 -76
  19. package/dist/next-stream-file/index.js +6 -32
  20. package/dist/routes/graphql/handler.js +12 -35
  21. package/dist/routes/graphql/index.js +3 -21
  22. package/dist/routes/graphql/playground.js +6 -16
  23. package/dist/routes/index.js +4 -37
  24. package/dist/routes/rest/RouteError.js +10 -25
  25. package/dist/routes/rest/[collection]/file/[filename]/route.js +23 -38
  26. package/dist/routes/rest/auth/access.js +6 -21
  27. package/dist/routes/rest/auth/forgotPassword.js +6 -21
  28. package/dist/routes/rest/auth/init.js +4 -14
  29. package/dist/routes/rest/auth/login.js +10 -25
  30. package/dist/routes/rest/auth/logout.js +9 -24
  31. package/dist/routes/rest/auth/me.js +8 -23
  32. package/dist/routes/rest/auth/refresh.js +11 -25
  33. package/dist/routes/rest/auth/registerFirstUser.js +8 -23
  34. package/dist/routes/rest/auth/resetPassword.js +8 -23
  35. package/dist/routes/rest/auth/unlock.js +6 -21
  36. package/dist/routes/rest/auth/verifyEmail.js +6 -21
  37. package/dist/routes/rest/buildFormState.js +10 -33
  38. package/dist/routes/rest/checkEndpoints.js +4 -19
  39. package/dist/routes/rest/collections/create.js +8 -23
  40. package/dist/routes/rest/collections/delete.js +14 -29
  41. package/dist/routes/rest/collections/deleteByID.js +9 -24
  42. package/dist/routes/rest/collections/docAccess.js +6 -21
  43. package/dist/routes/rest/collections/find.js +12 -27
  44. package/dist/routes/rest/collections/findByID.js +8 -23
  45. package/dist/routes/rest/collections/findVersionByID.js +8 -23
  46. package/dist/routes/rest/collections/findVersions.js +12 -27
  47. package/dist/routes/rest/collections/restoreVersion.js +8 -23
  48. package/dist/routes/rest/collections/update.js +14 -29
  49. package/dist/routes/rest/collections/updateByID.js +8 -23
  50. package/dist/routes/rest/globals/docAccess.js +6 -21
  51. package/dist/routes/rest/globals/findOne.js +8 -23
  52. package/dist/routes/rest/globals/findVersionByID.js +8 -23
  53. package/dist/routes/rest/globals/findVersions.js +12 -27
  54. package/dist/routes/rest/globals/restoreVersion.js +8 -23
  55. package/dist/routes/rest/globals/update.js +8 -23
  56. package/dist/routes/rest/index.js +91 -120
  57. package/dist/routes/rest/types.js +2 -5
  58. package/dist/utilities/auth.js +7 -17
  59. package/dist/utilities/createPayloadRequest.js +22 -31
  60. package/dist/utilities/getDataAndFile.js +4 -14
  61. package/dist/utilities/getNextI18n.js +11 -21
  62. package/dist/utilities/getNextT.js +11 -21
  63. package/dist/utilities/getPayload.js +6 -21
  64. package/dist/utilities/getRequestLanguage.js +4 -14
  65. package/dist/utilities/getRequestLocales.js +2 -12
  66. package/dist/utilities/initPage.js +22 -37
  67. package/dist/utilities/meta.js +5 -15
  68. package/dist/utilities/timestamp.js +2 -12
  69. package/dist/views/API/RenderJSON/index.js +16 -67
  70. package/dist/views/API/index.client.js +47 -103
  71. package/dist/views/API/index.js +7 -22
  72. package/dist/views/API/meta.js +4 -14
  73. package/dist/views/Account/Settings/index.js +13 -28
  74. package/dist/views/Account/ToggleTheme/index.js +9 -59
  75. package/dist/views/Account/index.js +17 -76
  76. package/dist/views/Account/meta.js +4 -14
  77. package/dist/views/CreateFirstUser/index.client.js +6 -21
  78. package/dist/views/CreateFirstUser/index.js +12 -35
  79. package/dist/views/CreateFirstUser/meta.js +4 -14
  80. package/dist/views/Dashboard/Default/index.client.js +27 -78
  81. package/dist/views/Dashboard/Default/index.js +13 -28
  82. package/dist/views/Dashboard/index.js +14 -78
  83. package/dist/views/Dashboard/meta.js +4 -14
  84. package/dist/views/Document/getCustomViewByKey.js +2 -12
  85. package/dist/views/Document/getCustomViewByPath.js +2 -12
  86. package/dist/views/Document/getMetaBySegment.js +21 -31
  87. package/dist/views/Document/getViewsFromConfig.js +35 -45
  88. package/dist/views/Document/index.js +23 -87
  89. package/dist/views/Document/meta.js +3 -13
  90. package/dist/views/Edit/Default/Auth/APIKey.js +24 -75
  91. package/dist/views/Edit/Default/Auth/index.js +31 -87
  92. package/dist/views/Edit/Default/Auth/types.js +2 -5
  93. package/dist/views/Edit/Default/RenderCustomView.js +0 -1
  94. package/dist/views/Edit/Default/SetDocumentTitle/index.js +11 -21
  95. package/dist/views/Edit/Default/SetStepNav/index.js +12 -22
  96. package/dist/views/Edit/Default/index.js +32 -84
  97. package/dist/views/Edit/Default/types.js +2 -5
  98. package/dist/views/Edit/index.client.js +14 -64
  99. package/dist/views/Edit/index.js +7 -22
  100. package/dist/views/Edit/meta.js +11 -21
  101. package/dist/views/Edit/sanitizeEditViewProps.js +2 -12
  102. package/dist/views/ForgotPassword/index.js +14 -81
  103. package/dist/views/ForgotPassword/meta.js +4 -14
  104. package/dist/views/List/Default/Cell/cellTypes.spec.js +21 -30
  105. package/dist/views/List/Default/Cell/fields/Array/index.js +8 -23
  106. package/dist/views/List/Default/Cell/fields/Blocks/index.js +11 -26
  107. package/dist/views/List/Default/Cell/fields/Checkbox/index.js +5 -20
  108. package/dist/views/List/Default/Cell/fields/Code/index.js +6 -21
  109. package/dist/views/List/Default/Cell/fields/Date/index.js +7 -22
  110. package/dist/views/List/Default/Cell/fields/File/index.js +8 -23
  111. package/dist/views/List/Default/Cell/fields/JSON/index.js +6 -21
  112. package/dist/views/List/Default/Cell/fields/Relationship/index.js +19 -70
  113. package/dist/views/List/Default/Cell/fields/Richtext/index.js +0 -1
  114. package/dist/views/List/Default/Cell/fields/Select/index.js +10 -25
  115. package/dist/views/List/Default/Cell/fields/Textarea/index.js +4 -19
  116. package/dist/views/List/Default/Cell/fields/index.js +24 -34
  117. package/dist/views/List/Default/Cell/index.js +22 -37
  118. package/dist/views/List/Default/RelationshipProvider/index.js +19 -83
  119. package/dist/views/List/Default/RelationshipProvider/reducer.js +2 -12
  120. package/dist/views/List/Default/index.js +48 -104
  121. package/dist/views/List/Default/types.js +2 -5
  122. package/dist/views/List/index.js +16 -75
  123. package/dist/views/List/meta.js +6 -16
  124. package/dist/views/LivePreview/Context/collisionDetection.js +6 -14
  125. package/dist/views/LivePreview/Context/context.js +4 -22
  126. package/dist/views/LivePreview/Context/index.js +25 -76
  127. package/dist/views/LivePreview/Context/sizeReducer.js +2 -12
  128. package/dist/views/LivePreview/Device/index.js +10 -61
  129. package/dist/views/LivePreview/DeviceContainer/index.js +6 -21
  130. package/dist/views/LivePreview/IFrame/index.js +7 -58
  131. package/dist/views/LivePreview/Preview/index.js +21 -72
  132. package/dist/views/LivePreview/Toolbar/Controls/index.js +22 -37
  133. package/dist/views/LivePreview/Toolbar/SizeInput/index.js +10 -61
  134. package/dist/views/LivePreview/Toolbar/index.js +17 -32
  135. package/dist/views/LivePreview/ToolbarArea/index.js +7 -22
  136. package/dist/views/LivePreview/index.client.js +35 -86
  137. package/dist/views/LivePreview/index.js +6 -21
  138. package/dist/views/LivePreview/meta.js +11 -21
  139. package/dist/views/LivePreview/usePopupWindow.js +11 -21
  140. package/dist/views/Login/LoginForm/index.js +17 -32
  141. package/dist/views/Login/index.js +15 -77
  142. package/dist/views/Login/meta.js +4 -14
  143. package/dist/views/Logout/LogoutClient.js +13 -69
  144. package/dist/views/Logout/index.js +12 -38
  145. package/dist/views/Logout/meta.js +4 -14
  146. package/dist/views/NotFound/index.js +14 -28
  147. package/dist/views/ResetPassword/index.js +20 -46
  148. package/dist/views/ResetPassword/meta.js +4 -14
  149. package/dist/views/Root/index.js +51 -74
  150. package/dist/views/Root/meta.js +28 -38
  151. package/dist/views/Unauthorized/UnauthorizedClient.js +8 -23
  152. package/dist/views/Unauthorized/index.js +6 -29
  153. package/dist/views/Unauthorized/meta.js +4 -14
  154. package/dist/views/Verify/index.js +13 -39
  155. package/dist/views/Verify/meta.js +4 -14
  156. package/dist/views/Version/Default/SetStepNav.js +13 -23
  157. package/dist/views/Version/Default/index.js +35 -91
  158. package/dist/views/Version/Default/types.js +2 -5
  159. package/dist/views/Version/RenderFieldsToDiff/Label/index.js +5 -20
  160. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.js +16 -31
  161. package/dist/views/Version/RenderFieldsToDiff/fields/Nested/index.js +11 -26
  162. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.js +17 -32
  163. package/dist/views/Version/RenderFieldsToDiff/fields/Select/DiffViewer/index.js +6 -62
  164. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.js +14 -29
  165. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.js +9 -24
  166. package/dist/views/Version/RenderFieldsToDiff/fields/Text/DiffViewer/index.js +6 -62
  167. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.js +12 -27
  168. package/dist/views/Version/RenderFieldsToDiff/fields/diffMethods.js +2 -12
  169. package/dist/views/Version/RenderFieldsToDiff/fields/index.js +25 -40
  170. package/dist/views/Version/RenderFieldsToDiff/fields/styles.js +2 -12
  171. package/dist/views/Version/RenderFieldsToDiff/fields/types.js +2 -5
  172. package/dist/views/Version/RenderFieldsToDiff/index.js +16 -31
  173. package/dist/views/Version/RenderFieldsToDiff/types.js +2 -5
  174. package/dist/views/Version/Restore/index.js +21 -71
  175. package/dist/views/Version/Restore/types.js +2 -5
  176. package/dist/views/Version/SelectComparison/index.js +25 -80
  177. package/dist/views/Version/SelectComparison/types.js +2 -5
  178. package/dist/views/Version/SelectLocales/index.js +11 -25
  179. package/dist/views/Version/SelectLocales/types.js +2 -5
  180. package/dist/views/Version/index.js +9 -24
  181. package/dist/views/Version/meta.js +9 -19
  182. package/dist/views/Version/shared.js +3 -21
  183. package/dist/views/Versions/buildColumns.js +13 -28
  184. package/dist/views/Versions/cells/AutosaveCell/index.js +8 -59
  185. package/dist/views/Versions/cells/CreatedAt/index.js +10 -25
  186. package/dist/views/Versions/cells/ID/index.js +6 -57
  187. package/dist/views/Versions/index.client.js +19 -70
  188. package/dist/views/Versions/index.js +18 -41
  189. package/dist/views/Versions/meta.js +7 -17
  190. package/dist/views/Versions/types.js +2 -5
  191. package/dist/withPayload.js +2 -3
  192. package/package.json +6 -6
@@ -1,40 +1,17 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- function _export(target, all) {
6
- for(var name in all)Object.defineProperty(target, name, {
7
- enumerable: true,
8
- get: all[name]
9
- });
10
- }
11
- _export(exports, {
12
- RootLayout: function() {
13
- return RootLayout;
14
- },
15
- metadata: function() {
16
- return metadata;
17
- }
18
- });
19
- const _client = require("@payloadcms/translations/client");
20
- const _ui = require("@payloadcms/ui");
21
- require("@payloadcms/ui/scss/app.scss");
22
- const _headers = require("next/headers");
23
- const _auth = require("payload/auth");
24
- const _config = require("payload/config");
25
- const _utilities = require("payload/utilities");
26
- const _react = /*#__PURE__*/ _interop_require_default(require("react"));
27
- require("react-toastify/dist/ReactToastify.css");
28
- const _getRequestLanguage = require("../../utilities/getRequestLanguage");
29
- const _Default = require("../../views/Edit/Default");
30
- const _Default1 = require("../../views/List/Default");
31
- const _Cell = require("../../views/List/Default/Cell");
32
- function _interop_require_default(obj) {
33
- return obj && obj.__esModule ? obj : {
34
- default: obj
35
- };
36
- }
37
- const metadata = {
1
+ import { translations } from '@payloadcms/translations/client';
2
+ import { RootProvider, buildComponentMap } from '@payloadcms/ui';
3
+ import '@payloadcms/ui/scss/app.scss';
4
+ import { headers as getHeaders } from 'next/headers';
5
+ import { parseCookies } from 'payload/auth';
6
+ import { createClientConfig } from 'payload/config';
7
+ import { deepMerge } from 'payload/utilities';
8
+ import React from 'react';
9
+ import 'react-toastify/dist/ReactToastify.css';
10
+ import { getRequestLanguage } from '../../utilities/getRequestLanguage';
11
+ import { DefaultEditView } from '../../views/Edit/Default';
12
+ import { DefaultListView } from '../../views/List/Default';
13
+ import { DefaultCell } from '../../views/List/Default/Cell';
14
+ export const metadata = {
38
15
  description: 'Generated by Next.js',
39
16
  title: 'Next.js'
40
17
  };
@@ -51,40 +28,40 @@ const rtlLanguages = [
51
28
  'he',
52
29
  'yi'
53
30
  ];
54
- const RootLayout = async ({ children, config: configPromise })=>{
31
+ export const RootLayout = async ({ children, config: configPromise })=>{
55
32
  const config = await configPromise;
56
- const clientConfig = await (0, _config.createClientConfig)(config);
57
- const headers = (0, _headers.headers)();
58
- const cookies = (0, _auth.parseCookies)(headers);
59
- const lang = (0, _getRequestLanguage.getRequestLanguage)({
33
+ const clientConfig = await createClientConfig(config);
34
+ const headers = getHeaders();
35
+ const cookies = parseCookies(headers);
36
+ const lang = getRequestLanguage({
60
37
  cookies,
61
38
  headers
62
39
  }) ?? clientConfig.i18n.fallbackLanguage;
63
40
  const dir = rtlLanguages.includes(lang) ? 'RTL' : 'LTR';
64
- const mergedTranslations = (0, _utilities.deepMerge)(_client.translations, clientConfig.i18n.translations);
65
- const languageOptions = Object.entries(_client.translations || {}).map(([language, translations])=>({
41
+ const mergedTranslations = deepMerge(translations, clientConfig.i18n.translations);
42
+ const languageOptions = Object.entries(translations || {}).map(([language, translations])=>({
66
43
  label: translations.general.thisLanguage,
67
44
  value: language
68
45
  }));
69
- const componentMap = (0, _ui.buildComponentMap)({
70
- DefaultCell: _Cell.DefaultCell,
71
- DefaultEditView: _Default.DefaultEditView,
72
- DefaultListView: _Default1.DefaultListView,
46
+ const componentMap = buildComponentMap({
47
+ DefaultCell,
48
+ DefaultEditView,
49
+ DefaultListView,
73
50
  config
74
51
  });
75
- return /*#__PURE__*/ _react.default.createElement("html", {
52
+ return /*#__PURE__*/ React.createElement("html", {
76
53
  dir: dir,
77
54
  lang: lang
78
- }, /*#__PURE__*/ _react.default.createElement("body", null, /*#__PURE__*/ _react.default.createElement(_ui.RootProvider, {
55
+ }, /*#__PURE__*/ React.createElement("body", null, /*#__PURE__*/ React.createElement(RootProvider, {
79
56
  componentMap: componentMap,
80
57
  config: clientConfig,
81
58
  fallbackLang: clientConfig.i18n.fallbackLanguage,
82
59
  lang: lang,
83
60
  languageOptions: languageOptions,
84
61
  translations: mergedTranslations[lang]
85
- }, children), /*#__PURE__*/ _react.default.createElement("div", {
62
+ }, children), /*#__PURE__*/ React.createElement("div", {
86
63
  id: "portal"
87
64
  })));
88
65
  };
89
66
 
90
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9sYXlvdXRzL1Jvb3QvaW5kZXgudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgU2FuaXRpemVkQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgYXV0aCB9IGZyb20gJ0BwYXlsb2FkY21zL25leHQvdXRpbGl0aWVzL2F1dGgnXG5pbXBvcnQgeyB0cmFuc2xhdGlvbnMgfSBmcm9tICdAcGF5bG9hZGNtcy90cmFuc2xhdGlvbnMvY2xpZW50J1xuaW1wb3J0IHsgUm9vdFByb3ZpZGVyLCBidWlsZENvbXBvbmVudE1hcCB9IGZyb20gJ0BwYXlsb2FkY21zL3VpJ1xuaW1wb3J0ICdAcGF5bG9hZGNtcy91aS9zY3NzL2FwcC5zY3NzJ1xuaW1wb3J0IHsgaGVhZGVycyBhcyBnZXRIZWFkZXJzIH0gZnJvbSAnbmV4dC9oZWFkZXJzJ1xuaW1wb3J0IHsgcGFyc2VDb29raWVzIH0gZnJvbSAncGF5bG9hZC9hdXRoJ1xuaW1wb3J0IHsgY3JlYXRlQ2xpZW50Q29uZmlnIH0gZnJvbSAncGF5bG9hZC9jb25maWcnXG5pbXBvcnQgeyBkZWVwTWVyZ2UgfSBmcm9tICdwYXlsb2FkL3V0aWxpdGllcydcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCdcbmltcG9ydCAncmVhY3QtdG9hc3RpZnkvZGlzdC9SZWFjdFRvYXN0aWZ5LmNzcydcblxuaW1wb3J0IHsgZ2V0UmVxdWVzdExhbmd1YWdlIH0gZnJvbSAnLi4vLi4vdXRpbGl0aWVzL2dldFJlcXVlc3RMYW5ndWFnZSdcbmltcG9ydCB7IERlZmF1bHRFZGl0VmlldyB9IGZyb20gJy4uLy4uL3ZpZXdzL0VkaXQvRGVmYXVsdCdcbmltcG9ydCB7IERlZmF1bHRMaXN0VmlldyB9IGZyb20gJy4uLy4uL3ZpZXdzL0xpc3QvRGVmYXVsdCdcbmltcG9ydCB7IERlZmF1bHRDZWxsIH0gZnJvbSAnLi4vLi4vdmlld3MvTGlzdC9EZWZhdWx0L0NlbGwnXG5cbmV4cG9ydCBjb25zdCBtZXRhZGF0YSA9IHtcbiAgZGVzY3JpcHRpb246ICdHZW5lcmF0ZWQgYnkgTmV4dC5qcycsXG4gIHRpdGxlOiAnTmV4dC5qcycsXG59XG5cbmNvbnN0IHJ0bExhbmd1YWdlcyA9IFsnYXInLCAnZmEnLCAnaGEnLCAna3UnLCAndXInLCAncHMnLCAnZHYnLCAna3MnLCAna2h3JywgJ2hlJywgJ3lpJ11cblxuZXhwb3J0IGNvbnN0IFJvb3RMYXlvdXQgPSBhc3luYyAoe1xuICBjaGlsZHJlbixcbiAgY29uZmlnOiBjb25maWdQcm9taXNlLFxufToge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlXG4gIGNvbmZpZzogUHJvbWlzZTxTYW5pdGl6ZWRDb25maWc+XG59KSA9PiB7XG4gIGNvbnN0IGNvbmZpZyA9IGF3YWl0IGNvbmZpZ1Byb21pc2VcbiAgY29uc3QgY2xpZW50Q29uZmlnID0gYXdhaXQgY3JlYXRlQ2xpZW50Q29uZmlnKGNvbmZpZylcblxuICBjb25zdCBoZWFkZXJzID0gZ2V0SGVhZGVycygpXG4gIGNvbnN0IGNvb2tpZXMgPSBwYXJzZUNvb2tpZXMoaGVhZGVycylcblxuICBjb25zdCBsYW5nID1cbiAgICBnZXRSZXF1ZXN0TGFuZ3VhZ2Uoe1xuICAgICAgY29va2llcyxcbiAgICAgIGhlYWRlcnMsXG4gICAgfSkgPz8gY2xpZW50Q29uZmlnLmkxOG4uZmFsbGJhY2tMYW5ndWFnZVxuXG4gIGNvbnN0IGRpciA9IHJ0bExhbmd1YWdlcy5pbmNsdWRlcyhsYW5nKSA/ICdSVEwnIDogJ0xUUidcblxuICBjb25zdCBtZXJnZWRUcmFuc2xhdGlvbnMgPSBkZWVwTWVyZ2UodHJhbnNsYXRpb25zLCBjbGllbnRDb25maWcuaTE4bi50cmFuc2xhdGlvbnMpXG5cbiAgY29uc3QgbGFuZ3VhZ2VPcHRpb25zID0gT2JqZWN0LmVudHJpZXModHJhbnNsYXRpb25zIHx8IHt9KS5tYXAoKFtsYW5ndWFnZSwgdHJhbnNsYXRpb25zXSkgPT4gKHtcbiAgICBsYWJlbDogdHJhbnNsYXRpb25zLmdlbmVyYWwudGhpc0xhbmd1YWdlLFxuICAgIHZhbHVlOiBsYW5ndWFnZSxcbiAgfSkpXG5cbiAgY29uc3QgY29tcG9uZW50TWFwID0gYnVpbGRDb21wb25lbnRNYXAoe1xuICAgIERlZmF1bHRDZWxsLFxuICAgIERlZmF1bHRFZGl0VmlldyxcbiAgICBEZWZhdWx0TGlzdFZpZXcsXG4gICAgY29uZmlnLFxuICB9KVxuXG4gIHJldHVybiAoXG4gICAgPGh0bWwgZGlyPXtkaXJ9IGxhbmc9e2xhbmd9PlxuICAgICAgPGJvZHk+XG4gICAgICAgIDxSb290UHJvdmlkZXJcbiAgICAgICAgICBjb21wb25lbnRNYXA9e2NvbXBvbmVudE1hcH1cbiAgICAgICAgICBjb25maWc9e2NsaWVudENvbmZpZ31cbiAgICAgICAgICBmYWxsYmFja0xhbmc9e2NsaWVudENvbmZpZy5pMThuLmZhbGxiYWNrTGFuZ3VhZ2V9XG4gICAgICAgICAgbGFuZz17bGFuZ31cbiAgICAgICAgICBsYW5ndWFnZU9wdGlvbnM9e2xhbmd1YWdlT3B0aW9uc31cbiAgICAgICAgICB0cmFuc2xhdGlvbnM9e21lcmdlZFRyYW5zbGF0aW9uc1tsYW5nXX1cbiAgICAgICAgPlxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9Sb290UHJvdmlkZXI+XG4gICAgICAgIDxkaXYgaWQ9XCJwb3J0YWxcIiAvPlxuICAgICAgPC9ib2R5PlxuICAgIDwvaHRtbD5cbiAgKVxufVxuIl0sIm5hbWVzIjpbIlJvb3RMYXlvdXQiLCJtZXRhZGF0YSIsImRlc2NyaXB0aW9uIiwidGl0bGUiLCJydGxMYW5ndWFnZXMiLCJjaGlsZHJlbiIsImNvbmZpZyIsImNvbmZpZ1Byb21pc2UiLCJjbGllbnRDb25maWciLCJjcmVhdGVDbGllbnRDb25maWciLCJoZWFkZXJzIiwiZ2V0SGVhZGVycyIsImNvb2tpZXMiLCJwYXJzZUNvb2tpZXMiLCJsYW5nIiwiZ2V0UmVxdWVzdExhbmd1YWdlIiwiaTE4biIsImZhbGxiYWNrTGFuZ3VhZ2UiLCJkaXIiLCJpbmNsdWRlcyIsIm1lcmdlZFRyYW5zbGF0aW9ucyIsImRlZXBNZXJnZSIsInRyYW5zbGF0aW9ucyIsImxhbmd1YWdlT3B0aW9ucyIsIk9iamVjdCIsImVudHJpZXMiLCJtYXAiLCJsYW5ndWFnZSIsImxhYmVsIiwiZ2VuZXJhbCIsInRoaXNMYW5ndWFnZSIsInZhbHVlIiwiY29tcG9uZW50TWFwIiwiYnVpbGRDb21wb25lbnRNYXAiLCJEZWZhdWx0Q2VsbCIsIkRlZmF1bHRFZGl0VmlldyIsIkRlZmF1bHRMaXN0VmlldyIsImh0bWwiLCJib2R5IiwiUm9vdFByb3ZpZGVyIiwiZmFsbGJhY2tMYW5nIiwiZGl2IiwiaWQiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0lBeUJhQSxVQUFVO2VBQVZBOztJQVBBQyxRQUFRO2VBQVJBOzs7d0JBZmdCO29CQUNtQjtRQUN6Qzt5QkFDK0I7c0JBQ1Q7d0JBQ007MkJBQ1Q7OERBQ1I7UUFDWDtvQ0FFNEI7eUJBQ0g7MEJBQ0E7c0JBQ0o7Ozs7OztBQUVyQixNQUFNQSxXQUFXO0lBQ3RCQyxhQUFhO0lBQ2JDLE9BQU87QUFDVDtBQUVBLE1BQU1DLGVBQWU7SUFBQztJQUFNO0lBQU07SUFBTTtJQUFNO0lBQU07SUFBTTtJQUFNO0lBQU07SUFBTztJQUFNO0NBQUs7QUFFakYsTUFBTUosYUFBYSxPQUFPLEVBQy9CSyxRQUFRLEVBQ1JDLFFBQVFDLGFBQWEsRUFJdEI7SUFDQyxNQUFNRCxTQUFTLE1BQU1DO0lBQ3JCLE1BQU1DLGVBQWUsTUFBTUMsSUFBQUEsMEJBQWtCLEVBQUNIO0lBRTlDLE1BQU1JLFVBQVVDLElBQUFBLGdCQUFVO0lBQzFCLE1BQU1DLFVBQVVDLElBQUFBLGtCQUFZLEVBQUNIO0lBRTdCLE1BQU1JLE9BQ0pDLElBQUFBLHNDQUFrQixFQUFDO1FBQ2pCSDtRQUNBRjtJQUNGLE1BQU1GLGFBQWFRLElBQUksQ0FBQ0MsZ0JBQWdCO0lBRTFDLE1BQU1DLE1BQU1kLGFBQWFlLFFBQVEsQ0FBQ0wsUUFBUSxRQUFRO0lBRWxELE1BQU1NLHFCQUFxQkMsSUFBQUEsb0JBQVMsRUFBQ0Msb0JBQVksRUFBRWQsYUFBYVEsSUFBSSxDQUFDTSxZQUFZO0lBRWpGLE1BQU1DLGtCQUFrQkMsT0FBT0MsT0FBTyxDQUFDSCxvQkFBWSxJQUFJLENBQUMsR0FBR0ksR0FBRyxDQUFDLENBQUMsQ0FBQ0MsVUFBVUwsYUFBYSxHQUFNLENBQUE7WUFDNUZNLE9BQU9OLGFBQWFPLE9BQU8sQ0FBQ0MsWUFBWTtZQUN4Q0MsT0FBT0o7UUFDVCxDQUFBO0lBRUEsTUFBTUssZUFBZUMsSUFBQUEscUJBQWlCLEVBQUM7UUFDckNDLGFBQUFBLGlCQUFXO1FBQ1hDLGlCQUFBQSx3QkFBZTtRQUNmQyxpQkFBQUEseUJBQWU7UUFDZjlCO0lBQ0Y7SUFFQSxxQkFDRSw2QkFBQytCO1FBQUtuQixLQUFLQTtRQUFLSixNQUFNQTtxQkFDcEIsNkJBQUN3Qiw0QkFDQyw2QkFBQ0MsZ0JBQVk7UUFDWFAsY0FBY0E7UUFDZDFCLFFBQVFFO1FBQ1JnQyxjQUFjaEMsYUFBYVEsSUFBSSxDQUFDQyxnQkFBZ0I7UUFDaERILE1BQU1BO1FBQ05TLGlCQUFpQkE7UUFDakJELGNBQWNGLGtCQUFrQixDQUFDTixLQUFLO09BRXJDVCx5QkFFSCw2QkFBQ29DO1FBQUlDLElBQUc7O0FBSWhCIn0=
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9sYXlvdXRzL1Jvb3QvaW5kZXgudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgU2FuaXRpemVkQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgYXV0aCB9IGZyb20gJ0BwYXlsb2FkY21zL25leHQvdXRpbGl0aWVzL2F1dGgnXG5pbXBvcnQgeyB0cmFuc2xhdGlvbnMgfSBmcm9tICdAcGF5bG9hZGNtcy90cmFuc2xhdGlvbnMvY2xpZW50J1xuaW1wb3J0IHsgUm9vdFByb3ZpZGVyLCBidWlsZENvbXBvbmVudE1hcCB9IGZyb20gJ0BwYXlsb2FkY21zL3VpJ1xuaW1wb3J0ICdAcGF5bG9hZGNtcy91aS9zY3NzL2FwcC5zY3NzJ1xuaW1wb3J0IHsgaGVhZGVycyBhcyBnZXRIZWFkZXJzIH0gZnJvbSAnbmV4dC9oZWFkZXJzJ1xuaW1wb3J0IHsgcGFyc2VDb29raWVzIH0gZnJvbSAncGF5bG9hZC9hdXRoJ1xuaW1wb3J0IHsgY3JlYXRlQ2xpZW50Q29uZmlnIH0gZnJvbSAncGF5bG9hZC9jb25maWcnXG5pbXBvcnQgeyBkZWVwTWVyZ2UgfSBmcm9tICdwYXlsb2FkL3V0aWxpdGllcydcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCdcbmltcG9ydCAncmVhY3QtdG9hc3RpZnkvZGlzdC9SZWFjdFRvYXN0aWZ5LmNzcydcblxuaW1wb3J0IHsgZ2V0UmVxdWVzdExhbmd1YWdlIH0gZnJvbSAnLi4vLi4vdXRpbGl0aWVzL2dldFJlcXVlc3RMYW5ndWFnZSdcbmltcG9ydCB7IERlZmF1bHRFZGl0VmlldyB9IGZyb20gJy4uLy4uL3ZpZXdzL0VkaXQvRGVmYXVsdCdcbmltcG9ydCB7IERlZmF1bHRMaXN0VmlldyB9IGZyb20gJy4uLy4uL3ZpZXdzL0xpc3QvRGVmYXVsdCdcbmltcG9ydCB7IERlZmF1bHRDZWxsIH0gZnJvbSAnLi4vLi4vdmlld3MvTGlzdC9EZWZhdWx0L0NlbGwnXG5cbmV4cG9ydCBjb25zdCBtZXRhZGF0YSA9IHtcbiAgZGVzY3JpcHRpb246ICdHZW5lcmF0ZWQgYnkgTmV4dC5qcycsXG4gIHRpdGxlOiAnTmV4dC5qcycsXG59XG5cbmNvbnN0IHJ0bExhbmd1YWdlcyA9IFsnYXInLCAnZmEnLCAnaGEnLCAna3UnLCAndXInLCAncHMnLCAnZHYnLCAna3MnLCAna2h3JywgJ2hlJywgJ3lpJ11cblxuZXhwb3J0IGNvbnN0IFJvb3RMYXlvdXQgPSBhc3luYyAoe1xuICBjaGlsZHJlbixcbiAgY29uZmlnOiBjb25maWdQcm9taXNlLFxufToge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlXG4gIGNvbmZpZzogUHJvbWlzZTxTYW5pdGl6ZWRDb25maWc+XG59KSA9PiB7XG4gIGNvbnN0IGNvbmZpZyA9IGF3YWl0IGNvbmZpZ1Byb21pc2VcbiAgY29uc3QgY2xpZW50Q29uZmlnID0gYXdhaXQgY3JlYXRlQ2xpZW50Q29uZmlnKGNvbmZpZylcblxuICBjb25zdCBoZWFkZXJzID0gZ2V0SGVhZGVycygpXG4gIGNvbnN0IGNvb2tpZXMgPSBwYXJzZUNvb2tpZXMoaGVhZGVycylcblxuICBjb25zdCBsYW5nID1cbiAgICBnZXRSZXF1ZXN0TGFuZ3VhZ2Uoe1xuICAgICAgY29va2llcyxcbiAgICAgIGhlYWRlcnMsXG4gICAgfSkgPz8gY2xpZW50Q29uZmlnLmkxOG4uZmFsbGJhY2tMYW5ndWFnZVxuXG4gIGNvbnN0IGRpciA9IHJ0bExhbmd1YWdlcy5pbmNsdWRlcyhsYW5nKSA/ICdSVEwnIDogJ0xUUidcblxuICBjb25zdCBtZXJnZWRUcmFuc2xhdGlvbnMgPSBkZWVwTWVyZ2UodHJhbnNsYXRpb25zLCBjbGllbnRDb25maWcuaTE4bi50cmFuc2xhdGlvbnMpXG5cbiAgY29uc3QgbGFuZ3VhZ2VPcHRpb25zID0gT2JqZWN0LmVudHJpZXModHJhbnNsYXRpb25zIHx8IHt9KS5tYXAoKFtsYW5ndWFnZSwgdHJhbnNsYXRpb25zXSkgPT4gKHtcbiAgICBsYWJlbDogdHJhbnNsYXRpb25zLmdlbmVyYWwudGhpc0xhbmd1YWdlLFxuICAgIHZhbHVlOiBsYW5ndWFnZSxcbiAgfSkpXG5cbiAgY29uc3QgY29tcG9uZW50TWFwID0gYnVpbGRDb21wb25lbnRNYXAoe1xuICAgIERlZmF1bHRDZWxsLFxuICAgIERlZmF1bHRFZGl0VmlldyxcbiAgICBEZWZhdWx0TGlzdFZpZXcsXG4gICAgY29uZmlnLFxuICB9KVxuXG4gIHJldHVybiAoXG4gICAgPGh0bWwgZGlyPXtkaXJ9IGxhbmc9e2xhbmd9PlxuICAgICAgPGJvZHk+XG4gICAgICAgIDxSb290UHJvdmlkZXJcbiAgICAgICAgICBjb21wb25lbnRNYXA9e2NvbXBvbmVudE1hcH1cbiAgICAgICAgICBjb25maWc9e2NsaWVudENvbmZpZ31cbiAgICAgICAgICBmYWxsYmFja0xhbmc9e2NsaWVudENvbmZpZy5pMThuLmZhbGxiYWNrTGFuZ3VhZ2V9XG4gICAgICAgICAgbGFuZz17bGFuZ31cbiAgICAgICAgICBsYW5ndWFnZU9wdGlvbnM9e2xhbmd1YWdlT3B0aW9uc31cbiAgICAgICAgICB0cmFuc2xhdGlvbnM9e21lcmdlZFRyYW5zbGF0aW9uc1tsYW5nXX1cbiAgICAgICAgPlxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9Sb290UHJvdmlkZXI+XG4gICAgICAgIDxkaXYgaWQ9XCJwb3J0YWxcIiAvPlxuICAgICAgPC9ib2R5PlxuICAgIDwvaHRtbD5cbiAgKVxufVxuIl0sIm5hbWVzIjpbInRyYW5zbGF0aW9ucyIsIlJvb3RQcm92aWRlciIsImJ1aWxkQ29tcG9uZW50TWFwIiwiaGVhZGVycyIsImdldEhlYWRlcnMiLCJwYXJzZUNvb2tpZXMiLCJjcmVhdGVDbGllbnRDb25maWciLCJkZWVwTWVyZ2UiLCJSZWFjdCIsImdldFJlcXVlc3RMYW5ndWFnZSIsIkRlZmF1bHRFZGl0VmlldyIsIkRlZmF1bHRMaXN0VmlldyIsIkRlZmF1bHRDZWxsIiwibWV0YWRhdGEiLCJkZXNjcmlwdGlvbiIsInRpdGxlIiwicnRsTGFuZ3VhZ2VzIiwiUm9vdExheW91dCIsImNoaWxkcmVuIiwiY29uZmlnIiwiY29uZmlnUHJvbWlzZSIsImNsaWVudENvbmZpZyIsImNvb2tpZXMiLCJsYW5nIiwiaTE4biIsImZhbGxiYWNrTGFuZ3VhZ2UiLCJkaXIiLCJpbmNsdWRlcyIsIm1lcmdlZFRyYW5zbGF0aW9ucyIsImxhbmd1YWdlT3B0aW9ucyIsIk9iamVjdCIsImVudHJpZXMiLCJtYXAiLCJsYW5ndWFnZSIsImxhYmVsIiwiZ2VuZXJhbCIsInRoaXNMYW5ndWFnZSIsInZhbHVlIiwiY29tcG9uZW50TWFwIiwiaHRtbCIsImJvZHkiLCJmYWxsYmFja0xhbmciLCJkaXYiLCJpZCJdLCJtYXBwaW5ncyI6IkFBR0EsU0FBU0EsWUFBWSxRQUFRLGtDQUFpQztBQUM5RCxTQUFTQyxZQUFZLEVBQUVDLGlCQUFpQixRQUFRLGlCQUFnQjtBQUNoRSxPQUFPLCtCQUE4QjtBQUNyQyxTQUFTQyxXQUFXQyxVQUFVLFFBQVEsZUFBYztBQUNwRCxTQUFTQyxZQUFZLFFBQVEsZUFBYztBQUMzQyxTQUFTQyxrQkFBa0IsUUFBUSxpQkFBZ0I7QUFDbkQsU0FBU0MsU0FBUyxRQUFRLG9CQUFtQjtBQUM3QyxPQUFPQyxXQUFXLFFBQU87QUFDekIsT0FBTyx3Q0FBdUM7QUFFOUMsU0FBU0Msa0JBQWtCLFFBQVEscUNBQW9DO0FBQ3ZFLFNBQVNDLGVBQWUsUUFBUSwyQkFBMEI7QUFDMUQsU0FBU0MsZUFBZSxRQUFRLDJCQUEwQjtBQUMxRCxTQUFTQyxXQUFXLFFBQVEsZ0NBQStCO0FBRTNELE9BQU8sTUFBTUMsV0FBVztJQUN0QkMsYUFBYTtJQUNiQyxPQUFPO0FBQ1QsRUFBQztBQUVELE1BQU1DLGVBQWU7SUFBQztJQUFNO0lBQU07SUFBTTtJQUFNO0lBQU07SUFBTTtJQUFNO0lBQU07SUFBTztJQUFNO0NBQUs7QUFFeEYsT0FBTyxNQUFNQyxhQUFhLE9BQU8sRUFDL0JDLFFBQVEsRUFDUkMsUUFBUUMsYUFBYSxFQUl0QjtJQUNDLE1BQU1ELFNBQVMsTUFBTUM7SUFDckIsTUFBTUMsZUFBZSxNQUFNZixtQkFBbUJhO0lBRTlDLE1BQU1oQixVQUFVQztJQUNoQixNQUFNa0IsVUFBVWpCLGFBQWFGO0lBRTdCLE1BQU1vQixPQUNKZCxtQkFBbUI7UUFDakJhO1FBQ0FuQjtJQUNGLE1BQU1rQixhQUFhRyxJQUFJLENBQUNDLGdCQUFnQjtJQUUxQyxNQUFNQyxNQUFNVixhQUFhVyxRQUFRLENBQUNKLFFBQVEsUUFBUTtJQUVsRCxNQUFNSyxxQkFBcUJyQixVQUFVUCxjQUFjcUIsYUFBYUcsSUFBSSxDQUFDeEIsWUFBWTtJQUVqRixNQUFNNkIsa0JBQWtCQyxPQUFPQyxPQUFPLENBQUMvQixnQkFBZ0IsQ0FBQyxHQUFHZ0MsR0FBRyxDQUFDLENBQUMsQ0FBQ0MsVUFBVWpDLGFBQWEsR0FBTSxDQUFBO1lBQzVGa0MsT0FBT2xDLGFBQWFtQyxPQUFPLENBQUNDLFlBQVk7WUFDeENDLE9BQU9KO1FBQ1QsQ0FBQTtJQUVBLE1BQU1LLGVBQWVwQyxrQkFBa0I7UUFDckNVO1FBQ0FGO1FBQ0FDO1FBQ0FRO0lBQ0Y7SUFFQSxxQkFDRSxvQkFBQ29CO1FBQUtiLEtBQUtBO1FBQUtILE1BQU1BO3FCQUNwQixvQkFBQ2lCLDRCQUNDLG9CQUFDdkM7UUFDQ3FDLGNBQWNBO1FBQ2RuQixRQUFRRTtRQUNSb0IsY0FBY3BCLGFBQWFHLElBQUksQ0FBQ0MsZ0JBQWdCO1FBQ2hERixNQUFNQTtRQUNOTSxpQkFBaUJBO1FBQ2pCN0IsY0FBYzRCLGtCQUFrQixDQUFDTCxLQUFLO09BRXJDTCx5QkFFSCxvQkFBQ3dCO1FBQUlDLElBQUc7O0FBSWhCLEVBQUMifQ==
@@ -1,29 +1,19 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "fileFactory", {
6
- enumerable: true,
7
- get: function() {
8
- return fileFactory;
9
- }
10
- });
11
- const _utilities = require("./utilities");
1
+ import { checkAndMakeDir, debugLog, isFunc, moveFile, promiseCallback, saveBufferToFile } from './utilities';
12
2
  /**
13
3
  * Returns Local function that moves the file to a different location on the filesystem
14
4
  * which takes two function arguments to make it compatible w/ Promise or Callback APIs
15
5
  */ const moveFromTemp = (filePath, options, fileUploadOptions)=>(resolve, reject)=>{
16
- (0, _utilities.debugLog)(fileUploadOptions, `Moving temporary file ${options.tempFilePath} to ${filePath}`);
17
- (0, _utilities.moveFile)(options.tempFilePath, filePath, (0, _utilities.promiseCallback)(resolve, reject));
6
+ debugLog(fileUploadOptions, `Moving temporary file ${options.tempFilePath} to ${filePath}`);
7
+ moveFile(options.tempFilePath, filePath, promiseCallback(resolve, reject));
18
8
  };
19
9
  /**
20
10
  * Returns Local function that moves the file from buffer to a different location on the filesystem
21
11
  * which takes two function arguments to make it compatible w/ Promise or Callback APIs
22
12
  */ const moveFromBuffer = (filePath, options, fileUploadOptions)=>(resolve, reject)=>{
23
- (0, _utilities.debugLog)(fileUploadOptions, `Moving uploaded buffer to ${filePath}`);
24
- (0, _utilities.saveBufferToFile)(options.buffer, filePath, (0, _utilities.promiseCallback)(resolve, reject));
13
+ debugLog(fileUploadOptions, `Moving uploaded buffer to ${filePath}`);
14
+ saveBufferToFile(options.buffer, filePath, promiseCallback(resolve, reject));
25
15
  };
26
- const fileFactory = (options, fileUploadOptions)=>{
16
+ export const fileFactory = (options, fileUploadOptions)=>{
27
17
  // see: https://github.com/richardgirges/express-fileupload/issues/14
28
18
  // firefox uploads empty file in case of cache miss when f5ing page.
29
19
  // resulting in unexpected behavior. if there is no file data, the file is invalid.
@@ -39,10 +29,10 @@ const fileFactory = (options, fileUploadOptions)=>{
39
29
  // Define a proper move function.
40
30
  const moveFunc = fileUploadOptions.useTempFiles ? moveFromTemp(filePath, options, fileUploadOptions) : moveFromBuffer(filePath, options, fileUploadOptions);
41
31
  // Create a folder for a file.
42
- (0, _utilities.checkAndMakeDir)(fileUploadOptions, filePath);
32
+ checkAndMakeDir(fileUploadOptions, filePath);
43
33
  // If callback is passed in, use the callback API, otherwise return a promise.
44
34
  const defaultReject = ()=>undefined;
45
- return (0, _utilities.isFunc)(callback) ? moveFunc(callback, defaultReject) : new Promise(moveFunc);
35
+ return isFunc(callback) ? moveFunc(callback, defaultReject) : new Promise(moveFunc);
46
36
  },
47
37
  size: options.size,
48
38
  tempFilePath: options.tempFilePath,
@@ -50,4 +40,4 @@ const fileFactory = (options, fileUploadOptions)=>{
50
40
  };
51
41
  };
52
42
 
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9uZXh0LWZpbGV1cGxvYWQvZmlsZUZhY3RvcnkudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBGaWxlU2hhcGUsIE5leHRGaWxlVXBsb2FkT3B0aW9ucyB9IGZyb20gJy4nXG5cbmltcG9ydCB7XG4gIGNoZWNrQW5kTWFrZURpcixcbiAgZGVidWdMb2csXG4gIGlzRnVuYyxcbiAgbW92ZUZpbGUsXG4gIHByb21pc2VDYWxsYmFjayxcbiAgc2F2ZUJ1ZmZlclRvRmlsZSxcbn0gZnJvbSAnLi91dGlsaXRpZXMnXG5cbnR5cGUgTW92ZUZpbGUgPSAoXG4gIGZpbGVQYXRoOiBzdHJpbmcsXG4gIG9wdGlvbnM6IEZpbGVGYWN0b3J5T3B0aW9ucyxcbiAgZmlsZVVwbG9hZE9wdGlvbnM6IE5leHRGaWxlVXBsb2FkT3B0aW9ucyxcbikgPT4gKHJlc29sdmU6ICgpID0+IHZvaWQsIHJlamVjdDogKCkgPT4gdm9pZCkgPT4gdm9pZFxuXG4vKipcbiAqIFJldHVybnMgTG9jYWwgZnVuY3Rpb24gdGhhdCBtb3ZlcyB0aGUgZmlsZSB0byBhIGRpZmZlcmVudCBsb2NhdGlvbiBvbiB0aGUgZmlsZXN5c3RlbVxuICogd2hpY2ggdGFrZXMgdHdvIGZ1bmN0aW9uIGFyZ3VtZW50cyB0byBtYWtlIGl0IGNvbXBhdGlibGUgdy8gUHJvbWlzZSBvciBDYWxsYmFjayBBUElzXG4gKi9cbmNvbnN0IG1vdmVGcm9tVGVtcDogTW92ZUZpbGUgPSAoZmlsZVBhdGgsIG9wdGlvbnMsIGZpbGVVcGxvYWRPcHRpb25zKSA9PiAocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gIGRlYnVnTG9nKGZpbGVVcGxvYWRPcHRpb25zLCBgTW92aW5nIHRlbXBvcmFyeSBmaWxlICR7b3B0aW9ucy50ZW1wRmlsZVBhdGh9IHRvICR7ZmlsZVBhdGh9YClcbiAgbW92ZUZpbGUob3B0aW9ucy50ZW1wRmlsZVBhdGgsIGZpbGVQYXRoLCBwcm9taXNlQ2FsbGJhY2socmVzb2x2ZSwgcmVqZWN0KSlcbn1cblxuLyoqXG4gKiBSZXR1cm5zIExvY2FsIGZ1bmN0aW9uIHRoYXQgbW92ZXMgdGhlIGZpbGUgZnJvbSBidWZmZXIgdG8gYSBkaWZmZXJlbnQgbG9jYXRpb24gb24gdGhlIGZpbGVzeXN0ZW1cbiAqIHdoaWNoIHRha2VzIHR3byBmdW5jdGlvbiBhcmd1bWVudHMgdG8gbWFrZSBpdCBjb21wYXRpYmxlIHcvIFByb21pc2Ugb3IgQ2FsbGJhY2sgQVBJc1xuICovXG5jb25zdCBtb3ZlRnJvbUJ1ZmZlcjogTW92ZUZpbGUgPSAoZmlsZVBhdGgsIG9wdGlvbnMsIGZpbGVVcGxvYWRPcHRpb25zKSA9PiAocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gIGRlYnVnTG9nKGZpbGVVcGxvYWRPcHRpb25zLCBgTW92aW5nIHVwbG9hZGVkIGJ1ZmZlciB0byAke2ZpbGVQYXRofWApXG4gIHNhdmVCdWZmZXJUb0ZpbGUob3B0aW9ucy5idWZmZXIsIGZpbGVQYXRoLCBwcm9taXNlQ2FsbGJhY2socmVzb2x2ZSwgcmVqZWN0KSlcbn1cblxudHlwZSBGaWxlRmFjdG9yeU9wdGlvbnMgPSB7XG4gIGJ1ZmZlcjogQnVmZmVyXG4gIGVuY29kaW5nOiBzdHJpbmdcbiAgaGFzaDogQnVmZmVyIHwgc3RyaW5nXG4gIG1pbWV0eXBlOiBzdHJpbmdcbiAgbmFtZTogc3RyaW5nXG4gIHNpemU6IG51bWJlclxuICB0ZW1wRmlsZVBhdGg6IHN0cmluZ1xuICB0cnVuY2F0ZWQ6IGJvb2xlYW5cbn1cbnR5cGUgRmlsZUZhY3RvcnkgPSAoXG4gIG9wdGlvbnM6IEZpbGVGYWN0b3J5T3B0aW9ucyxcbiAgZmlsZVVwbG9hZE9wdGlvbnM6IE5leHRGaWxlVXBsb2FkT3B0aW9ucyxcbikgPT4gRmlsZVNoYXBlXG5leHBvcnQgY29uc3QgZmlsZUZhY3Rvcnk6IEZpbGVGYWN0b3J5ID0gKG9wdGlvbnMsIGZpbGVVcGxvYWRPcHRpb25zKSA9PiB7XG4gIC8vIHNlZTogaHR0cHM6Ly9naXRodWIuY29tL3JpY2hhcmRnaXJnZXMvZXhwcmVzcy1maWxldXBsb2FkL2lzc3Vlcy8xNFxuICAvLyBmaXJlZm94IHVwbG9hZHMgZW1wdHkgZmlsZSBpbiBjYXNlIG9mIGNhY2hlIG1pc3Mgd2hlbiBmNWluZyBwYWdlLlxuICAvLyByZXN1bHRpbmcgaW4gdW5leHBlY3RlZCBiZWhhdmlvci4gaWYgdGhlcmUgaXMgbm8gZmlsZSBkYXRhLCB0aGUgZmlsZSBpcyBpbnZhbGlkLlxuICAvLyBpZiAoIWZpbGVVcGxvYWRPcHRpb25zLnVzZVRlbXBGaWxlcyAmJiAhb3B0aW9ucy5idWZmZXIubGVuZ3RoKSByZXR1cm47XG5cbiAgLy8gQ3JlYXRlIGFuZCByZXR1cm4gZmlsZSBvYmplY3QuXG4gIHJldHVybiB7XG4gICAgbmFtZTogb3B0aW9ucy5uYW1lLFxuICAgIGRhdGE6IG9wdGlvbnMuYnVmZmVyLFxuICAgIGVuY29kaW5nOiBvcHRpb25zLmVuY29kaW5nLFxuICAgIG1kNTogb3B0aW9ucy5oYXNoLFxuICAgIG1pbWV0eXBlOiBvcHRpb25zLm1pbWV0eXBlLFxuICAgIG12OiAoZmlsZVBhdGg6IHN0cmluZywgY2FsbGJhY2spID0+IHtcbiAgICAgIC8vIERlZmluZSBhIHByb3BlciBtb3ZlIGZ1bmN0aW9uLlxuICAgICAgY29uc3QgbW92ZUZ1bmMgPSBmaWxlVXBsb2FkT3B0aW9ucy51c2VUZW1wRmlsZXNcbiAgICAgICAgPyBtb3ZlRnJvbVRlbXAoZmlsZVBhdGgsIG9wdGlvbnMsIGZpbGVVcGxvYWRPcHRpb25zKVxuICAgICAgICA6IG1vdmVGcm9tQnVmZmVyKGZpbGVQYXRoLCBvcHRpb25zLCBmaWxlVXBsb2FkT3B0aW9ucylcbiAgICAgIC8vIENyZWF0ZSBhIGZvbGRlciBmb3IgYSBmaWxlLlxuICAgICAgY2hlY2tBbmRNYWtlRGlyKGZpbGVVcGxvYWRPcHRpb25zLCBmaWxlUGF0aClcbiAgICAgIC8vIElmIGNhbGxiYWNrIGlzIHBhc3NlZCBpbiwgdXNlIHRoZSBjYWxsYmFjayBBUEksIG90aGVyd2lzZSByZXR1cm4gYSBwcm9taXNlLlxuICAgICAgY29uc3QgZGVmYXVsdFJlamVjdCA9ICgpID0+IHVuZGVmaW5lZFxuICAgICAgcmV0dXJuIGlzRnVuYyhjYWxsYmFjaykgPyBtb3ZlRnVuYyhjYWxsYmFjaywgZGVmYXVsdFJlamVjdCkgOiBuZXcgUHJvbWlzZShtb3ZlRnVuYylcbiAgICB9LFxuICAgIHNpemU6IG9wdGlvbnMuc2l6ZSxcbiAgICB0ZW1wRmlsZVBhdGg6IG9wdGlvbnMudGVtcEZpbGVQYXRoLFxuICAgIHRydW5jYXRlZDogb3B0aW9ucy50cnVuY2F0ZWQsXG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJmaWxlRmFjdG9yeSIsIm1vdmVGcm9tVGVtcCIsImZpbGVQYXRoIiwib3B0aW9ucyIsImZpbGVVcGxvYWRPcHRpb25zIiwicmVzb2x2ZSIsInJlamVjdCIsImRlYnVnTG9nIiwidGVtcEZpbGVQYXRoIiwibW92ZUZpbGUiLCJwcm9taXNlQ2FsbGJhY2siLCJtb3ZlRnJvbUJ1ZmZlciIsInNhdmVCdWZmZXJUb0ZpbGUiLCJidWZmZXIiLCJuYW1lIiwiZGF0YSIsImVuY29kaW5nIiwibWQ1IiwiaGFzaCIsIm1pbWV0eXBlIiwibXYiLCJjYWxsYmFjayIsIm1vdmVGdW5jIiwidXNlVGVtcEZpbGVzIiwiY2hlY2tBbmRNYWtlRGlyIiwiZGVmYXVsdFJlamVjdCIsInVuZGVmaW5lZCIsImlzRnVuYyIsIlByb21pc2UiLCJzaXplIiwidHJ1bmNhdGVkIl0sIm1hcHBpbmdzIjoiOzs7OytCQWlEYUE7OztlQUFBQTs7OzJCQXhDTjtBQVFQOzs7Q0FHQyxHQUNELE1BQU1DLGVBQXlCLENBQUNDLFVBQVVDLFNBQVNDLG9CQUFzQixDQUFDQyxTQUFTQztRQUNqRkMsSUFBQUEsbUJBQVEsRUFBQ0gsbUJBQW1CLENBQUMsc0JBQXNCLEVBQUVELFFBQVFLLFlBQVksQ0FBQyxJQUFJLEVBQUVOLFNBQVMsQ0FBQztRQUMxRk8sSUFBQUEsbUJBQVEsRUFBQ04sUUFBUUssWUFBWSxFQUFFTixVQUFVUSxJQUFBQSwwQkFBZSxFQUFDTCxTQUFTQztJQUNwRTtBQUVBOzs7Q0FHQyxHQUNELE1BQU1LLGlCQUEyQixDQUFDVCxVQUFVQyxTQUFTQyxvQkFBc0IsQ0FBQ0MsU0FBU0M7UUFDbkZDLElBQUFBLG1CQUFRLEVBQUNILG1CQUFtQixDQUFDLDBCQUEwQixFQUFFRixTQUFTLENBQUM7UUFDbkVVLElBQUFBLDJCQUFnQixFQUFDVCxRQUFRVSxNQUFNLEVBQUVYLFVBQVVRLElBQUFBLDBCQUFlLEVBQUNMLFNBQVNDO0lBQ3RFO0FBZ0JPLE1BQU1OLGNBQTJCLENBQUNHLFNBQVNDO0lBQ2hELHFFQUFxRTtJQUNyRSxvRUFBb0U7SUFDcEUsbUZBQW1GO0lBQ25GLHlFQUF5RTtJQUV6RSxpQ0FBaUM7SUFDakMsT0FBTztRQUNMVSxNQUFNWCxRQUFRVyxJQUFJO1FBQ2xCQyxNQUFNWixRQUFRVSxNQUFNO1FBQ3BCRyxVQUFVYixRQUFRYSxRQUFRO1FBQzFCQyxLQUFLZCxRQUFRZSxJQUFJO1FBQ2pCQyxVQUFVaEIsUUFBUWdCLFFBQVE7UUFDMUJDLElBQUksQ0FBQ2xCLFVBQWtCbUI7WUFDckIsaUNBQWlDO1lBQ2pDLE1BQU1DLFdBQVdsQixrQkFBa0JtQixZQUFZLEdBQzNDdEIsYUFBYUMsVUFBVUMsU0FBU0MscUJBQ2hDTyxlQUFlVCxVQUFVQyxTQUFTQztZQUN0Qyw4QkFBOEI7WUFDOUJvQixJQUFBQSwwQkFBZSxFQUFDcEIsbUJBQW1CRjtZQUNuQyw4RUFBOEU7WUFDOUUsTUFBTXVCLGdCQUFnQixJQUFNQztZQUM1QixPQUFPQyxJQUFBQSxpQkFBTSxFQUFDTixZQUFZQyxTQUFTRCxVQUFVSSxpQkFBaUIsSUFBSUcsUUFBUU47UUFDNUU7UUFDQU8sTUFBTTFCLFFBQVEwQixJQUFJO1FBQ2xCckIsY0FBY0wsUUFBUUssWUFBWTtRQUNsQ3NCLFdBQVczQixRQUFRMkIsU0FBUztJQUM5QjtBQUNGIn0=
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9uZXh0LWZpbGV1cGxvYWQvZmlsZUZhY3RvcnkudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBGaWxlU2hhcGUsIE5leHRGaWxlVXBsb2FkT3B0aW9ucyB9IGZyb20gJy4nXG5cbmltcG9ydCB7XG4gIGNoZWNrQW5kTWFrZURpcixcbiAgZGVidWdMb2csXG4gIGlzRnVuYyxcbiAgbW92ZUZpbGUsXG4gIHByb21pc2VDYWxsYmFjayxcbiAgc2F2ZUJ1ZmZlclRvRmlsZSxcbn0gZnJvbSAnLi91dGlsaXRpZXMnXG5cbnR5cGUgTW92ZUZpbGUgPSAoXG4gIGZpbGVQYXRoOiBzdHJpbmcsXG4gIG9wdGlvbnM6IEZpbGVGYWN0b3J5T3B0aW9ucyxcbiAgZmlsZVVwbG9hZE9wdGlvbnM6IE5leHRGaWxlVXBsb2FkT3B0aW9ucyxcbikgPT4gKHJlc29sdmU6ICgpID0+IHZvaWQsIHJlamVjdDogKCkgPT4gdm9pZCkgPT4gdm9pZFxuXG4vKipcbiAqIFJldHVybnMgTG9jYWwgZnVuY3Rpb24gdGhhdCBtb3ZlcyB0aGUgZmlsZSB0byBhIGRpZmZlcmVudCBsb2NhdGlvbiBvbiB0aGUgZmlsZXN5c3RlbVxuICogd2hpY2ggdGFrZXMgdHdvIGZ1bmN0aW9uIGFyZ3VtZW50cyB0byBtYWtlIGl0IGNvbXBhdGlibGUgdy8gUHJvbWlzZSBvciBDYWxsYmFjayBBUElzXG4gKi9cbmNvbnN0IG1vdmVGcm9tVGVtcDogTW92ZUZpbGUgPSAoZmlsZVBhdGgsIG9wdGlvbnMsIGZpbGVVcGxvYWRPcHRpb25zKSA9PiAocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gIGRlYnVnTG9nKGZpbGVVcGxvYWRPcHRpb25zLCBgTW92aW5nIHRlbXBvcmFyeSBmaWxlICR7b3B0aW9ucy50ZW1wRmlsZVBhdGh9IHRvICR7ZmlsZVBhdGh9YClcbiAgbW92ZUZpbGUob3B0aW9ucy50ZW1wRmlsZVBhdGgsIGZpbGVQYXRoLCBwcm9taXNlQ2FsbGJhY2socmVzb2x2ZSwgcmVqZWN0KSlcbn1cblxuLyoqXG4gKiBSZXR1cm5zIExvY2FsIGZ1bmN0aW9uIHRoYXQgbW92ZXMgdGhlIGZpbGUgZnJvbSBidWZmZXIgdG8gYSBkaWZmZXJlbnQgbG9jYXRpb24gb24gdGhlIGZpbGVzeXN0ZW1cbiAqIHdoaWNoIHRha2VzIHR3byBmdW5jdGlvbiBhcmd1bWVudHMgdG8gbWFrZSBpdCBjb21wYXRpYmxlIHcvIFByb21pc2Ugb3IgQ2FsbGJhY2sgQVBJc1xuICovXG5jb25zdCBtb3ZlRnJvbUJ1ZmZlcjogTW92ZUZpbGUgPSAoZmlsZVBhdGgsIG9wdGlvbnMsIGZpbGVVcGxvYWRPcHRpb25zKSA9PiAocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gIGRlYnVnTG9nKGZpbGVVcGxvYWRPcHRpb25zLCBgTW92aW5nIHVwbG9hZGVkIGJ1ZmZlciB0byAke2ZpbGVQYXRofWApXG4gIHNhdmVCdWZmZXJUb0ZpbGUob3B0aW9ucy5idWZmZXIsIGZpbGVQYXRoLCBwcm9taXNlQ2FsbGJhY2socmVzb2x2ZSwgcmVqZWN0KSlcbn1cblxudHlwZSBGaWxlRmFjdG9yeU9wdGlvbnMgPSB7XG4gIGJ1ZmZlcjogQnVmZmVyXG4gIGVuY29kaW5nOiBzdHJpbmdcbiAgaGFzaDogQnVmZmVyIHwgc3RyaW5nXG4gIG1pbWV0eXBlOiBzdHJpbmdcbiAgbmFtZTogc3RyaW5nXG4gIHNpemU6IG51bWJlclxuICB0ZW1wRmlsZVBhdGg6IHN0cmluZ1xuICB0cnVuY2F0ZWQ6IGJvb2xlYW5cbn1cbnR5cGUgRmlsZUZhY3RvcnkgPSAoXG4gIG9wdGlvbnM6IEZpbGVGYWN0b3J5T3B0aW9ucyxcbiAgZmlsZVVwbG9hZE9wdGlvbnM6IE5leHRGaWxlVXBsb2FkT3B0aW9ucyxcbikgPT4gRmlsZVNoYXBlXG5leHBvcnQgY29uc3QgZmlsZUZhY3Rvcnk6IEZpbGVGYWN0b3J5ID0gKG9wdGlvbnMsIGZpbGVVcGxvYWRPcHRpb25zKSA9PiB7XG4gIC8vIHNlZTogaHR0cHM6Ly9naXRodWIuY29tL3JpY2hhcmRnaXJnZXMvZXhwcmVzcy1maWxldXBsb2FkL2lzc3Vlcy8xNFxuICAvLyBmaXJlZm94IHVwbG9hZHMgZW1wdHkgZmlsZSBpbiBjYXNlIG9mIGNhY2hlIG1pc3Mgd2hlbiBmNWluZyBwYWdlLlxuICAvLyByZXN1bHRpbmcgaW4gdW5leHBlY3RlZCBiZWhhdmlvci4gaWYgdGhlcmUgaXMgbm8gZmlsZSBkYXRhLCB0aGUgZmlsZSBpcyBpbnZhbGlkLlxuICAvLyBpZiAoIWZpbGVVcGxvYWRPcHRpb25zLnVzZVRlbXBGaWxlcyAmJiAhb3B0aW9ucy5idWZmZXIubGVuZ3RoKSByZXR1cm47XG5cbiAgLy8gQ3JlYXRlIGFuZCByZXR1cm4gZmlsZSBvYmplY3QuXG4gIHJldHVybiB7XG4gICAgbmFtZTogb3B0aW9ucy5uYW1lLFxuICAgIGRhdGE6IG9wdGlvbnMuYnVmZmVyLFxuICAgIGVuY29kaW5nOiBvcHRpb25zLmVuY29kaW5nLFxuICAgIG1kNTogb3B0aW9ucy5oYXNoLFxuICAgIG1pbWV0eXBlOiBvcHRpb25zLm1pbWV0eXBlLFxuICAgIG12OiAoZmlsZVBhdGg6IHN0cmluZywgY2FsbGJhY2spID0+IHtcbiAgICAgIC8vIERlZmluZSBhIHByb3BlciBtb3ZlIGZ1bmN0aW9uLlxuICAgICAgY29uc3QgbW92ZUZ1bmMgPSBmaWxlVXBsb2FkT3B0aW9ucy51c2VUZW1wRmlsZXNcbiAgICAgICAgPyBtb3ZlRnJvbVRlbXAoZmlsZVBhdGgsIG9wdGlvbnMsIGZpbGVVcGxvYWRPcHRpb25zKVxuICAgICAgICA6IG1vdmVGcm9tQnVmZmVyKGZpbGVQYXRoLCBvcHRpb25zLCBmaWxlVXBsb2FkT3B0aW9ucylcbiAgICAgIC8vIENyZWF0ZSBhIGZvbGRlciBmb3IgYSBmaWxlLlxuICAgICAgY2hlY2tBbmRNYWtlRGlyKGZpbGVVcGxvYWRPcHRpb25zLCBmaWxlUGF0aClcbiAgICAgIC8vIElmIGNhbGxiYWNrIGlzIHBhc3NlZCBpbiwgdXNlIHRoZSBjYWxsYmFjayBBUEksIG90aGVyd2lzZSByZXR1cm4gYSBwcm9taXNlLlxuICAgICAgY29uc3QgZGVmYXVsdFJlamVjdCA9ICgpID0+IHVuZGVmaW5lZFxuICAgICAgcmV0dXJuIGlzRnVuYyhjYWxsYmFjaykgPyBtb3ZlRnVuYyhjYWxsYmFjaywgZGVmYXVsdFJlamVjdCkgOiBuZXcgUHJvbWlzZShtb3ZlRnVuYylcbiAgICB9LFxuICAgIHNpemU6IG9wdGlvbnMuc2l6ZSxcbiAgICB0ZW1wRmlsZVBhdGg6IG9wdGlvbnMudGVtcEZpbGVQYXRoLFxuICAgIHRydW5jYXRlZDogb3B0aW9ucy50cnVuY2F0ZWQsXG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJjaGVja0FuZE1ha2VEaXIiLCJkZWJ1Z0xvZyIsImlzRnVuYyIsIm1vdmVGaWxlIiwicHJvbWlzZUNhbGxiYWNrIiwic2F2ZUJ1ZmZlclRvRmlsZSIsIm1vdmVGcm9tVGVtcCIsImZpbGVQYXRoIiwib3B0aW9ucyIsImZpbGVVcGxvYWRPcHRpb25zIiwicmVzb2x2ZSIsInJlamVjdCIsInRlbXBGaWxlUGF0aCIsIm1vdmVGcm9tQnVmZmVyIiwiYnVmZmVyIiwiZmlsZUZhY3RvcnkiLCJuYW1lIiwiZGF0YSIsImVuY29kaW5nIiwibWQ1IiwiaGFzaCIsIm1pbWV0eXBlIiwibXYiLCJjYWxsYmFjayIsIm1vdmVGdW5jIiwidXNlVGVtcEZpbGVzIiwiZGVmYXVsdFJlamVjdCIsInVuZGVmaW5lZCIsIlByb21pc2UiLCJzaXplIiwidHJ1bmNhdGVkIl0sIm1hcHBpbmdzIjoiQUFFQSxTQUNFQSxlQUFlLEVBQ2ZDLFFBQVEsRUFDUkMsTUFBTSxFQUNOQyxRQUFRLEVBQ1JDLGVBQWUsRUFDZkMsZ0JBQWdCLFFBQ1gsY0FBYTtBQVFwQjs7O0NBR0MsR0FDRCxNQUFNQyxlQUF5QixDQUFDQyxVQUFVQyxTQUFTQyxvQkFBc0IsQ0FBQ0MsU0FBU0M7UUFDakZWLFNBQVNRLG1CQUFtQixDQUFDLHNCQUFzQixFQUFFRCxRQUFRSSxZQUFZLENBQUMsSUFBSSxFQUFFTCxTQUFTLENBQUM7UUFDMUZKLFNBQVNLLFFBQVFJLFlBQVksRUFBRUwsVUFBVUgsZ0JBQWdCTSxTQUFTQztJQUNwRTtBQUVBOzs7Q0FHQyxHQUNELE1BQU1FLGlCQUEyQixDQUFDTixVQUFVQyxTQUFTQyxvQkFBc0IsQ0FBQ0MsU0FBU0M7UUFDbkZWLFNBQVNRLG1CQUFtQixDQUFDLDBCQUEwQixFQUFFRixTQUFTLENBQUM7UUFDbkVGLGlCQUFpQkcsUUFBUU0sTUFBTSxFQUFFUCxVQUFVSCxnQkFBZ0JNLFNBQVNDO0lBQ3RFO0FBZ0JBLE9BQU8sTUFBTUksY0FBMkIsQ0FBQ1AsU0FBU0M7SUFDaEQscUVBQXFFO0lBQ3JFLG9FQUFvRTtJQUNwRSxtRkFBbUY7SUFDbkYseUVBQXlFO0lBRXpFLGlDQUFpQztJQUNqQyxPQUFPO1FBQ0xPLE1BQU1SLFFBQVFRLElBQUk7UUFDbEJDLE1BQU1ULFFBQVFNLE1BQU07UUFDcEJJLFVBQVVWLFFBQVFVLFFBQVE7UUFDMUJDLEtBQUtYLFFBQVFZLElBQUk7UUFDakJDLFVBQVViLFFBQVFhLFFBQVE7UUFDMUJDLElBQUksQ0FBQ2YsVUFBa0JnQjtZQUNyQixpQ0FBaUM7WUFDakMsTUFBTUMsV0FBV2Ysa0JBQWtCZ0IsWUFBWSxHQUMzQ25CLGFBQWFDLFVBQVVDLFNBQVNDLHFCQUNoQ0ksZUFBZU4sVUFBVUMsU0FBU0M7WUFDdEMsOEJBQThCO1lBQzlCVCxnQkFBZ0JTLG1CQUFtQkY7WUFDbkMsOEVBQThFO1lBQzlFLE1BQU1tQixnQkFBZ0IsSUFBTUM7WUFDNUIsT0FBT3pCLE9BQU9xQixZQUFZQyxTQUFTRCxVQUFVRyxpQkFBaUIsSUFBSUUsUUFBUUo7UUFDNUU7UUFDQUssTUFBTXJCLFFBQVFxQixJQUFJO1FBQ2xCakIsY0FBY0osUUFBUUksWUFBWTtRQUNsQ2tCLFdBQVd0QixRQUFRc0IsU0FBUztJQUM5QjtBQUNGLEVBQUMifQ==
@@ -1,113 +1,49 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- function _export(target, all) {
6
- for(var name in all)Object.defineProperty(target, name, {
7
- enumerable: true,
8
- get: all[name]
9
- });
10
- }
11
- _export(exports, {
12
- memHandler: function() {
13
- return memHandler;
14
- },
15
- tempFileHandler: function() {
16
- return tempFileHandler;
17
- }
18
- });
19
- const _crypto = /*#__PURE__*/ _interop_require_default(require("crypto"));
20
- const _fs = /*#__PURE__*/ _interop_require_wildcard(require("fs"));
21
- const _path = /*#__PURE__*/ _interop_require_default(require("path"));
22
- const _utilities = require("./utilities");
23
- function _interop_require_default(obj) {
24
- return obj && obj.__esModule ? obj : {
25
- default: obj
26
- };
27
- }
28
- function _getRequireWildcardCache(nodeInterop) {
29
- if (typeof WeakMap !== "function") return null;
30
- var cacheBabelInterop = new WeakMap();
31
- var cacheNodeInterop = new WeakMap();
32
- return (_getRequireWildcardCache = function(nodeInterop) {
33
- return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
34
- })(nodeInterop);
35
- }
36
- function _interop_require_wildcard(obj, nodeInterop) {
37
- if (!nodeInterop && obj && obj.__esModule) {
38
- return obj;
39
- }
40
- if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
41
- return {
42
- default: obj
43
- };
44
- }
45
- var cache = _getRequireWildcardCache(nodeInterop);
46
- if (cache && cache.has(obj)) {
47
- return cache.get(obj);
48
- }
49
- var newObj = {
50
- __proto__: null
51
- };
52
- var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
53
- for(var key in obj){
54
- if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
55
- var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
56
- if (desc && (desc.get || desc.set)) {
57
- Object.defineProperty(newObj, key, desc);
58
- } else {
59
- newObj[key] = obj[key];
60
- }
61
- }
62
- }
63
- newObj.default = obj;
64
- if (cache) {
65
- cache.set(obj, newObj);
66
- }
67
- return newObj;
68
- }
69
- const tempFileHandler = (options, fieldname, filename)=>{
70
- const dir = _path.default.normalize(options.tempFileDir);
71
- const tempFilePath = _path.default.join(process.cwd(), dir, (0, _utilities.getTempFilename)());
72
- (0, _utilities.checkAndMakeDir)({
1
+ import crypto from 'crypto';
2
+ import fs, { WriteStream } from 'fs';
3
+ import path from 'path';
4
+ import { checkAndMakeDir, debugLog, deleteFile, getTempFilename } from './utilities';
5
+ export const tempFileHandler = (options, fieldname, filename)=>{
6
+ const dir = path.normalize(options.tempFileDir);
7
+ const tempFilePath = path.join(process.cwd(), dir, getTempFilename());
8
+ checkAndMakeDir({
73
9
  createParentPath: true
74
10
  }, tempFilePath);
75
- (0, _utilities.debugLog)(options, `Temporary file path is ${tempFilePath}`);
76
- const hash = _crypto.default.createHash('md5');
11
+ debugLog(options, `Temporary file path is ${tempFilePath}`);
12
+ const hash = crypto.createHash('md5');
77
13
  let fileSize = 0;
78
14
  let completed = false;
79
- (0, _utilities.debugLog)(options, `Opening write stream for ${fieldname}->${filename}...`);
80
- const writeStream = _fs.default.createWriteStream(tempFilePath);
15
+ debugLog(options, `Opening write stream for ${fieldname}->${filename}...`);
16
+ const writeStream = fs.createWriteStream(tempFilePath);
81
17
  const writePromise = new Promise((resolve, reject)=>{
82
18
  writeStream.on('finish', ()=>resolve(true));
83
19
  writeStream.on('error', (err)=>{
84
- (0, _utilities.debugLog)(options, `Error write temp file: ${err}`);
20
+ debugLog(options, `Error write temp file: ${err}`);
85
21
  reject(err);
86
22
  });
87
23
  });
88
24
  return {
89
25
  cleanup: ()=>{
90
26
  completed = true;
91
- (0, _utilities.debugLog)(options, `Cleaning up temporary file ${tempFilePath}...`);
27
+ debugLog(options, `Cleaning up temporary file ${tempFilePath}...`);
92
28
  writeStream.end();
93
- (0, _utilities.deleteFile)(tempFilePath, (err)=>err ? (0, _utilities.debugLog)(options, `Cleaning up temporary file ${tempFilePath} failed: ${err}`) : (0, _utilities.debugLog)(options, `Cleaning up temporary file ${tempFilePath} done.`));
29
+ deleteFile(tempFilePath, (err)=>err ? debugLog(options, `Cleaning up temporary file ${tempFilePath} failed: ${err}`) : debugLog(options, `Cleaning up temporary file ${tempFilePath} done.`));
94
30
  },
95
31
  complete: ()=>{
96
32
  completed = true;
97
- (0, _utilities.debugLog)(options, `Upload ${fieldname}->${filename} completed, bytes:${fileSize}.`);
98
- if (writeStream instanceof _fs.WriteStream) writeStream.end();
33
+ debugLog(options, `Upload ${fieldname}->${filename} completed, bytes:${fileSize}.`);
34
+ if (writeStream instanceof WriteStream) writeStream.end();
99
35
  // Return empty buff since data was uploaded into a temp file.
100
36
  return Buffer.concat([]);
101
37
  },
102
38
  dataHandler: (data)=>{
103
39
  if (completed === true) {
104
- (0, _utilities.debugLog)(options, `Error: got ${fieldname}->${filename} data chunk for completed upload!`);
40
+ debugLog(options, `Error: got ${fieldname}->${filename} data chunk for completed upload!`);
105
41
  return;
106
42
  }
107
43
  writeStream.write(data);
108
44
  hash.update(data);
109
45
  fileSize += data.length;
110
- (0, _utilities.debugLog)(options, `Uploading ${fieldname}->${filename}, bytes:${fileSize}...`);
46
+ debugLog(options, `Uploading ${fieldname}->${filename}, bytes:${fileSize}...`);
111
47
  },
112
48
  getFilePath: ()=>tempFilePath,
113
49
  getFileSize: ()=>fileSize,
@@ -115,9 +51,9 @@ const tempFileHandler = (options, fieldname, filename)=>{
115
51
  getWritePromise: ()=>writePromise
116
52
  };
117
53
  };
118
- const memHandler = (options, fieldname, filename)=>{
54
+ export const memHandler = (options, fieldname, filename)=>{
119
55
  const buffers = [];
120
- const hash = _crypto.default.createHash('md5');
56
+ const hash = crypto.createHash('md5');
121
57
  let fileSize = 0;
122
58
  let completed = false;
123
59
  const getBuffer = ()=>Buffer.concat(buffers, fileSize);
@@ -126,19 +62,19 @@ const memHandler = (options, fieldname, filename)=>{
126
62
  completed = true;
127
63
  },
128
64
  complete: ()=>{
129
- (0, _utilities.debugLog)(options, `Upload ${fieldname}->${filename} completed, bytes:${fileSize}.`);
65
+ debugLog(options, `Upload ${fieldname}->${filename} completed, bytes:${fileSize}.`);
130
66
  completed = true;
131
67
  return getBuffer();
132
68
  },
133
69
  dataHandler: (data)=>{
134
70
  if (completed === true) {
135
- (0, _utilities.debugLog)(options, `Error: got ${fieldname}->${filename} data chunk for completed upload!`);
71
+ debugLog(options, `Error: got ${fieldname}->${filename} data chunk for completed upload!`);
136
72
  return;
137
73
  }
138
74
  buffers.push(data);
139
75
  hash.update(data);
140
76
  fileSize += data.length;
141
- (0, _utilities.debugLog)(options, `Uploading ${fieldname}->${filename}, bytes:${fileSize}...`);
77
+ debugLog(options, `Uploading ${fieldname}->${filename}, bytes:${fileSize}...`);
142
78
  },
143
79
  getFilePath: ()=>'',
144
80
  getFileSize: ()=>fileSize,
@@ -147,4 +83,4 @@ const memHandler = (options, fieldname, filename)=>{
147
83
  };
148
84
  };
149
85
 
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/next-fileupload/handlers.ts"],"sourcesContent":["import crypto from 'crypto'\nimport fs, { WriteStream } from 'fs'\nimport path from 'path'\n\nimport type { NextFileUploadOptions } from '.'\n\nimport { checkAndMakeDir, debugLog, deleteFile, getTempFilename } from './utilities'\n\ntype Handler = (\n  options: NextFileUploadOptions,\n  fieldname: string,\n  filename: string,\n) => {\n  cleanup: () => void\n  complete: () => Buffer\n  dataHandler: (data: Buffer) => void\n  getFilePath: () => string\n  getFileSize: () => number\n  getHash: () => string\n  getWritePromise: () => Promise<boolean>\n}\n\nexport const tempFileHandler: Handler = (options, fieldname, filename) => {\n  const dir = path.normalize(options.tempFileDir)\n  const tempFilePath = path.join(process.cwd(), dir, getTempFilename())\n  checkAndMakeDir({ createParentPath: true }, tempFilePath)\n\n  debugLog(options, `Temporary file path is ${tempFilePath}`)\n\n  const hash = crypto.createHash('md5')\n  let fileSize = 0\n  let completed = false\n\n  debugLog(options, `Opening write stream for ${fieldname}->${filename}...`)\n  const writeStream = fs.createWriteStream(tempFilePath)\n  const writePromise = new Promise<boolean>((resolve, reject) => {\n    writeStream.on('finish', () => resolve(true))\n    writeStream.on('error', (err) => {\n      debugLog(options, `Error write temp file: ${err}`)\n      reject(err)\n    })\n  })\n\n  return {\n    cleanup: () => {\n      completed = true\n      debugLog(options, `Cleaning up temporary file ${tempFilePath}...`)\n      writeStream.end()\n      deleteFile(tempFilePath, (err) =>\n        err\n          ? debugLog(options, `Cleaning up temporary file ${tempFilePath} failed: ${err}`)\n          : debugLog(options, `Cleaning up temporary file ${tempFilePath} done.`),\n      )\n    },\n    complete: () => {\n      completed = true\n      debugLog(options, `Upload ${fieldname}->${filename} completed, bytes:${fileSize}.`)\n      if (writeStream instanceof WriteStream) writeStream.end()\n      // Return empty buff since data was uploaded into a temp file.\n      return Buffer.concat([])\n    },\n    dataHandler: (data) => {\n      if (completed === true) {\n        debugLog(options, `Error: got ${fieldname}->${filename} data chunk for completed upload!`)\n        return\n      }\n      writeStream.write(data)\n      hash.update(data)\n      fileSize += data.length\n      debugLog(options, `Uploading ${fieldname}->${filename}, bytes:${fileSize}...`)\n    },\n    getFilePath: () => tempFilePath,\n    getFileSize: () => fileSize,\n    getHash: () => hash.digest('hex'),\n    getWritePromise: () => writePromise,\n  }\n}\n\nexport const memHandler: Handler = (options, fieldname, filename) => {\n  const buffers = []\n  const hash = crypto.createHash('md5')\n  let fileSize = 0\n  let completed = false\n\n  const getBuffer = () => Buffer.concat(buffers, fileSize)\n\n  return {\n    cleanup: () => {\n      completed = true\n    },\n    complete: () => {\n      debugLog(options, `Upload ${fieldname}->${filename} completed, bytes:${fileSize}.`)\n      completed = true\n      return getBuffer()\n    },\n    dataHandler: (data) => {\n      if (completed === true) {\n        debugLog(options, `Error: got ${fieldname}->${filename} data chunk for completed upload!`)\n        return\n      }\n      buffers.push(data)\n      hash.update(data)\n      fileSize += data.length\n      debugLog(options, `Uploading ${fieldname}->${filename}, bytes:${fileSize}...`)\n    },\n    getFilePath: () => '',\n    getFileSize: () => fileSize,\n    getHash: () => hash.digest('hex'),\n    getWritePromise: () => Promise.resolve(true),\n  }\n}\n"],"names":["memHandler","tempFileHandler","options","fieldname","filename","dir","path","normalize","tempFileDir","tempFilePath","join","process","cwd","getTempFilename","checkAndMakeDir","createParentPath","debugLog","hash","crypto","createHash","fileSize","completed","writeStream","fs","createWriteStream","writePromise","Promise","resolve","reject","on","err","cleanup","end","deleteFile","complete","WriteStream","Buffer","concat","dataHandler","data","write","update","length","getFilePath","getFileSize","getHash","digest","getWritePromise","buffers","getBuffer","push"],"mappings":"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"}
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/next-fileupload/handlers.ts"],"sourcesContent":["import crypto from 'crypto'\nimport fs, { WriteStream } from 'fs'\nimport path from 'path'\n\nimport type { NextFileUploadOptions } from '.'\n\nimport { checkAndMakeDir, debugLog, deleteFile, getTempFilename } from './utilities'\n\ntype Handler = (\n  options: NextFileUploadOptions,\n  fieldname: string,\n  filename: string,\n) => {\n  cleanup: () => void\n  complete: () => Buffer\n  dataHandler: (data: Buffer) => void\n  getFilePath: () => string\n  getFileSize: () => number\n  getHash: () => string\n  getWritePromise: () => Promise<boolean>\n}\n\nexport const tempFileHandler: Handler = (options, fieldname, filename) => {\n  const dir = path.normalize(options.tempFileDir)\n  const tempFilePath = path.join(process.cwd(), dir, getTempFilename())\n  checkAndMakeDir({ createParentPath: true }, tempFilePath)\n\n  debugLog(options, `Temporary file path is ${tempFilePath}`)\n\n  const hash = crypto.createHash('md5')\n  let fileSize = 0\n  let completed = false\n\n  debugLog(options, `Opening write stream for ${fieldname}->${filename}...`)\n  const writeStream = fs.createWriteStream(tempFilePath)\n  const writePromise = new Promise<boolean>((resolve, reject) => {\n    writeStream.on('finish', () => resolve(true))\n    writeStream.on('error', (err) => {\n      debugLog(options, `Error write temp file: ${err}`)\n      reject(err)\n    })\n  })\n\n  return {\n    cleanup: () => {\n      completed = true\n      debugLog(options, `Cleaning up temporary file ${tempFilePath}...`)\n      writeStream.end()\n      deleteFile(tempFilePath, (err) =>\n        err\n          ? debugLog(options, `Cleaning up temporary file ${tempFilePath} failed: ${err}`)\n          : debugLog(options, `Cleaning up temporary file ${tempFilePath} done.`),\n      )\n    },\n    complete: () => {\n      completed = true\n      debugLog(options, `Upload ${fieldname}->${filename} completed, bytes:${fileSize}.`)\n      if (writeStream instanceof WriteStream) writeStream.end()\n      // Return empty buff since data was uploaded into a temp file.\n      return Buffer.concat([])\n    },\n    dataHandler: (data) => {\n      if (completed === true) {\n        debugLog(options, `Error: got ${fieldname}->${filename} data chunk for completed upload!`)\n        return\n      }\n      writeStream.write(data)\n      hash.update(data)\n      fileSize += data.length\n      debugLog(options, `Uploading ${fieldname}->${filename}, bytes:${fileSize}...`)\n    },\n    getFilePath: () => tempFilePath,\n    getFileSize: () => fileSize,\n    getHash: () => hash.digest('hex'),\n    getWritePromise: () => writePromise,\n  }\n}\n\nexport const memHandler: Handler = (options, fieldname, filename) => {\n  const buffers = []\n  const hash = crypto.createHash('md5')\n  let fileSize = 0\n  let completed = false\n\n  const getBuffer = () => Buffer.concat(buffers, fileSize)\n\n  return {\n    cleanup: () => {\n      completed = true\n    },\n    complete: () => {\n      debugLog(options, `Upload ${fieldname}->${filename} completed, bytes:${fileSize}.`)\n      completed = true\n      return getBuffer()\n    },\n    dataHandler: (data) => {\n      if (completed === true) {\n        debugLog(options, `Error: got ${fieldname}->${filename} data chunk for completed upload!`)\n        return\n      }\n      buffers.push(data)\n      hash.update(data)\n      fileSize += data.length\n      debugLog(options, `Uploading ${fieldname}->${filename}, bytes:${fileSize}...`)\n    },\n    getFilePath: () => '',\n    getFileSize: () => fileSize,\n    getHash: () => hash.digest('hex'),\n    getWritePromise: () => Promise.resolve(true),\n  }\n}\n"],"names":["crypto","fs","WriteStream","path","checkAndMakeDir","debugLog","deleteFile","getTempFilename","tempFileHandler","options","fieldname","filename","dir","normalize","tempFileDir","tempFilePath","join","process","cwd","createParentPath","hash","createHash","fileSize","completed","writeStream","createWriteStream","writePromise","Promise","resolve","reject","on","err","cleanup","end","complete","Buffer","concat","dataHandler","data","write","update","length","getFilePath","getFileSize","getHash","digest","getWritePromise","memHandler","buffers","getBuffer","push"],"mappings":"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"}
@@ -1,22 +1,7 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "nextFileUpload", {
6
- enumerable: true,
7
- get: function() {
8
- return nextFileUpload;
9
- }
10
- });
11
- const _path = /*#__PURE__*/ _interop_require_default(require("path"));
12
- const _isEligibleRequest = require("./isEligibleRequest");
13
- const _processMultipart = require("./processMultipart");
14
- const _utilities = require("./utilities");
15
- function _interop_require_default(obj) {
16
- return obj && obj.__esModule ? obj : {
17
- default: obj
18
- };
19
- }
1
+ import path from 'path';
2
+ import { isEligibleRequest } from './isEligibleRequest';
3
+ import { processMultipart } from './processMultipart';
4
+ import { debugLog } from './utilities';
20
5
  const DEFAULT_OPTIONS = {
21
6
  abortOnLimit: false,
22
7
  createParentPath: false,
@@ -27,18 +12,18 @@ const DEFAULT_OPTIONS = {
27
12
  preserveExtension: false,
28
13
  responseOnLimit: 'File size limit has been reached',
29
14
  safeFileNames: false,
30
- tempFileDir: _path.default.join(process.cwd(), 'tmp'),
15
+ tempFileDir: path.join(process.cwd(), 'tmp'),
31
16
  uploadTimeout: 60000,
32
17
  uriDecodeFileNames: false,
33
18
  useTempFiles: false
34
19
  };
35
- const nextFileUpload = async ({ options, request })=>{
20
+ export const nextFileUpload = async ({ options, request })=>{
36
21
  const uploadOptions = {
37
22
  ...DEFAULT_OPTIONS,
38
23
  ...options
39
24
  };
40
- if (!(0, _isEligibleRequest.isEligibleRequest)(request)) {
41
- (0, _utilities.debugLog)(uploadOptions, 'Request is not eligible for file upload!');
25
+ if (!isEligibleRequest(request)) {
26
+ debugLog(uploadOptions, 'Request is not eligible for file upload!');
42
27
  return {
43
28
  error: {
44
29
  code: 500,
@@ -48,11 +33,11 @@ const nextFileUpload = async ({ options, request })=>{
48
33
  files: undefined
49
34
  };
50
35
  } else {
51
- return (0, _processMultipart.processMultipart)({
36
+ return processMultipart({
52
37
  options: uploadOptions,
53
38
  request
54
39
  });
55
40
  }
56
41
  };
57
42
 
58
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/next-fileupload/index.ts"],"sourcesContent":["import type { BusboyConfig } from 'busboy'\n\nimport path from 'path'\n\nimport { isEligibleRequest } from './isEligibleRequest'\nimport { processMultipart } from './processMultipart'\nimport { debugLog } from './utilities'\n\nconst DEFAULT_OPTIONS = {\n  abortOnLimit: false,\n  createParentPath: false,\n  debug: false,\n  fileHandler: false,\n  limitHandler: false,\n  parseNested: false,\n  preserveExtension: false,\n  responseOnLimit: 'File size limit has been reached',\n  safeFileNames: false,\n  tempFileDir: path.join(process.cwd(), 'tmp'),\n  uploadTimeout: 60000,\n  uriDecodeFileNames: false,\n  useTempFiles: false,\n}\n\nexport type FileShape = {\n  data: Buffer\n  encoding: string\n  md5: Buffer | string\n  mimetype: string\n  mv: (filePath: string, callback: () => void) => Promise<void> | void\n  name: string\n  size: number\n  tempFilePath: string\n  truncated: boolean\n}\n\nexport type NextFileUploadOptions = {\n  /**\n   * Returns a HTTP 413 when the file is bigger than the size limit if `true`.\n   * Otherwise, it will add a `truncated = true` to the resulting file structure.\n   * @default false\n   */\n  abortOnLimit?: boolean | undefined\n  /**\n   * Automatically creates the directory path specified in `.mv(filePathName)`\n   * @default false\n   */\n  createParentPath?: boolean | undefined\n  /**\n   * Turn on/off upload process logging. Can be useful for troubleshooting.\n   * @default false\n   */\n  debug?: boolean | undefined\n  /**\n   * User defined limit handler which will be invoked if the file is bigger than configured limits.\n   * @default false\n   */\n  limitHandler?: ((args: { request: Request; size: number }) => void) | boolean | undefined\n  /**\n   * By default, `req.body` and `req.files` are flattened like this:\n   * `{'name': 'John', 'hobbies[0]': 'Cinema', 'hobbies[1]': 'Bike'}\n   *\n   * When this option is enabled they are parsed in order to be nested like this:\n   * `{'name': 'John', 'hobbies': ['Cinema', 'Bike']}`\n   * @default false\n   */\n  parseNested?: boolean | undefined\n  /**\n   * Preserves filename extension when using `safeFileNames` option.\n   * If set to `true`, will default to an extension length of `3`.\n   * If set to `number`, this will be the max allowable extension length.\n   * If an extension is smaller than the extension length, it remains untouched. If the extension is longer,\n   * it is shifted.\n   * @default false\n   *\n   * @example\n   * // true\n   * app.use(fileUpload({ safeFileNames: true, preserveExtension: true }));\n   * // myFileName.ext --> myFileName.ext\n   *\n   * @example\n   * // max extension length 2, extension shifted\n   * app.use(fileUpload({ safeFileNames: true, preserveExtension: 2 }));\n   * // myFileName.ext --> myFileNamee.xt\n   */\n  preserveExtension?: boolean | number | undefined\n  /**\n   * Response which will be send to client if file size limit exceeded when `abortOnLimit` set to `true`.\n   * @default 'File size limit has been reached'\n   */\n  responseOnLimit?: string | undefined\n  /**\n   * Strips characters from the upload's filename.\n   * You can use custom regex to determine what to strip.\n   * If set to `true`, non-alphanumeric characters _except_ dashes and underscores will be stripped.\n   * This option is off by default.\n   * @default false\n   *\n   * @example\n   * // strip slashes from file names\n   * app.use(fileUpload({ safeFileNames: /\\\\/g }))\n   *\n   * @example\n   * app.use(fileUpload({ safeFileNames: true }))\n   */\n  safeFileNames?: RegExp | boolean | undefined\n  /**\n   * Path to store temporary files.\n   * Used along with the `useTempFiles` option. By default this module uses `'tmp'` folder\n   * in the current working directory.\n   * You can use trailing slash, but it is not necessary.\n   * @default './tmp'\n   */\n  tempFileDir?: string | undefined\n  /**\n   * This defines how long to wait for data before aborting. Set to `0` if you want to turn off timeout checks.\n   * @default 60_000\n   */\n  uploadTimeout?: number | undefined\n  /**\n   * Applies uri decoding to file names if set `true`.\n   * @default false\n   */\n  uriDecodeFileNames?: boolean | undefined\n  /**\n   * By default this module uploads files into RAM.\n   * Setting this option to `true` turns on using temporary files instead of utilising RAM.\n   * This avoids memory overflow issues when uploading large files or in case of uploading\n   * lots of files at same time.\n   * @default false\n   */\n  useTempFiles?: boolean | undefined\n} & Partial<BusboyConfig>\n\ntype NextFileUploadResponseFile = {\n  data: Buffer\n  mimetype: string\n  name: string\n  size: number\n  tempFilePath?: string\n}\n\nexport type NextFileUploadResponse = {\n  error?: {\n    code: number\n    message: string\n  }\n  fields: Record<string, string>\n  files: Record<string, NextFileUploadResponseFile>\n}\n\ntype NextFileUpload = (args: {\n  options?: NextFileUploadOptions\n  request: Request\n}) => Promise<NextFileUploadResponse>\nexport const nextFileUpload: NextFileUpload = async ({ options, request }) => {\n  const uploadOptions = { ...DEFAULT_OPTIONS, ...options }\n  if (!isEligibleRequest(request)) {\n    debugLog(uploadOptions, 'Request is not eligible for file upload!')\n    return {\n      error: {\n        code: 500,\n        message: 'Request is not eligible for file upload',\n      },\n      fields: undefined,\n      files: undefined,\n    }\n  } else {\n    return processMultipart({ options: uploadOptions, request })\n  }\n}\n"],"names":["nextFileUpload","DEFAULT_OPTIONS","abortOnLimit","createParentPath","debug","fileHandler","limitHandler","parseNested","preserveExtension","responseOnLimit","safeFileNames","tempFileDir","path","join","process","cwd","uploadTimeout","uriDecodeFileNames","useTempFiles","options","request","uploadOptions","isEligibleRequest","debugLog","error","code","message","fields","undefined","files","processMultipart"],"mappings":";;;;+BA2JaA;;;eAAAA;;;6DAzJI;mCAEiB;kCACD;2BACR;;;;;;AAEzB,MAAMC,kBAAkB;IACtBC,cAAc;IACdC,kBAAkB;IAClBC,OAAO;IACPC,aAAa;IACbC,cAAc;IACdC,aAAa;IACbC,mBAAmB;IACnBC,iBAAiB;IACjBC,eAAe;IACfC,aAAaC,aAAI,CAACC,IAAI,CAACC,QAAQC,GAAG,IAAI;IACtCC,eAAe;IACfC,oBAAoB;IACpBC,cAAc;AAChB;AAqIO,MAAMlB,iBAAiC,OAAO,EAAEmB,OAAO,EAAEC,OAAO,EAAE;IACvE,MAAMC,gBAAgB;QAAE,GAAGpB,eAAe;QAAE,GAAGkB,OAAO;IAAC;IACvD,IAAI,CAACG,IAAAA,oCAAiB,EAACF,UAAU;QAC/BG,IAAAA,mBAAQ,EAACF,eAAe;QACxB,OAAO;YACLG,OAAO;gBACLC,MAAM;gBACNC,SAAS;YACX;YACAC,QAAQC;YACRC,OAAOD;QACT;IACF,OAAO;QACL,OAAOE,IAAAA,kCAAgB,EAAC;YAAEX,SAASE;YAAeD;QAAQ;IAC5D;AACF"}
43
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/next-fileupload/index.ts"],"sourcesContent":["import type { BusboyConfig } from 'busboy'\n\nimport path from 'path'\n\nimport { isEligibleRequest } from './isEligibleRequest'\nimport { processMultipart } from './processMultipart'\nimport { debugLog } from './utilities'\n\nconst DEFAULT_OPTIONS = {\n  abortOnLimit: false,\n  createParentPath: false,\n  debug: false,\n  fileHandler: false,\n  limitHandler: false,\n  parseNested: false,\n  preserveExtension: false,\n  responseOnLimit: 'File size limit has been reached',\n  safeFileNames: false,\n  tempFileDir: path.join(process.cwd(), 'tmp'),\n  uploadTimeout: 60000,\n  uriDecodeFileNames: false,\n  useTempFiles: false,\n}\n\nexport type FileShape = {\n  data: Buffer\n  encoding: string\n  md5: Buffer | string\n  mimetype: string\n  mv: (filePath: string, callback: () => void) => Promise<void> | void\n  name: string\n  size: number\n  tempFilePath: string\n  truncated: boolean\n}\n\nexport type NextFileUploadOptions = {\n  /**\n   * Returns a HTTP 413 when the file is bigger than the size limit if `true`.\n   * Otherwise, it will add a `truncated = true` to the resulting file structure.\n   * @default false\n   */\n  abortOnLimit?: boolean | undefined\n  /**\n   * Automatically creates the directory path specified in `.mv(filePathName)`\n   * @default false\n   */\n  createParentPath?: boolean | undefined\n  /**\n   * Turn on/off upload process logging. Can be useful for troubleshooting.\n   * @default false\n   */\n  debug?: boolean | undefined\n  /**\n   * User defined limit handler which will be invoked if the file is bigger than configured limits.\n   * @default false\n   */\n  limitHandler?: ((args: { request: Request; size: number }) => void) | boolean | undefined\n  /**\n   * By default, `req.body` and `req.files` are flattened like this:\n   * `{'name': 'John', 'hobbies[0]': 'Cinema', 'hobbies[1]': 'Bike'}\n   *\n   * When this option is enabled they are parsed in order to be nested like this:\n   * `{'name': 'John', 'hobbies': ['Cinema', 'Bike']}`\n   * @default false\n   */\n  parseNested?: boolean | undefined\n  /**\n   * Preserves filename extension when using `safeFileNames` option.\n   * If set to `true`, will default to an extension length of `3`.\n   * If set to `number`, this will be the max allowable extension length.\n   * If an extension is smaller than the extension length, it remains untouched. If the extension is longer,\n   * it is shifted.\n   * @default false\n   *\n   * @example\n   * // true\n   * app.use(fileUpload({ safeFileNames: true, preserveExtension: true }));\n   * // myFileName.ext --> myFileName.ext\n   *\n   * @example\n   * // max extension length 2, extension shifted\n   * app.use(fileUpload({ safeFileNames: true, preserveExtension: 2 }));\n   * // myFileName.ext --> myFileNamee.xt\n   */\n  preserveExtension?: boolean | number | undefined\n  /**\n   * Response which will be send to client if file size limit exceeded when `abortOnLimit` set to `true`.\n   * @default 'File size limit has been reached'\n   */\n  responseOnLimit?: string | undefined\n  /**\n   * Strips characters from the upload's filename.\n   * You can use custom regex to determine what to strip.\n   * If set to `true`, non-alphanumeric characters _except_ dashes and underscores will be stripped.\n   * This option is off by default.\n   * @default false\n   *\n   * @example\n   * // strip slashes from file names\n   * app.use(fileUpload({ safeFileNames: /\\\\/g }))\n   *\n   * @example\n   * app.use(fileUpload({ safeFileNames: true }))\n   */\n  safeFileNames?: RegExp | boolean | undefined\n  /**\n   * Path to store temporary files.\n   * Used along with the `useTempFiles` option. By default this module uses `'tmp'` folder\n   * in the current working directory.\n   * You can use trailing slash, but it is not necessary.\n   * @default './tmp'\n   */\n  tempFileDir?: string | undefined\n  /**\n   * This defines how long to wait for data before aborting. Set to `0` if you want to turn off timeout checks.\n   * @default 60_000\n   */\n  uploadTimeout?: number | undefined\n  /**\n   * Applies uri decoding to file names if set `true`.\n   * @default false\n   */\n  uriDecodeFileNames?: boolean | undefined\n  /**\n   * By default this module uploads files into RAM.\n   * Setting this option to `true` turns on using temporary files instead of utilising RAM.\n   * This avoids memory overflow issues when uploading large files or in case of uploading\n   * lots of files at same time.\n   * @default false\n   */\n  useTempFiles?: boolean | undefined\n} & Partial<BusboyConfig>\n\ntype NextFileUploadResponseFile = {\n  data: Buffer\n  mimetype: string\n  name: string\n  size: number\n  tempFilePath?: string\n}\n\nexport type NextFileUploadResponse = {\n  error?: {\n    code: number\n    message: string\n  }\n  fields: Record<string, string>\n  files: Record<string, NextFileUploadResponseFile>\n}\n\ntype NextFileUpload = (args: {\n  options?: NextFileUploadOptions\n  request: Request\n}) => Promise<NextFileUploadResponse>\nexport const nextFileUpload: NextFileUpload = async ({ options, request }) => {\n  const uploadOptions = { ...DEFAULT_OPTIONS, ...options }\n  if (!isEligibleRequest(request)) {\n    debugLog(uploadOptions, 'Request is not eligible for file upload!')\n    return {\n      error: {\n        code: 500,\n        message: 'Request is not eligible for file upload',\n      },\n      fields: undefined,\n      files: undefined,\n    }\n  } else {\n    return processMultipart({ options: uploadOptions, request })\n  }\n}\n"],"names":["path","isEligibleRequest","processMultipart","debugLog","DEFAULT_OPTIONS","abortOnLimit","createParentPath","debug","fileHandler","limitHandler","parseNested","preserveExtension","responseOnLimit","safeFileNames","tempFileDir","join","process","cwd","uploadTimeout","uriDecodeFileNames","useTempFiles","nextFileUpload","options","request","uploadOptions","error","code","message","fields","undefined","files"],"mappings":"AAEA,OAAOA,UAAU,OAAM;AAEvB,SAASC,iBAAiB,QAAQ,sBAAqB;AACvD,SAASC,gBAAgB,QAAQ,qBAAoB;AACrD,SAASC,QAAQ,QAAQ,cAAa;AAEtC,MAAMC,kBAAkB;IACtBC,cAAc;IACdC,kBAAkB;IAClBC,OAAO;IACPC,aAAa;IACbC,cAAc;IACdC,aAAa;IACbC,mBAAmB;IACnBC,iBAAiB;IACjBC,eAAe;IACfC,aAAad,KAAKe,IAAI,CAACC,QAAQC,GAAG,IAAI;IACtCC,eAAe;IACfC,oBAAoB;IACpBC,cAAc;AAChB;AAqIA,OAAO,MAAMC,iBAAiC,OAAO,EAAEC,OAAO,EAAEC,OAAO,EAAE;IACvE,MAAMC,gBAAgB;QAAE,GAAGpB,eAAe;QAAE,GAAGkB,OAAO;IAAC;IACvD,IAAI,CAACrB,kBAAkBsB,UAAU;QAC/BpB,SAASqB,eAAe;QACxB,OAAO;YACLC,OAAO;gBACLC,MAAM;gBACNC,SAAS;YACX;YACAC,QAAQC;YACRC,OAAOD;QACT;IACF,OAAO;QACL,OAAO3B,iBAAiB;YAAEoB,SAASE;YAAeD;QAAQ;IAC5D;AACF,EAAC"}
@@ -1,13 +1,3 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "isEligibleRequest", {
6
- enumerable: true,
7
- get: function() {
8
- return isEligibleRequest;
9
- }
10
- });
11
1
  const ACCEPTABLE_CONTENT_TYPE = /^multipart\/['"()+-_]+(?:; ?['"()+-_]*)+$/i;
12
2
  const UNACCEPTABLE_METHODS = new Set([
13
3
  'GET',
@@ -25,7 +15,7 @@ const hasAcceptableContentType = (req)=>{
25
15
  const contType = req.headers.get('content-type');
26
16
  return contType.includes('boundary=') && ACCEPTABLE_CONTENT_TYPE.test(contType);
27
17
  };
28
- const isEligibleRequest = (req)=>{
18
+ export const isEligibleRequest = (req)=>{
29
19
  try {
30
20
  return hasBody(req) && hasAcceptableMethod(req) && hasAcceptableContentType(req);
31
21
  } catch (e) {
@@ -33,4 +23,4 @@ const isEligibleRequest = (req)=>{
33
23
  }
34
24
  };
35
25
 
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9uZXh0LWZpbGV1cGxvYWQvaXNFbGlnaWJsZVJlcXVlc3QudHMiXSwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgQUNDRVBUQUJMRV9DT05URU5UX1RZUEUgPSAvXm11bHRpcGFydFxcL1snXCIoKSstX10rKD86OyA/WydcIigpKy1fXSopKyQvaVxuY29uc3QgVU5BQ0NFUFRBQkxFX01FVEhPRFMgPSBuZXcgU2V0KFsnR0VUJywgJ0hFQUQnLCAnREVMRVRFJywgJ09QVElPTlMnLCAnQ09OTkVDVCcsICdUUkFDRSddKVxuXG5jb25zdCBoYXNCb2R5ID0gKHJlcTogUmVxdWVzdCk6IGJvb2xlYW4gPT4ge1xuICByZXR1cm4gQm9vbGVhbihcbiAgICByZXEuaGVhZGVycy5nZXQoJ3RyYW5zZmVyLWVuY29kaW5nJykgfHxcbiAgICAgIChyZXEuaGVhZGVycy5nZXQoJ2NvbnRlbnQtbGVuZ3RoJykgJiYgcmVxLmhlYWRlcnMuZ2V0KCdjb250ZW50LWxlbmd0aCcpICE9PSAnMCcpLFxuICApXG59XG5cbmNvbnN0IGhhc0FjY2VwdGFibGVNZXRob2QgPSAocmVxOiBSZXF1ZXN0KTogYm9vbGVhbiA9PiAhVU5BQ0NFUFRBQkxFX01FVEhPRFMuaGFzKHJlcS5tZXRob2QpXG5cbmNvbnN0IGhhc0FjY2VwdGFibGVDb250ZW50VHlwZSA9IChyZXE6IFJlcXVlc3QpOiBib29sZWFuID0+IHtcbiAgY29uc3QgY29udFR5cGUgPSByZXEuaGVhZGVycy5nZXQoJ2NvbnRlbnQtdHlwZScpXG4gIHJldHVybiBjb250VHlwZS5pbmNsdWRlcygnYm91bmRhcnk9JykgJiYgQUNDRVBUQUJMRV9DT05URU5UX1RZUEUudGVzdChjb250VHlwZSlcbn1cblxuZXhwb3J0IGNvbnN0IGlzRWxpZ2libGVSZXF1ZXN0ID0gKHJlcTogUmVxdWVzdCk6IGJvb2xlYW4gPT4ge1xuICB0cnkge1xuICAgIHJldHVybiBoYXNCb2R5KHJlcSkgJiYgaGFzQWNjZXB0YWJsZU1ldGhvZChyZXEpICYmIGhhc0FjY2VwdGFibGVDb250ZW50VHlwZShyZXEpXG4gIH0gY2F0Y2ggKGUpIHtcbiAgICByZXR1cm4gZmFsc2VcbiAgfVxufVxuIl0sIm5hbWVzIjpbImlzRWxpZ2libGVSZXF1ZXN0IiwiQUNDRVBUQUJMRV9DT05URU5UX1RZUEUiLCJVTkFDQ0VQVEFCTEVfTUVUSE9EUyIsIlNldCIsImhhc0JvZHkiLCJyZXEiLCJCb29sZWFuIiwiaGVhZGVycyIsImdldCIsImhhc0FjY2VwdGFibGVNZXRob2QiLCJoYXMiLCJtZXRob2QiLCJoYXNBY2NlcHRhYmxlQ29udGVudFR5cGUiLCJjb250VHlwZSIsImluY2x1ZGVzIiwidGVzdCIsImUiXSwibWFwcGluZ3MiOiI7Ozs7K0JBaUJhQTs7O2VBQUFBOzs7QUFqQmIsTUFBTUMsMEJBQTBCO0FBQ2hDLE1BQU1DLHVCQUF1QixJQUFJQyxJQUFJO0lBQUM7SUFBTztJQUFRO0lBQVU7SUFBVztJQUFXO0NBQVE7QUFFN0YsTUFBTUMsVUFBVSxDQUFDQztJQUNmLE9BQU9DLFFBQ0xELElBQUlFLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDLHdCQUNiSCxJQUFJRSxPQUFPLENBQUNDLEdBQUcsQ0FBQyxxQkFBcUJILElBQUlFLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDLHNCQUFzQjtBQUVsRjtBQUVBLE1BQU1DLHNCQUFzQixDQUFDSixNQUEwQixDQUFDSCxxQkFBcUJRLEdBQUcsQ0FBQ0wsSUFBSU0sTUFBTTtBQUUzRixNQUFNQywyQkFBMkIsQ0FBQ1A7SUFDaEMsTUFBTVEsV0FBV1IsSUFBSUUsT0FBTyxDQUFDQyxHQUFHLENBQUM7SUFDakMsT0FBT0ssU0FBU0MsUUFBUSxDQUFDLGdCQUFnQmIsd0JBQXdCYyxJQUFJLENBQUNGO0FBQ3hFO0FBRU8sTUFBTWIsb0JBQW9CLENBQUNLO0lBQ2hDLElBQUk7UUFDRixPQUFPRCxRQUFRQyxRQUFRSSxvQkFBb0JKLFFBQVFPLHlCQUF5QlA7SUFDOUUsRUFBRSxPQUFPVyxHQUFHO1FBQ1YsT0FBTztJQUNUO0FBQ0YifQ==
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9uZXh0LWZpbGV1cGxvYWQvaXNFbGlnaWJsZVJlcXVlc3QudHMiXSwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgQUNDRVBUQUJMRV9DT05URU5UX1RZUEUgPSAvXm11bHRpcGFydFxcL1snXCIoKSstX10rKD86OyA/WydcIigpKy1fXSopKyQvaVxuY29uc3QgVU5BQ0NFUFRBQkxFX01FVEhPRFMgPSBuZXcgU2V0KFsnR0VUJywgJ0hFQUQnLCAnREVMRVRFJywgJ09QVElPTlMnLCAnQ09OTkVDVCcsICdUUkFDRSddKVxuXG5jb25zdCBoYXNCb2R5ID0gKHJlcTogUmVxdWVzdCk6IGJvb2xlYW4gPT4ge1xuICByZXR1cm4gQm9vbGVhbihcbiAgICByZXEuaGVhZGVycy5nZXQoJ3RyYW5zZmVyLWVuY29kaW5nJykgfHxcbiAgICAgIChyZXEuaGVhZGVycy5nZXQoJ2NvbnRlbnQtbGVuZ3RoJykgJiYgcmVxLmhlYWRlcnMuZ2V0KCdjb250ZW50LWxlbmd0aCcpICE9PSAnMCcpLFxuICApXG59XG5cbmNvbnN0IGhhc0FjY2VwdGFibGVNZXRob2QgPSAocmVxOiBSZXF1ZXN0KTogYm9vbGVhbiA9PiAhVU5BQ0NFUFRBQkxFX01FVEhPRFMuaGFzKHJlcS5tZXRob2QpXG5cbmNvbnN0IGhhc0FjY2VwdGFibGVDb250ZW50VHlwZSA9IChyZXE6IFJlcXVlc3QpOiBib29sZWFuID0+IHtcbiAgY29uc3QgY29udFR5cGUgPSByZXEuaGVhZGVycy5nZXQoJ2NvbnRlbnQtdHlwZScpXG4gIHJldHVybiBjb250VHlwZS5pbmNsdWRlcygnYm91bmRhcnk9JykgJiYgQUNDRVBUQUJMRV9DT05URU5UX1RZUEUudGVzdChjb250VHlwZSlcbn1cblxuZXhwb3J0IGNvbnN0IGlzRWxpZ2libGVSZXF1ZXN0ID0gKHJlcTogUmVxdWVzdCk6IGJvb2xlYW4gPT4ge1xuICB0cnkge1xuICAgIHJldHVybiBoYXNCb2R5KHJlcSkgJiYgaGFzQWNjZXB0YWJsZU1ldGhvZChyZXEpICYmIGhhc0FjY2VwdGFibGVDb250ZW50VHlwZShyZXEpXG4gIH0gY2F0Y2ggKGUpIHtcbiAgICByZXR1cm4gZmFsc2VcbiAgfVxufVxuIl0sIm5hbWVzIjpbIkFDQ0VQVEFCTEVfQ09OVEVOVF9UWVBFIiwiVU5BQ0NFUFRBQkxFX01FVEhPRFMiLCJTZXQiLCJoYXNCb2R5IiwicmVxIiwiQm9vbGVhbiIsImhlYWRlcnMiLCJnZXQiLCJoYXNBY2NlcHRhYmxlTWV0aG9kIiwiaGFzIiwibWV0aG9kIiwiaGFzQWNjZXB0YWJsZUNvbnRlbnRUeXBlIiwiY29udFR5cGUiLCJpbmNsdWRlcyIsInRlc3QiLCJpc0VsaWdpYmxlUmVxdWVzdCIsImUiXSwibWFwcGluZ3MiOiJBQUFBLE1BQU1BLDBCQUEwQjtBQUNoQyxNQUFNQyx1QkFBdUIsSUFBSUMsSUFBSTtJQUFDO0lBQU87SUFBUTtJQUFVO0lBQVc7SUFBVztDQUFRO0FBRTdGLE1BQU1DLFVBQVUsQ0FBQ0M7SUFDZixPQUFPQyxRQUNMRCxJQUFJRSxPQUFPLENBQUNDLEdBQUcsQ0FBQyx3QkFDYkgsSUFBSUUsT0FBTyxDQUFDQyxHQUFHLENBQUMscUJBQXFCSCxJQUFJRSxPQUFPLENBQUNDLEdBQUcsQ0FBQyxzQkFBc0I7QUFFbEY7QUFFQSxNQUFNQyxzQkFBc0IsQ0FBQ0osTUFBMEIsQ0FBQ0gscUJBQXFCUSxHQUFHLENBQUNMLElBQUlNLE1BQU07QUFFM0YsTUFBTUMsMkJBQTJCLENBQUNQO0lBQ2hDLE1BQU1RLFdBQVdSLElBQUlFLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDO0lBQ2pDLE9BQU9LLFNBQVNDLFFBQVEsQ0FBQyxnQkFBZ0JiLHdCQUF3QmMsSUFBSSxDQUFDRjtBQUN4RTtBQUVBLE9BQU8sTUFBTUcsb0JBQW9CLENBQUNYO0lBQ2hDLElBQUk7UUFDRixPQUFPRCxRQUFRQyxRQUFRSSxvQkFBb0JKLFFBQVFPLHlCQUF5QlA7SUFDOUUsRUFBRSxPQUFPWSxHQUFHO1FBQ1YsT0FBTztJQUNUO0FBQ0YsRUFBQyJ9