@webiny/api-page-builder-import-export 0.0.0-unstable.de38392959 → 0.0.0-unstable.e0bfc55d5a

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 (225) hide show
  1. package/client.d.ts +1 -1
  2. package/client.js.map +1 -1
  3. package/export/combine/blocksHandler.d.ts +2 -2
  4. package/export/combine/blocksHandler.js.map +1 -1
  5. package/export/combine/formsHandler.d.ts +2 -2
  6. package/export/combine/formsHandler.js.map +1 -1
  7. package/export/combine/index.d.ts +2 -2
  8. package/export/combine/index.js +2 -2
  9. package/export/combine/index.js.map +1 -1
  10. package/export/combine/templatesHandler.d.ts +2 -2
  11. package/export/combine/templatesHandler.js.map +1 -1
  12. package/export/pages/ExportPagesCleanup.d.ts +5 -0
  13. package/export/pages/ExportPagesCleanup.js +82 -0
  14. package/export/pages/ExportPagesCleanup.js.map +1 -0
  15. package/export/pages/ExportPagesController.d.ts +5 -0
  16. package/export/pages/ExportPagesController.js +31 -0
  17. package/export/pages/ExportPagesController.js.map +1 -0
  18. package/export/pages/ExportPagesZipPages.d.ts +5 -0
  19. package/export/pages/ExportPagesZipPages.js +23 -0
  20. package/export/pages/ExportPagesZipPages.js.map +1 -0
  21. package/export/pages/controller/CombineZippedPages.d.ts +5 -0
  22. package/export/pages/controller/CombineZippedPages.js +75 -0
  23. package/export/pages/controller/CombineZippedPages.js.map +1 -0
  24. package/export/pages/controller/CreateZipPagesTasks.d.ts +8 -0
  25. package/export/pages/controller/CreateZipPagesTasks.js +103 -0
  26. package/export/pages/controller/CreateZipPagesTasks.js.map +1 -0
  27. package/export/pages/controller/ProcessZipPagesTasks.d.ts +6 -0
  28. package/export/pages/controller/ProcessZipPagesTasks.js +61 -0
  29. package/export/pages/controller/ProcessZipPagesTasks.js.map +1 -0
  30. package/export/pages/types.d.ts +53 -0
  31. package/export/pages/types.js +26 -0
  32. package/export/pages/types.js.map +1 -0
  33. package/export/pages/utils.d.ts +2 -0
  34. package/export/pages/utils.js +13 -0
  35. package/export/pages/utils.js.map +1 -0
  36. package/export/pages/zipPages/ZipPages.d.ts +5 -0
  37. package/export/pages/zipPages/ZipPages.js +100 -0
  38. package/export/pages/zipPages/ZipPages.js.map +1 -0
  39. package/export/pages/zipPages/ZipPagesDataManager.d.ts +14 -0
  40. package/export/pages/zipPages/ZipPagesDataManager.js +46 -0
  41. package/export/pages/zipPages/ZipPagesDataManager.js.map +1 -0
  42. package/export/pages/zipPages/getPageFactory.d.ts +4 -0
  43. package/export/pages/zipPages/getPageFactory.js +38 -0
  44. package/export/pages/zipPages/getPageFactory.js.map +1 -0
  45. package/export/process/blocksHandler.d.ts +2 -2
  46. package/export/process/blocksHandler.js.map +1 -1
  47. package/export/process/exporters/BlockExporter.d.ts +2 -2
  48. package/export/process/exporters/BlockExporter.js.map +1 -1
  49. package/export/process/exporters/FormExporter.d.ts +2 -2
  50. package/export/process/exporters/FormExporter.js.map +1 -1
  51. package/export/process/exporters/PageExporter.d.ts +10 -3
  52. package/export/process/exporters/PageExporter.js +2 -1
  53. package/export/process/exporters/PageExporter.js.map +1 -1
  54. package/export/process/exporters/PageTemplateExporter.d.ts +3 -3
  55. package/export/process/exporters/PageTemplateExporter.js +3 -1
  56. package/export/process/exporters/PageTemplateExporter.js.map +1 -1
  57. package/export/process/formsHandler.d.ts +2 -2
  58. package/export/process/formsHandler.js.map +1 -1
  59. package/export/process/index.d.ts +2 -2
  60. package/export/process/index.js +2 -2
  61. package/export/process/index.js.map +1 -1
  62. package/export/process/templatesHandler.d.ts +2 -2
  63. package/export/process/templatesHandler.js.map +1 -1
  64. package/export/s3Stream.d.ts +6 -4
  65. package/export/s3Stream.js +1 -2
  66. package/export/s3Stream.js.map +1 -1
  67. package/export/utils.d.ts +4 -4
  68. package/export/utils.js +7 -9
  69. package/export/utils.js.map +1 -1
  70. package/export/zipper.d.ts +3 -2
  71. package/export/zipper.js.map +1 -1
  72. package/graphql/crud/blocks.crud.d.ts +1 -1
  73. package/graphql/crud/blocks.crud.js +1 -2
  74. package/graphql/crud/blocks.crud.js.map +1 -1
  75. package/graphql/crud/forms.crud.d.ts +1 -1
  76. package/graphql/crud/forms.crud.js +1 -2
  77. package/graphql/crud/forms.crud.js.map +1 -1
  78. package/graphql/crud/importExportTasks.crud.d.ts +2 -2
  79. package/graphql/crud/importExportTasks.crud.js +73 -58
  80. package/graphql/crud/importExportTasks.crud.js.map +1 -1
  81. package/graphql/crud/pages.crud.d.ts +1 -2
  82. package/graphql/crud/pages.crud.js +208 -125
  83. package/graphql/crud/pages.crud.js.map +1 -1
  84. package/graphql/crud/templates.crud.d.ts +1 -1
  85. package/graphql/crud/templates.crud.js +1 -2
  86. package/graphql/crud/templates.crud.js.map +1 -1
  87. package/graphql/crud.d.ts +2 -2
  88. package/graphql/crud.js.map +1 -1
  89. package/graphql/graphql/blocks.gql.d.ts +2 -2
  90. package/graphql/graphql/blocks.gql.js +4 -6
  91. package/graphql/graphql/blocks.gql.js.map +1 -1
  92. package/graphql/graphql/forms.gql.d.ts +2 -2
  93. package/graphql/graphql/forms.gql.js +4 -6
  94. package/graphql/graphql/forms.gql.js.map +1 -1
  95. package/graphql/graphql/importExportTasks.gql.d.ts +2 -2
  96. package/graphql/graphql/importExportTasks.gql.js +5 -7
  97. package/graphql/graphql/importExportTasks.gql.js.map +1 -1
  98. package/graphql/graphql/pages.gql.d.ts +2 -2
  99. package/graphql/graphql/pages.gql.js +101 -14
  100. package/graphql/graphql/pages.gql.js.map +1 -1
  101. package/graphql/graphql/templates.gql.d.ts +2 -2
  102. package/graphql/graphql/templates.gql.js +4 -6
  103. package/graphql/graphql/templates.gql.js.map +1 -1
  104. package/graphql/graphql/utils/resolve.d.ts +3 -3
  105. package/graphql/graphql/utils/resolve.js +14 -5
  106. package/graphql/graphql/utils/resolve.js.map +1 -1
  107. package/graphql/graphql.d.ts +1 -1
  108. package/graphql/graphql.js +1 -2
  109. package/graphql/graphql.js.map +1 -1
  110. package/graphql/index.d.ts +2 -2
  111. package/graphql/index.js +2 -1
  112. package/graphql/index.js.map +1 -1
  113. package/graphql/types.d.ts +61 -33
  114. package/graphql/types.js.map +1 -1
  115. package/import/constants.js +3 -6
  116. package/import/constants.js.map +1 -1
  117. package/import/create/blocksHandler.d.ts +2 -2
  118. package/import/create/blocksHandler.js.map +1 -1
  119. package/import/create/formsHandler.d.ts +2 -2
  120. package/import/create/formsHandler.js.map +1 -1
  121. package/import/create/index.d.ts +2 -2
  122. package/import/create/index.js +2 -2
  123. package/import/create/index.js.map +1 -1
  124. package/import/create/pagesHandler.d.ts +2 -2
  125. package/import/create/pagesHandler.js.map +1 -1
  126. package/import/create/templatesHandler.d.ts +2 -2
  127. package/import/create/templatesHandler.js.map +1 -1
  128. package/import/pages/ImportPagesController.d.ts +5 -0
  129. package/import/pages/ImportPagesController.js +29 -0
  130. package/import/pages/ImportPagesController.js.map +1 -0
  131. package/import/pages/ImportPagesProcessPages.d.ts +6 -0
  132. package/import/pages/ImportPagesProcessPages.js +112 -0
  133. package/import/pages/ImportPagesProcessPages.js.map +1 -0
  134. package/import/pages/controller/ImportPagesProcessPagesChecker.d.ts +6 -0
  135. package/import/pages/controller/ImportPagesProcessPagesChecker.js +40 -0
  136. package/import/pages/controller/ImportPagesProcessPagesChecker.js.map +1 -0
  137. package/import/pages/controller/ImportPagesProcessZipFile.d.ts +5 -0
  138. package/import/pages/controller/ImportPagesProcessZipFile.js +71 -0
  139. package/import/pages/controller/ImportPagesProcessZipFile.js.map +1 -0
  140. package/import/{process/pages → pages/process}/importPage.d.ts +3 -4
  141. package/import/pages/process/importPage.js.map +1 -0
  142. package/import/pages/types.d.ts +48 -0
  143. package/import/pages/types.js +20 -0
  144. package/import/pages/types.js.map +1 -0
  145. package/import/process/blocks/ElementIdsProcessor.d.ts +5 -0
  146. package/import/process/blocks/ElementIdsProcessor.js +26 -0
  147. package/import/process/blocks/ElementIdsProcessor.js.map +1 -0
  148. package/import/process/blocks/blocksHandler.d.ts +2 -2
  149. package/import/process/blocks/blocksHandler.js.map +1 -1
  150. package/import/process/blocks/importBlock.d.ts +3 -3
  151. package/import/process/blocks/importBlock.js +5 -2
  152. package/import/process/blocks/importBlock.js.map +1 -1
  153. package/import/process/forms/formsHandler.d.ts +2 -2
  154. package/import/process/forms/formsHandler.js.map +1 -1
  155. package/import/process/forms/importForm.d.ts +2 -2
  156. package/import/process/forms/importForm.js.map +1 -1
  157. package/import/process/index.d.ts +2 -2
  158. package/import/process/index.js +2 -2
  159. package/import/process/index.js.map +1 -1
  160. package/import/process/templates/importTemplate.d.ts +3 -3
  161. package/import/process/templates/importTemplate.js.map +1 -1
  162. package/import/process/templates/templatesHandler.d.ts +2 -2
  163. package/import/process/templates/templatesHandler.js +3 -1
  164. package/import/process/templates/templatesHandler.js.map +1 -1
  165. package/import/utils/deleteS3Folder.js.map +1 -1
  166. package/import/utils/extractAndUploadZipFileContents.d.ts +1 -1
  167. package/import/utils/extractAndUploadZipFileContents.js +6 -3
  168. package/import/utils/extractAndUploadZipFileContents.js.map +1 -1
  169. package/import/utils/extractZipAndUploadToS3.d.ts +1 -1
  170. package/import/utils/extractZipAndUploadToS3.js.map +1 -1
  171. package/import/utils/getFileNameWithoutExt.js.map +1 -1
  172. package/import/utils/index.js.map +1 -1
  173. package/import/utils/initialStats.js.map +1 -1
  174. package/import/utils/prepareDataDirMap.d.ts +1 -1
  175. package/import/utils/prepareDataDirMap.js.map +1 -1
  176. package/import/utils/updateFilesInData.d.ts +1 -1
  177. package/import/utils/updateFilesInData.js.map +1 -1
  178. package/import/utils/uploadAssets.d.ts +3 -3
  179. package/import/utils/uploadAssets.js.map +1 -1
  180. package/import/utils/uploadFilesFromS3.d.ts +3 -3
  181. package/import/utils/uploadFilesFromS3.js.map +1 -1
  182. package/mockSecurity.d.ts +1 -1
  183. package/mockSecurity.js.map +1 -1
  184. package/package.json +33 -41
  185. package/tasks/common/ChildTasksCleanup.d.ts +12 -0
  186. package/tasks/common/ChildTasksCleanup.js +64 -0
  187. package/tasks/common/ChildTasksCleanup.js.map +1 -0
  188. package/tasks/index.d.ts +1 -0
  189. package/tasks/index.js +13 -0
  190. package/tasks/index.js.map +1 -0
  191. package/tasks/pages/exportPagesCleanupTask.d.ts +3 -0
  192. package/tasks/pages/exportPagesCleanupTask.js +36 -0
  193. package/tasks/pages/exportPagesCleanupTask.js.map +1 -0
  194. package/tasks/pages/exportPagesControllerTask.d.ts +3 -0
  195. package/tasks/pages/exportPagesControllerTask.js +83 -0
  196. package/tasks/pages/exportPagesControllerTask.js.map +1 -0
  197. package/tasks/pages/exportPagesZipPagesTask.d.ts +3 -0
  198. package/tasks/pages/exportPagesZipPagesTask.js +39 -0
  199. package/tasks/pages/exportPagesZipPagesTask.js.map +1 -0
  200. package/tasks/pages/importPagesControllerTask.d.ts +3 -0
  201. package/tasks/pages/importPagesControllerTask.js +39 -0
  202. package/tasks/pages/importPagesControllerTask.js.map +1 -0
  203. package/tasks/pages/importPagesProcessPageTask.d.ts +3 -0
  204. package/tasks/pages/importPagesProcessPageTask.js +39 -0
  205. package/tasks/pages/importPagesProcessPageTask.js.map +1 -0
  206. package/tasks/pages/index.d.ts +1 -0
  207. package/tasks/pages/index.js +17 -0
  208. package/tasks/pages/index.js.map +1 -0
  209. package/types.d.ts +2 -2
  210. package/types.js +2 -4
  211. package/types.js.map +1 -1
  212. package/utils/ZipFiles.d.ts +11 -0
  213. package/utils/ZipFiles.js +124 -0
  214. package/utils/ZipFiles.js.map +1 -0
  215. package/export/combine/pagesHandler.d.ts +0 -6
  216. package/export/combine/pagesHandler.js +0 -101
  217. package/export/combine/pagesHandler.js.map +0 -1
  218. package/export/process/pagesHandler.d.ts +0 -6
  219. package/export/process/pagesHandler.js +0 -191
  220. package/export/process/pagesHandler.js.map +0 -1
  221. package/import/process/pages/importPage.js.map +0 -1
  222. package/import/process/pages/pagesHandler.d.ts +0 -3
  223. package/import/process/pages/pagesHandler.js +0 -185
  224. package/import/process/pages/pagesHandler.js.map +0 -1
  225. /package/import/{process/pages → pages/process}/importPage.js +0 -0
