@machinemetrics/mm-erp-sdk 0.1.4-beta.6 → 0.1.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 (30) hide show
  1. package/README.md +1 -1
  2. package/dist/{connector-factory-13bvmpQB.js → connector-factory-DHmMYsRs.js} +7 -7
  3. package/dist/connector-factory-DHmMYsRs.js.map +1 -0
  4. package/dist/mm-erp-sdk.js +5 -3
  5. package/dist/mm-erp-sdk.js.map +1 -1
  6. package/dist/services/data-sync-service/jobs/clean-up-expired-cache.d.ts.map +1 -1
  7. package/dist/services/data-sync-service/jobs/clean-up-expired-cache.js +5 -3
  8. package/dist/services/data-sync-service/jobs/clean-up-expired-cache.js.map +1 -1
  9. package/dist/services/data-sync-service/jobs/from-erp.d.ts.map +1 -1
  10. package/dist/services/data-sync-service/jobs/from-erp.js +6 -7
  11. package/dist/services/data-sync-service/jobs/from-erp.js.map +1 -1
  12. package/dist/services/data-sync-service/jobs/retry-failed-labor-tickets.js +2 -2
  13. package/dist/services/data-sync-service/jobs/retry-failed-labor-tickets.js.map +1 -1
  14. package/dist/services/data-sync-service/jobs/run-migrations.js +2 -2
  15. package/dist/services/data-sync-service/jobs/run-migrations.js.map +1 -1
  16. package/dist/services/data-sync-service/jobs/to-erp.d.ts.map +1 -1
  17. package/dist/services/data-sync-service/jobs/to-erp.js +6 -7
  18. package/dist/services/data-sync-service/jobs/to-erp.js.map +1 -1
  19. package/dist/utils/connector-factory.d.ts.map +1 -1
  20. package/dist/utils/connector-log/log-deduper.d.ts.map +1 -1
  21. package/package.json +1 -1
  22. package/src/services/data-sync-service/jobs/clean-up-expired-cache.ts +5 -3
  23. package/src/services/data-sync-service/jobs/from-erp.ts +6 -9
  24. package/src/services/data-sync-service/jobs/retry-failed-labor-tickets.ts +1 -1
  25. package/src/services/data-sync-service/jobs/run-migrations.ts +2 -2
  26. package/src/services/data-sync-service/jobs/to-erp.ts +5 -8
  27. package/src/utils/application-initializer.ts +1 -1
  28. package/src/utils/connector-factory.ts +9 -13
  29. package/src/utils/connector-log/log-deduper.ts +3 -1
  30. package/dist/connector-factory-13bvmpQB.js.map +0 -1
package/README.md CHANGED
@@ -46,7 +46,7 @@ export default class MyERPConnector
46
46
  await runDataSyncService();
47
47
  } catch (error) {
48
48
  console.error("Startup failed:", error);
49
- process.exit(1);
49
+ process.exitCode = 1;
50
50
  }
51
51
  }
52
52
 
@@ -2,14 +2,14 @@ import { l as logger } from "./logger-hqtl8hFM.js";
2
2
  import { pathToFileURL } from "url";
