@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,314 @@
1
+ import { z } from 'zod';
2
+ import { accountIdSchema } from './account.types';
3
+ import { assetIdSchema } from './asset.types';
4
+ import {
5
+ OfferingType,
6
+ CoveredPersonsStatus,
7
+ CoveredPersonsRoleType,
8
+ AssetType,
9
+ AccountZod,
10
+ DurationType,
11
+ ManagedByType,
12
+ SubmitIssuerOfferingError,
13
+ ErrorResponseZod,
14
+ numberFromStringOrNumber,
15
+ } from './common.types';
16
+ import { coveredPersonIdSchema } from './covered-person.types';
17
+ import { issuerIdSchema, IssuerTypes } from './issuer.types';
18
+ import { offeringIdSchema, offeringRevisionIdSchema } from './offering.types';
19
+ import { StateCode } from './states.types';
20
+ import { CountryCode } from './countries.types';
21
+
22
+ export const SubmitIssuerOfferingResponse = z.object({
23
+ valid: z.boolean(),
24
+ errors: z.array(SubmitIssuerOfferingError),
25
+ checks: z.object({
26
+ issuer: ErrorResponseZod,
27
+ offering: ErrorResponseZod,
28
+ assets: ErrorResponseZod,
29
+ }),
30
+ });
31
+ export type SubmitIssuerOfferingResponse = z.infer<
32
+ typeof SubmitIssuerOfferingResponse
33
+ >;
34
+ export const OfferingsReviewZod = z.object({
35
+ id: offeringIdSchema,
36
+ type: z.nativeEnum(OfferingType, {
37
+ message: 'Type field is required.',
38
+ }),
39
+ platform: z
40
+ .string({ message: 'Platform field is required.' })
41
+ .min(2, { message: 'Platform ID should have at least 2 characters.' })
42
+ .max(50, {
43
+ message: 'Platform ID can’t be longer than 50 characters.',
44
+ }),
45
+ enabled: z.boolean({
46
+ message: 'Enabled field is required.',
47
+ }),
48
+ accountId: accountIdSchema,
49
+ issuerId: issuerIdSchema,
50
+ managedBy: z
51
+ .nativeEnum(ManagedByType, {
52
+ message: 'Please choose a valid type for the offering.',
53
+ })
54
+ .nullable(),
55
+ });
56
+ export const OfferingsRevisionReviewZod = z.object({
57
+ id: offeringRevisionIdSchema, // Assuming this already validates the ID
58
+ name: z
59
+ .string({ message: 'Name field is required.' })
60
+ .min(2, { message: 'Name should have at least 2 characters.' })
61
+ .max(100, { message: 'Name can’t be longer than 100 characters.' }),
62
+ description: z
63
+ .string({ message: 'Description field is required.' })
64
+ .min(1, { message: 'Description should have at least 1 character.' })
65
+ .max(1000, {
66
+ message: 'Description can’t be longer than 1000 characters.',
67
+ })
68
+ .optional()
69
+ .nullable(),
70
+ tid: z
71
+ .string({ message: 'Please enter a tid if applicable.' })
72
+ .min(2, {
73
+ message: 'Tid should have at least 2 characters.',
74
+ })
75
+ .max(50, {
76
+ message: 'Tid can’t be longer than 50 characters.',
77
+ })
78
+ .optional()
79
+ .nullable(),
80
+
81
+ raiseAmount: numberFromStringOrNumber('RaiseAmount')
82
+ .pipe(
83
+ z
84
+ .number()
85
+ .min(0, { message: 'Raise amount must be at least 0.' })
86
+ .max(10000000000, {
87
+ message: 'Raise amount can’t exceed 10 billion.',
88
+ }),
89
+ )
90
+ .nullable()
91
+ .optional(),
92
+ targetAmount: numberFromStringOrNumber('TargetAmount').pipe(
93
+ z
94
+ .number()
95
+ .min(0.01, { message: 'Target amount must be at least 0.01.' })
96
+ .max(10000000000, {
97
+ message: 'Target amount can’t exceed 10 billion.',
98
+ }),
99
+ ),
100
+
101
+ minInvestment: numberFromStringOrNumber('MinInvestment')
102
+ .pipe(
103
+ z
104
+ .number()
105
+ .min(0, { message: 'Minimum investment must be at least 0.' })
106
+ .max(10000000000, {
107
+ message: 'Minimum investment can’t exceed 10 billion.',
108
+ }),
109
+ )
110
+ .nullable()
111
+ .optional(),
112
+ maxInvestment: numberFromStringOrNumber('MaxInvestment')
113
+ .pipe(
114
+ z
115
+ .number()
116
+ .min(0, { message: 'Maximum investment must be at least 0.' })
117
+ .max(10000000000, {
118
+ message: 'Maximum investment can’t exceed 10 billion.',
119
+ }),
120
+ )
121
+ .nullable()
122
+ .optional(),
123
+ contingencyAmount: numberFromStringOrNumber('ContingencyAmount')
124
+ .pipe(
125
+ z
126
+ .number()
127
+ .min(0, { message: 'Contingency amount must be at least 0.' })
128
+ .max(10000000000, {
129
+ message: 'Contingency amount can’t exceed 10 billion.',
130
+ }),
131
+ )
132
+ .nullable()
133
+ .optional(),
134
+ startAt: z
135
+ .date({ message: 'StartAt field is required.' })
136
+ .nullable()
137
+ .optional(),
138
+ endAt: z.date({ message: 'EndAt field is required.' }).nullable().optional(),
139
+ });
140
+
141
+ export const IssuerReviewZod = z.object({
142
+ id: issuerIdSchema,
143
+ accountId: accountIdSchema,
144
+ legalName: z
145
+ .string({ message: 'LegalName field is required.' })
146
+ .min(1, { message: 'Legal name should have at least 1 character.' })
147
+ .max(100, { message: 'Legal name can’t exceed 100 characters.' }),
148
+ dba: z
149
+ .string({
150
+ message: 'Please provide the Doing Business As (DBA) name if applicable.',
151
+ })
152
+ .max(100, { message: 'DBA name can’t exceed 100 characters.' })
153
+ .nullable()
154
+ .optional(),
155
+ ein: z
156
+ .string({ message: 'EIN field is required.' })
157
+ .regex(/^\d{9}$/, {
158
+ message: 'EIN should be exactly 9 digits long.',
159
+ })
160
+ .transform((val) => val.replace(/(\d{2})(\d{7})/, '$1-$2'))
161
+ .nullable()
162
+ .optional(),
163
+ type: z.nativeEnum(IssuerTypes, {
164
+ message: 'Type field is required.',
165
+ invalid_type_error: 'Selected issuer type is not valid.',
166
+ }),
167
+ address: z
168
+ .string({ message: 'Address field is required.' })
169
+ .min(2, { message: 'Address should have at least 2 characters.' })
170
+ .max(150, { message: 'Address can’t exceed 150 characters.' })
171
+ .nullable()
172
+ .optional(),
173
+ address2: z
174
+ .string({ message: 'Please provide address 2 if applicable.' })
175
+ .nullable()
176
+ .optional(),
177
+ city: z
178
+ .string({ message: 'City field is required.' })
179
+ .min(2, { message: 'City should have at least 2 characters.' })
180
+ .max(50, { message: 'City can’t exceed 50 characters.' })
181
+ .nullable()
182
+ .optional(),
183
+ state: z
184
+ .nativeEnum(StateCode, {
185
+ message: 'State field is required.',
186
+ })
187
+ .nullable()
188
+ .optional(),
189
+ zip: z
190
+ .string({ message: 'Zip field is required.' })
191
+ .regex(/^\d{5}$/, {
192
+ message: 'ZIP code must be a 5-digit number.',
193
+ })
194
+ .nullable()
195
+ .optional(),
196
+ country: z
197
+ .nativeEnum(CountryCode, {
198
+ message: 'Country field is required.',
199
+ })
200
+ .nullable()
201
+ .optional(),
202
+ ss4LetterFileId: z
203
+ .string({
204
+ message: 'Ss4LetterFileId field is required.',
205
+ })
206
+ .nullable()
207
+ .optional(),
208
+ });
209
+ export const CoveredPersonReviewZod = z
210
+ .object({
211
+ id: coveredPersonIdSchema,
212
+ firstName: z
213
+ .string()
214
+ .min(2, {
215
+ message: 'FirstName field is required.',
216
+ })
217
+ .max(50, {
218
+ message: 'First name can’t be longer than 50 characters.',
219
+ }),
220
+ lastName: z
221
+ .string()
222
+ .min(2, {
223
+ message: 'LastName field is required.',
224
+ })
225
+ .max(50, { message: 'Last name can’t be longer than 50 characters.' })
226
+ .nullable()
227
+ .optional(),
228
+ status: z.nativeEnum(CoveredPersonsStatus, {
229
+ message: 'Status field is required.',
230
+ }),
231
+ issuerId: issuerIdSchema,
232
+ email: z
233
+ .string()
234
+ .email({ message: 'Email field is required.' })
235
+ .nullable()
236
+ .optional(),
237
+ role: z.nativeEnum(CoveredPersonsRoleType, {
238
+ message: 'Role field is required.',
239
+ }),
240
+ ownership: z
241
+ .number()
242
+ .min(0, { message: 'Ownership percentage cannot be less than 0%.' })
243
+ .max(100, { message: 'Ownership percentage cannot exceed 100%.' }),
244
+ parentId: coveredPersonIdSchema.nullable().optional(),
245
+ accountId: accountIdSchema,
246
+ })
247
+ .superRefine((data, ctx) => {
248
+ if (data.role !== CoveredPersonsRoleType.ENTITY) {
249
+ if (!data.email) {
250
+ ctx.addIssue({
251
+ path: ['email'],
252
+ message:
253
+ 'An email address is required when the role type is not ENTITY.',
254
+ code: 'custom',
255
+ });
256
+ }
257
+ } else {
258
+ if (data.lastName) {
259
+ ctx.addIssue({
260
+ path: ['lastName'],
261
+ message:
262
+ 'Last name should not be provided when the role type is ENTITY.',
263
+ code: 'custom',
264
+ });
265
+ }
266
+ }
267
+ });
268
+
269
+ const BaseAssetReviewZod = z.object({
270
+ id: assetIdSchema,
271
+ name: z
272
+ .string({ message: 'Name field is required.' })
273
+ .min(2, { message: 'Name must have at least 2 characters.' })
274
+ .max(50, { message: 'Name cannot exceed 50 characters.' }),
275
+ type: z
276
+ .nativeEnum(AssetType, { message: 'Type field is required.' })
277
+ .nullable(),
278
+ pricePerUnit: numberFromStringOrNumber('PricePerUnit').pipe(
279
+ z
280
+ .number()
281
+ .min(0.01, { message: 'Price per unit must be at least 0.01.' })
282
+ .max(10000000000, {
283
+ message: 'Price per unit cannot exceed 10 billion.',
284
+ }),
285
+ ),
286
+ totalUnits: numberFromStringOrNumber('TotalUnits').pipe(
287
+ z
288
+ .number()
289
+ .min(0.01, { message: 'Total units must be at least 0.01.' })
290
+ .max(10000000000, {
291
+ message: 'Total units cannot exceed 10 billion.',
292
+ }),
293
+ ),
294
+ accountId: accountIdSchema,
295
+ account: AccountZod.optional().nullable(),
296
+ offeringId: offeringIdSchema,
297
+ });
298
+ export const StockAssetReviewZod = BaseAssetReviewZod.extend({});
299
+
300
+ export const BondAssetReviewZod = BaseAssetReviewZod.extend({
301
+ yield: numberFromStringOrNumber('Yield').pipe(
302
+ z
303
+ .number()
304
+ .min(0.01, { message: 'Yield must be at least 0.01.' })
305
+ .max(10000000000, { message: 'Yield cannot exceed 10 billion.' }),
306
+ ),
307
+ duration: z
308
+ .number({ message: 'Duration field is required.' })
309
+ .min(1, { message: 'Duration must be at least 1.' })
310
+ .max(1000, { message: 'Duration cannot exceed 1000.' }),
311
+ durationType: z.nativeEnum(DurationType, {
312
+ message: 'DurationType field is required.',
313
+ }),
314
+ });
@@ -0,0 +1,91 @@
1
+ import { z } from 'zod';
2
+ import { OfferingSettings, OfferingFeeType } from './offering.types';
3
+
4
+ describe('OfferingSettings Schema', () => {
5
+ it('should pass with all null or undefined values', () => {
6
+ const data = {
7
+ settingsBrokerageFeeValue: null,
8
+ settingsBrokerageFeeType: null,
9
+ settingsCardFeeValue: null,
10
+ settingsCardFeeType: null,
11
+ settingsDisbursementFeeValue: null,
12
+ settingsDisbursementFeeType: null,
13
+ settingsRefundPoolFeeValue: null,
14
+ settingsRefundPoolFeeType: null,
15
+ serviceCharges: null,
16
+ serviceChargesType: null,
17
+ };
18
+ expect(() => OfferingSettings.parse(data)).not.toThrow();
19
+ });
20
+
21
+ it('should pass with valid non-null pair values', () => {
22
+ const data = {
23
+ settingsBrokerageFeeValue: 50,
24
+ settingsBrokerageFeeType: OfferingFeeType.PERCENTAGE,
25
+ settingsCardFeeValue: 25,
26
+ settingsCardFeeType: OfferingFeeType.PERCENTAGE,
27
+ settingsDisbursementFeeValue: 30,
28
+ settingsDisbursementFeeType: OfferingFeeType.PERCENTAGE,
29
+ settingsRefundPoolFeeValue: 40,
30
+ settingsRefundPoolFeeType: OfferingFeeType.PERCENTAGE,
31
+ };
32
+ expect(() => OfferingSettings.parse(data)).not.toThrow();
33
+ });
34
+
35
+ it('should fail if one of a pair is null and the other is not', () => {
36
+ const data = {
37
+ settingsBrokerageFeeValue: 10,
38
+ settingsBrokerageFeeType: null,
39
+ settingsCardFeeValue: null,
40
+ settingsCardFeeType: OfferingFeeType.PERCENTAGE,
41
+ settingsDisbursementFeeValue: 15,
42
+ settingsDisbursementFeeType: null,
43
+ settingsRefundPoolFeeValue: null,
44
+ settingsRefundPoolFeeType: OfferingFeeType.PERCENTAGE,
45
+ };
46
+ expect(() => OfferingSettings.parse(data)).toThrow(
47
+ 'settingsBrokerageFeeType and settingsBrokerageFeeValue must both be either null or not-null',
48
+ );
49
+ expect(() => OfferingSettings.parse(data)).toThrow(
50
+ 'settingsCardFeeType and settingsCardFeeValue must both be either null or not-null',
51
+ );
52
+ });
53
+
54
+ it('should fail if percentage fee values exceed 100', () => {
55
+ const data = {
56
+ settingsBrokerageFeeValue: 101,
57
+ settingsBrokerageFeeType: OfferingFeeType.PERCENTAGE,
58
+ settingsCardFeeValue: 50,
59
+ settingsCardFeeType: OfferingFeeType.PERCENTAGE,
60
+ settingsDisbursementFeeValue: 200,
61
+ settingsDisbursementFeeType: OfferingFeeType.PERCENTAGE,
62
+ settingsRefundPoolFeeValue: 150,
63
+ settingsRefundPoolFeeType: OfferingFeeType.PERCENTAGE,
64
+ };
65
+ expect(() => OfferingSettings.parse(data)).toThrow(
66
+ 'settingsBrokerageFeeValue must be less than or equal to 100',
67
+ );
68
+ expect(() => OfferingSettings.parse(data)).toThrow(
69
+ 'settingsDisbursementFeeValue must be less than 100',
70
+ );
71
+ expect(() => OfferingSettings.parse(data)).toThrow(
72
+ 'settingsRefundPoolFeeValue must be less than or equal to 100',
73
+ );
74
+ });
75
+
76
+ it('should fail if required values are missing', () => {
77
+ const data = {
78
+ settingsBrokerageFeeValue: undefined,
79
+ settingsBrokerageFeeType: OfferingFeeType.PERCENTAGE,
80
+ };
81
+ expect(() => OfferingSettings.parse(data)).toThrow(z.ZodError);
82
+ });
83
+
84
+ it('should fail if invalid types are provided', () => {
85
+ const data = {
86
+ settingsBrokerageFeeValue: 'invalid', // should be a number
87
+ settingsBrokerageFeeType: OfferingFeeType.PERCENTAGE,
88
+ };
89
+ expect(() => OfferingSettings.parse(data)).toThrow(z.ZodError);
90
+ });
91
+ });