@machinemetrics/mm-erp-sdk 0.1.9-beta.2 → 0.1.9-beta.4

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 (316) hide show
  1. package/dist/index.d.ts +42 -42
  2. package/dist/index.d.ts.map +1 -1
  3. package/dist/index.js +48 -0
  4. package/dist/index.js.map +1 -0
  5. package/dist/knexfile.d.ts.map +1 -1
  6. package/dist/knexfile.js +19 -0
  7. package/dist/knexfile.js.map +1 -0
  8. package/dist/migrations/20241015162631_create_cache_table.d.ts +4 -0
  9. package/dist/migrations/20241015162631_create_cache_table.d.ts.map +1 -0
  10. package/dist/migrations/20241015162631_create_cache_table.js +11 -15
  11. package/dist/migrations/20241015162631_create_cache_table.js.map +1 -1
  12. package/dist/migrations/20241015162632_create_sdk_cache_table.d.ts +4 -0
  13. package/dist/migrations/20241015162632_create_sdk_cache_table.d.ts.map +1 -0
  14. package/dist/migrations/20241015162632_create_sdk_cache_table.js +11 -15
  15. package/dist/migrations/20241015162632_create_sdk_cache_table.js.map +1 -1
  16. package/dist/migrations/20250103162631_create_record_tracking_table.d.ts +4 -0
  17. package/dist/migrations/20250103162631_create_record_tracking_table.d.ts.map +1 -0
  18. package/dist/migrations/20250103162631_create_record_tracking_table.js +14 -15
  19. package/dist/migrations/20250103162631_create_record_tracking_table.js.map +1 -1
  20. package/dist/services/caching-service/batch-cache-manager.d.ts +1 -1
  21. package/dist/services/caching-service/batch-cache-manager.d.ts.map +1 -1
  22. package/dist/services/caching-service/batch-cache-manager.js +84 -0
  23. package/dist/services/caching-service/batch-cache-manager.js.map +1 -0
  24. package/dist/services/caching-service/hashed-cache-manager.d.ts +2 -2
  25. package/dist/services/caching-service/hashed-cache-manager.d.ts.map +1 -1
  26. package/dist/services/caching-service/hashed-cache-manager.js +223 -0
  27. package/dist/services/caching-service/hashed-cache-manager.js.map +1 -0
  28. package/dist/services/caching-service/index.d.ts +1 -1
  29. package/dist/services/caching-service/index.d.ts.map +1 -1
  30. package/dist/services/caching-service/index.js +2 -0
  31. package/dist/services/caching-service/index.js.map +1 -0
  32. package/dist/services/caching-service/record-tracking-manager.d.ts +1 -1
  33. package/dist/services/caching-service/record-tracking-manager.d.ts.map +1 -1
  34. package/dist/services/caching-service/record-tracking-manager.js +28 -0
  35. package/dist/services/caching-service/record-tracking-manager.js.map +1 -0
  36. package/dist/services/data-sync-service/configuration-manager.d.ts +1 -1
  37. package/dist/services/data-sync-service/configuration-manager.d.ts.map +1 -1
  38. package/dist/services/data-sync-service/configuration-manager.js +163 -0
  39. package/dist/services/data-sync-service/configuration-manager.js.map +1 -0
  40. package/dist/services/data-sync-service/data-sync-service.d.ts.map +1 -1
  41. package/dist/services/data-sync-service/data-sync-service.js +95 -0
  42. package/dist/services/data-sync-service/data-sync-service.js.map +1 -0
  43. package/dist/services/data-sync-service/index.d.ts +3 -3
  44. package/dist/services/data-sync-service/index.d.ts.map +1 -1
  45. package/dist/services/data-sync-service/index.js +10 -0
  46. package/dist/services/data-sync-service/index.js.map +1 -0
  47. package/dist/services/data-sync-service/jobs/clean-up-expired-cache.js +40 -39
  48. package/dist/services/data-sync-service/jobs/clean-up-expired-cache.js.map +1 -1
  49. package/dist/services/data-sync-service/jobs/from-erp.js +48 -43
  50. package/dist/services/data-sync-service/jobs/from-erp.js.map +1 -1
  51. package/dist/services/data-sync-service/jobs/retry-failed-labor-tickets.js +36 -35
  52. package/dist/services/data-sync-service/jobs/retry-failed-labor-tickets.js.map +1 -1
  53. package/dist/services/data-sync-service/jobs/run-migrations.js +22 -21
  54. package/dist/services/data-sync-service/jobs/run-migrations.js.map +1 -1
  55. package/dist/services/data-sync-service/jobs/to-erp.js +48 -42
  56. package/dist/services/data-sync-service/jobs/to-erp.js.map +1 -1
  57. package/dist/services/erp-api-services/errors.d.ts +1 -1
  58. package/dist/services/erp-api-services/errors.d.ts.map +1 -1
  59. package/dist/services/erp-api-services/errors.js +83 -0
  60. package/dist/services/erp-api-services/errors.js.map +1 -0
  61. package/dist/services/erp-api-services/graphql/graphql-service.d.ts +2 -2
  62. package/dist/services/erp-api-services/graphql/graphql-service.d.ts.map +1 -1
  63. package/dist/services/erp-api-services/graphql/graphql-service.js +102 -0
  64. package/dist/services/erp-api-services/graphql/graphql-service.js.map +1 -0
  65. package/dist/services/erp-api-services/graphql/types.js +6 -0
  66. package/dist/services/erp-api-services/graphql/types.js.map +1 -0
  67. package/dist/services/erp-api-services/index.d.ts +8 -8
  68. package/dist/services/erp-api-services/index.d.ts.map +1 -1
  69. package/dist/services/erp-api-services/index.js +13 -0
  70. package/dist/services/erp-api-services/index.js.map +1 -0
  71. package/dist/services/erp-api-services/oauth-client.js +41 -0
  72. package/dist/services/erp-api-services/oauth-client.js.map +1 -0
  73. package/dist/services/erp-api-services/rest/get-query-params.js +23 -0
  74. package/dist/services/erp-api-services/rest/get-query-params.js.map +1 -0
  75. package/dist/services/erp-api-services/rest/rest-api-service.d.ts +2 -2
  76. package/dist/services/erp-api-services/rest/rest-api-service.d.ts.map +1 -1
  77. package/dist/services/erp-api-services/rest/rest-api-service.js +163 -0
  78. package/dist/services/erp-api-services/rest/rest-api-service.js.map +1 -0
  79. package/dist/services/erp-api-services/types.d.ts +2 -2
  80. package/dist/services/erp-api-services/types.d.ts.map +1 -1
  81. package/dist/services/erp-api-services/types.js +2 -0
  82. package/dist/services/erp-api-services/types.js.map +1 -0
  83. package/dist/services/mm-api-service/index.d.ts +6 -6
  84. package/dist/services/mm-api-service/index.d.ts.map +1 -1
  85. package/dist/services/mm-api-service/index.js +15 -0
  86. package/dist/services/mm-api-service/index.js.map +1 -0
  87. package/dist/services/mm-api-service/mm-api-service.d.ts +7 -7
  88. package/dist/services/mm-api-service/mm-api-service.d.ts.map +1 -1
  89. package/dist/services/mm-api-service/mm-api-service.js +519 -0
  90. package/dist/services/mm-api-service/mm-api-service.js.map +1 -0
  91. package/dist/services/mm-api-service/token-mgr.js +113 -0
  92. package/dist/services/mm-api-service/token-mgr.js.map +1 -0
  93. package/dist/services/mm-api-service/types/checkpoint.js +2 -0
  94. package/dist/services/mm-api-service/types/checkpoint.js.map +1 -0
  95. package/dist/services/mm-api-service/types/entity-transformer.d.ts +2 -2
  96. package/dist/services/mm-api-service/types/entity-transformer.d.ts.map +1 -1
  97. package/dist/services/mm-api-service/types/entity-transformer.js +186 -0
  98. package/dist/services/mm-api-service/types/entity-transformer.js.map +1 -0
  99. package/dist/services/mm-api-service/types/mm-response-interfaces.js +34 -0
  100. package/dist/services/mm-api-service/types/mm-response-interfaces.js.map +1 -0
  101. package/dist/services/mm-api-service/types/receive-types.js +55 -0
  102. package/dist/services/mm-api-service/types/receive-types.js.map +1 -0
  103. package/dist/services/mm-api-service/types/send-types.js +337 -0
  104. package/dist/services/mm-api-service/types/send-types.js.map +1 -0
  105. package/dist/services/psql-erp-service/configuration.js +2 -0
  106. package/dist/services/psql-erp-service/configuration.js.map +1 -0
  107. package/dist/services/psql-erp-service/index.d.ts +3 -3
  108. package/dist/services/psql-erp-service/index.d.ts.map +1 -1
  109. package/dist/services/psql-erp-service/index.js +10 -0
  110. package/dist/services/psql-erp-service/index.js.map +1 -0
  111. package/dist/services/psql-erp-service/internal/types/psql-types.js +5 -0
  112. package/dist/services/psql-erp-service/internal/types/psql-types.js.map +1 -0
  113. package/dist/services/psql-erp-service/psql-helpers.js +99 -0
  114. package/dist/services/psql-erp-service/psql-helpers.js.map +1 -0
  115. package/dist/services/psql-erp-service/psql-service.d.ts +2 -2
  116. package/dist/services/psql-erp-service/psql-service.d.ts.map +1 -1
  117. package/dist/services/psql-erp-service/psql-service.js +187 -0
  118. package/dist/services/psql-erp-service/psql-service.js.map +1 -0
  119. package/dist/services/reporting-service/index.d.ts +1 -1
  120. package/dist/services/reporting-service/index.d.ts.map +1 -1
  121. package/dist/services/reporting-service/index.js +5 -0
  122. package/dist/services/reporting-service/index.js.map +1 -0
  123. package/dist/services/reporting-service/logger.js +217 -0
  124. package/dist/services/reporting-service/logger.js.map +1 -0
  125. package/dist/services/sql-server-erp-service/configuration.js +2 -0
  126. package/dist/services/sql-server-erp-service/configuration.js.map +1 -0
  127. package/dist/services/sql-server-erp-service/index.d.ts +3 -3
  128. package/dist/services/sql-server-erp-service/index.d.ts.map +1 -1
  129. package/dist/services/sql-server-erp-service/index.js +11 -0
  130. package/dist/services/sql-server-erp-service/index.js.map +1 -0
  131. package/dist/services/sql-server-erp-service/internal/sql-labor-ticket-operations.d.ts +2 -2
  132. package/dist/services/sql-server-erp-service/internal/sql-labor-ticket-operations.d.ts.map +1 -1
  133. package/dist/services/sql-server-erp-service/internal/sql-labor-ticket-operations.js +50 -0
  134. package/dist/services/sql-server-erp-service/internal/sql-labor-ticket-operations.js.map +1 -0
  135. package/dist/services/sql-server-erp-service/internal/sql-server-config.js +40 -0
  136. package/dist/services/sql-server-erp-service/internal/sql-server-config.js.map +1 -0
  137. package/dist/services/sql-server-erp-service/internal/sql-transaction-manager.js +36 -0
  138. package/dist/services/sql-server-erp-service/internal/sql-transaction-manager.js.map +1 -0
  139. package/dist/services/sql-server-erp-service/internal/types/sql-server-types.js +2 -0
  140. package/dist/services/sql-server-erp-service/internal/types/sql-server-types.js.map +1 -0
  141. package/dist/services/sql-server-erp-service/sql-server-helpers.d.ts +3 -3
  142. package/dist/services/sql-server-erp-service/sql-server-helpers.d.ts.map +1 -1
  143. package/dist/services/sql-server-erp-service/sql-server-helpers.js +66 -0
  144. package/dist/services/sql-server-erp-service/sql-server-helpers.js.map +1 -0
  145. package/dist/services/sql-server-erp-service/sql-server-service.d.ts +2 -2
  146. package/dist/services/sql-server-erp-service/sql-server-service.d.ts.map +1 -1
  147. package/dist/services/sql-server-erp-service/sql-server-service.js +154 -0
  148. package/dist/services/sql-server-erp-service/sql-server-service.js.map +1 -0
  149. package/dist/services/sql-server-erp-service/types/sql-input-param.js +2 -0
  150. package/dist/services/sql-server-erp-service/types/sql-input-param.js.map +1 -0
  151. package/dist/services/sqlite-service/index.d.ts +1 -1
  152. package/dist/services/sqlite-service/index.d.ts.map +1 -1
  153. package/dist/services/sqlite-service/index.js +2 -0
  154. package/dist/services/sqlite-service/index.js.map +1 -0
  155. package/dist/services/sqlite-service/sqlite-coordinator.js +60 -0
  156. package/dist/services/sqlite-service/sqlite-coordinator.js.map +1 -0
  157. package/dist/types/erp-connector.d.ts +1 -1
  158. package/dist/types/erp-connector.d.ts.map +1 -1
  159. package/dist/types/erp-connector.js +2 -0
  160. package/dist/types/erp-connector.js.map +1 -0
  161. package/dist/types/erp-types.js +13 -0
  162. package/dist/types/erp-types.js.map +1 -0
  163. package/dist/types/index.d.ts +2 -2
  164. package/dist/types/index.d.ts.map +1 -1
  165. package/dist/types/index.js +6 -0
  166. package/dist/types/index.js.map +1 -0
  167. package/dist/utils/application-initializer.js +55 -0
  168. package/dist/utils/application-initializer.js.map +1 -0
  169. package/dist/utils/cleanup-numbers.js +6 -0
  170. package/dist/utils/cleanup-numbers.js.map +1 -0
  171. package/dist/utils/connector-factory.d.ts +1 -1
  172. package/dist/utils/connector-factory.d.ts.map +1 -1
  173. package/dist/utils/connector-factory.js +34 -0
  174. package/dist/utils/connector-factory.js.map +1 -0
  175. package/dist/utils/connector-log/log-deduper.d.ts +1 -1
  176. package/dist/utils/connector-log/log-deduper.d.ts.map +1 -1
  177. package/dist/utils/connector-log/log-deduper.js +240 -0
  178. package/dist/utils/connector-log/log-deduper.js.map +1 -0
  179. package/dist/utils/connector-log/mm-connector-logger-example.d.ts +1 -0
  180. package/dist/utils/connector-log/mm-connector-logger-example.js +88 -0
  181. package/dist/utils/connector-log/mm-connector-logger-example.js.map +1 -0
  182. package/dist/utils/connector-log/mm-connector-logger.d.ts +1 -1
  183. package/dist/utils/connector-log/mm-connector-logger.d.ts.map +1 -1
  184. package/dist/utils/connector-log/mm-connector-logger.js +151 -0
  185. package/dist/utils/connector-log/mm-connector-logger.js.map +1 -0
  186. package/dist/utils/data-transformation.js +38 -0
  187. package/dist/utils/data-transformation.js.map +1 -0
  188. package/dist/utils/erp-type-from-entity.d.ts +1 -1
  189. package/dist/utils/erp-type-from-entity.d.ts.map +1 -1
  190. package/dist/utils/erp-type-from-entity.js +6 -0
  191. package/dist/utils/erp-type-from-entity.js.map +1 -0
  192. package/dist/utils/error-utils.js +21 -0
  193. package/dist/utils/error-utils.js.map +1 -0
  194. package/dist/utils/http-client.js +186 -0
  195. package/dist/utils/http-client.js.map +1 -0
  196. package/dist/utils/index.d.ts +33 -33
  197. package/dist/utils/index.d.ts.map +1 -1
  198. package/dist/utils/index.js +65 -0
  199. package/dist/utils/index.js.map +1 -0
  200. package/dist/utils/local-data-store/database-lock.js +68 -0
  201. package/dist/utils/local-data-store/database-lock.js.map +1 -0
  202. package/dist/utils/local-data-store/jobs-shared-data.js +116 -0
  203. package/dist/utils/local-data-store/jobs-shared-data.js.map +1 -0
  204. package/dist/utils/mm-labor-ticket-helpers.d.ts +1 -1
  205. package/dist/utils/mm-labor-ticket-helpers.d.ts.map +1 -1
  206. package/dist/utils/mm-labor-ticket-helpers.js +23 -0
  207. package/dist/utils/mm-labor-ticket-helpers.js.map +1 -0
  208. package/dist/utils/removeExtraneousFields.d.ts +1 -1
  209. package/dist/utils/removeExtraneousFields.d.ts.map +1 -1
  210. package/dist/utils/removeExtraneousFields.js +16 -0
  211. package/dist/utils/removeExtraneousFields.js.map +1 -0
  212. package/dist/utils/removeIdFieldFromPayload.d.ts +1 -1
  213. package/dist/utils/removeIdFieldFromPayload.d.ts.map +1 -1
  214. package/dist/utils/removeIdFieldFromPayload.js +16 -0
  215. package/dist/utils/removeIdFieldFromPayload.js.map +1 -0
  216. package/dist/utils/resource-group.d.ts +1 -1
  217. package/dist/utils/resource-group.d.ts.map +1 -1
  218. package/dist/utils/resource-group.js +59 -0
  219. package/dist/utils/resource-group.js.map +1 -0
  220. package/dist/utils/standard-process-drivers/error-processor.d.ts +3 -3
  221. package/dist/utils/standard-process-drivers/error-processor.d.ts.map +1 -1
  222. package/dist/utils/standard-process-drivers/error-processor.js +262 -0
  223. package/dist/utils/standard-process-drivers/error-processor.js.map +1 -0
  224. package/dist/utils/standard-process-drivers/index.d.ts +3 -3
  225. package/dist/utils/standard-process-drivers/index.d.ts.map +1 -1
  226. package/dist/utils/standard-process-drivers/index.js +4 -0
  227. package/dist/utils/standard-process-drivers/index.js.map +1 -0
  228. package/dist/utils/standard-process-drivers/labor-ticket-erp-synchronizer.d.ts +1 -1
  229. package/dist/utils/standard-process-drivers/labor-ticket-erp-synchronizer.d.ts.map +1 -1
  230. package/dist/utils/standard-process-drivers/labor-ticket-erp-synchronizer.js +164 -0
  231. package/dist/utils/standard-process-drivers/labor-ticket-erp-synchronizer.js.map +1 -0
  232. package/dist/utils/standard-process-drivers/mm-entity-processor.d.ts +4 -4
  233. package/dist/utils/standard-process-drivers/mm-entity-processor.d.ts.map +1 -1
  234. package/dist/utils/standard-process-drivers/mm-entity-processor.js +168 -0
  235. package/dist/utils/standard-process-drivers/mm-entity-processor.js.map +1 -0
  236. package/dist/utils/standard-process-drivers/standard-process-drivers.d.ts +4 -4
  237. package/dist/utils/standard-process-drivers/standard-process-drivers.d.ts.map +1 -1
  238. package/dist/utils/standard-process-drivers/standard-process-drivers.js +324 -0
  239. package/dist/utils/standard-process-drivers/standard-process-drivers.js.map +1 -0
  240. package/dist/utils/time-utils.js +96 -0
  241. package/dist/utils/time-utils.js.map +1 -0
  242. package/dist/utils/timezone.js +105 -0
  243. package/dist/utils/timezone.js.map +1 -0
  244. package/dist/utils/trimObjectValues.js +11 -0
  245. package/dist/utils/trimObjectValues.js.map +1 -0
  246. package/dist/utils/uniqueRows.js +35 -0
  247. package/dist/utils/uniqueRows.js.map +1 -0
  248. package/package.json +5 -6
  249. package/src/index.ts +42 -42
  250. package/src/knexfile.ts +1 -0
  251. package/src/services/caching-service/batch-cache-manager.ts +2 -2
  252. package/src/services/caching-service/hashed-cache-manager.ts +5 -5
  253. package/src/services/caching-service/index.ts +1 -1
  254. package/src/services/caching-service/record-tracking-manager.ts +2 -2
  255. package/src/services/data-sync-service/configuration-manager.ts +2 -2
  256. package/src/services/data-sync-service/data-sync-service.ts +9 -3
  257. package/src/services/data-sync-service/index.ts +3 -3
  258. package/src/services/data-sync-service/jobs/clean-up-expired-cache.ts +3 -3
  259. package/src/services/data-sync-service/jobs/from-erp.ts +3 -3
  260. package/src/services/data-sync-service/jobs/retry-failed-labor-tickets.ts +2 -2
  261. package/src/services/data-sync-service/jobs/run-migrations.ts +2 -2
  262. package/src/services/data-sync-service/jobs/to-erp.ts +2 -2
  263. package/src/services/erp-api-services/errors.ts +3 -3
  264. package/src/services/erp-api-services/graphql/graphql-service.ts +5 -5
  265. package/src/services/erp-api-services/index.ts +8 -8
  266. package/src/services/erp-api-services/rest/rest-api-service.ts +4 -4
  267. package/src/services/erp-api-services/types.ts +2 -2
  268. package/src/services/mm-api-service/index.ts +6 -6
  269. package/src/services/mm-api-service/mm-api-service.ts +10 -10
  270. package/src/services/mm-api-service/token-mgr.ts +4 -4
  271. package/src/services/mm-api-service/types/entity-transformer.ts +3 -3
  272. package/src/services/psql-erp-service/index.ts +3 -3
  273. package/src/services/psql-erp-service/psql-service.ts +4 -4
  274. package/src/services/reporting-service/index.ts +1 -1
  275. package/src/services/sql-server-erp-service/index.ts +3 -3
  276. package/src/services/sql-server-erp-service/internal/sql-labor-ticket-operations.ts +2 -2
  277. package/src/services/sql-server-erp-service/internal/sql-transaction-manager.ts +1 -1
  278. package/src/services/sql-server-erp-service/sql-server-helpers.ts +6 -6
  279. package/src/services/sql-server-erp-service/sql-server-service.ts +4 -4
  280. package/src/services/sqlite-service/index.ts +1 -1
  281. package/src/services/sqlite-service/sqlite-coordinator.ts +2 -2
  282. package/src/types/erp-connector.ts +1 -1
  283. package/src/types/index.ts +2 -2
  284. package/src/utils/application-initializer.ts +5 -5
  285. package/src/utils/connector-factory.ts +2 -2
  286. package/src/utils/connector-log/log-deduper.ts +2 -2
  287. package/src/utils/connector-log/mm-connector-logger.ts +3 -3
  288. package/src/utils/erp-type-from-entity.ts +1 -1
  289. package/src/utils/http-client.ts +1 -1
  290. package/src/utils/index.ts +33 -33
  291. package/src/utils/local-data-store/database-lock.ts +1 -1
  292. package/src/utils/mm-labor-ticket-helpers.ts +2 -2
  293. package/src/utils/removeExtraneousFields.ts +1 -1
  294. package/src/utils/removeIdFieldFromPayload.ts +1 -1
  295. package/src/utils/resource-group.ts +2 -2
  296. package/src/utils/standard-process-drivers/error-processor.ts +5 -5
  297. package/src/utils/standard-process-drivers/index.ts +3 -3
  298. package/src/utils/standard-process-drivers/labor-ticket-erp-synchronizer.ts +6 -6
  299. package/src/utils/standard-process-drivers/mm-entity-processor.ts +7 -7
  300. package/src/utils/standard-process-drivers/standard-process-drivers.ts +6 -6
  301. package/src/utils/time-utils.ts +3 -3
  302. package/src/utils/timezone.ts +2 -2
  303. package/dist/config-Bax6Ofp5.js +0 -418
  304. package/dist/config-Bax6Ofp5.js.map +0 -1
  305. package/dist/connector-factory-BaMIlES8.js +0 -30
  306. package/dist/connector-factory-BaMIlES8.js.map +0 -1
  307. package/dist/hashed-cache-manager-C1u9jQgY.js +0 -322
  308. package/dist/hashed-cache-manager-C1u9jQgY.js.map +0 -1
  309. package/dist/index-BkVlW0ZW.js +0 -192
  310. package/dist/index-BkVlW0ZW.js.map +0 -1
  311. package/dist/knexfile-Bng2Ru9c.js +0 -20
  312. package/dist/knexfile-Bng2Ru9c.js.map +0 -1
  313. package/dist/logger-DW5fyhVS.js +0 -17593
  314. package/dist/logger-DW5fyhVS.js.map +0 -1
  315. package/dist/mm-erp-sdk.js +0 -4266
  316. package/dist/mm-erp-sdk.js.map +0 -1
