@resolveio/server-lib 22.2.33 → 22.2.34

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 (649) hide show
  1. package/.github/workflows/ai-assistant-nightly-eval.yml +224 -0
  2. package/.github/workflows/ai-assistant-pr-guardrails.yml +60 -0
  3. package/.nodemon.json +5 -0
  4. package/.vscode/settings.json +21 -0
  5. package/AGENTS.md +179 -0
  6. package/README.md +22 -0
  7. package/build_package.sh +5 -0
  8. package/compileDTS.pl +64 -0
  9. package/docs/ai-assistant-nightly-eval.md +65 -0
  10. package/docs/ai-assistant-preflight-checklist.md +23 -0
  11. package/docs/ai-assistant-report-builder-bridge-playbook.md +115 -0
  12. package/eslint-plugin-custom/index.js +7 -0
  13. package/eslint-plugin-custom/rules/no-filter-zero-index.js +44 -0
  14. package/eslint.config.js +103 -0
  15. package/gulpfile.js +216 -0
  16. package/methodAndPublicationListGenerator.py +319 -0
  17. package/mongodbensurers.js +2 -0
  18. package/mongostop.js +3 -0
  19. package/package.json +1 -1
  20. package/settings.development.json +25 -0
  21. package/settings.development.redacted.json +25 -0
  22. package/src/.env +12 -0
  23. package/src/ai/assistant-core-heuristics.ts +577 -0
  24. package/src/client-server-app.ts +12 -0
  25. package/src/collections/ai-terminal-conversation.collection.ts +91 -0
  26. package/src/collections/ai-terminal-issue-report.collection.ts +99 -0
  27. package/src/collections/ai-terminal-message.collection.ts +77 -0
  28. package/src/collections/app-setting.collection.ts +104 -0
  29. package/src/collections/app-status.collection.ts +58 -0
  30. package/src/collections/communication-metric.collection.ts +84 -0
  31. package/src/collections/counter.collection.ts +56 -0
  32. package/src/collections/cron-job-history.collection.ts +94 -0
  33. package/src/collections/cron-job.collection.ts +92 -0
  34. package/src/collections/customer-notification.collection.ts +131 -0
  35. package/src/collections/customer-portal-password.collection.ts +76 -0
  36. package/src/collections/email-history.collection.ts +121 -0
  37. package/src/collections/email-verified.collection.ts +61 -0
  38. package/src/collections/file.collection.ts +74 -0
  39. package/src/collections/flag-update.collection.ts +57 -0
  40. package/src/collections/flag.collection.ts +57 -0
  41. package/src/collections/log-method-latency.collection.ts +77 -0
  42. package/src/collections/log-subscription.collection.ts +80 -0
  43. package/src/collections/log.collection.ts +93 -0
  44. package/src/collections/logged-in-users.collection.ts +67 -0
  45. package/src/collections/monitor-cpu.collection.ts +65 -0
  46. package/src/collections/monitor-function.collection.ts +74 -0
  47. package/src/collections/monitor-memory.collection.ts +77 -0
  48. package/src/collections/monitor-mongo.collection.ts +71 -0
  49. package/src/collections/notification.collection.ts +57 -0
  50. package/src/collections/openai-usage-ledger.collection.ts +77 -0
  51. package/src/collections/report-builder-dashboard-builder.collection.ts +109 -0
  52. package/src/collections/report-builder-library.collection.ts +89 -0
  53. package/src/collections/report-builder-report.collection.ts +180 -0
  54. package/src/collections/user-group.collection.ts +89 -0
  55. package/src/collections/user-guide.collection.ts +57 -0
  56. package/src/collections/user.collection.ts +181 -0
  57. package/src/cron/cron.ts +117 -0
  58. package/src/fixtures/cron-jobs.ts +95 -0
  59. package/src/fixtures/init.ts +35 -0
  60. package/src/http/auth.ts +764 -0
  61. package/src/http/health.ts +7 -0
  62. package/src/http/home.ts +90 -0
  63. package/src/http/slow-query-publication.ts +49 -0
  64. package/src/index.ts +1 -0
  65. package/src/managers/communication-metric.manager.ts +82 -0
  66. package/src/managers/cron.manager.ts +333 -0
  67. package/src/managers/customer-notification-content.manager.ts +236 -0
  68. package/src/managers/diagnostic-manager-bootstrap.ts +165 -0
  69. package/src/managers/error-auto-fix.manager.ts +2767 -0
  70. package/src/managers/local-log.manager.ts +113 -0
  71. package/src/managers/method.manager.ts +1557 -0
  72. package/src/managers/mongo.manager.ts +4566 -0
  73. package/src/managers/monitor.manager.ts +489 -0
  74. package/src/managers/openai-usage-ledger.manager.ts +116 -0
  75. package/src/managers/slow-query-verifier.manager.ts +3590 -0
  76. package/src/managers/slow-query.manager.ts +519 -0
  77. package/src/managers/subscription.manager.ts +3120 -0
  78. package/src/managers/websocket.manager.ts +746 -0
  79. package/src/managers/worker-dispatcher.manager.ts +1318 -0
  80. package/src/managers/worker-server.manager.ts +468 -0
  81. package/src/methods/accounts.ts +532 -0
  82. package/src/methods/ai-terminal.ts +25505 -0
  83. package/src/methods/app-settings.ts +114 -0
  84. package/src/methods/aws.ts +646 -0
  85. package/src/methods/collections.ts +544 -0
  86. package/src/methods/counters.ts +67 -0
  87. package/src/methods/cron-jobs.ts +2610 -0
  88. package/src/methods/customer-notifications.ts +458 -0
  89. package/src/methods/diagnostics.ts +447 -0
  90. package/src/methods/flag-updates.ts +7 -0
  91. package/src/methods/flags.ts +7 -0
  92. package/src/methods/logs.ts +656 -0
  93. package/src/methods/mongo-explorer.ts +1883 -0
  94. package/src/methods/monitor.ts +540 -0
  95. package/src/methods/pdf.ts +1210 -0
  96. package/src/methods/publications.ts +128 -0
  97. package/src/methods/report-builder.ts +3305 -0
  98. package/src/methods/support.ts +210 -0
  99. package/src/models/ai-terminal-conversation.model.ts +19 -0
  100. package/src/models/ai-terminal-issue-report.model.ts +21 -0
  101. package/src/models/ai-terminal-message.model.ts +24 -0
  102. package/src/models/app-setting.model.ts +17 -0
  103. package/{models/app-status.model.d.ts → src/models/app-status.model.ts} +3 -2
  104. package/{models/billing-logged-in-users.model.d.ts → src/models/billing-logged-in-users.model.ts} +5 -4
  105. package/src/models/collection-document.model.ts +24 -0
  106. package/src/models/communication-metric.model.ts +23 -0
  107. package/{models/counter.model.d.ts → src/models/counter.model.ts} +4 -3
  108. package/src/models/cron-job-history.model.ts +16 -0
  109. package/src/models/cron-job.model.ts +15 -0
  110. package/src/models/customer-notification.model.ts +28 -0
  111. package/src/models/customer-portal-password.model.ts +12 -0
  112. package/src/models/dialog.model.ts +25 -0
  113. package/{models/email-history.model.js → src/models/email-history.model.ts} +34 -4
  114. package/{models/email-verified.model.d.ts → src/models/email-verified.model.ts} +6 -5
  115. package/{models/file.model.d.ts → src/models/file.model.ts} +8 -7
  116. package/{models/flag-update.model.d.ts → src/models/flag-update.model.ts} +4 -3
  117. package/{models/flag.model.d.ts → src/models/flag.model.ts} +4 -3
  118. package/src/models/log-method-latency.model.ts +11 -0
  119. package/{models/log-subscription.model.d.ts → src/models/log-subscription.model.ts} +11 -9
  120. package/src/models/log.model.ts +19 -0
  121. package/{models/logged-in-users.model.d.ts → src/models/logged-in-users.model.ts} +6 -5
  122. package/{models/method-response.model.d.ts → src/models/method-response.model.ts} +7 -6
  123. package/src/models/method.model.ts +23 -0
  124. package/{models/monitor-cpu.model.d.ts → src/models/monitor-cpu.model.ts} +9 -7
  125. package/src/models/monitor-function.model.ts +16 -0
  126. package/src/models/monitor-memory.model.ts +17 -0
  127. package/src/models/monitor-mongo.model.ts +15 -0
  128. package/{models/notification.model.d.ts → src/models/notification.model.ts} +6 -4
  129. package/src/models/openai-usage-ledger.model.ts +16 -0
  130. package/src/models/pagination.model.ts +35 -0
  131. package/src/models/permission.model.ts +14 -0
  132. package/src/models/report-builder-dashboard-builder.model.ts +29 -0
  133. package/src/models/report-builder-library.model.ts +20 -0
  134. package/src/models/report-builder-report.model.ts +135 -0
  135. package/src/models/report-builder.model.ts +68 -0
  136. package/src/models/select-data-label.model.ts +9 -0
  137. package/src/models/server-message.model.ts +31 -0
  138. package/src/models/slow-query-report.model.ts +23 -0
  139. package/src/models/subscription.model.ts +73 -0
  140. package/src/models/support-ticket.model.ts +96 -0
  141. package/src/models/user-group.model.ts +24 -0
  142. package/{models/user-guide.model.d.ts → src/models/user-guide.model.ts} +5 -4
  143. package/src/models/user.model.ts +96 -0
  144. package/src/private/images/ResolveIO.png +0 -0
  145. package/src/publications/ai-terminal.ts +73 -0
  146. package/src/publications/app-settings.ts +25 -0
  147. package/src/publications/app-status.ts +13 -0
  148. package/src/publications/cron-jobs.ts +29 -0
  149. package/src/publications/customer-notifications.ts +101 -0
  150. package/src/publications/files.ts +33 -0
  151. package/src/publications/flags-update.ts +19 -0
  152. package/src/publications/flags.ts +19 -0
  153. package/src/publications/logs.ts +163 -0
  154. package/src/publications/notifications.ts +13 -0
  155. package/src/publications/report-builder-dashboard-builders.ts +39 -0
  156. package/src/publications/report-builder-libraries.ts +41 -0
  157. package/src/publications/report-builder-reports.ts +47 -0
  158. package/src/publications/super-admin.ts +13 -0
  159. package/src/publications/user-groups.ts +12 -0
  160. package/src/publications/user-guides.ts +12 -0
  161. package/src/resolveio-server-app.ts +617 -0
  162. package/src/server-app.ts +2616 -0
  163. package/src/services/codex-client.ts +1117 -0
  164. package/src/services/openai-client.ts +265 -0
  165. package/src/types/error-report.ts +26 -0
  166. package/src/types/js-tiktoken.d.ts +11 -0
  167. package/src/types/slow-query-report.ts +28 -0
  168. package/src/util/common.ts +649 -0
  169. package/src/util/customer-portal-password.ts +183 -0
  170. package/src/util/error-reporter.ts +332 -0
  171. package/src/util/error-tracking.ts +79 -0
  172. package/src/util/report-builder-unwinds.ts +180 -0
  173. package/src/util/schema-report-builder.ts +448 -0
  174. package/src/util/slow-query-reporter.ts +216 -0
  175. package/src/util/subscription-dependency-context.ts +1096 -0
  176. package/src/util/tokenizer.ts +38 -0
  177. package/src/workers/codex-runner.worker.ts +142 -0
  178. package/start_server.sh +5 -0
  179. package/tests/ai-assistant-corpus-build.ts +484 -0
  180. package/tests/ai-assistant-corpus-replay-e2e.ts +773 -0
  181. package/tests/ai-assistant-data-parity-e2e.ts +2018 -0
  182. package/tests/ai-assistant-eval-triage.ts +831 -0
  183. package/tests/ai-assistant-openai-e2e.ts +1061 -0
  184. package/tests/ai-assistant-openai-git-e2e.ts +155 -0
  185. package/tests/ai-assistant-preflight-matrix.ts +215 -0
  186. package/tests/ai-assistant-routing-eval.test.ts +560 -0
  187. package/tests/ai-assistant-snf-live-eval.ts +921 -0
  188. package/tests/ai-assistant-utils.test.ts +2165 -0
  189. package/tests/error-reporter.test.ts +145 -0
  190. package/tests/report-builder-linking.test.ts +79 -0
  191. package/tests/subscription-connect-race.test.ts +157 -0
  192. package/tests/subscription-dependency-context.test.ts +324 -0
  193. package/tests/subscription-manager-collection-tracking.test.ts +86 -0
  194. package/tests/subscription-manager-invalidation.test.ts +85 -0
  195. package/tsconfig.json +34 -0
  196. package/ai/assistant-core-heuristics.d.ts +0 -11
  197. package/ai/assistant-core-heuristics.js +0 -531
  198. package/ai/assistant-core-heuristics.js.map +0 -1
  199. package/client-server-app.d.ts +0 -1
  200. package/client-server-app.js +0 -68
  201. package/client-server-app.js.map +0 -1
  202. package/collections/ai-terminal-conversation.collection.d.ts +0 -2
  203. package/collections/ai-terminal-conversation.collection.js +0 -140
  204. package/collections/ai-terminal-conversation.collection.js.map +0 -1
  205. package/collections/ai-terminal-issue-report.collection.d.ts +0 -2
  206. package/collections/ai-terminal-issue-report.collection.js +0 -148
  207. package/collections/ai-terminal-issue-report.collection.js.map +0 -1
  208. package/collections/ai-terminal-message.collection.d.ts +0 -2
  209. package/collections/ai-terminal-message.collection.js +0 -121
  210. package/collections/ai-terminal-message.collection.js.map +0 -1
  211. package/collections/app-setting.collection.d.ts +0 -3
  212. package/collections/app-setting.collection.js +0 -103
  213. package/collections/app-setting.collection.js.map +0 -1
  214. package/collections/app-status.collection.d.ts +0 -3
  215. package/collections/app-status.collection.js +0 -57
  216. package/collections/app-status.collection.js.map +0 -1
  217. package/collections/communication-metric.collection.d.ts +0 -2
  218. package/collections/communication-metric.collection.js +0 -133
  219. package/collections/communication-metric.collection.js.map +0 -1
  220. package/collections/counter.collection.d.ts +0 -3
  221. package/collections/counter.collection.js +0 -56
  222. package/collections/counter.collection.js.map +0 -1
  223. package/collections/cron-job-history.collection.d.ts +0 -3
  224. package/collections/cron-job-history.collection.js +0 -137
  225. package/collections/cron-job-history.collection.js.map +0 -1
  226. package/collections/cron-job.collection.d.ts +0 -3
  227. package/collections/cron-job.collection.js +0 -92
  228. package/collections/cron-job.collection.js.map +0 -1
  229. package/collections/customer-notification.collection.d.ts +0 -3
  230. package/collections/customer-notification.collection.js +0 -130
  231. package/collections/customer-notification.collection.js.map +0 -1
  232. package/collections/customer-portal-password.collection.d.ts +0 -3
  233. package/collections/customer-portal-password.collection.js +0 -75
  234. package/collections/customer-portal-password.collection.js.map +0 -1
  235. package/collections/email-history.collection.d.ts +0 -3
  236. package/collections/email-history.collection.js +0 -121
  237. package/collections/email-history.collection.js.map +0 -1
  238. package/collections/email-verified.collection.d.ts +0 -3
  239. package/collections/email-verified.collection.js +0 -61
  240. package/collections/email-verified.collection.js.map +0 -1
  241. package/collections/file.collection.d.ts +0 -3
  242. package/collections/file.collection.js +0 -74
  243. package/collections/file.collection.js.map +0 -1
  244. package/collections/flag-update.collection.d.ts +0 -3
  245. package/collections/flag-update.collection.js +0 -57
  246. package/collections/flag-update.collection.js.map +0 -1
  247. package/collections/flag.collection.d.ts +0 -3
  248. package/collections/flag.collection.js +0 -57
  249. package/collections/flag.collection.js.map +0 -1
  250. package/collections/log-method-latency.collection.d.ts +0 -3
  251. package/collections/log-method-latency.collection.js +0 -77
  252. package/collections/log-method-latency.collection.js.map +0 -1
  253. package/collections/log-subscription.collection.d.ts +0 -3
  254. package/collections/log-subscription.collection.js +0 -80
  255. package/collections/log-subscription.collection.js.map +0 -1
  256. package/collections/log.collection.d.ts +0 -3
  257. package/collections/log.collection.js +0 -93
  258. package/collections/log.collection.js.map +0 -1
  259. package/collections/logged-in-users.collection.d.ts +0 -3
  260. package/collections/logged-in-users.collection.js +0 -67
  261. package/collections/logged-in-users.collection.js.map +0 -1
  262. package/collections/monitor-cpu.collection.d.ts +0 -3
  263. package/collections/monitor-cpu.collection.js +0 -65
  264. package/collections/monitor-cpu.collection.js.map +0 -1
  265. package/collections/monitor-function.collection.d.ts +0 -3
  266. package/collections/monitor-function.collection.js +0 -74
  267. package/collections/monitor-function.collection.js.map +0 -1
  268. package/collections/monitor-memory.collection.d.ts +0 -3
  269. package/collections/monitor-memory.collection.js +0 -77
  270. package/collections/monitor-memory.collection.js.map +0 -1
  271. package/collections/monitor-mongo.collection.d.ts +0 -3
  272. package/collections/monitor-mongo.collection.js +0 -71
  273. package/collections/monitor-mongo.collection.js.map +0 -1
  274. package/collections/notification.collection.d.ts +0 -3
  275. package/collections/notification.collection.js +0 -57
  276. package/collections/notification.collection.js.map +0 -1
  277. package/collections/openai-usage-ledger.collection.d.ts +0 -2
  278. package/collections/openai-usage-ledger.collection.js +0 -124
  279. package/collections/openai-usage-ledger.collection.js.map +0 -1
  280. package/collections/report-builder-dashboard-builder.collection.d.ts +0 -3
  281. package/collections/report-builder-dashboard-builder.collection.js +0 -109
  282. package/collections/report-builder-dashboard-builder.collection.js.map +0 -1
  283. package/collections/report-builder-library.collection.d.ts +0 -3
  284. package/collections/report-builder-library.collection.js +0 -87
  285. package/collections/report-builder-library.collection.js.map +0 -1
  286. package/collections/report-builder-report.collection.d.ts +0 -4
  287. package/collections/report-builder-report.collection.js +0 -180
  288. package/collections/report-builder-report.collection.js.map +0 -1
  289. package/collections/user-group.collection.d.ts +0 -4
  290. package/collections/user-group.collection.js +0 -89
  291. package/collections/user-group.collection.js.map +0 -1
  292. package/collections/user-guide.collection.d.ts +0 -3
  293. package/collections/user-guide.collection.js +0 -57
  294. package/collections/user-guide.collection.js.map +0 -1
  295. package/collections/user.collection.d.ts +0 -4
  296. package/collections/user.collection.js +0 -180
  297. package/collections/user.collection.js.map +0 -1
  298. package/cron/cron.d.ts +0 -14
  299. package/cron/cron.js +0 -216
  300. package/cron/cron.js.map +0 -1
  301. package/fixtures/cron-jobs.d.ts +0 -1
  302. package/fixtures/cron-jobs.js +0 -150
  303. package/fixtures/cron-jobs.js.map +0 -1
  304. package/fixtures/init.d.ts +0 -1
  305. package/fixtures/init.js +0 -91
  306. package/fixtures/init.js.map +0 -1
  307. package/http/auth.d.ts +0 -2
  308. package/http/auth.js +0 -903
  309. package/http/auth.js.map +0 -1
  310. package/http/health.d.ts +0 -1
  311. package/http/health.js +0 -11
  312. package/http/health.js.map +0 -1
  313. package/http/home.d.ts +0 -1
  314. package/http/home.js +0 -134
  315. package/http/home.js.map +0 -1
  316. package/http/slow-query-publication.d.ts +0 -2
  317. package/http/slow-query-publication.js +0 -99
  318. package/http/slow-query-publication.js.map +0 -1
  319. package/index.d.ts +0 -1
  320. package/index.js +0 -19
  321. package/index.js.map +0 -1
  322. package/managers/communication-metric.manager.d.ts +0 -16
  323. package/managers/communication-metric.manager.js +0 -134
  324. package/managers/communication-metric.manager.js.map +0 -1
  325. package/managers/cron.manager.d.ts +0 -20
  326. package/managers/cron.manager.js +0 -534
  327. package/managers/cron.manager.js.map +0 -1
  328. package/managers/customer-notification-content.manager.d.ts +0 -55
  329. package/managers/customer-notification-content.manager.js +0 -158
  330. package/managers/customer-notification-content.manager.js.map +0 -1
  331. package/managers/diagnostic-manager-bootstrap.d.ts +0 -9
  332. package/managers/diagnostic-manager-bootstrap.js +0 -260
  333. package/managers/diagnostic-manager-bootstrap.js.map +0 -1
  334. package/managers/error-auto-fix.manager.d.ts +0 -149
  335. package/managers/error-auto-fix.manager.js +0 -3064
  336. package/managers/error-auto-fix.manager.js.map +0 -1
  337. package/managers/local-log.manager.d.ts +0 -18
  338. package/managers/local-log.manager.js +0 -88
  339. package/managers/local-log.manager.js.map +0 -1
  340. package/managers/method.manager.d.ts +0 -77
  341. package/managers/method.manager.js +0 -1701
  342. package/managers/method.manager.js.map +0 -1
  343. package/managers/mongo.manager.d.ts +0 -222
  344. package/managers/mongo.manager.js +0 -4984
  345. package/managers/mongo.manager.js.map +0 -1
  346. package/managers/monitor.manager.d.ts +0 -69
  347. package/managers/monitor.manager.js +0 -534
  348. package/managers/monitor.manager.js.map +0 -1
  349. package/managers/openai-usage-ledger.manager.d.ts +0 -15
  350. package/managers/openai-usage-ledger.manager.js +0 -144
  351. package/managers/openai-usage-ledger.manager.js.map +0 -1
  352. package/managers/slow-query-verifier.manager.d.ts +0 -144
  353. package/managers/slow-query-verifier.manager.js +0 -3857
  354. package/managers/slow-query-verifier.manager.js.map +0 -1
  355. package/managers/slow-query.manager.d.ts +0 -28
  356. package/managers/slow-query.manager.js +0 -468
  357. package/managers/slow-query.manager.js.map +0 -1
  358. package/managers/subscription.manager.d.ts +0 -169
  359. package/managers/subscription.manager.js +0 -3422
  360. package/managers/subscription.manager.js.map +0 -1
  361. package/managers/websocket.manager.d.ts +0 -73
  362. package/managers/websocket.manager.js +0 -673
  363. package/managers/websocket.manager.js.map +0 -1
  364. package/managers/worker-dispatcher.manager.d.ts +0 -117
  365. package/managers/worker-dispatcher.manager.js +0 -1210
  366. package/managers/worker-dispatcher.manager.js.map +0 -1
  367. package/managers/worker-server.manager.d.ts +0 -16
  368. package/managers/worker-server.manager.js +0 -530
  369. package/managers/worker-server.manager.js.map +0 -1
  370. package/methods/accounts.d.ts +0 -2
  371. package/methods/accounts.js +0 -624
  372. package/methods/accounts.js.map +0 -1
  373. package/methods/ai-terminal.d.ts +0 -304
  374. package/methods/ai-terminal.js +0 -25096
  375. package/methods/ai-terminal.js.map +0 -1
  376. package/methods/app-settings.d.ts +0 -2
  377. package/methods/app-settings.js +0 -169
  378. package/methods/app-settings.js.map +0 -1
  379. package/methods/aws.d.ts +0 -2
  380. package/methods/aws.js +0 -874
  381. package/methods/aws.js.map +0 -1
  382. package/methods/collections.d.ts +0 -2
  383. package/methods/collections.js +0 -626
  384. package/methods/collections.js.map +0 -1
  385. package/methods/counters.d.ts +0 -2
  386. package/methods/counters.js +0 -111
  387. package/methods/counters.js.map +0 -1
  388. package/methods/cron-jobs.d.ts +0 -2
  389. package/methods/cron-jobs.js +0 -2471
  390. package/methods/cron-jobs.js.map +0 -1
  391. package/methods/customer-notifications.d.ts +0 -2
  392. package/methods/customer-notifications.js +0 -528
  393. package/methods/customer-notifications.js.map +0 -1
  394. package/methods/diagnostics.d.ts +0 -2
  395. package/methods/diagnostics.js +0 -514
  396. package/methods/diagnostics.js.map +0 -1
  397. package/methods/flag-updates.d.ts +0 -2
  398. package/methods/flag-updates.js +0 -8
  399. package/methods/flag-updates.js.map +0 -1
  400. package/methods/flags.d.ts +0 -2
  401. package/methods/flags.js +0 -8
  402. package/methods/flags.js.map +0 -1
  403. package/methods/logs.d.ts +0 -2
  404. package/methods/logs.js +0 -750
  405. package/methods/logs.js.map +0 -1
  406. package/methods/mongo-explorer.d.ts +0 -2
  407. package/methods/mongo-explorer.js +0 -1811
  408. package/methods/mongo-explorer.js.map +0 -1
  409. package/methods/monitor.d.ts +0 -2
  410. package/methods/monitor.js +0 -543
  411. package/methods/monitor.js.map +0 -1
  412. package/methods/pdf.d.ts +0 -2
  413. package/methods/pdf.js +0 -1195
  414. package/methods/pdf.js.map +0 -1
  415. package/methods/publications.d.ts +0 -1
  416. package/methods/publications.js +0 -183
  417. package/methods/publications.js.map +0 -1
  418. package/methods/report-builder.d.ts +0 -2
  419. package/methods/report-builder.js +0 -2960
  420. package/methods/report-builder.js.map +0 -1
  421. package/methods/support.d.ts +0 -2
  422. package/methods/support.js +0 -313
  423. package/methods/support.js.map +0 -1
  424. package/models/ai-terminal-conversation.model.d.ts +0 -17
  425. package/models/ai-terminal-conversation.model.js +0 -4
  426. package/models/ai-terminal-conversation.model.js.map +0 -1
  427. package/models/ai-terminal-issue-report.model.d.ts +0 -19
  428. package/models/ai-terminal-issue-report.model.js +0 -4
  429. package/models/ai-terminal-issue-report.model.js.map +0 -1
  430. package/models/ai-terminal-message.model.d.ts +0 -22
  431. package/models/ai-terminal-message.model.js +0 -4
  432. package/models/ai-terminal-message.model.js.map +0 -1
  433. package/models/app-setting.model.d.ts +0 -16
  434. package/models/app-setting.model.js +0 -4
  435. package/models/app-setting.model.js.map +0 -1
  436. package/models/app-status.model.js +0 -4
  437. package/models/app-status.model.js.map +0 -1
  438. package/models/billing-logged-in-users.model.js +0 -4
  439. package/models/billing-logged-in-users.model.js.map +0 -1
  440. package/models/collection-document.model.d.ts +0 -21
  441. package/models/collection-document.model.js +0 -4
  442. package/models/collection-document.model.js.map +0 -1
  443. package/models/communication-metric.model.d.ts +0 -20
  444. package/models/communication-metric.model.js +0 -4
  445. package/models/communication-metric.model.js.map +0 -1
  446. package/models/counter.model.js +0 -4
  447. package/models/counter.model.js.map +0 -1
  448. package/models/cron-job-history.model.d.ts +0 -15
  449. package/models/cron-job-history.model.js +0 -4
  450. package/models/cron-job-history.model.js.map +0 -1
  451. package/models/cron-job.model.d.ts +0 -14
  452. package/models/cron-job.model.js +0 -4
  453. package/models/cron-job.model.js.map +0 -1
  454. package/models/customer-notification.model.d.ts +0 -26
  455. package/models/customer-notification.model.js +0 -4
  456. package/models/customer-notification.model.js.map +0 -1
  457. package/models/customer-portal-password.model.d.ts +0 -11
  458. package/models/customer-portal-password.model.js +0 -4
  459. package/models/customer-portal-password.model.js.map +0 -1
  460. package/models/dialog.model.d.ts +0 -23
  461. package/models/dialog.model.js +0 -4
  462. package/models/dialog.model.js.map +0 -1
  463. package/models/email-history.model.d.ts +0 -30
  464. package/models/email-history.model.js.map +0 -1
  465. package/models/email-verified.model.js +0 -4
  466. package/models/email-verified.model.js.map +0 -1
  467. package/models/file.model.js +0 -4
  468. package/models/file.model.js.map +0 -1
  469. package/models/flag-update.model.js +0 -4
  470. package/models/flag-update.model.js.map +0 -1
  471. package/models/flag.model.js +0 -4
  472. package/models/flag.model.js.map +0 -1
  473. package/models/log-method-latency.model.d.ts +0 -10
  474. package/models/log-method-latency.model.js +0 -4
  475. package/models/log-method-latency.model.js.map +0 -1
  476. package/models/log-subscription.model.js +0 -4
  477. package/models/log-subscription.model.js.map +0 -1
  478. package/models/log.model.d.ts +0 -17
  479. package/models/log.model.js +0 -4
  480. package/models/log.model.js.map +0 -1
  481. package/models/logged-in-users.model.js +0 -4
  482. package/models/logged-in-users.model.js.map +0 -1
  483. package/models/method-response.model.js +0 -4
  484. package/models/method-response.model.js.map +0 -1
  485. package/models/method.model.d.ts +0 -24
  486. package/models/method.model.js +0 -4
  487. package/models/method.model.js.map +0 -1
  488. package/models/monitor-cpu.model.js +0 -4
  489. package/models/monitor-cpu.model.js.map +0 -1
  490. package/models/monitor-function.model.d.ts +0 -14
  491. package/models/monitor-function.model.js +0 -4
  492. package/models/monitor-function.model.js.map +0 -1
  493. package/models/monitor-memory.model.d.ts +0 -15
  494. package/models/monitor-memory.model.js +0 -4
  495. package/models/monitor-memory.model.js.map +0 -1
  496. package/models/monitor-mongo.model.d.ts +0 -13
  497. package/models/monitor-mongo.model.js +0 -4
  498. package/models/monitor-mongo.model.js.map +0 -1
  499. package/models/notification.model.js +0 -4
  500. package/models/notification.model.js.map +0 -1
  501. package/models/openai-usage-ledger.model.d.ts +0 -15
  502. package/models/openai-usage-ledger.model.js +0 -4
  503. package/models/openai-usage-ledger.model.js.map +0 -1
  504. package/models/pagination.model.d.ts +0 -11
  505. package/models/pagination.model.js +0 -28
  506. package/models/pagination.model.js.map +0 -1
  507. package/models/permission.model.d.ts +0 -12
  508. package/models/permission.model.js +0 -4
  509. package/models/permission.model.js.map +0 -1
  510. package/models/report-builder-dashboard-builder.model.d.ts +0 -25
  511. package/models/report-builder-dashboard-builder.model.js +0 -4
  512. package/models/report-builder-dashboard-builder.model.js.map +0 -1
  513. package/models/report-builder-library.model.d.ts +0 -17
  514. package/models/report-builder-library.model.js +0 -4
  515. package/models/report-builder-library.model.js.map +0 -1
  516. package/models/report-builder-report.model.d.ts +0 -120
  517. package/models/report-builder-report.model.js +0 -4
  518. package/models/report-builder-report.model.js.map +0 -1
  519. package/models/report-builder.model.d.ts +0 -61
  520. package/models/report-builder.model.js +0 -4
  521. package/models/report-builder.model.js.map +0 -1
  522. package/models/select-data-label.model.d.ts +0 -9
  523. package/models/select-data-label.model.js +0 -4
  524. package/models/select-data-label.model.js.map +0 -1
  525. package/models/server-message.model.d.ts +0 -32
  526. package/models/server-message.model.js +0 -4
  527. package/models/server-message.model.js.map +0 -1
  528. package/models/slow-query-report.model.d.ts +0 -23
  529. package/models/slow-query-report.model.js +0 -4
  530. package/models/slow-query-report.model.js.map +0 -1
  531. package/models/subscription.model.d.ts +0 -31
  532. package/models/subscription.model.js +0 -4
  533. package/models/subscription.model.js.map +0 -1
  534. package/models/support-ticket.model.d.ts +0 -86
  535. package/models/support-ticket.model.js +0 -4
  536. package/models/support-ticket.model.js.map +0 -1
  537. package/models/user-group.model.d.ts +0 -20
  538. package/models/user-group.model.js +0 -4
  539. package/models/user-group.model.js.map +0 -1
  540. package/models/user-guide.model.js +0 -4
  541. package/models/user-guide.model.js.map +0 -1
  542. package/models/user.model.d.ts +0 -84
  543. package/models/user.model.js +0 -4
  544. package/models/user.model.js.map +0 -1
  545. package/private/images/ResolveIO.png +0 -0
  546. package/public_api.js +0 -107
  547. package/public_api.js.map +0 -1
  548. package/publications/ai-terminal.d.ts +0 -1
  549. package/publications/ai-terminal.js +0 -122
  550. package/publications/ai-terminal.js.map +0 -1
  551. package/publications/app-settings.d.ts +0 -2
  552. package/publications/app-settings.js +0 -28
  553. package/publications/app-settings.js.map +0 -1
  554. package/publications/app-status.d.ts +0 -2
  555. package/publications/app-status.js +0 -16
  556. package/publications/app-status.js.map +0 -1
  557. package/publications/cron-jobs.d.ts +0 -2
  558. package/publications/cron-jobs.js +0 -32
  559. package/publications/cron-jobs.js.map +0 -1
  560. package/publications/customer-notifications.d.ts +0 -2
  561. package/publications/customer-notifications.js +0 -161
  562. package/publications/customer-notifications.js.map +0 -1
  563. package/publications/files.d.ts +0 -2
  564. package/publications/files.js +0 -36
  565. package/publications/files.js.map +0 -1
  566. package/publications/flags-update.d.ts +0 -2
  567. package/publications/flags-update.js +0 -22
  568. package/publications/flags-update.js.map +0 -1
  569. package/publications/flags.d.ts +0 -2
  570. package/publications/flags.js +0 -22
  571. package/publications/flags.js.map +0 -1
  572. package/publications/logs.d.ts +0 -2
  573. package/publications/logs.js +0 -164
  574. package/publications/logs.js.map +0 -1
  575. package/publications/notifications.d.ts +0 -2
  576. package/publications/notifications.js +0 -16
  577. package/publications/notifications.js.map +0 -1
  578. package/publications/report-builder-dashboard-builders.d.ts +0 -2
  579. package/publications/report-builder-dashboard-builders.js +0 -42
  580. package/publications/report-builder-dashboard-builders.js.map +0 -1
  581. package/publications/report-builder-libraries.d.ts +0 -2
  582. package/publications/report-builder-libraries.js +0 -90
  583. package/publications/report-builder-libraries.js.map +0 -1
  584. package/publications/report-builder-reports.d.ts +0 -2
  585. package/publications/report-builder-reports.js +0 -50
  586. package/publications/report-builder-reports.js.map +0 -1
  587. package/publications/super-admin.d.ts +0 -2
  588. package/publications/super-admin.js +0 -16
  589. package/publications/super-admin.js.map +0 -1
  590. package/publications/user-groups.d.ts +0 -1
  591. package/publications/user-groups.js +0 -16
  592. package/publications/user-groups.js.map +0 -1
  593. package/publications/user-guides.d.ts +0 -1
  594. package/publications/user-guides.js +0 -16
  595. package/publications/user-guides.js.map +0 -1
  596. package/resolveio-server-app.d.ts +0 -70
  597. package/resolveio-server-app.js +0 -801
  598. package/resolveio-server-app.js.map +0 -1
  599. package/server-app.d.ts +0 -167
  600. package/server-app.js +0 -2784
  601. package/server-app.js.map +0 -1
  602. package/services/codex-client.d.ts +0 -119
  603. package/services/codex-client.js +0 -1470
  604. package/services/codex-client.js.map +0 -1
  605. package/services/openai-client.d.ts +0 -46
  606. package/services/openai-client.js +0 -318
  607. package/services/openai-client.js.map +0 -1
  608. package/types/error-report.d.ts +0 -25
  609. package/types/error-report.js +0 -4
  610. package/types/error-report.js.map +0 -1
  611. package/types/slow-query-report.d.ts +0 -27
  612. package/types/slow-query-report.js +0 -6
  613. package/types/slow-query-report.js.map +0 -1
  614. package/util/common.d.ts +0 -31
  615. package/util/common.js +0 -683
  616. package/util/common.js.map +0 -1
  617. package/util/customer-portal-password.d.ts +0 -13
  618. package/util/customer-portal-password.js +0 -209
  619. package/util/customer-portal-password.js.map +0 -1
  620. package/util/error-reporter.d.ts +0 -52
  621. package/util/error-reporter.js +0 -326
  622. package/util/error-reporter.js.map +0 -1
  623. package/util/error-tracking.d.ts +0 -13
  624. package/util/error-tracking.js +0 -120
  625. package/util/error-tracking.js.map +0 -1
  626. package/util/report-builder-unwinds.d.ts +0 -15
  627. package/util/report-builder-unwinds.js +0 -156
  628. package/util/report-builder-unwinds.js.map +0 -1
  629. package/util/schema-report-builder.d.ts +0 -6
  630. package/util/schema-report-builder.js +0 -481
  631. package/util/schema-report-builder.js.map +0 -1
  632. package/util/slow-query-reporter.d.ts +0 -28
  633. package/util/slow-query-reporter.js +0 -226
  634. package/util/slow-query-reporter.js.map +0 -1
  635. package/util/subscription-dependency-context.d.ts +0 -34
  636. package/util/subscription-dependency-context.js +0 -1283
  637. package/util/subscription-dependency-context.js.map +0 -1
  638. package/util/tokenizer.d.ts +0 -5
  639. package/util/tokenizer.js +0 -41
  640. package/util/tokenizer.js.map +0 -1
  641. package/workers/codex-runner.worker.d.ts +0 -1
  642. package/workers/codex-runner.worker.js +0 -192
  643. package/workers/codex-runner.worker.js.map +0 -1
  644. /package/{private → src/private}/email-templates/enrollment.html +0 -0
  645. /package/{private → src/private}/email-templates/forgot-password.html +0 -0
  646. /package/{private → src/private}/email-templates/support-ticket-deleted.html +0 -0
  647. /package/{private → src/private}/email-templates/support-ticket-modified.html +0 -0
  648. /package/{private → src/private}/email-templates/support-ticket.html +0 -0
  649. /package/{public_api.d.ts → src/public_api.ts} +0 -0
