@adaptic/backend-legacy 0.0.960 → 0.0.961

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 (258) hide show
  1. package/ABTest.cjs +180 -66
  2. package/Account.cjs +180 -66
  3. package/AccountDecisionRecord.cjs +180 -66
  4. package/AccountLinkingRequest.cjs +180 -66
  5. package/Action.cjs +180 -66
  6. package/Alert.cjs +180 -66
  7. package/Allocation.cjs +180 -66
  8. package/AlpacaAccount.cjs +180 -66
  9. package/AnalyticsConfiguration.cjs +180 -66
  10. package/AnalyticsSnapshot.cjs +180 -66
  11. package/Asset.cjs +180 -66
  12. package/AuditLog.cjs +180 -66
  13. package/Authenticator.cjs +180 -66
  14. package/Configuration.cjs +180 -66
  15. package/ConflictEvent.cjs +180 -66
  16. package/ConnectionHealthSnapshot.cjs +180 -66
  17. package/Customer.cjs +180 -66
  18. package/DeadLetterMessage.cjs +180 -66
  19. package/DecisionMemorySummary.cjs +180 -66
  20. package/EconomicEvent.cjs +180 -66
  21. package/EquityBar.cjs +180 -66
  22. package/Event.cjs +180 -66
  23. package/EventSnapshot.cjs +180 -66
  24. package/FeatureImportanceAnalysis.cjs +180 -66
  25. package/InstitutionalFlowSignal.cjs +180 -66
  26. package/InstitutionalHolding.cjs +180 -66
  27. package/InstitutionalSentimentAlerts.cjs +180 -66
  28. package/InstitutionalSentimentErrors.cjs +180 -66
  29. package/InstitutionalSentimentHistory.cjs +180 -66
  30. package/InstitutionalSentimentMetrics.cjs +180 -66
  31. package/InviteToken.cjs +180 -66
  32. package/LinkedProvider.cjs +180 -66
  33. package/LlmConfiguration.cjs +180 -66
  34. package/MLModelVersion.cjs +180 -66
  35. package/MLTrainingData.cjs +180 -66
  36. package/MarketSentiment.cjs +180 -66
  37. package/ModelArtifact.cjs +180 -66
  38. package/ModelVersion.cjs +180 -66
  39. package/ModelVersionArtifact.cjs +180 -66
  40. package/NewsArticle.cjs +180 -66
  41. package/NewsArticleAssetSentiment.cjs +180 -66
  42. package/OptionsContract.cjs +180 -66
  43. package/OptionsGreeksHistory.cjs +180 -66
  44. package/OptionsPosition.cjs +180 -66
  45. package/OptionsPositionEvent.cjs +180 -66
  46. package/OptionsTradeExecution.cjs +180 -66
  47. package/PolicyOverlay.cjs +180 -66
  48. package/PortfolioGreeksHistory.cjs +180 -66
  49. package/ScheduledOptionOrder.cjs +180 -66
  50. package/Session.cjs +180 -66
  51. package/SignalGeneratorMetrics.cjs +180 -66
  52. package/SignalLineage.cjs +180 -66
  53. package/SignalOutcome.cjs +180 -66
  54. package/SignalPriorityQueue.cjs +180 -66
  55. package/SyncEvent.cjs +180 -66
  56. package/SystemAlert.cjs +180 -66
  57. package/Trade.cjs +180 -66
  58. package/TradeAuditEvent.cjs +180 -66
  59. package/TradeExecutionHistory.cjs +180 -66
  60. package/TradeOutcome.cjs +180 -66
  61. package/TradingPolicy.cjs +180 -66
  62. package/User.cjs +180 -66
  63. package/VerificationToken.cjs +180 -66
  64. package/WaitlistEntry.cjs +180 -66
  65. package/esm/ABTest.d.ts.map +1 -1
  66. package/esm/ABTest.js.map +1 -1
  67. package/esm/ABTest.mjs +180 -66
  68. package/esm/Account.d.ts.map +1 -1
  69. package/esm/Account.js.map +1 -1
  70. package/esm/Account.mjs +180 -66
  71. package/esm/AccountDecisionRecord.d.ts.map +1 -1
  72. package/esm/AccountDecisionRecord.js.map +1 -1
  73. package/esm/AccountDecisionRecord.mjs +180 -66
  74. package/esm/AccountLinkingRequest.d.ts.map +1 -1
  75. package/esm/AccountLinkingRequest.js.map +1 -1
  76. package/esm/AccountLinkingRequest.mjs +180 -66
  77. package/esm/Action.d.ts.map +1 -1
  78. package/esm/Action.js.map +1 -1
  79. package/esm/Action.mjs +180 -66
  80. package/esm/Alert.d.ts.map +1 -1
  81. package/esm/Alert.js.map +1 -1
  82. package/esm/Alert.mjs +180 -66
  83. package/esm/Allocation.d.ts.map +1 -1
  84. package/esm/Allocation.js.map +1 -1
  85. package/esm/Allocation.mjs +180 -66
  86. package/esm/AlpacaAccount.d.ts.map +1 -1
  87. package/esm/AlpacaAccount.js.map +1 -1
  88. package/esm/AlpacaAccount.mjs +180 -66
  89. package/esm/AnalyticsConfiguration.d.ts.map +1 -1
  90. package/esm/AnalyticsConfiguration.js.map +1 -1
  91. package/esm/AnalyticsConfiguration.mjs +180 -66
  92. package/esm/AnalyticsSnapshot.d.ts.map +1 -1
  93. package/esm/AnalyticsSnapshot.js.map +1 -1
  94. package/esm/AnalyticsSnapshot.mjs +180 -66
  95. package/esm/Asset.d.ts.map +1 -1
  96. package/esm/Asset.js.map +1 -1
  97. package/esm/Asset.mjs +180 -66
  98. package/esm/AuditLog.d.ts.map +1 -1
  99. package/esm/AuditLog.js.map +1 -1
  100. package/esm/AuditLog.mjs +180 -66
  101. package/esm/Authenticator.d.ts.map +1 -1
  102. package/esm/Authenticator.js.map +1 -1
  103. package/esm/Authenticator.mjs +180 -66
  104. package/esm/Configuration.d.ts.map +1 -1
  105. package/esm/Configuration.js.map +1 -1
  106. package/esm/Configuration.mjs +180 -66
  107. package/esm/ConflictEvent.d.ts.map +1 -1
  108. package/esm/ConflictEvent.js.map +1 -1
  109. package/esm/ConflictEvent.mjs +180 -66
  110. package/esm/ConnectionHealthSnapshot.d.ts.map +1 -1
  111. package/esm/ConnectionHealthSnapshot.js.map +1 -1
  112. package/esm/ConnectionHealthSnapshot.mjs +180 -66
  113. package/esm/Customer.d.ts.map +1 -1
  114. package/esm/Customer.js.map +1 -1
  115. package/esm/Customer.mjs +180 -66
  116. package/esm/DeadLetterMessage.d.ts.map +1 -1
  117. package/esm/DeadLetterMessage.js.map +1 -1
  118. package/esm/DeadLetterMessage.mjs +180 -66
  119. package/esm/DecisionMemorySummary.d.ts.map +1 -1
  120. package/esm/DecisionMemorySummary.js.map +1 -1
  121. package/esm/DecisionMemorySummary.mjs +180 -66
  122. package/esm/EconomicEvent.d.ts.map +1 -1
  123. package/esm/EconomicEvent.js.map +1 -1
  124. package/esm/EconomicEvent.mjs +180 -66
  125. package/esm/EquityBar.d.ts.map +1 -1
  126. package/esm/EquityBar.js.map +1 -1
  127. package/esm/EquityBar.mjs +180 -66
  128. package/esm/Event.d.ts.map +1 -1
  129. package/esm/Event.js.map +1 -1
  130. package/esm/Event.mjs +180 -66
  131. package/esm/EventSnapshot.d.ts.map +1 -1
  132. package/esm/EventSnapshot.js.map +1 -1
  133. package/esm/EventSnapshot.mjs +180 -66
  134. package/esm/FeatureImportanceAnalysis.d.ts.map +1 -1
  135. package/esm/FeatureImportanceAnalysis.js.map +1 -1
  136. package/esm/FeatureImportanceAnalysis.mjs +180 -66
  137. package/esm/InstitutionalFlowSignal.d.ts.map +1 -1
  138. package/esm/InstitutionalFlowSignal.js.map +1 -1
  139. package/esm/InstitutionalFlowSignal.mjs +180 -66
  140. package/esm/InstitutionalHolding.d.ts.map +1 -1
  141. package/esm/InstitutionalHolding.js.map +1 -1
  142. package/esm/InstitutionalHolding.mjs +180 -66
  143. package/esm/InstitutionalSentimentAlerts.d.ts.map +1 -1
  144. package/esm/InstitutionalSentimentAlerts.js.map +1 -1
  145. package/esm/InstitutionalSentimentAlerts.mjs +180 -66
  146. package/esm/InstitutionalSentimentErrors.d.ts.map +1 -1
  147. package/esm/InstitutionalSentimentErrors.js.map +1 -1
  148. package/esm/InstitutionalSentimentErrors.mjs +180 -66
  149. package/esm/InstitutionalSentimentHistory.d.ts.map +1 -1
  150. package/esm/InstitutionalSentimentHistory.js.map +1 -1
  151. package/esm/InstitutionalSentimentHistory.mjs +180 -66
  152. package/esm/InstitutionalSentimentMetrics.d.ts.map +1 -1
  153. package/esm/InstitutionalSentimentMetrics.js.map +1 -1
  154. package/esm/InstitutionalSentimentMetrics.mjs +180 -66
  155. package/esm/InviteToken.d.ts.map +1 -1
  156. package/esm/InviteToken.js.map +1 -1
  157. package/esm/InviteToken.mjs +180 -66
  158. package/esm/LinkedProvider.d.ts.map +1 -1
  159. package/esm/LinkedProvider.js.map +1 -1
  160. package/esm/LinkedProvider.mjs +180 -66
  161. package/esm/LlmConfiguration.d.ts.map +1 -1
  162. package/esm/LlmConfiguration.js.map +1 -1
  163. package/esm/LlmConfiguration.mjs +180 -66
  164. package/esm/MLModelVersion.d.ts.map +1 -1
  165. package/esm/MLModelVersion.js.map +1 -1
  166. package/esm/MLModelVersion.mjs +180 -66
  167. package/esm/MLTrainingData.d.ts.map +1 -1
  168. package/esm/MLTrainingData.js.map +1 -1
  169. package/esm/MLTrainingData.mjs +180 -66
  170. package/esm/MarketSentiment.d.ts.map +1 -1
  171. package/esm/MarketSentiment.js.map +1 -1
  172. package/esm/MarketSentiment.mjs +180 -66
  173. package/esm/ModelArtifact.d.ts.map +1 -1
  174. package/esm/ModelArtifact.js.map +1 -1
  175. package/esm/ModelArtifact.mjs +180 -66
  176. package/esm/ModelVersion.d.ts.map +1 -1
  177. package/esm/ModelVersion.js.map +1 -1
  178. package/esm/ModelVersion.mjs +180 -66
  179. package/esm/ModelVersionArtifact.d.ts.map +1 -1
  180. package/esm/ModelVersionArtifact.js.map +1 -1
  181. package/esm/ModelVersionArtifact.mjs +180 -66
  182. package/esm/NewsArticle.d.ts.map +1 -1
  183. package/esm/NewsArticle.js.map +1 -1
  184. package/esm/NewsArticle.mjs +180 -66
  185. package/esm/NewsArticleAssetSentiment.d.ts.map +1 -1
  186. package/esm/NewsArticleAssetSentiment.js.map +1 -1
  187. package/esm/NewsArticleAssetSentiment.mjs +180 -66
  188. package/esm/OptionsContract.d.ts.map +1 -1
  189. package/esm/OptionsContract.js.map +1 -1
  190. package/esm/OptionsContract.mjs +180 -66
  191. package/esm/OptionsGreeksHistory.d.ts.map +1 -1
  192. package/esm/OptionsGreeksHistory.js.map +1 -1
  193. package/esm/OptionsGreeksHistory.mjs +180 -66
  194. package/esm/OptionsPosition.d.ts.map +1 -1
  195. package/esm/OptionsPosition.js.map +1 -1
  196. package/esm/OptionsPosition.mjs +180 -66
  197. package/esm/OptionsPositionEvent.d.ts.map +1 -1
  198. package/esm/OptionsPositionEvent.js.map +1 -1
  199. package/esm/OptionsPositionEvent.mjs +180 -66
  200. package/esm/OptionsTradeExecution.d.ts.map +1 -1
  201. package/esm/OptionsTradeExecution.js.map +1 -1
  202. package/esm/OptionsTradeExecution.mjs +180 -66
  203. package/esm/PolicyOverlay.d.ts.map +1 -1
  204. package/esm/PolicyOverlay.js.map +1 -1
  205. package/esm/PolicyOverlay.mjs +180 -66
  206. package/esm/PortfolioGreeksHistory.d.ts.map +1 -1
  207. package/esm/PortfolioGreeksHistory.js.map +1 -1
  208. package/esm/PortfolioGreeksHistory.mjs +180 -66
  209. package/esm/ScheduledOptionOrder.d.ts.map +1 -1
  210. package/esm/ScheduledOptionOrder.js.map +1 -1
  211. package/esm/ScheduledOptionOrder.mjs +180 -66
  212. package/esm/Session.d.ts.map +1 -1
  213. package/esm/Session.js.map +1 -1
  214. package/esm/Session.mjs +180 -66
  215. package/esm/SignalGeneratorMetrics.d.ts.map +1 -1
  216. package/esm/SignalGeneratorMetrics.js.map +1 -1
  217. package/esm/SignalGeneratorMetrics.mjs +180 -66
  218. package/esm/SignalLineage.d.ts.map +1 -1
  219. package/esm/SignalLineage.js.map +1 -1
  220. package/esm/SignalLineage.mjs +180 -66
  221. package/esm/SignalOutcome.d.ts.map +1 -1
  222. package/esm/SignalOutcome.js.map +1 -1
  223. package/esm/SignalOutcome.mjs +180 -66
  224. package/esm/SignalPriorityQueue.d.ts.map +1 -1
  225. package/esm/SignalPriorityQueue.js.map +1 -1
  226. package/esm/SignalPriorityQueue.mjs +180 -66
  227. package/esm/SyncEvent.d.ts.map +1 -1
  228. package/esm/SyncEvent.js.map +1 -1
  229. package/esm/SyncEvent.mjs +180 -66
  230. package/esm/SystemAlert.d.ts.map +1 -1
  231. package/esm/SystemAlert.js.map +1 -1
  232. package/esm/SystemAlert.mjs +180 -66
  233. package/esm/Trade.d.ts.map +1 -1
  234. package/esm/Trade.js.map +1 -1
  235. package/esm/Trade.mjs +180 -66
  236. package/esm/TradeAuditEvent.d.ts.map +1 -1
  237. package/esm/TradeAuditEvent.js.map +1 -1
  238. package/esm/TradeAuditEvent.mjs +180 -66
  239. package/esm/TradeExecutionHistory.d.ts.map +1 -1
  240. package/esm/TradeExecutionHistory.js.map +1 -1
  241. package/esm/TradeExecutionHistory.mjs +180 -66
  242. package/esm/TradeOutcome.d.ts.map +1 -1
  243. package/esm/TradeOutcome.js.map +1 -1
  244. package/esm/TradeOutcome.mjs +180 -66
  245. package/esm/TradingPolicy.d.ts.map +1 -1
  246. package/esm/TradingPolicy.js.map +1 -1
  247. package/esm/TradingPolicy.mjs +180 -66
  248. package/esm/User.d.ts.map +1 -1
  249. package/esm/User.js.map +1 -1
  250. package/esm/User.mjs +180 -66
  251. package/esm/VerificationToken.d.ts.map +1 -1
  252. package/esm/VerificationToken.js.map +1 -1
  253. package/esm/VerificationToken.mjs +180 -66
  254. package/esm/WaitlistEntry.d.ts.map +1 -1
  255. package/esm/WaitlistEntry.js.map +1 -1
  256. package/esm/WaitlistEntry.mjs +180 -66
  257. package/esm/index.d.ts.map +1 -1
  258. package/package.json +1 -1