@@ -1 +1 @@
1
- {"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["import { Topic } from \"@webiny/pubsub/types\";\nimport { PbContext } from \"@webiny/api-page-builder/types\";\nimport { FormBuilderContext } from \"@webiny/api-form-builder/types\";\nimport {\n ExportRevisionType,\n ImportExportTask,\n ImportExportTaskStatus,\n ImportExportTaskStorageOperations,\n ImportExportTaskStorageOperationsListParams\n} from \"~/types\";\n\nexport interface ExportPagesParams {\n ids?: string[];\n revisionType: ExportRevisionType;\n where?: {\n category?: string;\n status?: string;\n tags?: { query: string[]; rule?: \"any\" | \"all\" };\n [key: string]: any;\n };\n search?: { query?: string };\n sort?: string[];\n}\n\nexport interface ImportPagesParams {\n category: string;\n zipFileUrl: string;\n meta?: Record<string, any>;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnPagesBeforeExportTopicParams {\n params: ExportPagesParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnPagesAfterExportTopicParams {\n params: ExportPagesParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnPagesBeforeImportTopicParams {\n params: ImportPagesParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnPagesAfterImportTopicParams {\n params: ImportPagesParams;\n}\n\nexport type PagesImportExportCrud = {\n exportPages(params: ExportPagesParams): Promise<{ task: ImportExportTask }>;\n importPages(params: ImportPagesParams): Promise<{ task: ImportExportTask }>;\n\n onPagesBeforeExport: Topic<OnPagesBeforeExportTopicParams>;\n onPagesAfterExport: Topic<OnPagesAfterExportTopicParams>;\n onPagesBeforeImport: Topic<OnPagesBeforeImportTopicParams>;\n onPagesAfterImport: Topic<OnPagesAfterImportTopicParams>;\n};\n\nexport interface ExportBlocksParams {\n ids?: string[];\n sort?: string[];\n where?: {\n blockCategory?: string;\n };\n}\n\nexport interface ImportBlocksParams {\n zipFileUrl: string;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnBlocksBeforeExportTopicParams {\n params: ExportBlocksParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnBlocksAfterExportTopicParams {\n params: ExportBlocksParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnBlocksBeforeImportTopicParams {\n params: ImportBlocksParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnBlocksAfterImportTopicParams {\n params: ImportBlocksParams;\n}\n\nexport type BlocksImportExportCrud = {\n exportBlocks(params: ExportBlocksParams): Promise<{ task: ImportExportTask }>;\n importBlocks(params: ImportBlocksParams): Promise<{ task: ImportExportTask }>;\n\n onBlocksBeforeExport: Topic<OnBlocksBeforeExportTopicParams>;\n onBlocksAfterExport: Topic<OnBlocksAfterExportTopicParams>;\n onBlocksBeforeImport: Topic<OnBlocksBeforeImportTopicParams>;\n onBlocksAfterImport: Topic<OnBlocksAfterImportTopicParams>;\n};\n\nexport interface ExportTemplatesParams {\n ids?: string[];\n sort?: string[];\n}\n\nexport interface ImportTemplatesParams {\n zipFileUrl: string;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnTemplatesBeforeExportTopicParams {\n params: ExportTemplatesParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnTemplatesAfterExportTopicParams {\n params: ExportTemplatesParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnTemplatesBeforeImportTopicParams {\n params: ImportTemplatesParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnTemplatesAfterImportTopicParams {\n params: ImportTemplatesParams;\n}\n\nexport type TemplatesImportExportCrud = {\n exportTemplates(params: ExportTemplatesParams): Promise<{ task: ImportExportTask }>;\n importTemplates(params: ImportTemplatesParams): Promise<{ task: ImportExportTask }>;\n\n onTemplatesBeforeExport: Topic<OnTemplatesBeforeExportTopicParams>;\n onTemplatesAfterExport: Topic<OnTemplatesAfterExportTopicParams>;\n onTemplatesBeforeImport: Topic<OnTemplatesBeforeImportTopicParams>;\n onTemplatesAfterImport: Topic<OnTemplatesAfterImportTopicParams>;\n};\n\nexport interface ExportFormsParams {\n ids?: string[];\n revisionType: ExportRevisionType;\n search?: { query?: string };\n sort?: string[];\n}\n\nexport interface ImportFormsParams {\n zipFileUrl: string;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnFormsBeforeExportTopicParams {\n params: ExportFormsParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnFormsAfterExportTopicParams {\n params: ExportFormsParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnFormsBeforeImportTopicParams {\n params: ImportFormsParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnFormsAfterImportTopicParams {\n params: ImportFormsParams;\n}\n\nexport type FormsImportExportCrud = {\n exportForms(params: ExportFormsParams): Promise<{ task: ImportExportTask }>;\n importForms(params: ImportFormsParams): Promise<{ task: ImportExportTask }>;\n\n onFormsBeforeExport: Topic<OnFormsBeforeExportTopicParams>;\n onFormsAfterExport: Topic<OnFormsAfterExportTopicParams>;\n onFormsBeforeImport: Topic<OnFormsBeforeImportTopicParams>;\n onFormsAfterImport: Topic<OnFormsAfterImportTopicParams>;\n};\n\ntype ImportExportTaskCreateData = Omit<ImportExportTask, \"id\" | \"createdOn\" | \"createdBy\">;\n\nexport type ImportExportTaskCrud = {\n /**\n * To be used internally in our code.\n * @internal\n */\n storageOperations: ImportExportTaskStorageOperations;\n\n getTask(id: string): Promise<ImportExportTask | null>;\n listTasks(params?: ImportExportTaskStorageOperationsListParams): Promise<ImportExportTask[]>;\n createTask(data: Partial<ImportExportTaskCreateData>): Promise<ImportExportTask>;\n updateTask(id: string, data: Partial<ImportExportTaskCreateData>): Promise<ImportExportTask>;\n updateStats(\n id: string,\n data: {\n prevStatus: ImportExportTaskStatus;\n nextStatus: ImportExportTaskStatus;\n }\n ): Promise<ImportExportTask>;\n deleteTask(id: string): Promise<ImportExportTask>;\n getSubTask(id: string, subtaskId: string): Promise<ImportExportTask | null>;\n listSubTasks(\n id: string,\n status: ImportExportTaskStatus,\n limit: number\n ): Promise<ImportExportTask[]>;\n createSubTask(\n id: string,\n subTaskId: string,\n data: Partial<ImportExportTaskCreateData>\n ): Promise<ImportExportTask>;\n updateSubTask(\n id: string,\n subTaskId: string,\n data: Partial<ImportExportTaskCreateData>\n ): Promise<ImportExportTask>;\n};\n\nexport interface PbImportExportContext extends PbContext {\n pageBuilder: PbContext[\"pageBuilder\"] & {\n pages: PagesImportExportCrud;\n blocks: BlocksImportExportCrud;\n templates: TemplatesImportExportCrud;\n importExportTask: ImportExportTaskCrud;\n };\n formBuilder: FormBuilderContext[\"formBuilder\"] & {\n forms: FormsImportExportCrud;\n };\n}\n\nexport interface ImportExportPluginsParams {\n storageOperations: ImportExportTaskStorageOperations;\n}\n"],"mappings":""}
1
+ {"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["import type { Topic } from \"@webiny/pubsub/types\";\nimport type { CreatedBy, ListPagesParams, Page, PbContext } from \"@webiny/api-page-builder/types\";\nimport type { FormBuilderContext } from \"@webiny/api-form-builder/types\";\nimport type {\n ExportRevisionType,\n ImportExportTask,\n ImportExportTaskStatus,\n ImportExportTaskStorageOperations,\n ImportExportTaskStorageOperationsListParams\n} from \"~/types\";\nimport type { Context as TasksContext, IResponseError } from \"@webiny/tasks/types\";\n\nexport interface ExportPagesParams extends Pick<ListPagesParams, \"where\" | \"sort\" | \"search\"> {\n limit?: number;\n revisionType: ExportRevisionType;\n}\n\nexport interface ImportPagesParams {\n category: string;\n zipFileUrl: string;\n meta?: Record<string, any>;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnPagesBeforeExportTopicParams {\n params: ExportPagesParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnPagesAfterExportTopicParams {\n params: ExportPagesParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnPagesBeforeImportTopicParams {\n params: ImportPagesParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnPagesAfterImportTopicParams {\n params: ImportPagesParams;\n}\n\nexport interface PbExportPagesTaskData {\n url?: string;\n error?: IResponseError;\n}\n\nexport interface PbExportPagesTask {\n id: string;\n createdOn: string;\n createdBy: CreatedBy;\n status: string;\n data: PbExportPagesTaskData;\n stats: {\n total: number;\n completed: number;\n failed: number;\n };\n}\n\nexport interface PbExportPagesResponse {\n task: PbExportPagesTask;\n}\n\nexport interface PbImportPagesTaskData {\n error?: IResponseError;\n}\n\nexport interface PbImportPagesTaskStats {\n total: number;\n completed: number;\n failed: number;\n}\n\nexport interface PbImportPagesTask {\n id: string;\n createdOn: string;\n createdBy: CreatedBy;\n status: string;\n data: PbImportPagesTaskData;\n stats: PbImportPagesTaskStats;\n}\n\nexport interface PbImportPagesResponse {\n task: PbImportPagesTask;\n}\n\nexport interface PagesImportExportCrud {\n exportPages(params: ExportPagesParams): Promise<PbExportPagesResponse>;\n importPages(params: ImportPagesParams): Promise<PbImportPagesResponse>;\n /**\n * Background tasks implementation.\n */\n getExportPagesTask: (id: string) => Promise<PbExportPagesTask | null>;\n getImportPagesTask: (id: string) => Promise<PbImportPagesTask | null>;\n listImportedPages: (taskId: string) => Promise<Pick<Page, \"id\" | \"title\" | \"version\">[]>;\n\n onPagesBeforeExport: Topic<OnPagesBeforeExportTopicParams>;\n onPagesAfterExport: Topic<OnPagesAfterExportTopicParams>;\n onPagesBeforeImport: Topic<OnPagesBeforeImportTopicParams>;\n onPagesAfterImport: Topic<OnPagesAfterImportTopicParams>;\n}\n\nexport interface ExportBlocksParams {\n ids?: string[];\n sort?: string[];\n where?: {\n blockCategory?: string;\n };\n}\n\nexport interface ImportBlocksParams {\n zipFileUrl: string;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnBlocksBeforeExportTopicParams {\n params: ExportBlocksParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnBlocksAfterExportTopicParams {\n params: ExportBlocksParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnBlocksBeforeImportTopicParams {\n params: ImportBlocksParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnBlocksAfterImportTopicParams {\n params: ImportBlocksParams;\n}\n\nexport type BlocksImportExportCrud = {\n exportBlocks(params: ExportBlocksParams): Promise<{ task: ImportExportTask }>;\n importBlocks(params: ImportBlocksParams): Promise<{ task: ImportExportTask }>;\n\n onBlocksBeforeExport: Topic<OnBlocksBeforeExportTopicParams>;\n onBlocksAfterExport: Topic<OnBlocksAfterExportTopicParams>;\n onBlocksBeforeImport: Topic<OnBlocksBeforeImportTopicParams>;\n onBlocksAfterImport: Topic<OnBlocksAfterImportTopicParams>;\n};\n\nexport interface ExportTemplatesParams {\n ids?: string[];\n sort?: string[];\n}\n\nexport interface ImportTemplatesParams {\n zipFileUrl: string;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnTemplatesBeforeExportTopicParams {\n params: ExportTemplatesParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnTemplatesAfterExportTopicParams {\n params: ExportTemplatesParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnTemplatesBeforeImportTopicParams {\n params: ImportTemplatesParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnTemplatesAfterImportTopicParams {\n params: ImportTemplatesParams;\n}\n\nexport type TemplatesImportExportCrud = {\n exportTemplates(params: ExportTemplatesParams): Promise<{ task: ImportExportTask }>;\n importTemplates(params: ImportTemplatesParams): Promise<{ task: ImportExportTask }>;\n\n onTemplatesBeforeExport: Topic<OnTemplatesBeforeExportTopicParams>;\n onTemplatesAfterExport: Topic<OnTemplatesAfterExportTopicParams>;\n onTemplatesBeforeImport: Topic<OnTemplatesBeforeImportTopicParams>;\n onTemplatesAfterImport: Topic<OnTemplatesAfterImportTopicParams>;\n};\n\nexport interface ExportFormsParams {\n ids?: string[];\n revisionType: ExportRevisionType;\n search?: { query?: string };\n sort?: string[];\n}\n\nexport interface ImportFormsParams {\n zipFileUrl: string;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnFormsBeforeExportTopicParams {\n params: ExportFormsParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnFormsAfterExportTopicParams {\n params: ExportFormsParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnFormsBeforeImportTopicParams {\n params: ImportFormsParams;\n}\n\n/**\n * @category Lifecycle events\n */\nexport interface OnFormsAfterImportTopicParams {\n params: ImportFormsParams;\n}\n\nexport type FormsImportExportCrud = {\n exportForms(params: ExportFormsParams): Promise<{ task: ImportExportTask }>;\n importForms(params: ImportFormsParams): Promise<{ task: ImportExportTask }>;\n\n onFormsBeforeExport: Topic<OnFormsBeforeExportTopicParams>;\n onFormsAfterExport: Topic<OnFormsAfterExportTopicParams>;\n onFormsBeforeImport: Topic<OnFormsBeforeImportTopicParams>;\n onFormsAfterImport: Topic<OnFormsAfterImportTopicParams>;\n};\n\ntype ImportExportTaskCreateData = Omit<ImportExportTask, \"id\" | \"createdOn\" | \"createdBy\">;\n\nexport type ImportExportTaskCrud = {\n /**\n * To be used internally in our code.\n * @internal\n */\n storageOperations: ImportExportTaskStorageOperations;\n\n getTask(id: string): Promise<ImportExportTask | null>;\n listTasks(params?: ImportExportTaskStorageOperationsListParams): Promise<ImportExportTask[]>;\n createTask(data: Partial<ImportExportTaskCreateData>): Promise<ImportExportTask>;\n updateTask(id: string, data: Partial<ImportExportTaskCreateData>): Promise<ImportExportTask>;\n updateStats(\n id: string,\n data: {\n prevStatus: ImportExportTaskStatus;\n nextStatus: ImportExportTaskStatus;\n }\n ): Promise<ImportExportTask>;\n deleteTask(id: string): Promise<ImportExportTask>;\n getSubTask(id: string, subtaskId: string): Promise<ImportExportTask | null>;\n listSubTasks(\n id: string,\n status: ImportExportTaskStatus,\n limit: number\n ): Promise<ImportExportTask[]>;\n createSubTask(\n id: string,\n subTaskId: string,\n data: Partial<ImportExportTaskCreateData>\n ): Promise<ImportExportTask>;\n updateSubTask(\n id: string,\n subTaskId: string,\n data: Partial<ImportExportTaskCreateData>\n ): Promise<ImportExportTask>;\n};\n\nexport interface PbImportExportContext extends TasksContext, PbContext {\n pageBuilder: PbContext[\"pageBuilder\"] & {\n pages: PagesImportExportCrud;\n blocks: BlocksImportExportCrud;\n templates: TemplatesImportExportCrud;\n importExportTask: ImportExportTaskCrud;\n };\n formBuilder: FormBuilderContext[\"formBuilder\"] & {\n forms: FormsImportExportCrud;\n };\n}\n\nexport interface ImportExportPluginsParams {\n storageOperations: ImportExportTaskStorageOperations;\n}\n"],"mappings":"","ignoreList":[]}
@@ -6,11 +6,8 @@ Object.defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports.INSTALL_EXTRACT_DIR = exports.INSTALL_DIR = exports.ASSETS_DIR_NAME = void 0;
8
8
  var _path = _interopRequireDefault(require("path"));