@@ -0,0 +1,1210 @@
1
+ import * as fs from 'fs';
2
+ import * as os from 'os';
3
+ import * as path from 'path';
4
+ import axios from 'axios';
5
+ import { ParseSpeeds, PDFDocument } from 'pdf-lib';
6
+ import * as puppeteer from 'puppeteer';
7
+ import SimpleSchema from 'simpl-schema';
8
+ import { Flags } from '../collections/flag.collection';
9
+ import { MethodManager } from '../managers/method.manager';
10
+ import { objectIdHexString } from '../util/common';
11
+
12
+ const PUPPETEER_ARGS = [
13
+ '--disable-dev-shm-usage',
14
+ '--no-sandbox',
15
+ '--disable-setuid-sandbox',
16
+ '--disable-accelerated-2d-canvas',
17
+ '--disable-gpu',
18
+ '--allow-file-access-from-files',
19
+ '--enable-local-file-accesses',
20
+ '--font-render-hinting=none',
21
+ '--disable-breakpad',
22
+ '--no-zygote'
23
+ ];
24
+
25
+ const LOW_RESOURCE_PUPPETEER_ARGS = [
26
+ '--single-process',
27
+ '--renderer-process-limit=1',
28
+ '--disable-extensions',
29
+ '--disable-features=AudioServiceOutOfProcess'
30
+ ];
31
+
32
+ let cachedExecutablePath: string = null;
33
+ let cachedTmpExecutablePath: string = null;
34
+
35
+ function envMs(name: string, fallback: number) {
36
+ let raw = process.env[name];
37
+ if (!raw) {
38
+ return fallback;
39
+ }
40
+
41
+ let parsed = parseInt(raw, 10);
42
+ if (!Number.isFinite(parsed) || parsed <= 0) {
43
+ return fallback;
44
+ }
45
+
46
+ return parsed;
47
+ }
48
+
49
+ const PDF_LAUNCH_TIMEOUT_MS = envMs('PDF_LAUNCH_TIMEOUT_MS', 60000);
50
+ const PDF_CONTENT_TIMEOUT_MS = envMs('PDF_CONTENT_TIMEOUT_MS', 60000);
51
+ const PDF_FONTS_TIMEOUT_MS = envMs('PDF_FONTS_TIMEOUT_MS', 30000);
52
+ const PDF_IMAGES_TIMEOUT_MS = envMs('PDF_IMAGES_TIMEOUT_MS', 15000);
53
+ const PDF_RENDER_TIMEOUT_MS = envMs('PDF_RENDER_TIMEOUT_MS', 120000);
54
+ const PDF_PROTOCOL_TIMEOUT_MS = envMs('PDF_PROTOCOL_TIMEOUT_MS', 120000);
55
+ const PDF_OVERALL_TIMEOUT_MS = envMs('PDF_OVERALL_TIMEOUT_MS', 240000);
56
+
57
+ class PdfTimeoutError extends Error {
58
+ step: string;
59
+ timeoutMs: number;
60
+
61
+ constructor(step: string, timeoutMs: number) {
62
+ super(`PDF step timed out after ${timeoutMs}ms: ${step}`);
63
+ this.name = 'PdfTimeoutError';
64
+ this.step = step;
65
+ this.timeoutMs = timeoutMs;
66
+ }
67
+ }
68
+
69
+ function withTimeout<T>(promise: Promise<T>, timeoutMs: number, step: string): Promise<T> {
70
+ if (!timeoutMs || timeoutMs <= 0) {
71
+ return promise;
72
+ }
73
+
74
+ let timeoutHandle: NodeJS.Timeout = null;
75
+
76
+ // eslint-disable-next-line no-restricted-syntax
77
+ return new Promise<T>((resolve, reject) => {
78
+ timeoutHandle = setTimeout(() => {
79
+ reject(new PdfTimeoutError(step, timeoutMs));
80
+ }, timeoutMs);
81
+
82
+ // eslint-disable-next-line no-restricted-syntax, promise/prefer-await-to-then
83
+ promise.then(resolve, reject).finally(() => {
84
+ if (timeoutHandle) {
85
+ clearTimeout(timeoutHandle);
86
+ }
87
+ });
88
+ });
89
+ }
90
+
91
+ function getEnvExecutablePath() {
92
+ let envExecutablePath = process.env.PUPPETEER_EXECUTABLE_PATH || process.env.CHROME_EXECUTABLE_PATH || process.env.CHROME_PATH;
93
+
94
+ if (envExecutablePath && fs.existsSync(envExecutablePath)) {
95
+ return envExecutablePath;
96
+ }
97
+
98
+ return null;
99
+ }
100
+
101
+ function shouldRetryBrowserLaunch(err: any) {
102
+ if (!err) {
103
+ return false;
104
+ }
105
+
106
+ let message = err.message || '';
107
+ let stderr = err.stderr ? err.stderr.toString() : '';
108
+
109
+ return message.includes('chrome_crashpad_handler') || message.includes('Operation not permitted') || message.includes('Resource temporarily unavailable') || stderr.includes('pthread_create') || stderr.includes('Resource temporarily unavailable') || stderr.includes('Failed to connect to the bus');
110
+ }
111
+
112
+ function prepareExecutableFallback(executablePath?: string) {
113
+ try {
114
+ let currentExecutablePath = executablePath || cachedExecutablePath || puppeteer.executablePath();
115
+
116
+ if (!currentExecutablePath) {
117
+ return null;
118
+ }
119
+
120
+ // Avoid copying if we're already running from a tmp dir.
121
+ if (currentExecutablePath.startsWith(os.tmpdir())) {
122
+ return null;
123
+ }
124
+
125
+ // Retry from a tmp location when the packaged Chromium cannot be executed (e.g. noexec home dirs).
126
+ let chromiumDir = path.dirname(currentExecutablePath);
127
+ let tmpRoot = path.join(os.tmpdir(), 'puppeteer-chromium');
128
+ let tmpChromiumDir = path.join(tmpRoot, path.basename(chromiumDir));
129
+ let tmpExecutablePath = path.join(tmpChromiumDir, path.basename(currentExecutablePath));
130
+
131
+ if (!fs.existsSync(tmpExecutablePath)) {
132
+ fs.mkdirSync(tmpChromiumDir, { recursive: true });
133
+ fs.cpSync(chromiumDir, tmpChromiumDir, { recursive: true, force: true });
134
+ }
135
+
136
+ cachedTmpExecutablePath = tmpExecutablePath;
137
+ return tmpExecutablePath;
138
+ }
139
+ catch (errCopy) {
140
+ console.error(new Date(), 'Failed to prepare Chromium fallback', errCopy);
141
+ return null;
142
+ }
143
+ }
144
+
145
+ function sanitizeLaunchEnv(env?: NodeJS.ProcessEnv) {
146
+ let launchEnv: NodeJS.ProcessEnv = { ...process.env, ...env };
147
+
148
+ if (launchEnv.DBUS_SESSION_BUS_ADDRESS && !launchEnv.DBUS_SESSION_BUS_ADDRESS.startsWith('unix:') && !launchEnv.DBUS_SESSION_BUS_ADDRESS.startsWith('tcp:')) {
149
+ delete launchEnv.DBUS_SESSION_BUS_ADDRESS;
150
+ }
151
+
152
+ return launchEnv;
153
+ }
154
+
155
+ function applyLowResourceLaunchTweaks(options: puppeteer.LaunchOptions): puppeteer.LaunchOptions {
156
+ let mergedArgs = [...(options.args || [])];
157
+
158
+ LOW_RESOURCE_PUPPETEER_ARGS.forEach((arg) => {
159
+ if (!mergedArgs.includes(arg)) {
160
+ mergedArgs.push(arg);
161
+ }
162
+ });
163
+
164
+ return {
165
+ ...options,
166
+ args: mergedArgs,
167
+ ignoreDefaultArgs: undefined,
168
+ env: sanitizeLaunchEnv(options.env)
169
+ };
170
+ }
171
+
172
+ async function safeCloseBrowser(browser: puppeteer.Browser) {
173
+ if (!browser) {
174
+ return;
175
+ }
176
+
177
+ let proc: any = null;
178
+
179
+ try {
180
+ proc = typeof browser.process === 'function' ? browser.process() : null;
181
+ }
182
+ catch {
183
+ proc = null;
184
+ }
185
+
186
+ try {
187
+ await withTimeout(browser.close(), 5000, 'browser.close');
188
+ }
189
+ catch (errClose) {
190
+ console.error(new Date(), 'Puppeteer close failed, forcing kill', errClose && errClose.message ? errClose.message : errClose);
191
+ }
192
+ finally {
193
+ let needsKill = proc && proc.exitCode === null && proc.signalCode === null;
194
+
195
+ if (needsKill) {
196
+ try {
197
+ proc.kill('SIGKILL');
198
+ }
199
+ catch (errKill: any) {
200
+ if (!errKill || errKill.code !== 'ESRCH') {
201
+ console.error(new Date(), 'Failed to kill Puppeteer process', errKill);
202
+ }
203
+ }
204
+ }
205
+ }
206
+ }
207
+
208
+ async function launchPDFBrowser(headless: boolean, devtools: boolean) {
209
+ let envExecutablePath = getEnvExecutablePath();
210
+
211
+ if (!cachedExecutablePath) {
212
+ cachedExecutablePath = envExecutablePath || puppeteer.executablePath();
213
+ }
214
+
215
+ let launchOptions: puppeteer.LaunchOptions = {
216
+ headless,
217
+ devtools,
218
+ args: [...PUPPETEER_ARGS],
219
+ ignoreDefaultArgs: ['--disable-extensions'],
220
+ env: sanitizeLaunchEnv(),
221
+ timeout: PDF_LAUNCH_TIMEOUT_MS,
222
+ protocolTimeout: PDF_PROTOCOL_TIMEOUT_MS
223
+ };
224
+
225
+ if (cachedExecutablePath) {
226
+ launchOptions.executablePath = cachedExecutablePath;
227
+ }
228
+
229
+ try {
230
+ return await puppeteer.launch(launchOptions);
231
+ }
232
+ catch (errLaunch) {
233
+ if (!shouldRetryBrowserLaunch(errLaunch)) {
234
+ throw errLaunch;
235
+ }
236
+
237
+ let fallbackExecutablePath = cachedTmpExecutablePath || prepareExecutableFallback(launchOptions.executablePath);
238
+
239
+ let retryOptions: puppeteer.LaunchOptions = applyLowResourceLaunchTweaks({
240
+ ...launchOptions,
241
+ executablePath: fallbackExecutablePath || launchOptions.executablePath
242
+ });
243
+
244
+ if (fallbackExecutablePath) {
245
+ cachedExecutablePath = fallbackExecutablePath;
246
+ }
247
+
248
+ console.warn(new Date(), 'Retrying Puppeteer launch with low-resource args');
249
+
250
+ return await puppeteer.launch(retryOptions);
251
+ }
252
+ }
253
+
254
+ export function loadPDFMethods(methodManager: MethodManager) {
255
+ methodManager.methods({
256
+ generatePDF: {
257
+ bypassSession: true,
258
+ check: new SimpleSchema({
259
+ html: {
260
+ type: String
261
+ },
262
+ fileName: {
263
+ type: String
264
+ },
265
+ orientation: {
266
+ type: String,
267
+ optional: true
268
+ },
269
+ fontSize: {
270
+ type: String,
271
+ optional: true
272
+ },
273
+ upload: {
274
+ type: Boolean,
275
+ optional: true
276
+ },
277
+ uploadFileOrder: {
278
+ type: Number,
279
+ optional: true
280
+ },
281
+ uploadFileType: {
282
+ type: String,
283
+ optional: true
284
+ }
285
+ }),
286
+ function: async function(html, fileName, orientation = 'portrait', fontSize = '12px', upload = false, uploadFileOrder = -1, uploadFileType = '') {
287
+ // console.log(new Date(), 'GENERATE PDF CALL', fileName, orientation, fontSize, upload);
288
+
289
+ let enableDebugFlag = await Flags.findOne({type: 'Enable Debug PDF'});
290
+
291
+ let enableDebug = !!(enableDebugFlag && enableDebugFlag.value);
292
+
293
+ const maxAttempts = 2;
294
+ let lastError: any = null;
295
+
296
+ for (let attempt = 1; attempt <= maxAttempts; attempt++) {
297
+ let browser: puppeteer.Browser = null;
298
+ let page: puppeteer.Page = null;
299
+ let overallTimedOut = false;
300
+ let overallTimeoutHandle: NodeJS.Timeout = null;
301
+
302
+ try {
303
+ browser = await withTimeout(launchPDFBrowser(!enableDebug, enableDebug), PDF_LAUNCH_TIMEOUT_MS, 'launchPDFBrowser');
304
+
305
+ overallTimeoutHandle = setTimeout(() => {
306
+ overallTimedOut = true;
307
+ console.error(new Date(), 'generatePDF overall timeout hit', { fileName, attempt });
308
+ // eslint-disable-next-line no-restricted-syntax, promise/prefer-await-to-then
309
+ safeCloseBrowser(browser).catch(() => {});
310
+ }, PDF_OVERALL_TIMEOUT_MS);
311
+
312
+ page = await browser.newPage(); // create new tab
313
+ page.setDefaultTimeout(PDF_CONTENT_TIMEOUT_MS);
314
+
315
+ let pathToFont = '';
316
+
317
+ if (fs.existsSync(path.join(__dirname, ('../private/fonts/dejavuserif.woff')))) {
318
+ pathToFont = path.join(__dirname, ('../private/fonts/'));
319
+ }
320
+ else {
321
+ if (fs.existsSync(path.join(this.clientDir, ('./private/fonts/dejavuserif.woff')))) {
322
+ pathToFont = path.join(this.clientDir, ('./private/fonts/'));
323
+ }
324
+ else {
325
+ pathToFont = '/usr/share/fonts/dejavu/';
326
+ }
327
+ }
328
+
329
+ let dejavuserif_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif.woff').buffer).toString('base64');
330
+ let dejavuserifBold_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-bold.woff').buffer).toString('base64');
331
+ let dejavuserifItalic_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-italic.woff').buffer).toString('base64');
332
+ let dejavuserifBoldItalic_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-bolditalic.woff').buffer).toString('base64');
333
+
334
+ let content = `
335
+ <head>
336
+ <style type="text/css">
337
+ @font-face {
338
+ font-family: 'Dejavu Serif';
339
+ font-style: normal;
340
+ font-weight: normal;
341
+ src: url("` + dejavuserif_woff + `") format('woff');
342
+ }
343
+
344
+ @font-face {
345
+ font-family: 'Dejavu Serif';
346
+ font-style: normal;
347
+ font-weight: bold;
348
+ src: url("` + dejavuserifBold_woff + `") format('woff');
349
+ }
350
+
351
+ @font-face {
352
+ font-family: 'Dejavu Serif';
353
+ font-style: italic;
354
+ font-weight: normal;
355
+ src: url("` + dejavuserifItalic_woff + `") format('woff');
356
+ }
357
+
358
+ @font-face {
359
+ font-family: 'Dejavu Serif';
360
+ font-style: italic;
361
+ font-weight: bold;
362
+ src: url("` + dejavuserifBoldItalic_woff + `") format('woff');
363
+ }
364
+
365
+ body {
366
+ font-family: 'Dejavu Serif', serif;
367
+ font-size: ` + (fontSize ? fontSize : '12px') + `;
368
+ }
369
+
370
+ .row {
371
+ display: -webkit-flex;
372
+ display: flex;
373
+ flex-wrap: wrap;
374
+ -webkit-flex-wrap: wrap;
375
+ page-break-inside: avoid !important;
376
+ }
377
+
378
+ .page-break {
379
+ page-break-before: always !important;
380
+ padding-top: 1px;
381
+ }
382
+
383
+ .cell {
384
+ box-sizing: border-box;
385
+ padding : 2px;
386
+ -webkit-flex: 1;
387
+ word-wrap: break-word;
388
+ }
389
+
390
+ .cell-no-padding {
391
+ box-sizing: border-box;
392
+ -webkit-flex: 1;
393
+ word-wrap: break-word;
394
+ }
395
+
396
+ .centered {
397
+ -webkit-justify-content: center;
398
+ -webkit-align-items: center;
399
+ display: -webkit-flex;
400
+ text-align: center;
401
+ }
402
+
403
+ .centered-left {
404
+ -webkit-align-items: center;
405
+ display: -webkit-flex;
406
+ -webkit-justify-content: flex-start;
407
+ }
408
+
409
+ .centered-right {
410
+ -webkit-justify-content: flex-end;
411
+ -webkit-align-items: center;
412
+ display: -webkit-flex;
413
+ }
414
+
415
+ .box {
416
+ border: 1px solid black;
417
+ margin: -1px 0px 0px -1px;
418
+ }
419
+
420
+ .boxNoBorder {
421
+ margin: -1px 0px 0px -1px;
422
+ }
423
+
424
+ pre {
425
+ white-space: pre-wrap; /* css-3 */
426
+ white-space: -moz-pre-wrap; /* Mozilla, since 1999 */
427
+ white-space: -pre-wrap; /* Opera 4-6 */
428
+ white-space: -o-pre-wrap; /* Opera 7 */
429
+ word-wrap: break-word; /* Internet Explorer 5.5+ */
430
+ font-size: 12px;
431
+ font-family: 'Dejavu Serif';
432
+ }
433
+ </style>
434
+ <meta charset="UTF-8">
435
+ </head>
436
+ <body>
437
+ ` + html.replace(new RegExp('flex-basis:', 'g'), '-webkit-flex-basis:').replace(new RegExp('flex:', 'g'), '-webkit-flex:') + '</body>';
438
+
439
+ await withTimeout(page.setContent(content, { waitUntil: ['domcontentloaded'], timeout: PDF_CONTENT_TIMEOUT_MS }), PDF_CONTENT_TIMEOUT_MS, 'page.setContent');
440
+ await withTimeout(page.evaluateHandle('document.fonts.ready'), PDF_FONTS_TIMEOUT_MS, 'document.fonts.ready');
441
+
442
+ if (PDF_IMAGES_TIMEOUT_MS > 0) {
443
+ try {
444
+ await withTimeout(
445
+ page.waitForFunction(() => Array.from(document.images).every((img: any) => img.complete), { timeout: 0 }),
446
+ PDF_IMAGES_TIMEOUT_MS,
447
+ 'waitForImages'
448
+ );
449
+ }
450
+ catch (errImages) {
451
+ if (errImages instanceof PdfTimeoutError) {
452
+ console.warn(new Date(), 'generatePDF timed out waiting for images', { fileName, attempt });
453
+ }
454
+ else {
455
+ throw errImages;
456
+ }
457
+ }
458
+ }
459
+
460
+ let tmpFileName = objectIdHexString() + '.pdf';
461
+
462
+ await withTimeout(page.pdf({
463
+ scale: 1,
464
+ landscape: orientation === 'portrait' ? false : true,
465
+ format: 'letter',
466
+ margin: {
467
+ top: '1cm',
468
+ bottom: '1cm',
469
+ left: '1cm',
470
+ right: '1cm'
471
+ },
472
+ printBackground: true,
473
+ displayHeaderFooter: true,
474
+ headerTemplate: `
475
+ <style>
476
+ #header {
477
+ padding: 0 0 10px 10px !important;
478
+ }
479
+ </style>
480
+ <span></span>
481
+ `,
482
+ footerTemplate: `
483
+ <style>
484
+ #footer {
485
+ padding: 0 0 10px 10px !important;
486
+ font-size: 10px;
487
+ font-family: san-serif;
488
+ }
489
+ </style>
490
+ <div style="padding-bottom: 2px; padding-right: 15px; text-align: right; width: 100%;">
491
+ Page&nbsp;<span class="pageNumber"></span>&nbsp;of&nbsp;<span class="totalPages"></span>
492
+ </div>
493
+ `,
494
+ path: path.join(__dirname, (tmpFileName)),
495
+ timeout: PDF_RENDER_TIMEOUT_MS
496
+ }), PDF_RENDER_TIMEOUT_MS, 'page.pdf');
497
+
498
+ if (enableDebugFlag && enableDebugFlag.value) {
499
+ // Set viewport dimensions based on orientation
500
+ if (orientation === 'landscape') {
501
+ await page.setViewport({ width: 1100, height: 850 });
502
+ }
503
+ else {
504
+ await page.setViewport({ width: 850, height: 1100 });
505
+ }
506
+ }
507
+
508
+ if (fs.existsSync(path.join(__dirname, (tmpFileName)))) {
509
+ try {
510
+ let data = fs.readFileSync(path.join(__dirname, (tmpFileName)));
511
+ fs.unlinkSync(path.join(__dirname, (tmpFileName)));
512
+ if (!upload) {
513
+ return 'data:application/pdf;base64,' + data.toString('base64');
514
+ }
515
+ else {
516
+ let fileData = 'data:application/pdf;base64,' + data.toString('base64');
517
+ return this.callMethod('uploadFileAndSave', fileName, fileData, (4 * Math.ceil(fileData.length / 3)), uploadFileOrder !== null ? uploadFileOrder : -1, uploadFileType, false);
518
+ }
519
+ }
520
+ catch (errRead) {
521
+ errRead.message = 'Error in Generate PDF: No file - ' + errRead.message;
522
+ throw errRead;
523
+ }
524
+ }
525
+ else {
526
+ console.log('No tmp file ', tmpFileName);
527
+ throw new Error('Error in Generate PDF: No tmp file');
528
+ }
529
+ }
530
+ catch (err) {
531
+ lastError = err;
532
+
533
+ if (browser) {
534
+ // eslint-disable-next-line no-restricted-syntax
535
+ await browser.close().catch(() => {});
536
+ }
537
+
538
+ if (attempt < maxAttempts) {
539
+ console.warn(new Date(), 'Retry generatePDF after error', {
540
+ attempt,
541
+ message: err && err.message ? err.message : err
542
+ });
543
+ continue;
544
+ }
545
+
546
+ console.error(new Date(), 'generatePDF failed', { fileName, attempt, message: err && err.message ? err.message : err });
547
+ throw err;
548
+ }
549
+ finally {
550
+ if (overallTimeoutHandle) {
551
+ clearTimeout(overallTimeoutHandle);
552
+ }
553
+
554
+ if (page) {
555
+ // eslint-disable-next-line no-restricted-syntax
556
+ await page.close().catch(() => {});
557
+ page = null;
558
+ }
559
+
560
+ await safeCloseBrowser(browser);
561
+ browser = null;
562
+
563
+ if (overallTimedOut) {
564
+ throw new PdfTimeoutError('generatePDF overall', PDF_OVERALL_TIMEOUT_MS);
565
+ }
566
+ }
567
+ }
568
+
569
+ throw lastError;
570
+ },
571
+ workerTaskWeight: 2,
572
+ maxConcurrency: 1,
573
+ timeoutOverride: 300000
574
+ },
575
+ generatePDFNoPageNumber: {
576
+ bypassSession: true,
577
+ check: new SimpleSchema({
578
+ html: {
579
+ type: String
580
+ },
581
+ fileName: {
582
+ type: String
583
+ },
584
+ orientation: {
585
+ type: String,
586
+ optional: true
587
+ },
588
+ fontSize: {
589
+ type: String,
590
+ optional: true
591
+ },
592
+ upload: {
593
+ type: Boolean,
594
+ optional: true
595
+ },
596
+ uploadFileOrder: {
597
+ type: Number,
598
+ optional: true
599
+ },
600
+ uploadFileType: {
601
+ type: String,
602
+ optional: true
603
+ }
604
+ }),
605
+ function: async function(html, fileName, orientation = 'portrait', fontSize = '12px', upload = false, uploadFileOrder = -1, uploadFileType = '') {
606
+ // console.log(new Date(), 'GENERATE PDF CALL', fileName, orientation, fontSize, upload);
607
+
608
+ const maxAttempts = 2;
609
+ let lastError: any = null;
610
+
611
+ for (let attempt = 1; attempt <= maxAttempts; attempt++) {
612
+ let browser: puppeteer.Browser = null;
613
+ let page: puppeteer.Page = null;
614
+ let overallTimedOut = false;
615
+ let overallTimeoutHandle: NodeJS.Timeout = null;
616
+
617
+ try {
618
+ browser = await withTimeout(launchPDFBrowser(true, false), PDF_LAUNCH_TIMEOUT_MS, 'launchPDFBrowser');
619
+
620
+ overallTimeoutHandle = setTimeout(() => {
621
+ overallTimedOut = true;
622
+ console.error(new Date(), 'generatePDFNoPageNumber overall timeout hit', { fileName, attempt });
623
+ // eslint-disable-next-line no-restricted-syntax, promise/prefer-await-to-then
624
+ safeCloseBrowser(browser).catch(() => {});
625
+ }, PDF_OVERALL_TIMEOUT_MS);
626
+
627
+ page = await browser.newPage(); // create new tab
628
+ page.setDefaultTimeout(PDF_CONTENT_TIMEOUT_MS);
629
+
630
+ let pathToFont = '';
631
+
632
+ if (fs.existsSync(path.join(__dirname, ('../private/fonts/dejavuserif.woff')))) {
633
+ pathToFont = path.join(__dirname, ('../private/fonts/'));
634
+ }
635
+ else {
636
+ if (fs.existsSync(path.join(this.clientDir, ('./private/fonts/dejavuserif.woff')))) {
637
+ pathToFont = path.join(this.clientDir, ('./private/fonts/'));
638
+ }
639
+ else {
640
+ pathToFont = '/usr/share/fonts/dejavu/';
641
+ }
642
+ }
643
+
644
+ let dejavuserif_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif.woff').buffer).toString('base64');
645
+ let dejavuserifBold_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-bold.woff').buffer).toString('base64');
646
+ let dejavuserifItalic_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-italic.woff').buffer).toString('base64');
647
+ let dejavuserifBoldItalic_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-bolditalic.woff').buffer).toString('base64');
648
+
649
+ let content = `
650
+ <head>
651
+ <style type="text/css">
652
+ @font-face {
653
+ font-family: 'Dejavu Serif';
654
+ font-style: normal;
655
+ font-weight: normal;
656
+ src: url("` + dejavuserif_woff + `") format('woff');
657
+ }
658
+
659
+ @font-face {
660
+ font-family: 'Dejavu Serif';
661
+ font-style: normal;
662
+ font-weight: bold;
663
+ src: url("` + dejavuserifBold_woff + `") format('woff');
664
+ }
665
+
666
+ @font-face {
667
+ font-family: 'Dejavu Serif';
668
+ font-style: italic;
669
+ font-weight: normal;
670
+ src: url("` + dejavuserifItalic_woff + `") format('woff');
671
+ }
672
+
673
+ @font-face {
674
+ font-family: 'Dejavu Serif';
675
+ font-style: italic;
676
+ font-weight: bold;
677
+ src: url("` + dejavuserifBoldItalic_woff + `") format('woff');
678
+ }
679
+
680
+ body {
681
+ font-family: 'Dejavu Serif', serif;
682
+ font-size: ` + (fontSize ? fontSize : '12px') + `;
683
+ }
684
+
685
+ .row {
686
+ display: -webkit-flex;
687
+ display: flex;
688
+ flex-wrap: wrap;
689
+ -webkit-flex-wrap: wrap;
690
+ page-break-inside: avoid !important;
691
+ }
692
+
693
+ .page-break {
694
+ page-break-before: always !important;
695
+ padding-top: 1px;
696
+ }
697
+
698
+ .cell {
699
+ box-sizing: border-box;
700
+ padding : 2px;
701
+ -webkit-flex: 1;
702
+ word-wrap: break-word;
703
+ }
704
+
705
+ .cell-no-padding {
706
+ box-sizing: border-box;
707
+ -webkit-flex: 1;
708
+ word-wrap: break-word;
709
+ }
710
+
711
+ .centered {
712
+ -webkit-justify-content: center;
713
+ -webkit-align-items: center;
714
+ display: -webkit-flex;
715
+ text-align: center;
716
+ }
717
+
718
+ .centered-left {
719
+ -webkit-align-items: center;
720
+ display: -webkit-flex;
721
+ -webkit-justify-content: flex-start;
722
+ }
723
+
724
+ .centered-right {
725
+ -webkit-justify-content: flex-end;
726
+ -webkit-align-items: center;
727
+ display: -webkit-flex;
728
+ }
729
+
730
+ .box {
731
+ border: 1px solid black;
732
+ margin: -1px 0px 0px -1px;
733
+ }
734
+
735
+ .boxNoBorder {
736
+ margin: -1px 0px 0px -1px;
737
+ }
738
+
739
+ pre {
740
+ white-space: pre-wrap; /* css-3 */
741
+ white-space: -moz-pre-wrap; /* Mozilla, since 1999 */
742
+ white-space: -pre-wrap; /* Opera 4-6 */
743
+ white-space: -o-pre-wrap; /* Opera 7 */
744
+ word-wrap: break-word; /* Internet Explorer 5.5+ */
745
+ font-size: 12px;
746
+ font-family: 'Dejavu Serif';
747
+ }
748
+ </style>
749
+ <meta charset="UTF-8">
750
+ </head>
751
+ <body>
752
+ ` + html.replace(new RegExp('flex-basis:', 'g'), '-webkit-flex-basis:').replace(new RegExp('flex:', 'g'), '-webkit-flex:') + `</body>`;
753
+
754
+ await withTimeout(page.setContent(content, { waitUntil: ['domcontentloaded'], timeout: PDF_CONTENT_TIMEOUT_MS }), PDF_CONTENT_TIMEOUT_MS, 'page.setContent');
755
+ await withTimeout(page.evaluateHandle('document.fonts.ready'), PDF_FONTS_TIMEOUT_MS, 'document.fonts.ready');
756
+
757
+ if (PDF_IMAGES_TIMEOUT_MS > 0) {
758
+ try {
759
+ await withTimeout(
760
+ page.waitForFunction(() => Array.from(document.images).every((img: any) => img.complete), { timeout: 0 }),
761
+ PDF_IMAGES_TIMEOUT_MS,
762
+ 'waitForImages'
763
+ );
764
+ }
765
+ catch (errImages) {
766
+ if (errImages instanceof PdfTimeoutError) {
767
+ console.warn(new Date(), 'generatePDFNoPageNumber timed out waiting for images', { fileName, attempt });
768
+ }
769
+ else {
770
+ throw errImages;
771
+ }
772
+ }
773
+ }
774
+
775
+ let tmpFileName = objectIdHexString() + '.pdf';
776
+
777
+ await withTimeout(page.pdf({
778
+ scale: 1,
779
+ landscape: orientation === 'portrait' ? false : true,
780
+ format: 'letter',
781
+ margin: {
782
+ top: '1cm',
783
+ bottom: '1cm',
784
+ left: '1cm',
785
+ right: '1cm'
786
+ },
787
+ printBackground: true,
788
+ displayHeaderFooter: true,
789
+ headerTemplate: `
790
+ <style>
791
+ #header {
792
+ padding: 0 0 10px 10px !important;
793
+ }
794
+ </style>
795
+ <span></span>
796
+ `,
797
+ footerTemplate: `
798
+ <style>
799
+ #footer {
800
+ padding: 0 0 10px 10px !important;
801
+ font-size: 10px;
802
+ font-family: san-serif;
803
+ }
804
+ </style>
805
+ <div style="padding-bottom: 2px; padding-right: 15px; text-align: right; width: 100%;">
806
+
807
+ </div>
808
+ `,
809
+ path: path.join(__dirname, (tmpFileName)),
810
+ timeout: PDF_RENDER_TIMEOUT_MS
811
+ }), PDF_RENDER_TIMEOUT_MS, 'page.pdf');
812
+
813
+ if (fs.existsSync(path.join(__dirname, (tmpFileName)))) {
814
+ try {
815
+ let data = fs.readFileSync(path.join(__dirname, (tmpFileName)))
816
+ fs.unlinkSync(path.join(__dirname, (tmpFileName)));
817
+ if (!upload) {
818
+ return 'data:application/pdf;base64,' + data.toString('base64');
819
+ }
820
+ else {
821
+ let fileData = 'data:application/pdf;base64,' + data.toString('base64');
822
+ return this.callMethod('uploadFileAndSave', fileName, fileData, (4 * Math.ceil(fileData.length / 3)), uploadFileOrder !== null ? uploadFileOrder : -1, uploadFileType, false);
823
+ }
824
+ }
825
+ catch (errRead) {
826
+ errRead.message = 'Error in Generate PDF No Page Number: No file - ' + errRead.message;
827
+ throw errRead;
828
+ }
829
+ }
830
+ else {
831
+ console.log('No tmp file ', tmpFileName);
832
+ throw new Error('Error in Generate PDF No Page Number: No tmp file');
833
+ }
834
+ }
835
+ catch (err) {
836
+ lastError = err;
837
+
838
+ if (browser) {
839
+ // eslint-disable-next-line no-restricted-syntax
840
+ await browser.close().catch(() => {});
841
+ }
842
+
843
+ if (attempt < maxAttempts) {
844
+ console.warn(new Date(), 'Retry generatePDFNoPageNumber after error', {
845
+ attempt,
846
+ message: err && err.message ? err.message : err
847
+ });
848
+ continue;
849
+ }
850
+
851
+ console.error(new Date(), 'generatePDFNoPageNumber failed', { fileName, attempt, message: err && err.message ? err.message : err });
852
+ throw err;
853
+ }
854
+ finally {
855
+ if (overallTimeoutHandle) {
856
+ clearTimeout(overallTimeoutHandle);
857
+ }
858
+
859
+ if (page) {
860
+ // eslint-disable-next-line no-restricted-syntax
861
+ await page.close().catch(() => {});
862
+ page = null;
863
+ }
864
+
865
+ await safeCloseBrowser(browser);
866
+ browser = null;
867
+
868
+ if (overallTimedOut) {
869
+ throw new PdfTimeoutError('generatePDFNoPageNumber overall', PDF_OVERALL_TIMEOUT_MS);
870
+ }
871
+ }
872
+ }
873
+
874
+ throw lastError;
875
+ },
876
+ workerTaskWeight: 2,
877
+ maxConcurrency: 1,
878
+ timeoutOverride: 300000
879
+ },
880
+ mergePDFResolve: {
881
+ bypassSession: true,
882
+ check: new SimpleSchema({
883
+ fileKeys: {
884
+ type: Array
885
+ },
886
+ 'fileKeys.$': {
887
+ type: String
888
+ },
889
+ fileName: {
890
+ type: String
891
+ },
892
+ fileType: {
893
+ type: String,
894
+ optional: true
895
+ }
896
+ }),
897
+ function: async function(fileKeys: string[], fileName: string, fileType?: string) {
898
+ let resSigneds = null;
899
+
900
+ try {
901
+ resSigneds = await this.callMethod('getSignedUrls', fileKeys, 900);
902
+ }
903
+ catch (err) {
904
+ err.message = 'Error in Merge PDF Resolve: PDF Merge - Get Signed URLs - ' + err.message;
905
+ throw err;
906
+ }
907
+
908
+ if (!resSigneds || !resSigneds.length) {
909
+ throw new Error('Error in Merge PDF Resolve: PDF Merge - No signed urls');
910
+ }
911
+
912
+ const mergedPdf = await PDFDocument.create();
913
+
914
+ for (let i = 0; i < resSigneds.length; i++) {
915
+ let signedUrl = resSigneds[i];
916
+ let fileKey = fileKeys && fileKeys[i] ? fileKeys[i] : '';
917
+
918
+ let response = null;
919
+ try {
920
+ response = await axios.get(signedUrl, {
921
+ responseType: 'arraybuffer'
922
+ });
923
+ }
924
+ catch (err) {
925
+ err.message = `Error in Merge PDF Resolve: PDF Merge - Download failed (${fileKey || 'unknown key'}) - ${err.message}`;
926
+ throw err;
927
+ }
928
+
929
+ if (!response || response.status !== 200) {
930
+ throw new Error(`Error in Merge PDF Resolve: PDF Merge - Download failed (${fileKey || 'unknown key'}) - status: ${response ? response.status : 'unknown'}`);
931
+ }
932
+
933
+ let contentTypeHeader = response.headers ? response.headers['content-type'] : '';
934
+ let contentType = (contentTypeHeader ? String(contentTypeHeader) : '').toLowerCase().split(';')[0].trim();
935
+
936
+ let responseData = response.data;
937
+ let fileDataBuffer = Buffer.isBuffer(responseData) ? responseData : Buffer.from(responseData);
938
+
939
+ if (!fileDataBuffer) {
940
+ throw new Error(`Error in Merge PDF Resolve: PDF Merge - No file data returned (${fileKey || 'unknown key'})`);
941
+ }
942
+
943
+ let fileKeyLower = fileKey ? fileKey.toLowerCase() : '';
944
+ let isPdf = contentType === 'application/pdf' || contentType === 'application/x-pdf' || fileKeyLower.endsWith('.pdf');
945
+ let isJpg = contentType === 'image/jpeg' || contentType === 'image/jpg' || fileKeyLower.endsWith('.jpg') || fileKeyLower.endsWith('.jpeg');
946
+ let isPng = contentType === 'image/png' || fileKeyLower.endsWith('.png');
947
+
948
+ try {
949
+ if (isPdf) {
950
+ const pdf = await PDFDocument.load(fileDataBuffer as any, { updateMetadata: false, parseSpeed: ParseSpeeds.Fastest, ignoreEncryption: true });
951
+ let pageCount = pdf.getPageCount();
952
+
953
+ for (let pageIndex = 0; pageIndex < pageCount; pageIndex++) {
954
+ const copiedPages = await mergedPdf.copyPages(pdf, [pageIndex]);
955
+ mergedPdf.addPage(copiedPages[0]);
956
+
957
+ if (pageIndex > 0 && pageIndex % 25 === 0) {
958
+ // eslint-disable-next-line no-restricted-syntax
959
+ await new Promise(resolve => setImmediate(resolve));
960
+ }
961
+ }
962
+ }
963
+ else if (isJpg) {
964
+ const img = await mergedPdf.embedJpg(fileDataBuffer as any);
965
+ const page = mergedPdf.addPage();
966
+ let imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);
967
+ page.drawImage(img, {
968
+ x: page.getWidth() / 2 - imgDim.width / 2,
969
+ y: page.getHeight() / 2 - imgDim.height / 2,
970
+ width: imgDim.width,
971
+ height: imgDim.height,
972
+ });
973
+ }
974
+ else if (isPng) {
975
+ const img = await mergedPdf.embedPng(fileDataBuffer as any);
976
+ const page = mergedPdf.addPage();
977
+ let imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);
978
+ page.drawImage(img, {
979
+ x: page.getWidth() / 2 - imgDim.width / 2,
980
+ y: page.getHeight() / 2 - imgDim.height / 2,
981
+ width: imgDim.width,
982
+ height: imgDim.height,
983
+ });
984
+ }
985
+ else {
986
+ console.log('Error - unsupported!!', { fileKey, contentType });
987
+ throw new Error(`Error in Merge PDF Resolve: Unsupported document type (${contentType || 'unknown content-type'})`);
988
+ }
989
+ }
990
+ catch (err) {
991
+ err.message = `Error in Merge PDF Resolve: PDF Merge - Error processing file (${fileKey || 'unknown key'}) - ${err.message}`;
992
+ throw err;
993
+ }
994
+ finally {
995
+ response = null;
996
+ responseData = null;
997
+ fileDataBuffer = null;
998
+ }
999
+ }
1000
+
1001
+ let mergedPDFUint8 = await mergedPdf.save();
1002
+ let mergedPDFBuffer = Buffer.from(mergedPDFUint8.buffer, mergedPDFUint8.byteOffset, mergedPDFUint8.byteLength);
1003
+
1004
+ return this.callMethod('uploadPDFBufferAndSave', fileName, mergedPDFBuffer, mergedPDFBuffer.byteLength, -1, fileType || 'pdf');
1005
+ },
1006
+ workerTaskWeight: 2,
1007
+ maxConcurrency: 1,
1008
+ timeoutOverride: 300000
1009
+ },
1010
+ mergePDFResolveNoSave: {
1011
+ bypassSession: true,
1012
+ check: new SimpleSchema({
1013
+ fileKeys: {
1014
+ type: Array
1015
+ },
1016
+ 'fileKeys.$': {
1017
+ type: String
1018
+ }
1019
+ }),
1020
+ function: async function(fileKeys: string[]) {
1021
+ try {
1022
+ let resSigneds = await this.callMethod('getSignedUrls', fileKeys, 900);
1023
+ if (resSigneds && resSigneds.length) {
1024
+ let promises = [];
1025
+
1026
+ resSigneds.forEach((signedUrl) => {
1027
+ promises.push(this.callMethod('getDataURIfromURL', signedUrl));
1028
+ });
1029
+
1030
+ let fileDatas = await Promise.all(promises);
1031
+ const mergedPdf = await PDFDocument.create();
1032
+
1033
+ for (let i = 0; i < fileDatas.length; i++) {
1034
+ let fileData = fileDatas[i];
1035
+
1036
+ if (fileData) {
1037
+ try {
1038
+ if (fileData.startsWith('data:application/pdf;base64,')) {
1039
+ const pdf = await PDFDocument.load(fileData, { updateMetadata: false, parseSpeed: ParseSpeeds.Fastest, ignoreEncryption: true});
1040
+ const copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());
1041
+ copiedPages.forEach((page) => {
1042
+ mergedPdf.addPage(page);
1043
+ });
1044
+ }
1045
+ else if (fileData.startsWith('data:image/jpeg;base64,/9j/') || fileData.startsWith('data:image/png;base64,/9j/')) {
1046
+ const pdf = await PDFDocument.create();
1047
+ const img = await pdf.embedJpg(fileData);
1048
+ const page = pdf.addPage();
1049
+ let imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);
1050
+ page.drawImage(img, {
1051
+ x: page.getWidth() / 2 - imgDim.width / 2,
1052
+ y: page.getHeight() / 2 - imgDim.height / 2,
1053
+ width: imgDim.width,
1054
+ height: imgDim.height,
1055
+ });
1056
+ const copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());
1057
+ copiedPages.forEach((page) => {
1058
+ mergedPdf.addPage(page);
1059
+ });
1060
+ }
1061
+ else if (fileData.startsWith('data:image/png;base64,iVBOR')) {
1062
+ const pdf = await PDFDocument.create();
1063
+ const img = await pdf.embedPng(fileData);
1064
+ const page = pdf.addPage();
1065
+ let imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);
1066
+ page.drawImage(img, {
1067
+ x: page.getWidth() / 2 - imgDim.width / 2,
1068
+ y: page.getHeight() / 2 - imgDim.height / 2,
1069
+ width: imgDim.width,
1070
+ height: imgDim.height,
1071
+ });
1072
+ const copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());
1073
+ copiedPages.forEach((page) => {
1074
+ mergedPdf.addPage(page);
1075
+ });
1076
+ }
1077
+ else {
1078
+ console.log('Error - unsupported!!', fileData.slice(0, 60));
1079
+ }
1080
+ }
1081
+ catch (error) {
1082
+ console.log('Error processing fileData:', fileData.slice(0, 60), error);
1083
+ }
1084
+ }
1085
+ else {
1086
+ console.log('Error - no filedata!!', fileData);
1087
+ }
1088
+ }
1089
+
1090
+ let mergedPDFUint8 = await mergedPdf.save();
1091
+
1092
+ const b64PDF = 'data:application/pdf;base64,' + Buffer.from(mergedPDFUint8).toString('base64');
1093
+
1094
+ return b64PDF;
1095
+ }
1096
+ else {
1097
+ throw new Error('Error in Merge PDF Resolve No Save: No signed urls');
1098
+ }
1099
+ }
1100
+ catch (err) {
1101
+ err.message = `Error in Merge PDF Resolve: ${err.message}`;
1102
+ throw err;
1103
+ }
1104
+ },
1105
+ workerTaskWeight: 2,
1106
+ maxConcurrency: 1,
1107
+ timeoutOverride: 300000
1108
+ },
1109
+ mergePDFResolveHtml: {
1110
+ bypassSession: true,
1111
+ check: new SimpleSchema({
1112
+ htmls: {
1113
+ type: Array
1114
+ },
1115
+ 'htmls.$': {
1116
+ type: String
1117
+ },
1118
+ fileName: {
1119
+ type: String
1120
+ },
1121
+ fileType: {
1122
+ type: String,
1123
+ optional: true
1124
+ },
1125
+ save: {
1126
+ type: Boolean,
1127
+ optional: true
1128
+ }
1129
+ }),
1130
+ function: async function(htmls: string[], fileName: string, fileType?: string, save = true) {
1131
+ const mergedPdf = await PDFDocument.create();
1132
+
1133
+ for (let i = 0; i < htmls.length; i++) {
1134
+ let fileData = htmls[i];
1135
+
1136
+ if (fileData) {
1137
+ try {
1138
+ if (fileData.startsWith('data:application/pdf;base64,')) {
1139
+ const pdf = await PDFDocument.load(fileData, { updateMetadata: false, parseSpeed: ParseSpeeds.Fastest, ignoreEncryption: true });
1140
+ const copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());
1141
+ copiedPages.forEach((page) => {
1142
+ mergedPdf.addPage(page);
1143
+ });
1144
+ }
1145
+ else if (fileData.startsWith('data:image/jpeg;base64,/9j/') || fileData.startsWith('data:image/png;base64,/9j/')) {
1146
+ const pdf = await PDFDocument.create();
1147
+ const img = await pdf.embedJpg(fileData);
1148
+ const page = pdf.addPage();
1149
+ let imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);
1150
+ page.drawImage(img, {
1151
+ x: page.getWidth() / 2 - imgDim.width / 2,
1152
+ y: page.getHeight() / 2 - imgDim.height / 2,
1153
+ width: imgDim.width,
1154
+ height: imgDim.height,
1155
+ });
1156
+ const copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());
1157
+ copiedPages.forEach((page) => {
1158
+ mergedPdf.addPage(page);
1159
+ });
1160
+ }
1161
+ else if (fileData.startsWith('data:image/png;base64,iVBOR')) {
1162
+ const pdf = await PDFDocument.create();
1163
+ const img = await pdf.embedPng(fileData);
1164
+ const page = pdf.addPage();
1165
+ let imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);
1166
+ page.drawImage(img, {
1167
+ x: page.getWidth() / 2 - imgDim.width / 2,
1168
+ y: page.getHeight() / 2 - imgDim.height / 2,
1169
+ width: imgDim.width,
1170
+ height: imgDim.height,
1171
+ });
1172
+ const copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());
1173
+ copiedPages.forEach((page) => {
1174
+ mergedPdf.addPage(page);
1175
+ });
1176
+ }
1177
+ else {
1178
+ console.log('Error - unsupported!!', fileData.slice(0, 60));
1179
+ throw new Error('Error in Merge PDF Resolve HTML: Unsupported file - ' + fileData.slice(0, 60));
1180
+ }
1181
+ }
1182
+ catch (error) {
1183
+ console.log('Error processing fileData:', fileData.slice(0, 60), error);
1184
+ error.message = `Error in Merge PDF Resolve HTML: Error processing filedata - ${error.message}`;
1185
+ throw error;
1186
+ }
1187
+ }
1188
+ else {
1189
+ console.log('Error - no filedata!!', fileData);
1190
+ throw new Error('Error in Merge PDF Resolve HTML: No File data');
1191
+ }
1192
+ }
1193
+
1194
+ let mergedPDFUint8 = await mergedPdf.save();
1195
+
1196
+ const b64PDF = 'data:application/pdf;base64,' + Buffer.from(mergedPDFUint8).toString('base64');
1197
+
1198
+ if (save) {
1199
+ return this.callMethod('uploadFileAndSave', fileName, b64PDF, (4 * Math.ceil(b64PDF.length / 3)), -1, fileType, false);
1200
+ }
1201
+ else {
1202
+ return b64PDF;
1203
+ }
1204
+ },
1205
+ workerTaskWeight: 2,
1206
+ maxConcurrency: 1,
1207
+ timeoutOverride: 300000
1208
+ }
1209
+ });
1210
+ }