@crowdin/app-project-module 0.105.1 → 0.107.0-cf-0

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 (164) hide show
  1. package/out/app-test/integration/get-integration-files.js +0 -1
  2. package/out/app-test/integration/mocks/mock-axios.js +0 -1
  3. package/out/app-test/integration/update-crowdin.js +0 -1
  4. package/out/app-test/integration/update-integration.js +0 -1
  5. package/out/index.d.ts +1 -0
  6. package/out/index.js +30 -12
  7. package/out/middlewares/crowdin-client.d.ts +1 -1
  8. package/out/middlewares/integration-credentials.d.ts +1 -1
  9. package/out/middlewares/integration-credentials.js +4 -1
  10. package/out/middlewares/render-ui-module.d.ts +3 -3
  11. package/out/middlewares/render-ui-module.js +9 -13
  12. package/out/middlewares/ui-module.d.ts +1 -1
  13. package/out/middlewares/ui-module.js +10 -1
  14. package/out/modules/about.d.ts +2 -1
  15. package/out/modules/about.js +10 -3
  16. package/out/modules/ai-prompt-provider/handlers/compile.d.ts +1 -1
  17. package/out/modules/ai-prompt-provider/index.js +2 -2
  18. package/out/modules/ai-provider/handlers/chat-completions.d.ts +1 -1
  19. package/out/modules/ai-provider/handlers/chat-completions.js +0 -1
  20. package/out/modules/ai-provider/handlers/get-model-list.d.ts +1 -1
  21. package/out/modules/ai-provider/index.js +2 -2
  22. package/out/modules/ai-provider/types.d.ts +2 -2
  23. package/out/modules/ai-provider/util/index.js +0 -2
  24. package/out/modules/ai-request-processors/handler.d.ts +1 -1
  25. package/out/modules/ai-tools/handlers/tool-calls.d.ts +1 -1
  26. package/out/modules/ai-tools/index.js +1 -1
  27. package/out/modules/api/api.js +0 -1
  28. package/out/modules/auth-guard/handlers/verify.d.ts +1 -1
  29. package/out/modules/auth-guard/index.js +1 -1
  30. package/out/modules/automation-action/handlers/execute.d.ts +1 -1
  31. package/out/modules/automation-action/handlers/input-schema.d.ts +1 -1
  32. package/out/modules/automation-action/handlers/output-schema.d.ts +1 -1
  33. package/out/modules/automation-action/handlers/validate-settings.d.ts +1 -1
  34. package/out/modules/automation-action/index.js +1 -1
  35. package/out/modules/context-menu/index.js +2 -2
  36. package/out/modules/custom-mt/handlers/translate.d.ts +2 -2
  37. package/out/modules/custom-mt/handlers/translate.js +53 -4
  38. package/out/modules/custom-mt/index.js +6 -3
  39. package/out/modules/custom-mt/types.d.ts +14 -2
  40. package/out/modules/custom-spell-check/handlers/get-languages-list.d.ts +1 -1
  41. package/out/modules/custom-spell-check/handlers/spell-check.d.ts +1 -1
  42. package/out/modules/custom-spell-check/index.js +4 -4
  43. package/out/modules/editor-right-panel/index.js +1 -1
  44. package/out/modules/external-qa-check/handlers/validate.d.ts +1 -1
  45. package/out/modules/external-qa-check/index.js +2 -2
  46. package/out/modules/file-processing/handlers/custom-file-format.d.ts +7 -2
  47. package/out/modules/file-processing/handlers/custom-file-format.js +59 -19
  48. package/out/modules/file-processing/handlers/file-download.d.ts +1 -1
  49. package/out/modules/file-processing/handlers/file-download.js +5 -0
  50. package/out/modules/file-processing/handlers/pre-post-process.d.ts +1 -1
  51. package/out/modules/file-processing/handlers/pre-post-process.js +34 -14
  52. package/out/modules/file-processing/handlers/translations-alignment.d.ts +1 -1
  53. package/out/modules/file-processing/index.js +12 -2
  54. package/out/modules/file-processing/util/defaults.js +50 -6
  55. package/out/modules/file-processing/util/files.js +2 -1
  56. package/out/modules/form-data-display.d.ts +1 -1
  57. package/out/modules/form-data-save.d.ts +1 -1
  58. package/out/modules/install.d.ts +1 -1
  59. package/out/modules/integration/handlers/crowdin-file-progress.d.ts +1 -1
  60. package/out/modules/integration/handlers/crowdin-files.d.ts +1 -1
  61. package/out/modules/integration/handlers/crowdin-project.d.ts +1 -1
  62. package/out/modules/integration/handlers/crowdin-update.d.ts +1 -1
  63. package/out/modules/integration/handlers/crowdin-webhook.d.ts +1 -1
  64. package/out/modules/integration/handlers/integration-data.d.ts +1 -1
  65. package/out/modules/integration/handlers/integration-login.d.ts +1 -1
  66. package/out/modules/integration/handlers/integration-logout.d.ts +1 -1
  67. package/out/modules/integration/handlers/integration-update.d.ts +1 -1
  68. package/out/modules/integration/handlers/integration-webhook.d.ts +1 -1
  69. package/out/modules/integration/handlers/invite-users.d.ts +1 -1
  70. package/out/modules/integration/handlers/job-cancel.d.ts +1 -1
  71. package/out/modules/integration/handlers/job-info-deprecated.d.ts +1 -1
  72. package/out/modules/integration/handlers/job-info.d.ts +1 -1
  73. package/out/modules/integration/handlers/job-list.d.ts +1 -1
  74. package/out/modules/integration/handlers/main.d.ts +1 -1
  75. package/out/modules/integration/handlers/main.js +13 -1
  76. package/out/modules/integration/handlers/oauth-login.d.ts +1 -1
  77. package/out/modules/integration/handlers/oauth-login.js +12 -3
  78. package/out/modules/integration/handlers/oauth-polling.d.ts +2 -2
  79. package/out/modules/integration/handlers/oauth-polling.js +5 -3
  80. package/out/modules/integration/handlers/oauth-url.d.ts +1 -1
  81. package/out/modules/integration/handlers/settings-save.d.ts +1 -1
  82. package/out/modules/integration/handlers/settings.d.ts +1 -1
  83. package/out/modules/integration/handlers/sync-settings-save.d.ts +1 -1
  84. package/out/modules/integration/handlers/sync-settings-save.js +0 -2
  85. package/out/modules/integration/handlers/sync-settings.d.ts +1 -1
  86. package/out/modules/integration/handlers/user-errors.d.ts +1 -1
  87. package/out/modules/integration/handlers/users.d.ts +1 -1
  88. package/out/modules/integration/index.js +13 -34
  89. package/out/modules/integration/util/cron.js +1 -10
  90. package/out/modules/integration/util/defaults.js +31 -28
  91. package/out/modules/integration/util/files.js +18 -11
  92. package/out/modules/integration/util/job.js +0 -4
  93. package/out/modules/integration/util/snapshot.js +1 -5
  94. package/out/modules/integration/util/webhooks.js +1 -8
  95. package/out/modules/manifest.js +15 -13
  96. package/out/modules/modal/index.js +2 -2
  97. package/out/modules/organization-menu/index.js +5 -4
  98. package/out/modules/organization-settings-menu/index.js +5 -4
  99. package/out/modules/profile-resources-menu/index.js +5 -4
  100. package/out/modules/profile-settings-menu/index.js +5 -4
  101. package/out/modules/project-menu/index.js +1 -1
  102. package/out/modules/project-menu-crowdsource/index.js +1 -1
  103. package/out/modules/project-reports/index.js +3 -2
  104. package/out/modules/project-tools/index.js +3 -2
  105. package/out/modules/status.d.ts +1 -1
  106. package/out/modules/status.js +12 -3
  107. package/out/modules/subscription-paid.d.ts +1 -1
  108. package/out/modules/uninstall.d.ts +1 -1
  109. package/out/modules/webhooks/handlers/webhook-handler.d.ts +1 -1
  110. package/out/modules/webhooks/handlers/webhook-handler.js +30 -15
  111. package/out/modules/webhooks/types.d.ts +7 -0
  112. package/out/modules/workflow-step-type/handlers/delete-step.d.ts +1 -1
  113. package/out/modules/workflow-step-type/handlers/step-settings-save.d.ts +1 -1
  114. package/out/modules/workflow-step-type/index.js +2 -2
  115. package/out/storage/d1.d.ts +107 -0
  116. package/out/storage/d1.js +829 -0
  117. package/out/storage/index.js +8 -2
  118. package/out/storage/mysql.js +0 -3
  119. package/out/storage/postgre.js +0 -1
  120. package/out/storage/sqlite.js +0 -3
  121. package/out/types.d.ts +41 -2
  122. package/out/util/axios.js +0 -1
  123. package/out/util/credentials-masker.d.ts +1 -1
  124. package/out/util/cron.d.ts +29 -0
  125. package/out/util/cron.js +87 -0
  126. package/out/util/index.d.ts +12 -1
  127. package/out/util/index.js +54 -6
  128. package/out/util/jsx-renderer.d.ts +6 -0
  129. package/out/util/jsx-renderer.js +13 -0
  130. package/out/util/logger.js +0 -4
  131. package/out/util/static-files.d.ts +19 -0
  132. package/out/util/static-files.js +87 -0
  133. package/out/views/AboutPage.d.ts +10 -0
  134. package/out/views/AboutPage.js +76 -0
  135. package/out/views/ErrorPage.d.ts +18 -0
  136. package/out/views/ErrorPage.js +56 -0
  137. package/out/views/FormPage.d.ts +14 -0
  138. package/out/views/FormPage.js +28 -0
  139. package/out/views/InstallPage.d.ts +10 -0
  140. package/out/views/InstallPage.js +22 -0
  141. package/out/views/LoginPage.d.ts +33 -0
  142. package/out/views/LoginPage.js +200 -0
  143. package/out/views/MainPage.d.ts +81 -0
  144. package/out/views/MainPage.js +1784 -0
  145. package/out/views/OAuthPage.d.ts +7 -0
  146. package/out/views/OAuthPage.js +17 -0
  147. package/out/views/SubscriptionPage.d.ts +7 -0
  148. package/out/views/SubscriptionPage.js +26 -0
  149. package/out/views/index.d.ts +13 -0
  150. package/out/views/index.js +25 -0
  151. package/out/views/layout/Head.d.ts +9 -0
  152. package/out/views/layout/Head.js +54 -0
  153. package/package.json +33 -18
  154. package/out/util/handlebars.d.ts +0 -1
  155. package/out/util/handlebars.js +0 -46
  156. package/out/views/about.handlebars +0 -102
  157. package/out/views/error.handlebars +0 -54
  158. package/out/views/form.handlebars +0 -31
  159. package/out/views/install.handlebars +0 -16
  160. package/out/views/login.handlebars +0 -332
  161. package/out/views/main.handlebars +0 -2042
  162. package/out/views/oauth.handlebars +0 -11
  163. package/out/views/partials/head.handlebars +0 -53
  164. package/out/views/subscription.handlebars +0 -26