package/SyncEvent.cjs CHANGED
@@ -148,13 +148,28 @@ exports.SyncEvent = {
148
148
  await new Promise(resolve => setTimeout(resolve, delay));
149
149
  continue;
150
150
  }
151
- // Log structured error details and rethrow
152
- logger_1.logger.error("Database create operation failed", {
153
- operation: 'createOneSyncEvent',
154
- model: 'SyncEvent',
155
- error: String(error),
156
- isRetryable: isConnectionError,
157
- });
151
+ // Log structured error details and rethrow.
152
+ // Demote transient failures to WARN with explicit transient+recoveryHint
153
+ // metadata so log analytics can distinguish recoverable upstream retries
154
+ // from true defects.
155
+ if (isConnectionError) {
156
+ logger_1.logger.warn("Database create operation failed (transient after retries)", {
157
+ operation: 'createOneSyncEvent',
158
+ model: 'SyncEvent',
159
+ error: String(error),
160
+ isRetryable: true,
161
+ transient: true,
162
+ recoveryHint: "Upstream caller should retry on next cycle",
163
+ });
164
+ }
165
+ else {
166
+ logger_1.logger.error("Database create operation failed", {
167
+ operation: 'createOneSyncEvent',
168
+ model: 'SyncEvent',
169
+ error: String(error),
170
+ isRetryable: false,
171
+ });
172
+ }
158
173
  throw error;