9
- const INSTALL_DIR = "/tmp";
10
- exports.INSTALL_DIR = INSTALL_DIR;
11
- const INSTALL_EXTRACT_DIR = _path.default.join(INSTALL_DIR, "apiPageBuilderImport");
12
- exports.INSTALL_EXTRACT_DIR = INSTALL_EXTRACT_DIR;
13
- const ASSETS_DIR_NAME = "/assets";
14
- exports.ASSETS_DIR_NAME = ASSETS_DIR_NAME;
9
+ const INSTALL_DIR = exports.INSTALL_DIR = "/tmp";
10
+ const INSTALL_EXTRACT_DIR = exports.INSTALL_EXTRACT_DIR = _path.default.join(INSTALL_DIR, "apiPageBuilderImport");
11
+ const ASSETS_DIR_NAME = exports.ASSETS_DIR_NAME = "/assets";
15
12
 
16
13
  //# sourceMappingURL=constants.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["_path","_interopRequireDefault","require","INSTALL_DIR","exports","INSTALL_EXTRACT_DIR","path","join","ASSETS_DIR_NAME"],"sources":["constants.ts"],"sourcesContent":["import path from \"path\";\n\nexport const INSTALL_DIR = \"/tmp\";\nexport const INSTALL_EXTRACT_DIR = path.join(INSTALL_DIR, \"apiPageBuilderImport\");\nexport const ASSETS_DIR_NAME = \"/assets\";\n"],"mappings":";;;;;;;AAAA,IAAAA,KAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEO,MAAMC,WAAW,GAAG,MAAM;AAACC,OAAA,CAAAD,WAAA,GAAAA,WAAA;AAC3B,MAAME,mBAAmB,GAAGC,aAAI,CAACC,IAAI,CAACJ,WAAW,EAAE,sBAAsB,CAAC;AAACC,OAAA,CAAAC,mBAAA,GAAAA,mBAAA;AAC3E,MAAMG,eAAe,GAAG,SAAS;AAACJ,OAAA,CAAAI,eAAA,GAAAA,eAAA"}
1
+ {"version":3,"names":["_path","_interopRequireDefault","require","INSTALL_DIR","exports","INSTALL_EXTRACT_DIR","path","join","ASSETS_DIR_NAME"],"sources":["constants.ts"],"sourcesContent":["import path from \"path\";\n\nexport const INSTALL_DIR = \"/tmp\";\nexport const INSTALL_EXTRACT_DIR = path.join(INSTALL_DIR, \"apiPageBuilderImport\");\nexport const ASSETS_DIR_NAME = \"/assets\";\n"],"mappings":";;;;;;;AAAA,IAAAA,KAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEO,MAAMC,WAAW,GAAAC,OAAA,CAAAD,WAAA,GAAG,MAAM;AAC1B,MAAME,mBAAmB,GAAAD,OAAA,CAAAC,mBAAA,GAAGC,aAAI,CAACC,IAAI,CAACJ,WAAW,EAAE,sBAAsB,CAAC;AAC1E,MAAMK,eAAe,GAAAJ,OAAA,CAAAI,eAAA,GAAG,SAAS","ignoreList":[]}
@@ -1,3 +1,3 @@
1
- import { PbImportExportContext } from "../../types";
2
- import { Configuration, Payload, Response } from ".";
1
+ import type { PbImportExportContext } from "../../types";
2
+ import type { Configuration, Payload, Response } from "./";
3
3
  export declare const blocksHandler: (configuration: Configuration, payload: Payload, context: PbImportExportContext) => Promise<Response>;