@@ -266,11 +266,8 @@ function prepareWebhookData({ config, integration, provider, webhookUrlParam, })
266
266
  }
267
267
  const context = Object.assign({ jwtPayload: {
268
268
  context: {
269
- // eslint-disable-next-line @typescript-eslint/camelcase
270
269
  project_id: projectId,
271
- // eslint-disable-next-line @typescript-eslint/camelcase
272
270
  organization_id: crowdinCredentials === null || crowdinCredentials === void 0 ? void 0 : crowdinCredentials.organizationId,
273
- // eslint-disable-next-line @typescript-eslint/camelcase
274
271
  user_id: crowdinCredentials === null || crowdinCredentials === void 0 ? void 0 : crowdinCredentials.userId,
275
272
  },
276
273
  }, crowdinId: crowdinCredentials.id }, ((integrationCredentials === null || integrationCredentials === void 0 ? void 0 : integrationCredentials.id) && { clientId: integrationCredentials.id }));
@@ -325,11 +322,7 @@ function updateCrowdinFromWebhookRequest(args) {
325
322
  if (fileNodeType !== '1') {
326
323
  continue;
327
324
  }
328
- const initFile = Object.assign({ id: file.id, name: file.name, sync: false, schedule: true,
329
- // eslint-disable-next-line @typescript-eslint/camelcase
330
- parent_id: file.parent_id || file.parentId,
331
- // eslint-disable-next-line @typescript-eslint/camelcase
332
- node_type: file.nodeType || file.node_type || '1' }, (file.type ? { type: file.type } : {}));
325
+ const initFile = Object.assign({ id: file.id, name: file.name, sync: false, schedule: true, parent_id: file.parent_id || file.parentId, node_type: file.nodeType || file.node_type || '1' }, (file.type ? { type: file.type } : {}));
333
326
  if (syncSettings) {
334
327
  if (!syncFiles.find((obj) => obj.id === initFile.id)) {
335
328
  yield (0, storage_1.getStorage)().updateSyncSettings(JSON.stringify([...syncFiles, initFile]), syncSettings.integrationId, syncSettings.crowdinId, 'schedule', syncSettings.provider);
@@ -21,7 +21,7 @@ function handle(config) {
21
21
  // prevent possible overrides of the other modules
22
22
  config.projectIntegration = Object.assign(Object.assign({}, config.projectIntegration), { key: config.identifier + '-int' });
23
23
  modules['project-integrations'] = [
24
- Object.assign({ key: config.projectIntegration.key, name: config.name, description: config.description, logo: (0, util_1.getLogoUrl)(config.projectIntegration, '/integration'), url: '/' }, (!!config.projectIntegration.environments && {
24
+ Object.assign({ key: config.projectIntegration.key, name: config.name, description: config.description, logo: (0, util_1.getLogoUrl)(config, config.projectIntegration, '/integration'), url: '/' }, (!!config.projectIntegration.environments && {
25
25
  environments: normalizeEnvironments(config.projectIntegration.environments),
26
26
  })),
27
27
  ];
@@ -102,9 +102,11 @@ function handle(config) {
102
102
  // prevent possible overrides of the other modules
103
103
  config.customMT = Object.assign(Object.assign({}, config.customMT), { key: config.identifier + '-mt' });
104
104
  modules['custom-mt'] = [
105
- Object.assign(Object.assign(Object.assign({ key: config.customMT.key, name: config.name, logo: (0, util_1.getLogoUrl)(config.customMT, '/mt'), url: '/mt/translate', withContext: !!config.customMT.withContext }, (config.customMT.batchSize !== null && {
105
+ Object.assign(Object.assign(Object.assign(Object.assign({ key: config.customMT.key, name: config.name, logo: (0, util_1.getLogoUrl)(config, config.customMT, '/mt'), url: '/mt/translate', withContext: !!config.customMT.withContext }, ((0, util_1.isDefined)(config.customMT.splitStringsIntoChunks) && {
106
+ splitStringsIntoChunks: config.customMT.splitStringsIntoChunks,
107
+ })), ((0, util_1.isDefined)(config.customMT.batchSize) && {
106
108
  batchSize: config.customMT.batchSize,
107
- })), (config.customMT.maskEntities !== null && {
109
+ })), ((0, util_1.isDefined)(config.customMT.maskEntities) && {
108
110
  maskEntities: config.customMT.maskEntities,
109
111
  })), (!!config.customMT.environments && {
110
112
  environments: normalizeEnvironments(config.customMT.environments),
@@ -119,7 +121,7 @@ function handle(config) {
119
121
  key: config.organizationMenu.key,
120
122
  name: config.organizationMenu.name || config.name,
121
123
  url: '/organization-menu/' + (config.organizationMenu.fileName || 'index.html'),
122
- icon: (0, util_1.getLogoUrl)(config.organizationMenu, '/resources'),
124
+ icon: (0, util_1.getLogoUrl)(config, config.organizationMenu, '/resources'),
123
125
  },
124
126
  ];
125
127
  }
@@ -131,7 +133,7 @@ function handle(config) {
131
133
  key: config.organizationSettingsMenu.key,
132
134
  name: config.organizationSettingsMenu.name || config.name,
133
135
  url: '/organization-settings/' + (config.organizationSettingsMenu.fileName || 'index.html'),
134
- icon: (0, util_1.getLogoUrl)(config.organizationSettingsMenu, '/organization-settings'),
136
+ icon: (0, util_1.getLogoUrl)(config, config.organizationSettingsMenu, '/organization-settings'),
135
137
  },
136
138
  ];
137
139
  }
@@ -139,7 +141,7 @@ function handle(config) {
139
141
  // prevent possible overrides of the other modules
140
142
  config.profileResourcesMenu = Object.assign(Object.assign({}, config.profileResourcesMenu), { key: config.identifier + '-profile-resources-menu' });
141
143
  modules['profile-resources-menu'] = [
142
- Object.assign({ key: config.profileResourcesMenu.key, name: config.profileResourcesMenu.name || config.name, url: '/profile-resources/' + (config.profileResourcesMenu.fileName || 'index.html'), icon: (0, util_1.getLogoUrl)(config.profileResourcesMenu, '/profile-resources') }, (!!config.profileResourcesMenu.environments && {
144
+ Object.assign({ key: config.profileResourcesMenu.key, name: config.profileResourcesMenu.name || config.name, url: '/profile-resources/' + (config.profileResourcesMenu.fileName || 'index.html'), icon: (0, util_1.getLogoUrl)(config, config.profileResourcesMenu, '/profile-resources') }, (!!config.profileResourcesMenu.environments && {
143
145
  environments: normalizeEnvironments(config.profileResourcesMenu.environments),
144
146
  })),
145
147
  ];
@@ -148,7 +150,7 @@ function handle(config) {
148
150
  // prevent possible overrides of the other modules
149
151
  config.profileSettingsMenu = Object.assign(Object.assign({}, config.profileSettingsMenu), { key: config.identifier + '-profile-settings-menu' });
150
152
  modules['profile-settings-menu'] = [
151
- Object.assign({ key: config.profileSettingsMenu.key, name: config.profileSettingsMenu.name || config.name, url: '/profile-settings/' + (config.profileSettingsMenu.fileName || 'index.html'), icon: (0, util_1.getLogoUrl)(config.profileSettingsMenu, '/profile-settings') }, (!!config.profileSettingsMenu.environments && {
153
+ Object.assign({ key: config.profileSettingsMenu.key, name: config.profileSettingsMenu.name || config.name, url: '/profile-settings/' + (config.profileSettingsMenu.fileName || 'index.html'), icon: (0, util_1.getLogoUrl)(config, config.profileSettingsMenu, '/profile-settings') }, (!!config.profileSettingsMenu.environments && {
152
154
  environments: normalizeEnvironments(config.profileSettingsMenu.environments),
153
155
  })),
154
156
  ];
@@ -186,7 +188,7 @@ function handle(config) {
186
188
  // prevent possible overrides of the other modules
187
189
  config.projectTools = Object.assign(Object.assign({}, config.projectTools), { key: config.identifier + '-tools' });
188
190
  modules['project-tools'] = [
189
- Object.assign({ key: config.projectTools.key, name: config.projectTools.name || config.name, description: config.description, logo: (0, util_1.getLogoUrl)(config.projectTools, '/tools'), url: '/tools/' + (config.projectTools.fileName || 'index.html') }, (!!config.projectTools.environments && {
191
+ Object.assign({ key: config.projectTools.key, name: config.projectTools.name || config.name, description: config.description, logo: (0, util_1.getLogoUrl)(config, config.projectTools, '/tools'), url: '/tools/' + (config.projectTools.fileName || 'index.html') }, (!!config.projectTools.environments && {
190
192
  environments: normalizeEnvironments(config.projectTools.environments),
191
193
  })),
192
194
  ];
@@ -199,7 +201,7 @@ function handle(config) {
199
201
  key: config.projectReports.key,
200
202
  name: config.projectReports.name || config.name,
201
203
  description: config.description,
202
- logo: (0, util_1.getLogoUrl)(config.projectReports, '/reports'),
204
+ logo: (0, util_1.getLogoUrl)(config, config.projectReports, '/reports'),
203
205
  url: '/reports/' + (config.projectReports.fileName || 'index.html'),
204
206
  },
205
207
  ];
@@ -270,7 +272,7 @@ function handle(config) {
270
272
  config.aiProvider = Object.assign(Object.assign({}, config.aiProvider), { key: config.identifier + '-aiprovider' });
271
273
  const uiModule = config.aiProvider.settingsUiModule;
272
274
  modules['ai-provider'] = [
273
- Object.assign(Object.assign({ key: config.aiProvider.key, name: config.aiProvider.name || config.name, description: config.aiProvider.description || config.description, logo: (0, util_1.getLogoUrl)(config.aiProvider, '/aiprovider'), chatCompletionsUrl: '/ai-provider/completions', modelsUrl: '/ai-provider/models' }, (!!config.aiProvider.environments && {
275
+ Object.assign(Object.assign({ key: config.aiProvider.key, name: config.aiProvider.name || config.name, description: config.aiProvider.description || config.description, logo: (0, util_1.getLogoUrl)(config, config.aiProvider, '/aiprovider'), chatCompletionsUrl: '/ai-provider/completions', modelsUrl: '/ai-provider/models' }, (!!config.aiProvider.environments && {
274
276
  environments: normalizeEnvironments(config.aiProvider.environments),
275
277
  })), (uiModule ? { url: '/settings/' + (uiModule.fileName || 'index.html') } : {})),
276
278
  ];
@@ -295,7 +297,7 @@ function handle(config) {
295
297
  // prevent possible overrides of the other modules
296
298
  config.aiPromptProvider = Object.assign(Object.assign({}, config.aiPromptProvider), { key: config.identifier + '-ai-prompt-provider' });
297
299
  modules['ai-prompt-provider'] = [
298
- Object.assign(Object.assign({ key: config.aiPromptProvider.key, name: config.aiPromptProvider.name || config.name, logo: (0, util_1.getLogoUrl)(config.aiPromptProvider, '/ai-prompt-provider'), compileUrl: '/prompt-provider/compile' }, (config.aiPromptProvider.actions
300
+ Object.assign(Object.assign({ key: config.aiPromptProvider.key, name: config.aiPromptProvider.name || config.name, logo: (0, util_1.getLogoUrl)(config, config.aiPromptProvider, '/ai-prompt-provider'), compileUrl: '/prompt-provider/compile' }, (config.aiPromptProvider.actions
299
301
  ? {
300
302
  actions: config.aiPromptProvider.actions,
301
303
  }
@@ -384,7 +386,7 @@ function handle(config) {
384
386
  workflowStep.key = config.identifier + '-' + (0, util_3.getWorkflowStepKey)(workflowStep);
385
387
  }
386
388
  const uiModule = ((_b = workflowStep === null || workflowStep === void 0 ? void 0 : workflowStep.settingsUiModule) === null || _b === void 0 ? void 0 : _b.formSchema) || ((_c = workflowStep === null || workflowStep === void 0 ? void 0 : workflowStep.settingsUiModule) === null || _c === void 0 ? void 0 : _c.fileName);
387
- modules['workflow-step-type'].push(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ key: workflowStep.key, name: workflowStep.name || config.name }, ((workflowStep === null || workflowStep === void 0 ? void 0 : workflowStep.imagePath) ? { logo: (0, util_1.getLogoUrl)(workflowStep, `-${workflowStep.key}`) } : {})), { description: workflowStep.description || config.description, boundaries: workflowStep.boundaries }), (workflowStep.editorMode ? { editorMode: workflowStep.editorMode } : {})), { updateSettingsUrl: (0, util_3.getWorkflowStepUrl)('/workflow-step/settings', workflowStep), deleteSettingsUrl: (0, util_3.getWorkflowStepUrl)('/workflow-step/delete', workflowStep) }), (uiModule ? { url: (0, util_3.getWorkflowStepUrl)('/workflow-step', workflowStep) } : {})));
389
+ modules['workflow-step-type'].push(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ key: workflowStep.key, name: workflowStep.name || config.name }, ((workflowStep === null || workflowStep === void 0 ? void 0 : workflowStep.imagePath) ? { logo: (0, util_1.getLogoUrl)(config, workflowStep, `-${workflowStep.key}`) } : {})), { description: workflowStep.description || config.description, boundaries: workflowStep.boundaries }), (workflowStep.editorMode ? { editorMode: workflowStep.editorMode } : {})), { updateSettingsUrl: (0, util_3.getWorkflowStepUrl)('/workflow-step/settings', workflowStep), deleteSettingsUrl: (0, util_3.getWorkflowStepUrl)('/workflow-step/delete', workflowStep) }), (uiModule ? { url: (0, util_3.getWorkflowStepUrl)('/workflow-step', workflowStep) } : {})));
388
390
  }
389
391
  }
390
392
  if (config.automationAction) {
@@ -448,7 +450,7 @@ function handle(config) {
448
450
  events['subscription_paid'] = '/subscription-paid';
449
451
  }
450
452
  return (_req, res) => {
451
- const manifest = Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ identifier: config.identifier, name: config.name, logo: (0, util_1.getLogoUrl)(), baseUrl: config.baseUrl, authentication: {
453
+ const manifest = Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ identifier: config.identifier, name: config.name, logo: (0, util_1.getLogoUrl)(config), baseUrl: config.baseUrl, authentication: {
452
454
  type: config.authenticationType || types_1.AuthenticationType.APP,
453
455
  clientId: config.clientId,
454
456
  }, restrictAiToSameApp: config.restrictAiToSameApp }, (config.stringBasedAvailable !== undefined && { stringBasedAvailable: config.stringBasedAvailable })), (config.agent && { agent: config.agent })), { events, scopes: config.scopes ? config.scopes : [types_1.Scope.PROJECTS] }), (config.defaultPermissions && { default_permissions: config.defaultPermissions })), { modules });
@@ -16,14 +16,14 @@ function register({ config, app }) {
16
16
  if (Array.isArray(config.modal)) {
17
17
  config.modal.forEach((modal) => {
18
18
  if ((modal === null || modal === void 0 ? void 0 : modal.uiPath) || (modal === null || modal === void 0 ? void 0 : modal.formSchema)) {
19
- app.use(`/modal-${modal.key}`, (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: modal.key }), (0, render_ui_module_1.default)(modal));
19
+ app.use(`/modal-${modal.key}`, (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: modal.key }), (0, render_ui_module_1.default)(modal, config));
20
20
  }
21
21
  });
22
22
  }
23
23
  else {
24
24
  // backward compatibility will be removed after migration
25
25
  if (((_a = config.modal) === null || _a === void 0 ? void 0 : _a.uiPath) || ((_b = config.modal) === null || _b === void 0 ? void 0 : _b.formSchema)) {
26
- app.use('/modal', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.modal.key }), (0, render_ui_module_1.default)(config.modal));
26
+ app.use('/modal', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.modal.key }), (0, render_ui_module_1.default)(config.modal, config));
27
27
  }
28
28
  }
29
29
  }
@@ -7,16 +7,17 @@ exports.register = void 0;
7
7
  const render_ui_module_1 = __importDefault(require("../../middlewares/render-ui-module"));
8
8
  const ui_module_1 = __importDefault(require("../../middlewares/ui-module"));
9
9
  const util_1 = require("../../util");
10
+ const util_2 = require("../../util");
10
11
  function register({ config, app }) {
11
12
  if (!config.organizationMenu) {
12
13
  return;
13
14
  }
14
15
  const allowUnauthorized = !(0, util_1.isAuthorizedConfig)(config);
15
- app.get((0, util_1.getLogoUrl)(config.organizationMenu, '/organization-menu'), (req, res) => { var _a; return res.sendFile(((_a = config.organizationMenu) === null || _a === void 0 ? void 0 : _a.imagePath) || config.imagePath); });
16
- app.use('/organization-menu', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.organizationMenu.key }), (0, render_ui_module_1.default)(config.organizationMenu));
16
+ app.use('/logo/organization-menu', (0, util_2.serveLogo)(config, config.organizationMenu));
17
+ app.use('/organization-menu', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.organizationMenu.key }), (0, render_ui_module_1.default)(config.organizationMenu, config));
17
18
  // TEMPORARY CODE: it needs to support old path
18
- app.get((0, util_1.getLogoUrl)(config.organizationMenu, '/resources'), (req, res) => { var _a; return res.sendFile(((_a = config.organizationMenu) === null || _a === void 0 ? void 0 : _a.imagePath) || config.imagePath); });
19
- app.use('/resources', (0, ui_module_1.default)({ config, allowUnauthorized }), (0, render_ui_module_1.default)(config.organizationMenu));
19
+ app.use('/logo/resources', (0, util_2.serveLogo)(config, config.organizationMenu));
20
+ app.use('/resources', (0, ui_module_1.default)({ config, allowUnauthorized }), (0, render_ui_module_1.default)(config.organizationMenu, config));
20
21
  // END TEMPORARY CODE
21
22
  }
22
23
  exports.register = register;
@@ -7,16 +7,17 @@ exports.register = void 0;
7
7
  const render_ui_module_1 = __importDefault(require("../../middlewares/render-ui-module"));
8
8
  const ui_module_1 = __importDefault(require("../../middlewares/ui-module"));
9
9
  const util_1 = require("../../util");
10
+ const util_2 = require("../../util");
10
11
  function register({ config, app }) {
11
12
  if (!config.organizationSettingsMenu) {
12
13
  return;
13
14
  }
14
15
  const allowUnauthorized = !(0, util_1.isAuthorizedConfig)(config);
15
- app.get((0, util_1.getLogoUrl)(config.organizationSettingsMenu, '/organization-settings'), (req, res) => { var _a; return res.sendFile(((_a = config.organizationSettingsMenu) === null || _a === void 0 ? void 0 : _a.imagePath) || config.imagePath); });
16
- app.use('/organization-settings', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.organizationSettingsMenu.key }), (0, render_ui_module_1.default)(config.organizationSettingsMenu));
16
+ app.use('/logo/organization-settings', (0, util_2.serveLogo)(config, config.organizationSettingsMenu));
17
+ app.use('/organization-settings', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.organizationSettingsMenu.key }), (0, render_ui_module_1.default)(config.organizationSettingsMenu, config));
17
18
  // TEMPORARY CODE: it needs to support old path
18
- app.get((0, util_1.getLogoUrl)(config.organizationSettingsMenu, '/settings'), (req, res) => { var _a; return res.sendFile(((_a = config.organizationSettingsMenu) === null || _a === void 0 ? void 0 : _a.imagePath) || config.imagePath); });
19
- app.use('/settings', (0, ui_module_1.default)({ config, allowUnauthorized }), (0, render_ui_module_1.default)(config.organizationSettingsMenu));
19
+ app.use('/logo/settings', (0, util_2.serveLogo)(config, config.organizationSettingsMenu));
20
+ app.use('/settings', (0, ui_module_1.default)({ config, allowUnauthorized }), (0, render_ui_module_1.default)(config.organizationSettingsMenu, config));
20
21
  // END TEMPORARY CODE
21
22
  }
22
23
  exports.register = register;
@@ -7,16 +7,17 @@ exports.register = void 0;
7
7
  const render_ui_module_1 = __importDefault(require("../../middlewares/render-ui-module"));
8
8
  const ui_module_1 = __importDefault(require("../../middlewares/ui-module"));
9
9
  const util_1 = require("../../util");
10
+ const util_2 = require("../../util");
10
11
  function register({ config, app }) {
11
12
  if (!config.profileResourcesMenu) {
12
13
  return;
13
14
  }
14
- app.get((0, util_1.getLogoUrl)(config.profileResourcesMenu, '/profile-resources'), (req, res) => { var _a; return res.sendFile(((_a = config.profileResourcesMenu) === null || _a === void 0 ? void 0 : _a.imagePath) || config.imagePath); });
15
+ app.use('/logo/profile-resources', (0, util_2.serveLogo)(config, config.profileResourcesMenu));
15
16
  const allowUnauthorized = !(0, util_1.isAuthorizedConfig)(config);
16
- app.use('/profile-resources', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.profileResourcesMenu.key }), (0, render_ui_module_1.default)(config.profileResourcesMenu));
17
+ app.use('/profile-resources', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.profileResourcesMenu.key }), (0, render_ui_module_1.default)(config.profileResourcesMenu, config));
17
18
  // TEMPORARY CODE: it needs to support old path
18
- app.get((0, util_1.getLogoUrl)(config.profileResourcesMenu, '/resources'), (req, res) => { var _a; return res.sendFile(((_a = config.profileResourcesMenu) === null || _a === void 0 ? void 0 : _a.imagePath) || config.imagePath); });
19
- app.use('/resources', (0, ui_module_1.default)({ config, allowUnauthorized }), (0, render_ui_module_1.default)(config.profileResourcesMenu));
19
+ app.use('/logo/resources', (0, util_2.serveLogo)(config, config.profileResourcesMenu));
20
+ app.use('/resources', (0, ui_module_1.default)({ config, allowUnauthorized }), (0, render_ui_module_1.default)(config.profileResourcesMenu, config));
20
21
  // END TEMPORARY CODE
21
22
  }
22
23
  exports.register = register;
@@ -7,16 +7,17 @@ exports.register = void 0;
7
7
  const render_ui_module_1 = __importDefault(require("../../middlewares/render-ui-module"));
8
8
  const ui_module_1 = __importDefault(require("../../middlewares/ui-module"));
9
9
  const util_1 = require("../../util");
10
+ const util_2 = require("../../util");
10
11
  function register({ config, app }) {
11
12
  if (!config.profileSettingsMenu) {
12
13
  return;
13
14
  }
14
- app.get((0, util_1.getLogoUrl)(config.profileSettingsMenu, '/profile-settings'), (req, res) => { var _a; return res.sendFile(((_a = config.profileSettingsMenu) === null || _a === void 0 ? void 0 : _a.imagePath) || config.imagePath); });
15
+ app.use('/logo/profile-settings', (0, util_2.serveLogo)(config, config.profileSettingsMenu));
15
16
  const allowUnauthorized = !(0, util_1.isAuthorizedConfig)(config);
16
- app.use('/profile-settings', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.profileSettingsMenu.key }), (0, render_ui_module_1.default)(config.profileSettingsMenu));
17
+ app.use('/profile-settings', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.profileSettingsMenu.key }), (0, render_ui_module_1.default)(config.profileSettingsMenu, config));
17
18
  // TEMPORARY CODE: it needs to support old path