159
174
  }
160
175
  }
@@ -281,13 +296,25 @@ exports.SyncEvent = {
281
296
  await new Promise(resolve => setTimeout(resolve, delay));
282
297
  continue;
283
298
  }
284
- // Log structured error details and rethrow
285
- logger_1.logger.error("Database createMany operation failed", {
286
- operation: 'createManySyncEvent',
287
- model: 'SyncEvent',
288
- error: String(error),
289
- isRetryable: isConnectionError,
290
- });
299
+ // Log structured error details and rethrow (transient -> WARN).
300
+ if (isConnectionError) {
301
+ logger_1.logger.warn("Database createMany operation failed (transient after retries)", {
302
+ operation: 'createManySyncEvent',
303
+ model: 'SyncEvent',
304
+ error: String(error),
305
+ isRetryable: true,
306
+ transient: true,
307
+ recoveryHint: "Upstream caller should retry on next cycle",
308
+ });
309
+ }
310
+ else {
311
+ logger_1.logger.error("Database createMany operation failed", {
312
+ operation: 'createManySyncEvent',
313
+ model: 'SyncEvent',
314
+ error: String(error),
315
+ isRetryable: false,
316
+ });
317
+ }
291
318
  throw error;
292
319
  }
293
320
  }
@@ -437,14 +464,27 @@ exports.SyncEvent = {
437
464
  await new Promise(resolve => setTimeout(resolve, delay));
438
465
  continue;
439
466
  }
