@dalmore/api-contracts 1.0.6 → 1.0.7

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/dist/contracts/clients/index.d.ts +19 -0
  2. package/index.mjs +4 -1
  3. package/package.json +4 -4
  4. package/src/common/types/account-contact.types.ts +0 -98
  5. package/src/common/types/account-detail.types.ts +0 -27
  6. package/src/common/types/account-integration.types.ts +0 -143
  7. package/src/common/types/account-manager.types.ts +0 -124
  8. package/src/common/types/account.types.ts +0 -296
  9. package/src/common/types/activity.types.ts +0 -274
  10. package/src/common/types/address.spec.ts +0 -203
  11. package/src/common/types/address.types.ts +0 -41
  12. package/src/common/types/aic.types.ts +0 -246
  13. package/src/common/types/aml.types.ts +0 -18
  14. package/src/common/types/api-key-logs.types.ts +0 -66
  15. package/src/common/types/api-keys.types.ts +0 -69
  16. package/src/common/types/asset.types.ts +0 -338
  17. package/src/common/types/auth.types.ts +0 -370
  18. package/src/common/types/batch-jobs.types.ts +0 -151
  19. package/src/common/types/bonus-tier.types.ts +0 -147
  20. package/src/common/types/cart.types.ts +0 -18
  21. package/src/common/types/checklist-items.types.ts +0 -70
  22. package/src/common/types/checklist.types.ts +0 -97
  23. package/src/common/types/common.types.spec.ts +0 -336
  24. package/src/common/types/common.types.ts +0 -1520
  25. package/src/common/types/comply-advantage-api.types.ts +0 -316
  26. package/src/common/types/comply-advantage.types.ts +0 -25
  27. package/src/common/types/contact-us.types.ts +0 -107
  28. package/src/common/types/contract-helpers.ts +0 -205
  29. package/src/common/types/countries.types.ts +0 -375
  30. package/src/common/types/covered-person.types.ts +0 -274
  31. package/src/common/types/dashboard.types.ts +0 -799
  32. package/src/common/types/data-record.types.ts +0 -325
  33. package/src/common/types/data-room.types.ts +0 -242
  34. package/src/common/types/default-theme-config.types.ts +0 -87
  35. package/src/common/types/disbursement-adjustment.types.ts +0 -32
  36. package/src/common/types/disbursement-approval-user.types.ts +0 -100
  37. package/src/common/types/disbursement-review.types.ts +0 -110
  38. package/src/common/types/disbursement-transaction.types.ts +0 -72
  39. package/src/common/types/disbursements.types.ts +0 -310
  40. package/src/common/types/domain-filter.types.ts +0 -55
  41. package/src/common/types/email-theme.types.ts +0 -442
  42. package/src/common/types/entity.types.ts +0 -15
  43. package/src/common/types/error-responses.types.ts +0 -135
  44. package/src/common/types/escrow-account.types.ts +0 -104
  45. package/src/common/types/exchange-api-key.types.ts +0 -121
  46. package/src/common/types/exchange-import.types.ts +0 -36
  47. package/src/common/types/exchange-provider.types.ts +0 -329
  48. package/src/common/types/file.types.ts +0 -461
  49. package/src/common/types/files.types.spec.ts +0 -154
  50. package/src/common/types/health.types.ts +0 -29
  51. package/src/common/types/index.ts +0 -48
  52. package/src/common/types/individuals.types.ts +0 -554
  53. package/src/common/types/investor-account.types.ts +0 -1239
  54. package/src/common/types/investorAccountIdSchema.type.ts +0 -0
  55. package/src/common/types/investors-offering.types.ts +0 -65
  56. package/src/common/types/invite.types.ts +0 -133
  57. package/src/common/types/issuer-bank-account.types.ts +0 -107
  58. package/src/common/types/issuer-offering.types.ts +0 -306
  59. package/src/common/types/issuer-payment-method.types.spec.ts +0 -612
  60. package/src/common/types/issuer-payment-method.types.ts +0 -341
  61. package/src/common/types/issuer.types.ts +0 -312
  62. package/src/common/types/job-item.types.ts +0 -119
  63. package/src/common/types/jobs.types.ts +0 -171
  64. package/src/common/types/kyb.types.ts +0 -53
  65. package/src/common/types/kyc.types.ts +0 -188
  66. package/src/common/types/legal-entity.types.ts +0 -185
  67. package/src/common/types/login-history.types.ts +0 -46
  68. package/src/common/types/mail-template.types.ts +0 -436
  69. package/src/common/types/north-cap-integration.types.ts +0 -190
  70. package/src/common/types/note.types.ts +0 -109
  71. package/src/common/types/notification.types.ts +0 -58
  72. package/src/common/types/notion-api.types.ts +0 -374
  73. package/src/common/types/notion-database.types.ts +0 -125
  74. package/src/common/types/notion-page.types.ts +0 -267
  75. package/src/common/types/offering-reports.types.ts +0 -153
  76. package/src/common/types/offering-submission.types.ts +0 -314
  77. package/src/common/types/offering.types.spec.ts +0 -91
  78. package/src/common/types/offering.types.ts +0 -590
  79. package/src/common/types/page-revision.types.ts +0 -86
  80. package/src/common/types/page.types.ts +0 -436
  81. package/src/common/types/password.type.ts +0 -15
  82. package/src/common/types/payment-methods.types.ts +0 -298
  83. package/src/common/types/phone.spec.ts +0 -76
  84. package/src/common/types/phone.type.ts +0 -27
  85. package/src/common/types/portfolio.types.ts +0 -50
  86. package/src/common/types/privacy-policy-and-tos.types.ts +0 -231
  87. package/src/common/types/queue.types.ts +0 -112
  88. package/src/common/types/registered-reps.types.ts +0 -25
  89. package/src/common/types/rejection-reasons.types.ts +0 -56
  90. package/src/common/types/reminder-config.types.ts +0 -40
  91. package/src/common/types/review.types.ts +0 -133
  92. package/src/common/types/role.types.ts +0 -26
  93. package/src/common/types/secondary-customer.types.ts +0 -66
  94. package/src/common/types/secondary-issuer.types.ts +0 -50
  95. package/src/common/types/secondary-order.types.ts +0 -58
  96. package/src/common/types/secondary-security.types.ts +0 -60
  97. package/src/common/types/secondary-trade.entity.ts +0 -16
  98. package/src/common/types/secondary-trade.types.ts +0 -95
  99. package/src/common/types/secure-request.types.ts +0 -68
  100. package/src/common/types/signer.types.ts +0 -651
  101. package/src/common/types/site-link.types.spec.ts +0 -134
  102. package/src/common/types/site-link.types.ts +0 -166
  103. package/src/common/types/site-settings.types.ts +0 -726
  104. package/src/common/types/site.types.ts +0 -270
  105. package/src/common/types/sms.types.ts +0 -30
  106. package/src/common/types/state-machine.types.ts +0 -177
  107. package/src/common/types/states.types.ts +0 -163
  108. package/src/common/types/subdoc-preview.types.ts +0 -35
  109. package/src/common/types/task.types.ts +0 -258
  110. package/src/common/types/trade-adjustment.type.ts +0 -33
  111. package/src/common/types/trade-line-item.type.ts +0 -132
  112. package/src/common/types/trade.types.ts +0 -929
  113. package/src/common/types/transaction.types.ts +0 -198
  114. package/src/common/types/trusted-contact.types.ts +0 -122
  115. package/src/common/types/typography.types.ts +0 -75
  116. package/src/common/types/user-manual.types.ts +0 -290
  117. package/src/common/types/user-setting.types.ts +0 -133
  118. package/src/common/types/user.types.ts +0 -320
  119. package/src/common/types/webhook.types.ts +0 -588
  120. package/src/common/types/zip.type.ts +0 -36
  121. package/src/contracts/clients/accounts/index.ts +0 -61
  122. package/src/contracts/clients/aic/index.ts +0 -59
  123. package/src/contracts/clients/api-key-logs/index.ts +0 -53
  124. package/src/contracts/clients/api-keys/index.ts +0 -73
  125. package/src/contracts/clients/assets/index.ts +0 -102
  126. package/src/contracts/clients/auth/index.ts +0 -50
  127. package/src/contracts/clients/files/index.ts +0 -166
  128. package/src/contracts/clients/files-public/index.ts +0 -166
  129. package/src/contracts/clients/index.ts +0 -44
  130. package/src/contracts/clients/individuals/index.ts +0 -93
  131. package/src/contracts/clients/investor-accounts/index.ts +0 -93
  132. package/src/contracts/clients/issuers/index.ts +0 -94
  133. package/src/contracts/clients/legal-entities/index.ts +0 -93
  134. package/src/contracts/clients/offerings/index.ts +0 -117
  135. package/src/contracts/clients/secure-requests/index.ts +0 -34
  136. package/src/contracts/clients/sites/index.ts +0 -56
  137. package/src/contracts/clients/trades/index.ts +0 -122
