@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
@@ -465,13 +465,28 @@ export const OptionsGreeksHistory = {
465
465
  await new Promise(resolve => setTimeout(resolve, delay));
466
466
  continue;
467
467
  }
468
- // Log structured error details and rethrow
469
- logger.error("Database create operation failed", {
470
- operation: 'createOneOptionsGreeksHistory',
471
- model: 'OptionsGreeksHistory',
472
- error: String(error),
473
- isRetryable: isConnectionError,
474
- });
468
+ // Log structured error details and rethrow.
469
+ // Demote transient failures to WARN with explicit transient+recoveryHint
470
+ // metadata so log analytics can distinguish recoverable upstream retries
471
+ // from true defects.
472
+ if (isConnectionError) {
473
+ logger.warn("Database create operation failed (transient after retries)", {
474
+ operation: 'createOneOptionsGreeksHistory',
475
+ model: 'OptionsGreeksHistory',
476
+ error: String(error),
477
+ isRetryable: true,
478
+ transient: true,
479
+ recoveryHint: "Upstream caller should retry on next cycle",
480
+ });
481
+ }
482
+ else {
483
+ logger.error("Database create operation failed", {
484
+ operation: 'createOneOptionsGreeksHistory',
485
+ model: 'OptionsGreeksHistory',
486
+ error: String(error),
487
+ isRetryable: false,
488
+ });
489
+ }
475
490
  throw error;
476
491
  }
477
492
  }
@@ -606,13 +621,25 @@ export const OptionsGreeksHistory = {
606
621
  await new Promise(resolve => setTimeout(resolve, delay));
607
622
  continue;
608
623
  }
609
- // Log structured error details and rethrow
610
- logger.error("Database createMany operation failed", {
611
- operation: 'createManyOptionsGreeksHistory',
612
- model: 'OptionsGreeksHistory',
613
- error: String(error),
614
- isRetryable: isConnectionError,
615
- });
624
+ // Log structured error details and rethrow (transient -> WARN).
625
+ if (isConnectionError) {
626
+ logger.warn("Database createMany operation failed (transient after retries)", {
627
+ operation: 'createManyOptionsGreeksHistory',
628
+ model: 'OptionsGreeksHistory',
629
+ error: String(error),
630
+ isRetryable: true,
631
+ transient: true,
632
+ recoveryHint: "Upstream caller should retry on next cycle",
633
+ });
634
+ }
635
+ else {
636
+ logger.error("Database createMany operation failed", {
637
+ operation: 'createManyOptionsGreeksHistory',
638
+ model: 'OptionsGreeksHistory',
639
+ error: String(error),
640
+ isRetryable: false,
641
+ });
642
+ }
616
643
  throw error;
617
644
  }
618
645
  }
@@ -1853,14 +1880,27 @@ export const OptionsGreeksHistory = {
1853
1880
  await new Promise(resolve => setTimeout(resolve, delay));
1854
1881
  continue;
1855
1882
  }
1856
- // Log structured error details and rethrow
1857
- logger.error("Database update operation failed", {
1858
- operation: 'updateOneOptionsGreeksHistory',
1859
- model: 'OptionsGreeksHistory',
1860
- error: String(error),
1861
- recordId: props.id,
1862
- isRetryable: isConnectionError,
1863
- });
1883
+ // Log structured error details and rethrow (transient -> WARN).
1884
+ if (isConnectionError) {
1885
+ logger.warn("Database update operation failed (transient after retries)", {
1886
+ operation: 'updateOneOptionsGreeksHistory',
1887
+ model: 'OptionsGreeksHistory',
1888
+ error: String(error),
1889
+ recordId: props.id,
1890
+ isRetryable: true,
1891
+ transient: true,
1892
+ recoveryHint: "Upstream caller should retry on next cycle",
1893
+ });
1894
+ }
1895
+ else {
1896
+ logger.error("Database update operation failed", {
1897
+ operation: 'updateOneOptionsGreeksHistory',
1898
+ model: 'OptionsGreeksHistory',
1899
+ error: String(error),
1900
+ recordId: props.id,
1901
+ isRetryable: false,
1902
+ });
1903
+ }
1864
1904
  throw error;
1865
1905
  }
1866
1906
  }