440
- // Log structured error details and rethrow
441
- logger_1.logger.error("Database update operation failed", {
442
- operation: 'updateOneSyncEvent',
443
- model: 'SyncEvent',
444
- error: String(error),
445
- recordId: props.id,
446
- isRetryable: isConnectionError,
447
- });
467
+ // Log structured error details and rethrow (transient -> WARN).
468
+ if (isConnectionError) {
469
+ logger_1.logger.warn("Database update operation failed (transient after retries)", {
470
+ operation: 'updateOneSyncEvent',
471
+ model: 'SyncEvent',
472
+ error: String(error),
473
+ recordId: props.id,
474
+ isRetryable: true,
475
+ transient: true,
476
+ recoveryHint: "Upstream caller should retry on next cycle",
477
+ });
478
+ }
479
+ else {
480
+ logger_1.logger.error("Database update operation failed", {
481
+ operation: 'updateOneSyncEvent',
482
+ model: 'SyncEvent',
483
+ error: String(error),
484
+ recordId: props.id,
485
+ isRetryable: false,
486
+ });
487
+ }
448
488
  throw error;
449
489
  }
450
490
  }
@@ -608,14 +648,27 @@ exports.SyncEvent = {
608
648
  await new Promise(resolve => setTimeout(resolve, delay));
609
649
  continue;
610
650
  }
