@dalmore/api-contracts 1.0.5 → 1.0.6

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 (137) hide show
  1. package/package.json +4 -5
  2. package/src/common/types/account-contact.types.ts +98 -0
  3. package/src/common/types/account-detail.types.ts +27 -0
  4. package/src/common/types/account-integration.types.ts +143 -0
  5. package/src/common/types/account-manager.types.ts +124 -0
  6. package/src/common/types/account.types.ts +296 -0
  7. package/src/common/types/activity.types.ts +274 -0
  8. package/src/common/types/address.spec.ts +203 -0
  9. package/src/common/types/address.types.ts +41 -0
  10. package/src/common/types/aic.types.ts +246 -0
  11. package/src/common/types/aml.types.ts +18 -0
  12. package/src/common/types/api-key-logs.types.ts +66 -0
  13. package/src/common/types/api-keys.types.ts +69 -0
  14. package/src/common/types/asset.types.ts +338 -0
  15. package/src/common/types/auth.types.ts +370 -0
  16. package/src/common/types/batch-jobs.types.ts +151 -0
  17. package/src/common/types/bonus-tier.types.ts +147 -0
  18. package/src/common/types/cart.types.ts +18 -0
  19. package/src/common/types/checklist-items.types.ts +70 -0
  20. package/src/common/types/checklist.types.ts +97 -0
  21. package/src/common/types/common.types.spec.ts +336 -0
  22. package/src/common/types/common.types.ts +1520 -0
  23. package/src/common/types/comply-advantage-api.types.ts +316 -0
  24. package/src/common/types/comply-advantage.types.ts +25 -0
  25. package/src/common/types/contact-us.types.ts +107 -0
  26. package/src/common/types/contract-helpers.ts +205 -0
  27. package/src/common/types/countries.types.ts +375 -0
  28. package/src/common/types/covered-person.types.ts +274 -0
  29. package/src/common/types/dashboard.types.ts +799 -0
  30. package/src/common/types/data-record.types.ts +325 -0
  31. package/src/common/types/data-room.types.ts +242 -0
  32. package/src/common/types/default-theme-config.types.ts +87 -0
  33. package/src/common/types/disbursement-adjustment.types.ts +32 -0
  34. package/src/common/types/disbursement-approval-user.types.ts +100 -0
  35. package/src/common/types/disbursement-review.types.ts +110 -0
  36. package/src/common/types/disbursement-transaction.types.ts +72 -0
  37. package/src/common/types/disbursements.types.ts +310 -0
  38. package/src/common/types/domain-filter.types.ts +55 -0
  39. package/src/common/types/email-theme.types.ts +442 -0
  40. package/src/common/types/entity.types.ts +15 -0
  41. package/src/common/types/error-responses.types.ts +135 -0
  42. package/src/common/types/escrow-account.types.ts +104 -0
  43. package/src/common/types/exchange-api-key.types.ts +121 -0
  44. package/src/common/types/exchange-import.types.ts +36 -0
  45. package/src/common/types/exchange-provider.types.ts +329 -0
  46. package/src/common/types/file.types.ts +461 -0
  47. package/src/common/types/files.types.spec.ts +154 -0
  48. package/src/common/types/health.types.ts +29 -0
  49. package/src/common/types/index.ts +48 -0
  50. package/src/common/types/individuals.types.ts +554 -0
  51. package/src/common/types/investor-account.types.ts +1239 -0
  52. package/src/common/types/investorAccountIdSchema.type.ts +0 -0
  53. package/src/common/types/investors-offering.types.ts +65 -0
  54. package/src/common/types/invite.types.ts +133 -0
  55. package/src/common/types/issuer-bank-account.types.ts +107 -0
  56. package/src/common/types/issuer-offering.types.ts +306 -0
  57. package/src/common/types/issuer-payment-method.types.spec.ts +612 -0
  58. package/src/common/types/issuer-payment-method.types.ts +341 -0
  59. package/src/common/types/issuer.types.ts +312 -0
  60. package/src/common/types/job-item.types.ts +119 -0
  61. package/src/common/types/jobs.types.ts +171 -0
  62. package/src/common/types/kyb.types.ts +53 -0
  63. package/src/common/types/kyc.types.ts +188 -0
  64. package/src/common/types/legal-entity.types.ts +185 -0
  65. package/src/common/types/login-history.types.ts +46 -0
  66. package/src/common/types/mail-template.types.ts +436 -0
  67. package/src/common/types/north-cap-integration.types.ts +190 -0
  68. package/src/common/types/note.types.ts +109 -0
  69. package/src/common/types/notification.types.ts +58 -0
  70. package/src/common/types/notion-api.types.ts +374 -0
  71. package/src/common/types/notion-database.types.ts +125 -0
  72. package/src/common/types/notion-page.types.ts +267 -0
  73. package/src/common/types/offering-reports.types.ts +153 -0
  74. package/src/common/types/offering-submission.types.ts +314 -0
  75. package/src/common/types/offering.types.spec.ts +91 -0
  76. package/src/common/types/offering.types.ts +590 -0
  77. package/src/common/types/page-revision.types.ts +86 -0
  78. package/src/common/types/page.types.ts +436 -0
  79. package/src/common/types/password.type.ts +15 -0
  80. package/src/common/types/payment-methods.types.ts +298 -0
  81. package/src/common/types/phone.spec.ts +76 -0
  82. package/src/common/types/phone.type.ts +27 -0
  83. package/src/common/types/portfolio.types.ts +50 -0
  84. package/src/common/types/privacy-policy-and-tos.types.ts +231 -0
  85. package/src/common/types/queue.types.ts +112 -0
  86. package/src/common/types/registered-reps.types.ts +25 -0
  87. package/src/common/types/rejection-reasons.types.ts +56 -0
  88. package/src/common/types/reminder-config.types.ts +40 -0
  89. package/src/common/types/review.types.ts +133 -0
  90. package/src/common/types/role.types.ts +26 -0
  91. package/src/common/types/secondary-customer.types.ts +66 -0
  92. package/src/common/types/secondary-issuer.types.ts +50 -0
  93. package/src/common/types/secondary-order.types.ts +58 -0
  94. package/src/common/types/secondary-security.types.ts +60 -0
  95. package/src/common/types/secondary-trade.entity.ts +16 -0
  96. package/src/common/types/secondary-trade.types.ts +95 -0
  97. package/src/common/types/secure-request.types.ts +68 -0
  98. package/src/common/types/signer.types.ts +651 -0
  99. package/src/common/types/site-link.types.spec.ts +134 -0
  100. package/src/common/types/site-link.types.ts +166 -0
  101. package/src/common/types/site-settings.types.ts +726 -0
  102. package/src/common/types/site.types.ts +270 -0
  103. package/src/common/types/sms.types.ts +30 -0
  104. package/src/common/types/state-machine.types.ts +177 -0
  105. package/src/common/types/states.types.ts +163 -0
  106. package/src/common/types/subdoc-preview.types.ts +35 -0
  107. package/src/common/types/task.types.ts +258 -0
  108. package/src/common/types/trade-adjustment.type.ts +33 -0
  109. package/src/common/types/trade-line-item.type.ts +132 -0
  110. package/src/common/types/trade.types.ts +929 -0
  111. package/src/common/types/transaction.types.ts +198 -0
  112. package/src/common/types/trusted-contact.types.ts +122 -0
  113. package/src/common/types/typography.types.ts +75 -0
  114. package/src/common/types/user-manual.types.ts +290 -0
  115. package/src/common/types/user-setting.types.ts +133 -0
  116. package/src/common/types/user.types.ts +320 -0
  117. package/src/common/types/webhook.types.ts +588 -0
  118. package/src/common/types/zip.type.ts +36 -0
  119. package/src/contracts/clients/accounts/index.ts +61 -0
  120. package/src/contracts/clients/aic/index.ts +59 -0
  121. package/src/contracts/clients/api-key-logs/index.ts +53 -0
  122. package/src/contracts/clients/api-keys/index.ts +73 -0
  123. package/src/contracts/clients/assets/index.ts +102 -0
  124. package/src/contracts/clients/auth/index.ts +50 -0
  125. package/src/contracts/clients/files/index.ts +166 -0
  126. package/src/contracts/clients/files-public/index.ts +166 -0
  127. package/src/contracts/clients/index.ts +44 -0
  128. package/src/contracts/clients/individuals/index.ts +93 -0
  129. package/src/contracts/clients/investor-accounts/index.ts +93 -0
  130. package/src/contracts/clients/issuers/index.ts +94 -0
  131. package/src/contracts/clients/legal-entities/index.ts +93 -0
  132. package/src/contracts/clients/offerings/index.ts +117 -0
  133. package/src/contracts/clients/secure-requests/index.ts +34 -0
  134. package/src/contracts/clients/sites/index.ts +56 -0
  135. package/src/contracts/clients/trades/index.ts +122 -0
  136. package/index.d.mts +0 -17
  137. package/index.d.ts +0 -17