@@ -3388,14 +3428,27 @@ export const OptionsGreeksHistory = {
3388
3428
  await new Promise(resolve => setTimeout(resolve, delay));
3389
3429
  continue;
3390
3430
  }
3391
- // Log structured error details and rethrow
3392
- logger.error("Database upsert operation failed", {
3393
- operation: 'upsertOneOptionsGreeksHistory',
3394
- model: 'OptionsGreeksHistory',
3395
- error: String(error),
3396
- recordId: props.id,
3397
- isRetryable: isConnectionError,
3398
- });
3431
+ // Log structured error details and rethrow (transient -> WARN).
3432
+ if (isConnectionError) {
3433
+ logger.warn("Database upsert operation failed (transient after retries)", {
3434
+ operation: 'upsertOneOptionsGreeksHistory',
3435
+ model: 'OptionsGreeksHistory',
3436
+ error: String(error),
3437
+ recordId: props.id,
3438
+ isRetryable: true,
3439
+ transient: true,
3440
+ recoveryHint: "Upstream caller should retry on next cycle",
3441
+ });
3442
+ }
3443
+ else {
3444
+ logger.error("Database upsert operation failed", {
3445
+ operation: 'upsertOneOptionsGreeksHistory',
3446
+ model: 'OptionsGreeksHistory',
3447
+ error: String(error),
3448
+ recordId: props.id,
3449
+ isRetryable: false,
3450
+ });
3451
+ }
3399
3452
  throw error;
3400
3453
  }
3401
3454
  }
@@ -4634,13 +4687,25 @@ export const OptionsGreeksHistory = {
4634
4687
  await new Promise(resolve => setTimeout(resolve, delay));
4635
4688
  continue;
4636
4689
  }
4637
- // Log structured error details and rethrow
4638
- logger.error("Database updateMany operation failed", {
4639
- operation: 'updateManyOptionsGreeksHistory',
4640
- model: 'OptionsGreeksHistory',
4641
- error: String(error),
4642
- isRetryable: isConnectionError,
4643
- });
4690
+ // Log structured error details and rethrow (transient -> WARN).
4691
+ if (isConnectionError) {
4692
+ logger.warn("Database updateMany operation failed (transient after retries)", {
4693
+ operation: 'updateManyOptionsGreeksHistory',
4694
+ model: 'OptionsGreeksHistory',
4695
+ error: String(error),
4696
+ isRetryable: true,
4697
+ transient: true,
4698
+ recoveryHint: "Upstream caller should retry on next cycle",
4699
+ });
4700
+ }
4701
+ else {
4702
+ logger.error("Database updateMany operation failed", {
4703
+ operation: 'updateManyOptionsGreeksHistory',
4704
+ model: 'OptionsGreeksHistory',
4705
+ error: String(error),
4706
+ isRetryable: false,
4707
+ });
4708
+ }
4644
4709
  throw error;
4645
4710
  }
4646
4711
  }
@@ -4762,14 +4827,27 @@ export const OptionsGreeksHistory = {
4762
4827
  await new Promise(resolve => setTimeout(resolve, delay));
4763
4828
  continue;
4764
4829
  }
4765
- // Log structured error details and rethrow
4766
- logger.error("Database delete operation failed", {
4767
- operation: 'deleteOneOptionsGreeksHistory',
4768
- model: 'OptionsGreeksHistory',
4769
- error: String(error),
4770
- recordId: props.id,
4771
- isRetryable: isConnectionError,
4772
- });
4830
+ // Log structured error details and rethrow (transient -> WARN).
4831
+ if (isConnectionError) {
4832
+ logger.warn("Database delete operation failed (transient after retries)", {
4833
+ operation: 'deleteOneOptionsGreeksHistory',
4834
+ model: 'OptionsGreeksHistory',
4835
+ error: String(error),
4836
+ recordId: props.id,
4837
+ isRetryable: true,
4838
+ transient: true,
4839
+ recoveryHint: "Upstream caller should retry on next cycle",
4840
+ });
4841
+ }
4842
+ else {
4843
+ logger.error("Database delete operation failed", {
4844
+ operation: 'deleteOneOptionsGreeksHistory',
4845
+ model: 'OptionsGreeksHistory',
4846
+ error: String(error),
4847
+ recordId: props.id,
4848
+ isRetryable: false,
4849
+ });
4850
+ }
4773
4851
  throw error;
