@voyant-travel/distribution 0.109.8

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 (168) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +42 -0
  3. package/dist/booking-extension.d.ts +168 -0
  4. package/dist/booking-extension.d.ts.map +1 -0
  5. package/dist/booking-extension.js +102 -0
  6. package/dist/channel-push/admin-routes.d.ts +31 -0
  7. package/dist/channel-push/admin-routes.d.ts.map +1 -0
  8. package/dist/channel-push/admin-routes.js +165 -0
  9. package/dist/channel-push/availability-push.d.ts +76 -0
  10. package/dist/channel-push/availability-push.d.ts.map +1 -0
  11. package/dist/channel-push/availability-push.js +236 -0
  12. package/dist/channel-push/booking-push-helpers.d.ts +36 -0
  13. package/dist/channel-push/booking-push-helpers.d.ts.map +1 -0
  14. package/dist/channel-push/booking-push-helpers.js +169 -0
  15. package/dist/channel-push/booking-push.d.ts +108 -0
  16. package/dist/channel-push/booking-push.d.ts.map +1 -0
  17. package/dist/channel-push/booking-push.js +335 -0
  18. package/dist/channel-push/boundary-sql.d.ts +23 -0
  19. package/dist/channel-push/boundary-sql.d.ts.map +1 -0
  20. package/dist/channel-push/boundary-sql.js +75 -0
  21. package/dist/channel-push/content-push.d.ts +60 -0
  22. package/dist/channel-push/content-push.d.ts.map +1 -0
  23. package/dist/channel-push/content-push.js +252 -0
  24. package/dist/channel-push/index.d.ts +15 -0
  25. package/dist/channel-push/index.d.ts.map +1 -0
  26. package/dist/channel-push/index.js +18 -0
  27. package/dist/channel-push/plugin.d.ts +18 -0
  28. package/dist/channel-push/plugin.d.ts.map +1 -0
  29. package/dist/channel-push/plugin.js +21 -0
  30. package/dist/channel-push/reconciler.d.ts +85 -0
  31. package/dist/channel-push/reconciler.d.ts.map +1 -0
  32. package/dist/channel-push/reconciler.js +179 -0
  33. package/dist/channel-push/subscriber.d.ts +40 -0
  34. package/dist/channel-push/subscriber.d.ts.map +1 -0
  35. package/dist/channel-push/subscriber.js +199 -0
  36. package/dist/channel-push/types.d.ts +43 -0
  37. package/dist/channel-push/types.d.ts.map +1 -0
  38. package/dist/channel-push/types.js +32 -0
  39. package/dist/channel-push/workflows.d.ts +56 -0
  40. package/dist/channel-push/workflows.d.ts.map +1 -0
  41. package/dist/channel-push/workflows.js +100 -0
  42. package/dist/external-refs/index.d.ts +11 -0
  43. package/dist/external-refs/index.d.ts.map +1 -0
  44. package/dist/external-refs/index.js +12 -0
  45. package/dist/external-refs/routes.d.ts +253 -0
  46. package/dist/external-refs/routes.d.ts.map +1 -0
  47. package/dist/external-refs/routes.js +52 -0
  48. package/dist/external-refs/schema.d.ts +251 -0
  49. package/dist/external-refs/schema.d.ts.map +1 -0
  50. package/dist/external-refs/schema.js +32 -0
  51. package/dist/external-refs/service.d.ts +82 -0
  52. package/dist/external-refs/service.d.ts.map +1 -0
  53. package/dist/external-refs/service.js +112 -0
  54. package/dist/external-refs/validation.d.ts +91 -0
  55. package/dist/external-refs/validation.d.ts.map +1 -0
  56. package/dist/external-refs/validation.js +40 -0
  57. package/dist/index.d.ts +21 -0
  58. package/dist/index.d.ts.map +1 -0
  59. package/dist/index.js +20 -0
  60. package/dist/interface-types.d.ts +128 -0
  61. package/dist/interface-types.d.ts.map +1 -0
  62. package/dist/interface-types.js +1 -0
  63. package/dist/interface.d.ts +10 -0
  64. package/dist/interface.d.ts.map +1 -0
  65. package/dist/interface.js +286 -0
  66. package/dist/rate-limit.d.ts +69 -0
  67. package/dist/rate-limit.d.ts.map +1 -0
  68. package/dist/rate-limit.js +135 -0
  69. package/dist/routes/batch.d.ts +200 -0
  70. package/dist/routes/batch.d.ts.map +1 -0
  71. package/dist/routes/batch.js +52 -0
  72. package/dist/routes/env.d.ts +8 -0
  73. package/dist/routes/env.d.ts.map +1 -0
  74. package/dist/routes/env.js +1 -0
  75. package/dist/routes/inventory.d.ts +604 -0
  76. package/dist/routes/inventory.d.ts.map +1 -0
  77. package/dist/routes/inventory.js +138 -0
  78. package/dist/routes/settlements.d.ts +1649 -0
  79. package/dist/routes/settlements.d.ts.map +1 -0
  80. package/dist/routes/settlements.js +265 -0
  81. package/dist/routes.d.ts +3909 -0
  82. package/dist/routes.d.ts.map +1 -0
  83. package/dist/routes.js +323 -0
  84. package/dist/schema-automation.d.ts +680 -0
  85. package/dist/schema-automation.d.ts.map +1 -0
  86. package/dist/schema-automation.js +76 -0
  87. package/dist/schema-core.d.ts +1674 -0
  88. package/dist/schema-core.d.ts.map +1 -0
  89. package/dist/schema-core.js +227 -0
  90. package/dist/schema-finance.d.ts +1372 -0
  91. package/dist/schema-finance.d.ts.map +1 -0
  92. package/dist/schema-finance.js +153 -0
  93. package/dist/schema-inventory.d.ts +855 -0
  94. package/dist/schema-inventory.d.ts.map +1 -0
  95. package/dist/schema-inventory.js +102 -0
  96. package/dist/schema-push-intents.d.ts +387 -0
  97. package/dist/schema-push-intents.d.ts.map +1 -0
  98. package/dist/schema-push-intents.js +77 -0
  99. package/dist/schema-relations.d.ts +95 -0
  100. package/dist/schema-relations.d.ts.map +1 -0
  101. package/dist/schema-relations.js +196 -0
  102. package/dist/schema-shared.d.ts +24 -0
  103. package/dist/schema-shared.d.ts.map +1 -0
  104. package/dist/schema-shared.js +123 -0
  105. package/dist/schema.d.ts +9 -0
  106. package/dist/schema.d.ts.map +1 -0
  107. package/dist/schema.js +8 -0
  108. package/dist/service/channels.d.ts +167 -0
  109. package/dist/service/channels.d.ts.map +1 -0
  110. package/dist/service/channels.js +305 -0
  111. package/dist/service/commercial.d.ts +385 -0
  112. package/dist/service/commercial.d.ts.map +1 -0
  113. package/dist/service/commercial.js +248 -0
  114. package/dist/service/helpers.d.ts +10 -0
  115. package/dist/service/helpers.d.ts.map +1 -0
  116. package/dist/service/helpers.js +7 -0
  117. package/dist/service/inventory.d.ts +193 -0
  118. package/dist/service/inventory.d.ts.map +1 -0
  119. package/dist/service/inventory.js +154 -0
  120. package/dist/service/settlement-policies.d.ts +325 -0
  121. package/dist/service/settlement-policies.d.ts.map +1 -0
  122. package/dist/service/settlement-policies.js +272 -0
  123. package/dist/service/settlements.d.ts +357 -0
  124. package/dist/service/settlements.d.ts.map +1 -0
  125. package/dist/service/settlements.js +319 -0
  126. package/dist/service/types.d.ts +60 -0
  127. package/dist/service/types.d.ts.map +1 -0
  128. package/dist/service/types.js +1 -0
  129. package/dist/service.d.ts +1418 -0
  130. package/dist/service.d.ts.map +1 -0
  131. package/dist/service.js +17 -0
  132. package/dist/suppliers/index.d.ts +15 -0
  133. package/dist/suppliers/index.d.ts.map +1 -0
  134. package/dist/suppliers/index.js +23 -0
  135. package/dist/suppliers/routes.d.ts +1202 -0
  136. package/dist/suppliers/routes.d.ts.map +1 -0
  137. package/dist/suppliers/routes.js +290 -0
  138. package/dist/suppliers/schema.d.ts +1272 -0
  139. package/dist/suppliers/schema.d.ts.map +1 -0
  140. package/dist/suppliers/schema.js +219 -0
  141. package/dist/suppliers/service-aggregates.d.ts +23 -0
  142. package/dist/suppliers/service-aggregates.d.ts.map +1 -0
  143. package/dist/suppliers/service-aggregates.js +51 -0
  144. package/dist/suppliers/service-core.d.ts +89 -0
  145. package/dist/suppliers/service-core.d.ts.map +1 -0
  146. package/dist/suppliers/service-core.js +164 -0
  147. package/dist/suppliers/service-identity.d.ts +162 -0
  148. package/dist/suppliers/service-identity.d.ts.map +1 -0
  149. package/dist/suppliers/service-identity.js +101 -0
  150. package/dist/suppliers/service-operations.d.ts +1500 -0
  151. package/dist/suppliers/service-operations.d.ts.map +1 -0
  152. package/dist/suppliers/service-operations.js +157 -0
  153. package/dist/suppliers/service-shared.d.ts +45 -0
  154. package/dist/suppliers/service-shared.d.ts.map +1 -0
  155. package/dist/suppliers/service-shared.js +294 -0
  156. package/dist/suppliers/service.d.ts +41 -0
  157. package/dist/suppliers/service.d.ts.map +1 -0
  158. package/dist/suppliers/service.js +40 -0
  159. package/dist/suppliers/validation.d.ts +2 -0
  160. package/dist/suppliers/validation.d.ts.map +1 -0
  161. package/dist/suppliers/validation.js +1 -0
  162. package/dist/validation.d.ts +1371 -0
  163. package/dist/validation.d.ts.map +1 -0
  164. package/dist/validation.js +445 -0
  165. package/dist/webhook-deliveries.d.ts +86 -0
  166. package/dist/webhook-deliveries.d.ts.map +1 -0
  167. package/dist/webhook-deliveries.js +296 -0
  168. package/package.json +71 -0