611
- // Log structured error details and rethrow
612
- logger_1.logger.error("Database upsert operation failed", {
613
- operation: 'upsertOneSyncEvent',
614
- model: 'SyncEvent',
615
- error: String(error),
616
- recordId: props.id,
617
- isRetryable: isConnectionError,
618
- });
651
+ // Log structured error details and rethrow (transient -> WARN).
652
+ if (isConnectionError) {
653
+ logger_1.logger.warn("Database upsert operation failed (transient after retries)", {
654
+ operation: 'upsertOneSyncEvent',
655
+ model: 'SyncEvent',
656
+ error: String(error),
657
+ recordId: props.id,
658
+ isRetryable: true,
659
+ transient: true,
660
+ recoveryHint: "Upstream caller should retry on next cycle",
661
+ });
662
+ }
663
+ else {
664
+ logger_1.logger.error("Database upsert operation failed", {
665
+ operation: 'upsertOneSyncEvent',
666
+ model: 'SyncEvent',
667
+ error: String(error),
668
+ recordId: props.id,
669
+ isRetryable: false,
670
+ });
671
+ }
619
672
  throw error;
620
673
  }
621
674
  }
@@ -763,13 +816,25 @@ exports.SyncEvent = {
763
816
  await new Promise(resolve => setTimeout(resolve, delay));
764
817
  continue;
765
818
  }
766
- // Log structured error details and rethrow
767
- logger_1.logger.error("Database updateMany operation failed", {
768
- operation: 'updateManySyncEvent',
769
- model: 'SyncEvent',
770
- error: String(error),
771
- isRetryable: isConnectionError,
772
- });
819
+ // Log structured error details and rethrow (transient -> WARN).
820
+ if (isConnectionError) {
821
+ logger_1.logger.warn("Database updateMany operation failed (transient after retries)", {
822
+ operation: 'updateManySyncEvent',
823
+ model: 'SyncEvent',
824
+ error: String(error),
825
+ isRetryable: true,
826
+ transient: true,
827
+ recoveryHint: "Upstream caller should retry on next cycle",
828
+ });
829
+ }
830
+ else {
831
+ logger_1.logger.error("Database updateMany operation failed", {
832
+ operation: 'updateManySyncEvent',
833
+ model: 'SyncEvent',
834
+ error: String(error),
835
+ isRetryable: false,
836
+ });
837
+ }
773
838
  throw error;
774
839
  }
775
840
  }
@@ -892,14 +957,27 @@ exports.SyncEvent = {
892
957
  await new Promise(resolve => setTimeout(resolve, delay));
893
958
  continue;
894
959
  }
895
- // Log structured error details and rethrow
896
- logger_1.logger.error("Database delete operation failed", {
897
- operation: 'deleteOneSyncEvent',
898
- model: 'SyncEvent',
899
- error: String(error),
900
- recordId: props.id,
901
- isRetryable: isConnectionError,
902
- });
960
+ // Log structured error details and rethrow (transient -> WARN).
961
+ if (isConnectionError) {
962
+ logger_1.logger.warn("Database delete operation failed (transient after retries)", {
963
+ operation: 'deleteOneSyncEvent',
964
+ model: 'SyncEvent',
965
+ error: String(error),
966
+ recordId: props.id,
967
+ isRetryable: true,
968
+ transient: true,
969
+ recoveryHint: "Upstream caller should retry on next cycle",
970
+ });
971
+ }
972
+ else {
973
+ logger_1.logger.error("Database delete operation failed", {
974
+ operation: 'deleteOneSyncEvent',
975
+ model: 'SyncEvent',
976
+ error: String(error),
977
+ recordId: props.id,
978
+ isRetryable: false,
979
+ });
980
+ }
903
981
  throw error;
904
982
  }
905
983
  }
@@ -1001,13 +1079,25 @@ exports.SyncEvent = {
1001
1079
  await new Promise(resolve => setTimeout(resolve, delay));
1002
1080
  continue;
1003
1081
  }
1004
- // Log structured error details and rethrow
1005
- logger_1.logger.error("Database get operation failed", {
1006
- operation: 'getSyncEvent',
1007
- model: 'SyncEvent',
1008
- error: String(error),
1009
- isRetryable: isConnectionError,
1010
- });
1082
+ // Log structured error details and rethrow (transient -> WARN).
1083
+ if (isConnectionError) {
1084
+ logger_1.logger.warn("Database get operation failed (transient after retries)", {
1085
+ operation: 'getSyncEvent',
1086
+ model: 'SyncEvent',
1087
+ error: String(error),
1088
+ isRetryable: true,
1089
+ transient: true,
1090
+ recoveryHint: "Upstream caller should retry on next cycle",
1091
+ });
1092
+ }
1093
+ else {
1094
+ logger_1.logger.error("Database get operation failed", {
1095
+ operation: 'getSyncEvent',
1096
+ model: 'SyncEvent',
1097
+ error: String(error),
1098
+ isRetryable: false,
1099
+ });
1100
+ }
1011
1101
  throw error;