4774
4852
  }
4775
4853
  }
@@ -4867,13 +4945,25 @@ export const OptionsGreeksHistory = {
4867
4945
  await new Promise(resolve => setTimeout(resolve, delay));
4868
4946
  continue;
4869
4947
  }
4870
- // Log structured error details and rethrow
4871
- logger.error("Database get operation failed", {
4872
- operation: 'getOptionsGreeksHistory',
4873
- model: 'OptionsGreeksHistory',
4874
- error: String(error),
4875
- isRetryable: isConnectionError,
4876
- });
4948
+ // Log structured error details and rethrow (transient -> WARN).
4949
+ if (isConnectionError) {
4950
+ logger.warn("Database get operation failed (transient after retries)", {
4951
+ operation: 'getOptionsGreeksHistory',
4952
+ model: 'OptionsGreeksHistory',
4953
+ error: String(error),
4954
+ isRetryable: true,
4955
+ transient: true,
4956
+ recoveryHint: "Upstream caller should retry on next cycle",
4957
+ });
4958
+ }
4959
+ else {
4960
+ logger.error("Database get operation failed", {
4961
+ operation: 'getOptionsGreeksHistory',
4962
+ model: 'OptionsGreeksHistory',
4963
+ error: String(error),
4964
+ isRetryable: false,
4965
+ });
4966
+ }
4877
4967
  throw error;
4878
4968
  }
4879
4969
  }
@@ -4959,13 +5049,25 @@ export const OptionsGreeksHistory = {
4959
5049
  await new Promise(resolve => setTimeout(resolve, delay));
4960
5050
  continue;
4961
5051
  }
4962
- // Log structured error details and rethrow
4963
- logger.error("Database getAll operation failed", {
4964
- operation: 'getAllOptionsGreeksHistory',
4965
- model: 'OptionsGreeksHistory',
4966
- error: String(error),
4967
- isRetryable: isConnectionError,
4968
- });
5052
+ // Log structured error details and rethrow (transient -> WARN).
5053
+ if (isConnectionError) {
5054
+ logger.warn("Database getAll operation failed (transient after retries)", {
5055
+ operation: 'getAllOptionsGreeksHistory',
5056
+ model: 'OptionsGreeksHistory',
5057
+ error: String(error),
5058
+ isRetryable: true,
5059
+ transient: true,
5060
+ recoveryHint: "Upstream caller should retry on next cycle",
5061
+ });
5062
+ }
5063
+ else {
5064
+ logger.error("Database getAll operation failed", {
5065
+ operation: 'getAllOptionsGreeksHistory',
5066
+ model: 'OptionsGreeksHistory',
5067
+ error: String(error),
5068
+ isRetryable: false,
5069
+ });
5070
+ }
4969
5071
  throw error;
4970
5072
  }
4971
5073
  }
@@ -5075,13 +5177,25 @@ export const OptionsGreeksHistory = {
5075
5177
  await new Promise(resolve => setTimeout(resolve, delay));
5076
5178
  continue;
5077
5179
  }
5078
- // Log structured error details and rethrow
5079
- logger.error("Database findMany operation failed", {
5080
- operation: 'findManyOptionsGreeksHistory',
5081
- model: 'OptionsGreeksHistory',
5082
- error: String(error),
5083
- isRetryable: isConnectionError,
5084
- });
5180
+ // Log structured error details and rethrow (transient -> WARN).
5181
+ if (isConnectionError) {
5182
+ logger.warn("Database findMany operation failed (transient after retries)", {
5183
+ operation: 'findManyOptionsGreeksHistory',
5184
+ model: 'OptionsGreeksHistory',
5185
+ error: String(error),
5186
+ isRetryable: true,
5187
+ transient: true,
5188
+ recoveryHint: "Upstream caller should retry on next cycle",
5189
+ });
5190
+ }
5191
+ else {
5192
+ logger.error("Database findMany operation failed", {
5193
+ operation: 'findManyOptionsGreeksHistory',
5194
+ model: 'OptionsGreeksHistory',
5195
+ error: String(error),
5196
+ isRetryable: false,
5197
+ });
5198
+ }
5085
5199
  throw error;