@@ -0,0 +1,325 @@
1
+ import type { PostgresJsDatabase } from "drizzle-orm/postgres-js";
2
+ import type { ChannelReconciliationPolicyListQuery, ChannelReleaseScheduleListQuery, ChannelRemittanceExceptionListQuery, ChannelSettlementApprovalListQuery, ChannelSettlementPolicyListQuery, CreateChannelReconciliationPolicyInput, CreateChannelReleaseScheduleInput, CreateChannelRemittanceExceptionInput, CreateChannelSettlementApprovalInput, CreateChannelSettlementPolicyInput, UpdateChannelReconciliationPolicyInput, UpdateChannelReleaseScheduleInput, UpdateChannelRemittanceExceptionInput, UpdateChannelSettlementApprovalInput, UpdateChannelSettlementPolicyInput } from "./types.js";
3
+ export declare const settlementPolicyServiceOperations: {
4
+ listSettlementPolicies(db: PostgresJsDatabase, query: ChannelSettlementPolicyListQuery): Promise<{
5
+ data: {
6
+ id: string;
7
+ channelId: string;
8
+ contractId: string | null;
9
+ frequency: "manual" | "daily" | "weekly" | "monthly";
10
+ autoGenerate: boolean;
11
+ approvalRequired: boolean;
12
+ remittanceDaysAfterPeriodEnd: number | null;
13
+ minimumPayoutAmountCents: number | null;
14
+ currencyCode: string | null;
15
+ active: boolean;
16
+ notes: string | null;
17
+ metadata: Record<string, unknown> | null;
18
+ createdAt: Date;
19
+ updatedAt: Date;
20
+ }[];
21
+ total: number;
22
+ limit: number;
23
+ offset: number;
24
+ }>;
25
+ getSettlementPolicyById(db: PostgresJsDatabase, id: string): Promise<{
26
+ id: string;
27
+ channelId: string;
28
+ contractId: string | null;
29
+ frequency: "manual" | "daily" | "weekly" | "monthly";
30
+ autoGenerate: boolean;
31
+ approvalRequired: boolean;
32
+ remittanceDaysAfterPeriodEnd: number | null;
33
+ minimumPayoutAmountCents: number | null;
34
+ currencyCode: string | null;
35
+ active: boolean;
36
+ notes: string | null;
37
+ metadata: Record<string, unknown> | null;
38
+ createdAt: Date;
39
+ updatedAt: Date;
40
+ } | null>;
41
+ createSettlementPolicy(db: PostgresJsDatabase, data: CreateChannelSettlementPolicyInput): Promise<{
42
+ createdAt: Date;
43
+ updatedAt: Date;
44
+ metadata: Record<string, unknown> | null;
45
+ id: string;
46
+ active: boolean;
47
+ channelId: string;
48
+ notes: string | null;
49
+ contractId: string | null;
50
+ currencyCode: string | null;
51
+ frequency: "manual" | "daily" | "weekly" | "monthly";
52
+ autoGenerate: boolean;
53
+ approvalRequired: boolean;
54
+ remittanceDaysAfterPeriodEnd: number | null;
55
+ minimumPayoutAmountCents: number | null;
56
+ } | undefined>;
57
+ updateSettlementPolicy(db: PostgresJsDatabase, id: string, data: UpdateChannelSettlementPolicyInput): Promise<{
58
+ id: string;
59
+ channelId: string;
60
+ contractId: string | null;
61
+ frequency: "manual" | "daily" | "weekly" | "monthly";
62
+ autoGenerate: boolean;
63
+ approvalRequired: boolean;
64
+ remittanceDaysAfterPeriodEnd: number | null;
65
+ minimumPayoutAmountCents: number | null;
66
+ currencyCode: string | null;
67
+ active: boolean;
68
+ notes: string | null;
69
+ metadata: Record<string, unknown> | null;
70
+ createdAt: Date;
71
+ updatedAt: Date;
72
+ } | null>;
73
+ deleteSettlementPolicy(db: PostgresJsDatabase, id: string): Promise<{
74
+ id: string;
75
+ } | null>;
76
+ listReconciliationPolicies(db: PostgresJsDatabase, query: ChannelReconciliationPolicyListQuery): Promise<{
77
+ data: {
78
+ id: string;
79
+ channelId: string;
80
+ contractId: string | null;
81
+ frequency: "manual" | "daily" | "weekly" | "monthly";
82
+ autoRun: boolean;
83
+ compareGrossAmounts: boolean;
84
+ compareStatuses: boolean;
85
+ compareCancellations: boolean;
86
+ amountToleranceCents: number | null;
87
+ active: boolean;
88
+ notes: string | null;
89
+ metadata: Record<string, unknown> | null;
90
+ createdAt: Date;
91
+ updatedAt: Date;
92
+ }[];
93
+ total: number;
94
+ limit: number;
95
+ offset: number;
96
+ }>;
97
+ getReconciliationPolicyById(db: PostgresJsDatabase, id: string): Promise<{
98
+ id: string;
99
+ channelId: string;
100
+ contractId: string | null;
101
+ frequency: "manual" | "daily" | "weekly" | "monthly";
102
+ autoRun: boolean;
103
+ compareGrossAmounts: boolean;
104
+ compareStatuses: boolean;
105
+ compareCancellations: boolean;
106
+ amountToleranceCents: number | null;
107
+ active: boolean;
108
+ notes: string | null;
109
+ metadata: Record<string, unknown> | null;
110
+ createdAt: Date;
111
+ updatedAt: Date;
112
+ } | null>;
113
+ createReconciliationPolicy(db: PostgresJsDatabase, data: CreateChannelReconciliationPolicyInput): Promise<{
114
+ createdAt: Date;
115
+ updatedAt: Date;
116
+ metadata: Record<string, unknown> | null;
117
+ id: string;
118
+ active: boolean;
119
+ channelId: string;
120
+ notes: string | null;
121
+ contractId: string | null;
122
+ frequency: "manual" | "daily" | "weekly" | "monthly";
123
+ autoRun: boolean;
124
+ compareGrossAmounts: boolean;
125
+ compareStatuses: boolean;
126
+ compareCancellations: boolean;
127
+ amountToleranceCents: number | null;
128
+ } | undefined>;
129
+ updateReconciliationPolicy(db: PostgresJsDatabase, id: string, data: UpdateChannelReconciliationPolicyInput): Promise<{
130
+ id: string;
131
+ channelId: string;
132
+ contractId: string | null;
133
+ frequency: "manual" | "daily" | "weekly" | "monthly";
134
+ autoRun: boolean;
135
+ compareGrossAmounts: boolean;
136
+ compareStatuses: boolean;
137
+ compareCancellations: boolean;
138
+ amountToleranceCents: number | null;
139
+ active: boolean;
140
+ notes: string | null;
141
+ metadata: Record<string, unknown> | null;
142
+ createdAt: Date;
143
+ updatedAt: Date;
144
+ } | null>;
145
+ deleteReconciliationPolicy(db: PostgresJsDatabase, id: string): Promise<{
146
+ id: string;
147
+ } | null>;
148
+ listReleaseSchedules(db: PostgresJsDatabase, query: ChannelReleaseScheduleListQuery): Promise<{
149
+ data: {
150
+ id: string;
151
+ releaseRuleId: string;
152
+ scheduleKind: "manual" | "daily" | "hourly";
153
+ nextRunAt: Date | null;
154
+ lastRunAt: Date | null;
155
+ active: boolean;
156
+ notes: string | null;
157
+ metadata: Record<string, unknown> | null;
158
+ createdAt: Date;
159
+ updatedAt: Date;
160
+ }[];
161
+ total: number;
162
+ limit: number;
163
+ offset: number;
164
+ }>;
165
+ getReleaseScheduleById(db: PostgresJsDatabase, id: string): Promise<{
166
+ id: string;
167
+ releaseRuleId: string;
168
+ scheduleKind: "manual" | "daily" | "hourly";
169
+ nextRunAt: Date | null;
170
+ lastRunAt: Date | null;
171
+ active: boolean;
172
+ notes: string | null;
173
+ metadata: Record<string, unknown> | null;
174
+ createdAt: Date;
175
+ updatedAt: Date;
176
+ } | null>;
177
+ createReleaseSchedule(db: PostgresJsDatabase, data: CreateChannelReleaseScheduleInput): Promise<{
178
+ createdAt: Date;
179
+ updatedAt: Date;
180
+ metadata: Record<string, unknown> | null;
181
+ id: string;
182
+ active: boolean;
183
+ notes: string | null;
184
+ releaseRuleId: string;
185
+ scheduleKind: "manual" | "daily" | "hourly";
186
+ nextRunAt: Date | null;
187
+ lastRunAt: Date | null;
188
+ } | undefined>;
189
+ updateReleaseSchedule(db: PostgresJsDatabase, id: string, data: UpdateChannelReleaseScheduleInput): Promise<{
190
+ id: string;
191
+ releaseRuleId: string;
192
+ scheduleKind: "manual" | "daily" | "hourly";
193
+ nextRunAt: Date | null;
194
+ lastRunAt: Date | null;
195
+ active: boolean;
196
+ notes: string | null;
197
+ metadata: Record<string, unknown> | null;
198
+ createdAt: Date;
199
+ updatedAt: Date;
200
+ } | null>;
201
+ deleteReleaseSchedule(db: PostgresJsDatabase, id: string): Promise<{
202
+ id: string;
203
+ } | null>;
204
+ listRemittanceExceptions(db: PostgresJsDatabase, query: ChannelRemittanceExceptionListQuery): Promise<{
205
+ data: {
206
+ id: string;
207
+ channelId: string;
208
+ settlementItemId: string | null;
209
+ reconciliationItemId: string | null;
210
+ exceptionType: string;
211
+ severity: "error" | "info" | "warning";
212
+ status: "ignored" | "open" | "resolved" | "investigating";
213
+ openedAt: Date;
214
+ resolvedAt: Date | null;
215
+ notes: string | null;
216
+ metadata: Record<string, unknown> | null;
217
+ createdAt: Date;
218
+ updatedAt: Date;
219
+ }[];
220
+ total: number;
221
+ limit: number;
222
+ offset: number;
223
+ }>;
224
+ getRemittanceExceptionById(db: PostgresJsDatabase, id: string): Promise<{
225
+ id: string;
226
+ channelId: string;
227
+ settlementItemId: string | null;
228
+ reconciliationItemId: string | null;
229
+ exceptionType: string;
230
+ severity: "error" | "info" | "warning";
231
+ status: "ignored" | "open" | "resolved" | "investigating";
232
+ openedAt: Date;
233
+ resolvedAt: Date | null;
234
+ notes: string | null;
235
+ metadata: Record<string, unknown> | null;
236
+ createdAt: Date;
237
+ updatedAt: Date;
238
+ } | null>;
239
+ createRemittanceException(db: PostgresJsDatabase, data: CreateChannelRemittanceExceptionInput): Promise<{
240
+ createdAt: Date;
241
+ updatedAt: Date;
242
+ metadata: Record<string, unknown> | null;
243
+ id: string;
244
+ status: "ignored" | "open" | "resolved" | "investigating";
245
+ channelId: string;
246
+ notes: string | null;
247
+ severity: "error" | "info" | "warning";
248
+ resolvedAt: Date | null;
249
+ settlementItemId: string | null;
250
+ reconciliationItemId: string | null;
251
+ exceptionType: string;
252
+ openedAt: Date;
253
+ } | undefined>;
254
+ updateRemittanceException(db: PostgresJsDatabase, id: string, data: UpdateChannelRemittanceExceptionInput): Promise<{
255
+ id: string;
256
+ channelId: string;
257
+ settlementItemId: string | null;
258
+ reconciliationItemId: string | null;
259
+ exceptionType: string;
260
+ severity: "error" | "info" | "warning";
261
+ status: "ignored" | "open" | "resolved" | "investigating";
262
+ openedAt: Date;
263
+ resolvedAt: Date | null;
264
+ notes: string | null;
265
+ metadata: Record<string, unknown> | null;
266
+ createdAt: Date;
267
+ updatedAt: Date;
268
+ } | null>;
269
+ deleteRemittanceException(db: PostgresJsDatabase, id: string): Promise<{
270
+ id: string;
271
+ } | null>;
272
+ listSettlementApprovals(db: PostgresJsDatabase, query: ChannelSettlementApprovalListQuery): Promise<{
273
+ data: {
274
+ id: string;
275
+ settlementRunId: string;
276
+ approverUserId: string | null;
277
+ status: "pending" | "approved" | "rejected";
278
+ decidedAt: Date | null;
279
+ notes: string | null;
280
+ metadata: Record<string, unknown> | null;
281
+ createdAt: Date;
282
+ updatedAt: Date;
283
+ }[];
284
+ total: number;
285
+ limit: number;
286
+ offset: number;
287
+ }>;
288
+ getSettlementApprovalById(db: PostgresJsDatabase, id: string): Promise<{
289
+ id: string;
290
+ settlementRunId: string;
291
+ approverUserId: string | null;
292
+ status: "pending" | "approved" | "rejected";
293
+ decidedAt: Date | null;
294
+ notes: string | null;
295
+ metadata: Record<string, unknown> | null;
296
+ createdAt: Date;
297
+ updatedAt: Date;
298
+ } | null>;
299
+ createSettlementApproval(db: PostgresJsDatabase, data: CreateChannelSettlementApprovalInput): Promise<{
300
+ createdAt: Date;
301
+ updatedAt: Date;
302
+ metadata: Record<string, unknown> | null;
303
+ id: string;
304
+ status: "pending" | "approved" | "rejected";
305
+ notes: string | null;
306
+ settlementRunId: string;
307
+ approverUserId: string | null;
308
+ decidedAt: Date | null;
309
+ } | undefined>;
310
+ updateSettlementApproval(db: PostgresJsDatabase, id: string, data: UpdateChannelSettlementApprovalInput): Promise<{
311
+ id: string;
312
+ settlementRunId: string;
313
+ approverUserId: string | null;
314
+ status: "pending" | "approved" | "rejected";
315
+ decidedAt: Date | null;
316
+ notes: string | null;
317
+ metadata: Record<string, unknown> | null;
318
+ createdAt: Date;
319
+ updatedAt: Date;
320
+ } | null>;
321
+ deleteSettlementApproval(db: PostgresJsDatabase, id: string): Promise<{
322
+ id: string;
323
+ } | null>;
324
+ };
325
+ //# sourceMappingURL=settlement-policies.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"settlement-policies.d.ts","sourceRoot":"","sources":["../../src/service/settlement-policies.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAUjE,OAAO,KAAK,EACV,oCAAoC,EACpC,+BAA+B,EAC/B,mCAAmC,EACnC,kCAAkC,EAClC,gCAAgC,EAChC,sCAAsC,EACtC,iCAAiC,EACjC,qCAAqC,EACrC,oCAAoC,EACpC,kCAAkC,EAClC,sCAAsC,EACtC,iCAAiC,EACjC,qCAAqC,EACrC,oCAAoC,EACpC,kCAAkC,EACnC,MAAM,YAAY,CAAA;AAEnB,eAAO,MAAM,iCAAiC;+BACX,kBAAkB,SAAS,gCAAgC;;;;;;;;;;;;;;;;;;;;;gCAuB1D,kBAAkB,MAAM,MAAM;;;;;;;;;;;;;;;;+BAS/B,kBAAkB,QAAQ,kCAAkC;;;;;;;;;;;;;;;;+BAMvF,kBAAkB,MAClB,MAAM,QACJ,kCAAkC;;;;;;;;;;;;;;;;+BAUT,kBAAkB,MAAM,MAAM;;;mCASzD,kBAAkB,SACf,oCAAoC;;;;;;;;;;;;;;;;;;;;;oCA6BP,kBAAkB,MAAM,MAAM;;;;;;;;;;;;;;;;mCAU9D,kBAAkB,QAChB,sCAAsC;;;;;;;;;;;;;;;;mCAOxC,kBAAkB,MAClB,MAAM,QACJ,sCAAsC;;;;;;;;;;;;;;;;mCAUT,kBAAkB,MAAM,MAAM;;;6BAQpC,kBAAkB,SAAS,+BAA+B;;;;;;;;;;;;;;;;;+BAuBxD,kBAAkB,MAAM,MAAM;;;;;;;;;;;;8BAS/B,kBAAkB,QAAQ,iCAAiC;;;;;;;;;;;;8BAarF,kBAAkB,MAClB,MAAM,QACJ,iCAAiC;;;;;;;;;;;;8BAeT,kBAAkB,MAAM,MAAM;;;iCASxD,kBAAkB,SACf,mCAAmC;;;;;;;;;;;;;;;;;;;;mCA6BP,kBAAkB,MAAM,MAAM;;;;;;;;;;;;;;;kCAU7D,kBAAkB,QAChB,qCAAqC;;;;;;;;;;;;;;;kCAcvC,kBAAkB,MAClB,MAAM,QACJ,qCAAqC;;;;;;;;;;;;;;;kCAeT,kBAAkB,MAAM,MAAM;;;gCAQhC,kBAAkB,SAAS,kCAAkC;;;;;;;;;;;;;;;;kCAuB3D,kBAAkB,MAAM,MAAM;;;;;;;;;;;iCAU5D,kBAAkB,QAChB,oCAAoC;;;;;;;;;;;iCAatC,kBAAkB,MAClB,MAAM,QACJ,oCAAoC;;;;;;;;;;;iCAcT,kBAAkB,MAAM,MAAM;;;CAOlE,CAAA"}
@@ -0,0 +1,272 @@
1
+ import { and, desc, eq, sql } from "drizzle-orm";
2
+ import { channelReconciliationPolicies, channelReleaseSchedules, channelRemittanceExceptions, channelSettlementApprovals, channelSettlementPolicies, } from "../schema.js";
3
+ import { paginate, toDateOrNull } from "./helpers.js";
4
+ export const settlementPolicyServiceOperations = {
5
+ async listSettlementPolicies(db, query) {
6
+ const conditions = [];
7
+ if (query.channelId)
8
+ conditions.push(eq(channelSettlementPolicies.channelId, query.channelId));
9
+ if (query.contractId)
10
+ conditions.push(eq(channelSettlementPolicies.contractId, query.contractId));
11
+ if (query.frequency)
12
+ conditions.push(eq(channelSettlementPolicies.frequency, query.frequency));
13
+ if (query.active !== undefined)
14
+ conditions.push(eq(channelSettlementPolicies.active, query.active));
15
+ const where = conditions.length ? and(...conditions) : undefined;
16
+ return paginate(db
17
+ .select()
18
+ .from(channelSettlementPolicies)
19
+ .where(where)
20
+ .limit(query.limit)
21
+ .offset(query.offset)
22
+ .orderBy(desc(channelSettlementPolicies.updatedAt)), db.select({ count: sql `count(*)::int` }).from(channelSettlementPolicies).where(where), query.limit, query.offset);
23
+ },
24
+ async getSettlementPolicyById(db, id) {
25
+ const [row] = await db
26
+ .select()
27
+ .from(channelSettlementPolicies)
28
+ .where(eq(channelSettlementPolicies.id, id))
29
+ .limit(1);
30
+ return row ?? null;
31
+ },
32
+ async createSettlementPolicy(db, data) {
33
+ const [row] = await db.insert(channelSettlementPolicies).values(data).returning();
34
+ return row;
35
+ },
36
+ async updateSettlementPolicy(db, id, data) {
37
+ const [row] = await db
38
+ .update(channelSettlementPolicies)
39
+ .set({ ...data, updatedAt: new Date() })
40
+ .where(eq(channelSettlementPolicies.id, id))
41
+ .returning();
42
+ return row ?? null;
43
+ },
44
+ async deleteSettlementPolicy(db, id) {
45
+ const [row] = await db
46
+ .delete(channelSettlementPolicies)
47
+ .where(eq(channelSettlementPolicies.id, id))
48
+ .returning({ id: channelSettlementPolicies.id });
49
+ return row ?? null;
50
+ },
51
+ async listReconciliationPolicies(db, query) {
52
+ const conditions = [];
53
+ if (query.channelId)
54
+ conditions.push(eq(channelReconciliationPolicies.channelId, query.channelId));
55
+ if (query.contractId)
56
+ conditions.push(eq(channelReconciliationPolicies.contractId, query.contractId));
57
+ if (query.frequency)
58
+ conditions.push(eq(channelReconciliationPolicies.frequency, query.frequency));
59
+ if (query.active !== undefined)
60
+ conditions.push(eq(channelReconciliationPolicies.active, query.active));
61
+ const where = conditions.length ? and(...conditions) : undefined;
62
+ return paginate(db
63
+ .select()
64
+ .from(channelReconciliationPolicies)
65
+ .where(where)
66
+ .limit(query.limit)
67
+ .offset(query.offset)
68
+ .orderBy(desc(channelReconciliationPolicies.updatedAt)), db
69
+ .select({ count: sql `count(*)::int` })
70
+ .from(channelReconciliationPolicies)
71
+ .where(where), query.limit, query.offset);
72
+ },
73
+ async getReconciliationPolicyById(db, id) {
74
+ const [row] = await db
75
+ .select()
76
+ .from(channelReconciliationPolicies)
77
+ .where(eq(channelReconciliationPolicies.id, id))
78
+ .limit(1);
79
+ return row ?? null;
80
+ },
81
+ async createReconciliationPolicy(db, data) {
82
+ const [row] = await db.insert(channelReconciliationPolicies).values(data).returning();
83
+ return row;
84
+ },
85
+ async updateReconciliationPolicy(db, id, data) {
86
+ const [row] = await db
87
+ .update(channelReconciliationPolicies)
88
+ .set({ ...data, updatedAt: new Date() })
89
+ .where(eq(channelReconciliationPolicies.id, id))
90
+ .returning();
91
+ return row ?? null;
92
+ },
93
+ async deleteReconciliationPolicy(db, id) {
94
+ const [row] = await db
95
+ .delete(channelReconciliationPolicies)
96
+ .where(eq(channelReconciliationPolicies.id, id))
97
+ .returning({ id: channelReconciliationPolicies.id });
98
+ return row ?? null;
99
+ },
100
+ async listReleaseSchedules(db, query) {
101
+ const conditions = [];
102
+ if (query.releaseRuleId)
103
+ conditions.push(eq(channelReleaseSchedules.releaseRuleId, query.releaseRuleId));
104
+ if (query.scheduleKind)
105
+ conditions.push(eq(channelReleaseSchedules.scheduleKind, query.scheduleKind));
106
+ if (query.active !== undefined)
107
+ conditions.push(eq(channelReleaseSchedules.active, query.active));
108
+ const where = conditions.length ? and(...conditions) : undefined;
109
+ return paginate(db
110
+ .select()
111
+ .from(channelReleaseSchedules)
112
+ .where(where)
113
+ .limit(query.limit)
114
+ .offset(query.offset)
115
+ .orderBy(desc(channelReleaseSchedules.updatedAt)), db.select({ count: sql `count(*)::int` }).from(channelReleaseSchedules).where(where), query.limit, query.offset);
116
+ },
117
+ async getReleaseScheduleById(db, id) {
118
+ const [row] = await db
119
+ .select()
120
+ .from(channelReleaseSchedules)
121
+ .where(eq(channelReleaseSchedules.id, id))
122
+ .limit(1);
123
+ return row ?? null;
124
+ },
125
+ async createReleaseSchedule(db, data) {
126
+ const [row] = await db
127
+ .insert(channelReleaseSchedules)
128
+ .values({
129
+ ...data,
130
+ nextRunAt: toDateOrNull(data.nextRunAt),
131
+ lastRunAt: toDateOrNull(data.lastRunAt),
132
+ })
133
+ .returning();
134
+ return row;
135
+ },
136
+ async updateReleaseSchedule(db, id, data) {
137
+ const [row] = await db
138
+ .update(channelReleaseSchedules)
139
+ .set({
140
+ ...data,
141
+ nextRunAt: toDateOrNull(data.nextRunAt),
142
+ lastRunAt: toDateOrNull(data.lastRunAt),
143
+ updatedAt: new Date(),
144
+ })
145
+ .where(eq(channelReleaseSchedules.id, id))
146
+ .returning();
147
+ return row ?? null;
148
+ },
149
+ async deleteReleaseSchedule(db, id) {
150
+ const [row] = await db
151
+ .delete(channelReleaseSchedules)
152
+ .where(eq(channelReleaseSchedules.id, id))
153
+ .returning({ id: channelReleaseSchedules.id });
154
+ return row ?? null;
155
+ },
156
+ async listRemittanceExceptions(db, query) {
157
+ const conditions = [];
158
+ if (query.channelId)
159
+ conditions.push(eq(channelRemittanceExceptions.channelId, query.channelId));
160
+ if (query.settlementItemId)
161
+ conditions.push(eq(channelRemittanceExceptions.settlementItemId, query.settlementItemId));
162
+ if (query.reconciliationItemId)
163
+ conditions.push(eq(channelRemittanceExceptions.reconciliationItemId, query.reconciliationItemId));
164
+ if (query.status)
165
+ conditions.push(eq(channelRemittanceExceptions.status, query.status));
166
+ const where = conditions.length ? and(...conditions) : undefined;
167
+ return paginate(db
168
+ .select()
169
+ .from(channelRemittanceExceptions)
170
+ .where(where)
171
+ .limit(query.limit)
172
+ .offset(query.offset)
173
+ .orderBy(desc(channelRemittanceExceptions.updatedAt)), db
174
+ .select({ count: sql `count(*)::int` })
175
+ .from(channelRemittanceExceptions)
176
+ .where(where), query.limit, query.offset);
177
+ },
178
+ async getRemittanceExceptionById(db, id) {
179
+ const [row] = await db
180
+ .select()
181
+ .from(channelRemittanceExceptions)
182
+ .where(eq(channelRemittanceExceptions.id, id))
183
+ .limit(1);
184
+ return row ?? null;
185
+ },
186
+ async createRemittanceException(db, data) {
187
+ const [row] = await db
188
+ .insert(channelRemittanceExceptions)
189
+ .values({
190
+ ...data,
191
+ openedAt: toDateOrNull(data.openedAt) ?? new Date(),
192
+ resolvedAt: toDateOrNull(data.resolvedAt),
193
+ })
194
+ .returning();
195
+ return row;
196
+ },
197
+ async updateRemittanceException(db, id, data) {
198
+ const [row] = await db
199
+ .update(channelRemittanceExceptions)
200
+ .set({
201
+ ...data,
202
+ openedAt: data.openedAt ? new Date(data.openedAt) : undefined,
203
+ resolvedAt: toDateOrNull(data.resolvedAt),
204
+ updatedAt: new Date(),
205
+ })
206
+ .where(eq(channelRemittanceExceptions.id, id))
207
+ .returning();
208
+ return row ?? null;
209
+ },
210
+ async deleteRemittanceException(db, id) {
211
+ const [row] = await db
212
+ .delete(channelRemittanceExceptions)
213
+ .where(eq(channelRemittanceExceptions.id, id))
214
+ .returning({ id: channelRemittanceExceptions.id });
215
+ return row ?? null;
216
+ },
217
+ async listSettlementApprovals(db, query) {
218
+ const conditions = [];
219
+ if (query.settlementRunId)
220
+ conditions.push(eq(channelSettlementApprovals.settlementRunId, query.settlementRunId));
221
+ if (query.status)
222
+ conditions.push(eq(channelSettlementApprovals.status, query.status));
223
+ const where = conditions.length ? and(...conditions) : undefined;
224
+ return paginate(db
225
+ .select()
226
+ .from(channelSettlementApprovals)
227
+ .where(where)
228
+ .limit(query.limit)
229
+ .offset(query.offset)
230
+ .orderBy(desc(channelSettlementApprovals.updatedAt)), db
231
+ .select({ count: sql `count(*)::int` })
232
+ .from(channelSettlementApprovals)
233
+ .where(where), query.limit, query.offset);
234
+ },
235
+ async getSettlementApprovalById(db, id) {
236
+ const [row] = await db
237
+ .select()
238
+ .from(channelSettlementApprovals)
239
+ .where(eq(channelSettlementApprovals.id, id))
240
+ .limit(1);
241
+ return row ?? null;
242
+ },
243
+ async createSettlementApproval(db, data) {
244
+ const [row] = await db
245
+ .insert(channelSettlementApprovals)
246
+ .values({
247
+ ...data,
248
+ decidedAt: toDateOrNull(data.decidedAt),
249
+ })
250
+ .returning();
251
+ return row;
252
+ },
253
+ async updateSettlementApproval(db, id, data) {
254
+ const [row] = await db
255
+ .update(channelSettlementApprovals)
256
+ .set({
257
+ ...data,
258
+ decidedAt: toDateOrNull(data.decidedAt),
259
+ updatedAt: new Date(),
260
+ })
261
+ .where(eq(channelSettlementApprovals.id, id))
262
+ .returning();
263
+ return row ?? null;
264
+ },
265
+ async deleteSettlementApproval(db, id) {
266
+ const [row] = await db
267
+ .delete(channelSettlementApprovals)
268
+ .where(eq(channelSettlementApprovals.id, id))
269
+ .returning({ id: channelSettlementApprovals.id });
270
+ return row ?? null;
271
+ },
272
+ };