18
- app.get((0, util_1.getLogoUrl)(config.profileSettingsMenu, '/settings'), (req, res) => { var _a; return res.sendFile(((_a = config.profileSettingsMenu) === null || _a === void 0 ? void 0 : _a.imagePath) || config.imagePath); });
19
- app.use('/settings', (0, ui_module_1.default)({ config, allowUnauthorized }), (0, render_ui_module_1.default)(config.profileSettingsMenu));
19
+ app.use('/logo/settings', (0, util_2.serveLogo)(config, config.profileSettingsMenu));
20
+ app.use('/settings', (0, ui_module_1.default)({ config, allowUnauthorized }), (0, render_ui_module_1.default)(config.profileSettingsMenu, config));
20
21
  // END TEMPORARY CODE
21
22
  }
22
23
  exports.register = register;
@@ -12,6 +12,6 @@ function register({ config, app }) {
12
12
  return;
13
13
  }
14
14
  const allowUnauthorized = !(0, util_1.isAuthorizedConfig)(config);
15
- app.use('/project-menu', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.projectMenu.key }), (0, render_ui_module_1.default)(config.projectMenu));
15
+ app.use('/project-menu', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.projectMenu.key }), (0, render_ui_module_1.default)(config.projectMenu, config));
16
16
  }
17
17
  exports.register = register;