@@ -1 +1 @@
1
- {"version":3,"names":["_types","require","_utils","_client","_mockSecurity","_utils2","_extractAndUploadZipFileContents","blocksHandler","configuration","payload","context","log","console","pageBuilder","task","type","zipFileUrl","identity","data","error","message","mockSecurity","blockImportDataList","extractAndUploadZipFileContents","i","length","blocksDirMap","subtask","importExportTask","createSubTask","id","zeroPad","status","ImportExportTaskStatus","PENDING","blockKey","key","input","fileUploadsData","updateTask","PROCESSING","stats","initialStats","invokeHandlerClient","name","handlers","process","taskId","subTaskIndex","security","getIdentity","description","e","FAILED","code","exports"],"sources":["blocksHandler.ts"],"sourcesContent":["import { ImportExportTaskStatus, PbImportExportContext } from \"~/types\";\nimport { initialStats } from \"~/import/utils\";\nimport { invokeHandlerClient } from \"~/client\";\nimport { Payload as ProcessPayload } from \"../process\";\nimport { mockSecurity } from \"~/mockSecurity\";\nimport { zeroPad } from \"@webiny/utils\";\nimport { Configuration, Payload, Response } from \"~/import/create\";\nimport { extractAndUploadZipFileContents } from \"~/import/utils/extractAndUploadZipFileContents\";\n\nexport const blocksHandler = async (\n configuration: Configuration,\n payload: Payload,\n context: PbImportExportContext\n): Promise<Response> => {\n const log = console.log;\n\n const { pageBuilder } = context;\n const { task, type, zipFileUrl, identity } = payload;\n try {\n log(\"RUNNING Import Blocks Create\");\n if (!zipFileUrl) {\n return {\n data: null,\n error: {\n message: `Missing \"zipFileUrl\"!`\n }\n };\n }\n mockSecurity(identity, context);\n // Step 1: Read the zip file\n const blockImportDataList = await extractAndUploadZipFileContents(zipFileUrl);\n\n // For each block create a subtask and invoke the process handler\n for (let i = 0; i < blockImportDataList.length; i++) {\n const blocksDirMap = blockImportDataList[i];\n // Create sub-task\n const subtask = await pageBuilder.importExportTask.createSubTask(\n task.id,\n zeroPad(i + 1, 5),\n {\n status: ImportExportTaskStatus.PENDING,\n data: {\n blockKey: blocksDirMap.key,\n zipFileUrl,\n input: {\n fileUploadsData: blocksDirMap\n }\n }\n }\n );\n log(`Added SUB_TASK \"${subtask.id}\" to queue.`);\n }\n // Update main task status\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.PROCESSING,\n stats: initialStats(blockImportDataList.length)\n });\n\n await invokeHandlerClient<ProcessPayload>({\n context,\n name: configuration.handlers.process,\n payload: {\n taskId: task.id,\n // Execute \"Process\" for the first sub-task.\n subTaskIndex: 1,\n type,\n identity: context.security.getIdentity()\n },\n description: \"Import blocks - process - first\"\n });\n } catch (e) {\n log(\"[IMPORT_BLOCKS_CREATE] Error => \", e);\n\n /**\n * In case of error, we'll update the task status to \"failed\",\n * so that, client can show notify the user appropriately.\n */\n\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.FAILED,\n error: {\n name: e.name,\n message: e.message,\n code: e.code || \"EXPORT_FAILED\"\n }\n });\n\n return {\n data: null,\n error: {\n message: e.message\n }\n };\n }\n\n return {\n data: \"\",\n error: null\n };\n};\n"],"mappings":"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"}
1
+ {"version":3,"names":["_types","require","_utils","_client","_mockSecurity","_utils2","_extractAndUploadZipFileContents","blocksHandler","configuration","payload","context","log","console","pageBuilder","task","type","zipFileUrl","identity","data","error","message","mockSecurity","blockImportDataList","extractAndUploadZipFileContents","i","length","blocksDirMap","subtask","importExportTask","createSubTask","id","zeroPad","status","ImportExportTaskStatus","PENDING","blockKey","key","input","fileUploadsData","updateTask","PROCESSING","stats","initialStats","invokeHandlerClient","name","handlers","process","taskId","subTaskIndex","security","getIdentity","description","e","FAILED","code","exports"],"sources":["blocksHandler.ts"],"sourcesContent":["import type { PbImportExportContext } from \"~/types\";\nimport { ImportExportTaskStatus } from \"~/types\";\nimport { initialStats } from \"~/import/utils\";\nimport { invokeHandlerClient } from \"~/client\";\nimport type { Payload as ProcessPayload } from \"../process\";\nimport { mockSecurity } from \"~/mockSecurity\";\nimport { zeroPad } from \"@webiny/utils\";\nimport type { Configuration, Payload, Response } from \"~/import/create\";\nimport { extractAndUploadZipFileContents } from \"~/import/utils/extractAndUploadZipFileContents\";\n\nexport const blocksHandler = async (\n configuration: Configuration,\n payload: Payload,\n context: PbImportExportContext\n): Promise<Response> => {\n const log = console.log;\n\n const { pageBuilder } = context;\n const { task, type, zipFileUrl, identity } = payload;\n try {\n log(\"RUNNING Import Blocks Create\");\n if (!zipFileUrl) {\n return {\n data: null,\n error: {\n message: `Missing \"zipFileUrl\"!`\n }\n };\n }\n mockSecurity(identity, context);\n // Step 1: Read the zip file\n const blockImportDataList = await extractAndUploadZipFileContents(zipFileUrl);\n\n // For each block create a subtask and invoke the process handler\n for (let i = 0; i < blockImportDataList.length; i++) {\n const blocksDirMap = blockImportDataList[i];\n // Create sub-task\n const subtask = await pageBuilder.importExportTask.createSubTask(\n task.id,\n zeroPad(i + 1, 5),\n {\n status: ImportExportTaskStatus.PENDING,\n data: {\n blockKey: blocksDirMap.key,\n zipFileUrl,\n input: {\n fileUploadsData: blocksDirMap\n }\n }\n }\n );\n log(`Added SUB_TASK \"${subtask.id}\" to queue.`);\n }\n // Update main task status\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.PROCESSING,\n stats: initialStats(blockImportDataList.length)\n });\n\n await invokeHandlerClient<ProcessPayload>({\n context,\n name: configuration.handlers.process,\n payload: {\n taskId: task.id,\n // Execute \"Process\" for the first sub-task.\n subTaskIndex: 1,\n type,\n identity: context.security.getIdentity()\n },\n description: \"Import blocks - process - first\"\n });\n } catch (e) {\n log(\"[IMPORT_BLOCKS_CREATE] Error => \", e);\n\n /**\n * In case of error, we'll update the task status to \"failed\",\n * so that, client can show notify the user appropriately.\n */\n\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.FAILED,\n error: {\n name: e.name,\n message: e.message,\n code: e.code || \"EXPORT_FAILED\"\n }\n });\n\n return {\n data: null,\n error: {\n message: e.message\n }\n };\n }\n\n return {\n data: \"\",\n error: null\n };\n};\n"],"mappings":"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","ignoreList":[]}
@@ -1,3 +1,3 @@
1
- import { PbImportExportContext } from "../../types";
2
- import { Configuration, Payload, Response } from ".";
1
+ import type { PbImportExportContext } from "../../types";
2
+ import type { Configuration, Payload, Response } from "./";
3
3
  export declare const formsHandler: (configuration: Configuration, payload: Payload, context: PbImportExportContext) => Promise<Response>;
