@resolveio/server-lib 22.3.220 → 22.3.221

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