@@ -12,6 +12,6 @@ function register({ config, app }) {
12
12
  return;
13
13
  }
14
14
  const allowUnauthorized = !(0, util_1.isAuthorizedConfig)(config);
15
- app.use('/project-menu-crowdsource', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.projectMenuCrowdsource.key }), (0, render_ui_module_1.default)(config.projectMenuCrowdsource));
15
+ app.use('/project-menu-crowdsource', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.projectMenuCrowdsource.key }), (0, render_ui_module_1.default)(config.projectMenuCrowdsource, config));
16
16
  }
17
17
  exports.register = register;
@@ -7,12 +7,13 @@ exports.register = void 0;
7
7
  const render_ui_module_1 = __importDefault(require("../../middlewares/render-ui-module"));
8
8
  const ui_module_1 = __importDefault(require("../../middlewares/ui-module"));
9
9
  const util_1 = require("../../util");
10
+ const util_2 = require("../../util");
10
11
  function register({ config, app }) {
11
12
  if (!config.projectReports) {
12
13
  return;
13
14
  }
14
15
  const allowUnauthorized = !(0, util_1.isAuthorizedConfig)(config);
15
- app.get((0, util_1.getLogoUrl)(config.projectReports, '/reports'), (req, res) => { var _a; return res.sendFile(((_a = config.projectReports) === null || _a === void 0 ? void 0 : _a.imagePath) || config.imagePath); });
16
- app.use('/reports', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.projectReports.key }), (0, render_ui_module_1.default)(config.projectReports));
16
+ app.use('/logo/reports', (0, util_2.serveLogo)(config, config.projectReports));
17
+ app.use('/reports', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.projectReports.key }), (0, render_ui_module_1.default)(config.projectReports, config));
17
18
  }
