@dalmore/api-contracts 1.0.7 → 1.0.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.
- package/README.md +18 -2
- package/index.mjs +1 -4
- package/package.json +4 -4
- package/src/common/types/account-contact.types.ts +98 -0
- package/src/common/types/account-detail.types.ts +27 -0
- package/src/common/types/account-integration.types.ts +143 -0
- package/src/common/types/account-manager.types.ts +124 -0
- package/src/common/types/account.types.ts +296 -0
- package/src/common/types/activity.types.ts +274 -0
- package/src/common/types/address.spec.ts +203 -0
- package/src/common/types/address.types.ts +41 -0
- package/src/common/types/aic.types.ts +246 -0
- package/src/common/types/aml.types.ts +18 -0
- package/src/common/types/api-key-logs.types.ts +66 -0
- package/src/common/types/api-keys.types.ts +69 -0
- package/src/common/types/asset.types.ts +338 -0
- package/src/common/types/auth.types.ts +370 -0
- package/src/common/types/batch-jobs.types.ts +151 -0
- package/src/common/types/bonus-tier.types.ts +147 -0
- package/src/common/types/cart.types.ts +18 -0
- package/src/common/types/checklist-items.types.ts +70 -0
- package/src/common/types/checklist.types.ts +97 -0
- package/src/common/types/common.types.spec.ts +336 -0
- package/src/common/types/common.types.ts +1520 -0
- package/src/common/types/comply-advantage-api.types.ts +316 -0
- package/src/common/types/comply-advantage.types.ts +25 -0
- package/src/common/types/contact-us.types.ts +107 -0
- package/src/common/types/contract-helpers.ts +205 -0
- package/src/common/types/countries.types.ts +375 -0
- package/src/common/types/covered-person.types.ts +274 -0
- package/src/common/types/dashboard.types.ts +799 -0
- package/src/common/types/data-record.types.ts +325 -0
- package/src/common/types/data-room.types.ts +242 -0
- package/src/common/types/default-theme-config.types.ts +87 -0
- package/src/common/types/disbursement-adjustment.types.ts +32 -0
- package/src/common/types/disbursement-approval-user.types.ts +100 -0
- package/src/common/types/disbursement-review.types.ts +110 -0
- package/src/common/types/disbursement-transaction.types.ts +72 -0
- package/src/common/types/disbursements.types.ts +310 -0
- package/src/common/types/domain-filter.types.ts +55 -0
- package/src/common/types/email-theme.types.ts +442 -0
- package/src/common/types/entity.types.ts +15 -0
- package/src/common/types/error-responses.types.ts +135 -0
- package/src/common/types/escrow-account.types.ts +104 -0
- package/src/common/types/exchange-api-key.types.ts +121 -0
- package/src/common/types/exchange-import.types.ts +36 -0
- package/src/common/types/exchange-provider.types.ts +329 -0
- package/src/common/types/file.types.ts +461 -0
- package/src/common/types/files.types.spec.ts +154 -0
- package/src/common/types/health.types.ts +29 -0
- package/src/common/types/index.ts +48 -0
- package/src/common/types/individuals.types.ts +554 -0
- package/src/common/types/investor-account.types.ts +1239 -0
- package/src/common/types/investorAccountIdSchema.type.ts +0 -0
- package/src/common/types/investors-offering.types.ts +65 -0
- package/src/common/types/invite.types.ts +133 -0
- package/src/common/types/issuer-bank-account.types.ts +107 -0
- package/src/common/types/issuer-offering.types.ts +306 -0
- package/src/common/types/issuer-payment-method.types.spec.ts +612 -0
- package/src/common/types/issuer-payment-method.types.ts +341 -0
- package/src/common/types/issuer.types.ts +312 -0
- package/src/common/types/job-item.types.ts +119 -0
- package/src/common/types/jobs.types.ts +171 -0
- package/src/common/types/kyb.types.ts +53 -0
- package/src/common/types/kyc.types.ts +188 -0
- package/src/common/types/legal-entity.types.ts +185 -0
- package/src/common/types/login-history.types.ts +46 -0
- package/src/common/types/mail-template.types.ts +436 -0
- package/src/common/types/north-cap-integration.types.ts +190 -0
- package/src/common/types/note.types.ts +109 -0
- package/src/common/types/notification.types.ts +58 -0
- package/src/common/types/notion-api.types.ts +374 -0
- package/src/common/types/notion-database.types.ts +125 -0
- package/src/common/types/notion-page.types.ts +267 -0
- package/src/common/types/offering-reports.types.ts +153 -0
- package/src/common/types/offering-submission.types.ts +314 -0
- package/src/common/types/offering.types.spec.ts +91 -0
- package/src/common/types/offering.types.ts +590 -0
- package/src/common/types/page-revision.types.ts +86 -0
- package/src/common/types/page.types.ts +436 -0
- package/src/common/types/password.type.ts +15 -0
- package/src/common/types/payment-methods.types.ts +298 -0
- package/src/common/types/phone.spec.ts +76 -0
- package/src/common/types/phone.type.ts +27 -0
- package/src/common/types/portfolio.types.ts +50 -0
- package/src/common/types/privacy-policy-and-tos.types.ts +231 -0
- package/src/common/types/queue.types.ts +112 -0
- package/src/common/types/registered-reps.types.ts +25 -0
- package/src/common/types/rejection-reasons.types.ts +56 -0
- package/src/common/types/reminder-config.types.ts +40 -0
- package/src/common/types/review.types.ts +133 -0
- package/src/common/types/role.types.ts +26 -0
- package/src/common/types/secondary-customer.types.ts +66 -0
- package/src/common/types/secondary-issuer.types.ts +50 -0
- package/src/common/types/secondary-order.types.ts +58 -0
- package/src/common/types/secondary-security.types.ts +60 -0
- package/src/common/types/secondary-trade.entity.ts +16 -0
- package/src/common/types/secondary-trade.types.ts +95 -0
- package/src/common/types/secure-request.types.ts +68 -0
- package/src/common/types/signer.types.ts +651 -0
- package/src/common/types/site-link.types.spec.ts +134 -0
- package/src/common/types/site-link.types.ts +166 -0
- package/src/common/types/site-settings.types.ts +726 -0
- package/src/common/types/site.types.ts +270 -0
- package/src/common/types/sms.types.ts +30 -0
- package/src/common/types/state-machine.types.ts +177 -0
- package/src/common/types/states.types.ts +163 -0
- package/src/common/types/subdoc-preview.types.ts +35 -0
- package/src/common/types/task.types.ts +258 -0
- package/src/common/types/trade-adjustment.type.ts +33 -0
- package/src/common/types/trade-line-item.type.ts +132 -0
- package/src/common/types/trade.types.ts +912 -0
- package/src/common/types/transaction.types.ts +198 -0
- package/src/common/types/trusted-contact.types.ts +122 -0
- package/src/common/types/typography.types.ts +75 -0
- package/src/common/types/user-manual.types.ts +290 -0
- package/src/common/types/user-setting.types.ts +133 -0
- package/src/common/types/user.types.ts +320 -0
- package/src/common/types/webhook.types.ts +588 -0
- package/src/common/types/zip.type.ts +36 -0
- package/src/contracts/clients/accounts/index.ts +61 -0
- package/src/contracts/clients/aic/index.ts +59 -0
- package/src/contracts/clients/api-key-logs/index.ts +53 -0
- package/src/contracts/clients/api-keys/index.ts +73 -0
- package/src/contracts/clients/assets/index.ts +102 -0
- package/src/contracts/clients/auth/index.ts +50 -0
- package/src/contracts/clients/files/index.ts +166 -0
- package/src/contracts/clients/files-public/index.ts +166 -0
- package/src/contracts/clients/index.ts +44 -0
- package/src/contracts/clients/individuals/index.ts +93 -0
- package/src/contracts/clients/investor-accounts/index.ts +93 -0
- package/src/contracts/clients/issuers/index.ts +94 -0
- package/src/contracts/clients/legal-entities/index.ts +93 -0
- package/src/contracts/clients/offerings/index.ts +117 -0
- package/src/contracts/clients/secure-requests/index.ts +34 -0
- package/src/contracts/clients/sites/index.ts +56 -0
- package/src/contracts/clients/trades/index.ts +122 -0
- package/dist/contracts/clients/index.d.ts +0 -19
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { initContract } from '@ts-rest/core';
|
|
2
|
+
import {
|
|
3
|
+
ForbiddenError,
|
|
4
|
+
IPaginatedIndividual,
|
|
5
|
+
NotFoundError,
|
|
6
|
+
PaginationOptionsZod,
|
|
7
|
+
UnauthorizedError,
|
|
8
|
+
IndividualFiltersZod,
|
|
9
|
+
IndividualsIncludeQuery,
|
|
10
|
+
individualIdSchema,
|
|
11
|
+
PostIndividualBodySchema,
|
|
12
|
+
UpdateIndividualBodySchema,
|
|
13
|
+
IndividualResponseSchema,
|
|
14
|
+
IIndividualZod,
|
|
15
|
+
} from '../../../common/types';
|
|
16
|
+
import { z } from 'zod';
|
|
17
|
+
|
|
18
|
+
const c = initContract();
|
|
19
|
+
|
|
20
|
+
export const individualsContract = c.router(
|
|
21
|
+
{
|
|
22
|
+
createIndividual: {
|
|
23
|
+
summary: 'Create individual',
|
|
24
|
+
method: 'POST',
|
|
25
|
+
path: '/',
|
|
26
|
+
body: PostIndividualBodySchema,
|
|
27
|
+
metadata: {
|
|
28
|
+
auth: true,
|
|
29
|
+
},
|
|
30
|
+
responses: {
|
|
31
|
+
201: IndividualResponseSchema,
|
|
32
|
+
401: UnauthorizedError,
|
|
33
|
+
403: ForbiddenError,
|
|
34
|
+
404: NotFoundError,
|
|
35
|
+
},
|
|
36
|
+
},
|
|
37
|
+
updateIndividual: {
|
|
38
|
+
summary: 'Update individual',
|
|
39
|
+
method: 'PATCH',
|
|
40
|
+
path: '/:id',
|
|
41
|
+
pathParams: z.object({
|
|
42
|
+
id: individualIdSchema,
|
|
43
|
+
}),
|
|
44
|
+
body: UpdateIndividualBodySchema,
|
|
45
|
+
metadata: {
|
|
46
|
+
auth: true,
|
|
47
|
+
},
|
|
48
|
+
responses: {
|
|
49
|
+
201: IndividualResponseSchema,
|
|
50
|
+
401: UnauthorizedError,
|
|
51
|
+
403: ForbiddenError,
|
|
52
|
+
404: NotFoundError,
|
|
53
|
+
},
|
|
54
|
+
},
|
|
55
|
+
getIndividual: {
|
|
56
|
+
summary: 'Get individual by id',
|
|
57
|
+
method: 'GET',
|
|
58
|
+
path: '/:id',
|
|
59
|
+
metadata: {
|
|
60
|
+
auth: true,
|
|
61
|
+
},
|
|
62
|
+
query: z.object({}).merge(IndividualsIncludeQuery),
|
|
63
|
+
pathParams: z.object({
|
|
64
|
+
id: individualIdSchema,
|
|
65
|
+
}),
|
|
66
|
+
responses: {
|
|
67
|
+
200: IIndividualZod,
|
|
68
|
+
401: UnauthorizedError,
|
|
69
|
+
403: ForbiddenError,
|
|
70
|
+
404: NotFoundError,
|
|
71
|
+
},
|
|
72
|
+
},
|
|
73
|
+
getIndividuals: {
|
|
74
|
+
summary: 'Get individuals',
|
|
75
|
+
method: 'GET',
|
|
76
|
+
path: '',
|
|
77
|
+
metadata: {
|
|
78
|
+
auth: true,
|
|
79
|
+
},
|
|
80
|
+
query: PaginationOptionsZod.merge(IndividualFiltersZod).merge(
|
|
81
|
+
IndividualsIncludeQuery,
|
|
82
|
+
),
|
|
83
|
+
responses: {
|
|
84
|
+
200: IPaginatedIndividual,
|
|
85
|
+
401: UnauthorizedError,
|
|
86
|
+
403: ForbiddenError,
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
pathPrefix: 'individuals',
|
|
92
|
+
},
|
|
93
|
+
);
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { initContract } from '@ts-rest/core';
|
|
2
|
+
import {
|
|
3
|
+
ForbiddenError,
|
|
4
|
+
NotFoundError,
|
|
5
|
+
PaginationOptionsZod,
|
|
6
|
+
UnauthorizedError,
|
|
7
|
+
} from '../../../common/types';
|
|
8
|
+
import { z } from 'zod';
|
|
9
|
+
import {
|
|
10
|
+
IInvestorAccount,
|
|
11
|
+
investorAccountIdSchema,
|
|
12
|
+
InvestorAccountsFiltersZod,
|
|
13
|
+
InvestorAccountsIncludeQuery,
|
|
14
|
+
InvestorUpdatePathParamsSchema,
|
|
15
|
+
IPaginatedInvestorAccounts,
|
|
16
|
+
PostClientInvestorAccountBodySchema,
|
|
17
|
+
UpdateInvestorAccountBodySchema,
|
|
18
|
+
} from '../../../common/types/investor-account.types';
|
|
19
|
+
|
|
20
|
+
const c = initContract();
|
|
21
|
+
|
|
22
|
+
export const investorAccountsContract = c.router(
|
|
23
|
+
{
|
|
24
|
+
createInvestorAccount: {
|
|
25
|
+
summary: 'Create investor account ',
|
|
26
|
+
method: 'POST',
|
|
27
|
+
path: '',
|
|
28
|
+
metadata: {
|
|
29
|
+
auth: true,
|
|
30
|
+
},
|
|
31
|
+
body: PostClientInvestorAccountBodySchema,
|
|
32
|
+
responses: {
|
|
33
|
+
201: IInvestorAccount,
|
|
34
|
+
401: UnauthorizedError,
|
|
35
|
+
403: ForbiddenError,
|
|
36
|
+
404: NotFoundError,
|
|
37
|
+
},
|
|
38
|
+
},
|
|
39
|
+
updateInvestorAccount: {
|
|
40
|
+
summary: 'Update investor account ',
|
|
41
|
+
method: 'PATCH',
|
|
42
|
+
path: '/:id',
|
|
43
|
+
metadata: {
|
|
44
|
+
auth: true,
|
|
45
|
+
},
|
|
46
|
+
pathParams: InvestorUpdatePathParamsSchema,
|
|
47
|
+
body: UpdateInvestorAccountBodySchema,
|
|
48
|
+
responses: {
|
|
49
|
+
201: IInvestorAccount,
|
|
50
|
+
401: UnauthorizedError,
|
|
51
|
+
403: ForbiddenError,
|
|
52
|
+
404: NotFoundError,
|
|
53
|
+
},
|
|
54
|
+
},
|
|
55
|
+
getInvestorAccount: {
|
|
56
|
+
summary: 'Get investor account by id',
|
|
57
|
+
method: 'GET',
|
|
58
|
+
path: '/:id',
|
|
59
|
+
metadata: {
|
|
60
|
+
auth: true,
|
|
61
|
+
},
|
|
62
|
+
query: z.object({}).merge(InvestorAccountsIncludeQuery),
|
|
63
|
+
pathParams: z.object({
|
|
64
|
+
id: investorAccountIdSchema,
|
|
65
|
+
}),
|
|
66
|
+
responses: {
|
|
67
|
+
200: IInvestorAccount,
|
|
68
|
+
401: UnauthorizedError,
|
|
69
|
+
403: ForbiddenError,
|
|
70
|
+
404: NotFoundError,
|
|
71
|
+
},
|
|
72
|
+
},
|
|
73
|
+
getInvestorAccounts: {
|
|
74
|
+
summary: 'Get investor accounts',
|
|
75
|
+
method: 'GET',
|
|
76
|
+
path: '',
|
|
77
|
+
metadata: {
|
|
78
|
+
auth: true,
|
|
79
|
+
},
|
|
80
|
+
query: PaginationOptionsZod.merge(InvestorAccountsIncludeQuery).merge(
|
|
81
|
+
InvestorAccountsFiltersZod,
|
|
82
|
+
),
|
|
83
|
+
responses: {
|
|
84
|
+
200: IPaginatedInvestorAccounts,
|
|
85
|
+
401: UnauthorizedError,
|
|
86
|
+
403: ForbiddenError,
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
pathPrefix: 'investor-accounts',
|
|
92
|
+
},
|
|
93
|
+
);
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { initContract } from '@ts-rest/core';
|
|
2
|
+
import { z } from 'zod';
|
|
3
|
+
import {
|
|
4
|
+
BadRequestError,
|
|
5
|
+
ForbiddenError,
|
|
6
|
+
InternalError,
|
|
7
|
+
NotFoundError,
|
|
8
|
+
PaginationOptionsZod,
|
|
9
|
+
UnauthorizedError,
|
|
10
|
+
} from '../../../common/types';
|
|
11
|
+
import {
|
|
12
|
+
GetIssuersZod,
|
|
13
|
+
IIssuer,
|
|
14
|
+
IPaginatedIssuer,
|
|
15
|
+
IssuersIncludeQuery,
|
|
16
|
+
issuerIdSchema,
|
|
17
|
+
PostIssuerZod,
|
|
18
|
+
PutIssuerZod,
|
|
19
|
+
} from '../../../common/types/issuer.types';
|
|
20
|
+
const c = initContract();
|
|
21
|
+
|
|
22
|
+
export const issuersContract = c.router(
|
|
23
|
+
{
|
|
24
|
+
getIssuers: {
|
|
25
|
+
summary: 'Get Issuers',
|
|
26
|
+
method: 'GET',
|
|
27
|
+
path: '',
|
|
28
|
+
metadata: {
|
|
29
|
+
auth: true,
|
|
30
|
+
},
|
|
31
|
+
query:
|
|
32
|
+
PaginationOptionsZod.merge(IssuersIncludeQuery).merge(GetIssuersZod),
|
|
33
|
+
responses: {
|
|
34
|
+
200: IPaginatedIssuer,
|
|
35
|
+
401: UnauthorizedError,
|
|
36
|
+
403: ForbiddenError,
|
|
37
|
+
},
|
|
38
|
+
},
|
|
39
|
+
postIssuer: {
|
|
40
|
+
summary: 'Create an issuer',
|
|
41
|
+
method: 'POST',
|
|
42
|
+
path: '',
|
|
43
|
+
metadata: {
|
|
44
|
+
auth: true,
|
|
45
|
+
},
|
|
46
|
+
body: PostIssuerZod,
|
|
47
|
+
responses: {
|
|
48
|
+
201: IIssuer,
|
|
49
|
+
401: UnauthorizedError,
|
|
50
|
+
403: ForbiddenError,
|
|
51
|
+
500: InternalError,
|
|
52
|
+
},
|
|
53
|
+
},
|
|
54
|
+
getIssuer: {
|
|
55
|
+
summary: 'Get issuer by id',
|
|
56
|
+
method: 'GET',
|
|
57
|
+
path: '/:id',
|
|
58
|
+
metadata: {
|
|
59
|
+
auth: true,
|
|
60
|
+
},
|
|
61
|
+
query: z.object({}).merge(IssuersIncludeQuery),
|
|
62
|
+
pathParams: z.object({ id: issuerIdSchema }),
|
|
63
|
+
responses: {
|
|
64
|
+
200: IIssuer,
|
|
65
|
+
401: UnauthorizedError,
|
|
66
|
+
403: ForbiddenError,
|
|
67
|
+
404: NotFoundError,
|
|
68
|
+
},
|
|
69
|
+
},
|
|
70
|
+
updateIssuer: {
|
|
71
|
+
summary: 'Update issuer',
|
|
72
|
+
method: 'PUT',
|
|
73
|
+
path: '/:id',
|
|
74
|
+
metadata: {
|
|
75
|
+
auth: true,
|
|
76
|
+
},
|
|
77
|
+
pathParams: z.object({
|
|
78
|
+
id: issuerIdSchema,
|
|
79
|
+
}),
|
|
80
|
+
body: PutIssuerZod,
|
|
81
|
+
responses: {
|
|
82
|
+
201: IIssuer,
|
|
83
|
+
400: BadRequestError,
|
|
84
|
+
401: UnauthorizedError,
|
|
85
|
+
403: ForbiddenError,
|
|
86
|
+
404: NotFoundError,
|
|
87
|
+
500: InternalError,
|
|
88
|
+
},
|
|
89
|
+
},
|
|
90
|
+
},
|
|
91
|
+
{
|
|
92
|
+
pathPrefix: 'issuers',
|
|
93
|
+
},
|
|
94
|
+
);
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { initContract } from '@ts-rest/core';
|
|
2
|
+
import {
|
|
3
|
+
PostLegalEntitySchema,
|
|
4
|
+
ResponseLegalEntitySchema,
|
|
5
|
+
UnauthorizedError,
|
|
6
|
+
ForbiddenError,
|
|
7
|
+
legalEntityIdSchema,
|
|
8
|
+
UpdateLegalEntitySchema,
|
|
9
|
+
LegalEntitiesIncludeQuery,
|
|
10
|
+
LegalEntityZod,
|
|
11
|
+
PaginationOptionsZod,
|
|
12
|
+
LegalEntityFiltersZod,
|
|
13
|
+
IPaginatedLegalEntity,
|
|
14
|
+
NotFoundError,
|
|
15
|
+
} from '../../../common/types';
|
|
16
|
+
import { z } from 'zod';
|
|
17
|
+
|
|
18
|
+
const c = initContract();
|
|
19
|
+
|
|
20
|
+
export const legalEntityContract = c.router(
|
|
21
|
+
{
|
|
22
|
+
createLegalEntity: {
|
|
23
|
+
summary: 'Create Legal Entity',
|
|
24
|
+
method: 'POST',
|
|
25
|
+
path: '/',
|
|
26
|
+
body: PostLegalEntitySchema,
|
|
27
|
+
metadata: {
|
|
28
|
+
auth: true,
|
|
29
|
+
},
|
|
30
|
+
responses: {
|
|
31
|
+
201: ResponseLegalEntitySchema,
|
|
32
|
+
401: UnauthorizedError,
|
|
33
|
+
403: ForbiddenError,
|
|
34
|
+
404: NotFoundError,
|
|
35
|
+
},
|
|
36
|
+
},
|
|
37
|
+
updateLegalEntity: {
|
|
38
|
+
summary: 'Update Legal Entity',
|
|
39
|
+
method: 'PATCH',
|
|
40
|
+
path: '/:id',
|
|
41
|
+
pathParams: z.object({
|
|
42
|
+
id: legalEntityIdSchema,
|
|
43
|
+
}),
|
|
44
|
+
body: UpdateLegalEntitySchema,
|
|
45
|
+
metadata: {
|
|
46
|
+
auth: true,
|
|
47
|
+
},
|
|
48
|
+
responses: {
|
|
49
|
+
200: ResponseLegalEntitySchema,
|
|
50
|
+
401: UnauthorizedError,
|
|
51
|
+
403: ForbiddenError,
|
|
52
|
+
404: NotFoundError,
|
|
53
|
+
},
|
|
54
|
+
},
|
|
55
|
+
getLegalEntity: {
|
|
56
|
+
summary: 'Get legalEntity by id',
|
|
57
|
+
method: 'GET',
|
|
58
|
+
path: '/:id',
|
|
59
|
+
metadata: {
|
|
60
|
+
auth: true,
|
|
61
|
+
},
|
|
62
|
+
query: z.object({}).merge(LegalEntitiesIncludeQuery),
|
|
63
|
+
pathParams: z.object({
|
|
64
|
+
id: legalEntityIdSchema,
|
|
65
|
+
}),
|
|
66
|
+
responses: {
|
|
67
|
+
200: LegalEntityZod,
|
|
68
|
+
401: UnauthorizedError,
|
|
69
|
+
403: ForbiddenError,
|
|
70
|
+
404: NotFoundError,
|
|
71
|
+
},
|
|
72
|
+
},
|
|
73
|
+
getLegalEntities: {
|
|
74
|
+
summary: 'Get legalEntities',
|
|
75
|
+
method: 'GET',
|
|
76
|
+
path: '/',
|
|
77
|
+
metadata: {
|
|
78
|
+
auth: true,
|
|
79
|
+
},
|
|
80
|
+
query: PaginationOptionsZod.merge(LegalEntityFiltersZod).merge(
|
|
81
|
+
LegalEntitiesIncludeQuery,
|
|
82
|
+
),
|
|
83
|
+
responses: {
|
|
84
|
+
200: IPaginatedLegalEntity,
|
|
85
|
+
401: UnauthorizedError,
|
|
86
|
+
403: ForbiddenError,
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
pathPrefix: 'legal-entities',
|
|
92
|
+
},
|
|
93
|
+
);
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { initContract } from '@ts-rest/core';
|
|
2
|
+
import { z } from 'zod';
|
|
3
|
+
import {
|
|
4
|
+
BadRequestError,
|
|
5
|
+
ForbiddenError,
|
|
6
|
+
InternalError,
|
|
7
|
+
IOffering,
|
|
8
|
+
IPaginatedOffering,
|
|
9
|
+
NotFoundError,
|
|
10
|
+
OfferingFiltersZod,
|
|
11
|
+
offeringIdSchema,
|
|
12
|
+
OfferingsIncludeQuery,
|
|
13
|
+
OfferingSummaryFiltersZod,
|
|
14
|
+
PaginatedOfferingSummaryResponseZod,
|
|
15
|
+
PaginationOptionsZod,
|
|
16
|
+
PatchIssuerOffering,
|
|
17
|
+
PostIssuerOffering,
|
|
18
|
+
UnauthorizedError,
|
|
19
|
+
} from '../../../common/types';
|
|
20
|
+
|
|
21
|
+
const c = initContract();
|
|
22
|
+
|
|
23
|
+
export const offeringsContract = c.router(
|
|
24
|
+
{
|
|
25
|
+
getOfferings: {
|
|
26
|
+
summary: 'Get offerings',
|
|
27
|
+
method: 'GET',
|
|
28
|
+
path: '',
|
|
29
|
+
metadata: {
|
|
30
|
+
auth: true,
|
|
31
|
+
},
|
|
32
|
+
query: PaginationOptionsZod.merge(OfferingsIncludeQuery).merge(
|
|
33
|
+
OfferingFiltersZod,
|
|
34
|
+
),
|
|
35
|
+
responses: {
|
|
36
|
+
200: IPaginatedOffering,
|
|
37
|
+
400: BadRequestError,
|
|
38
|
+
401: UnauthorizedError,
|
|
39
|
+
403: ForbiddenError,
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
getOfferingsSummary: {
|
|
43
|
+
summary: 'Get offerings summary',
|
|
44
|
+
method: 'GET',
|
|
45
|
+
path: '/summary',
|
|
46
|
+
metadata: {
|
|
47
|
+
auth: true,
|
|
48
|
+
},
|
|
49
|
+
query: PaginationOptionsZod.merge(OfferingSummaryFiltersZod),
|
|
50
|
+
responses: {
|
|
51
|
+
200: PaginatedOfferingSummaryResponseZod,
|
|
52
|
+
400: BadRequestError,
|
|
53
|
+
401: UnauthorizedError,
|
|
54
|
+
403: ForbiddenError,
|
|
55
|
+
500: InternalError,
|
|
56
|
+
},
|
|
57
|
+
},
|
|
58
|
+
getOffering: {
|
|
59
|
+
summary: 'Get offering by id',
|
|
60
|
+
method: 'GET',
|
|
61
|
+
path: '/:id',
|
|
62
|
+
metadata: {
|
|
63
|
+
auth: true,
|
|
64
|
+
},
|
|
65
|
+
query: z.object({}).merge(OfferingsIncludeQuery),
|
|
66
|
+
pathParams: z.object({
|
|
67
|
+
id: offeringIdSchema,
|
|
68
|
+
}),
|
|
69
|
+
responses: {
|
|
70
|
+
200: IOffering,
|
|
71
|
+
400: BadRequestError,
|
|
72
|
+
401: UnauthorizedError,
|
|
73
|
+
403: ForbiddenError,
|
|
74
|
+
404: NotFoundError,
|
|
75
|
+
},
|
|
76
|
+
},
|
|
77
|
+
patchOffering: {
|
|
78
|
+
summary: 'Update offering by id',
|
|
79
|
+
method: 'PATCH',
|
|
80
|
+
path: '/:id',
|
|
81
|
+
metadata: {
|
|
82
|
+
auth: true,
|
|
83
|
+
},
|
|
84
|
+
pathParams: z.object({
|
|
85
|
+
id: offeringIdSchema,
|
|
86
|
+
}),
|
|
87
|
+
body: PatchIssuerOffering,
|
|
88
|
+
responses: {
|
|
89
|
+
201: IOffering,
|
|
90
|
+
400: BadRequestError,
|
|
91
|
+
401: UnauthorizedError,
|
|
92
|
+
403: ForbiddenError,
|
|
93
|
+
404: NotFoundError,
|
|
94
|
+
500: InternalError,
|
|
95
|
+
},
|
|
96
|
+
},
|
|
97
|
+
postOffering: {
|
|
98
|
+
summary: '[ADMIN] Create offering',
|
|
99
|
+
method: 'POST',
|
|
100
|
+
path: '',
|
|
101
|
+
metadata: {
|
|
102
|
+
auth: true,
|
|
103
|
+
},
|
|
104
|
+
body: PostIssuerOffering,
|
|
105
|
+
responses: {
|
|
106
|
+
201: IOffering,
|
|
107
|
+
400: BadRequestError,
|
|
108
|
+
401: UnauthorizedError,
|
|
109
|
+
403: ForbiddenError,
|
|
110
|
+
500: InternalError,
|
|
111
|
+
},
|
|
112
|
+
},
|
|
113
|
+
},
|
|
114
|
+
{
|
|
115
|
+
pathPrefix: 'offerings',
|
|
116
|
+
},
|
|
117
|
+
);
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { initContract } from '@ts-rest/core';
|
|
2
|
+
import {
|
|
3
|
+
NotFoundError,
|
|
4
|
+
UnauthorizedError,
|
|
5
|
+
InternalError,
|
|
6
|
+
BadRequestError,
|
|
7
|
+
} from '../../../common/types';
|
|
8
|
+
import {
|
|
9
|
+
PostSecureRequestBody,
|
|
10
|
+
SecureRequestZod,
|
|
11
|
+
} from '../../../common/types/secure-request.types';
|
|
12
|
+
|
|
13
|
+
const c = initContract();
|
|
14
|
+
|
|
15
|
+
export const secureRequestContract = c.router(
|
|
16
|
+
{
|
|
17
|
+
postSecureRequest: {
|
|
18
|
+
summary: 'Create Secure Request',
|
|
19
|
+
method: 'POST',
|
|
20
|
+
path: '/',
|
|
21
|
+
body: PostSecureRequestBody,
|
|
22
|
+
responses: {
|
|
23
|
+
202: SecureRequestZod,
|
|
24
|
+
400: BadRequestError,
|
|
25
|
+
401: UnauthorizedError,
|
|
26
|
+
404: NotFoundError,
|
|
27
|
+
500: InternalError,
|
|
28
|
+
},
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
pathPrefix: 'secure-request',
|
|
33
|
+
},
|
|
34
|
+
);
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { initContract } from '@ts-rest/core';
|
|
2
|
+
import {
|
|
3
|
+
ForbiddenError,
|
|
4
|
+
NotFoundError,
|
|
5
|
+
PaginationOptionsZod,
|
|
6
|
+
UnauthorizedError,
|
|
7
|
+
} from '../../../common/types';
|
|
8
|
+
import {
|
|
9
|
+
SitesFiltersZod,
|
|
10
|
+
SitesIncludeQuery,
|
|
11
|
+
SitesPaginated,
|
|
12
|
+
SitesParamSchema,
|
|
13
|
+
SiteZod,
|
|
14
|
+
} from '../../../common/types/site.types';
|
|
15
|
+
|
|
16
|
+
const c = initContract();
|
|
17
|
+
|
|
18
|
+
export const sitesContract = c.router(
|
|
19
|
+
{
|
|
20
|
+
getSite: {
|
|
21
|
+
summary: 'get site by id',
|
|
22
|
+
method: 'GET',
|
|
23
|
+
path: '/:id',
|
|
24
|
+
pathParams: SitesParamSchema,
|
|
25
|
+
metadata: {
|
|
26
|
+
auth: true,
|
|
27
|
+
},
|
|
28
|
+
query: SitesIncludeQuery.merge(SitesFiltersZod),
|
|
29
|
+
responses: {
|
|
30
|
+
200: SiteZod,
|
|
31
|
+
401: UnauthorizedError,
|
|
32
|
+
403: ForbiddenError,
|
|
33
|
+
404: NotFoundError,
|
|
34
|
+
},
|
|
35
|
+
},
|
|
36
|
+
getSites: {
|
|
37
|
+
summary: 'query sites by url',
|
|
38
|
+
method: 'GET',
|
|
39
|
+
path: '/',
|
|
40
|
+
metadata: {
|
|
41
|
+
auth: true,
|
|
42
|
+
},
|
|
43
|
+
query:
|
|
44
|
+
PaginationOptionsZod.merge(SitesFiltersZod).merge(SitesIncludeQuery),
|
|
45
|
+
responses: {
|
|
46
|
+
200: SitesPaginated,
|
|
47
|
+
401: UnauthorizedError,
|
|
48
|
+
403: ForbiddenError,
|
|
49
|
+
404: NotFoundError,
|
|
50
|
+
},
|
|
51
|
+
},
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
pathPrefix: 'sites',
|
|
55
|
+
},
|
|
56
|
+
);
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { initContract } from '@ts-rest/core';
|
|
2
|
+
import {
|
|
3
|
+
BadRequestError,
|
|
4
|
+
ForbiddenError,
|
|
5
|
+
InternalError,
|
|
6
|
+
NotFoundError,
|
|
7
|
+
PaginationOptionsZod,
|
|
8
|
+
UnauthorizedError,
|
|
9
|
+
} from '../../../common/types';
|
|
10
|
+
import {
|
|
11
|
+
InvestorsTradeResponse,
|
|
12
|
+
IPaginatedTrade,
|
|
13
|
+
IssuersTradeFiltersZod,
|
|
14
|
+
PatchTradeStatus,
|
|
15
|
+
PostTradeBody,
|
|
16
|
+
tradeIdOrTidSchema,
|
|
17
|
+
TradesIncludeQuery,
|
|
18
|
+
TradeZod,
|
|
19
|
+
} from '../../../common/types/trade.types';
|
|
20
|
+
import { z } from 'zod';
|
|
21
|
+
import {
|
|
22
|
+
PostTradeLineItem,
|
|
23
|
+
TradeLineItemQuery,
|
|
24
|
+
TradeLineItemResponse,
|
|
25
|
+
} from '../../../common/types/trade-line-item.type';
|
|
26
|
+
|
|
27
|
+
const c = initContract();
|
|
28
|
+
|
|
29
|
+
export const tradesContract = c.router(
|
|
30
|
+
{
|
|
31
|
+
getTrade: {
|
|
32
|
+
summary: 'Get trade by id - id could be either the entity id or tid',
|
|
33
|
+
method: 'GET',
|
|
34
|
+
path: '/:id',
|
|
35
|
+
metadata: {
|
|
36
|
+
auth: true,
|
|
37
|
+
},
|
|
38
|
+
query: z
|
|
39
|
+
.object({})
|
|
40
|
+
.merge(IssuersTradeFiltersZod)
|
|
41
|
+
.merge(TradesIncludeQuery),
|
|
42
|
+
pathParams: z.object({
|
|
43
|
+
id: tradeIdOrTidSchema,
|
|
44
|
+
}),
|
|
45
|
+
responses: {
|
|
46
|
+
200: TradeZod,
|
|
47
|
+
401: UnauthorizedError,
|
|
48
|
+
403: ForbiddenError,
|
|
49
|
+
404: NotFoundError,
|
|
50
|
+
},
|
|
51
|
+
},
|
|
52
|
+
getTrades: {
|
|
53
|
+
summary: 'Get trades',
|
|
54
|
+
method: 'GET',
|
|
55
|
+
path: '',
|
|
56
|
+
metadata: {
|
|
57
|
+
auth: true,
|
|
58
|
+
},
|
|
59
|
+
query: PaginationOptionsZod.merge(IssuersTradeFiltersZod).merge(
|
|
60
|
+
TradesIncludeQuery,
|
|
61
|
+
),
|
|
62
|
+
responses: {
|
|
63
|
+
200: IPaginatedTrade,
|
|
64
|
+
401: UnauthorizedError,
|
|
65
|
+
403: ForbiddenError,
|
|
66
|
+
},
|
|
67
|
+
},
|
|
68
|
+
createTrades: {
|
|
69
|
+
summary: 'Create Trades',
|
|
70
|
+
method: 'POST',
|
|
71
|
+
path: '/',
|
|
72
|
+
metadata: {
|
|
73
|
+
auth: true,
|
|
74
|
+
},
|
|
75
|
+
body: PostTradeBody,
|
|
76
|
+
responses: {
|
|
77
|
+
201: InvestorsTradeResponse,
|
|
78
|
+
401: UnauthorizedError,
|
|
79
|
+
403: ForbiddenError,
|
|
80
|
+
},
|
|
81
|
+
},
|
|
82
|
+
postLineItem: {
|
|
83
|
+
summary: 'Create a Line Item',
|
|
84
|
+
method: 'POST',
|
|
85
|
+
path: '/line-items',
|
|
86
|
+
metadata: {
|
|
87
|
+
auth: true,
|
|
88
|
+
},
|
|
89
|
+
query: TradeLineItemQuery,
|
|
90
|
+
body: PostTradeLineItem,
|
|
91
|
+
responses: {
|
|
92
|
+
201: TradeLineItemResponse,
|
|
93
|
+
401: UnauthorizedError,
|
|
94
|
+
403: ForbiddenError,
|
|
95
|
+
400: BadRequestError,
|
|
96
|
+
500: InternalError,
|
|
97
|
+
},
|
|
98
|
+
},
|
|
99
|
+
patchTradeStatus: {
|
|
100
|
+
summary: 'Patch a trade status',
|
|
101
|
+
method: 'PATCH',
|
|
102
|
+
path: '/:id',
|
|
103
|
+
pathParams: z.object({
|
|
104
|
+
id: tradeIdOrTidSchema,
|
|
105
|
+
}),
|
|
106
|
+
metadata: {
|
|
107
|
+
auth: true,
|
|
108
|
+
},
|
|
109
|
+
body: PatchTradeStatus,
|
|
110
|
+
responses: {
|
|
111
|
+
201: TradeZod,
|
|
112
|
+
401: UnauthorizedError,
|
|
113
|
+
403: ForbiddenError,
|
|
114
|
+
400: BadRequestError,
|
|
115
|
+
500: InternalError,
|
|
116
|
+
},
|
|
117
|
+
},
|
|
118
|
+
},
|
|
119
|
+
{
|
|
120
|
+
pathPrefix: 'trades',
|
|
121
|
+
},
|
|
122
|
+
);
|