@@ -1 +1 @@
1
- {"version":3,"names":["_types","require","_utils","_client","_mockSecurity","_utils2","_extractAndUploadZipFileContents","formsHandler","configuration","payload","context","log","console","pageBuilder","task","type","category","zipFileUrl","identity","meta","data","error","message","mockSecurity","formImportDataList","extractAndUploadZipFileContents","i","length","formsDirMap","subtask","importExportTask","createSubTask","id","zeroPad","status","ImportExportTaskStatus","PENDING","formKey","key","input","fileUploadsData","updateTask","PROCESSING","stats","initialStats","invokeHandlerClient","name","handlers","process","taskId","subTaskIndex","security","getIdentity","description","e","FAILED","code","exports"],"sources":["formsHandler.ts"],"sourcesContent":["import { ImportExportTaskStatus, PbImportExportContext } from \"~/types\";\nimport { initialStats } from \"~/import/utils\";\nimport { invokeHandlerClient } from \"~/client\";\nimport { Payload as ProcessPayload } from \"../process\";\nimport { mockSecurity } from \"~/mockSecurity\";\nimport { zeroPad } from \"@webiny/utils\";\nimport { Configuration, Payload, Response } from \"~/import/create\";\nimport { extractAndUploadZipFileContents } from \"~/import/utils/extractAndUploadZipFileContents\";\n\nexport const formsHandler = async (\n configuration: Configuration,\n payload: Payload,\n context: PbImportExportContext\n): Promise<Response> => {\n const log = console.log;\n\n const { pageBuilder } = context;\n const { task, type, category, zipFileUrl, identity, meta } = payload;\n try {\n log(\"RUNNING Import Forms Create\");\n if (!zipFileUrl) {\n return {\n data: null,\n error: {\n message: `Missing \"zipFileUrl\"!`\n }\n };\n }\n mockSecurity(identity, context);\n // Step 1: Read the zip file\n const formImportDataList = await extractAndUploadZipFileContents(zipFileUrl);\n\n // For each form create a subtask and invoke the process handler\n for (let i = 0; i < formImportDataList.length; i++) {\n const formsDirMap = formImportDataList[i];\n // Create sub-task\n const subtask = await pageBuilder.importExportTask.createSubTask(\n task.id,\n zeroPad(i + 1, 5),\n {\n status: ImportExportTaskStatus.PENDING,\n data: {\n formKey: formsDirMap.key,\n category,\n zipFileUrl,\n meta,\n input: {\n fileUploadsData: formsDirMap\n }\n }\n }\n );\n log(`Added SUB_TASK \"${subtask.id}\" to queue.`);\n }\n // Update main task status\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.PROCESSING,\n stats: initialStats(formImportDataList.length)\n });\n\n await invokeHandlerClient<ProcessPayload>({\n context,\n name: configuration.handlers.process,\n payload: {\n taskId: task.id,\n // Execute \"Process\" for the first sub task.\n subTaskIndex: 1,\n type,\n identity: context.security.getIdentity()\n },\n description: \"Import forms - process - first\"\n });\n } catch (e) {\n log(\"[IMPORT_FORMS_CREATE] Error => \", e);\n\n /**\n * In case of error, we'll update the task status to \"failed\",\n * so that, client can show notify the user appropriately.\n */\n\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.FAILED,\n error: {\n name: e.name,\n message: e.message,\n code: e.code || \"EXPORT_FAILED\"\n }\n });\n\n return {\n data: null,\n error: {\n message: e.message\n }\n };\n }\n\n return {\n data: \"\",\n error: null\n };\n};\n"],"mappings":"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"}
1
+ {"version":3,"names":["_types","require","_utils","_client","_mockSecurity","_utils2","_extractAndUploadZipFileContents","formsHandler","configuration","payload","context","log","console","pageBuilder","task","type","category","zipFileUrl","identity","meta","data","error","message","mockSecurity","formImportDataList","extractAndUploadZipFileContents","i","length","formsDirMap","subtask","importExportTask","createSubTask","id","zeroPad","status","ImportExportTaskStatus","PENDING","formKey","key","input","fileUploadsData","updateTask","PROCESSING","stats","initialStats","invokeHandlerClient","name","handlers","process","taskId","subTaskIndex","security","getIdentity","description","e","FAILED","code","exports"],"sources":["formsHandler.ts"],"sourcesContent":["import type { PbImportExportContext } from \"~/types\";\nimport { ImportExportTaskStatus } from \"~/types\";\nimport { initialStats } from \"~/import/utils\";\nimport { invokeHandlerClient } from \"~/client\";\nimport type { Payload as ProcessPayload } from \"../process\";\nimport { mockSecurity } from \"~/mockSecurity\";\nimport { zeroPad } from \"@webiny/utils\";\nimport type { Configuration, Payload, Response } from \"~/import/create\";\nimport { extractAndUploadZipFileContents } from \"~/import/utils/extractAndUploadZipFileContents\";\n\nexport const formsHandler = async (\n configuration: Configuration,\n payload: Payload,\n context: PbImportExportContext\n): Promise<Response> => {\n const log = console.log;\n\n const { pageBuilder } = context;\n const { task, type, category, zipFileUrl, identity, meta } = payload;\n try {\n log(\"RUNNING Import Forms Create\");\n if (!zipFileUrl) {\n return {\n data: null,\n error: {\n message: `Missing \"zipFileUrl\"!`\n }\n };\n }\n mockSecurity(identity, context);\n // Step 1: Read the zip file\n const formImportDataList = await extractAndUploadZipFileContents(zipFileUrl);\n\n // For each form create a subtask and invoke the process handler\n for (let i = 0; i < formImportDataList.length; i++) {\n const formsDirMap = formImportDataList[i];\n // Create sub-task\n const subtask = await pageBuilder.importExportTask.createSubTask(\n task.id,\n zeroPad(i + 1, 5),\n {\n status: ImportExportTaskStatus.PENDING,\n data: {\n formKey: formsDirMap.key,\n category,\n zipFileUrl,\n meta,\n input: {\n fileUploadsData: formsDirMap\n }\n }\n }\n );\n log(`Added SUB_TASK \"${subtask.id}\" to queue.`);\n }\n // Update main task status\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.PROCESSING,\n stats: initialStats(formImportDataList.length)\n });\n\n await invokeHandlerClient<ProcessPayload>({\n context,\n name: configuration.handlers.process,\n payload: {\n taskId: task.id,\n // Execute \"Process\" for the first sub task.\n subTaskIndex: 1,\n type,\n identity: context.security.getIdentity()\n },\n description: \"Import forms - process - first\"\n });\n } catch (e) {\n log(\"[IMPORT_FORMS_CREATE] Error => \", e);\n\n /**\n * In case of error, we'll update the task status to \"failed\",\n * so that, client can show notify the user appropriately.\n */\n\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.FAILED,\n error: {\n name: e.name,\n message: e.message,\n code: e.code || \"EXPORT_FAILED\"\n }\n });\n\n return {\n data: null,\n error: {\n message: e.message\n }\n };\n }\n\n return {\n data: \"\",\n error: null\n };\n};\n"],"mappings":"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","ignoreList":[]}
@@ -1,5 +1,5 @@
1
- import { ImportExportTask, PbImportExportContext } from "../../types";
2
- import { SecurityIdentity } from "@webiny/api-security/types";
1
+ import type { ImportExportTask, PbImportExportContext } from "../../types";
2
+ import type { SecurityIdentity } from "@webiny/api-security/types";
3
3
  export interface Configuration {
4
4
  handlers: {
5
5
  process: string;
@@ -7,7 +7,6 @@ exports.default = void 0;
7
7
  var _handlerAws = require("@webiny/handler-aws");
8
8
  var _blocksHandler = require("./blocksHandler");
9
9
  var _formsHandler = require("./formsHandler");
10
- var _pagesHandler = require("./pagesHandler");
11
10
  var _templatesHandler = require("./templatesHandler");
12
11
  /**
13
12
  * Handles the import page workflow.
@@ -33,7 +32,8 @@ var _default = configuration => {
33
32
  }
34
33
  default:
35
34
  {
36
- return (0, _pagesHandler.pagesHandler)(configuration, payload, context);
35
+ console.error("Import PB", JSON.stringify(payload));
36
+ throw new Error("Invalid type provided: pb page.");
37
37
  }
38
38
  }
39
39
  });
@@ -1 +1 @@
1
- {"version":3,"names":["_handlerAws","require","_blocksHandler","_formsHandler","_pagesHandler","_templatesHandler","_default","configuration","createRawEventHandler","payload","context","security","withoutAuthorization","type","blocksHandler","formsHandler","templatesHandler","pagesHandler","exports","default"],"sources":["index.ts"],"sourcesContent":["import { ImportExportTask, PbImportExportContext } from \"~/types\";\nimport { SecurityIdentity } from \"@webiny/api-security/types\";\nimport { createRawEventHandler } from \"@webiny/handler-aws\";\nimport { blocksHandler } from \"~/import/create/blocksHandler\";\nimport { formsHandler } from \"~/import/create/formsHandler\";\nimport { pagesHandler } from \"~/import/create/pagesHandler\";\nimport { templatesHandler } from \"~/import/create/templatesHandler\";\n\nexport interface Configuration {\n handlers: {\n process: string;\n };\n}\n\nexport interface Payload {\n category?: string;\n zipFileUrl: string;\n task: ImportExportTask;\n type: string;\n identity: SecurityIdentity;\n meta?: Record<string, any>;\n}\nexport interface Response {\n data: string | null;\n error: Partial<Error> | null;\n}\n\n/**\n * Handles the import page workflow.\n */\nexport default (configuration: Configuration) => {\n return createRawEventHandler<Payload, PbImportExportContext, Response>(\n async ({ payload, context }) => {\n return context.security.withoutAuthorization(() => {\n switch (payload.type) {\n case \"block\": {\n return blocksHandler(configuration, payload, context);\n }\n case \"form\": {\n return formsHandler(configuration, payload, context);\n }\n case \"template\": {\n return templatesHandler(configuration, payload, context);\n }\n default: {\n return pagesHandler(configuration, payload, context);\n }\n }\n });\n }\n );\n};\n"],"mappings":";;;;;;AAEA,IAAAA,WAAA,GAAAC,OAAA;AACA,IAAAC,cAAA,GAAAD,OAAA;AACA,IAAAE,aAAA,GAAAF,OAAA;AACA,IAAAG,aAAA,GAAAH,OAAA;AACA,IAAAI,iBAAA,GAAAJ,OAAA;AAqBA;AACA;AACA;AAFA,IAAAK,QAAA,GAGgBC,aAA4B,IAAK;EAC7C,OAAO,IAAAC,iCAAqB,EACxB,OAAO;IAAEC,OAAO;IAAEC;EAAQ,CAAC,KAAK;IAC5B,OAAOA,OAAO,CAACC,QAAQ,CAACC,oBAAoB,CAAC,MAAM;MAC/C,QAAQH,OAAO,CAACI,IAAI;QAChB,KAAK,OAAO;UAAE;YACV,OAAO,IAAAC,4BAAa,EAACP,aAAa,EAAEE,OAAO,EAAEC,OAAO,CAAC;UACzD;QACA,KAAK,MAAM;UAAE;YACT,OAAO,IAAAK,0BAAY,EAACR,aAAa,EAAEE,OAAO,EAAEC,OAAO,CAAC;UACxD;QACA,KAAK,UAAU;UAAE;YACb,OAAO,IAAAM,kCAAgB,EAACT,aAAa,EAAEE,OAAO,EAAEC,OAAO,CAAC;UAC5D;QACA;UAAS;YACL,OAAO,IAAAO,0BAAY,EAACV,aAAa,EAAEE,OAAO,EAAEC,OAAO,CAAC;UACxD;MACJ;IACJ,CAAC,CAAC;EACN,CACJ,CAAC;AACL,CAAC;AAAAQ,OAAA,CAAAC,OAAA,GAAAb,QAAA"}
1
+ {"version":3,"names":["_handlerAws","require","_blocksHandler","_formsHandler","_templatesHandler","_default","configuration","createRawEventHandler","payload","context","security","withoutAuthorization","type","blocksHandler","formsHandler","templatesHandler","console","error","JSON","stringify","Error","exports","default"],"sources":["index.ts"],"sourcesContent":["import type { ImportExportTask, PbImportExportContext } from \"~/types\";\nimport type { SecurityIdentity } from \"@webiny/api-security/types\";\nimport { createRawEventHandler } from \"@webiny/handler-aws\";\nimport { blocksHandler } from \"~/import/create/blocksHandler\";\nimport { formsHandler } from \"~/import/create/formsHandler\";\nimport { templatesHandler } from \"~/import/create/templatesHandler\";\n\nexport interface Configuration {\n handlers: {\n process: string;\n };\n}\n\nexport interface Payload {\n category?: string;\n zipFileUrl: string;\n task: ImportExportTask;\n type: string;\n identity: SecurityIdentity;\n meta?: Record<string, any>;\n}\nexport interface Response {\n data: string | null;\n error: Partial<Error> | null;\n}\n\n/**\n * Handles the import page workflow.\n */\nexport default (configuration: Configuration) => {\n return createRawEventHandler<Payload, PbImportExportContext, Response>(\n async ({ payload, context }) => {\n return context.security.withoutAuthorization(() => {\n switch (payload.type) {\n case \"block\": {\n return blocksHandler(configuration, payload, context);\n }\n case \"form\": {\n return formsHandler(configuration, payload, context);\n }\n case \"template\": {\n return templatesHandler(configuration, payload, context);\n }\n default: {\n console.error(\"Import PB\", JSON.stringify(payload));\n throw new Error(\"Invalid type provided: pb page.\");\n }\n }\n });\n }\n );\n};\n"],"mappings":";;;;;;AAEA,IAAAA,WAAA,GAAAC,OAAA;AACA,IAAAC,cAAA,GAAAD,OAAA;AACA,IAAAE,aAAA,GAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAH,OAAA;AAqBA;AACA;AACA;AAFA,IAAAI,QAAA,GAGgBC,aAA4B,IAAK;EAC7C,OAAO,IAAAC,iCAAqB,EACxB,OAAO;IAAEC,OAAO;IAAEC;EAAQ,CAAC,KAAK;IAC5B,OAAOA,OAAO,CAACC,QAAQ,CAACC,oBAAoB,CAAC,MAAM;MAC/C,QAAQH,OAAO,CAACI,IAAI;QAChB,KAAK,OAAO;UAAE;YACV,OAAO,IAAAC,4BAAa,EAACP,aAAa,EAAEE,OAAO,EAAEC,OAAO,CAAC;UACzD;QACA,KAAK,MAAM;UAAE;YACT,OAAO,IAAAK,0BAAY,EAACR,aAAa,EAAEE,OAAO,EAAEC,OAAO,CAAC;UACxD;QACA,KAAK,UAAU;UAAE;YACb,OAAO,IAAAM,kCAAgB,EAACT,aAAa,EAAEE,OAAO,EAAEC,OAAO,CAAC;UAC5D;QACA;UAAS;YACLO,OAAO,CAACC,KAAK,CAAC,WAAW,EAAEC,IAAI,CAACC,SAAS,CAACX,OAAO,CAAC,CAAC;YACnD,MAAM,IAAIY,KAAK,CAAC,iCAAiC,CAAC;UACtD;MACJ;IACJ,CAAC,CAAC;EACN,CACJ,CAAC;AACL,CAAC;AAAAC,OAAA,CAAAC,OAAA,GAAAjB,QAAA","ignoreList":[]}
@@ -1,3 +1,3 @@
1
- import { PbImportExportContext } from "../../types";
2
- import { Configuration, Payload, Response } from ".";
1
+ import type { PbImportExportContext } from "../../types";
2
+ import type { Configuration, Payload, Response } from "./";
3
3
  export declare const pagesHandler: (configuration: Configuration, payload: Payload, context: PbImportExportContext) => Promise<Response>;
@@ -1 +1 @@
1
- {"version":3,"names":["_types","require","_utils","_client","_mockSecurity","_utils2","_extractAndUploadZipFileContents","pagesHandler","configuration","payload","context","log","console","pageBuilder","task","type","category","zipFileUrl","identity","meta","data","error","message","mockSecurity","pageImportDataList","extractAndUploadZipFileContents","i","length","pagesDirMap","subtask","importExportTask","createSubTask","id","zeroPad","status","ImportExportTaskStatus","PENDING","pageKey","key","input","fileUploadsData","updateTask","PROCESSING","stats","initialStats","invokeHandlerClient","name","handlers","process","taskId","subTaskIndex","security","getIdentity","description","e","FAILED","code","exports"],"sources":["pagesHandler.ts"],"sourcesContent":["import { ImportExportTaskStatus, PbImportExportContext } from \"~/types\";\nimport { initialStats } from \"~/import/utils\";\nimport { invokeHandlerClient } from \"~/client\";\nimport { Payload as ProcessPayload } from \"../process\";\nimport { mockSecurity } from \"~/mockSecurity\";\nimport { zeroPad } from \"@webiny/utils\";\nimport { Configuration, Payload, Response } from \"~/import/create\";\nimport { extractAndUploadZipFileContents } from \"~/import/utils/extractAndUploadZipFileContents\";\n\nexport const pagesHandler = async (\n configuration: Configuration,\n payload: Payload,\n context: PbImportExportContext\n): Promise<Response> => {\n const log = console.log;\n\n const { pageBuilder } = context;\n const { task, type, category, zipFileUrl, identity, meta } = payload;\n try {\n log(\"RUNNING Import Pages Create\");\n if (!zipFileUrl) {\n return {\n data: null,\n error: {\n message: `Missing \"zipFileUrl\"!`\n }\n };\n }\n mockSecurity(identity, context);\n // Step 1: Read the zip file\n const pageImportDataList = await extractAndUploadZipFileContents(zipFileUrl);\n\n // For each page create a subtask and invoke the process handler\n for (let i = 0; i < pageImportDataList.length; i++) {\n const pagesDirMap = pageImportDataList[i];\n // Create sub-task\n const subtask = await pageBuilder.importExportTask.createSubTask(\n task.id,\n zeroPad(i + 1, 5),\n {\n status: ImportExportTaskStatus.PENDING,\n data: {\n pageKey: pagesDirMap.key,\n category,\n zipFileUrl,\n meta,\n input: {\n fileUploadsData: pagesDirMap\n }\n }\n }\n );\n log(`Added SUB_TASK \"${subtask.id}\" to queue.`);\n }\n // Update main task status\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.PROCESSING,\n stats: initialStats(pageImportDataList.length)\n });\n\n await invokeHandlerClient<ProcessPayload>({\n context,\n name: configuration.handlers.process,\n payload: {\n taskId: task.id,\n // Execute \"Process\" for the first sub task.\n subTaskIndex: 1,\n type,\n identity: context.security.getIdentity()\n },\n description: \"Import pages - process - first\"\n });\n } catch (e) {\n log(\"[IMPORT_PAGES_CREATE] Error => \", e);\n\n /**\n * In case of error, we'll update the task status to \"failed\",\n * so that, client can show notify the user appropriately.\n */\n\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.FAILED,\n error: {\n name: e.name,\n message: e.message,\n code: e.code || \"EXPORT_FAILED\"\n }\n });\n\n return {\n data: null,\n error: {\n message: e.message\n }\n };\n }\n\n return {\n data: \"\",\n error: null\n };\n};\n"],"mappings":"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"}
1
+ {"version":3,"names":["_types","require","_utils","_client","_mockSecurity","_utils2","_extractAndUploadZipFileContents","pagesHandler","configuration","payload","context","log","console","pageBuilder","task","type","category","zipFileUrl","identity","meta","data","error","message","mockSecurity","pageImportDataList","extractAndUploadZipFileContents","i","length","pagesDirMap","subtask","importExportTask","createSubTask","id","zeroPad","status","ImportExportTaskStatus","PENDING","pageKey","key","input","fileUploadsData","updateTask","PROCESSING","stats","initialStats","invokeHandlerClient","name","handlers","process","taskId","subTaskIndex","security","getIdentity","description","e","FAILED","code","exports"],"sources":["pagesHandler.ts"],"sourcesContent":["import type { PbImportExportContext } from \"~/types\";\nimport { ImportExportTaskStatus } from \"~/types\";\nimport { initialStats } from \"~/import/utils\";\nimport { invokeHandlerClient } from \"~/client\";\nimport type { Payload as ProcessPayload } from \"../process\";\nimport { mockSecurity } from \"~/mockSecurity\";\nimport { zeroPad } from \"@webiny/utils\";\nimport type { Configuration, Payload, Response } from \"~/import/create\";\nimport { extractAndUploadZipFileContents } from \"~/import/utils/extractAndUploadZipFileContents\";\n\nexport const pagesHandler = async (\n configuration: Configuration,\n payload: Payload,\n context: PbImportExportContext\n): Promise<Response> => {\n const log = console.log;\n\n const { pageBuilder } = context;\n const { task, type, category, zipFileUrl, identity, meta } = payload;\n try {\n log(\"RUNNING Import Pages Create\");\n if (!zipFileUrl) {\n return {\n data: null,\n error: {\n message: `Missing \"zipFileUrl\"!`\n }\n };\n }\n mockSecurity(identity, context);\n // Step 1: Read the zip file\n const pageImportDataList = await extractAndUploadZipFileContents(zipFileUrl);\n\n // For each page create a subtask and invoke the process handler\n for (let i = 0; i < pageImportDataList.length; i++) {\n const pagesDirMap = pageImportDataList[i];\n // Create sub-task\n const subtask = await pageBuilder.importExportTask.createSubTask(\n task.id,\n zeroPad(i + 1, 5),\n {\n status: ImportExportTaskStatus.PENDING,\n data: {\n pageKey: pagesDirMap.key,\n category,\n zipFileUrl,\n meta,\n input: {\n fileUploadsData: pagesDirMap\n }\n }\n }\n );\n log(`Added SUB_TASK \"${subtask.id}\" to queue.`);\n }\n // Update main task status\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.PROCESSING,\n stats: initialStats(pageImportDataList.length)\n });\n\n await invokeHandlerClient<ProcessPayload>({\n context,\n name: configuration.handlers.process,\n payload: {\n taskId: task.id,\n // Execute \"Process\" for the first sub task.\n subTaskIndex: 1,\n type,\n identity: context.security.getIdentity()\n },\n description: \"Import pages - process - first\"\n });\n } catch (e) {\n log(\"[IMPORT_PAGES_CREATE] Error => \", e);\n\n /**\n * In case of error, we'll update the task status to \"failed\",\n * so that, client can show notify the user appropriately.\n */\n\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.FAILED,\n error: {\n name: e.name,\n message: e.message,\n code: e.code || \"EXPORT_FAILED\"\n }\n });\n\n return {\n data: null,\n error: {\n message: e.message\n }\n };\n }\n\n return {\n data: \"\",\n error: null\n };\n};\n"],"mappings":"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","ignoreList":[]}
@@ -1,3 +1,3 @@
1
- import { PbImportExportContext } from "../../types";
2
- import { Configuration, Payload, Response } from ".";
1
+ import type { PbImportExportContext } from "../../types";
2
+ import type { Configuration, Payload, Response } from "./";
3
3
  export declare const templatesHandler: (configuration: Configuration, payload: Payload, context: PbImportExportContext) => Promise<Response>;
@@ -1 +1 @@
1
- {"version":3,"names":["_types","require","_utils","_client","_mockSecurity","_utils2","_extractAndUploadZipFileContents","templatesHandler","configuration","payload","context","log","console","pageBuilder","task","type","zipFileUrl","identity","data","error","message","mockSecurity","templateImportDataList","extractAndUploadZipFileContents","i","length","templatesDirMap","subtask","importExportTask","createSubTask","id","zeroPad","status","ImportExportTaskStatus","PENDING","templateKey","key","input","fileUploadsData","updateTask","PROCESSING","stats","initialStats","invokeHandlerClient","name","handlers","process","taskId","subTaskIndex","security","getIdentity","description","e","FAILED","code","exports"],"sources":["templatesHandler.ts"],"sourcesContent":["import { ImportExportTaskStatus, PbImportExportContext } from \"~/types\";\nimport { initialStats } from \"~/import/utils\";\nimport { invokeHandlerClient } from \"~/client\";\nimport { Payload as ProcessPayload } from \"../process\";\nimport { mockSecurity } from \"~/mockSecurity\";\nimport { zeroPad } from \"@webiny/utils\";\nimport { Configuration, Payload, Response } from \"~/import/create\";\nimport { extractAndUploadZipFileContents } from \"~/import/utils/extractAndUploadZipFileContents\";\n\nexport const templatesHandler = async (\n configuration: Configuration,\n payload: Payload,\n context: PbImportExportContext\n): Promise<Response> => {\n const log = console.log;\n\n const { pageBuilder } = context;\n const { task, type, zipFileUrl, identity } = payload;\n try {\n log(\"RUNNING Import Templates Create\");\n if (!zipFileUrl) {\n return {\n data: null,\n error: {\n message: `Missing \"zipFileUrl\"!`\n }\n };\n }\n mockSecurity(identity, context);\n // Step 1: Read the zip file\n const templateImportDataList = await extractAndUploadZipFileContents(zipFileUrl);\n\n // For each template create a subtask and invoke the process handler\n for (let i = 0; i < templateImportDataList.length; i++) {\n const templatesDirMap = templateImportDataList[i];\n // Create sub task\n const subtask = await pageBuilder.importExportTask.createSubTask(\n task.id,\n zeroPad(i + 1, 5),\n {\n status: ImportExportTaskStatus.PENDING,\n data: {\n templateKey: templatesDirMap.key,\n zipFileUrl,\n input: {\n fileUploadsData: templatesDirMap\n }\n }\n }\n );\n log(`Added SUB_TASK \"${subtask.id}\" to queue.`);\n }\n // Update main task status\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.PROCESSING,\n stats: initialStats(templateImportDataList.length)\n });\n\n await invokeHandlerClient<ProcessPayload>({\n context,\n name: configuration.handlers.process,\n payload: {\n taskId: task.id,\n // Execute \"Process\" for the first sub task.\n subTaskIndex: 1,\n type,\n identity: context.security.getIdentity()\n },\n description: \"Import templates - process - first\"\n });\n } catch (e) {\n log(\"[IMPORT_TEMPLATES_CREATE] Error => \", e);\n\n /**\n * In case of error, we'll update the task status to \"failed\",\n * so that, client can show notify the user appropriately.\n */\n\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.FAILED,\n error: {\n name: e.name,\n message: e.message,\n code: e.code || \"EXPORT_FAILED\"\n }\n });\n\n return {\n data: null,\n error: {\n message: e.message\n }\n };\n }\n\n return {\n data: \"\",\n error: null\n };\n};\n"],"mappings":"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"}
1
+ {"version":3,"names":["_types","require","_utils","_client","_mockSecurity","_utils2","_extractAndUploadZipFileContents","templatesHandler","configuration","payload","context","log","console","pageBuilder","task","type","zipFileUrl","identity","data","error","message","mockSecurity","templateImportDataList","extractAndUploadZipFileContents","i","length","templatesDirMap","subtask","importExportTask","createSubTask","id","zeroPad","status","ImportExportTaskStatus","PENDING","templateKey","key","input","fileUploadsData","updateTask","PROCESSING","stats","initialStats","invokeHandlerClient","name","handlers","process","taskId","subTaskIndex","security","getIdentity","description","e","FAILED","code","exports"],"sources":["templatesHandler.ts"],"sourcesContent":["import type { PbImportExportContext } from \"~/types\";\nimport { ImportExportTaskStatus } from \"~/types\";\nimport { initialStats } from \"~/import/utils\";\nimport { invokeHandlerClient } from \"~/client\";\nimport type { Payload as ProcessPayload } from \"../process\";\nimport { mockSecurity } from \"~/mockSecurity\";\nimport { zeroPad } from \"@webiny/utils\";\nimport type { Configuration, Payload, Response } from \"~/import/create\";\nimport { extractAndUploadZipFileContents } from \"~/import/utils/extractAndUploadZipFileContents\";\n\nexport const templatesHandler = async (\n configuration: Configuration,\n payload: Payload,\n context: PbImportExportContext\n): Promise<Response> => {\n const log = console.log;\n\n const { pageBuilder } = context;\n const { task, type, zipFileUrl, identity } = payload;\n try {\n log(\"RUNNING Import Templates Create\");\n if (!zipFileUrl) {\n return {\n data: null,\n error: {\n message: `Missing \"zipFileUrl\"!`\n }\n };\n }\n mockSecurity(identity, context);\n // Step 1: Read the zip file\n const templateImportDataList = await extractAndUploadZipFileContents(zipFileUrl);\n\n // For each template create a subtask and invoke the process handler\n for (let i = 0; i < templateImportDataList.length; i++) {\n const templatesDirMap = templateImportDataList[i];\n // Create sub task\n const subtask = await pageBuilder.importExportTask.createSubTask(\n task.id,\n zeroPad(i + 1, 5),\n {\n status: ImportExportTaskStatus.PENDING,\n data: {\n templateKey: templatesDirMap.key,\n zipFileUrl,\n input: {\n fileUploadsData: templatesDirMap\n }\n }\n }\n );\n log(`Added SUB_TASK \"${subtask.id}\" to queue.`);\n }\n // Update main task status\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.PROCESSING,\n stats: initialStats(templateImportDataList.length)\n });\n\n await invokeHandlerClient<ProcessPayload>({\n context,\n name: configuration.handlers.process,\n payload: {\n taskId: task.id,\n // Execute \"Process\" for the first sub task.\n subTaskIndex: 1,\n type,\n identity: context.security.getIdentity()\n },\n description: \"Import templates - process - first\"\n });\n } catch (e) {\n log(\"[IMPORT_TEMPLATES_CREATE] Error => \", e);\n\n /**\n * In case of error, we'll update the task status to \"failed\",\n * so that, client can show notify the user appropriately.\n */\n\n await pageBuilder.importExportTask.updateTask(task.id, {\n status: ImportExportTaskStatus.FAILED,\n error: {\n name: e.name,\n message: e.message,\n code: e.code || \"EXPORT_FAILED\"\n }\n });\n\n return {\n data: null,\n error: {\n message: e.message\n }\n };\n }\n\n return {\n data: \"\",\n error: null\n };\n};\n"],"mappings":";;;;;;AACA,IAAAA,MAAA,GAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AACA,IAAAE,OAAA,GAAAF,OAAA;AAEA,IAAAG,aAAA,GAAAH,OAAA;AACA,IAAAI,OAAA,GAAAJ,OAAA;AAEA,IAAAK,gCAAA,GAAAL,OAAA;AAEO,MAAMM,gBAAgB,GAAG,MAAAA,CAC5BC,aAA4B,EAC5BC,OAAgB,EAChBC,OAA8B,KACV;EACpB,MAAMC,GAAG,GAAGC,OAAO,CAACD,GAAG;EAEvB,MAAM;IAAEE;EAAY,CAAC,GAAGH,OAAO;EAC/B,MAAM;IAAEI,IAAI;IAAEC,IAAI;IAAEC,UAAU;IAAEC;EAAS,CAAC,GAAGR,OAAO;EACpD,IAAI;IACAE,GAAG,CAAC,iCAAiC,CAAC;IACtC,IAAI,CAACK,UAAU,EAAE;MACb,OAAO;QACHE,IAAI,EAAE,IAAI;QACVC,KAAK,EAAE;UACHC,OAAO,EAAE;QACb;MACJ,CAAC;IACL;IACA,IAAAC,0BAAY,EAACJ,QAAQ,EAAEP,OAAO,CAAC;IAC/B;IACA,MAAMY,sBAAsB,GAAG,MAAM,IAAAC,gEAA+B,EAACP,UAAU,CAAC;;IAEhF;IACA,KAAK,IAAIQ,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGF,sBAAsB,CAACG,MAAM,EAAED,CAAC,EAAE,EAAE;MACpD,MAAME,eAAe,GAAGJ,sBAAsB,CAACE,CAAC,CAAC;MACjD;MACA,MAAMG,OAAO,GAAG,MAAMd,WAAW,CAACe,gBAAgB,CAACC,aAAa,CAC5Df,IAAI,CAACgB,EAAE,EACP,IAAAC,eAAO,EAACP,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,EACjB;QACIQ,MAAM,EAAEC,6BAAsB,CAACC,OAAO;QACtChB,IAAI,EAAE;UACFiB,WAAW,EAAET,eAAe,CAACU,GAAG;UAChCpB,UAAU;UACVqB,KAAK,EAAE;YACHC,eAAe,EAAEZ;UACrB;QACJ;MACJ,CACJ,CAAC;MACDf,GAAG,CAAC,mBAAmBgB,OAAO,CAACG,EAAE,aAAa,CAAC;IACnD;IACA;IACA,MAAMjB,WAAW,CAACe,gBAAgB,CAACW,UAAU,CAACzB,IAAI,CAACgB,EAAE,EAAE;MACnDE,MAAM,EAAEC,6BAAsB,CAACO,UAAU;MACzCC,KAAK,EAAE,IAAAC,mBAAY,EAACpB,sBAAsB,CAACG,MAAM;IACrD,CAAC,CAAC;IAEF,MAAM,IAAAkB,2BAAmB,EAAiB;MACtCjC,OAAO;MACPkC,IAAI,EAAEpC,aAAa,CAACqC,QAAQ,CAACC,OAAO;MACpCrC,OAAO,EAAE;QACLsC,MAAM,EAAEjC,IAAI,CAACgB,EAAE;QACf;QACAkB,YAAY,EAAE,CAAC;QACfjC,IAAI;QACJE,QAAQ,EAAEP,OAAO,CAACuC,QAAQ,CAACC,WAAW,CAAC;MAC3C,CAAC;MACDC,WAAW,EAAE;IACjB,CAAC,CAAC;EACN,CAAC,CAAC,OAAOC,CAAC,EAAE;IACRzC,GAAG,CAAC,qCAAqC,EAAEyC,CAAC,CAAC;;IAE7C;AACR;AACA;AACA;;IAEQ,MAAMvC,WAAW,CAACe,gBAAgB,CAACW,UAAU,CAACzB,IAAI,CAACgB,EAAE,EAAE;MACnDE,MAAM,EAAEC,6BAAsB,CAACoB,MAAM;MACrClC,KAAK,EAAE;QACHyB,IAAI,EAAEQ,CAAC,CAACR,IAAI;QACZxB,OAAO,EAAEgC,CAAC,CAAChC,OAAO;QAClBkC,IAAI,EAAEF,CAAC,CAACE,IAAI,IAAI;MACpB;IACJ,CAAC,CAAC;IAEF,OAAO;MACHpC,IAAI,EAAE,IAAI;MACVC,KAAK,EAAE;QACHC,OAAO,EAAEgC,CAAC,CAAChC;MACf;IACJ,CAAC;EACL;EAEA,OAAO;IACHF,IAAI,EAAE,EAAE;IACRC,KAAK,EAAE;EACX,CAAC;AACL,CAAC;AAACoC,OAAA,CAAAhD,gBAAA,GAAAA,gBAAA","ignoreList":[]}
@@ -0,0 +1,5 @@
1
+ import type { ITaskResponseResult } from "@webiny/tasks";
2
+ import type { IImportPagesControllerTaskParams } from "./types";
3
+ export declare class ImportPagesController {
4
+ execute(params: IImportPagesControllerTaskParams): Promise<ITaskResponseResult>;
5
+ }
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.ImportPagesController = void 0;
7
+ var _ImportPagesProcessPagesChecker = require("./controller/ImportPagesProcessPagesChecker");
8
+ var _ImportPagesProcessZipFile = require("./controller/ImportPagesProcessZipFile");
9
+ class ImportPagesController {
10
+ async execute(params) {
11
+ const {
12
+ response,
13
+ isAborted,
14
+ input
15
+ } = params;
16
+ if (isAborted()) {
17
+ return response.aborted();
18
+ }
19
+ if (input.processing) {
20
+ const importPagesProcessPagesChecker = new _ImportPagesProcessPagesChecker.ImportPagesProcessPagesChecker();
21
+ return await importPagesProcessPagesChecker.execute(params);
22
+ }
23
+ const importPagesProcessZipFile = new _ImportPagesProcessZipFile.ImportPagesProcessZipFile();
24
+ return importPagesProcessZipFile.execute(params);
25
+ }
26
+ }
27
+ exports.ImportPagesController = ImportPagesController;
28
+
29
+ //# sourceMappingURL=ImportPagesController.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_ImportPagesProcessPagesChecker","require","_ImportPagesProcessZipFile","ImportPagesController","execute","params","response","isAborted","input","aborted","processing","importPagesProcessPagesChecker","ImportPagesProcessPagesChecker","importPagesProcessZipFile","ImportPagesProcessZipFile","exports"],"sources":["ImportPagesController.ts"],"sourcesContent":["import type { ITaskResponseResult } from \"@webiny/tasks\";\nimport { ImportPagesProcessPagesChecker } from \"./controller/ImportPagesProcessPagesChecker\";\nimport { ImportPagesProcessZipFile } from \"./controller/ImportPagesProcessZipFile\";\nimport type { IImportPagesControllerTaskParams } from \"./types\";\n\nexport class ImportPagesController {\n public async execute(params: IImportPagesControllerTaskParams): Promise<ITaskResponseResult> {\n const { response, isAborted, input } = params;\n if (isAborted()) {\n return response.aborted();\n }\n if (input.processing) {\n const importPagesProcessPagesChecker = new ImportPagesProcessPagesChecker();\n\n return await importPagesProcessPagesChecker.execute(params);\n }\n const importPagesProcessZipFile = new ImportPagesProcessZipFile();\n\n return importPagesProcessZipFile.execute(params);\n }\n}\n"],"mappings":";;;;;;AACA,IAAAA,+BAAA,GAAAC,OAAA;AACA,IAAAC,0BAAA,GAAAD,OAAA;AAGO,MAAME,qBAAqB,CAAC;EAC/B,MAAaC,OAAOA,CAACC,MAAwC,EAAgC;IACzF,MAAM;MAAEC,QAAQ;MAAEC,SAAS;MAAEC;IAAM,CAAC,GAAGH,MAAM;IAC7C,IAAIE,SAAS,CAAC,CAAC,EAAE;MACb,OAAOD,QAAQ,CAACG,OAAO,CAAC,CAAC;IAC7B;IACA,IAAID,KAAK,CAACE,UAAU,EAAE;MAClB,MAAMC,8BAA8B,GAAG,IAAIC,8DAA8B,CAAC,CAAC;MAE3E,OAAO,MAAMD,8BAA8B,CAACP,OAAO,CAACC,MAAM,CAAC;IAC/D;IACA,MAAMQ,yBAAyB,GAAG,IAAIC,oDAAyB,CAAC,CAAC;IAEjE,OAAOD,yBAAyB,CAACT,OAAO,CAACC,MAAM,CAAC;EACpD;AACJ;AAACU,OAAA,CAAAZ,qBAAA,GAAAA,qBAAA","ignoreList":[]}
@@ -0,0 +1,6 @@
1
+ import type { ITaskResponseResult } from "@webiny/tasks";
2
+ import type { IImportPagesProcessPagesTaskParams } from "./types";
3
+ export declare class ImportPagesProcessPages {
4
+ execute(params: IImportPagesProcessPagesTaskParams): Promise<ITaskResponseResult>;
5
+ private importPage;
6
+ }
@@ -0,0 +1,112 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.ImportPagesProcessPages = void 0;
7
+ var _importPage = require("./process/importPage");
8
+ var _mockSecurity = require("../../mockSecurity");
9
+ class ImportPagesProcessPages {
10
+ async execute(params) {
11
+ const {
12
+ context,
13
+ response,
14
+ input,
15
+ store,
16
+ isAborted,
17
+ isCloseToTimeout
18
+ } = params;
19
+ const {
20
+ identity,
21
+ items,
22
+ meta,
23
+ category
24
+ } = input;
25
+ const pageIdList = Array.from(input.pageIdList || []);
26
+ const done = Array.from(input.done || []);
27
+ const failed = Array.from(input.failed || []);
28
+ for (const item of items) {
29
+ /**
30
+ * Possibility that a page was already imported in a execution run.
31
+ */
32
+ if (done.includes(item.key) || failed.includes(item.key)) {
33
+ continue;
34
+ } else if (isAborted()) {
35
+ return response.aborted();
36
+ } else if (isCloseToTimeout()) {
37
+ return response.continue({
38
+ ...input,
39
+ pageIdList,
40
+ done,
41
+ failed
42
+ });
43
+ }
44
+ let page;
45
+ try {
46
+ page = await this.importPage({
47
+ context,
48
+ identity,
49
+ item,
50
+ meta,
51
+ category
52
+ });
53
+ pageIdList.push(page.pid);
54
+ done.push(item.key);
55
+ } catch (ex) {
56
+ console.error(ex);
57
+ await store.addErrorLog({
58
+ error: ex,
59
+ message: `Could not import page: ${item.key}.`,
60
+ data: {
61
+ ...item
62
+ }
63
+ });
64
+ failed.push(item.key);
65
+ continue;
66
+ }
67
+ await store.addInfoLog({
68
+ message: `Page "${page.title}" imported successfully.`,
69
+ data: {
70
+ id: page.id,
71
+ title: page.title,
72
+ version: page.version,
73
+ status: page.status
74
+ }
75
+ });
76
+ }
77
+ return response.done({
78
+ done,
79
+ failed,
80
+ pageIdList
81
+ });
82
+ }
83
+ async importPage(params) {
84
+ const {
85
+ context,
86
+ identity,
87
+ item,
88
+ category,
89
+ meta
90
+ } = params;
91
+ (0, _mockSecurity.mockSecurity)(identity, context);
92
+ const page = await (0, _importPage.importPage)({
93
+ context,
94
+ pageKey: item.key,
95
+ fileUploadsData: {
96
+ data: item.data,
97
+ assets: item.assets
98
+ }
99
+ });
100
+ const pbPage = await context.pageBuilder.createPage(category, meta);
101
+ (0, _mockSecurity.mockSecurity)(identity, context);
102
+ return await context.pageBuilder.updatePage(pbPage.id, {
103
+ content: page.content,
104
+ title: page.title,
105
+ path: page.path,
106
+ settings: page.settings
107
+ });
108
+ }
109
+ }
110
+ exports.ImportPagesProcessPages = ImportPagesProcessPages;
111
+
112
+ //# sourceMappingURL=ImportPagesProcessPages.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_importPage","require","_mockSecurity","ImportPagesProcessPages","execute","params","context","response","input","store","isAborted","isCloseToTimeout","identity","items","meta","category","pageIdList","Array","from","done","failed","item","includes","key","aborted","continue","page","importPage","push","pid","ex","console","error","addErrorLog","message","data","addInfoLog","title","id","version","status","mockSecurity","pageKey","fileUploadsData","assets","pbPage","pageBuilder","createPage","updatePage","content","path","settings","exports"],"sources":["ImportPagesProcessPages.ts"],"sourcesContent":["import type { ITaskResponseResult } from \"@webiny/tasks\";\nimport type { IImportPagesControllerInputMeta, IImportPagesProcessPagesTaskParams } from \"./types\";\nimport { importPage } from \"./process/importPage\";\nimport { mockSecurity } from \"~/mockSecurity\";\nimport type { SecurityIdentity } from \"@webiny/api-security/types\";\nimport type { ImportData } from \"~/types\";\nimport type { Page } from \"@webiny/api-page-builder/types\";\n\ninterface ImportPageParams extends Pick<IImportPagesProcessPagesTaskParams, \"context\"> {\n identity: SecurityIdentity;\n item: ImportData;\n meta?: IImportPagesControllerInputMeta;\n category: string;\n}\n\nexport class ImportPagesProcessPages {\n public async execute(params: IImportPagesProcessPagesTaskParams): Promise<ITaskResponseResult> {\n const { context, response, input, store, isAborted, isCloseToTimeout } = params;\n\n const { identity, items, meta, category } = input;\n\n const pageIdList = Array.from(input.pageIdList || []);\n const done = Array.from(input.done || []);\n const failed = Array.from(input.failed || []);\n\n for (const item of items) {\n /**\n * Possibility that a page was already imported in a execution run.\n */\n if (done.includes(item.key) || failed.includes(item.key)) {\n continue;\n } else if (isAborted()) {\n return response.aborted();\n } else if (isCloseToTimeout()) {\n return response.continue({\n ...input,\n pageIdList,\n done,\n failed\n });\n }\n\n let page: Page;\n try {\n page = await this.importPage({\n context,\n identity,\n item,\n meta,\n category\n });\n pageIdList.push(page.pid);\n done.push(item.key);\n } catch (ex) {\n console.error(ex);\n await store.addErrorLog({\n error: ex,\n message: `Could not import page: ${item.key}.`,\n data: {\n ...item\n }\n });\n failed.push(item.key);\n continue;\n }\n await store.addInfoLog({\n message: `Page \"${page.title}\" imported successfully.`,\n data: {\n id: page.id,\n title: page.title,\n version: page.version,\n status: page.status\n }\n });\n }\n\n return response.done({\n done,\n failed,\n pageIdList\n });\n }\n\n private async importPage(params: ImportPageParams) {\n const { context, identity, item, category, meta } = params;\n mockSecurity(identity, context);\n\n const page = await importPage({\n context,\n pageKey: item.key,\n fileUploadsData: {\n data: item.data,\n assets: item.assets\n }\n });\n\n const pbPage = await context.pageBuilder.createPage(category, meta);\n\n mockSecurity(identity, context);\n\n return await context.pageBuilder.updatePage(pbPage.id, {\n content: page.content,\n title: page.title,\n path: page.path,\n settings: page.settings\n });\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,6 @@
1
+ import type { IImportPagesControllerTaskParams } from "../types";
2
+ import type { ITaskResponseResult } from "@webiny/tasks";
3
+ export declare const PROCESS_PAGES_WAIT_TIME = 5;
4
+ export declare class ImportPagesProcessPagesChecker {
5
+ execute(params: IImportPagesControllerTaskParams): Promise<ITaskResponseResult>;
6
+ }
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.PROCESS_PAGES_WAIT_TIME = exports.ImportPagesProcessPagesChecker = void 0;
7
+ var _types = require("../types");
8
+ var _tasks = require("@webiny/tasks");
9
+ const PROCESS_PAGES_WAIT_TIME = exports.PROCESS_PAGES_WAIT_TIME = 5; // seconds
10
+
11
+ class ImportPagesProcessPagesChecker {
12
+ async execute(params) {
13
+ const {
14
+ response,
15
+ context,
16
+ store
17
+ } = params;
18
+ const {
19
+ items
20
+ } = await context.tasks.listTasks({
21
+ where: {
22
+ parentId: store.getTask().id,
23
+ definitionId: _types.PageImportTask.Process,
24
+ taskStatus_in: [_tasks.TaskDataStatus.RUNNING, _tasks.TaskDataStatus.PENDING]
25
+ },
26
+ limit: 1
27
+ });
28
+ if (items.length > 0) {
29
+ return response.continue({
30
+ ...params.input
31
+ }, {
32
+ seconds: PROCESS_PAGES_WAIT_TIME
33
+ });
34
+ }
35
+ return response.done();
36
+ }
37
+ }
38
+ exports.ImportPagesProcessPagesChecker = ImportPagesProcessPagesChecker;
39
+
40
+ //# sourceMappingURL=ImportPagesProcessPagesChecker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_types","require","_tasks","PROCESS_PAGES_WAIT_TIME","exports","ImportPagesProcessPagesChecker","execute","params","response","context","store","items","tasks","listTasks","where","parentId","getTask","id","definitionId","PageImportTask","Process","taskStatus_in","TaskDataStatus","RUNNING","PENDING","limit","length","continue","input","seconds","done"],"sources":["ImportPagesProcessPagesChecker.ts"],"sourcesContent":["import type { IImportPagesControllerTaskParams } from \"~/import/pages/types\";\nimport { PageImportTask } from \"~/import/pages/types\";\nimport type { ITaskResponseResult } from \"@webiny/tasks\";\nimport { TaskDataStatus } from \"@webiny/tasks\";\n\nexport const PROCESS_PAGES_WAIT_TIME = 5; // seconds\n\nexport class ImportPagesProcessPagesChecker {\n public async execute(params: IImportPagesControllerTaskParams): Promise<ITaskResponseResult> {\n const { response, context, store } = params;\n\n const { items } = await context.tasks.listTasks({\n where: {\n parentId: store.getTask().id,\n definitionId: PageImportTask.Process,\n taskStatus_in: [TaskDataStatus.RUNNING, TaskDataStatus.PENDING]\n },\n limit: 1\n });\n if (items.length > 0) {\n return response.continue(\n {\n ...params.input\n },\n {\n seconds: PROCESS_PAGES_WAIT_TIME\n }\n );\n }\n return response.done();\n }\n}\n"],"mappings":";;;;;;AACA,IAAAA,MAAA,GAAAC,OAAA;AAEA,IAAAC,MAAA,GAAAD,OAAA;AAEO,MAAME,uBAAuB,GAAAC,OAAA,CAAAD,uBAAA,GAAG,CAAC,CAAC,CAAC;;AAEnC,MAAME,8BAA8B,CAAC;EACxC,MAAaC,OAAOA,CAACC,MAAwC,EAAgC;IACzF,MAAM;MAAEC,QAAQ;MAAEC,OAAO;MAAEC;IAAM,CAAC,GAAGH,MAAM;IAE3C,MAAM;MAAEI;IAAM,CAAC,GAAG,MAAMF,OAAO,CAACG,KAAK,CAACC,SAAS,CAAC;MAC5CC,KAAK,EAAE;QACHC,QAAQ,EAAEL,KAAK,CAACM,OAAO,CAAC,CAAC,CAACC,EAAE;QAC5BC,YAAY,EAAEC,qBAAc,CAACC,OAAO;QACpCC,aAAa,EAAE,CAACC,qBAAc,CAACC,OAAO,EAAED,qBAAc,CAACE,OAAO;MAClE,CAAC;MACDC,KAAK,EAAE;IACX,CAAC,CAAC;IACF,IAAId,KAAK,CAACe,MAAM,GAAG,CAAC,EAAE;MAClB,OAAOlB,QAAQ,CAACmB,QAAQ,CACpB;QACI,GAAGpB,MAAM,CAACqB;MACd,CAAC,EACD;QACIC,OAAO,EAAE1B;MACb,CACJ,CAAC;IACL;IACA,OAAOK,QAAQ,CAACsB,IAAI,CAAC,CAAC;EAC1B;AACJ;AAAC1B,OAAA,CAAAC,8BAAA,GAAAA,8BAAA","ignoreList":[]}
@@ -0,0 +1,5 @@
1
+ import type { IImportPagesControllerTaskParams } from "../types";
2
+ import type { ITaskResponseResult } from "@webiny/tasks";
3
+ export declare class ImportPagesProcessZipFile {
4
+ execute(params: IImportPagesControllerTaskParams): Promise<ITaskResponseResult>;
5
+ }
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.ImportPagesProcessZipFile = void 0;
8
+ var _types = require("../types");
9
+ var _utils = require("../../utils");
10
+ var _chunk = _interopRequireDefault(require("lodash/chunk"));
11
+ const PROCESSING_PAGES_PER_TASK = 5;
12
+ class ImportPagesProcessZipFile {
13
+ async execute(params) {
14
+ const {
15
+ response,
16
+ input,
17
+ trigger,
18
+ store
19
+ } = params;
20
+ const {
21
+ zipFileUrl
22
+ } = input;
23
+ if (!zipFileUrl) {
24
+ return response.error({
25
+ message: `Missing "zipFileUrl" in the input.`
26
+ });
27
+ }
28
+ const items = await (0, _utils.extractAndUploadZipFileContents)(zipFileUrl);
29
+ /**
30
+ * We will trigger subtasks for a batch of pages.
31
+ */
32
+ if (items.length === 0) {
33
+ return response.error({
34
+ message: `No pages found in the provided zip file.`
35
+ });
36
+ }
37
+ const chunks = (0, _chunk.default)(items, PROCESSING_PAGES_PER_TASK);
38
+ for (const pages of chunks) {
39
+ await trigger({
40
+ definition: _types.PageImportTask.Process,
41
+ input: {
42
+ category: input.category,
43
+ meta: input.meta,
44
+ identity: input.identity,
45
+ items: pages,
46
+ done: [],
47
+ failed: [],
48
+ pageIdList: []
49
+ }
50
+ });
51
+ }
52
+ await store.updateOutput({
53
+ total: items.length
54
+ }, {
55
+ save: false
56
+ });
57
+ return response.continue({
58
+ ...input,
59
+ processing: true
60
+ }, {
61
+ /**
62
+ * We will wait a bit before we run controller again,
63
+ * because of Lambda cold starts.
64
+ */
65
+ seconds: 10
66
+ });
67
+ }
68
+ }
69
+ exports.ImportPagesProcessZipFile = ImportPagesProcessZipFile;
70
+
71
+ //# sourceMappingURL=ImportPagesProcessZipFile.js.map