18
19
  exports.register = register;
@@ -7,12 +7,13 @@ exports.register = void 0;
7
7
  const render_ui_module_1 = __importDefault(require("../../middlewares/render-ui-module"));
8
8
  const ui_module_1 = __importDefault(require("../../middlewares/ui-module"));
9
9
  const util_1 = require("../../util");
10
+ const util_2 = require("../../util");
10
11
  function register({ config, app }) {
11
12
  if (!config.projectTools) {
12
13
  return;
13
14
  }
14
15
  const allowUnauthorized = !(0, util_1.isAuthorizedConfig)(config);
15
- app.get((0, util_1.getLogoUrl)(config.projectTools, '/tools'), (req, res) => { var _a; return res.sendFile(((_a = config.projectTools) === null || _a === void 0 ? void 0 : _a.imagePath) || config.imagePath); });
16
- app.use('/tools', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.projectTools.key }), (0, render_ui_module_1.default)(config.projectTools));
16
+ app.use('/logo/tools', (0, util_2.serveLogo)(config, config.projectTools));
17
+ app.use('/tools', (0, ui_module_1.default)({ config, allowUnauthorized, moduleType: config.projectTools.key }), (0, render_ui_module_1.default)(config.projectTools, config));
17
18
  }
18
19
  exports.register = register;