1012
1102
  }
1013
1103
  }
@@ -1094,13 +1184,25 @@ exports.SyncEvent = {
1094
1184
  await new Promise(resolve => setTimeout(resolve, delay));
1095
1185
  continue;
1096
1186
  }
1097
- // Log structured error details and rethrow
1098
- logger_1.logger.error("Database getAll operation failed", {
1099
- operation: 'getAllSyncEvent',
1100
- model: 'SyncEvent',
1101
- error: String(error),
1102
- isRetryable: isConnectionError,
1103
- });
1187
+ // Log structured error details and rethrow (transient -> WARN).
1188
+ if (isConnectionError) {
1189
+ logger_1.logger.warn("Database getAll operation failed (transient after retries)", {
1190
+ operation: 'getAllSyncEvent',
1191
+ model: 'SyncEvent',
1192
+ error: String(error),
1193
+ isRetryable: true,
1194
+ transient: true,
1195
+ recoveryHint: "Upstream caller should retry on next cycle",
1196
+ });
1197
+ }
1198
+ else {
1199
+ logger_1.logger.error("Database getAll operation failed", {
1200
+ operation: 'getAllSyncEvent',
1201
+ model: 'SyncEvent',
1202
+ error: String(error),
1203
+ isRetryable: false,
1204
+ });
1205
+ }
1104
1206
  throw error;
1105
1207
  }
1106
1208
  }
@@ -1214,13 +1316,25 @@ exports.SyncEvent = {
1214
1316
  await new Promise(resolve => setTimeout(resolve, delay));
1215
1317
  continue;
1216
1318
  }
1217
- // Log structured error details and rethrow
1218
- logger_1.logger.error("Database findMany operation failed", {
1219
- operation: 'findManySyncEvent',
1220
- model: 'SyncEvent',
1221
- error: String(error),
1222
- isRetryable: isConnectionError,
1223
- });
1319
+ // Log structured error details and rethrow (transient -> WARN).
1320
+ if (isConnectionError) {
1321
+ logger_1.logger.warn("Database findMany operation failed (transient after retries)", {
1322
+ operation: 'findManySyncEvent',
1323
+ model: 'SyncEvent',
1324
+ error: String(error),
1325
+ isRetryable: true,
1326
+ transient: true,
1327
+ recoveryHint: "Upstream caller should retry on next cycle",
1328
+ });
1329
+ }
1330
+ else {
1331
+ logger_1.logger.error("Database findMany operation failed", {
1332
+ operation: 'findManySyncEvent',
1333
+ model: 'SyncEvent',
1334
+ error: String(error),
1335
+ isRetryable: false,
1336
+ });
1337
+ }
1224
1338
  throw error;
1225
1339
  }
1226
1340
  }
package/SystemAlert.cjs CHANGED
@@ -172,13 +172,28 @@ exports.SystemAlert = {
172
172
  await new Promise(resolve => setTimeout(resolve, delay));
173
173
  continue;
174
174
  }
175
- // Log structured error details and rethrow
176
- logger_1.logger.error("Database create operation failed", {
177
- operation: 'createOneSystemAlert',
178
- model: 'SystemAlert',
179
- error: String(error),
180
- isRetryable: isConnectionError,
181
- });
175
+ // Log structured error details and rethrow.
176
+ // Demote transient failures to WARN with explicit transient+recoveryHint
177
+ // metadata so log analytics can distinguish recoverable upstream retries
178
+ // from true defects.
179
+ if (isConnectionError) {
180
+ logger_1.logger.warn("Database create operation failed (transient after retries)", {
181
+ operation: 'createOneSystemAlert',
182
+ model: 'SystemAlert',
183
+ error: String(error),
184
+ isRetryable: true,
185
+ transient: true,
186
+ recoveryHint: "Upstream caller should retry on next cycle",
187
+ });
188
+ }
189
+ else {
190
+ logger_1.logger.error("Database create operation failed", {
191
+ operation: 'createOneSystemAlert',
192
+ model: 'SystemAlert',
193
+ error: String(error),
194
+ isRetryable: false,
195
+ });
196
+ }
182
197
  throw error;
183
198
  }
184
199
  }
@@ -316,13 +331,25 @@ exports.SystemAlert = {
316
331
  await new Promise(resolve => setTimeout(resolve, delay));
317
332
  continue;
318
333
  }