3
3
  const createConnectorFromPath = async (connectorPath) => {
4
4
  try {
5
- logger.debug(`createConnectorFromPath: Received connector path: ${connectorPath}`);
6
- logger.debug(`createConnectorFromPath: Path type: ${typeof connectorPath}`);
7
- logger.debug(`createConnectorFromPath: Path length: ${connectorPath.length}`);
8
5
  const pathParts = connectorPath.split("/");
9
- logger.debug(`createConnectorFromPath: Path parts: ${JSON.stringify(pathParts)}`);
10
6
  const filename = pathParts[pathParts.length - 1];
11
- logger.debug(`createConnectorFromPath: Filename: ${filename}`);
12
- logger.debug(`createConnectorFromPath: Attempting to import: ${pathToFileURL(connectorPath).href}`);
7
+ logger.debug("createConnectorFromPath:", {
8
+ connectorPath,
9
+ pathParts,
10
+ filename,
11
+ finalImport: pathToFileURL(connectorPath).href
12
+ });
13
13
  const connectorModule = await import(pathToFileURL(connectorPath).href);
14
14
  const ConnectorClass = connectorModule.default || connectorModule[Object.keys(connectorModule)[0]];
15
15
  if (!ConnectorClass) {
@@ -27,4 +27,4 @@ const createConnectorFromPath = async (connectorPath) => {
27
27
  export {
28
28
  createConnectorFromPath as c
29
29
  };
30
- //# sourceMappingURL=connector-factory-13bvmpQB.js.map
30
+ //# sourceMappingURL=connector-factory-DHmMYsRs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connector-factory-DHmMYsRs.js","sources":["../src/utils/connector-factory.ts"],"sourcesContent":["import { IERPConnector } from \"../types/erp-connector\";\nimport logger from \"../services/reporting-service/logger\";\nimport { pathToFileURL } from \"url\";\n\n/**\n * Helper function to dynamically import and create connector instance from a file path\n * @param connectorPath - The file path to the connector module\n * @returns A new instance of the IERPConnector\n */\nexport const createConnectorFromPath = async (\n connectorPath: string\n): Promise<IERPConnector> => {\n try {\n // Some detailed debug logging to help with troubleshooting multi-platform connector paths\n const pathParts = connectorPath.split('/');\n const filename = pathParts[pathParts.length - 1];\n\n logger.debug(\"createConnectorFromPath:\", {\n connectorPath,\n pathParts,\n filename,\n finalImport: pathToFileURL(connectorPath).href,\n });\n\n const connectorModule = await import(pathToFileURL(connectorPath).href);\n\n // Get the default export or named export\n const ConnectorClass =\n connectorModule.default ||\n connectorModule[Object.keys(connectorModule)[0]];\n\n if (!ConnectorClass) {\n throw new Error(`No connector class found in module: ${connectorPath}`);\n }\n\n // Create new instance of the connector\n return new ConnectorClass();\n } catch (error) {\n logger.error(\n `Failed to create connector instance from path: ${connectorPath}`,\n { error }\n );\n throw error;\n }\n};"],"names":[],"mappings":";;AASO,MAAM,0BAA0B,OACrC,kBAC2B;AAC3B,MAAI;AAEF,UAAM,YAAY,cAAc,MAAM,GAAG;AACzC,UAAM,WAAW,UAAU,UAAU,SAAS,CAAC;AAE/C,WAAO,MAAM,4BAA4B;AAAA,MACvC;AAAA,MACA;AAAA,MACA;AAAA,MACA,aAAa,cAAc,aAAa,EAAE;AAAA,IAAA,CAC3C;AAED,UAAM,kBAAkB,MAAM,OAAO,cAAc,aAAa,EAAE;AAGlE,UAAM,iBACJ,gBAAgB,WAChB,gBAAgB,OAAO,KAAK,eAAe,EAAE,CAAC,CAAC;AAEjD,QAAI,CAAC,gBAAgB;AACnB,YAAM,IAAI,MAAM,uCAAuC,aAAa,EAAE;AAAA,IACxE;AAGA,WAAO,IAAI,eAAA;AAAA,EACb,SAAS,OAAO;AACd,WAAO;AAAA,MACL,kDAAkD,aAAa;AAAA,MAC/D,EAAE,MAAA;AAAA,IAAM;AAEV,UAAM;AAAA,EACR;AACF;"}
@@ -8,7 +8,7 @@ import knex from "knex";
8
8
  import { c as config } from "./knexfile-1qKKIORB.js";
9
9
  import fs from "fs";
10
10
  import path from "path";
11
- import "./connector-factory-13bvmpQB.js";
11
+ import "./connector-factory-DHmMYsRs.js";
12
12
  import Bree from "bree";
13
13
  import Graceful from "@ladjs/graceful";
14
14
  import { fileURLToPath } from "url";
@@ -3263,6 +3263,7 @@ class FileLogDeduper {
3263
3263
  store[key] = {
3264
3264
  ...existing,
3265
3265
  suppressedCount: existing.suppressedCount + 1,
3266
+ firstUnsentEventTs: existing.suppressedCount === 0 ? entry.eventTime ?? now : existing.firstUnsentEventTs,
3266
3267
  lastEventTs: entry.eventTime ?? now,
3267
3268
  level: entry.level,
3268
3269
  message: entry.message
@@ -3270,10 +3271,11 @@ class FileLogDeduper {
3270
3271
  this.writeStore(store);
3271
3272
  return null;
3272
3273
  }
3273
- const messageToSend2 = this.formatMessage(entry.message, entry.eventTime ?? now, existing.suppressedCount);
3274
+ const messageToSend2 = this.formatMessage(entry.message, entry.eventTime ?? now, existing.suppressedCount, existing.firstUnsentEventTs);
3274
3275
  store[key] = {
3275
3276
  ...existing,
3276
3277
  suppressedCount: 0,
3278
+ firstUnsentEventTs: 0,
3277
3279
  lastEventTs: entry.eventTime ?? now,
3278
3280
  level: entry.level,
3279
3281
  message: entry.message
@@ -3443,7 +3445,7 @@ class ApplicationInitializer {
3443
3445
  );
3444
3446
  } catch (error) {
3445
3447
  logger.error("Critical initialization failure. Exiting.", error);
3446
- process.exit(1);
3448
+ process.exitCode = 1;
3447
3449
  }
3448
3450
  }
3449
3451
  /**