@@ -1,4 +1,4 @@
1
1
  /// <reference types="qs" />
2
2
  import { Request, Response } from 'express';
3
3
  import { Config, UnauthorizedConfig } from '../types';
4
- export default function handle(config: Config | UnauthorizedConfig): (req: import("../types").CrowdinClientRequest | Request<import("express-serve-static-core").ParamsDictionary, any, any, import("qs").ParsedQs, Record<string, any>>, res: Response<any, Record<string, any>>, next: Function) => void;
4
+ export default function handle(config: Config | UnauthorizedConfig): (req: Request<import("express-serve-static-core").ParamsDictionary, any, any, import("qs").ParsedQs, Record<string, any>> | import("../types").CrowdinClientRequest, res: Response<any, Record<string, any>>, next: Function) => void;
@@ -47,9 +47,18 @@ function handle(config) {
47
47
  let status = 'ok';
48
48
  let message = 'Filesystem access successful';
49
49
  try {
50
- const testFile = path_1.default.join(os_1.default.tmpdir(), 'status-check.txt');
51
- yield promises_1.default.writeFile(testFile, 'test');
52
- yield promises_1.default.unlink(testFile);
50
+ if (config.fileStore) {
51
+ // Use custom fileStore if provided
52
+ const testContent = Buffer.from('test');
53
+ const fileRef = yield config.fileStore.storeFile(testContent);
54
+ yield config.fileStore.deleteFile(fileRef);
55
+ }
56
+ else {
57
+ // Fallback to default filesystem operations
58
+ const testFile = path_1.default.join(os_1.default.tmpdir(), `status-check-${Date.now()}.txt`);
59
+ yield promises_1.default.writeFile(testFile, 'test');
60
+ yield promises_1.default.unlink(testFile);
61
+ }
53
62
  }
54
63
  catch (e) {
55
64
  status = 'error';
@@ -1,3 +1,3 @@
1
1
  /// <reference types="qs" />
2
2
  import { Request, Response } from 'express';
3
- export default function handle(): (req: import("../types").CrowdinClientRequest | Request<import("express-serve-static-core").ParamsDictionary, any, any, import("qs").ParsedQs, Record<string, any>>, res: Response<any, Record<string, any>>, next: Function) => void;
3
+ export default function handle(): (req: Request<import("express-serve-static-core").ParamsDictionary, any, any, import("qs").ParsedQs, Record<string, any>> | import("../types").CrowdinClientRequest, res: Response<any, Record<string, any>>, next: Function) => void;
@@ -1,4 +1,4 @@
1
1
  /// <reference types="qs" />
2
2
  import { Request, Response } from 'express';
3
3
  import { Config } from '../types';
4
- export default function handle(config: Config): (req: import("../types").CrowdinClientRequest | Request<import("express-serve-static-core").ParamsDictionary, any, any, import("qs").ParsedQs, Record<string, any>>, res: Response<any, Record<string, any>>, next: Function) => void;
4
+ export default function handle(config: Config): (req: Request<import("express-serve-static-core").ParamsDictionary, any, any, import("qs").ParsedQs, Record<string, any>> | import("../types").CrowdinClientRequest, res: Response<any, Record<string, any>>, next: Function) => void;
@@ -2,4 +2,4 @@
2
2
  import { Config, CrowdinClientRequest } from '../../../types';
3
3
  import { Response } from 'express';
4
4
  import { Webhook } from '../types';
5
- export declare function webhookHandler(config: Config, webhooks: Webhook[]): (req: CrowdinClientRequest | import("express").Request<import("express-serve-static-core").ParamsDictionary, any, any, import("qs").ParsedQs, Record<string, any>>, res: Response<any, Record<string, any>>, next: Function) => void;
5
+ export declare function webhookHandler(config: Config, webhooks: Webhook[]): (req: import("express").Request<import("express-serve-static-core").ParamsDictionary, any, any, import("qs").ParsedQs, Record<string, any>> | CrowdinClientRequest, res: Response<any, Record<string, any>>, next: Function) => void;
@@ -64,22 +64,37 @@ function webhookHandler(config, webhooks) {
64
64
  res.status(403).send({ error: 'Invalid signature' });
65
65
  return;
66
66
  }
67
- res.status(200).send();
68
- const { client } = yield (0, connection_1.prepareCrowdinClient)({ config, credentials, autoRenew: true });
69
- const json = JSON.parse(req.body.toString());
70
- for (const webhook of webhooks) {
71
- if (webhook.key === moduleKey) {
72
- yield webhook.callback({
73
- events: json.events,
74
- client,
75
- webhookContext: {
76
- domain: credentials.domain,
77
- organizationId: credentials.organizationId,
78
- userId: credentials.userId,
79
- agentId: credentials.agentId,
80
- },
81
- });
67
+ const shouldDeferResponse = webhooks.some((webhook) => webhook.key === moduleKey && webhook.deferResponse);
68
+ if (!shouldDeferResponse) {
69
+ res.status(200).send();
70
+ }
71
+ try {
72
+ const { client } = yield (0, connection_1.prepareCrowdinClient)({ config, credentials, autoRenew: true });
73
+ const json = JSON.parse(req.body.toString());
74
+ for (const webhook of webhooks) {
75
+ if (webhook.key === moduleKey) {
76
+ yield webhook.callback({
77
+ events: json.events,
78
+ client,
79
+ webhookContext: {
80
+ domain: credentials.domain,
81
+ organizationId: credentials.organizationId,
82
+ userId: credentials.userId,
83
+ agentId: credentials.agentId,
84
+ },
85
+ });
86
+ }
87
+ }
88
+ if (!shouldDeferResponse) {
89
+ return;
90
+ }
91
+ res.status(200).send();
92
+ }
93
+ catch (error) {
94
+ if (!shouldDeferResponse) {
95
+ throw error;
82
96
  }
97
+ res.status(500).send({ error: 'Webhook processing failed' });
83
98
  }
84
99
  }));
85
100
  }
