@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 @@
1
+ {"version":3,"file":"schema-finance.d.ts","sourceRoot":"","sources":["../src/schema-finance.ts"],"names":[],"mappings":"AAoBA,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA8BjC,CAAA;AAED,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAmClC,CAAA;AAED,eAAO,MAAM,yBAAyB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA2BrC,CAAA;AAED,eAAO,MAAM,0BAA0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAuCtC,CAAA;AAED,eAAO,MAAM,2BAA2B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAqCvC,CAAA;AAED,eAAO,MAAM,0BAA0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAuBtC,CAAA;AAED,MAAM,MAAM,oBAAoB,GAAG,OAAO,qBAAqB,CAAC,YAAY,CAAA;AAC5E,MAAM,MAAM,uBAAuB,GAAG,OAAO,qBAAqB,CAAC,YAAY,CAAA;AAC/E,MAAM,MAAM,qBAAqB,GAAG,OAAO,sBAAsB,CAAC,YAAY,CAAA;AAC9E,MAAM,MAAM,wBAAwB,GAAG,OAAO,sBAAsB,CAAC,YAAY,CAAA;AACjF,MAAM,MAAM,wBAAwB,GAAG,OAAO,yBAAyB,CAAC,YAAY,CAAA;AACpF,MAAM,MAAM,2BAA2B,GAAG,OAAO,yBAAyB,CAAC,YAAY,CAAA;AACvF,MAAM,MAAM,yBAAyB,GAAG,OAAO,0BAA0B,CAAC,YAAY,CAAA;AACtF,MAAM,MAAM,4BAA4B,GAAG,OAAO,0BAA0B,CAAC,YAAY,CAAA;AACzF,MAAM,MAAM,0BAA0B,GAAG,OAAO,2BAA2B,CAAC,YAAY,CAAA;AACxF,MAAM,MAAM,6BAA6B,GAAG,OAAO,2BAA2B,CAAC,YAAY,CAAA;AAC3F,MAAM,MAAM,yBAAyB,GAAG,OAAO,0BAA0B,CAAC,YAAY,CAAA;AACtF,MAAM,MAAM,4BAA4B,GAAG,OAAO,0BAA0B,CAAC,YAAY,CAAA"}
@@ -0,0 +1,153 @@
1
+ import { typeId, typeIdRef } from "@voyant-travel/db/lib/typeid-column";
2
+ import { date, index, integer, jsonb, pgTable, text, timestamp } from "drizzle-orm/pg-core";
3
+ import { channelBookingLinks, channelCommissionRules, channelContracts, channels, } from "./schema-core.js";
4
+ import { channelReconciliationIssueTypeEnum, channelReconciliationResolutionStatusEnum, channelReconciliationRunStatusEnum, channelReconciliationSeverityEnum, channelRemittanceExceptionStatusEnum, channelSettlementApprovalStatusEnum, channelSettlementItemStatusEnum, channelSettlementRunStatusEnum, } from "./schema-shared.js";
5
+ export const channelSettlementRuns = pgTable("channel_settlement_runs", {
6
+ id: typeId("channel_settlement_runs"),
7
+ channelId: typeIdRef("channel_id")
8
+ .notNull()
9
+ .references(() => channels.id, { onDelete: "cascade" }),
10
+ contractId: typeIdRef("contract_id").references(() => channelContracts.id, {
11
+ onDelete: "set null",
12
+ }),
13
+ status: channelSettlementRunStatusEnum("status").notNull().default("draft"),
14
+ currencyCode: text("currency_code"),
15
+ periodStart: date("period_start"),
16
+ periodEnd: date("period_end"),
17
+ statementReference: text("statement_reference"),
18
+ generatedAt: timestamp("generated_at", { withTimezone: true }),
19
+ postedAt: timestamp("posted_at", { withTimezone: true }),
20
+ paidAt: timestamp("paid_at", { withTimezone: true }),
21
+ notes: text("notes"),
22
+ metadata: jsonb("metadata").$type(),
23
+ createdAt: timestamp("created_at", { withTimezone: true }).notNull().defaultNow(),
24
+ updatedAt: timestamp("updated_at", { withTimezone: true }).notNull().defaultNow(),
25
+ }, (table) => [
26
+ index("idx_channel_settlement_runs_updated").on(table.updatedAt),
27
+ index("idx_channel_settlement_runs_channel_updated").on(table.channelId, table.updatedAt),
28
+ index("idx_channel_settlement_runs_contract_updated").on(table.contractId, table.updatedAt),
29
+ index("idx_channel_settlement_runs_status_updated").on(table.status, table.updatedAt),
30
+ index("idx_channel_settlement_runs_period").on(table.periodStart, table.periodEnd),
31
+ ]);
32
+ export const channelSettlementItems = pgTable("channel_settlement_items", {
33
+ id: typeId("channel_settlement_items"),
34
+ settlementRunId: typeIdRef("settlement_run_id")
35
+ .notNull()
36
+ .references(() => channelSettlementRuns.id, { onDelete: "cascade" }),
37
+ bookingLinkId: typeIdRef("booking_link_id").references(() => channelBookingLinks.id, {
38
+ onDelete: "set null",
39
+ }),
40
+ bookingId: text("booking_id"),
41
+ commissionRuleId: typeIdRef("commission_rule_id").references(() => channelCommissionRules.id, {
42
+ onDelete: "set null",
43
+ }),
44
+ status: channelSettlementItemStatusEnum("status").notNull().default("pending"),
45
+ grossAmountCents: integer("gross_amount_cents").notNull().default(0),
46
+ commissionAmountCents: integer("commission_amount_cents").notNull().default(0),
47
+ netRemittanceAmountCents: integer("net_remittance_amount_cents").notNull().default(0),
48
+ currencyCode: text("currency_code"),
49
+ remittanceDueAt: timestamp("remittance_due_at", { withTimezone: true }),
50
+ paidAt: timestamp("paid_at", { withTimezone: true }),
51
+ notes: text("notes"),
52
+ createdAt: timestamp("created_at", { withTimezone: true }).notNull().defaultNow(),
53
+ updatedAt: timestamp("updated_at", { withTimezone: true }).notNull().defaultNow(),
54
+ }, (table) => [
55
+ index("idx_channel_settlement_items_updated").on(table.updatedAt),
56
+ index("idx_channel_settlement_items_run_updated").on(table.settlementRunId, table.updatedAt),
57
+ index("idx_channel_settlement_items_booking_link_updated").on(table.bookingLinkId, table.updatedAt),
58
+ index("idx_channel_settlement_items_booking_updated").on(table.bookingId, table.updatedAt),
59
+ index("idx_channel_settlement_items_status_updated").on(table.status, table.updatedAt),
60
+ ]);
61
+ export const channelReconciliationRuns = pgTable("channel_reconciliation_runs", {
62
+ id: typeId("channel_reconciliation_runs"),
63
+ channelId: typeIdRef("channel_id")
64
+ .notNull()
65
+ .references(() => channels.id, { onDelete: "cascade" }),
66
+ contractId: typeIdRef("contract_id").references(() => channelContracts.id, {
67
+ onDelete: "set null",
68
+ }),
69
+ status: channelReconciliationRunStatusEnum("status").notNull().default("draft"),
70
+ periodStart: date("period_start"),
71
+ periodEnd: date("period_end"),
72
+ externalReportReference: text("external_report_reference"),
73
+ startedAt: timestamp("started_at", { withTimezone: true }),
74
+ completedAt: timestamp("completed_at", { withTimezone: true }),
75
+ notes: text("notes"),
76
+ metadata: jsonb("metadata").$type(),
77
+ createdAt: timestamp("created_at", { withTimezone: true }).notNull().defaultNow(),
78
+ updatedAt: timestamp("updated_at", { withTimezone: true }).notNull().defaultNow(),
79
+ }, (table) => [
80
+ index("idx_channel_reconciliation_runs_updated").on(table.updatedAt),
81
+ index("idx_channel_reconciliation_runs_channel_updated").on(table.channelId, table.updatedAt),
82
+ index("idx_channel_reconciliation_runs_contract_updated").on(table.contractId, table.updatedAt),
83
+ index("idx_channel_reconciliation_runs_status_updated").on(table.status, table.updatedAt),
84
+ ]);
85
+ export const channelReconciliationItems = pgTable("channel_reconciliation_items", {
86
+ id: typeId("channel_reconciliation_items"),
87
+ reconciliationRunId: typeIdRef("reconciliation_run_id")
88
+ .notNull()
89
+ .references(() => channelReconciliationRuns.id, { onDelete: "cascade" }),
90
+ bookingLinkId: typeIdRef("booking_link_id").references(() => channelBookingLinks.id, {
91
+ onDelete: "set null",
92
+ }),
93
+ bookingId: text("booking_id"),
94
+ externalBookingId: text("external_booking_id"),
95
+ issueType: channelReconciliationIssueTypeEnum("issue_type").notNull().default("other"),
96
+ severity: channelReconciliationSeverityEnum("severity").notNull().default("warning"),
97
+ resolutionStatus: channelReconciliationResolutionStatusEnum("resolution_status")
98
+ .notNull()
99
+ .default("open"),
100
+ notes: text("notes"),
101
+ resolvedAt: timestamp("resolved_at", { withTimezone: true }),
102
+ createdAt: timestamp("created_at", { withTimezone: true }).notNull().defaultNow(),
103
+ updatedAt: timestamp("updated_at", { withTimezone: true }).notNull().defaultNow(),
104
+ }, (table) => [
105
+ index("idx_channel_reconciliation_items_updated").on(table.updatedAt),
106
+ index("idx_channel_reconciliation_items_run_updated").on(table.reconciliationRunId, table.updatedAt),
107
+ index("idx_channel_reconciliation_items_booking_link_updated").on(table.bookingLinkId, table.updatedAt),
108
+ index("idx_channel_reconciliation_items_booking_updated").on(table.bookingId, table.updatedAt),
109
+ index("idx_channel_reconciliation_items_issue_updated").on(table.issueType, table.updatedAt),
110
+ index("idx_channel_reconciliation_items_resolution_updated").on(table.resolutionStatus, table.updatedAt),
111
+ ]);
112
+ export const channelRemittanceExceptions = pgTable("channel_remittance_exceptions", {
113
+ id: typeId("channel_remittance_exceptions"),
114
+ channelId: typeIdRef("channel_id")
115
+ .notNull()
116
+ .references(() => channels.id, { onDelete: "cascade" }),
117
+ settlementItemId: typeIdRef("settlement_item_id").references(() => channelSettlementItems.id, {
118
+ onDelete: "set null",
119
+ }),
120
+ reconciliationItemId: typeIdRef("reconciliation_item_id").references(() => channelReconciliationItems.id, { onDelete: "set null" }),
121
+ exceptionType: text("exception_type").notNull(),
122
+ severity: channelReconciliationSeverityEnum("severity").notNull().default("warning"),
123
+ status: channelRemittanceExceptionStatusEnum("status").notNull().default("open"),
124
+ openedAt: timestamp("opened_at", { withTimezone: true }).notNull().defaultNow(),
125
+ resolvedAt: timestamp("resolved_at", { withTimezone: true }),
126
+ notes: text("notes"),
127
+ metadata: jsonb("metadata").$type(),
128
+ createdAt: timestamp("created_at", { withTimezone: true }).notNull().defaultNow(),
129
+ updatedAt: timestamp("updated_at", { withTimezone: true }).notNull().defaultNow(),
130
+ }, (table) => [
131
+ index("idx_channel_remittance_exceptions_updated").on(table.updatedAt),
132
+ index("idx_channel_remittance_exceptions_channel_updated").on(table.channelId, table.updatedAt),
133
+ index("idx_channel_remittance_exceptions_settlement_item_updated").on(table.settlementItemId, table.updatedAt),
134
+ index("idx_channel_remittance_exceptions_reconciliation_item_updated").on(table.reconciliationItemId, table.updatedAt),
135
+ index("idx_channel_remittance_exceptions_status_updated").on(table.status, table.updatedAt),
136
+ ]);
137
+ export const channelSettlementApprovals = pgTable("channel_settlement_approvals", {
138
+ id: typeId("channel_settlement_approvals"),
139
+ settlementRunId: typeIdRef("settlement_run_id")
140
+ .notNull()
141
+ .references(() => channelSettlementRuns.id, { onDelete: "cascade" }),
142
+ approverUserId: text("approver_user_id"),
143
+ status: channelSettlementApprovalStatusEnum("status").notNull().default("pending"),
144
+ decidedAt: timestamp("decided_at", { withTimezone: true }),
145
+ notes: text("notes"),
146
+ metadata: jsonb("metadata").$type(),
147
+ createdAt: timestamp("created_at", { withTimezone: true }).notNull().defaultNow(),
148
+ updatedAt: timestamp("updated_at", { withTimezone: true }).notNull().defaultNow(),
149
+ }, (table) => [
150
+ index("idx_channel_settlement_approvals_updated").on(table.updatedAt),
151
+ index("idx_channel_settlement_approvals_run_updated").on(table.settlementRunId, table.updatedAt),
152
+ index("idx_channel_settlement_approvals_status_updated").on(table.status, table.updatedAt),
153
+ ]);