319
- // Log structured error details and rethrow
320
- logger_1.logger.error("Database createMany operation failed", {
321
- operation: 'createManySystemAlert',
322
- model: 'SystemAlert',
323
- error: String(error),
324
- isRetryable: isConnectionError,
325
- });
334
+ // Log structured error details and rethrow (transient -> WARN).
335
+ if (isConnectionError) {
336
+ logger_1.logger.warn("Database createMany operation failed (transient after retries)", {
337
+ operation: 'createManySystemAlert',
338
+ model: 'SystemAlert',
339
+ error: String(error),
340
+ isRetryable: true,
341
+ transient: true,
342
+ recoveryHint: "Upstream caller should retry on next cycle",
343
+ });
344
+ }
345
+ else {
346
+ logger_1.logger.error("Database createMany operation failed", {
347
+ operation: 'createManySystemAlert',
348
+ model: 'SystemAlert',
349
+ error: String(error),
350
+ isRetryable: false,
351
+ });
352
+ }
326
353
  throw error;
327
354
  }
328
355
  }
@@ -507,14 +534,27 @@ exports.SystemAlert = {
507
534
  await new Promise(resolve => setTimeout(resolve, delay));
508
535
  continue;
509
536
  }
510
- // Log structured error details and rethrow
511
- logger_1.logger.error("Database update operation failed", {
512
- operation: 'updateOneSystemAlert',
513
- model: 'SystemAlert',
514
- error: String(error),
515
- recordId: props.id,
516
- isRetryable: isConnectionError,
517
- });
537
+ // Log structured error details and rethrow (transient -> WARN).
538
+ if (isConnectionError) {
539
+ logger_1.logger.warn("Database update operation failed (transient after retries)", {
540
+ operation: 'updateOneSystemAlert',
541
+ model: 'SystemAlert',
542
+ error: String(error),
543
+ recordId: props.id,
544
+ isRetryable: true,
545
+ transient: true,
546
+ recoveryHint: "Upstream caller should retry on next cycle",
547
+ });
548
+ }
549
+ else {
550
+ logger_1.logger.error("Database update operation failed", {
551
+ operation: 'updateOneSystemAlert',
552
+ model: 'SystemAlert',
553
+ error: String(error),
554
+ recordId: props.id,
555
+ isRetryable: false,
556
+ });
557
+ }
518
558
  throw error;
519
559
  }
520
560
  }
@@ -724,14 +764,27 @@ exports.SystemAlert = {
724
764
  await new Promise(resolve => setTimeout(resolve, delay));
725
765
  continue;
726
766
  }
727
- // Log structured error details and rethrow
728
- logger_1.logger.error("Database upsert operation failed", {
729
- operation: 'upsertOneSystemAlert',
730
- model: 'SystemAlert',
731
- error: String(error),
732
- recordId: props.id,
733
- isRetryable: isConnectionError,
734
- });
767
+ // Log structured error details and rethrow (transient -> WARN).
768
+ if (isConnectionError) {
769
+ logger_1.logger.warn("Database upsert operation failed (transient after retries)", {
770
+ operation: 'upsertOneSystemAlert',
771
+ model: 'SystemAlert',
772
+ error: String(error),
773
+ recordId: props.id,
774
+ isRetryable: true,
775
+ transient: true,
776
+ recoveryHint: "Upstream caller should retry on next cycle",
777
+ });
778
+ }
779
+ else {
780
+ logger_1.logger.error("Database upsert operation failed", {
781
+ operation: 'upsertOneSystemAlert',
782
+ model: 'SystemAlert',
783
+ error: String(error),
784
+ recordId: props.id,
785
+ isRetryable: false,
786
+ });
787
+ }
735
788
  throw error;
736
789
  }
737
790
  }
@@ -914,13 +967,25 @@ exports.SystemAlert = {
914
967
  await new Promise(resolve => setTimeout(resolve, delay));
915
968
  continue;
916
969
  }
917
- // Log structured error details and rethrow
918
- logger_1.logger.error("Database updateMany operation failed", {
919
- operation: 'updateManySystemAlert',
920
- model: 'SystemAlert',
921
- error: String(error),
922
- isRetryable: isConnectionError,
923
- });
970
+ // Log structured error details and rethrow (transient -> WARN).
971
+ if (isConnectionError) {
972
+ logger_1.logger.warn("Database updateMany operation failed (transient after retries)", {
973
+ operation: 'updateManySystemAlert',
974
+ model: 'SystemAlert',
975
+ error: String(error),
976
+ isRetryable: true,
977
+ transient: true,
978
+ recoveryHint: "Upstream caller should retry on next cycle",
979
+ });
980
+ }
981
+ else {
982
+ logger_1.logger.error("Database updateMany operation failed", {
983
+ operation: 'updateManySystemAlert',
984
+ model: 'SystemAlert',
985
+ error: String(error),
986
+ isRetryable: false,
987
+ });
988
+ }
924
989
  throw error;
925
990
  }
926
991
  }
@@ -1043,14 +1108,27 @@ exports.SystemAlert = {
1043
1108
  await new Promise(resolve => setTimeout(resolve, delay));
1044
1109
  continue;
1045
1110
  }