@@ -13,6 +13,13 @@ export interface Webhook extends ModuleKey {
13
13
  events: Event[];
14
14
  client: Crowdin;
15
15
  }) => Promise<void>;
16
+ /**
17
+ * If true, response will be sent after webhook processing is complete.
18
+ * This is required for Cloudflare Workers where the execution context
19
+ * terminates after the response is sent.
20
+ * Default: false (response is sent immediately after signature verification)
21
+ */
22
+ deferResponse?: boolean;
16
23
  }
17
24
  interface WebhookContext {
18
25
  domain?: string;
@@ -2,4 +2,4 @@
2
2
  import { Response } from 'express';
3
3
  import { CrowdinClientRequest } from '../../../types';
4
4
  import { WorkflowStepTypeModule } from '../types';
5
- export default function handle(workflowStep: WorkflowStepTypeModule): (req: CrowdinClientRequest | import("express").Request<import("express-serve-static-core").ParamsDictionary, any, any, import("qs").ParsedQs, Record<string, any>>, res: Response<any, Record<string, any>>, next: Function) => void;
5
+ export default function handle(workflowStep: WorkflowStepTypeModule): (req: import("express").Request<import("express-serve-static-core").ParamsDictionary, any, any, import("qs").ParsedQs, Record<string, any>> | CrowdinClientRequest, res: Response<any, Record<string, any>>, next: Function) => void;
@@ -2,4 +2,4 @@
2
2
  import { Response } from 'express';
3
3
  import { CrowdinClientRequest } from '../../../types';
4
4
  import { WorkflowStepTypeModule } from '../types';
5
- export default function handle(workflowStep: WorkflowStepTypeModule): (req: CrowdinClientRequest | import("express").Request<import("express-serve-static-core").ParamsDictionary, any, any, import("qs").ParsedQs, Record<string, any>>, res: Response<any, Record<string, any>>, next: Function) => void;
5
+ export default function handle(workflowStep: WorkflowStepTypeModule): (req: import("express").Request<import("express-serve-static-core").ParamsDictionary, any, any, import("qs").ParsedQs, Record<string, any>> | CrowdinClientRequest, res: Response<any, Record<string, any>>, next: Function) => void;
@@ -42,10 +42,10 @@ function register({ config, app }) {
42
42
  }), (0, delete_step_1.default)(workflowStep));
43
43
  // END TEMPORARY CODE
44
44
  if (workflowStep.imagePath) {
45
- app.get((0, util_2.getLogoUrl)(workflowStep, `-${workflowStep.key}`), (req, res) => res.sendFile(workflowStep.imagePath || config.imagePath));
45
+ app.use(`/logo-${workflowStep.key}`, (0, util_2.serveLogo)(config, workflowStep));
46
46
  }
47
47
  if (workflowStep.settingsUiModule) {
48
- app.use((0, util_1.getWorkflowStepUrl)('/workflow-step', workflowStep), (0, ui_module_1.default)({ config, moduleType: workflowStep.key }), (0, render_ui_module_1.default)(workflowStep.settingsUiModule));
48
+ app.use((0, util_1.getWorkflowStepUrl)('/workflow-step', workflowStep), (0, ui_module_1.default)({ config, moduleType: workflowStep.key }), (0, render_ui_module_1.default)(workflowStep.settingsUiModule, config));
49
49
  }
50
50
  }
51
51
  }