@@ -1,203 +0,0 @@
1
- import { createAddress } from '../../tests/factory/address.factory';
2
- import { AddressSchema } from './address.types';
3
-
4
- describe('AddressSchema Tests', () => {
5
- it('should fail if counry is not valid', () => {
6
- const address = createAddress({
7
- country: 'eg',
8
- });
9
- const parseRes = AddressSchema.safeParse(address);
10
-
11
- const result = parseRes.success;
12
- expect(result).toBeFalsy();
13
- });
14
-
15
- it('should succeed if counry is valid', () => {
16
- const address = createAddress({
17
- country: 'CA',
18
- zip: 'A1A 1A1',
19
- state: 'AB',
20
- });
21
- const parseRes = AddressSchema.safeParse(address);
22
-
23
- const result = parseRes.success;
24
- expect(result).toBeTruthy();
25
- });
26
-
27
- it('should fail if CANADA state is not valid', () => {
28
- const address = createAddress({
29
- country: 'CA',
30
- zip: 'A1A 1A1',
31
- state: 'AS',
32
- });
33
- const parseRes = AddressSchema.safeParse(address);
34
-
35
- const result = parseRes.success;
36
- expect(result).toBeFalsy();
37
- });
38
-
39
- it('should succeed if CANADA state is valid', () => {
40
- const address = createAddress({
41
- country: 'CA',
42
- zip: 'A1A 1A1',
43
- state: 'AB',
44
- });
45
- const parseRes = AddressSchema.safeParse(address);
46
-
47
- const result = parseRes.success;
48
- expect(result).toBeTruthy();
49
- });
50
-
51
- it('should fail if CANADA state is not valid', () => {
52
- const address = createAddress({
53
- country: 'CA',
54
- zip: '12345',
55
- state: 'AS',
56
- });
57
- const parseRes = AddressSchema.safeParse(address);
58
-
59
- const result = parseRes.success;
60
- expect(result).toBeFalsy();
61
- });
62
-
63
- it('should succeed if CANADA zip is valid', () => {
64
- const address = createAddress({
65
- country: 'CA',
66
- zip: 'A1A 1A1',
67
- state: 'AB',
68
- });
69
- const parseRes = AddressSchema.safeParse(address);
70
-
71
- const result = parseRes.success;
72
- expect(result).toBeTruthy();
73
- });
74
-
75
- it('should fail if US state is not valid', () => {
76
- const address = createAddress({
77
- country: 'US',
78
- zip: '12345',
79
- state: 'CS',
80
- });
81
- const parseRes = AddressSchema.safeParse(address);
82
-
83
- const result = parseRes.success;
84
- expect(result).toBeFalsy();
85
- });
86
-
87
- it('should succeed if US state is valid', () => {
88
- const address = createAddress({
89
- country: 'US',
90
- zip: '12345',
91
- state: 'CA',
92
- });
93
- const parseRes = AddressSchema.safeParse(address);
94
-
95
- const result = parseRes.success;
96
- expect(result).toBeTruthy();
97
- });
98
-
99
- it('should fail if US zip is not valid', () => {
100
- const address = createAddress({
101
- country: 'US',
102
- zip: '12345 d',
103
- state: 'CS',
104
- });
105
- const parseRes = AddressSchema.safeParse(address);
106
-
107
- const result = parseRes.success;
108
- expect(result).toBeFalsy();
109
- });
110
-
111
- it('should succeed if US zip is valid', () => {
112
- const address = createAddress({
113
- country: 'US',
114
- zip: '12345',
115
- state: 'CA',
116
- });
117
- const parseRes = AddressSchema.safeParse(address);
118
-
119
- const result = parseRes.success;
120
- expect(result).toBeTruthy();
121
- });
122
-
123
- it('should fail if state is not valid, state(min=2,max=35)', () => {
124
- const address = createAddress({
125
- country: 'EG',
126
- zip: '12345',
127
- state: 'Alex Cairo Tanta Hurgada Dahb Luxor Aswan Sharm ', // length 48
128
- });
129
- const parseRes = AddressSchema.safeParse(address);
130
-
131
- const result = parseRes.success;
132
- expect(result).toBeFalsy();
133
- });
134
-
135
- it('should fail if state is not valid', () => {
136
- const address = createAddress({
137
- country: 'EG',
138
- zip: '12345',
139
- state: 'A',
140
- });
141
- const parseRes = AddressSchema.safeParse(address);
142
-
143
- const result = parseRes.success;
144
- expect(result).toBeFalsy();
145
- });
146
-
147
- it('should succeed if state is valid', () => {
148
- const address = createAddress({
149
- country: 'EG',
150
- zip: '12345',
151
- state: 'Alexandria',
152
- });
153
- const parseRes = AddressSchema.safeParse(address);
154
-
155
- const result = parseRes.success;
156
- expect(result).toBeTruthy();
157
- });
158
-
159
- it('should fail if zip is not valid', () => {
160
- const address = createAddress({
161
- country: 'EG',
162
- zip: '1',
163
- state: 'Cairo',
164
- });
165
- const parseRes = AddressSchema.safeParse(address);
166
-
167
- const result = parseRes.success;
168
- expect(result).toBeFalsy();
169
- });
170
-
171
- it('should succeed if zip is valid', () => {
172
- const address = createAddress({
173
- country: 'EG',
174
- zip: '12345678',
175
- state: 'Cairo',
176
- });
177
- const parseRes = AddressSchema.safeParse(address);
178
-
179
- const result = parseRes.success;
180
- expect(result).toBeTruthy();
181
- });
182
-
183
- it('should succeed if zip is optional', () => {
184
- const address = createAddress({
185
- country: 'EG',
186
- state: 'Cairo',
187
- });
188
- const parseRes = AddressSchema.safeParse(address);
189
-
190
- const result = parseRes.success;
191
- expect(result).toBeTruthy();
192
- });
193
-
194
- it('should succeed if state is optional', () => {
195
- const address = createAddress({
196
- country: 'EG',
197
- });
198
- const parseRes = AddressSchema.safeParse(address);
199
-
200
- const result = parseRes.success;
201
- expect(result).toBeTruthy();
202
- });
203
- });
@@ -1,41 +0,0 @@
1
- import { z } from 'zod';
2
- import { CountryStateSchema, RequiredCountryStateSchema } from './states.types';
3
- import { CountryZipSchema, RequiredCountryZipSchema } from './zip.type';
4
-
5
- export const AddressSchema = z
6
- .object({
7
- address: z
8
- .string()
9
- .min(2, 'address is less than 2 characters')
10
- .nullable()
11
- .optional(),
12
- address2: z.string().nullable().optional(),
13
- city: z
14
- .string()
15
- .min(2, 'city is less than 2 characters')
16
- .max(30, 'city is more than 30 characters')
17
- .nullable()
18
- .optional(),
19
- })
20
- .and(CountryStateSchema)
21
- .and(CountryZipSchema);
22
-
23
- export type AddressType = z.infer<typeof AddressSchema>;
24
-
25
- export const RequiredAddressSchema = z
26
- .object({
27
- address: z.string().min(2, 'Address must be at least 2 characters'),
28
- address2: z
29
- .string()
30
- .max(100, 'Address2 cannot exceed 100 characters')
31
- .nullable()
32
- .optional(),
33
- city: z
34
- .string()
35
- .min(2, 'City must be at least 2 characters')
36
- .max(50, 'City cannot exceed 50 characters'),
37
- })
38
- .and(RequiredCountryStateSchema)
39
- .and(RequiredCountryZipSchema);
40
-
41
- export type RequiredAddressType = z.infer<typeof RequiredAddressSchema>;
@@ -1,246 +0,0 @@
1
- import { z } from 'zod';
2
- import { IBaseEntity } from './entity.types';
3
- import { extendZodWithOpenApi } from '@anatine/zod-openapi';
4
- import { TypeID } from 'typeid-js';
5
- import { fileIdSchema } from './file.types';
6
- import {
7
- AccountType,
8
- AicAccreditationType,
9
- ComplianceReview,
10
- FilingStatus,
11
- SystemReviewStatus,
12
- } from './common.types';
13
- import { IIndividualZod, individualIdSchema } from './individuals.types';
14
- import { userIdSchema, UserZod } from './user.types';
15
- import { accountIdSchema } from './account.types';
16
-
17
- extendZodWithOpenApi(z);
18
-
19
- export const aicIdSchema = z.string().refine(
20
- (value) => {
21
- try {
22
- const tid = TypeID.fromString(value);
23
- return tid.getType() === 'aic';
24
- } catch {
25
- return false;
26
- }
27
- },
28
- {
29
- message: `Invalid aic ID format. Must be a valid TypeID with "aic" prefix. Example: aic_01j5y5ghx5fg68d663j1fvy2x7`,
30
- },
31
- );
32
-
33
- export enum ProfessionalType {
34
- SECURITIES_LICENSES = 'SECURITIES_LICENSES',
35
- DIRECTORS = 'DIRECTORS',
36
- FAMILY_OFFICE = 'FAMILY_OFFICE',
37
- }
38
-
39
- export enum ResultType {
40
- PASS = 'PASS',
41
- FAIL = 'FAIL',
42
- }
43
-
44
- const aicInclude = z.enum(['individual']);
45
-
46
- export const AicIncludeQuery = z.object({
47
- include: z
48
- .string()
49
- .optional()
50
- .transform((str) => (str ? str.split(',') : []))
51
- .refine(
52
- (includes) =>
53
- includes.every((include) =>
54
- aicInclude.options.includes(include as any),
55
- ),
56
- {
57
- message: `Invalid include option provided. Valid options are: ${aicInclude.options.join(',')}`,
58
- },
59
- )
60
- .openapi({
61
- example: `${aicInclude.options.join(',')}`,
62
- }),
63
- });
64
-
65
- export const IncomeDataEntryZod = z.object({
66
- year: z
67
- .number()
68
- .int()
69
- .min(2020)
70
- .max(new Date().getFullYear() - 1),
71
- filingStatus: z.nativeEnum(FilingStatus),
72
- income: z.number().min(0).multipleOf(0.01),
73
- fileId: z.lazy(() => fileIdSchema),
74
- });
75
-
76
- export type IncomeDataEntryZod = z.infer<typeof IncomeDataEntryZod>;
77
-
78
- export const NetWorthDataEntryZod = z.object({
79
- institution: z.string().min(1).max(100),
80
- accountType: z.nativeEnum(AccountType),
81
- balance: z.number().min(0).multipleOf(0.01),
82
- fileId: z.lazy(() => fileIdSchema),
83
- });
84
-
85
- export type NetWorthDataEntryZod = z.infer<typeof NetWorthDataEntryZod>;
86
-
87
- export const ProfessionalDataEntryZod = z
88
- .object({
89
- professionalType: z.nativeEnum(ProfessionalType),
90
- licenseNumber: z.string().min(1).max(50).optional().nullable(),
91
- fileId: z
92
- .lazy(() => fileIdSchema)
93
- .optional()
94
- .nullable(),
95
- })
96
- .refine(
97
- (data) => {
98
- if (data.professionalType === ProfessionalType.SECURITIES_LICENSES) {
99
- return !!data.licenseNumber;
100
- }
101
- return true;
102
- },
103
- {
104
- message: `License number is required when professional type is ${ProfessionalType.SECURITIES_LICENSES}`,
105
- path: ['licenseNumber'],
106
- },
107
- );
108
-
109
- export type ProfessionalDataEntryZod = z.infer<typeof ProfessionalDataEntryZod>;
110
-
111
- export const EmployeeDataEntryZod = z.object({
112
- position: z.string().min(1).max(100),
113
- fileId: z.lazy(() => fileIdSchema),
114
- });
115
-
116
- export type EmployeeDataEntryZod = z.infer<typeof EmployeeDataEntryZod>;
117
-
118
- // Validation configuration types
119
- export interface AicValidationConfig<T> {
120
- schema: z.ZodType<T>;
121
- errorPrefix: string;
122
- }
123
-
124
- export type AicValidationConfigMap = {
125
- [AicAccreditationType.INCOME]: AicValidationConfig<IncomeDataEntryZod>;
126
- [AicAccreditationType.NET_WORTH]: AicValidationConfig<NetWorthDataEntryZod>;
127
- [AicAccreditationType.PROFESSIONAL_CERTIFICATION]: AicValidationConfig<ProfessionalDataEntryZod>;
128
- [AicAccreditationType.KNOWLEDGEABLE_EMPLOYEE]: AicValidationConfig<EmployeeDataEntryZod>;
129
- };
130
-
131
- export const validationConfig: AicValidationConfigMap = {
132
- [AicAccreditationType.INCOME]: {
133
- schema: IncomeDataEntryZod,
134
- errorPrefix: 'Income verification',
135
- },
136
- [AicAccreditationType.NET_WORTH]: {
137
- schema: NetWorthDataEntryZod,
138
- errorPrefix: 'Net worth verification',
139
- },
140
- [AicAccreditationType.PROFESSIONAL_CERTIFICATION]: {
141
- schema: ProfessionalDataEntryZod,
142
- errorPrefix: 'Professional certification',
143
- },
144
- [AicAccreditationType.KNOWLEDGEABLE_EMPLOYEE]: {
145
- schema: EmployeeDataEntryZod,
146
- errorPrefix: 'Employee verification',
147
- },
148
- } as const;
149
-
150
- export const AicSystemLogEntryZod = z.object({
151
- check: z.string().min(1),
152
- entered: z.number().optional(),
153
- extracted: z.number().optional(),
154
- result: z.nativeEnum(ResultType),
155
- reason: z.string().optional(),
156
- });
157
-
158
- export type AicSystemLogEntryZod = z.infer<typeof AicSystemLogEntryZod>;
159
-
160
- export const AicZod = IBaseEntity.extend({
161
- individualId: z.lazy(() => individualIdSchema),
162
- individual: z
163
- .lazy(() => IIndividualZod)
164
- .nullable()
165
- .optional(),
166
- complianceReview: z.nativeEnum(ComplianceReview),
167
- reviewedById: z.lazy(() => userIdSchema).nullable(),
168
- reviewedBy: z
169
- .lazy(() => UserZod)
170
- .nullable()
171
- .optional(),
172
- reviewedAt: z.date().nullable(),
173
- systemReview: z.nativeEnum(SystemReviewStatus),
174
- systemLog: z.array(AicSystemLogEntryZod).nullable(),
175
- firstName: z.string(),
176
- lastName: z.string(),
177
- method: z.nativeEnum(AicAccreditationType),
178
- incomeData: z.array(IncomeDataEntryZod).nullable(),
179
- netWorthData: z.array(NetWorthDataEntryZod).nullable(),
180
- professionalData: z.array(ProfessionalDataEntryZod).nullable(),
181
- employeeData: z.array(EmployeeDataEntryZod).nullable(),
182
- });
183
-
184
- export type AicZod = z.infer<typeof AicZod>;
185
-
186
- export const PostAicZod = z.object({
187
- firstName: z.string().min(1).max(50),
188
- lastName: z.string().min(1).max(50),
189
- method: z.nativeEnum(AicAccreditationType),
190
- });
191
-
192
- export type PostAicZod = z.infer<typeof PostAicZod>;
193
-
194
- export const UpdateAicZod = z.object({
195
- firstName: z.string().min(1).max(50),
196
- lastName: z.string().min(1).max(50),
197
- method: z.nativeEnum(AicAccreditationType),
198
- });
199
-
200
- export type UpdateAicZod = z.infer<typeof UpdateAicZod>;
201
-
202
- export const AttachAicFilePathParamsZod = z.object({
203
- individualId: z.lazy(() => individualIdSchema),
204
- fileId: z.lazy(() => fileIdSchema),
205
- });
206
-
207
- export type AttachAicFilePathParamsZod = z.infer<
208
- typeof AttachAicFilePathParamsZod
209
- >;
210
-
211
- export const AttachAicFileBodyZod = z.discriminatedUnion('type', [
212
- z.object({
213
- type: z.literal(AicAccreditationType.INCOME),
214
- metadata: z.array(IncomeDataEntryZod),
215
- }),
216
- z.object({
217
- type: z.literal(AicAccreditationType.NET_WORTH),
218
- metadata: z.array(NetWorthDataEntryZod),
219
- }),
220
- z.object({
221
- type: z.literal(AicAccreditationType.PROFESSIONAL_CERTIFICATION),
222
- metadata: z.array(ProfessionalDataEntryZod),
223
- }),
224
- z.object({
225
- type: z.literal(AicAccreditationType.KNOWLEDGEABLE_EMPLOYEE),
226
- metadata: z.array(EmployeeDataEntryZod),
227
- }),
228
- ]);
229
-
230
- export type AttachAicFilePathBodyZod = z.infer<typeof AttachAicFileBodyZod>;
231
-
232
- export const ComplianceAicQueryZod = z.object({
233
- accountId: z.lazy(() => accountIdSchema),
234
- });
235
-
236
- export type ComplianceAicQueryZod = z.infer<typeof ComplianceAicQueryZod>;
237
-
238
- export const ComplianceAttachAicFileBodyZod = AttachAicFileBodyZod.and(
239
- z.object({
240
- accountId: z.lazy(() => accountIdSchema),
241
- }),
242
- );
243
-
244
- export type ComplianceAttachAicFileBodyZod = z.infer<
245
- typeof ComplianceAttachAicFileBodyZod
246
- >;
@@ -1,18 +0,0 @@
1
- import { z } from 'zod';
2
- import { IBaseEntity } from './entity.types';
3
- import { extendZodWithOpenApi } from '@anatine/zod-openapi';
4
- import { AMLStatus } from './common.types';
5
-
6
- extendZodWithOpenApi(z);
7
-
8
- export const AmlZod = IBaseEntity.extend({
9
- tid: z.string().openapi({ example: 'third_party_kyc_123' }).nullable(),
10
- provider: z.string().nullable().openapi({ example: 'AML Provider' }),
11
- url: z.string().nullable().openapi({ example: 'https://example.com/aml' }),
12
- status: z.nativeEnum(AMLStatus).openapi({ example: 'PENDING' }),
13
- checkedAt: z.date().nullable().openapi({ example: '2022-01-01T00:00:00Z' }),
14
- individualId: z
15
- .string()
16
- .openapi({ example: 'individual_01j1xgme5qeqq97gpdztd7e4a6' }),
17
- });
18
- export type AmlZod = z.infer<typeof AmlZod>;
@@ -1,66 +0,0 @@
1
- import { z } from 'zod';
2
- import { TypeID } from 'typeid-js';
3
- import { HttpStatus } from '@nestjs/common';
4
- import { extendZodWithOpenApi } from '@anatine/zod-openapi';
5
- import { IPaginationMeta, HttpMethod, dateSchema } from './common.types';
6
- import { apiKeyIdSchema } from './api-keys.types';
7
- import { IBaseEntity } from './entity.types';
8
-
9
- extendZodWithOpenApi(z);
10
-
11
- export const ApiLogsFiltersZod = z.object({
12
- endpoint: z.string().optional(),
13
- apiKeyId: apiKeyIdSchema.optional(),
14
- method: z.nativeEnum(HttpMethod).optional(),
15
- status: z.nativeEnum(HttpStatus).optional(),
16
- from: dateSchema.optional().openapi({ example: 'MM/DD/YYYY' }),
17
- to: dateSchema.optional().openapi({ example: 'MM/DD/YYYY' }),
18
- });
19
- export type ApiLogsFiltersZod = z.infer<typeof ApiLogsFiltersZod>;
20
-
21
- export const apiKeyLogIdSchema = z.string().refine(
22
- (value) => {
23
- try {
24
- const tid = TypeID.fromString(value);
25
- return tid.getType() === 'api_key_log';
26
- } catch {
27
- return false;
28
- }
29
- },
30
- {
31
- message:
32
- 'Invalid Api Key Log ID format. Must be a valid TypeID with "api_key_log" prefix. Example: api_key_log_01j5y5ghx8fvc83dmx3pznq7hv',
33
- },
34
- );
35
-
36
- export const ApiKeyLogZod = IBaseEntity.extend({
37
- id: apiKeyLogIdSchema,
38
- apiKeyId: apiKeyIdSchema,
39
- method: z.nativeEnum(HttpMethod),
40
- path: z.string(),
41
- status: z.nativeEnum(HttpStatus),
42
- durationMs: z.number(),
43
- requestBody: z.record(z.any()).nullable(),
44
- responseBody: z.record(z.any()).nullable(),
45
- });
46
- export type ApiKeyLogZod = z.infer<typeof ApiKeyLogZod>;
47
-
48
- export const ApiLogsTotalsFiltersZod = z.object({
49
- apiKeyId: apiKeyIdSchema.optional(),
50
- from: dateSchema.optional().openapi({ example: 'MM/DD/YYYY' }),
51
- to: dateSchema.optional().openapi({ example: 'MM/DD/YYYY' }),
52
- });
53
- export type ApiLogsTotalsFiltersZod = z.infer<typeof ApiLogsTotalsFiltersZod>;
54
-
55
- export const ApiLogsTotalsZod = z.object({
56
- success: z.number(),
57
- failed: z.number(),
58
- total: z.number().optional(),
59
- });
60
- export type ApiLogsTotalsZod = z.infer<typeof ApiLogsTotalsZod>;
61
-
62
- export const IPaginatedApiLogs = z.object({
63
- items: z.array(ApiKeyLogZod),
64
- meta: IPaginationMeta,
65
- });
66
- export type IPaginatedApiLogs = z.infer<typeof IPaginatedApiLogs>;
@@ -1,69 +0,0 @@
1
- import { z } from 'zod';
2
- import { TypeID } from 'typeid-js';
3
- import { extendZodWithOpenApi } from '@anatine/zod-openapi';
4
- import { IBaseEntity } from './entity.types';
5
- import { IPaginationMeta, PortalType } from './common.types';
6
- import { accountIdSchema } from './account.types';
7
- extendZodWithOpenApi(z);
8
-
9
- export const apiKeyIdSchema = z.string().refine(
10
- (value) => {
11
- try {
12
- const tid = TypeID.fromString(value);
13
- return tid.getType() === 'api_key';
14
- } catch {
15
- return false;
16
- }
17
- },
18
- {
19
- message:
20
- 'Invalid Api Key ID format. Must be a valid TypeID with "api_key" prefix. Example: api_key_01j5y5ghx8fvc83dmx3pznq7hv',
21
- },
22
- );
23
-
24
- export const ApiKeyZod = IBaseEntity.extend({
25
- id: apiKeyIdSchema,
26
- name: z.string(),
27
- description: z.string().nullable(),
28
- key: z.string(),
29
- keyHash: z.string(),
30
- active: z.boolean(),
31
- lastUsedAt: z.date().nullable(),
32
- accountId: z.string(),
33
- roleId: z.string().nullable(),
34
- });
35
- export type ApiKeyZod = z.infer<typeof ApiKeyZod>;
36
-
37
- export const IPaginatedApiKeys = z.object({
38
- items: z.array(ApiKeyZod),
39
- meta: IPaginationMeta,
40
- });
41
- export type IPaginatedApiKeys = z.infer<typeof IPaginatedApiKeys>;
42
-
43
- export const PostApiKeyBody = z.object({
44
- name: z
45
- .string()
46
- .min(2, 'name is less than 2 characters')
47
- .max(30, 'name is more than 30 characters')
48
- .openapi({ description: 'Name of the API key' }),
49
- description: z
50
- .string()
51
- .min(2, 'description is less than 2 characters')
52
- .max(50, 'description is more than 50 characters')
53
- .optional()
54
- .openapi({ description: 'Description of the API key' }),
55
- accountId: accountIdSchema,
56
- contract: z
57
- .enum([
58
- PortalType.CLIENT,
59
- PortalType.SECONDARIES,
60
- PortalType.COMPLIANCE_APIKEY,
61
- ])
62
- .default(PortalType.CLIENT),
63
- });
64
- export type PostApiKeyBody = z.infer<typeof PostApiKeyBody>;
65
-
66
- //It removes accountId because issuers use user.accountId from authentication, so the request body shouldn't include it.
67
- export const PostIssuerApiKeyBody = PostApiKeyBody.omit({ accountId: true });
68
-
69
- export type PostIssuerApiKeyBody = z.infer<typeof PostIssuerApiKeyBody>;