@@ -0,0 +1,590 @@
1
+ import { extendZodWithOpenApi } from '@anatine/zod-openapi';
2
+ import { TypeID } from 'typeid-js';
3
+ import { z } from 'zod';
4
+ import { accountIdSchema } from './account.types';
5
+ import {
6
+ AccountZod,
7
+ ComplianceReview,
8
+ dateSchema,
9
+ IPaginationMeta,
10
+ OfferingType,
11
+ ManagedByType,
12
+ PaginationOptionsZod,
13
+ UrlSchema,
14
+ SortOrder,
15
+ SortBy,
16
+ OfferingVersioningType,
17
+ OfferingOnboardingStatus,
18
+ } from './common.types';
19
+ import { IBaseEntity } from './entity.types';
20
+ import { fileIdSchema, FileZod } from './file.types';
21
+ import { IIssuer, issuerIdSchema } from './issuer.types';
22
+ import {
23
+ InvestorsOfferingFiltersZod,
24
+ InvestorsOfferingsIncludeQuery,
25
+ } from './investors-offering.types';
26
+ import { OfferingStatus } from './issuer-offering.types';
27
+
28
+ export enum OfferingFeeType {
29
+ FIXED = 'FIXED',
30
+ PERCENTAGE = 'PERCENTAGE',
31
+ }
32
+
33
+ extendZodWithOpenApi(z);
34
+
35
+ export const offeringIdSchema = z.string().refine(
36
+ (value) => {
37
+ try {
38
+ const tid = TypeID.fromString(value);
39
+ return tid.getType() === 'offering';
40
+ } catch {
41
+ return false;
42
+ }
43
+ },
44
+ {
45
+ message: `Invalid offering ID format. Must be a valid TypeID with "offering" prefix. Example: offering_01j5y5ghx5fg68d663j1fvy2x7`,
46
+ },
47
+ );
48
+ export const offeringRevisionIdSchema = z.string().refine(
49
+ (value) => {
50
+ try {
51
+ const tid = TypeID.fromString(value);
52
+ return tid.getType() === 'offering_revision';
53
+ } catch {
54
+ return false;
55
+ }
56
+ },
57
+ {
58
+ message: `Invalid offering revision ID format. Must be a valid TypeID with "offering_revision" prefix. Example: offering_revision_01j5y5ghx5fg68d663j1fvy2x7`,
59
+ },
60
+ );
61
+
62
+ export const OfferingPlatformSettings = z.object({
63
+ backOfficePortal: z.string(),
64
+ username: z.string().nullable(),
65
+ password: z.string().nullable(),
66
+ apiKey: z.string().nullable(),
67
+ });
68
+ export type OfferingPlatformSettings = z.infer<typeof OfferingPlatformSettings>;
69
+
70
+ export const IOffering = IBaseEntity.extend({
71
+ name: z.string(),
72
+ tid: z.string().nullable(),
73
+ type: z.nativeEnum(OfferingType).nullable(),
74
+ description: z.string().nullable(),
75
+ raiseAmount: z.number().nullable(),
76
+ targetAmount: z.number().nullable(),
77
+ minInvestment: z.number().nullable(),
78
+ maxInvestment: z.number().nullable(),
79
+ contingencyAmount: z.number().nullable(),
80
+ startAt: z.date().nullable(),
81
+ endAt: z.date().nullable(),
82
+ platform: z.string(),
83
+ platformSettings: z.string().nullable(),
84
+ enabled: z.boolean(),
85
+ accountId: z.string().nullable(),
86
+ account: AccountZod.optional().nullable(),
87
+ issuer: z
88
+ .lazy(() => IIssuer)
89
+ .optional()
90
+ .nullable(), // Use z.lazy here
91
+ issuerId: z.string().nullable(),
92
+ coverArtId: z
93
+ .lazy(() => fileIdSchema)
94
+ .nullable()
95
+ .optional(),
96
+ coverArt: z.lazy(() => FileZod).nullable(),
97
+ cancellationPeriod: z.number().nullable(),
98
+ memorandumId: z
99
+ .lazy(() => fileIdSchema)
100
+ .nullable()
101
+ .optional(),
102
+ subscriptionAgreementId: z
103
+ .lazy(() => fileIdSchema)
104
+ .nullable()
105
+ .optional(),
106
+ managedBy: z.nativeEnum(ManagedByType).nullable(),
107
+ valuationCap: z.number().nullable(),
108
+ showTotalRaised: z.boolean().optional(),
109
+ });
110
+ export type IOffering = z.infer<typeof IOffering>;
111
+
112
+ export const IPaginatedOffering = z.object({
113
+ items: z.array(IOffering),
114
+ meta: IPaginationMeta,
115
+ });
116
+ export type IPaginatedOffering = z.infer<typeof IPaginatedOffering>;
117
+
118
+ export const PatchOffering = z.object({
119
+ name: z.string().optional(),
120
+ description: z.string().nullable().optional(),
121
+ tid: z.string().optional(),
122
+ type: z.nativeEnum(OfferingType).optional(),
123
+ targetAmount: z.number().min(0.01).max(10000000000).optional(),
124
+ raiseAmount: z
125
+ .number()
126
+ .min(0.01)
127
+ .max(10000000000)
128
+ .openapi({ example: 5000 })
129
+ .optional(),
130
+ minInvestment: z
131
+ .number()
132
+ .min(0.01)
133
+ .max(10000000000)
134
+ .openapi({ example: 5000 })
135
+ .optional()
136
+ .nullable(),
137
+ maxInvestment: z
138
+ .number()
139
+ .min(0.01)
140
+ .max(10000000000)
141
+ .openapi({ example: 5000 })
142
+ .optional()
143
+ .nullable(),
144
+ contingencyAmount: z
145
+ .number()
146
+ .min(0.0)
147
+ .max(10000000000)
148
+ .openapi({ example: 5000 })
149
+ .optional()
150
+ .nullable(),
151
+ startAt: dateSchema.optional(),
152
+ endAt: dateSchema.optional(),
153
+ platform: z.string().optional(),
154
+ coverArtId: z
155
+ .lazy(() => fileIdSchema)
156
+ .nullable()
157
+ .optional(),
158
+ platformSettings: OfferingPlatformSettings.optional().transform((val) =>
159
+ val ? JSON.stringify(val) : null,
160
+ ),
161
+ enabled: z.boolean().optional(),
162
+ entitySubscriptionAgreementTemplateId: z.string().optional().nullable(),
163
+ managedBy: z.nativeEnum(ManagedByType).optional(),
164
+ subscriptionAgreementTemplateId: z.string().optional().nullable(),
165
+ memorandumId: z
166
+ .lazy(() => fileIdSchema)
167
+ .nullable()
168
+ .optional(),
169
+ subscriptionAgreementId: z
170
+ .lazy(() => fileIdSchema)
171
+ .nullable()
172
+ .optional(),
173
+ jointSubscriptionAgreementTemplateId: z.string().optional().nullable(),
174
+ cancellationPeriod: z.number().min(2).max(5).optional().nullable(),
175
+ showTotalRaised: z.boolean().optional(),
176
+ issuerId: issuerIdSchema.optional(),
177
+ });
178
+
179
+ export type PatchOffering = z.infer<typeof PatchOffering>;
180
+
181
+ export const PostComplianceOffering = PatchOffering.merge(
182
+ z.object({
183
+ accountId: accountIdSchema,
184
+ }),
185
+ ).extend({
186
+ managedBy: z.nativeEnum(ManagedByType).optional(),
187
+ });
188
+ export type PostComplianceOffering = z.infer<typeof PostComplianceOffering>;
189
+
190
+ export const offeringsInclude = z.enum([
191
+ 'account',
192
+ 'issuer',
193
+ 'trades',
194
+ 'assets',
195
+ 'disbursements',
196
+ 'draftVersion',
197
+ 'publishedVersion',
198
+ 'revisions',
199
+ 'onboardingReviewedBy',
200
+ ]);
201
+
202
+ /**
203
+ * @description Query parameters for including related entities
204
+ * @xample in contract us as -> query: z.object({}).merge(UsersIncludeQuery),
205
+ */
206
+ export const OfferingsIncludeQuery = z.object({
207
+ include: z
208
+ .string()
209
+ .optional()
210
+ .transform((str) => (str ? str.split(',') : []))
211
+ .refine(
212
+ (includes) =>
213
+ includes.every((include) =>
214
+ offeringsInclude.options.includes(include as any),
215
+ ),
216
+ {
217
+ message: `Invalid include option provided. Valid options are: ${offeringsInclude.options.join(',')}`,
218
+ },
219
+ )
220
+ .openapi({
221
+ example: `${offeringsInclude.options.join(',')}`,
222
+ }),
223
+ });
224
+
225
+ export interface OfferingsIncludeQuery
226
+ extends z.infer<typeof OfferingsIncludeQuery> {}
227
+
228
+ /**
229
+ * @description
230
+ * Filters for querying offerings.
231
+ *
232
+ * The "combinedStatus" filter provides a unified status that combines three separate fields:
233
+ * - complianceReview: The compliance review status of the offering
234
+ * - onboardingStatus: The onboarding completion status
235
+ * - enabled: Whether the offering is currently enabled/active
236
+ *
237
+ * The combinedStatus is calculated using the following priority rules:
238
+ * 1. If onboardingStatus is "IN_REVIEW" → combinedStatus = "ONBOARDING"
239
+ * 2. Else if complianceReview is not "APPROVED" → combinedStatus = "IN_COMPLIANCE_REVIEW"
240
+ * 3. Else if onboardingStatus is "COMPLETE" and complianceReview is "APPROVED" →
241
+ * - If enabled is true → combinedStatus = "ACTIVE"
242
+ * - If enabled is false → combinedStatus = "PAUSED"
243
+ *
244
+ * This allows for filtering offerings by a single summary state that reflects the overall user-facing status,
245
+ * rather than requiring separate filters for each individual field.
246
+ */
247
+ export const OfferingFiltersZod = z.object({
248
+ issuerName: z.string().optional(),
249
+ name: z.string().optional(),
250
+ accountId: accountIdSchema.optional(),
251
+ issuerId: z.lazy(() => issuerIdSchema).optional(),
252
+ type: z.nativeEnum(OfferingType).optional(),
253
+ status: z.nativeEnum(ComplianceReview).optional(),
254
+ enabled: z.preprocess(
255
+ (val) =>
256
+ val === 'true' || val === '1'
257
+ ? true
258
+ : val === 'false' || val === '0'
259
+ ? false
260
+ : val,
261
+ z.boolean().optional(),
262
+ ),
263
+ managedBy: z.nativeEnum(ManagedByType).optional(),
264
+ versioningType: z.nativeEnum(OfferingVersioningType).optional(),
265
+ combinedStatus: z.nativeEnum(OfferingStatus).optional(),
266
+ onboardingStatus: z.nativeEnum(OfferingOnboardingStatus).optional(),
267
+ });
268
+ export type OfferingFiltersZod = z.infer<typeof OfferingFiltersZod>;
269
+
270
+ export const OfferingSortZod = z.object({
271
+ sort: z.enum([SortBy.NAME, SortBy.CREATED_AT, SortBy.UPDATED_AT]).optional(),
272
+ dir: z.nativeEnum(SortOrder).optional(),
273
+ });
274
+ export type OfferingSortZod = z.infer<typeof OfferingSortZod>;
275
+
276
+ export const OfferingSummaryFiltersZod = z.object({
277
+ accountId: accountIdSchema.optional(),
278
+ hasPendingTrades: z.coerce.boolean().optional(),
279
+ });
280
+ export type OfferingSummaryFiltersZod = z.infer<
281
+ typeof OfferingSummaryFiltersZod
282
+ >;
283
+
284
+ export const OfferingSummaryResponseZod = z.object({
285
+ id: offeringIdSchema,
286
+ name: z.string(),
287
+ account: z.object({ id: accountIdSchema, name: z.string() }),
288
+ trades: z.object({
289
+ total: z.number(),
290
+ tradeReview: z.number(),
291
+ readyForDisbursement: z.number(),
292
+ }),
293
+ });
294
+ export type OfferingSummaryResponse = z.infer<
295
+ typeof OfferingSummaryResponseZod
296
+ >;
297
+
298
+ export const PaginatedOfferingSummaryResponseZod = z.object({
299
+ items: z.array(OfferingSummaryResponseZod),
300
+ meta: IPaginationMeta,
301
+ });
302
+ export type PaginatedOfferingSummaryResponse = z.infer<
303
+ typeof PaginatedOfferingSummaryResponseZod
304
+ >;
305
+
306
+ const BaseOfferingSettings = z.object({
307
+ settingsBrokerageFeeValue: z.number().nonnegative().nullable().optional(),
308
+ settingsBrokerageFeeType: z.nativeEnum(OfferingFeeType).nullable().optional(),
309
+ settingsCardFeeValue: z.number().nonnegative().nullable().optional(),
310
+ settingsCardFeeType: z.nativeEnum(OfferingFeeType).nullable().optional(),
311
+ settingsDisbursementFeeValue: z.number().nonnegative().nullable().optional(),
312
+ settingsDisbursementFeeType: z
313
+ .nativeEnum(OfferingFeeType)
314
+ .nullable()
315
+ .optional(),
316
+ settingsRefundPoolFeeValue: z.number().nonnegative().nullable().optional(),
317
+ settingsRefundPoolFeeType: z
318
+ .nativeEnum(OfferingFeeType)
319
+ .nullable()
320
+ .optional(),
321
+ serviceChargesType: z.nativeEnum(OfferingFeeType).nullable().optional(),
322
+ serviceCharges: z.number().nonnegative().nullable().optional(),
323
+ });
324
+
325
+ export const OfferingSettings = BaseOfferingSettings.refine(
326
+ (data) =>
327
+ (data.settingsBrokerageFeeType === null &&
328
+ data.settingsBrokerageFeeValue === null) ||
329
+ (data.settingsBrokerageFeeType !== null &&
330
+ data.settingsBrokerageFeeValue !== null),
331
+ {
332
+ message:
333
+ 'settingsBrokerageFeeType and settingsBrokerageFeeValue must both be either null or not-null',
334
+ },
335
+ )
336
+ .refine(
337
+ (data) =>
338
+ (data.serviceChargesType === null && data.serviceCharges === null) ||
339
+ (data.serviceChargesType !== null && data.serviceCharges !== null),
340
+ {
341
+ message:
342
+ 'serviceChargesType and serviceCharges must both be either null or not-null',
343
+ },
344
+ )
345
+ .refine(
346
+ (data) =>
347
+ (data.settingsCardFeeType === null &&
348
+ data.settingsCardFeeValue === null) ||
349
+ (data.settingsCardFeeType !== null && data.settingsCardFeeValue !== null),
350
+ {
351
+ message:
352
+ 'settingsCardFeeType and settingsCardFeeValue must both be either null or not-null',
353
+ },
354
+ )
355
+ .refine(
356
+ (data) =>
357
+ (data.settingsDisbursementFeeType === null &&
358
+ data.settingsDisbursementFeeValue === null) ||
359
+ (data.settingsDisbursementFeeType !== null &&
360
+ data.settingsDisbursementFeeValue !== null),
361
+ {
362
+ message:
363
+ 'settingsDisbursementFeeType and settingsDisbursementFeeValue must both be either null or not-null',
364
+ },
365
+ )
366
+ .refine(
367
+ (data) =>
368
+ (data.settingsRefundPoolFeeType === null &&
369
+ data.settingsRefundPoolFeeValue === null) ||
370
+ (data.settingsRefundPoolFeeType !== null &&
371
+ data.settingsRefundPoolFeeValue !== null),
372
+ {
373
+ message:
374
+ 'settingsRefundPoolFeeType and settingsRefundPoolFeeValue must both be either null or not-null',
375
+ },
376
+ )
377
+ .refine(
378
+ (data) =>
379
+ data.settingsBrokerageFeeType !== OfferingFeeType.PERCENTAGE ||
380
+ (data.settingsBrokerageFeeValue !== null &&
381
+ data.settingsBrokerageFeeValue! <= 100),
382
+ {
383
+ message: 'settingsBrokerageFeeValue must be less than or equal to 100',
384
+ },
385
+ )
386
+ .refine(
387
+ (data) =>
388
+ data.settingsRefundPoolFeeType !== OfferingFeeType.PERCENTAGE ||
389
+ (data.settingsRefundPoolFeeValue !== null &&
390
+ data.settingsRefundPoolFeeValue! <= 100),
391
+ {
392
+ message: 'settingsRefundPoolFeeValue must be less than or equal to 100',
393
+ },
394
+ )
395
+ .refine(
396
+ (data) =>
397
+ data.settingsCardFeeType !== OfferingFeeType.PERCENTAGE ||
398
+ (data.settingsCardFeeValue !== null && data.settingsCardFeeValue! <= 100),
399
+ {
400
+ message: 'settingsCardFeeValue must be less than or equal to 100',
401
+ },
402
+ )
403
+ .refine(
404
+ (data) =>
405
+ data.settingsDisbursementFeeType !== OfferingFeeType.PERCENTAGE ||
406
+ (data.settingsDisbursementFeeValue !== null &&
407
+ data.settingsDisbursementFeeValue! <= 100),
408
+ {
409
+ message: 'settingsDisbursementFeeValue must be less than 100',
410
+ },
411
+ );
412
+
413
+ export type OfferingSettings = z.infer<typeof OfferingSettings>;
414
+
415
+ export const PatchComplianceOffering = z
416
+ .intersection(PatchOffering, OfferingSettings)
417
+ .refine(
418
+ (data) => {
419
+ // Check if both values are present, and if so, ensure minInvestment is less than maxInvestment
420
+ if (data.minInvestment && data.maxInvestment) {
421
+ return data.minInvestment < data.maxInvestment;
422
+ }
423
+ return true; // If one or both values are undefined, skip this check
424
+ },
425
+ {
426
+ message: 'Minimum investment must be less than maximum investment.',
427
+ path: ['minInvestment'],
428
+ },
429
+ );
430
+ export type PatchComplianceOffering = z.infer<typeof PatchComplianceOffering>;
431
+
432
+ export const IComplianceOffering = z.intersection(IOffering, OfferingSettings);
433
+ export type IComplianceOffering = z.infer<typeof IComplianceOffering>;
434
+
435
+ export const IPaginatedComplianceOffering = z.object({
436
+ items: z.array(IComplianceOffering),
437
+ meta: IPaginationMeta,
438
+ });
439
+ export type IPaginatedComplianceOffering = z.infer<
440
+ typeof IPaginatedComplianceOffering
441
+ >;
442
+
443
+ export const ReviewOfferings = z.object({
444
+ complianceReview: z.enum([
445
+ ComplianceReview.APPROVED,
446
+ ComplianceReview.REJECTED,
447
+ ]),
448
+ offerings: z
449
+ .array(offeringIdSchema)
450
+ .min(1, 'At least one offering is required')
451
+ .max(50, 'Maximum of 50 offerings allowed')
452
+ .openapi({
453
+ example: [
454
+ 'offering_01jjsdrx1seqfse7z4z47sgdp5',
455
+ 'offering_01jjsdrx27enkszq5cnc3hdhrf',
456
+ ],
457
+ }),
458
+ });
459
+ export type ReviewOfferings = z.infer<typeof ReviewOfferings>;
460
+
461
+ export const OfferingDetailsResponseZod = z.object({
462
+ raisedAmount: z.number(),
463
+ investors: z.number().int(),
464
+ minInvestment: z.number(),
465
+ maxInvestment: z.number(),
466
+ valuationCap: z.number(),
467
+ targetAmount: z.number(),
468
+ });
469
+
470
+ export type OfferingDetailsResponseZod = z.infer<
471
+ typeof OfferingDetailsResponseZod
472
+ >;
473
+
474
+ export const OfferingsArrayQueryZod = z.object({
475
+ offerings: z
476
+ .string()
477
+ .optional()
478
+ .transform((val) => {
479
+ if (!val) return undefined;
480
+ return val.split(',').map((id) => id.trim());
481
+ })
482
+ .pipe(
483
+ z
484
+ .array(z.string())
485
+ .optional()
486
+ .refine(
487
+ (val) => {
488
+ if (!val) return true;
489
+ return val.every((id) => {
490
+ try {
491
+ const tid = TypeID.fromString(id);
492
+ return tid.getType() === 'offering';
493
+ } catch {
494
+ return false;
495
+ }
496
+ });
497
+ },
498
+ {
499
+ message:
500
+ 'Invalid offering IDs format. Must be a valid TypeID with "offering" prefix.',
501
+ },
502
+ ),
503
+ ),
504
+ });
505
+
506
+ export const OfferingRaiseAmountResponseZod = z.object({
507
+ offeringId: offeringIdSchema,
508
+ totalRaisedAmount: z.number(),
509
+ });
510
+ export type OfferingRaiseAmountResponseZod = z.infer<
511
+ typeof OfferingRaiseAmountResponseZod
512
+ >;
513
+
514
+ export const PublicOfferingFiltersZod = PaginationOptionsZod.merge(
515
+ InvestorsOfferingsIncludeQuery,
516
+ )
517
+ .merge(InvestorsOfferingFiltersZod)
518
+ .extend({
519
+ url: UrlSchema,
520
+ });
521
+
522
+ export type PublicOfferingFiltersZod = z.infer<typeof PublicOfferingFiltersZod>;
523
+
524
+ export const PendingOfferingSummaryResponseZod = z.object({
525
+ id: offeringIdSchema,
526
+ name: z.string(),
527
+ assets: z.number(),
528
+ issuerName: z.string(),
529
+ issuerId: z.string(),
530
+ accountName: z.string(),
531
+ accountId: z.string(),
532
+ targetAmount: z.number().nullable(),
533
+ startAt: z.date().nullable(),
534
+ offeringType: z.nativeEnum(OfferingType),
535
+ });
536
+ export type PendingOfferingSummaryResponse = z.infer<
537
+ typeof PendingOfferingSummaryResponseZod
538
+ >;
539
+
540
+ export const PaginatedPendingOfferingSummaryResponseZod = z.object({
541
+ items: z.array(PendingOfferingSummaryResponseZod),
542
+ meta: IPaginationMeta,
543
+ });
544
+ export type PaginatedPendingOfferingSummaryResponse = z.infer<
545
+ typeof PaginatedPendingOfferingSummaryResponseZod
546
+ >;
547
+
548
+ export type OfferingUpdateFields = {
549
+ platform?: string;
550
+ platformSettings?: string | null;
551
+ managedBy?: ManagedByType | null;
552
+ enabled?: boolean;
553
+ showTotalRaised?: boolean;
554
+ };
555
+
556
+ export const ReviewOfferingOnboarding = z.object({
557
+ onboardingStatus: z.nativeEnum(OfferingOnboardingStatus),
558
+ });
559
+ export type ReviewOfferingOnboarding = z.infer<typeof ReviewOfferingOnboarding>;
560
+
561
+ export const OnboardingOfferingSummaryZod = z.object({
562
+ accountId: accountIdSchema,
563
+ accountName: z.string(),
564
+ offeringName: z.string(),
565
+ offeringId: z.string(),
566
+ memorandumId: z.string().nullable(),
567
+ subscriptionAgreementId: z.string().nullable(),
568
+ subscriptionAgreementTemplateId: z.string().nullable(),
569
+ jointSubscriptionAgreementTemplateId: z.string().nullable(),
570
+ entitySubscriptionAgreementTemplateId: z.string().nullable(),
571
+ });
572
+ export type OnboardingOfferingSummaryZod = z.infer<
573
+ typeof OnboardingOfferingSummaryZod
574
+ >;
575
+
576
+ export const OnboardingOfferingSummaryFilterZod = z.object({
577
+ search: z.string().optional(),
578
+ offeringId: offeringIdSchema.optional(),
579
+ });
580
+ export type OnboardingOfferingSummaryFilterZod = z.infer<
581
+ typeof OnboardingOfferingSummaryFilterZod
582
+ >;
583
+
584
+ export const IPaginatedOnboardingOfferingSummaryResponse = z.object({
585
+ items: z.array(OnboardingOfferingSummaryZod),
586
+ meta: IPaginationMeta,
587
+ });
588
+ export type IPaginatedOnboardingOfferingSummaryResponse = z.infer<
589
+ typeof IPaginatedOnboardingOfferingSummaryResponse
590
+ >;
@@ -0,0 +1,86 @@
1
+ import { extendZodWithOpenApi } from '@anatine/zod-openapi';
2
+ import { TypeID } from 'typeid-js';
3
+ import { z } from 'zod';
4
+ import { IBaseEntity } from './entity.types';
5
+ import { ComplianceReview, IPaginationMeta } from './common.types';
6
+ import {} from './common.types';
7
+ import {} from './page.types';
8
+ import { FileZod, IPage } from '.';
9
+ extendZodWithOpenApi(z);
10
+ export enum PageRevisionApprovalStatus {
11
+ APPROVED = 'APPROVED',
12
+ REJECTED = 'REJECTED',
13
+ }
14
+ export const pageRevisionIdSchema = z.string().refine(
15
+ (value) => {
16
+ try {
17
+ const tid = TypeID.fromString(value);
18
+ return tid.getType() === 'page_revision';
19
+ } catch {
20
+ return false;
21
+ }
22
+ },
23
+ {
24
+ message:
25
+ 'Invalid page revision ID format. Must be a valid TypeID with "page_revision" prefix.',
26
+ },
27
+ );
28
+
29
+ const pageRevisionsInclude = z.enum(['page']);
30
+
31
+ export const PageRevisionsIncludeQuery = z.object({
32
+ include: z
33
+ .string()
34
+ .optional()
35
+ .transform((str) => (str ? str.split(',') : []))
36
+ .refine(
37
+ (includes) =>
38
+ includes.every((include) =>
39
+ pageRevisionsInclude.options.includes(include as any),
40
+ ),
41
+ {
42
+ message: `Invalid include option provided. Valid options are: ${pageRevisionsInclude.options.join(',')}`,
43
+ },
44
+ )
45
+ .openapi({
46
+ example: `${pageRevisionsInclude.options.join(',')}`,
47
+ }),
48
+ });
49
+
50
+ export const IPageRevision = IBaseEntity.extend({
51
+ id: pageRevisionIdSchema,
52
+ title: z.string().optional().nullable(),
53
+ author: z.string().nullable().optional(),
54
+ complianceReview: z.nativeEnum(ComplianceReview),
55
+ version: z.number().default(1),
56
+ body: z.string().optional().nullable(),
57
+ pageId: z.string(),
58
+ page: z.lazy(() => IPage.optional().nullable()),
59
+ tag: z.string().optional().nullable(),
60
+ coverArtId: z.string().optional().nullable(),
61
+ coverArt: z.lazy(() => FileZod).nullable(),
62
+ });
63
+
64
+ export type IPageRevision = z.infer<typeof IPageRevision>;
65
+
66
+ export const IPaginatedPageRevisions = z.object({
67
+ items: z.array(IPageRevision),
68
+ meta: IPaginationMeta,
69
+ });
70
+ export type IPaginatedPageRevisions = z.infer<typeof IPaginatedPageRevisions>;
71
+
72
+ export const GetPageRevisionsZod = z.object({
73
+ title: z
74
+ .string()
75
+ .min(2)
76
+ .max(50)
77
+ .optional()
78
+ .openapi({ example: 'News Title' }),
79
+ complianceReview: z
80
+ .nativeEnum(ComplianceReview)
81
+ .optional()
82
+ .openapi({ example: ComplianceReview.PENDING }),
83
+ author: z.string().min(2).max(50).optional().openapi({ example: 'Author' }),
84
+ tag: z.string().optional().openapi({ example: 'Tag' }),
85
+ });
86
+ export type GetPageRevisionsZod = z.infer<typeof GetPageRevisionsZod>;