diff --git a/.github/workflows/build-test.yml b/.github/workflows/build-test.yml index b8d8376..97c7f70 100644 --- a/.github/workflows/build-test.yml +++ b/.github/workflows/build-test.yml @@ -4,12 +4,12 @@ on: push: branches: - main - - v1.X + - v1.x - release/beta pull_request: branches: - main - - v1.X + - v1.x - release/beta concurrency: diff --git a/.github/workflows/linting.yml b/.github/workflows/linting.yml index 9a2a5a9..5f80f12 100644 --- a/.github/workflows/linting.yml +++ b/.github/workflows/linting.yml @@ -4,12 +4,12 @@ on: push: branches: - main - - v1.X + - v1.x - release/beta pull_request: branches: - main - - v1.X + - v1.x - release/beta concurrency: diff --git a/.github/workflows/publish-latest.yml b/.github/workflows/publish-latest.yml index c0a1923..c5758e6 100644 --- a/.github/workflows/publish-latest.yml +++ b/.github/workflows/publish-latest.yml @@ -4,6 +4,7 @@ on: push: branches: - main + - v1.x jobs: run-publish: diff --git a/CHANGELOG.md b/CHANGELOG.md index 6c890ed..df30a4a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -12,6 +12,15 @@ When we make [non-breaking changes](https://developer.paddle.com/api-reference/a This means when upgrading minor versions of the SDK, you may notice type errors. You can safely ignore these or fix by adding additional type guards. +## 1.8.0 - 2024-10-08 + +### Added + +- Added `simulationTypes` resources +- Added `simulations` resources +- Added `simulationRuns` resources +- Added `simulationRunEvents` resources + ## 1.7.0 - 2024-09-18 ### Fixed @@ -23,7 +32,7 @@ This means when upgrading minor versions of the SDK, you may notice type errors. ## 1.6.0 - 2024-09-16 ### Added - + - Added `adjustments.getCreditNotePDF()` to [get a credit note for an adjustment](https://developer.paddle.com/api-reference/adjustments/get-credit-note-pdf?utm_source=dx&utm_medium=paddle-node-sdk) - Added `disposition` query parameter to `adjustments.getCreditNotePDF()` and `transactions.getInvoicePDF()` operations, see [related changelog](https://developer.paddle.com/changelog/2024/invoice-pdf-open-in-browser?utm_source=dx&utm_medium=paddle-node-sdk). - Added pagination support to `notificationSettings.list()` operation, see [related changelog](https://developer.paddle.com/changelog/2024/notification-settings-pagination?utm_source=dx&utm_medium=paddle-node-sdk). @@ -153,7 +162,7 @@ This means when upgrading minor versions of the SDK, you may notice type errors. ### Removed - **Breaking change:** Removed `*Includes` entity in favour of standard entities. - + - Use `Price` instead of `PriceWithIncludes` - Use `Product` instead of `ProductWithIncludes` - Use `Subscription` instead of `SubscriptionIncludes` @@ -213,7 +222,7 @@ This means when upgrading minor versions of the SDK, you may notice type errors. ### Fixed -- Marked `unitPriceOverrides` as optional in Price entity. +- Marked `unitPriceOverrides` as optional in Price entity. --- @@ -273,7 +282,7 @@ This means when upgrading minor versions of the SDK, you may notice type errors. - Added `notificationSettings.get()` to [get a notification settings](https://developer.paddle.com/api-reference/notification-settings/get-notification-setting?utm_source=dx&utm_medium=paddle-node-sdk) - Added `notificationSettings.update()` to [update a notification settings](https://developer.paddle.com/api-reference/notification-settings/update-notification-setting?utm_source=dx&utm_medium=paddle-node-sdk) - Added `notificationSettings.delete()` to [delete a notification settings](https://developer.paddle.com/api-reference/notification-settings/delete-notification-setting?utm_source=dx&utm_medium=paddle-node-sdk) -- Added `notifications.list()` to [list all notifications](https://developer.paddle.com/api-reference/notifications/list-notifications?utm_source=dx&utm_medium=paddle-node-sdk) +- Added `notifications.list()` to [list all notifications](https://developer.paddle.com/api-reference/notifications/list-notifications?utm_source=dx&utm_medium=paddle-node-sdk) - Added `notifications.get()` to [get a notification](https://developer.paddle.com/api-reference/notifications/get-notification?utm_source=dx&utm_medium=paddle-node-sdk) - Added `notifications.replay()` to [replay a notification](https://developer.paddle.com/api-reference/notifications/replay-notification?utm_source=dx&utm_medium=paddle-node-sdk) - Added `notifications.getLogs()` to [get all logs for a notification](https://developer.paddle.com/api-reference/notification-logs/list-notification-logs?utm_source=dx&utm_medium=paddle-node-sdk) @@ -298,7 +307,7 @@ This means when upgrading minor versions of the SDK, you may notice type errors. ### Added - Added helper function to archive supported entities -- Added `pricingPreview.preview()` to [preview calculations for one or more prices](https://developer.paddle.com/api-reference/pricing-preview/preview-prices?utm_source=dx&utm_medium=paddle-node-sdk) +- Added `pricingPreview.preview()` to [preview calculations for one or more prices](https://developer.paddle.com/api-reference/pricing-preview/preview-prices?utm_source=dx&utm_medium=paddle-node-sdk) ### Changed @@ -346,7 +355,7 @@ This means when upgrading minor versions of the SDK, you may notice type errors. - Added changelog. ---- +--- ## 0.1.6 - 2023-11-22 @@ -354,7 +363,7 @@ This means when upgrading minor versions of the SDK, you may notice type errors. - Fixed optional management URL object in subscription entities. ---- +--- ## 0.1.5 - 2023-11-14 diff --git a/package.json b/package.json index 8ce6101..1234641 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@paddle/paddle-node-sdk", - "version": "1.7.0", + "version": "1.8.0", "description": "A Node.js SDK that you can use to integrate Paddle Billing with applications written in server-side JavaScript.", "main": "./dist/cjs/index.js", "module": "./dist/esm/index.js", diff --git a/src/__tests__/mocks/resources/simulation-run-events.mock.ts b/src/__tests__/mocks/resources/simulation-run-events.mock.ts new file mode 100644 index 0000000..cd0ad92 --- /dev/null +++ b/src/__tests__/mocks/resources/simulation-run-events.mock.ts @@ -0,0 +1,39 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { ISimulationRunEventResponse } from '../../../types'; +import { Response, ResponsePaginated } from '../../../internal'; + +export const SimulationRunEventMock: ISimulationRunEventResponse = { + id: 'ntfsimevt_123', + status: 'success', + event_type: 'subscription.created', + payload: {}, + request: null, + response: null, + created_at: '2024-09-18T12:24:47.960617Z', + updated_at: '2024-09-18T12:24:48.309530Z', +}; + +export const SimulationRunEventMockResponse: Response = { + data: SimulationRunEventMock, + meta: { + request_id: '', + }, +}; + +export const ListSimulationRunEventMockResponse: ResponsePaginated = { + data: [SimulationRunEventMock], + meta: { + request_id: '', + pagination: { + estimated_total: 10, + has_more: true, + next: '/simulations/ntfsim_123/runs/ntfsimrun_123/events?after=1', + per_page: 10, + }, + }, +}; diff --git a/src/__tests__/mocks/resources/simulation-runs.mock.ts b/src/__tests__/mocks/resources/simulation-runs.mock.ts new file mode 100644 index 0000000..3d51679 --- /dev/null +++ b/src/__tests__/mocks/resources/simulation-runs.mock.ts @@ -0,0 +1,36 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { ISimulationRunResponse } from '../../../types'; +import { Response, ResponsePaginated } from '../../../internal'; + +export const SimulationRunMock: ISimulationRunResponse = { + id: 'ntfsimrun_01j82gvz2cgw08p7mak3gcd3a3', + status: 'completed', + type: 'subscription_creation', + created_at: '2024-09-18T12:14:15.628606Z', + updated_at: '2024-09-18T12:14:27.244695Z', +}; + +export const SimulationRunMockResponse: Response = { + data: SimulationRunMock, + meta: { + request_id: '', + }, +}; + +export const ListSimulationRunMockResponse: ResponsePaginated = { + data: [SimulationRunMock], + meta: { + request_id: '', + pagination: { + estimated_total: 10, + has_more: true, + next: '/simulations/ntfsim_123/runs?after=1', + per_page: 10, + }, + }, +}; diff --git a/src/__tests__/mocks/resources/simulation-types.mock.ts b/src/__tests__/mocks/resources/simulation-types.mock.ts new file mode 100644 index 0000000..541395b --- /dev/null +++ b/src/__tests__/mocks/resources/simulation-types.mock.ts @@ -0,0 +1,428 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { ISimulationTypeResponse } from '../../../types'; +import { Response } from '../../../internal'; + +export const SimulationTypesMock: ISimulationTypeResponse[] = [ + { + name: 'subscription_creation', + label: 'Subscription created from a checkout', + description: 'Occurs when a subscription is created.', + group: 'Subscription', + type: 'scenario', + events: [ + 'transaction.created', + 'customer.created', + 'address.created', + 'transaction.updated', + 'transaction.ready', + 'transaction.updated', + 'transaction.paid', + 'subscription.created', + 'subscription.activated', + 'transaction.updated', + 'transaction.updated', + 'transaction.completed', + ], + }, + { + name: 'subscription_renewal', + label: 'Subscription renewed successfully', + description: 'Occurs when a subscription is renewed.', + group: 'Subscription', + type: 'scenario', + events: [ + 'subscription.updated', + 'transaction.created', + 'transaction.billed', + 'transaction.updated', + 'transaction.paid', + 'transaction.updated', + 'transaction.completed', + ], + }, + { + name: 'subscription_pause', + label: 'Subscription paused by customer', + description: 'Occurs when a subscription is paused.', + group: 'Subscription', + type: 'scenario', + events: ['subscription.updated', 'subscription.paused'], + }, + { + name: 'subscription_resume', + label: 'Subscription resumed after being paused', + description: 'Occurs when a subscription is resumed after being paused.', + group: 'Subscription', + type: 'scenario', + events: [ + 'subscription.updated', + 'subscription.resumed', + 'transaction.created', + 'transaction.billed', + 'transaction.updated', + 'transaction.paid', + 'transaction.updated', + 'transaction.completed', + ], + }, + { + name: 'subscription_cancellation', + label: 'Subscription canceled by customer', + description: 'Occurs when a subscription is canceled.', + group: 'Subscription', + type: 'scenario', + events: ['subscription.updated', 'subscription.canceled'], + }, + { + name: 'subscription.activated', + label: 'subscription.activated', + description: + 'Occurs when a subscription becomes active. Its status field changes to active. This means any trial period has elapsed and Paddle has successfully billed the customer.', + group: 'Subscription', + type: 'single_event', + events: ['subscription.activated'], + }, + { + name: 'subscription.canceled', + label: 'subscription.canceled', + description: 'Occurs when a subscription is canceled. Its status field changes to canceled.', + group: 'Subscription', + type: 'single_event', + events: ['subscription.canceled'], + }, + { + name: 'subscription.created', + label: 'subscription.created', + description: + 'Occurs when a subscription is created. subscription.trialing or subscription.activated typically follow.', + group: 'Subscription', + type: 'single_event', + events: ['subscription.created'], + }, + { + name: 'subscription.past_due', + label: 'subscription.past_due', + description: 'Occurs when a subscription has an unpaid transaction. Its status changes to past_due.', + group: 'Subscription', + type: 'single_event', + events: ['subscription.past_due'], + }, + { + name: 'subscription.paused', + label: 'subscription.paused', + description: 'Occurs when a subscription is paused. Its status field changes to paused.', + group: 'Subscription', + type: 'single_event', + events: ['subscription.paused'], + }, + { + name: 'subscription.resumed', + label: 'subscription.resumed', + description: 'Occurs when a subscription is resumed after being paused. Its status field changes to active.', + group: 'Subscription', + type: 'single_event', + events: ['subscription.resumed'], + }, + { + name: 'subscription.trialing', + label: 'subscription.trialing', + description: 'Occurs when a subscription enters trial period.', + group: 'Subscription', + type: 'single_event', + events: ['subscription.trialing'], + }, + { + name: 'subscription.updated', + label: 'subscription.updated', + description: 'Occurs when a subscription is updated.', + group: 'Subscription', + type: 'single_event', + events: ['subscription.updated'], + }, + { + name: 'subscription.imported', + label: 'subscription.imported', + description: 'Occurs when a subscription is imported.', + group: 'Subscription', + type: 'single_event', + events: ['subscription.imported'], + }, + { + name: 'address.created', + label: 'address.created', + description: 'Occurs when an address is created.', + group: 'Address', + type: 'single_event', + events: ['address.created'], + }, + { + name: 'address.updated', + label: 'address.updated', + description: 'Occurs when an address is updated.', + group: 'Address', + type: 'single_event', + events: ['address.updated'], + }, + { + name: 'address.imported', + label: 'address.imported', + description: 'Occurs when a address is imported.', + group: 'Address', + type: 'single_event', + events: ['address.imported'], + }, + { + name: 'adjustment.created', + label: 'adjustment.created', + description: 'Occurs when an adjustment is created.', + group: 'Adjustment', + type: 'single_event', + events: ['adjustment.created'], + }, + { + name: 'adjustment.updated', + label: 'adjustment.updated', + description: + 'Occurs when an adjustment is updated, the only time an adjustment will be updated is when the status changes from pending to approved or from pending to rejected.', + group: 'Adjustment', + type: 'single_event', + events: ['adjustment.updated'], + }, + { + name: 'business.created', + label: 'business.created', + description: 'Occurs when a business is created.', + group: 'Business', + type: 'single_event', + events: ['business.created'], + }, + { + name: 'business.updated', + label: 'business.updated', + description: 'Occurs when a business is updated.', + group: 'Business', + type: 'single_event', + events: ['business.updated'], + }, + { + name: 'business.imported', + label: 'business.imported', + description: 'Occurs when a business is imported.', + group: 'Business', + type: 'single_event', + events: ['business.imported'], + }, + { + name: 'customer.created', + label: 'customer.created', + description: 'Occurs when a customer is created.', + group: 'Customer', + type: 'single_event', + events: ['customer.created'], + }, + { + name: 'customer.updated', + label: 'customer.updated', + description: 'Occurs when a customer is updated.', + group: 'Customer', + type: 'single_event', + events: ['customer.updated'], + }, + { + name: 'customer.imported', + label: 'customer.imported', + description: 'Occurs when a customer is imported.', + group: 'Customer', + type: 'single_event', + events: ['customer.imported'], + }, + { + name: 'discount.created', + label: 'discount.created', + description: 'Occurs when a discount is created.', + group: 'Discount', + type: 'single_event', + events: ['discount.created'], + }, + { + name: 'discount.updated', + label: 'discount.updated', + description: 'Occurs when a discount is updated.', + group: 'Discount', + type: 'single_event', + events: ['discount.updated'], + }, + { + name: 'discount.imported', + label: 'discount.imported', + description: 'Occurs when a discount is imported.', + group: 'Discount', + type: 'single_event', + events: ['discount.imported'], + }, + { + name: 'payout.created', + label: 'payout.created', + description: 'Occurs when a payout is created.', + group: 'Payout', + type: 'single_event', + events: ['payout.created'], + }, + { + name: 'payout.paid', + label: 'payout.paid', + description: 'Occurs when a payout is paid.', + group: 'Payout', + type: 'single_event', + events: ['payout.paid'], + }, + { + name: 'price.created', + label: 'price.created', + description: 'Occurs when a price is created.', + group: 'Price', + type: 'single_event', + events: ['price.created'], + }, + { + name: 'price.updated', + label: 'price.updated', + description: 'Occurs when a price is updated.', + group: 'Price', + type: 'single_event', + events: ['price.updated'], + }, + { + name: 'price.imported', + label: 'price.imported', + description: 'Occurs when a price is imported.', + group: 'Price', + type: 'single_event', + events: ['price.imported'], + }, + { + name: 'product.created', + label: 'product.created', + description: 'Occurs when a product is created.', + group: 'Product', + type: 'single_event', + events: ['product.created'], + }, + { + name: 'product.updated', + label: 'product.updated', + description: 'Occurs when a product is updated.', + group: 'Product', + type: 'single_event', + events: ['product.updated'], + }, + { + name: 'product.imported', + label: 'product.imported', + description: 'Occurs when a product is imported.', + group: 'Product', + type: 'single_event', + events: ['product.imported'], + }, + { + name: 'report.created', + label: 'report.created', + description: 'Occurs when a report is created.', + group: 'Report', + type: 'single_event', + events: ['report.created'], + }, + { + name: 'report.updated', + label: 'report.updated', + description: 'Occurs when a report is updated.', + group: 'Report', + type: 'single_event', + events: ['report.updated'], + }, + { + name: 'transaction.billed', + label: 'transaction.billed', + description: 'Occurs when a transaction is billed. Its status field changes to billed and billed_at is populated.', + group: 'Transaction', + type: 'single_event', + events: ['transaction.billed'], + }, + { + name: 'transaction.canceled', + label: 'transaction.canceled', + description: 'Occurs when a transaction is canceled. Its status field changes to canceled.', + group: 'Transaction', + type: 'single_event', + events: ['transaction.canceled'], + }, + { + name: 'transaction.completed', + label: 'transaction.completed', + description: 'Occurs when a transaction is completed. Its status field changes to completed.', + group: 'Transaction', + type: 'single_event', + events: ['transaction.completed'], + }, + { + name: 'transaction.created', + label: 'transaction.created', + description: 'Occurs when a transaction is created.', + group: 'Transaction', + type: 'single_event', + events: ['transaction.created'], + }, + { + name: 'transaction.paid', + label: 'transaction.paid', + description: 'Occurs when a transaction is paid. Its status field changes to paid.', + group: 'Transaction', + type: 'single_event', + events: ['transaction.paid'], + }, + { + name: 'transaction.past_due', + label: 'transaction.past_due', + description: 'Occurs when a transaction becomes past due. Its status field changes to past_due.', + group: 'Transaction', + type: 'single_event', + events: ['transaction.past_due'], + }, + { + name: 'transaction.payment_failed', + label: 'transaction.payment_failed', + description: + 'Occurs when a payment fails for a transaction. The payments array is updated with details of the payment attempt.', + group: 'Transaction', + type: 'single_event', + events: ['transaction.payment_failed'], + }, + { + name: 'transaction.ready', + label: 'transaction.ready', + description: 'Occurs when a transaction is ready to be billed. Its status field changes to ready.', + group: 'Transaction', + type: 'single_event', + events: ['transaction.ready'], + }, + { + name: 'transaction.updated', + label: 'transaction.updated', + description: 'Occurs when a transaction is updated.', + group: 'Transaction', + type: 'single_event', + events: ['transaction.updated'], + }, +]; + +export const ListSimulationTypeMockResponse: Response = { + data: SimulationTypesMock, + meta: { + request_id: '', + }, +}; diff --git a/src/__tests__/mocks/resources/simulations.mock.ts b/src/__tests__/mocks/resources/simulations.mock.ts new file mode 100644 index 0000000..b3a40c4 --- /dev/null +++ b/src/__tests__/mocks/resources/simulations.mock.ts @@ -0,0 +1,51 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { ISimulationResponse } from '../../../types'; +import { Response, ResponsePaginated } from '../../../internal'; +import { CreateSimulationRequestBody, UpdateSimulationRequestBody } from '../../../resources'; + +export const CreateSimulationMock: CreateSimulationRequestBody = { + notificationSettingId: 'ntfset_01gt21c5pdx9q1e4mh1xrsjjn6', + type: 'address.created', + name: 'New address created', +}; + +export const updateSimulationMock: UpdateSimulationRequestBody = { + name: 'New UK address created', +}; + +export const SimulationMock: ISimulationResponse = { + id: 'ntfsim_01ghbkd0frb9k95cnhwd1bxpvk', + status: 'active', + notification_setting_id: 'ntfset_01gt21c5pdx9q1e4mh1xrsjjn6', + name: 'New address created', + type: 'address.created', + payload: null, + last_run_at: '2024-10-12T07:20:50.52Z', + created_at: '2024-10-12T07:20:50.52Z', + updated_at: '2024-10-13T07:20:50.52Z', +}; + +export const SimulationMockResponse: Response = { + data: SimulationMock, + meta: { + request_id: '', + }, +}; + +export const ListSimulationMockResponse: ResponsePaginated = { + data: [SimulationMock], + meta: { + request_id: '', + pagination: { + estimated_total: 10, + has_more: true, + next: '/simulations?after=1', + per_page: 10, + }, + }, +}; diff --git a/src/__tests__/resources/simulation-run-events.test.ts b/src/__tests__/resources/simulation-run-events.test.ts new file mode 100644 index 0000000..456ef9f --- /dev/null +++ b/src/__tests__/resources/simulation-run-events.test.ts @@ -0,0 +1,91 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { SimulationRunEventsResource, type ListSimulationRunEventsQueryParameters } from '../../resources'; +import { getPaddleTestClient } from '../helpers/test-client'; +import { + ListSimulationRunEventMockResponse, + SimulationRunEventMock, + SimulationRunEventMockResponse, +} from '../mocks/resources/simulation-run-events.mock'; + +const simulationId = 'ntfsim_123'; +const simulationRunId = 'ntfsimrun_123'; + +describe('SimulationRunEventsResource', () => { + test('should return a list of simulationRunEvents', async () => { + const paddleInstance = getPaddleTestClient(); + paddleInstance.get = jest.fn().mockResolvedValue(ListSimulationRunEventMockResponse); + + const simulationRunEventsResource = new SimulationRunEventsResource(paddleInstance); + const simulationRunEventCollection = simulationRunEventsResource.list(simulationId, simulationRunId); + + let simulationRunEvents = await simulationRunEventCollection.next(); + expect(paddleInstance.get).toBeCalledWith(`/simulations/${simulationId}/runs/${simulationRunId}/events?`); + expect(simulationRunEvents.length).toBe(1); + + simulationRunEvents = await simulationRunEventCollection.next(); + expect(paddleInstance.get).toBeCalledWith(`/simulations/${simulationId}/runs/${simulationRunId}/events?after=1`); + expect(simulationRunEvents.length).toBe(1); + }); + + test('should accept query params and return a list of simulationRunEvents', async () => { + const paddleInstance = getPaddleTestClient(); + paddleInstance.get = jest.fn().mockResolvedValue(ListSimulationRunEventMockResponse); + const simulationRunEventsResource = new SimulationRunEventsResource(paddleInstance); + const queryParams: ListSimulationRunEventsQueryParameters = { + after: '2', + id: ['1234'], + }; + + const simulationRunEventCollection = simulationRunEventsResource.list(simulationId, simulationRunId, queryParams); + let simulationRunEvents = await simulationRunEventCollection.next(); + + expect(paddleInstance.get).toBeCalledWith( + `/simulations/${simulationId}/runs/${simulationRunId}/events?after=2&id=1234`, + ); + expect(simulationRunEvents.length).toBe(1); + }); + + test('should return a single simulationRunEvent by ID', async () => { + const simulationRunEventId = SimulationRunEventMock.id; + const paddleInstance = getPaddleTestClient(); + paddleInstance.get = jest.fn().mockResolvedValue(SimulationRunEventMockResponse); + + const simulationRunEventsResource = new SimulationRunEventsResource(paddleInstance); + const simulationRunEvent = await simulationRunEventsResource.get( + simulationId, + simulationRunId, + simulationRunEventId, + ); + + expect(paddleInstance.get).toBeCalledWith( + `/simulations/${simulationId}/runs/${simulationRunId}/events/${simulationRunEventId}`, + ); + expect(simulationRunEvent).toBeDefined(); + expect(simulationRunEvent.id).toBe(simulationRunEventId); + }); + + test('should replay an existing simulationRunEvent', async () => { + const simulationRunEventId = SimulationRunEventMock.id; + + const paddleInstance = getPaddleTestClient(); + paddleInstance.post = jest.fn().mockResolvedValue(SimulationRunEventMockResponse); + + const simulationRunEventsResource = new SimulationRunEventsResource(paddleInstance); + const replayedSimulationRunEvent = await simulationRunEventsResource.replay( + simulationId, + simulationRunId, + simulationRunEventId, + ); + + expect(paddleInstance.post).toBeCalledWith( + `/simulations/${simulationId}/runs/${simulationRunId}/events/${simulationRunEventId}/replay`, + undefined, + ); + expect(replayedSimulationRunEvent).toBeDefined(); + }); +}); diff --git a/src/__tests__/resources/simulation-runs.test.ts b/src/__tests__/resources/simulation-runs.test.ts new file mode 100644 index 0000000..ae7a010 --- /dev/null +++ b/src/__tests__/resources/simulation-runs.test.ts @@ -0,0 +1,101 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { + SimulationRunsResource, + type ListSimulationRunQueryParameters, + type GetSimulationRunQueryParameters, +} from '../../resources'; +import { getPaddleTestClient } from '../helpers/test-client'; +import { + SimulationRunMockResponse, + SimulationRunMock, + ListSimulationRunMockResponse, +} from '../mocks/resources/simulation-runs.mock'; +import { QueryParameters } from '../../internal/base'; + +const simulationId = 'ntfsim_123'; + +describe('SimulationRunsResource', () => { + test('should return a list of simulationRuns', async () => { + const paddleInstance = getPaddleTestClient(); + paddleInstance.get = jest.fn().mockResolvedValue(ListSimulationRunMockResponse); + + const simulationRunsResource = new SimulationRunsResource(paddleInstance); + const simulationRunCollection = simulationRunsResource.list(simulationId); + + let simulationRuns = await simulationRunCollection.next(); + expect(paddleInstance.get).toBeCalledWith(`/simulations/${simulationId}/runs?`); + expect(simulationRuns.length).toBe(1); + + simulationRuns = await simulationRunCollection.next(); + expect(paddleInstance.get).toBeCalledWith(`/simulations/${simulationId}/runs?after=1`); + expect(simulationRuns.length).toBe(1); + }); + + test('should accept query params and return a list of simulationRuns', async () => { + const paddleInstance = getPaddleTestClient(); + paddleInstance.get = jest.fn().mockResolvedValue(ListSimulationRunMockResponse); + const simulationRunsResource = new SimulationRunsResource(paddleInstance); + const queryParams: ListSimulationRunQueryParameters = { + after: '2', + id: ['1234'], + include: ['price'], + }; + + const simulationRunCollection = simulationRunsResource.list(simulationId, queryParams); + let simulationRuns = await simulationRunCollection.next(); + + expect(paddleInstance.get).toBeCalledWith(`/simulations/${simulationId}/runs?after=2&id=1234&include=price`); + expect(simulationRuns.length).toBe(1); + }); + + test('should return a single simulationRun by ID', async () => { + const simulationRunId = SimulationRunMock.id; + const paddleInstance = getPaddleTestClient(); + paddleInstance.get = jest.fn().mockResolvedValue(SimulationRunMockResponse); + + const simulationRunsResource = new SimulationRunsResource(paddleInstance); + const simulationRun = await simulationRunsResource.get(simulationId, simulationRunId); + + expect(paddleInstance.get).toBeCalledWith(`/simulations/${simulationId}/runs/${simulationRunId}`, { + queryParams: undefined, + }); + expect(simulationRun).toBeDefined(); + expect(simulationRun.id).toBe(simulationRunId); + }); + + test('should accepts query params and return a single simulationRun by ID', async () => { + const simulationRunId = SimulationRunMock.id; + const paddleInstance = getPaddleTestClient(); + + paddleInstance.get = jest.fn().mockResolvedValue(SimulationRunMockResponse); + const simulationRunsResource = new SimulationRunsResource(paddleInstance); + + const queryParams: GetSimulationRunQueryParameters = { + include: ['price'], + }; + const simulationRun = await simulationRunsResource.get(simulationId, simulationRunId, queryParams); + + expect(simulationRun).toBeDefined(); + expect(paddleInstance.get).toBeCalledWith( + `/simulations/${simulationId}/runs/${simulationRunId}`, + new QueryParameters(queryParams), + ); + expect(simulationRun.id).toBe(simulationRunId); + }); + + test('should create a new simulationRun', async () => { + const paddleInstance = getPaddleTestClient(); + + paddleInstance.post = jest.fn().mockResolvedValue(SimulationRunMockResponse); + const simulationRunsResource = new SimulationRunsResource(paddleInstance); + const createdSimulationRun = await simulationRunsResource.create(simulationId); + + expect(createdSimulationRun).toBeDefined(); + expect(createdSimulationRun.id).toBeDefined(); + }); +}); diff --git a/src/__tests__/resources/simulation-types.test.ts b/src/__tests__/resources/simulation-types.test.ts new file mode 100644 index 0000000..ff0638c --- /dev/null +++ b/src/__tests__/resources/simulation-types.test.ts @@ -0,0 +1,22 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { getPaddleTestClient } from '../helpers/test-client'; +import { SimulationTypesResource } from '../../resources'; +import { ListSimulationTypeMockResponse } from '../mocks/resources/simulation-types.mock'; + +describe('simulationTypesResource', () => { + test('should return a list of simulations', async () => { + const paddleInstance = getPaddleTestClient(); + paddleInstance.get = jest.fn().mockResolvedValue(ListSimulationTypeMockResponse); + + const simulationsResource = new SimulationTypesResource(paddleInstance); + const simulationTypes = await simulationsResource.list(); + + expect(paddleInstance.get).toBeCalledWith('/simulation-types'); + expect(simulationTypes.length).toBe(47); + }); +}); diff --git a/src/__tests__/resources/simulations.test.ts b/src/__tests__/resources/simulations.test.ts new file mode 100644 index 0000000..3e28290 --- /dev/null +++ b/src/__tests__/resources/simulations.test.ts @@ -0,0 +1,109 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { + CreateSimulationRequestBody, + UpdateSimulationRequestBody, + SimulationsResource, + ListSimulationQueryParameters, +} from '../../resources'; +import { getPaddleTestClient } from '../helpers/test-client'; +import { + SimulationMockResponse, + SimulationMock, + CreateSimulationMock, + updateSimulationMock, + ListSimulationMockResponse, +} from '../mocks/resources/simulations.mock'; + +describe('SimulationsResource', () => { + test('should return a list of simulations', async () => { + const paddleInstance = getPaddleTestClient(); + paddleInstance.get = jest.fn().mockResolvedValue(ListSimulationMockResponse); + + const simulationsResource = new SimulationsResource(paddleInstance); + const simulationCollection = simulationsResource.list(); + + let simulations = await simulationCollection.next(); + expect(paddleInstance.get).toBeCalledWith('/simulations?'); + expect(simulations.length).toBe(1); + + simulations = await simulationCollection.next(); + expect(paddleInstance.get).toBeCalledWith('/simulations?after=1'); + expect(simulations.length).toBe(1); + }); + + test('should accept query params and return a list of simulations', async () => { + const paddleInstance = getPaddleTestClient(); + paddleInstance.get = jest.fn().mockResolvedValue(ListSimulationMockResponse); + const simulationsResource = new SimulationsResource(paddleInstance); + const queryParams: ListSimulationQueryParameters = { + after: '2', + id: ['1234'], + }; + + const simulationCollection = simulationsResource.list(queryParams); + let simulations = await simulationCollection.next(); + + expect(paddleInstance.get).toBeCalledWith('/simulations?after=2&id=1234'); + expect(simulations.length).toBe(1); + }); + + test('should return a single simulation by ID', async () => { + const simulationId = SimulationMock.id; + const paddleInstance = getPaddleTestClient(); + paddleInstance.get = jest.fn().mockResolvedValue(SimulationMockResponse); + + const simulationsResource = new SimulationsResource(paddleInstance); + const simulation = await simulationsResource.get(simulationId); + + expect(paddleInstance.get).toBeCalledWith(`/simulations/${simulationId}`); + expect(simulation).toBeDefined(); + expect(simulation.id).toBe(simulationId); + }); + + test('should accepts query params and return a single simulation by ID', async () => { + const simulationId = SimulationMock.id; + const paddleInstance = getPaddleTestClient(); + + paddleInstance.get = jest.fn().mockResolvedValue(SimulationMockResponse); + const simulationsResource = new SimulationsResource(paddleInstance); + + const simulation = await simulationsResource.get(simulationId); + + expect(simulation).toBeDefined(); + expect(paddleInstance.get).toBeCalledWith(`/simulations/${simulationId}`); + expect(simulation.id).toBe(simulationId); + }); + + test('should create a new simulation', async () => { + const newSimulation: CreateSimulationRequestBody = CreateSimulationMock; + const paddleInstance = getPaddleTestClient(); + + paddleInstance.post = jest.fn().mockResolvedValue(SimulationMockResponse); + const simulationsResource = new SimulationsResource(paddleInstance); + const createdSimulation = await simulationsResource.create(newSimulation); + + expect(paddleInstance.post).toBeCalledWith(`/simulations`, newSimulation); + expect(createdSimulation).toBeDefined(); + expect(createdSimulation.id).toBeDefined(); + expect(createdSimulation.name).toBe(newSimulation.name); + }); + + test('should update an existing simulation', async () => { + const simulationId = SimulationMock.id; + const simulationToBeUpdated: UpdateSimulationRequestBody = updateSimulationMock; + + const paddleInstance = getPaddleTestClient(); + paddleInstance.patch = jest.fn().mockResolvedValue(SimulationMockResponse); + + const simulationsResource = new SimulationsResource(paddleInstance); + const updatedSimulation = await simulationsResource.update(simulationId, simulationToBeUpdated); + + expect(paddleInstance.patch).toBeCalledWith(`/simulations/${simulationId}`, simulationToBeUpdated); + expect(updatedSimulation).toBeDefined(); + }); +}); diff --git a/src/entities/index.ts b/src/entities/index.ts index 774a192..164cd63 100644 --- a/src/entities/index.ts +++ b/src/entities/index.ts @@ -20,5 +20,9 @@ export * from './event-types'; export * from './notification-settings'; export * from './notifications'; export * from './report'; +export * from './simulation-types'; +export * from './simulation'; +export * from './simulation-run'; +export * from './simulation-run-event'; export type CustomData = object; diff --git a/src/entities/shared/index.ts b/src/entities/shared/index.ts index 8e83ffa..33b3184 100644 --- a/src/entities/shared/index.ts +++ b/src/entities/shared/index.ts @@ -24,3 +24,5 @@ export * from './transaction-checkout'; export * from './total-adjustments'; export * from './payout-totals-adjustment'; export * from './import-meta'; +export * from './simulation-event-request'; +export * from './simulation-event-response'; diff --git a/src/entities/shared/simulation-event-request.ts b/src/entities/shared/simulation-event-request.ts new file mode 100644 index 0000000..0a97f41 --- /dev/null +++ b/src/entities/shared/simulation-event-request.ts @@ -0,0 +1,15 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { type ISimulationEventRequest } from '../../types'; + +export class SimulationEventRequest { + public readonly body: string; + + constructor(simulationEventRequestResponse: ISimulationEventRequest) { + this.body = simulationEventRequestResponse.body; + } +} diff --git a/src/entities/shared/simulation-event-response.ts b/src/entities/shared/simulation-event-response.ts new file mode 100644 index 0000000..d5e6189 --- /dev/null +++ b/src/entities/shared/simulation-event-response.ts @@ -0,0 +1,17 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { type ISimulationEventResponse } from '../../types'; + +export class SimulationEventResponse { + public readonly body: string; + public readonly statusCode: number; + + constructor(simulationEventResponse: ISimulationEventResponse) { + this.body = simulationEventResponse.body; + this.statusCode = simulationEventResponse.status_code; + } +} diff --git a/src/entities/simulation-run-event/index.ts b/src/entities/simulation-run-event/index.ts new file mode 100644 index 0000000..95542f9 --- /dev/null +++ b/src/entities/simulation-run-event/index.ts @@ -0,0 +1,8 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './simulation-run-event'; +export * from './simulation-run-event-collection'; diff --git a/src/entities/simulation-run-event/simulation-run-event-collection.ts b/src/entities/simulation-run-event/simulation-run-event-collection.ts new file mode 100644 index 0000000..64e0382 --- /dev/null +++ b/src/entities/simulation-run-event/simulation-run-event-collection.ts @@ -0,0 +1,15 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { SimulationRunEvent } from '../../entities'; +import { type ISimulationRunEventResponse } from '../../types'; +import { Collection } from '../../internal/base'; + +export class SimulationRunEventCollection extends Collection { + override fromJson(data: ISimulationRunEventResponse): SimulationRunEvent { + return new SimulationRunEvent(data); + } +} diff --git a/src/entities/simulation-run-event/simulation-run-event.ts b/src/entities/simulation-run-event/simulation-run-event.ts new file mode 100644 index 0000000..6fdca37 --- /dev/null +++ b/src/entities/simulation-run-event/simulation-run-event.ts @@ -0,0 +1,36 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import type { SimulationRunEventStatus, SimulationScenarioType } from '../../enums'; +import type { IEventName } from '../../notifications'; +import type { ISimulationRunEventResponse } from '../../types'; +import { SimulationEventRequest, SimulationEventResponse } from '../shared'; + +export class SimulationRunEvent { + public readonly id: string; + public readonly status: SimulationRunEventStatus; + public readonly eventType: IEventName | SimulationScenarioType; + public readonly payload: any; + public readonly request: SimulationEventRequest | null; + public readonly response: SimulationEventResponse | null; + public readonly createdAt: string; + public readonly updatedAt: string; + + constructor(simulationRunEventResponse: ISimulationRunEventResponse) { + this.id = simulationRunEventResponse.id; + this.status = simulationRunEventResponse.status; + this.eventType = simulationRunEventResponse.event_type; + this.payload = simulationRunEventResponse.payload; + this.request = simulationRunEventResponse.request + ? new SimulationEventRequest(simulationRunEventResponse.request) + : null; + this.response = simulationRunEventResponse.response + ? new SimulationEventResponse(simulationRunEventResponse.response) + : null; + this.createdAt = simulationRunEventResponse.created_at; + this.updatedAt = simulationRunEventResponse.updated_at; + } +} diff --git a/src/entities/simulation-run/index.ts b/src/entities/simulation-run/index.ts new file mode 100644 index 0000000..8f8264c --- /dev/null +++ b/src/entities/simulation-run/index.ts @@ -0,0 +1,8 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './simulation-run'; +export * from './simulation-run-collection'; diff --git a/src/entities/simulation-run/simulation-run-collection.ts b/src/entities/simulation-run/simulation-run-collection.ts new file mode 100644 index 0000000..8a86ff8 --- /dev/null +++ b/src/entities/simulation-run/simulation-run-collection.ts @@ -0,0 +1,15 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { SimulationRun } from '../../entities'; +import { type ISimulationRunResponse } from '../../types'; +import { Collection } from '../../internal/base'; + +export class SimulationRunCollection extends Collection { + override fromJson(data: ISimulationRunResponse): SimulationRun { + return new SimulationRun(data); + } +} diff --git a/src/entities/simulation-run/simulation-run.ts b/src/entities/simulation-run/simulation-run.ts new file mode 100644 index 0000000..24f8b9f --- /dev/null +++ b/src/entities/simulation-run/simulation-run.ts @@ -0,0 +1,28 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import type { SimulationRunStatus, SimulationScenarioType } from '../../enums'; +import type { IEventName } from '../../notifications'; +import type { ISimulationRunResponse } from '../../types'; +import { SimulationRunEvent } from '..'; + +export class SimulationRun { + public readonly id: string; + public readonly status: SimulationRunStatus; + public readonly createdAt: string; + public readonly updatedAt: string; + public readonly type: IEventName | SimulationScenarioType; + public readonly events: SimulationRunEvent[] | null; + + constructor(simulationRunResponse: ISimulationRunResponse) { + this.id = simulationRunResponse.id; + this.status = simulationRunResponse.status; + this.createdAt = simulationRunResponse.created_at; + this.updatedAt = simulationRunResponse.updated_at; + this.type = simulationRunResponse.type; + this.events = simulationRunResponse.events?.map((event) => new SimulationRunEvent(event)) ?? []; + } +} diff --git a/src/entities/simulation-types/index.ts b/src/entities/simulation-types/index.ts new file mode 100644 index 0000000..d3bf69b --- /dev/null +++ b/src/entities/simulation-types/index.ts @@ -0,0 +1,7 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './simulation-type'; diff --git a/src/entities/simulation-types/simulation-type.ts b/src/entities/simulation-types/simulation-type.ts new file mode 100644 index 0000000..d4e92a8 --- /dev/null +++ b/src/entities/simulation-types/simulation-type.ts @@ -0,0 +1,27 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { type SimulationKind } from '../../enums'; +import { type IEventName } from '../../notifications'; +import { type ISimulationTypeResponse } from '../../types'; + +export class SimulationType { + public readonly name: string; + public readonly label: string; + public readonly description: string; + public readonly group: string; + public readonly type: SimulationKind; + public readonly events: IEventName[]; + + constructor(simulationTypeResponse: ISimulationTypeResponse) { + this.name = simulationTypeResponse.name; + this.label = simulationTypeResponse.label; + this.description = simulationTypeResponse.description; + this.group = simulationTypeResponse.group; + this.type = simulationTypeResponse.type; + this.events = simulationTypeResponse.events; + } +} diff --git a/src/entities/simulation/index.ts b/src/entities/simulation/index.ts new file mode 100644 index 0000000..ee76e4e --- /dev/null +++ b/src/entities/simulation/index.ts @@ -0,0 +1,8 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './simulation'; +export * from './simulation-collection'; diff --git a/src/entities/simulation/simulation-collection.ts b/src/entities/simulation/simulation-collection.ts new file mode 100644 index 0000000..ae8d0b8 --- /dev/null +++ b/src/entities/simulation/simulation-collection.ts @@ -0,0 +1,15 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { Simulation } from '../../entities'; +import { type ISimulationResponse } from '../../types'; +import { Collection } from '../../internal/base'; + +export class SimulationCollection extends Collection { + override fromJson(data: ISimulationResponse): Simulation { + return new Simulation(data); + } +} diff --git a/src/entities/simulation/simulation.ts b/src/entities/simulation/simulation.ts new file mode 100644 index 0000000..9ab9795 --- /dev/null +++ b/src/entities/simulation/simulation.ts @@ -0,0 +1,33 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { type ISimulationResponse } from '../../types'; +import type { SimulationScenarioType, Status } from '../../enums'; +import type { IEventName } from '../../notifications'; + +export class Simulation { + public readonly id: string; + public readonly status: Status; + public readonly notificationSettingId: string; + public readonly name: string; + public readonly type: IEventName | SimulationScenarioType; + public readonly payload: any; + public readonly lastRunAt: string | null; + public readonly createdAt: string; + public readonly updatedAt: string; + + constructor(simulationResponse: ISimulationResponse) { + this.id = simulationResponse.id; + this.status = simulationResponse.status; + this.notificationSettingId = simulationResponse.notification_setting_id; + this.name = simulationResponse.name; + this.type = simulationResponse.type; + this.payload = simulationResponse.payload ?? null; + this.lastRunAt = simulationResponse.last_run_at ?? null; + this.createdAt = simulationResponse.created_at; + this.updatedAt = simulationResponse.updated_at; + } +} diff --git a/src/enums/index.ts b/src/enums/index.ts index 44a51ef..5485757 100644 --- a/src/enums/index.ts +++ b/src/enums/index.ts @@ -13,3 +13,7 @@ export * from './payout'; export * from './notification-settings'; export * from './notification'; export * from './report'; +export * from './simulation-type'; +export * from './simulation'; +export * from './simulation-run'; +export * from './simulation-run-event'; diff --git a/src/enums/simulation-run-event/index.ts b/src/enums/simulation-run-event/index.ts new file mode 100644 index 0000000..2fc1bb3 --- /dev/null +++ b/src/enums/simulation-run-event/index.ts @@ -0,0 +1,7 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './simulation-run-event-status'; diff --git a/src/enums/simulation-run-event/simulation-run-event-status.ts b/src/enums/simulation-run-event/simulation-run-event-status.ts new file mode 100644 index 0000000..3bebc36 --- /dev/null +++ b/src/enums/simulation-run-event/simulation-run-event-status.ts @@ -0,0 +1,7 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export type SimulationRunEventStatus = 'pending' | 'success' | 'failed' | 'aborted'; diff --git a/src/enums/simulation-run/index.ts b/src/enums/simulation-run/index.ts new file mode 100644 index 0000000..532d88f --- /dev/null +++ b/src/enums/simulation-run/index.ts @@ -0,0 +1,7 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './simulation-run-status'; diff --git a/src/enums/simulation-run/simulation-run-status.ts b/src/enums/simulation-run/simulation-run-status.ts new file mode 100644 index 0000000..16497fc --- /dev/null +++ b/src/enums/simulation-run/simulation-run-status.ts @@ -0,0 +1,7 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export type SimulationRunStatus = 'pending' | 'completed' | 'canceled'; diff --git a/src/enums/simulation-type/index.ts b/src/enums/simulation-type/index.ts new file mode 100644 index 0000000..ea98480 --- /dev/null +++ b/src/enums/simulation-type/index.ts @@ -0,0 +1,7 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './simulation-kind'; diff --git a/src/enums/simulation-type/simulation-kind.ts b/src/enums/simulation-type/simulation-kind.ts new file mode 100644 index 0000000..f63a822 --- /dev/null +++ b/src/enums/simulation-type/simulation-kind.ts @@ -0,0 +1,7 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export type SimulationKind = 'single_event' | 'scenario'; diff --git a/src/enums/simulation/index.ts b/src/enums/simulation/index.ts new file mode 100644 index 0000000..85f52eb --- /dev/null +++ b/src/enums/simulation/index.ts @@ -0,0 +1,7 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './simulation-scenario-type'; diff --git a/src/enums/simulation/simulation-scenario-type.ts b/src/enums/simulation/simulation-scenario-type.ts new file mode 100644 index 0000000..f99c37b --- /dev/null +++ b/src/enums/simulation/simulation-scenario-type.ts @@ -0,0 +1,12 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export type SimulationScenarioType = + | 'subscription_creation' + | 'subscription_renewal' + | 'subscription_pause' + | 'subscription_resume' + | 'subscription_cancellation'; diff --git a/src/notifications/helpers/types.ts b/src/notifications/helpers/types.ts index bb6e55b..bf3e53d 100644 --- a/src/notifications/helpers/types.ts +++ b/src/notifications/helpers/types.ts @@ -141,10 +141,12 @@ export type IEventName = | 'business.updated' | 'business.imported' | 'customer.created' + | 'customer.imported' | 'customer.updated' | 'discount.created' | 'discount.updated' | 'discount.imported' + | 'payout.created' | 'payout.updated' | 'payout.paid' | 'price.updated' diff --git a/src/paddle.ts b/src/paddle.ts index 5d71ce6..9e9b1be 100644 --- a/src/paddle.ts +++ b/src/paddle.ts @@ -12,6 +12,10 @@ import { PricingPreviewResource, ProductsResource, ReportsResource, + SimulationTypesResource, + SimulationsResource, + SimulationRunsResource, + SimulationRunEventsResource, SubscriptionsResource, TransactionsResource, } from './resources'; @@ -42,6 +46,10 @@ export class Paddle { public notificationSettings: NotificationSettingsResource; public notifications: NotificationsResource; public reports: ReportsResource; + public simulationTypes: SimulationTypesResource; + public simulations: SimulationsResource; + public simulationRuns: SimulationRunsResource; + public simulationRunEvents: SimulationRunEventsResource; constructor(apiKey: string, options?: PaddleOptions) { this.client = new Client( @@ -65,5 +73,9 @@ export class Paddle { this.notificationSettings = new NotificationSettingsResource(this.client); this.notifications = new NotificationsResource(this.client); this.reports = new ReportsResource(this.client); + this.simulationTypes = new SimulationTypesResource(this.client); + this.simulations = new SimulationsResource(this.client); + this.simulationRuns = new SimulationRunsResource(this.client); + this.simulationRunEvents = new SimulationRunEventsResource(this.client); } } diff --git a/src/resources/index.ts b/src/resources/index.ts index a85060e..03b27b6 100644 --- a/src/resources/index.ts +++ b/src/resources/index.ts @@ -12,3 +12,7 @@ export * from './event-types'; export * from './notification-settings'; export * from './notifications'; export * from './reports'; +export * from './simulation-types'; +export * from './simulations'; +export * from './simulation-runs'; +export * from './simulation-run-events'; diff --git a/src/resources/simulation-run-events/index.ts b/src/resources/simulation-run-events/index.ts new file mode 100644 index 0000000..af9a195 --- /dev/null +++ b/src/resources/simulation-run-events/index.ts @@ -0,0 +1,76 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { SimulationRunEvent, SimulationRunEventCollection } from '../../entities'; +import { type ISimulationRunEventResponse } from '../../types'; +import { type ErrorResponse, type Response } from '../../internal'; +import { BaseResource, PathParameters, QueryParameters } from '../../internal/base'; +import type { ListSimulationRunEventsQueryParameters } from './operations'; + +export * from './operations'; + +const SimulationRunEventPaths = { + list: '/simulations/{simulation_id}/runs/{simulation_run_id}/events', + get: '/simulations/{simulation_id}/runs/{simulation_run_id}/events/{simulation_event_id}', + replay: '/simulations/{simulation_id}/runs/{simulation_run_id}/events/{simulation_event_id}/replay', +} as const; + +export class SimulationRunEventsResource extends BaseResource { + public list( + simulationId: string, + simulationRunId: string, + queryParams?: ListSimulationRunEventsQueryParameters, + ): SimulationRunEventCollection { + const queryParameters = new QueryParameters(queryParams); + const urlWithPathParams = new PathParameters(SimulationRunEventPaths.list, { + simulation_id: simulationId, + simulation_run_id: simulationRunId, + }).deriveUrl(); + + return new SimulationRunEventCollection(this.client, urlWithPathParams + queryParameters.toQueryString()); + } + + public async get( + simulationId: string, + simulationRunId: string, + simulationEventId: string, + ): Promise { + const urlWithPathParams = new PathParameters(SimulationRunEventPaths.get, { + simulation_id: simulationId, + simulation_run_id: simulationRunId, + simulation_event_id: simulationEventId, + }).deriveUrl(); + + const response = await this.client.get | ErrorResponse>( + urlWithPathParams, + ); + + const data = this.handleResponse(response); + + return new SimulationRunEvent(data); + } + + public async replay( + simulationId: string, + simulationRunId: string, + simulationEventId: string, + ): Promise { + const urlWithPathParams = new PathParameters(SimulationRunEventPaths.replay, { + simulation_id: simulationId, + simulation_run_id: simulationRunId, + simulation_event_id: simulationEventId, + }).deriveUrl(); + + const response = await this.client.post | ErrorResponse>( + urlWithPathParams, + undefined, + ); + + const data = this.handleResponse(response); + + return new SimulationRunEvent(data); + } +} diff --git a/src/resources/simulation-run-events/operations/index.ts b/src/resources/simulation-run-events/operations/index.ts new file mode 100644 index 0000000..53ac822 --- /dev/null +++ b/src/resources/simulation-run-events/operations/index.ts @@ -0,0 +1,7 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './list-simulation-run-events-query-parameters'; diff --git a/src/resources/simulation-run-events/operations/list-simulation-run-events-query-parameters.ts b/src/resources/simulation-run-events/operations/list-simulation-run-events-query-parameters.ts new file mode 100644 index 0000000..5b75365 --- /dev/null +++ b/src/resources/simulation-run-events/operations/list-simulation-run-events-query-parameters.ts @@ -0,0 +1,12 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export interface ListSimulationRunEventsQueryParameters { + after?: string; + orderBy?: string; + perPage?: number; + id?: string[]; +} diff --git a/src/resources/simulation-runs/index.ts b/src/resources/simulation-runs/index.ts new file mode 100644 index 0000000..e2c7172 --- /dev/null +++ b/src/resources/simulation-runs/index.ts @@ -0,0 +1,67 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { SimulationRun, SimulationRunCollection } from '../../entities'; +import { type ErrorResponse, type Response } from '../../internal'; +import { BaseResource, PathParameters, QueryParameters } from '../../internal/base'; +import type { ISimulationRunResponse } from '../../types'; +import { type GetSimulationRunQueryParameters, type ListSimulationRunQueryParameters } from './operations'; + +export * from './operations'; + +const SimulationRunPaths = { + list: '/simulations/{simulation_id}/runs', + create: '/simulations/{simulation_id}/runs', + get: '/simulations/{simulation_id}/runs/{simulation_run_id}', +} as const; + +export class SimulationRunsResource extends BaseResource { + public list(simulationId: string, queryParams?: ListSimulationRunQueryParameters): SimulationRunCollection { + const queryParameters = new QueryParameters(queryParams); + const urlWithPathParams = new PathParameters(SimulationRunPaths.list, { + simulation_id: simulationId, + }).deriveUrl(); + + return new SimulationRunCollection(this.client, urlWithPathParams + queryParameters.toQueryString()); + } + + public async create(simulationId: string): Promise { + const urlWithPathParams = new PathParameters(SimulationRunPaths.create, { + simulation_id: simulationId, + }).deriveUrl(); + + const response = await this.client.post | ErrorResponse>( + urlWithPathParams, + undefined, + ); + + const data = this.handleResponse(response); + + return new SimulationRun(data); + } + + public async get( + simulationId: string, + simulationRunId: string, + queryParams?: GetSimulationRunQueryParameters, + ): Promise { + const queryParameters = new QueryParameters(queryParams); + + const urlWithPathParams = new PathParameters(SimulationRunPaths.get, { + simulation_id: simulationId, + simulation_run_id: simulationRunId, + }).deriveUrl(); + + const response = await this.client.get< + GetSimulationRunQueryParameters | undefined, + Response | ErrorResponse + >(urlWithPathParams, queryParameters); + + const data = this.handleResponse(response); + + return new SimulationRun(data); + } +} diff --git a/src/resources/simulation-runs/operations/get-simulation-run-query-parameters.ts b/src/resources/simulation-runs/operations/get-simulation-run-query-parameters.ts new file mode 100644 index 0000000..532c803 --- /dev/null +++ b/src/resources/simulation-runs/operations/get-simulation-run-query-parameters.ts @@ -0,0 +1,9 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export interface GetSimulationRunQueryParameters { + include: any[]; +} diff --git a/src/resources/simulation-runs/operations/index.ts b/src/resources/simulation-runs/operations/index.ts new file mode 100644 index 0000000..4b2db00 --- /dev/null +++ b/src/resources/simulation-runs/operations/index.ts @@ -0,0 +1,8 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './get-simulation-run-query-parameters'; +export * from './list-simulation-run-query-parameters'; diff --git a/src/resources/simulation-runs/operations/list-simulation-run-query-parameters.ts b/src/resources/simulation-runs/operations/list-simulation-run-query-parameters.ts new file mode 100644 index 0000000..6f59c54 --- /dev/null +++ b/src/resources/simulation-runs/operations/list-simulation-run-query-parameters.ts @@ -0,0 +1,13 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export interface ListSimulationRunQueryParameters { + after?: string; + include?: any[]; + orderBy?: string; + perPage?: number; + id?: string[]; +} diff --git a/src/resources/simulation-types/index.ts b/src/resources/simulation-types/index.ts new file mode 100644 index 0000000..2670781 --- /dev/null +++ b/src/resources/simulation-types/index.ts @@ -0,0 +1,26 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { BaseResource } from '../../internal/base'; +import { type ErrorResponse, type Response } from '../../internal'; +import { type ISimulationTypeResponse } from '../../types'; +import { SimulationType } from '../../entities'; + +const SimulationTypesPaths = { + list: '/simulation-types', +} as const; + +export class SimulationTypesResource extends BaseResource { + public async list(): Promise { + const response = await this.client.get | ErrorResponse>( + SimulationTypesPaths.list, + ); + + const data = this.handleResponse(response); + + return data.map((simulationType) => new SimulationType(simulationType)); + } +} diff --git a/src/resources/simulations/index.ts b/src/resources/simulations/index.ts new file mode 100644 index 0000000..1cb5bf7 --- /dev/null +++ b/src/resources/simulations/index.ts @@ -0,0 +1,69 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { Simulation, SimulationCollection } from '../../entities'; +import { type ErrorResponse, type Response } from '../../internal'; +import { BaseResource, PathParameters, QueryParameters } from '../../internal/base'; +import { type ISimulationResponse } from '../../types'; +import { + type CreateSimulationRequestBody, + type ListSimulationQueryParameters, + type UpdateSimulationRequestBody, +} from './operations'; + +export * from './operations'; + +const SimulationPaths = { + list: '/simulations', + create: '/simulations', + get: '/simulations/{simulation_id}', + update: '/simulations/{simulation_id}', +} as const; + +export class SimulationsResource extends BaseResource { + public list(queryParams?: ListSimulationQueryParameters): SimulationCollection { + const queryParameters = new QueryParameters(queryParams); + return new SimulationCollection(this.client, SimulationPaths.list + queryParameters.toQueryString()); + } + + public async create(createSimulationParameters: CreateSimulationRequestBody): Promise { + const response = await this.client.post | ErrorResponse>( + SimulationPaths.create, + createSimulationParameters, + ); + + const data = this.handleResponse(response); + + return new Simulation(data); + } + + public async get(simulationId: string): Promise { + const urlWithPathParams = new PathParameters(SimulationPaths.get, { + simulation_id: simulationId, + }).deriveUrl(); + + const response = await this.client.get | ErrorResponse>(urlWithPathParams); + + const data = this.handleResponse(response); + + return new Simulation(data); + } + + public async update(simulationId: string, updateSimulation: UpdateSimulationRequestBody): Promise { + const urlWithPathParams = new PathParameters(SimulationPaths.update, { + simulation_id: simulationId, + }).deriveUrl(); + + const response = await this.client.patch< + UpdateSimulationRequestBody, + Response | ErrorResponse + >(urlWithPathParams, updateSimulation); + + const data = this.handleResponse(response); + + return new Simulation(data); + } +} diff --git a/src/resources/simulations/operations/create-simulation-request-body.ts b/src/resources/simulations/operations/create-simulation-request-body.ts new file mode 100644 index 0000000..8425110 --- /dev/null +++ b/src/resources/simulations/operations/create-simulation-request-body.ts @@ -0,0 +1,11 @@ +import type { SimulationScenarioType } from '../../../enums'; +import type { IEventName } from '../../../notifications'; +import type { DiscriminatedSimulationEventResponse } from '../../../types'; + +interface BaseCreateSimulationRequestBody { + notificationSettingId: string; + name: string; + type: IEventName | SimulationScenarioType; +} + +export type CreateSimulationRequestBody = DiscriminatedSimulationEventResponse; diff --git a/src/resources/simulations/operations/index.ts b/src/resources/simulations/operations/index.ts new file mode 100644 index 0000000..88d213e --- /dev/null +++ b/src/resources/simulations/operations/index.ts @@ -0,0 +1,9 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './create-simulation-request-body'; +export * from './list-simulation-query-parameters'; +export * from './update-simulation-request-body'; diff --git a/src/resources/simulations/operations/list-simulation-query-parameters.ts b/src/resources/simulations/operations/list-simulation-query-parameters.ts new file mode 100644 index 0000000..47e2943 --- /dev/null +++ b/src/resources/simulations/operations/list-simulation-query-parameters.ts @@ -0,0 +1,16 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { type Status } from '../../../enums'; + +export interface ListSimulationQueryParameters { + after?: string; + notificationSettingId?: string[]; + orderBy?: string; + perPage?: number; + id?: string[]; + status?: Status[]; +} diff --git a/src/resources/simulations/operations/update-simulation-request-body.ts b/src/resources/simulations/operations/update-simulation-request-body.ts new file mode 100644 index 0000000..5e36375 --- /dev/null +++ b/src/resources/simulations/operations/update-simulation-request-body.ts @@ -0,0 +1,15 @@ +import type { Status } from '../../../enums'; +import type { DiscriminatedSimulationEventResponse } from '../../../types'; + +interface BaseUpdateSimulationRequestBody { + notificationSettingId?: string; + name?: string; + status?: Status; +} + +type RawUpdateSimulationRequestBody = DiscriminatedSimulationEventResponse; + +// Map all properties to be optional +export type UpdateSimulationRequestBody = { + [Key in keyof RawUpdateSimulationRequestBody]?: RawUpdateSimulationRequestBody[Key]; +}; diff --git a/src/types/index.ts b/src/types/index.ts index ed5837f..29e7e8f 100644 --- a/src/types/index.ts +++ b/src/types/index.ts @@ -21,3 +21,7 @@ export * from './event-types'; export * from './notification-settings'; export * from './notifications'; export * from './report'; +export * from './simulation-type'; +export * from './simulation'; +export * from './simulation-run'; +export * from './simulation-run-event'; diff --git a/src/types/shared/index.ts b/src/types/shared/index.ts index 0b322fe..730fb86 100644 --- a/src/types/shared/index.ts +++ b/src/types/shared/index.ts @@ -33,3 +33,6 @@ export * from './billing-details-create'; export * from './billing-details-update'; export * from './custom-data'; export * from './import-meta-response'; +export * from './simulation-event-request'; +export * from './simulation-event-response'; +export * from './simulation-payload'; diff --git a/src/types/shared/simulation-event-request.ts b/src/types/shared/simulation-event-request.ts new file mode 100644 index 0000000..8c604fc --- /dev/null +++ b/src/types/shared/simulation-event-request.ts @@ -0,0 +1,9 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export interface ISimulationEventRequest { + body: string; +} diff --git a/src/types/shared/simulation-event-response.ts b/src/types/shared/simulation-event-response.ts new file mode 100644 index 0000000..5807b2b --- /dev/null +++ b/src/types/shared/simulation-event-response.ts @@ -0,0 +1,10 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export interface ISimulationEventResponse { + body: string; + status_code: number; +} diff --git a/src/types/shared/simulation-payload.ts b/src/types/shared/simulation-payload.ts new file mode 100644 index 0000000..7359796 --- /dev/null +++ b/src/types/shared/simulation-payload.ts @@ -0,0 +1,102 @@ +import type { IEventName } from '../../notifications'; +import { + type AddressCreatedEvent, + type AddressImportedEvent, + type AddressUpdatedEvent, + type AdjustmentCreatedEvent, + type AdjustmentUpdatedEvent, + type BusinessCreatedEvent, + type BusinessImportedEvent, + type BusinessUpdatedEvent, + type CustomerCreatedEvent, + type CustomerImportedEvent, + type CustomerUpdatedEvent, + type DiscountCreatedEvent, + type DiscountImportedEvent, + type DiscountUpdatedEvent, + type PayoutCreatedEvent, + type PayoutPaidEvent, + type PriceCreatedEvent, + type PriceImportedEvent, + type PriceUpdatedEvent, + type ProductCreatedEvent, + type ProductImportedEvent, + type ProductUpdatedEvent, + type ReportCreatedEvent, + type ReportUpdatedEvent, + type SubscriptionActivatedEvent, + type SubscriptionCanceledEvent, + type SubscriptionCreatedEvent, + type SubscriptionImportedEvent, + type SubscriptionPastDueEvent, + type SubscriptionPausedEvent, + type SubscriptionResumedEvent, + type SubscriptionTrialingEvent, + type SubscriptionUpdatedEvent, + type TransactionBilledEvent, + type TransactionCanceledEvent, + type TransactionCompletedEvent, + type TransactionCreatedEvent, + type TransactionPaidEvent, + type TransactionPastDueEvent, + type TransactionPaymentFailedEvent, + type TransactionReadyEvent, + type TransactionUpdatedEvent, +} from '../../notifications/events'; + +interface SimulationEventPayloadMap { + 'address.created': AddressCreatedEvent; + 'address.updated': AddressUpdatedEvent; + 'address.imported': AddressImportedEvent; + 'adjustment.created': AdjustmentCreatedEvent; + 'adjustment.updated': AdjustmentUpdatedEvent; + 'business.created': BusinessCreatedEvent; + 'business.updated': BusinessUpdatedEvent; + 'business.imported': BusinessImportedEvent; + 'customer.created': CustomerCreatedEvent; + 'customer.updated': CustomerUpdatedEvent; + 'customer.imported': CustomerImportedEvent; + 'discount.created': DiscountCreatedEvent; + 'discount.updated': DiscountUpdatedEvent; + 'discount.imported': DiscountImportedEvent; + 'payout.created': PayoutCreatedEvent; + 'payout.paid': PayoutPaidEvent; + 'price.created': PriceCreatedEvent; + 'price.updated': PriceUpdatedEvent; + 'price.imported': PriceImportedEvent; + 'product.created': ProductCreatedEvent; + 'product.updated': ProductUpdatedEvent; + 'product.imported': ProductImportedEvent; + 'subscription.created': SubscriptionCreatedEvent; + 'subscription.past_due': SubscriptionPastDueEvent; + 'subscription.activated': SubscriptionActivatedEvent; + 'subscription.canceled': SubscriptionCanceledEvent; + 'subscription.imported': SubscriptionImportedEvent; + 'subscription.paused': SubscriptionPausedEvent; + 'subscription.resumed': SubscriptionResumedEvent; + 'subscription.trialing': SubscriptionTrialingEvent; + 'subscription.updated': SubscriptionUpdatedEvent; + 'transaction.billed': TransactionBilledEvent; + 'transaction.canceled': TransactionCanceledEvent; + 'transaction.completed': TransactionCompletedEvent; + 'transaction.created': TransactionCreatedEvent; + 'transaction.paid': TransactionPaidEvent; + 'transaction.past_due': TransactionPastDueEvent; + 'transaction.payment_failed': TransactionPaymentFailedEvent; + 'transaction.ready': TransactionReadyEvent; + 'transaction.updated': TransactionUpdatedEvent; + 'report.created': ReportCreatedEvent; + 'report.updated': ReportUpdatedEvent; + subscription_creation: never; + subscription_renewal: never; + subscription_pause: never; + subscription_resume: never; + subscription_cancellation: never; +} + +export type DiscriminatedSimulationEventResponse = { + [K in keyof SimulationEventPayloadMap]: Base & { + type: K; + payload?: K extends IEventName ? Partial | null : null; + }; +}[keyof SimulationEventPayloadMap]; diff --git a/src/types/simulation-run-event/index.ts b/src/types/simulation-run-event/index.ts new file mode 100644 index 0000000..3c831c0 --- /dev/null +++ b/src/types/simulation-run-event/index.ts @@ -0,0 +1,7 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './simulation-run-event-response'; diff --git a/src/types/simulation-run-event/simulation-run-event-response.ts b/src/types/simulation-run-event/simulation-run-event-response.ts new file mode 100644 index 0000000..7f2150d --- /dev/null +++ b/src/types/simulation-run-event/simulation-run-event-response.ts @@ -0,0 +1,20 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import type { ISimulationEventRequest, ISimulationEventResponse } from '../shared'; +import type { SimulationRunEventStatus, SimulationScenarioType } from '../../enums'; +import type { IEventName } from '../../notifications'; + +export interface ISimulationRunEventResponse { + id: string; + status: SimulationRunEventStatus; + event_type: IEventName | SimulationScenarioType; + payload: any; + request?: ISimulationEventRequest | null; + response?: ISimulationEventResponse | null; + created_at: string; + updated_at: string; +} diff --git a/src/types/simulation-run/index.ts b/src/types/simulation-run/index.ts new file mode 100644 index 0000000..07636a8 --- /dev/null +++ b/src/types/simulation-run/index.ts @@ -0,0 +1,7 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './simulation-run-response'; diff --git a/src/types/simulation-run/simulation-run-response.ts b/src/types/simulation-run/simulation-run-response.ts new file mode 100644 index 0000000..76b7c98 --- /dev/null +++ b/src/types/simulation-run/simulation-run-response.ts @@ -0,0 +1,18 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import type { ISimulationRunEventResponse } from '..'; +import type { SimulationRunStatus, SimulationScenarioType } from '../../enums'; +import type { IEventName } from '../../notifications'; + +export interface ISimulationRunResponse { + id: string; + status: SimulationRunStatus; + created_at: string; + updated_at: string; + type: IEventName | SimulationScenarioType; + events?: ISimulationRunEventResponse[]; +} diff --git a/src/types/simulation-type/index.ts b/src/types/simulation-type/index.ts new file mode 100644 index 0000000..d3bf69b --- /dev/null +++ b/src/types/simulation-type/index.ts @@ -0,0 +1,7 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './simulation-type'; diff --git a/src/types/simulation-type/simulation-type.ts b/src/types/simulation-type/simulation-type.ts new file mode 100644 index 0000000..8952838 --- /dev/null +++ b/src/types/simulation-type/simulation-type.ts @@ -0,0 +1,17 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +import { type SimulationKind } from '../../enums'; +import { type IEventName } from '../../notifications'; + +export interface ISimulationTypeResponse { + name: string; + label: string; + description: string; + group: string; + type: SimulationKind; + events: IEventName[]; +} diff --git a/src/types/simulation/index.ts b/src/types/simulation/index.ts new file mode 100644 index 0000000..114dc72 --- /dev/null +++ b/src/types/simulation/index.ts @@ -0,0 +1,7 @@ +/** + * ! Autogenerated code ! + * Do not make changes to this file. + * Changes may be overwritten as part of auto-generation. + */ + +export * from './simulation-response'; diff --git a/src/types/simulation/simulation-response.ts b/src/types/simulation/simulation-response.ts new file mode 100644 index 0000000..2fd6d84 --- /dev/null +++ b/src/types/simulation/simulation-response.ts @@ -0,0 +1,14 @@ +import type { Status } from '../../enums'; +import type { DiscriminatedSimulationEventResponse } from '../shared/simulation-payload'; + +export type ISimulationResponse = DiscriminatedSimulationEventResponse; + +interface BaseSimulationResponse { + id: string; + status: Status; + notification_setting_id: string; + name: string; + last_run_at?: string | null; + created_at: string; + updated_at: string; +}