@@ -0,0 +1,223 @@
1
+ import knex from "knex";
2
+ import config from "../../knexfile.js";
3
+ import stringify from "json-stable-stringify";
4
+ import XXH from "xxhashjs";
5
+ import { CoreConfiguration } from "../data-sync-service/configuration-manager.js";
6
+ import { logger } from "../reporting-service/index.js";
7
+ export class HashedCacheManager {
8
+ static TABLE_NAME = "sdk_cache";
9
+ db;
10
+ options;
11
+ static SEED = 0xabcd; // Arbitrary seed for hashing
12
+ isDestroyed = false;
13
+ metrics = {
14
+ recordCounts: {},
15
+ };
16
+ constructor(options) {
17
+ this.options = {
18
+ ttl: options?.ttl || CoreConfiguration.inst().cacheTTL,
19
+ tableName: options?.tableName || HashedCacheManager.TABLE_NAME,
20
+ };
21
+ this.db = knex({
22
+ ...config.local,
23
+ pool: {
24
+ min: 0,
25
+ max: 10,
26
+ },
27
+ });
28
+ }
29
+ /**
30
+ * Checks if the cache manager is still valid
31
+ * @throws Error if the cache manager has been destroyed
32
+ */
33
+ checkValid() {
34
+ if (this.isDestroyed) {
35
+ throw new Error("Cache manager has been destroyed");
36
+ }
37
+ }
38
+ /**
39
+ * Generates a stable hash of a record using JSON stringify + xxhash
40
+ */
41
+ static hashRecord(record) {
42
+ try {
43
+ const serialized = stringify(record);
44
+ if (!serialized) {
45
+ throw new Error("Failed to serialize record for hashing");
46
+ }
47
+ const hash = XXH.h64(serialized, HashedCacheManager.SEED).toString(16);
48
+ return hash;
49
+ }
50
+ catch (error) {
51
+ if (error instanceof Error && error.message.includes("circular")) {
52
+ throw new Error("Failed to serialize record for hashing");
53
+ }
54
+ throw error;
55
+ }
56
+ }
57
+ /**
58
+ * Gets a record from the cache
59
+ * @param type The type of record
60
+ * @param hash The hash of the record
61
+ * @returns The record if it exists, null otherwise
62
+ */
63
+ async getRecord(type, hash) {
64
+ this.checkValid();
65
+ return this.db(this.options.tableName)
66
+ .select("key")
67
+ .where({ type, key: hash })
68
+ .first();
69
+ }
70
+ /**
71
+ * Stores a record in the cache
72
+ * @param type The type of record
73
+ * @param record The record to store
74
+ * @returns true if a new record was created, false if an existing record was updated
75
+ */
76
+ async store(type, record) {
77
+ if (!this.isDestroyed && record) {
78
+ try {
79
+ const hash = HashedCacheManager.hashRecord(record);
80
+ const now = new Date();
81
+ // First check if record exists with same type and hash
82
+ const existing = await this.db(this.options.tableName)
83
+ .where({
84
+ type,
85
+ key: hash,
86
+ })
87
+ .first();
88
+ if (existing) {
89
+ return false; // No need to update, hash hasn't changed
90
+ }
91
+ else {
92
+ // Insert new record with minimal data
93
+ const result = await this.db(this.options.tableName)
94
+ .insert({
95
+ type,
96
+ key: hash,
97
+ created_at: now,
98
+ })
99
+ .returning("id");
100
+ return result.length > 0;
101
+ }
102
+ }
103
+ catch (error) {
104
+ logger.error("Error storing record:", error);
105
+ throw error;
106
+ }
107
+ }
108
+ return false;
109
+ }
110
+ /**
111
+ * Checks if a record has changed since last seen
112
+ * @param type The type of record
113
+ * @param record The record to check
114
+ * @returns true if the record has changed or is new
115
+ */
116
+ async hasChanged(type, record) {
117
+ this.checkValid();
118
+ const newHash = HashedCacheManager.hashRecord(record);
119
+ const existing = await this.getRecord(type, newHash);
120
+ return !existing;
121
+ }
122
+ /**
123
+ * Checks if a record has changed and stores it if it has
124
+ * @param type The type of record
125
+ * @param record The record to check and store
126
+ * @returns true if the record was changed or is new
127
+ */
128
+ async upsert(type, record) {
129
+ this.checkValid();
130
+ const hasChanged = await this.hasChanged(type, record);
131
+ if (hasChanged) {
132
+ await this.store(type, record);
133
+ }
134
+ return hasChanged;
135
+ }
136
+ /**
137
+ * Removes expired records based on TTL
138
+ */
139
+ async removeExpiredObjects() {
140
+ this.checkValid();
141
+ const ttl = this.options.ttl;
142
+ if (!ttl)
143
+ return;
144
+ const ttlMilliseconds = ttl * 1000;
145
+ const expirationLimitDate = new Date(Date.now() - ttlMilliseconds);
146
+ const expirationLimit = expirationLimitDate
147
+ .toISOString()
148
+ .slice(0, 19)
149
+ .replace("T", " ");
150
+ await this.db(this.options.tableName)
151
+ .where("created_at", "<", expirationLimit)
152
+ .del();
153
+ }
154
+ /**
155
+ * Gets all records of a specific type
156
+ */
157
+ async getRecordsByType(type) {
158
+ this.checkValid();
159
+ const records = await this.db(this.options.tableName)
160
+ .select("key")
161
+ .where({ type });
162
+ return records.map((record) => record.key);
163
+ }
164
+ /**
165
+ * Removes all records of a specific type
166
+ */
167
+ async removeRecordsByType(type) {
168
+ this.checkValid();
169
+ await this.db(this.options.tableName).where({ type }).del();
170
+ }
171
+ /**
172
+ * Removes a specific record
173
+ */
174
+ async removeRecord(type, record) {
175
+ if (!this.isDestroyed) {
176
+ try {
177
+ const hash = HashedCacheManager.hashRecord(record);
178
+ await this.db(this.options.tableName)
179
+ .where({ type, key: hash }) // Use key for deletion
180
+ .del();
181
+ }
182
+ catch (error) {
183
+ logger.error("Error removing record:", error);
184
+ throw error;
185
+ }
186
+ }
187
+ }
188
+ /**
189
+ * Clears all records from the cache
190
+ */
191
+ async clear() {
192
+ this.checkValid();
193
+ await this.db(this.options.tableName).del();
194
+ }
195
+ /**
196
+ * Cleans up database connection and marks the cache manager as destroyed
197
+ */
198
+ async destroy() {
199
+ if (!this.isDestroyed) {
200
+ await this.db.destroy();
201
+ this.isDestroyed = true;
202
+ }
203
+ }
204
+ /**
205
+ * Gets the current cache metrics
206
+ * @returns The current cache metrics
207
+ */
208
+ async getMetrics() {
209
+ this.checkValid();
210
+ // Get counts for each type
211
+ const counts = (await this.db(this.options.tableName)
212
+ .select("type")
213
+ .count("* as count")
214
+ .groupBy("type"));
215
+ // Update metrics
216
+ this.metrics.recordCounts = counts.reduce((acc, row) => {
217
+ acc[row.type] = parseInt(row.count, 10);
218
+ return acc;
219
+ }, {});
220
+ return this.metrics;
221
+ }
222
+ }
223
+ //# sourceMappingURL=hashed-cache-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hashed-cache-manager.js","sourceRoot":"","sources":["../../../src/services/caching-service/hashed-cache-manager.ts"],"names":[],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import { ERPObjType, ERPObject } from "../../types/erp-types";
1
+ import { ERPObjType, ERPObject } from "../../types/erp-types.js";
2
2
  export interface CacheServiceConfig {
3
3
  tableName: string;
4
4
  ttl?: number;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/caching-service/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAE9D,MAAM,WAAW,kBAAkB;IACjC,SAAS,EAAE,MAAM,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,YAAY;IAC3B;;;OAGG;IACH,YAAY,EAAE;QACZ,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAAC;KACxB,CAAC;CACH;AAED,MAAM,WAAW,YAAY;IAC3B;;;;;;OAMG;IACH,UAAU,CACR,IAAI,EAAE,UAAU,EAChB,GAAG,EAAE,MAAM,EACX,MAAM,EAAE,SAAS,GAChB,OAAO,CAAC,OAAO,CAAC,CAAC;IAEpB;;;;;OAKG;IACH,KAAK,CAAC,IAAI,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEvE;;;;;;OAMG;IACH,MAAM,CAAC,IAAI,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAE3E;;;;;;OAMG;IACH,UAAU,CACR,IAAI,EAAE,UAAU,EAChB,OAAO,EAAE,SAAS,EAAE,EACpB,OAAO,EAAE,MAAM,GACd,OAAO,CAAC;QAAE,UAAU,EAAE,SAAS,EAAE,CAAC;QAAC,aAAa,EAAE,SAAS,EAAE,CAAA;KAAE,CAAC,CAAC;IAEpE;;;;;OAKG;IACH,UAAU,CACR,IAAI,EAAE,UAAU,EAChB,OAAO,EAAE,SAAS,EAAE,EACpB,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,IAAI,CAAC,CAAC;IAEjB;;;;OAIG;IACH,gBAAgB,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IAEtD;;;OAGG;IACH,mBAAmB,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAErD;;;;OAIG;IACH,YAAY,CAAC,IAAI,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE3D;;OAEG;IACH,oBAAoB,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtC;;OAEG;IACH,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEvB;;;OAGG;IACH,UAAU,IAAI,YAAY,CAAC;IAE3B;;OAEG;IACH,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CAC1B"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/caching-service/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AAEjE,MAAM,WAAW,kBAAkB;IACjC,SAAS,EAAE,MAAM,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,YAAY;IAC3B;;;OAGG;IACH,YAAY,EAAE;QACZ,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAAC;KACxB,CAAC;CACH;AAED,MAAM,WAAW,YAAY;IAC3B;;;;;;OAMG;IACH,UAAU,CACR,IAAI,EAAE,UAAU,EAChB,GAAG,EAAE,MAAM,EACX,MAAM,EAAE,SAAS,GAChB,OAAO,CAAC,OAAO,CAAC,CAAC;IAEpB;;;;;OAKG;IACH,KAAK,CAAC,IAAI,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEvE;;;;;;OAMG;IACH,MAAM,CAAC,IAAI,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAE3E;;;;;;OAMG;IACH,UAAU,CACR,IAAI,EAAE,UAAU,EAChB,OAAO,EAAE,SAAS,EAAE,EACpB,OAAO,EAAE,MAAM,GACd,OAAO,CAAC;QAAE,UAAU,EAAE,SAAS,EAAE,CAAC;QAAC,aAAa,EAAE,SAAS,EAAE,CAAA;KAAE,CAAC,CAAC;IAEpE;;;;;OAKG;IACH,UAAU,CACR,IAAI,EAAE,UAAU,EAChB,OAAO,EAAE,SAAS,EAAE,EACpB,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,IAAI,CAAC,CAAC;IAEjB;;;;OAIG;IACH,gBAAgB,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IAEtD;;;OAGG;IACH,mBAAmB,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAErD;;;;OAIG;IACH,YAAY,CAAC,IAAI,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE3D;;OAEG;IACH,oBAAoB,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtC;;OAEG;IACH,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEvB;;;OAGG;IACH,UAAU,IAAI,YAAY,CAAC;IAE3B;;OAEG;IACH,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CAC1B"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/caching-service/index.ts"],"names":[],"mappings":""}
@@ -1,5 +1,5 @@
1
1
  import { Knex } from "knex";
2
- import { ERPObjType } from "../../types/erp-types";
2
+ import { ERPObjType } from "../../types/erp-types.js";
3
3
  export type RecordTrackingObject = {
4
4
  entityType?: ERPObjType;
5
5
  lastValue: string;
@@ -1 +1 @@
1
- {"version":3,"file":"record-tracking-manager.d.ts","sourceRoot":"","sources":["../../../src/services/caching-service/record-tracking-manager.ts"],"names":[],"mappings":"AAAA,OAAa,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAElC,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAInD,MAAM,MAAM,oBAAoB,GAAG;IACjC,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,qBAAa,qBAAqB;IAChC,EAAE,EAAE,IAAI,CAAC;;IAMH,YAAY,CAAC,MAAM,EAAE,oBAAoB;IAYzC,iBAAiB,CAAC,IAAI,EAAE,UAAU;IAMlC,OAAO;CAGd"}
1
+ {"version":3,"file":"record-tracking-manager.d.ts","sourceRoot":"","sources":["../../../src/services/caching-service/record-tracking-manager.ts"],"names":[],"mappings":"AAAA,OAAa,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAElC,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAItD,MAAM,MAAM,oBAAoB,GAAG;IACjC,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,qBAAa,qBAAqB;IAChC,EAAE,EAAE,IAAI,CAAC;;IAMH,YAAY,CAAC,MAAM,EAAE,oBAAoB;IAYzC,iBAAiB,CAAC,IAAI,EAAE,UAAU;IAMlC,OAAO;CAGd"}
@@ -0,0 +1,28 @@
1
+ import knex from "knex";
2
+ import config from "../../knexfile.js";
3
+ const DEFAULT_RECORD_TRACKING_TABLE_NAME = "record_tracking";
4
+ export class RecordTrackingManager {
5
+ db;
6
+ constructor() {
7
+ this.db = knex(config.local);
8
+ }
9
+ async updateRecord(record) {
10
+ if (record.lastValue && record.recordId) {
11
+ const recordUpdated = await this.db(DEFAULT_RECORD_TRACKING_TABLE_NAME)
12
+ .where({ entityType: record.entityType })
13
+ .update(record);
14
+ if (recordUpdated < 1) {
15
+ await this.db(DEFAULT_RECORD_TRACKING_TABLE_NAME).insert(record);
16
+ }
17
+ }
18
+ }
19
+ async getTrackingRecord(type) {
20
+ return await this.db(DEFAULT_RECORD_TRACKING_TABLE_NAME)
21
+ .select("*")
22
+ .where({ entityType: type.toString() });
23
+ }
24
+ async destroy() {
25
+ return this.db.destroy();
26
+ }
27
+ }
28
+ //# sourceMappingURL=record-tracking-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"record-tracking-manager.js","sourceRoot":"","sources":["../../../src/services/caching-service/record-tracking-manager.ts"],"names":[],"mappings":"AAAA,OAAO,IAAc,MAAM,MAAM,CAAC;AAClC,OAAO,MAAM,MAAM,mBAAmB,CAAC;AAGvC,MAAM,kCAAkC,GAAG,iBAAiB,CAAC;AAQ7D,MAAM,OAAO,qBAAqB;IAChC,EAAE,CAAO;IAET;QACE,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,MAA4B;QAC7C,IAAI,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;YACxC,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,EAAE,CAAC,kCAAkC,CAAC;iBACpE,KAAK,CAAC,EAAE,UAAU,EAAE,MAAM,CAAC,UAAU,EAAE,CAAC;iBACxC,MAAM,CAAC,MAAM,CAAC,CAAC;YAElB,IAAI,aAAa,GAAG,CAAC,EAAE,CAAC;gBACtB,MAAM,IAAI,CAAC,EAAE,CAAC,kCAAkC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YACnE,CAAC;QACH,CAAC;IACH,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,IAAgB;QACtC,OAAO,MAAM,IAAI,CAAC,EAAE,CAAC,kCAAkC,CAAC;aACrD,MAAM,CAAC,GAAG,CAAC;aACX,KAAK,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IAC5C,CAAC;IAED,KAAK,CAAC,OAAO;QACX,OAAO,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;CACF"}
@@ -1,5 +1,5 @@
1
1
  import "dotenv/config";
2
- import { SQLServerConfiguration } from "../sql-server-erp-service/configuration";
2
+ import { SQLServerConfiguration } from "../sql-server-erp-service/configuration.js";
3
3
  export declare class CoreConfiguration {
4
4
  private static instance;
5
5
  readonly logLevel: string;
@@ -1 +1 @@
1
- {"version":3,"file":"configuration-manager.d.ts","sourceRoot":"","sources":["../../../src/services/data-sync-service/configuration-manager.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,CAAC;AAEvB,OAAO,EAAE,sBAAsB,EAAE,MAAM,yCAAyC,CAAC;AAEjF,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAoB;IAG3C,SAAgB,QAAQ,EAAE,MAAM,CAAC;IACjC,SAAgB,SAAS,EAAE,MAAM,CAAC;IAClC,SAAgB,OAAO,EAAE,MAAM,CAAC;IAGhC,SAAgB,kBAAkB,EAAE,MAAM,CAAC;IAC3C,SAAgB,YAAY,EAAE,MAAM,CAAC;IACrC,SAAgB,cAAc,EAAE,MAAM,CAAC;IACvC,SAAgB,kBAAkB,EAAE,MAAM,CAAC;IAG3C,SAAgB,QAAQ,EAAE,MAAM,CAAC;IAGjC,SAAgB,iBAAiB,EAAE,MAAM,CAAC;IAG1C,SAAgB,eAAe,EAAE,MAAM,CAAC;IACxC,SAAgB,aAAa,EAAE,MAAM,CAAC;IACtC,SAAgB,yBAAyB,EAAE,MAAM,CAAC;IAClD,SAAgB,4BAA4B,EAAE,MAAM,CAAC;IAErD,OAAO;WA0DO,IAAI,IAAI,iBAAiB;IAOvC;;;OAGG;IACI,eAAe,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CA4BlD;AAED;;GAEG;AACH,eAAO,MAAM,yBAAyB,QAAO,sBAiB5C,CAAC;AAEF;;;GAGG;AACH,qBAAa,sBAAsB;aAEf,SAAS,EAAE,MAAM;aACjB,cAAc,EAAE,MAAM;aACtB,kBAAkB,EAAE,MAAM;aAC1B,oBAAoB,EAAE,MAAM;aAC5B,cAAc,EAAE,MAAM;aACtB,aAAa,EAAE,MAAM;gBALrB,SAAS,EAAE,MAAM,EAAE,kBAAkB;IACrC,cAAc,EAAE,MAAM,EAAE,qCAAqC;IAC7D,kBAAkB,EAAE,MAAM,EAAE,yCAAyC;IACrE,oBAAoB,EAAE,MAAM,EAAE,2BAA2B;IACzD,cAAc,EAAE,MAAM,EAAE,gBAAgB;IACxC,aAAa,GAAE,MAAU;CAE5C;AAED;;;;GAIG;AACH,eAAO,MAAM,yBAAyB,QAAO,sBAS5C,CAAC"}
1
+ {"version":3,"file":"configuration-manager.d.ts","sourceRoot":"","sources":["../../../src/services/data-sync-service/configuration-manager.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,CAAC;AAEvB,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AAEpF,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAoB;IAG3C,SAAgB,QAAQ,EAAE,MAAM,CAAC;IACjC,SAAgB,SAAS,EAAE,MAAM,CAAC;IAClC,SAAgB,OAAO,EAAE,MAAM,CAAC;IAGhC,SAAgB,kBAAkB,EAAE,MAAM,CAAC;IAC3C,SAAgB,YAAY,EAAE,MAAM,CAAC;IACrC,SAAgB,cAAc,EAAE,MAAM,CAAC;IACvC,SAAgB,kBAAkB,EAAE,MAAM,CAAC;IAG3C,SAAgB,QAAQ,EAAE,MAAM,CAAC;IAGjC,SAAgB,iBAAiB,EAAE,MAAM,CAAC;IAG1C,SAAgB,eAAe,EAAE,MAAM,CAAC;IACxC,SAAgB,aAAa,EAAE,MAAM,CAAC;IACtC,SAAgB,yBAAyB,EAAE,MAAM,CAAC;IAClD,SAAgB,4BAA4B,EAAE,MAAM,CAAC;IAErD,OAAO;WA0DO,IAAI,IAAI,iBAAiB;IAOvC;;;OAGG;IACI,eAAe,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CA4BlD;AAED;;GAEG;AACH,eAAO,MAAM,yBAAyB,QAAO,sBAiB5C,CAAC;AAEF;;;GAGG;AACH,qBAAa,sBAAsB;aAEf,SAAS,EAAE,MAAM;aACjB,cAAc,EAAE,MAAM;aACtB,kBAAkB,EAAE,MAAM;aAC1B,oBAAoB,EAAE,MAAM;aAC5B,cAAc,EAAE,MAAM;aACtB,aAAa,EAAE,MAAM;gBALrB,SAAS,EAAE,MAAM,EAAE,kBAAkB;IACrC,cAAc,EAAE,MAAM,EAAE,qCAAqC;IAC7D,kBAAkB,EAAE,MAAM,EAAE,yCAAyC;IACrE,oBAAoB,EAAE,MAAM,EAAE,2BAA2B;IACzD,cAAc,EAAE,MAAM,EAAE,gBAAgB;IACxC,aAAa,GAAE,MAAU;CAE5C;AAED;;;;GAIG;AACH,eAAO,MAAM,yBAAyB,QAAO,sBAS5C,CAAC"}
@@ -0,0 +1,163 @@
1
+ import "dotenv/config";
2
+ import { configureLogger } from "../reporting-service/logger.js";
3
+ export class CoreConfiguration {
4
+ static instance;
5
+ // General Configuration
6
+ logLevel;
7
+ erpSystem;
8
+ nodeEnv;
9
+ // MM API (aka "Mapping") Service
10
+ mmERPSvcApiBaseUrl;
11
+ mmApiBaseUrl;
12
+ mmApiAuthToken;
13
+ mmApiRetryAttempts;
14
+ // Caching (optionally used for interacting with the MM API)
15
+ cacheTTL;
16
+ // ERP API Service
17
+ erpApiPagingLimit; //Pagination limit for ERP API
18
+ // Job timing Intervals
19
+ fromErpInterval;
20
+ toErpInterval;
21
+ retryLaborTicketsInterval;
22
+ cacheExpirationCheckInterval;
23
+ constructor() {
24
+ this.logLevel = process.env.LOG_LEVEL || "info";
25
+ this.erpSystem = process.env.ERP_SYSTEM || "template";
26
+ this.nodeEnv = process.env.NODE_ENV || "development";
27
+ //#region MM API (aka "Mapping") Service
28
+ /**
29
+ * MM ERP Service REST API URL (typically https://erp-api.svc.machinemetrics.com)
30
+ */
31
+ this.mmERPSvcApiBaseUrl = process.env.MM_MAPPING_SERVICE_URL || "";
32
+ /**
33
+ * MM REST API URL (typically https://api.machinemetrics.com)
34
+ */
35
+ console.log("=== CONFIG DEBUG ===");
36
+ console.log("MM_MAPPING_AUTH_SERVICE_URL env var:", process.env.MM_MAPPING_AUTH_SERVICE_URL);
37
+ this.mmApiBaseUrl = process.env.MM_MAPPING_AUTH_SERVICE_URL || "";
38
+ console.log("mmApiBaseUrl set to:", this.mmApiBaseUrl);
39
+ console.log("=== END CONFIG DEBUG ===");
40
+ /**
41
+ * Company Auth Token
42
+ */
43
+ this.mmApiAuthToken = process.env.MM_MAPPING_SERVICE_TOKEN || "";
44
+ /**
45
+ * Number of retry attempts for MM API calls
46
+ */
47
+ this.mmApiRetryAttempts = parseInt(process.env.RETRY_ATTEMPTS || "0");
48
+ //#endregion MM API (aka "Mapping") Service
49
+ /**
50
+ * Default pagination limit for ERP API
51
+ */
52
+ this.erpApiPagingLimit = parseInt(process.env.ERP_PAGINATION_LIMIT || "0");
53
+ //#endregion ERP API Service
54
+ /**
55
+ * For how to define the intervals, see Bree's documentation: https://github.com/breejs/bree
56
+ */
57
+ this.fromErpInterval =
58
+ process.env.FROM_ERP_INTERVAL || process.env.POLL_INTERVAL || "5 min";
59
+ this.toErpInterval = process.env.TO_ERP_INTERVAL || "5 min";
60
+ this.retryLaborTicketsInterval =
61
+ process.env.RETRY_LABOR_TICKETS_INTERVAL || "30 min";
62
+ this.cacheExpirationCheckInterval =
63
+ process.env.CACHE_EXPIRATION_CHECK_INTERVAL || "5 min";
64
+ /**
65
+ * Cache TTL (in seconds)
66
+ */
67
+ const cacheTTLDef = 7 * 24 * 60 * 60; // 7 days
68
+ this.cacheTTL = parseInt(process.env.CACHE_TTL || cacheTTLDef.toString());
69
+ // Configure the logger with our settings
70
+ configureLogger(this.logLevel, this.nodeEnv);
71
+ }
72
+ static inst() {
73
+ if (!CoreConfiguration.instance) {
74
+ CoreConfiguration.instance = new CoreConfiguration();
75
+ }
76
+ return CoreConfiguration.instance;
77
+ }
78
+ /**
79
+ * Returns a sanitized version of the configuration for safe logging.
80
+ * Masks sensitive fields like authentication tokens.
81
+ */
82
+ toSafeLogObject() {
83
+ const maskSensitiveValue = (value) => {
84
+ if (!value || value.length === 0) {
85
+ return "";
86
+ }
87
+ if (value.length < 6) {
88
+ return "********";
89
+ }
90
+ // Show first 3 and last 3 characters, mask the middle
91
+ return value.substring(0, 3) + "********" + value.substring(value.length - 3);
92
+ };
93
+ return {
94
+ logLevel: this.logLevel,
95
+ erpSystem: this.erpSystem,
96
+ nodeEnv: this.nodeEnv,
97
+ mmERPSvcApiBaseUrl: this.mmERPSvcApiBaseUrl,
98
+ mmApiBaseUrl: this.mmApiBaseUrl,
99
+ mmApiAuthToken: maskSensitiveValue(this.mmApiAuthToken),
100
+ mmApiRetryAttempts: this.mmApiRetryAttempts,
101
+ cacheTTL: this.cacheTTL,
102
+ erpApiPagingLimit: this.erpApiPagingLimit,
103
+ fromErpInterval: this.fromErpInterval,
104
+ toErpInterval: this.toErpInterval,
105
+ retryLaborTicketsInterval: this.retryLaborTicketsInterval,
106
+ cacheExpirationCheckInterval: this.cacheExpirationCheckInterval,
107
+ };
108
+ }
109
+ }
110
+ /**
111
+ * Helper function to get the SQL Server Configuration for collectors that use SQL Server to interact with the ERP
112
+ */
113
+ export const getSQLServerConfiguration = () => {
114
+ return {
115
+ username: process.env.ERP_SQLSERVER_USERNAME || "",
116
+ password: process.env.ERP_SQLSERVER_PASSWORD || "",
117
+ database: process.env.ERP_SQLSERVER_DATABASE || "",
118
+ host: process.env.ERP_SQLSERVER_HOST || process.env.ERP_SQLSERVER_SERVER || "",
119
+ port: process.env.ERP_SQLSERVER_PORT || "1433",
120
+ connectionTimeout: process.env.ERP_SQLSERVER_CONNECTION_TIMEOUT || "30000",
121
+ requestTimeout: process.env.ERP_SQLSERVER_REQUEST_TIMEOUT || "60000",
122
+ poolMax: process.env.ERP_SQLSERVER_MAX || "10",
123
+ poolMin: process.env.ERP_SQLSERVER_MIN || "0",
124
+ idleTimeoutMillis: process.env.ERP_SQLSERVER_IDLE_TIMEOUT_MMILLIS || "30000",
125
+ encrypt: process.env.ERP_SQLSERVER_ENCRYPT === "true",
126
+ trustServer: process.env.ERP_SQLSERVER_TRUST_SERVER === "true",
127
+ };
128
+ };
129
+ /**
130
+ * Parameters required to connect to an ERP system via its API.
131
+ * Contains all the necessary settings to establish a connection and authenticate with an ERP system's API.
132
+ */
133
+ export class ErpApiConnectionParams {
134
+ erpApiUrl;
135
+ erpApiClientId;
136
+ erpApiClientSecret;
137
+ erpApiOrganizationId;
138
+ erpAuthBaseUrl;
139
+ retryAttempts;
140
+ constructor(erpApiUrl, // Base url of ERP
141
+ erpApiClientId, // Client ID to authenticate with ERP
142
+ erpApiClientSecret, // Client Secret to authenticate with ERP
143
+ erpApiOrganizationId, // Organization / tenant Id
144
+ erpAuthBaseUrl, // Auth base url
145
+ retryAttempts = 3 // Number of retry attempts for API calls
146
+ ) {
147
+ this.erpApiUrl = erpApiUrl;
148
+ this.erpApiClientId = erpApiClientId;
149
+ this.erpApiClientSecret = erpApiClientSecret;
150
+ this.erpApiOrganizationId = erpApiOrganizationId;
151
+ this.erpAuthBaseUrl = erpAuthBaseUrl;
152
+ this.retryAttempts = retryAttempts;
153
+ }
154
+ }
155
+ /**
156
+ * Helper function to get the ERP API Connection Parameters
157
+ * Not all connectors use these, but keeping these commonly values in one place may
158
+ * make it easier to set and understand env var names set in App.
159
+ */
160
+ export const getErpApiConnectionParams = () => {
161
+ return new ErpApiConnectionParams(process.env.ERP_API_URL || "", process.env.ERP_API_CLIENT_ID || "", process.env.ERP_API_CLIENT_SECRET || "", process.env.ERP_API_ORGANIZATION_ID || "", process.env.ERP_AUTH_BASE_URL || "", parseInt(process.env.ERP_API_RETRY_ATTEMPTS || "3"));
162
+ };
163
+ //# sourceMappingURL=configuration-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"configuration-manager.js","sourceRoot":"","sources":["../../../src/services/data-sync-service/configuration-manager.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"data-sync-service.d.ts","sourceRoot":"","sources":["../../../src/services/data-sync-service/data-sync-service.ts"],"names":[],"mappings":"AAOA,eAAO,MAAM,kBAAkB,GAAU,eAAe,MAAM,kBAuG7D,CAAC"}
1
+ {"version":3,"file":"data-sync-service.d.ts","sourceRoot":"","sources":["../../../src/services/data-sync-service/data-sync-service.ts"],"names":[],"mappings":"AAaA,eAAO,MAAM,kBAAkB,GAAU,eAAe,MAAM,kBAuG7D,CAAC"}
@@ -0,0 +1,95 @@
1
+ import Bree from "bree";
2
+ import Graceful from "@ladjs/graceful";
3
+ import path from "path";
4
+ import { fileURLToPath } from "url";
5
+ import { CoreConfiguration } from "./configuration-manager.js";
6
+ import logger from "../reporting-service/logger.js";
7
+ const GracefulClass = Graceful;
8
+ export const runDataSyncService = async (connectorPath) => {
9
+ const config = CoreConfiguration.inst();
10
+ try {
11
+ // Find the SDK's node_modules directory and jobs path using ES module import
12
+ const currentFileUrl = import.meta.url;
13
+ const currentFilePath = fileURLToPath(currentFileUrl);
14
+ // Navigate from current file to the SDK root and then to jobs
15
+ // Current: /path/to/sdk/dist/mm-erp-sdk.js.js
16
+ // Target: /path/to/sdk/dist/services/data-sync-service/jobs
17
+ const sdkDistPath = path.dirname(currentFilePath);
18
+ const jobsPath = path.join(sdkDistPath, "services", "data-sync-service", "jobs");
19
+ const bree = new Bree({
20
+ root: jobsPath,
21
+ logger,
22
+ worker: {
23
+ env: {
24
+ CONNECTOR_PATH: connectorPath,
25
+ // Pass through all required environment variables
26
+ MM_MAPPING_SERVICE_URL: process.env.MM_MAPPING_SERVICE_URL,
27
+ MM_MAPPING_AUTH_SERVICE_URL: process.env.MM_MAPPING_AUTH_SERVICE_URL,
28
+ MM_MAPPING_SERVICE_TOKEN: process.env.MM_MAPPING_SERVICE_TOKEN,
29
+ ERP_SYSTEM: process.env.ERP_SYSTEM,
30
+ LOG_LEVEL: process.env.LOG_LEVEL,
31
+ NODE_ENV: process.env.NODE_ENV,
32
+ RETRY_ATTEMPTS: process.env.RETRY_ATTEMPTS,
33
+ CACHE_TTL: process.env.CACHE_TTL,
34
+ // Pass through all other environment variables that might be needed
35
+ ...process.env,
36
+ },
37
+ },
38
+ jobs: [
39
+ // {
40
+ // name: 'run-migrations', // Running this once on startup will create the tables in the sqlite database
41
+ // },
42
+ {
43
+ name: "from-erp",
44
+ timeout: "10s",
45
+ interval: config.fromErpInterval,
46
+ },
47
+ {
48
+ name: "to-erp",
49
+ //timeout: '3s', // Use timeout during development to see the job in action quickly
50
+ interval: config.toErpInterval,
51
+ },
52
+ {
53
+ name: "retry-failed-labor-tickets",
54
+ interval: config.retryLaborTicketsInterval,
55
+ },
56
+ {
57
+ name: "clean-up-expired-cache",
58
+ interval: config.cacheExpirationCheckInterval,
59
+ },
60
+ ],
61
+ });
62
+ logger.info("\n================================INITIATING DATA SYNC CYCLES (Bree)================================\n");
63
+ const jobsConfig = bree.config.jobs.map((job) => ({
64
+ name: job.name,
65
+ interval: job.interval,
66
+ timeout: job.timeout,
67
+ }));
68
+ logger.info("JOBS CONFIGURATION:", { jobs: jobsConfig });
69
+ const graceful = new GracefulClass({ brees: [bree] });
70
+ graceful.listen();
71
+ (async () => {
72
+ await bree.start();
73
+ })();
74
+ bree.on("jobStarted", (job) => {
75
+ console.log("Job " + job.name + " started");
76
+ });
77
+ bree.on("jobCompleted", (job) => {
78
+ if (job.error) {
79
+ console.error("Job " + job.name + " failed:", job.error);
80
+ }
81
+ else {
82
+ console.log("Job " + job.name + " completed successfully!");
83
+ }
84
+ });
85
+ bree.on("error", (error) => {
86
+ console.error("Bree error:", error);
87
+ });
88
+ // Exit and let the jobs take over
89
+ logger.info("\n================================DATA SYNC CYCLES INITIATION COMPLETED================================\n");
90
+ }
91
+ catch (error) {
92
+ logger.error("startUp: Error initiating data sync cycles:", error);
93
+ }
94
+ };
95
+ //# sourceMappingURL=data-sync-service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-sync-service.js","sourceRoot":"","sources":["../../../src/services/data-sync-service/data-sync-service.ts"],"names":[],"mappings":"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"}
@@ -1,10 +1,10 @@
1
1
  /**
2
2
  * Core data sync service functionality
3
3
  */
4
- export { runDataSyncService } from "./data-sync-service";
4
+ export { runDataSyncService } from "./data-sync-service.js";
5
5
  /**
6
6
  * Configuration management for data sync
7
7
  */
8
- export { getSQLServerConfiguration } from "./configuration-manager";
9
- export { ErpApiConnectionParams, getErpApiConnectionParams } from "./configuration-manager";
8
+ export { getSQLServerConfiguration } from "./configuration-manager.js";
9
+ export { ErpApiConnectionParams, getErpApiConnectionParams } from "./configuration-manager.js";
10
10
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/data-sync-service/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAEzD;;GAEG;AACH,OAAO,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC;AAEpE,OAAO,EAAE,sBAAsB,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/data-sync-service/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAE5D;;GAEG;AACH,OAAO,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC;AAEvE,OAAO,EAAE,sBAAsB,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC"}
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Core data sync service functionality
3
+ */
4
+ export { runDataSyncService } from "./data-sync-service.js";
5
+ /**
6
+ * Configuration management for data sync
7
+ */
8
+ export { getSQLServerConfiguration } from "./configuration-manager.js";
9
+ export { ErpApiConnectionParams, getErpApiConnectionParams } from "./configuration-manager.js";
10
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/data-sync-service/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAE5D;;GAEG;AACH,OAAO,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC;AAEvE,OAAO,EAAE,sBAAsB,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC"}