5086
5200
  }
5087
5201
  }
@@ -1 +1 @@
1
- {"version":3,"file":"OptionsPosition.d.ts","sourceRoot":"","sources":["../../src/OptionsPosition.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,IAAI,mBAAmB,EAAE,MAAM,uDAAuD,CAAC;AAC/G,OAAO,EAAmB,gBAAgB,EAAE,qBAAqB,EAAoB,MAAM,UAAU,CAAC;AAuHpG,eAAO,MAAM,eAAe;IAE1B;;;;;OAKG;IAEH;;;;;;OAMG;kBACiB,mBAAmB,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,GAAG,OAAO,CAAC,mBAAmB,CAAC;IAkiBhI;;;;;;;OAOG;sBACqB,mBAAmB,EAAE,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,YAAY;QAAE,cAAc,CAAC,EAAE,OAAO,CAAA;KAAE,GAAG,OAAO,CAAC;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IAkKjL;;;;;;OAMG;kBACiB,mBAAmB,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,GAAG,OAAO,CAAC,mBAAmB,CAAC;IA+nD9H;;;;;;OAMG;kBACiB,mBAAmB,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,GAAG,OAAO,CAAC,mBAAmB,CAAC;IA+hE9H;;;;;;OAMG;sBACqB,mBAAmB,EAAE,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,GAAG,OAAO,CAAC;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IA8nDzI;;;;;;OAMG;kBACiB,mBAAmB,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,GAAG,OAAO,CAAC,mBAAmB,CAAC;IAyI9H;;;;;;;OAOG;eACc,mBAAmB,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,eAAe,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,mBAAmB,GAAG,IAAI,CAAC;IAmHxK;;;;;OAKG;0BACyB,gBAAgB,CAAC,qBAAqB,CAAC,GAAG,OAAO,CAAC,mBAAmB,EAAE,GAAG,IAAI,CAAC;IAkG3G;;;;;;;OAOG;oBACmB,mBAAmB,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,eAAe,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,mBAAmB,EAAE,GAAG,IAAI,CAAC;CA+HhL,CAAC"}
1
+ {"version":3,"file":"OptionsPosition.d.ts","sourceRoot":"","sources":["../../src/OptionsPosition.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,IAAI,mBAAmB,EAAE,MAAM,uDAAuD,CAAC;AAC/G,OAAO,EAAmB,gBAAgB,EAAE,qBAAqB,EAAoB,MAAM,UAAU,CAAC;AAuHpG,eAAO,MAAM,eAAe;IAE1B;;;;;OAKG;IAEH;;;;;;OAMG;kBACiB,mBAAmB,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,GAAG,OAAO,CAAC,mBAAmB,CAAC;IAgjBhI;;;;;;;OAOG;sBACqB,mBAAmB,EAAE,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,YAAY;QAAE,cAAc,CAAC,EAAE,OAAO,CAAA;KAAE,GAAG,OAAO,CAAC;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IA6KjL;;;;;;OAMG;kBACiB,mBAAmB,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,GAAG,OAAO,CAAC,mBAAmB,CAAC;IA2oD9H;;;;;;OAMG;kBACiB,mBAAmB,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,GAAG,OAAO,CAAC,mBAAmB,CAAC;IA2iE9H;;;;;;OAMG;sBACqB,mBAAmB,EAAE,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,GAAG,OAAO,CAAC;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IAyoDzI;;;;;;OAMG;kBACiB,mBAAmB,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,GAAG,OAAO,CAAC,mBAAmB,CAAC;IAqJ9H;;;;;;;OAOG;eACc,mBAAmB,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,eAAe,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,mBAAmB,GAAG,IAAI,CAAC;IA8HxK;;;;;OAKG;0BACyB,gBAAgB,CAAC,qBAAqB,CAAC,GAAG,OAAO,CAAC,mBAAmB,EAAE,GAAG,IAAI,CAAC;IA6G3G;;;;;;;OAOG;oBACmB,mBAAmB,iBAAiB,gBAAgB,CAAC,qBAAqB,CAAC,eAAe,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,mBAAmB,EAAE,GAAG,IAAI,CAAC;CA0IhL,CAAC"}