1046
- // Log structured error details and rethrow
1047
- logger_1.logger.error("Database delete operation failed", {
1048
- operation: 'deleteOneSystemAlert',
1049
- model: 'SystemAlert',
1050
- error: String(error),
1051
- recordId: props.id,
1052
- isRetryable: isConnectionError,
1053
- });
1111
+ // Log structured error details and rethrow (transient -> WARN).
1112
+ if (isConnectionError) {
1113
+ logger_1.logger.warn("Database delete operation failed (transient after retries)", {
1114
+ operation: 'deleteOneSystemAlert',
1115
+ model: 'SystemAlert',
1116
+ error: String(error),
1117
+ recordId: props.id,
1118
+ isRetryable: true,
1119
+ transient: true,
1120
+ recoveryHint: "Upstream caller should retry on next cycle",
1121
+ });
1122
+ }
1123
+ else {
1124
+ logger_1.logger.error("Database delete operation failed", {
1125
+ operation: 'deleteOneSystemAlert',
1126
+ model: 'SystemAlert',
1127
+ error: String(error),
1128
+ recordId: props.id,
1129
+ isRetryable: false,
1130
+ });
1131
+ }
1054
1132
  throw error;
1055
1133
  }
1056
1134
  }
@@ -1158,13 +1236,25 @@ exports.SystemAlert = {
1158
1236
  await new Promise(resolve => setTimeout(resolve, delay));
1159
1237
  continue;
1160
1238
  }
1161
- // Log structured error details and rethrow
1162
- logger_1.logger.error("Database get operation failed", {
1163
- operation: 'getSystemAlert',
1164
- model: 'SystemAlert',
1165
- error: String(error),
1166
- isRetryable: isConnectionError,
1167
- });
1239
+ // Log structured error details and rethrow (transient -> WARN).
1240
+ if (isConnectionError) {
1241
+ logger_1.logger.warn("Database get operation failed (transient after retries)", {
1242
+ operation: 'getSystemAlert',
1243
+ model: 'SystemAlert',
1244
+ error: String(error),
1245
+ isRetryable: true,
1246
+ transient: true,
1247
+ recoveryHint: "Upstream caller should retry on next cycle",
1248
+ });
1249
+ }
1250
+ else {
1251
+ logger_1.logger.error("Database get operation failed", {
1252
+ operation: 'getSystemAlert',
1253
+ model: 'SystemAlert',
1254
+ error: String(error),
1255
+ isRetryable: false,
1256
+ });
1257
+ }
1168
1258
  throw error;
1169
1259
  }
1170
1260
  }
@@ -1251,13 +1341,25 @@ exports.SystemAlert = {
1251
1341
  await new Promise(resolve => setTimeout(resolve, delay));
1252
1342
  continue;
1253
1343
  }
1254
- // Log structured error details and rethrow
1255
- logger_1.logger.error("Database getAll operation failed", {
1256
- operation: 'getAllSystemAlert',
1257
- model: 'SystemAlert',
1258
- error: String(error),
1259
- isRetryable: isConnectionError,
1260
- });
1344
+ // Log structured error details and rethrow (transient -> WARN).
1345
+ if (isConnectionError) {
1346
+ logger_1.logger.warn("Database getAll operation failed (transient after retries)", {
1347
+ operation: 'getAllSystemAlert',
1348
+ model: 'SystemAlert',
1349
+ error: String(error),
1350
+ isRetryable: true,
1351
+ transient: true,
1352
+ recoveryHint: "Upstream caller should retry on next cycle",
1353
+ });
1354
+ }
1355
+ else {
1356
+ logger_1.logger.error("Database getAll operation failed", {
1357
+ operation: 'getAllSystemAlert',
1358
+ model: 'SystemAlert',
1359
+ error: String(error),
1360
+ isRetryable: false,
1361
+ });
1362
+ }
1261
1363
  throw error;
1262
1364
  }
1263
1365
  }
@@ -1377,13 +1479,25 @@ exports.SystemAlert = {
1377
1479
  await new Promise(resolve => setTimeout(resolve, delay));
1378
1480
  continue;
1379
1481
  }
1380
- // Log structured error details and rethrow
1381
- logger_1.logger.error("Database findMany operation failed", {
1382
- operation: 'findManySystemAlert',
1383
- model: 'SystemAlert',
1384
- error: String(error),
1385
- isRetryable: isConnectionError,
1386
- });
1482
+ // Log structured error details and rethrow (transient -> WARN).
1483
+ if (isConnectionError) {
1484
+ logger_1.logger.warn("Database findMany operation failed (transient after retries)", {
1485
+ operation: 'findManySystemAlert',
1486
+ model: 'SystemAlert',
1487
+ error: String(error),
1488
+ isRetryable: true,
1489
+ transient: true,
1490
+ recoveryHint: "Upstream caller should retry on next cycle",
1491
+ });
1492
+ }
1493
+ else {
1494
+ logger_1.logger.error("Database findMany operation failed", {
1495
+ operation: 'findManySystemAlert',
1496
+ model: 'SystemAlert',
1497
+ error: String(error),
1498
+ isRetryable: false,
1499
+ });
1500
+ }
1387
1501
  throw error;
1388
1502
  }
1389
1503
  }