@@ -0,0 +1,107 @@
1
+ import type { D1Database } from '@cloudflare/workers-types';
2
+ import { Storage } from '.';
3
+ import { CrowdinCredentials } from '../types';
4
+ import { IntegrationConfig, IntegrationCredentials, IntegrationFilesSnapshot, IntegrationSyncSettings, IntegrationWebhooks } from '../modules/integration/types';
5
+ import { CreateJobParams, GetActiveJobsParams, GetJobParams, GetFileTranslationCacheByLanguageParams, Job, TranslationCache, UpdateJobParams, UpdateTranslationCacheParams, GetFileTranslationCache, UnsyncedFiles, GetUnsyncedFiles, IntegrationSyncedData, GetAllJobsParams } from '../modules/integration/util/types';
6
+ import { UserErrors } from './types';
7
+ export interface D1StorageConfig {
8
+ /**
9
+ * Cloudflare D1 database binding
10
+ * This should be passed from env.DB in Workers/Pages Functions
11
+ */
12
+ database: D1Database;
13
+ }
14
+ export declare class D1Storage implements Storage {
15
+ private db;
16
+ private migrated;
17
+ tables: {
18
+ crowdin_credentials: string;
19
+ integration_credentials: string;
20
+ sync_settings: string;
21
+ app_metadata: string;
22
+ files_snapshot: string;
23
+ webhooks: string;
24
+ user_errors: string;
25
+ integration_settings: string;
26
+ job: string;
27
+ translation_file_cache: string;
28
+ unsynced_files: string;
29
+ synced_data: string;
30
+ };
31
+ constructor(config: D1StorageConfig);
32
+ ensureMigrated(): Promise<void>;
33
+ private addColumn;
34
+ private updateTables;
35
+ migrate(): Promise<void>;
36
+ saveCrowdinCredentials(credentials: CrowdinCredentials): Promise<void>;
37
+ updateCrowdinCredentials(credentials: CrowdinCredentials): Promise<void>;
38
+ getCrowdinCredentials(id: string): Promise<CrowdinCredentials | undefined>;
39
+ getAllCrowdinCredentials(): Promise<CrowdinCredentials[]>;
40
+ deleteCrowdinCredentials(id: string): Promise<void>;
41
+ saveIntegrationCredentials(id: string, credentials: any, crowdinId: string): Promise<void>;
42
+ updateIntegrationCredentials(id: string, credentials: any): Promise<void>;
43
+ updateIntegrationManagers(id: string, managers: any): Promise<void>;
44
+ getIntegrationCredentials(id: string): Promise<IntegrationCredentials | undefined>;
45
+ getAllIntegrationCredentials(crowdinId: string): Promise<IntegrationCredentials[]>;
46
+ deleteIntegrationCredentials(id: string): Promise<void>;
47
+ deleteAllIntegrationCredentials(crowdinId: string): Promise<void>;
48
+ saveMetadata(id: string, metadata: any, crowdinId: string): Promise<void>;
49
+ updateMetadata(id: string, metadata: any, crowdinId: string): Promise<void>;
50
+ getMetadata(id: string): Promise<any>;
51
+ getAllMetadata(): Promise<any[]>;
52
+ deleteMetadata(id: string): Promise<void>;
53
+ getSyncSettingsByProvider(integrationId: string, provider: string): Promise<IntegrationSyncSettings | undefined>;
54
+ getSyncSettingsBySchedule(type: string, schedule: string): Promise<IntegrationSyncSettings[]>;
55
+ saveSyncSettings(files: any, integrationId: string, crowdinId: string, type: string, provider: string): Promise<void>;
56
+ updateSyncSettings(files: any, integrationId: string, crowdinId: string, type: string, provider: string): Promise<void>;
57
+ getSyncSettings(integrationId: string, crowdinId: string, type: string, provider: string): Promise<IntegrationSyncSettings | undefined>;
58
+ saveFilesSnapshot(files: any, integrationId: string, crowdinId: string, provider: string): Promise<void>;
59
+ updateFilesSnapshot(files: any, integrationId: string, crowdinId: string, provider: string): Promise<void>;
60
+ getFilesSnapshot(integrationId: string, crowdinId: string, provider: string): Promise<IntegrationFilesSnapshot | undefined>;
61
+ getAllWebhooks(integrationId: string, crowdinId: string, provider: string): Promise<IntegrationWebhooks[] | undefined>;
62
+ getWebhooks(fileId: string, integrationId: string, crowdinId: string, provider: string): Promise<IntegrationWebhooks | undefined>;
63
+ saveWebhooks(fileId: string, integrationId: string, crowdinId: string, provider: string): Promise<void>;
64
+ deleteWebhooks(fileIds: any[], integrationId: string, crowdinId: string, provider: string): Promise<void>;
65
+ getAllUserErrors(crowdinId: string, integrationId?: string): Promise<UserErrors[] | undefined>;
66
+ saveUserError(action: string, message: string, data: any, createdAt: string, crowdinId: string, integrationId?: string): Promise<void>;
67
+ deleteUserErrors(date: string, crowdinId: string, integrationId?: string): Promise<void>;
68
+ deleteAllUsersErrorsOlderThan(date: string): Promise<void>;
69
+ saveIntegrationConfig(integrationId: string, crowdinId: string, config: any): Promise<void>;
70
+ getAllIntegrationConfigs(crowdinId: string): Promise<IntegrationConfig[]>;
71
+ getIntegrationConfig(integrationId: string): Promise<IntegrationConfig | undefined>;
72
+ updateIntegrationConfig(integrationId: string, config: any): Promise<void>;
73
+ createJob(params: CreateJobParams): Promise<string>;
74
+ updateJob(params: UpdateJobParams): Promise<void>;
75
+ getJob(params: GetJobParams): Promise<Job | undefined>;
76
+ getActiveJobs(params: GetActiveJobsParams): Promise<Job[] | undefined>;
77
+ deleteFinishedJobs(): Promise<void>;
78
+ getAllInProgressJobs(): Promise<Job[] | undefined>;
79
+ getAllJobs(params: GetAllJobsParams): Promise<Job[] | undefined>;
80
+ saveTranslationCache(params: TranslationCache): Promise<void>;
81
+ getFileTranslationCache(params: GetFileTranslationCache): Promise<TranslationCache[] | undefined>;
82
+ getFileTranslationCacheByLanguage(params: GetFileTranslationCacheByLanguageParams): Promise<TranslationCache | undefined>;
83
+ updateTranslationCache(params: UpdateTranslationCacheParams): Promise<void>;
84
+ saveUnsyncedFiles(params: UnsyncedFiles): Promise<void>;
85
+ updateUnsyncedFiles(params: UnsyncedFiles): Promise<void>;
86
+ getUnsyncedFiles(params: GetUnsyncedFiles): Promise<UnsyncedFiles | undefined>;
87
+ registerCustomTable(tableName: string, schema: Record<string, string>): Promise<void>;
88
+ insertRecord(tableName: string, data: Record<string, any>): Promise<void>;
89
+ selectRecords(tableName: string, options?: {
90
+ columns?: string[];
91
+ whereClause?: string;
92
+ orderBy?: string;
93
+ limit?: number;
94
+ offset?: number;
95
+ distinct?: boolean;
96
+ }, params?: any[]): Promise<any[]>;
97
+ updateRecord(tableName: string, data: Record<string, any>, whereClause: string, params?: any[]): Promise<void>;
98
+ deleteRecord(tableName: string, whereClause: string, params?: any[]): Promise<void>;
99
+ saveSyncedData(files: any, integrationId: string, crowdinId: string, type: string): Promise<void>;
100
+ updateSyncedData(files: any, integrationId: string, crowdinId: string, type: string): Promise<void>;
101
+ getSyncedData(integrationId: string, crowdinId: string, type: string): Promise<IntegrationSyncedData | undefined>;
102
+ /**
103
+ * Converts undefined values to null for D1 compatibility
104
+ * D1 does not support undefined values, so we convert them to null
105
+ */
106
+ private sanitizeBindValues;
107
+ }