From 7e8aa742c35f82615786e9f3d70597b08dc9ca1d Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Fri, 16 Jan 2026 18:29:00 +0000 Subject: [PATCH 01/17] chore(internal): update `actions/checkout` version --- .github/workflows/ci.yml | 6 +++--- .github/workflows/publish-pypi.yml | 2 +- .github/workflows/release-doctor.yml | 2 +- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 0dc7ceeb..89bf7ed1 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -19,7 +19,7 @@ jobs: runs-on: ${{ github.repository == 'stainless-sdks/modern-treasury-python' && 'depot-ubuntu-24.04' || 'ubuntu-latest' }} if: github.event_name == 'push' || github.event.pull_request.head.repo.fork steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - name: Install Rye run: | @@ -44,7 +44,7 @@ jobs: id-token: write runs-on: ${{ github.repository == 'stainless-sdks/modern-treasury-python' && 'depot-ubuntu-24.04' || 'ubuntu-latest' }} steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - name: Install Rye run: | @@ -81,7 +81,7 @@ jobs: runs-on: ${{ github.repository == 'stainless-sdks/modern-treasury-python' && 'depot-ubuntu-24.04' || 'ubuntu-latest' }} if: github.event_name == 'push' || github.event.pull_request.head.repo.fork steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - name: Install Rye run: | diff --git a/.github/workflows/publish-pypi.yml b/.github/workflows/publish-pypi.yml index 8411b943..c1e08532 100644 --- a/.github/workflows/publish-pypi.yml +++ b/.github/workflows/publish-pypi.yml @@ -14,7 +14,7 @@ jobs: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - name: Install Rye run: | diff --git a/.github/workflows/release-doctor.yml b/.github/workflows/release-doctor.yml index 3777d44b..f1972652 100644 --- a/.github/workflows/release-doctor.yml +++ b/.github/workflows/release-doctor.yml @@ -12,7 +12,7 @@ jobs: if: github.repository == 'Modern-Treasury/modern-treasury-python' && (github.event_name == 'push' || github.event_name == 'workflow_dispatch' || startsWith(github.head_ref, 'release-please') || github.head_ref == 'next') steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - name: Check release environment run: | From 59421e99d18c022caeeae69b34b21c3ad4d44311 Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Tue, 20 Jan 2026 18:23:38 +0000 Subject: [PATCH 02/17] feat(api): api update --- .stats.yml | 4 ++-- .../resources/account_details.py | 2 ++ .../resources/legal_entities.py | 24 +++++++++++++++---- src/modern_treasury/types/account_detail.py | 1 + .../types/account_detail_create_params.py | 1 + .../types/bulk_request_create_params.py | 2 ++ .../types/child_legal_entity.py | 9 +++++-- .../connection_legal_entity_create_params.py | 13 ++++++++-- .../types/counterparty_create_params.py | 14 +++++++++-- .../types/external_account_create_params.py | 1 + .../types/incoming_payment_detail.py | 1 + src/modern_treasury/types/legal_entity.py | 9 +++++-- .../types/legal_entity_create_params.py | 13 ++++++++-- .../types/legal_entity_update_params.py | 4 ++-- .../payment_order_create_async_params.py | 1 + .../types/payment_order_create_params.py | 1 + .../types/payment_order_update_params.py | 1 + .../types/shared/child_legal_entity_create.py | 13 ++++++++-- .../child_legal_entity_create.py | 13 ++++++++-- .../types/virtual_account_create_params.py | 1 + .../test_connection_legal_entities.py | 4 ++++ tests/api_resources/test_counterparties.py | 4 ++++ tests/api_resources/test_legal_entities.py | 4 ++++ .../test_legal_entity_associations.py | 2 ++ 24 files changed, 120 insertions(+), 22 deletions(-) diff --git a/.stats.yml b/.stats.yml index 0b16fcb8..619477e0 100644 --- a/.stats.yml +++ b/.stats.yml @@ -1,4 +1,4 @@ configured_endpoints: 168 -openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-b70193f02d90e71e996b5cf45038db80fe123344267e22207026f755e3198f56.yml -openapi_spec_hash: 289fdda5739de528fa149e924511e428 +openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-e15a21ef6628dcc5510621b680a6373e71c53d5d36e89ca191a8223a94298be2.yml +openapi_spec_hash: e49d45dc10032cea0ee381f1ed002dc8 config_hash: 196d1bf0caae233683efb6abc123941f diff --git a/src/modern_treasury/resources/account_details.py b/src/modern_treasury/resources/account_details.py index be1a7f0d..acce2106 100644 --- a/src/modern_treasury/resources/account_details.py +++ b/src/modern_treasury/resources/account_details.py @@ -51,6 +51,7 @@ def create( account_number_type: Literal[ "au_number", "base_address", + "card_token", "clabe", "ethereum_address", "hk_number", @@ -280,6 +281,7 @@ async def create( account_number_type: Literal[ "au_number", "base_address", + "card_token", "clabe", "ethereum_address", "hk_number", diff --git a/src/modern_treasury/resources/legal_entities.py b/src/modern_treasury/resources/legal_entities.py index 591dcf75..34f801ad 100644 --- a/src/modern_treasury/resources/legal_entities.py +++ b/src/modern_treasury/resources/legal_entities.py @@ -57,6 +57,7 @@ def create( business_name: Optional[str] | Omit = omit, citizenship_country: Optional[str] | Omit = omit, compliance_details: Optional[LegalEntityComplianceDetail] | Omit = omit, + connection_id: Optional[str] | Omit = omit, country_of_incorporation: Optional[str] | Omit = omit, date_formed: Union[str, date, None] | Omit = omit, date_of_birth: Union[str, date, None] | Omit = omit, @@ -107,6 +108,12 @@ def create( citizenship_country: The country of citizenship for an individual. + connection_id: The connection ID for the connection the legal entity is associated with. + Defaults to the id of the connection designated with an is_default value of true + or the id of an existing operational connection if only one is available. Pass + in a value of null to prevent the connection from being associated with the + legal entity. + country_of_incorporation: The country code where the business is incorporated in the ISO 3166-1 alpha-2 or alpha-3 formats. @@ -116,7 +123,7 @@ def create( email: The entity's primary email. - expected_activity_volume: Monthly expected transaction volume in entity's local currency. + expected_activity_volume: Monthly expected transaction volume in USD. first_name: An individual's first name. @@ -175,6 +182,7 @@ def create( "business_name": business_name, "citizenship_country": citizenship_country, "compliance_details": compliance_details, + "connection_id": connection_id, "country_of_incorporation": country_of_incorporation, "date_formed": date_formed, "date_of_birth": date_of_birth, @@ -312,7 +320,7 @@ def update( email: The entity's primary email. - expected_activity_volume: Monthly expected transaction volume in entity's local currency. + expected_activity_volume: Monthly expected transaction volume in USD. first_name: An individual's first name. @@ -491,6 +499,7 @@ async def create( business_name: Optional[str] | Omit = omit, citizenship_country: Optional[str] | Omit = omit, compliance_details: Optional[LegalEntityComplianceDetail] | Omit = omit, + connection_id: Optional[str] | Omit = omit, country_of_incorporation: Optional[str] | Omit = omit, date_formed: Union[str, date, None] | Omit = omit, date_of_birth: Union[str, date, None] | Omit = omit, @@ -541,6 +550,12 @@ async def create( citizenship_country: The country of citizenship for an individual. + connection_id: The connection ID for the connection the legal entity is associated with. + Defaults to the id of the connection designated with an is_default value of true + or the id of an existing operational connection if only one is available. Pass + in a value of null to prevent the connection from being associated with the + legal entity. + country_of_incorporation: The country code where the business is incorporated in the ISO 3166-1 alpha-2 or alpha-3 formats. @@ -550,7 +565,7 @@ async def create( email: The entity's primary email. - expected_activity_volume: Monthly expected transaction volume in entity's local currency. + expected_activity_volume: Monthly expected transaction volume in USD. first_name: An individual's first name. @@ -609,6 +624,7 @@ async def create( "business_name": business_name, "citizenship_country": citizenship_country, "compliance_details": compliance_details, + "connection_id": connection_id, "country_of_incorporation": country_of_incorporation, "date_formed": date_formed, "date_of_birth": date_of_birth, @@ -746,7 +762,7 @@ async def update( email: The entity's primary email. - expected_activity_volume: Monthly expected transaction volume in entity's local currency. + expected_activity_volume: Monthly expected transaction volume in USD. first_name: An individual's first name. diff --git a/src/modern_treasury/types/account_detail.py b/src/modern_treasury/types/account_detail.py index 72a03d3d..ec3f279c 100644 --- a/src/modern_treasury/types/account_detail.py +++ b/src/modern_treasury/types/account_detail.py @@ -18,6 +18,7 @@ class AccountDetail(BaseModel): account_number_type: Literal[ "au_number", "base_address", + "card_token", "clabe", "ethereum_address", "hk_number", diff --git a/src/modern_treasury/types/account_detail_create_params.py b/src/modern_treasury/types/account_detail_create_params.py index cd7b49e9..df0ba20b 100644 --- a/src/modern_treasury/types/account_detail_create_params.py +++ b/src/modern_treasury/types/account_detail_create_params.py @@ -16,6 +16,7 @@ class AccountDetailCreateParams(TypedDict, total=False): account_number_type: Literal[ "au_number", "base_address", + "card_token", "clabe", "ethereum_address", "hk_number", diff --git a/src/modern_treasury/types/bulk_request_create_params.py b/src/modern_treasury/types/bulk_request_create_params.py index 35209659..56e81531 100644 --- a/src/modern_treasury/types/bulk_request_create_params.py +++ b/src/modern_treasury/types/bulk_request_create_params.py @@ -155,6 +155,7 @@ class ResourcePaymentOrderAsyncCreateRequestReceivingAccountAccountDetail(TypedD account_number_type: Literal[ "au_number", "base_address", + "card_token", "clabe", "ethereum_address", "hk_number", @@ -882,6 +883,7 @@ class ResourcePaymentOrderUpdateRequestWithIDReceivingAccountAccountDetail(Typed account_number_type: Literal[ "au_number", "base_address", + "card_token", "clabe", "ethereum_address", "hk_number", diff --git a/src/modern_treasury/types/child_legal_entity.py b/src/modern_treasury/types/child_legal_entity.py index 32c3d007..a51599c0 100644 --- a/src/modern_treasury/types/child_legal_entity.py +++ b/src/modern_treasury/types/child_legal_entity.py @@ -7,6 +7,7 @@ from typing_extensions import Literal from .._models import BaseModel +from .document import Document from .shared.legal_entity_compliance_detail import LegalEntityComplianceDetail from .shared.legal_entity_industry_classification import LegalEntityIndustryClassification @@ -113,6 +114,8 @@ class Identification(BaseModel): discarded_at: Optional[datetime] = None + documents: List[Document] + expiration_date: Optional[date] = None """ The date when the Identification is no longer considered valid by the issuing @@ -189,7 +192,7 @@ class WealthAndEmploymentDetails(BaseModel): id: str annual_income: Optional[int] = None - """The annual income of the individual.""" + """The annual income of the individual in USD.""" created_at: datetime @@ -369,13 +372,15 @@ class ChildLegalEntity(BaseModel): discarded_at: Optional[datetime] = None + documents: List[Document] + doing_business_as_names: List[str] email: Optional[str] = None """The entity's primary email.""" expected_activity_volume: Optional[int] = None - """Monthly expected transaction volume in entity's local currency.""" + """Monthly expected transaction volume in USD.""" first_name: Optional[str] = None """An individual's first name.""" diff --git a/src/modern_treasury/types/connection_legal_entity_create_params.py b/src/modern_treasury/types/connection_legal_entity_create_params.py index f0f9feb0..378b99e8 100644 --- a/src/modern_treasury/types/connection_legal_entity_create_params.py +++ b/src/modern_treasury/types/connection_legal_entity_create_params.py @@ -90,7 +90,7 @@ class LegalEntityWealthAndEmploymentDetails(TypedDict, total=False): id: Required[str] annual_income: Required[Optional[int]] - """The annual income of the individual.""" + """The annual income of the individual in USD.""" created_at: Required[Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]] @@ -264,6 +264,15 @@ class LegalEntity(TypedDict, total=False): compliance_details: Optional[LegalEntityComplianceDetail] + connection_id: Optional[str] + """The connection ID for the connection the legal entity is associated with. + + Defaults to the id of the connection designated with an is_default value of true + or the id of an existing operational connection if only one is available. Pass + in a value of null to prevent the connection from being associated with the + legal entity. + """ + country_of_incorporation: Optional[str] """ The country code where the business is incorporated in the ISO 3166-1 alpha-2 or @@ -282,7 +291,7 @@ class LegalEntity(TypedDict, total=False): """The entity's primary email.""" expected_activity_volume: Optional[int] - """Monthly expected transaction volume in entity's local currency.""" + """Monthly expected transaction volume in USD.""" first_name: Optional[str] """An individual's first name.""" diff --git a/src/modern_treasury/types/counterparty_create_params.py b/src/modern_treasury/types/counterparty_create_params.py index 4ba40cbb..d6fce210 100644 --- a/src/modern_treasury/types/counterparty_create_params.py +++ b/src/modern_treasury/types/counterparty_create_params.py @@ -93,6 +93,7 @@ class AccountAccountDetail(TypedDict, total=False): account_number_type: Literal[ "au_number", "base_address", + "card_token", "clabe", "ethereum_address", "hk_number", @@ -309,7 +310,7 @@ class LegalEntityWealthAndEmploymentDetails(TypedDict, total=False): id: Required[str] annual_income: Required[Optional[int]] - """The annual income of the individual.""" + """The annual income of the individual in USD.""" created_at: Required[Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]] @@ -484,6 +485,15 @@ class LegalEntity(TypedDict, total=False): compliance_details: Optional[LegalEntityComplianceDetail] + connection_id: Optional[str] + """The connection ID for the connection the legal entity is associated with. + + Defaults to the id of the connection designated with an is_default value of true + or the id of an existing operational connection if only one is available. Pass + in a value of null to prevent the connection from being associated with the + legal entity. + """ + country_of_incorporation: Optional[str] """ The country code where the business is incorporated in the ISO 3166-1 alpha-2 or @@ -502,7 +512,7 @@ class LegalEntity(TypedDict, total=False): """The entity's primary email.""" expected_activity_volume: Optional[int] - """Monthly expected transaction volume in entity's local currency.""" + """Monthly expected transaction volume in USD.""" first_name: Optional[str] """An individual's first name.""" diff --git a/src/modern_treasury/types/external_account_create_params.py b/src/modern_treasury/types/external_account_create_params.py index 051d0045..2729e2fb 100644 --- a/src/modern_treasury/types/external_account_create_params.py +++ b/src/modern_treasury/types/external_account_create_params.py @@ -76,6 +76,7 @@ class AccountDetail(TypedDict, total=False): account_number_type: Literal[ "au_number", "base_address", + "card_token", "clabe", "ethereum_address", "hk_number", diff --git a/src/modern_treasury/types/incoming_payment_detail.py b/src/modern_treasury/types/incoming_payment_detail.py index ff8de187..c41b6297 100644 --- a/src/modern_treasury/types/incoming_payment_detail.py +++ b/src/modern_treasury/types/incoming_payment_detail.py @@ -71,6 +71,7 @@ class IncomingPaymentDetail(BaseModel): Literal[ "au_number", "base_address", + "card_token", "clabe", "ethereum_address", "hk_number", diff --git a/src/modern_treasury/types/legal_entity.py b/src/modern_treasury/types/legal_entity.py index d2138e2d..024754ff 100644 --- a/src/modern_treasury/types/legal_entity.py +++ b/src/modern_treasury/types/legal_entity.py @@ -7,6 +7,7 @@ from typing_extensions import Literal from .._models import BaseModel +from .document import Document from .shared.legal_entity_compliance_detail import LegalEntityComplianceDetail from .shared.legal_entity_industry_classification import LegalEntityIndustryClassification @@ -113,6 +114,8 @@ class Identification(BaseModel): discarded_at: Optional[datetime] = None + documents: List[Document] + expiration_date: Optional[date] = None """ The date when the Identification is no longer considered valid by the issuing @@ -189,7 +192,7 @@ class WealthAndEmploymentDetails(BaseModel): id: str annual_income: Optional[int] = None - """The annual income of the individual.""" + """The annual income of the individual in USD.""" created_at: datetime @@ -369,13 +372,15 @@ class LegalEntity(BaseModel): discarded_at: Optional[datetime] = None + documents: List[Document] + doing_business_as_names: List[str] email: Optional[str] = None """The entity's primary email.""" expected_activity_volume: Optional[int] = None - """Monthly expected transaction volume in entity's local currency.""" + """Monthly expected transaction volume in USD.""" first_name: Optional[str] = None """An individual's first name.""" diff --git a/src/modern_treasury/types/legal_entity_create_params.py b/src/modern_treasury/types/legal_entity_create_params.py index ecfdba5a..736d26de 100644 --- a/src/modern_treasury/types/legal_entity_create_params.py +++ b/src/modern_treasury/types/legal_entity_create_params.py @@ -36,6 +36,15 @@ class LegalEntityCreateParams(TypedDict, total=False): compliance_details: Optional[LegalEntityComplianceDetail] + connection_id: Optional[str] + """The connection ID for the connection the legal entity is associated with. + + Defaults to the id of the connection designated with an is_default value of true + or the id of an existing operational connection if only one is available. Pass + in a value of null to prevent the connection from being associated with the + legal entity. + """ + country_of_incorporation: Optional[str] """ The country code where the business is incorporated in the ISO 3166-1 alpha-2 or @@ -54,7 +63,7 @@ class LegalEntityCreateParams(TypedDict, total=False): """The entity's primary email.""" expected_activity_volume: Optional[int] - """Monthly expected transaction volume in entity's local currency.""" + """Monthly expected transaction volume in USD.""" first_name: Optional[str] """An individual's first name.""" @@ -176,7 +185,7 @@ class WealthAndEmploymentDetails(TypedDict, total=False): id: Required[str] annual_income: Required[Optional[int]] - """The annual income of the individual.""" + """The annual income of the individual in USD.""" created_at: Required[Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]] diff --git a/src/modern_treasury/types/legal_entity_update_params.py b/src/modern_treasury/types/legal_entity_update_params.py index 1356b488..30b08373 100644 --- a/src/modern_treasury/types/legal_entity_update_params.py +++ b/src/modern_treasury/types/legal_entity_update_params.py @@ -51,7 +51,7 @@ class LegalEntityUpdateParams(TypedDict, total=False): """The entity's primary email.""" expected_activity_volume: Optional[int] - """Monthly expected transaction volume in entity's local currency.""" + """Monthly expected transaction volume in USD.""" first_name: Optional[str] """An individual's first name.""" @@ -170,7 +170,7 @@ class WealthAndEmploymentDetails(TypedDict, total=False): id: Required[str] annual_income: Required[Optional[int]] - """The annual income of the individual.""" + """The annual income of the individual in USD.""" created_at: Required[Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]] diff --git a/src/modern_treasury/types/payment_order_create_async_params.py b/src/modern_treasury/types/payment_order_create_async_params.py index 8dc48305..196beb01 100644 --- a/src/modern_treasury/types/payment_order_create_async_params.py +++ b/src/modern_treasury/types/payment_order_create_async_params.py @@ -300,6 +300,7 @@ class ReceivingAccountAccountDetail(TypedDict, total=False): account_number_type: Literal[ "au_number", "base_address", + "card_token", "clabe", "ethereum_address", "hk_number", diff --git a/src/modern_treasury/types/payment_order_create_params.py b/src/modern_treasury/types/payment_order_create_params.py index 14e6de91..12ebb784 100644 --- a/src/modern_treasury/types/payment_order_create_params.py +++ b/src/modern_treasury/types/payment_order_create_params.py @@ -341,6 +341,7 @@ class ReceivingAccountAccountDetail(TypedDict, total=False): account_number_type: Literal[ "au_number", "base_address", + "card_token", "clabe", "ethereum_address", "hk_number", diff --git a/src/modern_treasury/types/payment_order_update_params.py b/src/modern_treasury/types/payment_order_update_params.py index 27765ce8..3b801d71 100644 --- a/src/modern_treasury/types/payment_order_update_params.py +++ b/src/modern_treasury/types/payment_order_update_params.py @@ -317,6 +317,7 @@ class ReceivingAccountAccountDetail(TypedDict, total=False): account_number_type: Literal[ "au_number", "base_address", + "card_token", "clabe", "ethereum_address", "hk_number", diff --git a/src/modern_treasury/types/shared/child_legal_entity_create.py b/src/modern_treasury/types/shared/child_legal_entity_create.py index 6bd6017c..2c450c6b 100644 --- a/src/modern_treasury/types/shared/child_legal_entity_create.py +++ b/src/modern_treasury/types/shared/child_legal_entity_create.py @@ -71,7 +71,7 @@ class WealthAndEmploymentDetails(BaseModel): id: str annual_income: Optional[int] = None - """The annual income of the individual.""" + """The annual income of the individual in USD.""" created_at: datetime @@ -233,6 +233,15 @@ class ChildLegalEntityCreate(BaseModel): compliance_details: Optional[LegalEntityComplianceDetail] = None + connection_id: Optional[str] = None + """The connection ID for the connection the legal entity is associated with. + + Defaults to the id of the connection designated with an is_default value of true + or the id of an existing operational connection if only one is available. Pass + in a value of null to prevent the connection from being associated with the + legal entity. + """ + country_of_incorporation: Optional[str] = None """ The country code where the business is incorporated in the ISO 3166-1 alpha-2 or @@ -251,7 +260,7 @@ class ChildLegalEntityCreate(BaseModel): """The entity's primary email.""" expected_activity_volume: Optional[int] = None - """Monthly expected transaction volume in entity's local currency.""" + """Monthly expected transaction volume in USD.""" first_name: Optional[str] = None """An individual's first name.""" diff --git a/src/modern_treasury/types/shared_params/child_legal_entity_create.py b/src/modern_treasury/types/shared_params/child_legal_entity_create.py index a477224e..34427d3e 100644 --- a/src/modern_treasury/types/shared_params/child_legal_entity_create.py +++ b/src/modern_treasury/types/shared_params/child_legal_entity_create.py @@ -72,7 +72,7 @@ class WealthAndEmploymentDetails(TypedDict, total=False): id: Required[str] annual_income: Required[Optional[int]] - """The annual income of the individual.""" + """The annual income of the individual in USD.""" created_at: Required[Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]] @@ -244,6 +244,15 @@ class ChildLegalEntityCreate(TypedDict, total=False): compliance_details: Optional[LegalEntityComplianceDetail] + connection_id: Optional[str] + """The connection ID for the connection the legal entity is associated with. + + Defaults to the id of the connection designated with an is_default value of true + or the id of an existing operational connection if only one is available. Pass + in a value of null to prevent the connection from being associated with the + legal entity. + """ + country_of_incorporation: Optional[str] """ The country code where the business is incorporated in the ISO 3166-1 alpha-2 or @@ -262,7 +271,7 @@ class ChildLegalEntityCreate(TypedDict, total=False): """The entity's primary email.""" expected_activity_volume: Optional[int] - """Monthly expected transaction volume in entity's local currency.""" + """Monthly expected transaction volume in USD.""" first_name: Optional[str] """An individual's first name.""" diff --git a/src/modern_treasury/types/virtual_account_create_params.py b/src/modern_treasury/types/virtual_account_create_params.py index fde40b3b..3c7eeae1 100644 --- a/src/modern_treasury/types/virtual_account_create_params.py +++ b/src/modern_treasury/types/virtual_account_create_params.py @@ -64,6 +64,7 @@ class AccountDetail(TypedDict, total=False): account_number_type: Literal[ "au_number", "base_address", + "card_token", "clabe", "ethereum_address", "hk_number", diff --git a/tests/api_resources/test_connection_legal_entities.py b/tests/api_resources/test_connection_legal_entities.py index 634e7fcc..ce45108a 100644 --- a/tests/api_resources/test_connection_legal_entities.py +++ b/tests/api_resources/test_connection_legal_entities.py @@ -73,6 +73,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), "date_of_birth": parse_date("2019-12-27"), @@ -147,6 +148,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), "date_of_birth": parse_date("2019-12-27"), @@ -465,6 +467,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), "date_of_birth": parse_date("2019-12-27"), @@ -539,6 +542,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), "date_of_birth": parse_date("2019-12-27"), diff --git a/tests/api_resources/test_counterparties.py b/tests/api_resources/test_counterparties.py index 62abd915..e03b7d81 100644 --- a/tests/api_resources/test_counterparties.py +++ b/tests/api_resources/test_counterparties.py @@ -138,6 +138,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), "date_of_birth": parse_date("2019-12-27"), @@ -212,6 +213,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), "date_of_birth": parse_date("2019-12-27"), @@ -701,6 +703,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), "date_of_birth": parse_date("2019-12-27"), @@ -775,6 +778,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), "date_of_birth": parse_date("2019-12-27"), diff --git a/tests/api_resources/test_legal_entities.py b/tests/api_resources/test_legal_entities.py index 8711cf3f..a5245798 100644 --- a/tests/api_resources/test_legal_entities.py +++ b/tests/api_resources/test_legal_entities.py @@ -73,6 +73,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + connection_id="connection_id", country_of_incorporation="country_of_incorporation", date_formed=parse_date("2019-12-27"), date_of_birth=parse_date("2019-12-27"), @@ -147,6 +148,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), "date_of_birth": parse_date("2019-12-27"), @@ -568,6 +570,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + connection_id="connection_id", country_of_incorporation="country_of_incorporation", date_formed=parse_date("2019-12-27"), date_of_birth=parse_date("2019-12-27"), @@ -642,6 +645,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), "date_of_birth": parse_date("2019-12-27"), diff --git a/tests/api_resources/test_legal_entity_associations.py b/tests/api_resources/test_legal_entity_associations.py index 47a400c2..618b2562 100644 --- a/tests/api_resources/test_legal_entity_associations.py +++ b/tests/api_resources/test_legal_entity_associations.py @@ -73,6 +73,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), "date_of_birth": parse_date("2019-12-27"), @@ -243,6 +244,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "validated": True, "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), }, + "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), "date_of_birth": parse_date("2019-12-27"), From b019b1f45f89acebdfb3cd77e9485403c2671f8f Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Fri, 23 Jan 2026 18:13:52 +0000 Subject: [PATCH 03/17] chore(ci): upgrade `actions/github-script` --- .github/workflows/ci.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 89bf7ed1..f3856da3 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -63,7 +63,7 @@ jobs: - name: Get GitHub OIDC Token if: github.repository == 'stainless-sdks/modern-treasury-python' id: github-oidc - uses: actions/github-script@v6 + uses: actions/github-script@v8 with: script: core.setOutput('github_token', await core.getIDToken()); From a8c7d8d62b7ab86c8cbd940b6a66905d218a2002 Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Tue, 27 Jan 2026 15:24:07 +0000 Subject: [PATCH 04/17] feat(api): api update --- .stats.yml | 4 +- .../resources/legal_entities.py | 64 +++++++++++++++ .../types/child_legal_entity.py | 46 +++++++++++ .../connection_legal_entity_create_params.py | 46 +++++++++++ .../types/counterparty_create_params.py | 46 +++++++++++ src/modern_treasury/types/legal_entity.py | 46 +++++++++++ .../types/legal_entity_create_params.py | 54 ++++++++++++- .../types/legal_entity_update_params.py | 54 ++++++++++++- .../types/shared/child_legal_entity_create.py | 54 ++++++++++++- .../child_legal_entity_create.py | 54 ++++++++++++- src/modern_treasury/types/transaction.py | 2 +- .../test_connection_legal_entities.py | 52 +++++++++++++ tests/api_resources/test_counterparties.py | 52 +++++++++++++ tests/api_resources/test_legal_entities.py | 78 +++++++++++++++++++ .../test_legal_entity_associations.py | 26 +++++++ 15 files changed, 671 insertions(+), 7 deletions(-) diff --git a/.stats.yml b/.stats.yml index 619477e0..d70d0999 100644 --- a/.stats.yml +++ b/.stats.yml @@ -1,4 +1,4 @@ configured_endpoints: 168 -openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-e15a21ef6628dcc5510621b680a6373e71c53d5d36e89ca191a8223a94298be2.yml -openapi_spec_hash: e49d45dc10032cea0ee381f1ed002dc8 +openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-d8140aaa2f4b9b2fd803a2135c87078d7081b3fdac301913eb1263d0a4ee794d.yml +openapi_spec_hash: b5ff512582cc4da8d4cd625ef651bc84 config_hash: 196d1bf0caae233683efb6abc123941f diff --git a/src/modern_treasury/resources/legal_entities.py b/src/modern_treasury/resources/legal_entities.py index 34f801ad..209a604b 100644 --- a/src/modern_treasury/resources/legal_entities.py +++ b/src/modern_treasury/resources/legal_entities.py @@ -74,6 +74,7 @@ def create( Literal["corporation", "llc", "non_profit", "partnership", "sole_proprietorship", "trust"] ] | Omit = omit, + listed_exchange: Optional[str] | Omit = omit, metadata: Dict[str, str] | Omit = omit, middle_name: Optional[str] | Omit = omit, operating_jurisdictions: SequenceNotStr[str] | Omit = omit, @@ -82,8 +83,11 @@ def create( preferred_name: Optional[str] | Omit = omit, prefix: Optional[str] | Omit = omit, primary_social_media_sites: SequenceNotStr[str] | Omit = omit, + regulators: Optional[Iterable[legal_entity_create_params.Regulator]] | Omit = omit, risk_rating: Optional[Literal["low", "medium", "high"]] | Omit = omit, suffix: Optional[str] | Omit = omit, + third_party_verification: Optional[legal_entity_create_params.ThirdPartyVerification] | Omit = omit, + ticker_symbol: Optional[str] | Omit = omit, wealth_and_employment_details: Optional[legal_entity_create_params.WealthAndEmploymentDetails] | Omit = omit, website: Optional[str] | Omit = omit, # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. @@ -139,6 +143,8 @@ def create( legal_structure: The business's legal structure. + listed_exchange: ISO 10383 market identifier code. + metadata: Additional data represented as key-value pairs. Both the key and value must be strings. @@ -155,10 +161,16 @@ def create( primary_social_media_sites: A list of primary social media URLs for the business. + regulators: Array of regulatory bodies overseeing this institution. + risk_rating: The risk rating of the legal entity. One of low, medium, high. suffix: An individual's suffix. + third_party_verification: Information describing a third-party verification run by an external vendor. + + ticker_symbol: Stock ticker symbol for publicly traded companies. + website: The entity's primary website URL. extra_headers: Send extra headers @@ -196,6 +208,7 @@ def create( "last_name": last_name, "legal_entity_associations": legal_entity_associations, "legal_structure": legal_structure, + "listed_exchange": listed_exchange, "metadata": metadata, "middle_name": middle_name, "operating_jurisdictions": operating_jurisdictions, @@ -204,8 +217,11 @@ def create( "preferred_name": preferred_name, "prefix": prefix, "primary_social_media_sites": primary_social_media_sites, + "regulators": regulators, "risk_rating": risk_rating, "suffix": suffix, + "third_party_verification": third_party_verification, + "ticker_symbol": ticker_symbol, "wealth_and_employment_details": wealth_and_employment_details, "website": website, }, @@ -279,6 +295,7 @@ def update( Literal["corporation", "llc", "non_profit", "partnership", "sole_proprietorship", "trust"] ] | Omit = omit, + listed_exchange: Optional[str] | Omit = omit, metadata: Dict[str, str] | Omit = omit, middle_name: Optional[str] | Omit = omit, operating_jurisdictions: SequenceNotStr[str] | Omit = omit, @@ -287,8 +304,11 @@ def update( preferred_name: Optional[str] | Omit = omit, prefix: Optional[str] | Omit = omit, primary_social_media_sites: SequenceNotStr[str] | Omit = omit, + regulators: Optional[Iterable[legal_entity_update_params.Regulator]] | Omit = omit, risk_rating: Optional[Literal["low", "medium", "high"]] | Omit = omit, suffix: Optional[str] | Omit = omit, + third_party_verification: Optional[legal_entity_update_params.ThirdPartyVerification] | Omit = omit, + ticker_symbol: Optional[str] | Omit = omit, wealth_and_employment_details: Optional[legal_entity_update_params.WealthAndEmploymentDetails] | Omit = omit, website: Optional[str] | Omit = omit, # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. @@ -334,6 +354,8 @@ def update( legal_structure: The business's legal structure. + listed_exchange: ISO 10383 market identifier code. + metadata: Additional data represented as key-value pairs. Both the key and value must be strings. @@ -350,10 +372,16 @@ def update( primary_social_media_sites: A list of primary social media URLs for the business. + regulators: Array of regulatory bodies overseeing this institution. + risk_rating: The risk rating of the legal entity. One of low, medium, high. suffix: An individual's suffix. + third_party_verification: Information describing a third-party verification run by an external vendor. + + ticker_symbol: Stock ticker symbol for publicly traded companies. + website: The entity's primary website URL. extra_headers: Send extra headers @@ -390,6 +418,7 @@ def update( "intended_use": intended_use, "last_name": last_name, "legal_structure": legal_structure, + "listed_exchange": listed_exchange, "metadata": metadata, "middle_name": middle_name, "operating_jurisdictions": operating_jurisdictions, @@ -398,8 +427,11 @@ def update( "preferred_name": preferred_name, "prefix": prefix, "primary_social_media_sites": primary_social_media_sites, + "regulators": regulators, "risk_rating": risk_rating, "suffix": suffix, + "third_party_verification": third_party_verification, + "ticker_symbol": ticker_symbol, "wealth_and_employment_details": wealth_and_employment_details, "website": website, }, @@ -516,6 +548,7 @@ async def create( Literal["corporation", "llc", "non_profit", "partnership", "sole_proprietorship", "trust"] ] | Omit = omit, + listed_exchange: Optional[str] | Omit = omit, metadata: Dict[str, str] | Omit = omit, middle_name: Optional[str] | Omit = omit, operating_jurisdictions: SequenceNotStr[str] | Omit = omit, @@ -524,8 +557,11 @@ async def create( preferred_name: Optional[str] | Omit = omit, prefix: Optional[str] | Omit = omit, primary_social_media_sites: SequenceNotStr[str] | Omit = omit, + regulators: Optional[Iterable[legal_entity_create_params.Regulator]] | Omit = omit, risk_rating: Optional[Literal["low", "medium", "high"]] | Omit = omit, suffix: Optional[str] | Omit = omit, + third_party_verification: Optional[legal_entity_create_params.ThirdPartyVerification] | Omit = omit, + ticker_symbol: Optional[str] | Omit = omit, wealth_and_employment_details: Optional[legal_entity_create_params.WealthAndEmploymentDetails] | Omit = omit, website: Optional[str] | Omit = omit, # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. @@ -581,6 +617,8 @@ async def create( legal_structure: The business's legal structure. + listed_exchange: ISO 10383 market identifier code. + metadata: Additional data represented as key-value pairs. Both the key and value must be strings. @@ -597,10 +635,16 @@ async def create( primary_social_media_sites: A list of primary social media URLs for the business. + regulators: Array of regulatory bodies overseeing this institution. + risk_rating: The risk rating of the legal entity. One of low, medium, high. suffix: An individual's suffix. + third_party_verification: Information describing a third-party verification run by an external vendor. + + ticker_symbol: Stock ticker symbol for publicly traded companies. + website: The entity's primary website URL. extra_headers: Send extra headers @@ -638,6 +682,7 @@ async def create( "last_name": last_name, "legal_entity_associations": legal_entity_associations, "legal_structure": legal_structure, + "listed_exchange": listed_exchange, "metadata": metadata, "middle_name": middle_name, "operating_jurisdictions": operating_jurisdictions, @@ -646,8 +691,11 @@ async def create( "preferred_name": preferred_name, "prefix": prefix, "primary_social_media_sites": primary_social_media_sites, + "regulators": regulators, "risk_rating": risk_rating, "suffix": suffix, + "third_party_verification": third_party_verification, + "ticker_symbol": ticker_symbol, "wealth_and_employment_details": wealth_and_employment_details, "website": website, }, @@ -721,6 +769,7 @@ async def update( Literal["corporation", "llc", "non_profit", "partnership", "sole_proprietorship", "trust"] ] | Omit = omit, + listed_exchange: Optional[str] | Omit = omit, metadata: Dict[str, str] | Omit = omit, middle_name: Optional[str] | Omit = omit, operating_jurisdictions: SequenceNotStr[str] | Omit = omit, @@ -729,8 +778,11 @@ async def update( preferred_name: Optional[str] | Omit = omit, prefix: Optional[str] | Omit = omit, primary_social_media_sites: SequenceNotStr[str] | Omit = omit, + regulators: Optional[Iterable[legal_entity_update_params.Regulator]] | Omit = omit, risk_rating: Optional[Literal["low", "medium", "high"]] | Omit = omit, suffix: Optional[str] | Omit = omit, + third_party_verification: Optional[legal_entity_update_params.ThirdPartyVerification] | Omit = omit, + ticker_symbol: Optional[str] | Omit = omit, wealth_and_employment_details: Optional[legal_entity_update_params.WealthAndEmploymentDetails] | Omit = omit, website: Optional[str] | Omit = omit, # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. @@ -776,6 +828,8 @@ async def update( legal_structure: The business's legal structure. + listed_exchange: ISO 10383 market identifier code. + metadata: Additional data represented as key-value pairs. Both the key and value must be strings. @@ -792,10 +846,16 @@ async def update( primary_social_media_sites: A list of primary social media URLs for the business. + regulators: Array of regulatory bodies overseeing this institution. + risk_rating: The risk rating of the legal entity. One of low, medium, high. suffix: An individual's suffix. + third_party_verification: Information describing a third-party verification run by an external vendor. + + ticker_symbol: Stock ticker symbol for publicly traded companies. + website: The entity's primary website URL. extra_headers: Send extra headers @@ -832,6 +892,7 @@ async def update( "intended_use": intended_use, "last_name": last_name, "legal_structure": legal_structure, + "listed_exchange": listed_exchange, "metadata": metadata, "middle_name": middle_name, "operating_jurisdictions": operating_jurisdictions, @@ -840,8 +901,11 @@ async def update( "preferred_name": preferred_name, "prefix": prefix, "primary_social_media_sites": primary_social_media_sites, + "regulators": regulators, "risk_rating": risk_rating, "suffix": suffix, + "third_party_verification": third_party_verification, + "ticker_symbol": ticker_symbol, "wealth_and_employment_details": wealth_and_employment_details, "website": website, }, diff --git a/src/modern_treasury/types/child_legal_entity.py b/src/modern_treasury/types/child_legal_entity.py index a51599c0..0ff65980 100644 --- a/src/modern_treasury/types/child_legal_entity.py +++ b/src/modern_treasury/types/child_legal_entity.py @@ -20,6 +20,9 @@ "Identification", "PhoneNumbers", "PhoneNumber", + "Regulators", + "Regulator", + "ThirdPartyVerification", "WealthAndEmploymentDetails", ] @@ -188,6 +191,37 @@ class PhoneNumber(BaseModel): """ +class Regulator(BaseModel): + jurisdiction: str + """ + The country code where the regulator operates in the ISO 3166-1 alpha-2 format + (e.g., "US", "CA", "GB"). + """ + + name: str + """Full name of the regulatory body.""" + + registration_number: str + """Registration or identification number with the regulator.""" + + +Regulators = Regulator +"""This type is deprecated and will be removed in a future release. + +Please use Regulator instead. +""" + + +class ThirdPartyVerification(BaseModel): + """Information describing a third-party verification run by an external vendor.""" + + vendor: Literal["persona"] + """The vendor that performed the verification, e.g. `persona`.""" + + vendor_verification_id: str + """The identification of the third party verification in `vendor`'s system.""" + + class WealthAndEmploymentDetails(BaseModel): id: str @@ -408,6 +442,9 @@ class ChildLegalEntity(BaseModel): ] = None """The business's legal structure.""" + listed_exchange: Optional[str] = None + """ISO 10383 market identifier code.""" + live_mode: bool """ This field will be true if this object exists in the live environment or false @@ -445,12 +482,21 @@ class ChildLegalEntity(BaseModel): primary_social_media_sites: List[str] """A list of primary social media URLs for the business.""" + regulators: Optional[List[Regulator]] = None + """Array of regulatory bodies overseeing this institution.""" + risk_rating: Optional[Literal["low", "medium", "high"]] = None """The risk rating of the legal entity. One of low, medium, high.""" suffix: Optional[str] = None """An individual's suffix.""" + third_party_verification: Optional[ThirdPartyVerification] = None + """Information describing a third-party verification run by an external vendor.""" + + ticker_symbol: Optional[str] = None + """Stock ticker symbol for publicly traded companies.""" + updated_at: datetime wealth_and_employment_details: Optional[WealthAndEmploymentDetails] = None diff --git a/src/modern_treasury/types/connection_legal_entity_create_params.py b/src/modern_treasury/types/connection_legal_entity_create_params.py index 378b99e8..ba92a00d 100644 --- a/src/modern_treasury/types/connection_legal_entity_create_params.py +++ b/src/modern_treasury/types/connection_legal_entity_create_params.py @@ -19,6 +19,9 @@ "LegalEntityBankSettings", "LegalEntityPhoneNumbers", "LegalEntityPhoneNumber", + "LegalEntityRegulators", + "LegalEntityRegulator", + "LegalEntityThirdPartyVerification", "LegalEntityWealthAndEmploymentDetails", ] @@ -86,6 +89,37 @@ class LegalEntityPhoneNumber(TypedDict, total=False): """ +class LegalEntityRegulator(TypedDict, total=False): + jurisdiction: Required[str] + """ + The country code where the regulator operates in the ISO 3166-1 alpha-2 format + (e.g., "US", "CA", "GB"). + """ + + name: Required[str] + """Full name of the regulatory body.""" + + registration_number: Required[str] + """Registration or identification number with the regulator.""" + + +LegalEntityRegulators = LegalEntityRegulator +"""This type is deprecated and will be removed in a future release. + +Please use LegalEntityRegulator instead. +""" + + +class LegalEntityThirdPartyVerification(TypedDict, total=False): + """Information describing a third-party verification run by an external vendor.""" + + vendor: Required[Literal["persona"]] + """The vendor that performed the verification, e.g. `persona`.""" + + vendor_verification_id: Required[str] + """The identification of the third party verification in `vendor`'s system.""" + + class LegalEntityWealthAndEmploymentDetails(TypedDict, total=False): id: Required[str] @@ -319,6 +353,9 @@ class LegalEntity(TypedDict, total=False): ] """The business's legal structure.""" + listed_exchange: Optional[str] + """ISO 10383 market identifier code.""" + metadata: Dict[str, str] """Additional data represented as key-value pairs. @@ -348,12 +385,21 @@ class LegalEntity(TypedDict, total=False): primary_social_media_sites: SequenceNotStr[str] """A list of primary social media URLs for the business.""" + regulators: Optional[Iterable[LegalEntityRegulator]] + """Array of regulatory bodies overseeing this institution.""" + risk_rating: Optional[Literal["low", "medium", "high"]] """The risk rating of the legal entity. One of low, medium, high.""" suffix: Optional[str] """An individual's suffix.""" + third_party_verification: Optional[LegalEntityThirdPartyVerification] + """Information describing a third-party verification run by an external vendor.""" + + ticker_symbol: Optional[str] + """Stock ticker symbol for publicly traded companies.""" + wealth_and_employment_details: Optional[LegalEntityWealthAndEmploymentDetails] website: Optional[str] diff --git a/src/modern_treasury/types/counterparty_create_params.py b/src/modern_treasury/types/counterparty_create_params.py index d6fce210..bca2353f 100644 --- a/src/modern_treasury/types/counterparty_create_params.py +++ b/src/modern_treasury/types/counterparty_create_params.py @@ -30,6 +30,9 @@ "LegalEntityBankSettings", "LegalEntityPhoneNumbers", "LegalEntityPhoneNumber", + "LegalEntityRegulators", + "LegalEntityRegulator", + "LegalEntityThirdPartyVerification", "LegalEntityWealthAndEmploymentDetails", ] @@ -306,6 +309,37 @@ class LegalEntityPhoneNumber(TypedDict, total=False): """ +class LegalEntityRegulator(TypedDict, total=False): + jurisdiction: Required[str] + """ + The country code where the regulator operates in the ISO 3166-1 alpha-2 format + (e.g., "US", "CA", "GB"). + """ + + name: Required[str] + """Full name of the regulatory body.""" + + registration_number: Required[str] + """Registration or identification number with the regulator.""" + + +LegalEntityRegulators = LegalEntityRegulator +"""This type is deprecated and will be removed in a future release. + +Please use LegalEntityRegulator instead. +""" + + +class LegalEntityThirdPartyVerification(TypedDict, total=False): + """Information describing a third-party verification run by an external vendor.""" + + vendor: Required[Literal["persona"]] + """The vendor that performed the verification, e.g. `persona`.""" + + vendor_verification_id: Required[str] + """The identification of the third party verification in `vendor`'s system.""" + + class LegalEntityWealthAndEmploymentDetails(TypedDict, total=False): id: Required[str] @@ -537,6 +571,9 @@ class LegalEntity(TypedDict, total=False): ] """The business's legal structure.""" + listed_exchange: Optional[str] + """ISO 10383 market identifier code.""" + metadata: Dict[str, str] """Additional data represented as key-value pairs. @@ -566,12 +603,21 @@ class LegalEntity(TypedDict, total=False): primary_social_media_sites: SequenceNotStr[str] """A list of primary social media URLs for the business.""" + regulators: Optional[Iterable[LegalEntityRegulator]] + """Array of regulatory bodies overseeing this institution.""" + risk_rating: Optional[Literal["low", "medium", "high"]] """The risk rating of the legal entity. One of low, medium, high.""" suffix: Optional[str] """An individual's suffix.""" + third_party_verification: Optional[LegalEntityThirdPartyVerification] + """Information describing a third-party verification run by an external vendor.""" + + ticker_symbol: Optional[str] + """Stock ticker symbol for publicly traded companies.""" + wealth_and_employment_details: Optional[LegalEntityWealthAndEmploymentDetails] website: Optional[str] diff --git a/src/modern_treasury/types/legal_entity.py b/src/modern_treasury/types/legal_entity.py index 024754ff..21299226 100644 --- a/src/modern_treasury/types/legal_entity.py +++ b/src/modern_treasury/types/legal_entity.py @@ -20,6 +20,9 @@ "Identification", "PhoneNumbers", "PhoneNumber", + "Regulators", + "Regulator", + "ThirdPartyVerification", "WealthAndEmploymentDetails", ] @@ -188,6 +191,37 @@ class PhoneNumber(BaseModel): """ +class Regulator(BaseModel): + jurisdiction: str + """ + The country code where the regulator operates in the ISO 3166-1 alpha-2 format + (e.g., "US", "CA", "GB"). + """ + + name: str + """Full name of the regulatory body.""" + + registration_number: str + """Registration or identification number with the regulator.""" + + +Regulators = Regulator +"""This type is deprecated and will be removed in a future release. + +Please use Regulator instead. +""" + + +class ThirdPartyVerification(BaseModel): + """Information describing a third-party verification run by an external vendor.""" + + vendor: Literal["persona"] + """The vendor that performed the verification, e.g. `persona`.""" + + vendor_verification_id: str + """The identification of the third party verification in `vendor`'s system.""" + + class WealthAndEmploymentDetails(BaseModel): id: str @@ -405,6 +439,9 @@ class LegalEntity(BaseModel): ] = None """The business's legal structure.""" + listed_exchange: Optional[str] = None + """ISO 10383 market identifier code.""" + live_mode: bool """ This field will be true if this object exists in the live environment or false @@ -442,12 +479,21 @@ class LegalEntity(BaseModel): primary_social_media_sites: List[str] """A list of primary social media URLs for the business.""" + regulators: Optional[List[Regulator]] = None + """Array of regulatory bodies overseeing this institution.""" + risk_rating: Optional[Literal["low", "medium", "high"]] = None """The risk rating of the legal entity. One of low, medium, high.""" suffix: Optional[str] = None """An individual's suffix.""" + third_party_verification: Optional[ThirdPartyVerification] = None + """Information describing a third-party verification run by an external vendor.""" + + ticker_symbol: Optional[str] = None + """Stock ticker symbol for publicly traded companies.""" + updated_at: datetime wealth_and_employment_details: Optional[WealthAndEmploymentDetails] = None diff --git a/src/modern_treasury/types/legal_entity_create_params.py b/src/modern_treasury/types/legal_entity_create_params.py index 736d26de..83b49944 100644 --- a/src/modern_treasury/types/legal_entity_create_params.py +++ b/src/modern_treasury/types/legal_entity_create_params.py @@ -13,7 +13,16 @@ from .shared_params.legal_entity_address_create_request import LegalEntityAddressCreateRequest from .shared_params.legal_entity_industry_classification import LegalEntityIndustryClassification -__all__ = ["LegalEntityCreateParams", "BankSettings", "PhoneNumbers", "PhoneNumber", "WealthAndEmploymentDetails"] +__all__ = [ + "LegalEntityCreateParams", + "BankSettings", + "PhoneNumbers", + "PhoneNumber", + "Regulators", + "Regulator", + "ThirdPartyVerification", + "WealthAndEmploymentDetails", +] class LegalEntityCreateParams(TypedDict, total=False): @@ -88,6 +97,9 @@ class LegalEntityCreateParams(TypedDict, total=False): ] """The business's legal structure.""" + listed_exchange: Optional[str] + """ISO 10383 market identifier code.""" + metadata: Dict[str, str] """Additional data represented as key-value pairs. @@ -117,12 +129,21 @@ class LegalEntityCreateParams(TypedDict, total=False): primary_social_media_sites: SequenceNotStr[str] """A list of primary social media URLs for the business.""" + regulators: Optional[Iterable[Regulator]] + """Array of regulatory bodies overseeing this institution.""" + risk_rating: Optional[Literal["low", "medium", "high"]] """The risk rating of the legal entity. One of low, medium, high.""" suffix: Optional[str] """An individual's suffix.""" + third_party_verification: Optional[ThirdPartyVerification] + """Information describing a third-party verification run by an external vendor.""" + + ticker_symbol: Optional[str] + """Stock ticker symbol for publicly traded companies.""" + wealth_and_employment_details: Optional[WealthAndEmploymentDetails] website: Optional[str] @@ -181,6 +202,37 @@ class PhoneNumber(TypedDict, total=False): """ +class Regulator(TypedDict, total=False): + jurisdiction: Required[str] + """ + The country code where the regulator operates in the ISO 3166-1 alpha-2 format + (e.g., "US", "CA", "GB"). + """ + + name: Required[str] + """Full name of the regulatory body.""" + + registration_number: Required[str] + """Registration or identification number with the regulator.""" + + +Regulators = Regulator +"""This type is deprecated and will be removed in a future release. + +Please use Regulator instead. +""" + + +class ThirdPartyVerification(TypedDict, total=False): + """Information describing a third-party verification run by an external vendor.""" + + vendor: Required[Literal["persona"]] + """The vendor that performed the verification, e.g. `persona`.""" + + vendor_verification_id: Required[str] + """The identification of the third party verification in `vendor`'s system.""" + + class WealthAndEmploymentDetails(TypedDict, total=False): id: Required[str] diff --git a/src/modern_treasury/types/legal_entity_update_params.py b/src/modern_treasury/types/legal_entity_update_params.py index 30b08373..4d083675 100644 --- a/src/modern_treasury/types/legal_entity_update_params.py +++ b/src/modern_treasury/types/legal_entity_update_params.py @@ -13,7 +13,16 @@ from .shared_params.legal_entity_address_create_request import LegalEntityAddressCreateRequest from .shared_params.legal_entity_industry_classification import LegalEntityIndustryClassification -__all__ = ["LegalEntityUpdateParams", "BankSettings", "PhoneNumbers", "PhoneNumber", "WealthAndEmploymentDetails"] +__all__ = [ + "LegalEntityUpdateParams", + "BankSettings", + "PhoneNumbers", + "PhoneNumber", + "Regulators", + "Regulator", + "ThirdPartyVerification", + "WealthAndEmploymentDetails", +] class LegalEntityUpdateParams(TypedDict, total=False): @@ -73,6 +82,9 @@ class LegalEntityUpdateParams(TypedDict, total=False): ] """The business's legal structure.""" + listed_exchange: Optional[str] + """ISO 10383 market identifier code.""" + metadata: Dict[str, str] """Additional data represented as key-value pairs. @@ -102,12 +114,21 @@ class LegalEntityUpdateParams(TypedDict, total=False): primary_social_media_sites: SequenceNotStr[str] """A list of primary social media URLs for the business.""" + regulators: Optional[Iterable[Regulator]] + """Array of regulatory bodies overseeing this institution.""" + risk_rating: Optional[Literal["low", "medium", "high"]] """The risk rating of the legal entity. One of low, medium, high.""" suffix: Optional[str] """An individual's suffix.""" + third_party_verification: Optional[ThirdPartyVerification] + """Information describing a third-party verification run by an external vendor.""" + + ticker_symbol: Optional[str] + """Stock ticker symbol for publicly traded companies.""" + wealth_and_employment_details: Optional[WealthAndEmploymentDetails] website: Optional[str] @@ -166,6 +187,37 @@ class PhoneNumber(TypedDict, total=False): """ +class Regulator(TypedDict, total=False): + jurisdiction: Required[str] + """ + The country code where the regulator operates in the ISO 3166-1 alpha-2 format + (e.g., "US", "CA", "GB"). + """ + + name: Required[str] + """Full name of the regulatory body.""" + + registration_number: Required[str] + """Registration or identification number with the regulator.""" + + +Regulators = Regulator +"""This type is deprecated and will be removed in a future release. + +Please use Regulator instead. +""" + + +class ThirdPartyVerification(TypedDict, total=False): + """Information describing a third-party verification run by an external vendor.""" + + vendor: Required[Literal["persona"]] + """The vendor that performed the verification, e.g. `persona`.""" + + vendor_verification_id: Required[str] + """The identification of the third party verification in `vendor`'s system.""" + + class WealthAndEmploymentDetails(TypedDict, total=False): id: Required[str] diff --git a/src/modern_treasury/types/shared/child_legal_entity_create.py b/src/modern_treasury/types/shared/child_legal_entity_create.py index 2c450c6b..fc6a3b43 100644 --- a/src/modern_treasury/types/shared/child_legal_entity_create.py +++ b/src/modern_treasury/types/shared/child_legal_entity_create.py @@ -12,7 +12,16 @@ from .legal_entity_address_create_request import LegalEntityAddressCreateRequest from .legal_entity_industry_classification import LegalEntityIndustryClassification -__all__ = ["ChildLegalEntityCreate", "BankSettings", "PhoneNumbers", "PhoneNumber", "WealthAndEmploymentDetails"] +__all__ = [ + "ChildLegalEntityCreate", + "BankSettings", + "PhoneNumbers", + "PhoneNumber", + "Regulators", + "Regulator", + "ThirdPartyVerification", + "WealthAndEmploymentDetails", +] class BankSettings(BaseModel): @@ -67,6 +76,37 @@ class PhoneNumber(BaseModel): """ +class Regulator(BaseModel): + jurisdiction: str + """ + The country code where the regulator operates in the ISO 3166-1 alpha-2 format + (e.g., "US", "CA", "GB"). + """ + + name: str + """Full name of the regulatory body.""" + + registration_number: str + """Registration or identification number with the regulator.""" + + +Regulators = Regulator +"""This type is deprecated and will be removed in a future release. + +Please use Regulator instead. +""" + + +class ThirdPartyVerification(BaseModel): + """Information describing a third-party verification run by an external vendor.""" + + vendor: Literal["persona"] + """The vendor that performed the verification, e.g. `persona`.""" + + vendor_verification_id: str + """The identification of the third party verification in `vendor`'s system.""" + + class WealthAndEmploymentDetails(BaseModel): id: str @@ -288,6 +328,9 @@ class ChildLegalEntityCreate(BaseModel): ] = None """The business's legal structure.""" + listed_exchange: Optional[str] = None + """ISO 10383 market identifier code.""" + metadata: Optional[Dict[str, str]] = None """Additional data represented as key-value pairs. @@ -317,12 +360,21 @@ class ChildLegalEntityCreate(BaseModel): primary_social_media_sites: Optional[List[str]] = None """A list of primary social media URLs for the business.""" + regulators: Optional[List[Regulator]] = None + """Array of regulatory bodies overseeing this institution.""" + risk_rating: Optional[Literal["low", "medium", "high"]] = None """The risk rating of the legal entity. One of low, medium, high.""" suffix: Optional[str] = None """An individual's suffix.""" + third_party_verification: Optional[ThirdPartyVerification] = None + """Information describing a third-party verification run by an external vendor.""" + + ticker_symbol: Optional[str] = None + """Stock ticker symbol for publicly traded companies.""" + wealth_and_employment_details: Optional[WealthAndEmploymentDetails] = None website: Optional[str] = None diff --git a/src/modern_treasury/types/shared_params/child_legal_entity_create.py b/src/modern_treasury/types/shared_params/child_legal_entity_create.py index 34427d3e..e33e3a6c 100644 --- a/src/modern_treasury/types/shared_params/child_legal_entity_create.py +++ b/src/modern_treasury/types/shared_params/child_legal_entity_create.py @@ -13,7 +13,16 @@ from .legal_entity_address_create_request import LegalEntityAddressCreateRequest from .legal_entity_industry_classification import LegalEntityIndustryClassification -__all__ = ["ChildLegalEntityCreate", "BankSettings", "PhoneNumbers", "PhoneNumber", "WealthAndEmploymentDetails"] +__all__ = [ + "ChildLegalEntityCreate", + "BankSettings", + "PhoneNumbers", + "PhoneNumber", + "Regulators", + "Regulator", + "ThirdPartyVerification", + "WealthAndEmploymentDetails", +] class BankSettings(TypedDict, total=False): @@ -68,6 +77,37 @@ class PhoneNumber(TypedDict, total=False): """ +class Regulator(TypedDict, total=False): + jurisdiction: Required[str] + """ + The country code where the regulator operates in the ISO 3166-1 alpha-2 format + (e.g., "US", "CA", "GB"). + """ + + name: Required[str] + """Full name of the regulatory body.""" + + registration_number: Required[str] + """Registration or identification number with the regulator.""" + + +Regulators = Regulator +"""This type is deprecated and will be removed in a future release. + +Please use Regulator instead. +""" + + +class ThirdPartyVerification(TypedDict, total=False): + """Information describing a third-party verification run by an external vendor.""" + + vendor: Required[Literal["persona"]] + """The vendor that performed the verification, e.g. `persona`.""" + + vendor_verification_id: Required[str] + """The identification of the third party verification in `vendor`'s system.""" + + class WealthAndEmploymentDetails(TypedDict, total=False): id: Required[str] @@ -299,6 +339,9 @@ class ChildLegalEntityCreate(TypedDict, total=False): ] """The business's legal structure.""" + listed_exchange: Optional[str] + """ISO 10383 market identifier code.""" + metadata: Dict[str, str] """Additional data represented as key-value pairs. @@ -328,12 +371,21 @@ class ChildLegalEntityCreate(TypedDict, total=False): primary_social_media_sites: SequenceNotStr[str] """A list of primary social media URLs for the business.""" + regulators: Optional[Iterable[Regulator]] + """Array of regulatory bodies overseeing this institution.""" + risk_rating: Optional[Literal["low", "medium", "high"]] """The risk rating of the legal entity. One of low, medium, high.""" suffix: Optional[str] """An individual's suffix.""" + third_party_verification: Optional[ThirdPartyVerification] + """Information describing a third-party verification run by an external vendor.""" + + ticker_symbol: Optional[str] + """Stock ticker symbol for publicly traded companies.""" + wealth_and_employment_details: Optional[WealthAndEmploymentDetails] website: Optional[str] diff --git a/src/modern_treasury/types/transaction.py b/src/modern_treasury/types/transaction.py index fd035459..5ff00e14 100644 --- a/src/modern_treasury/types/transaction.py +++ b/src/modern_treasury/types/transaction.py @@ -152,7 +152,7 @@ class Transaction(BaseModel): "hifi", "iso20022", "jpmc", - "mt_flow", + "modern_treasury", "mx", "paxos", "paypal", diff --git a/tests/api_resources/test_connection_legal_entities.py b/tests/api_resources/test_connection_legal_entities.py index ce45108a..c4c2705a 100644 --- a/tests/api_resources/test_connection_legal_entities.py +++ b/tests/api_resources/test_connection_legal_entities.py @@ -182,6 +182,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "legal_entity_associations": [], "legal_entity_type": "business", "legal_structure": "corporation", + "listed_exchange": "listed_exchange", "metadata": { "key": "value", "foo": "bar", @@ -194,8 +195,20 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "preferred_name": "preferred_name", "prefix": "prefix", "primary_social_media_sites": ["string"], + "regulators": [ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], "risk_rating": "low", "suffix": "suffix", + "third_party_verification": { + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + "ticker_symbol": "ticker_symbol", "wealth_and_employment_details": { "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, @@ -225,6 +238,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: ], "legal_entity_type": "business", "legal_structure": "corporation", + "listed_exchange": "listed_exchange", "metadata": { "key": "value", "foo": "bar", @@ -237,8 +251,20 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "preferred_name": "preferred_name", "prefix": "prefix", "primary_social_media_sites": ["string"], + "regulators": [ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], "risk_rating": "low", "suffix": "suffix", + "third_party_verification": { + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + "ticker_symbol": "ticker_symbol", "wealth_and_employment_details": { "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, @@ -576,6 +602,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "legal_entity_associations": [], "legal_entity_type": "business", "legal_structure": "corporation", + "listed_exchange": "listed_exchange", "metadata": { "key": "value", "foo": "bar", @@ -588,8 +615,20 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "preferred_name": "preferred_name", "prefix": "prefix", "primary_social_media_sites": ["string"], + "regulators": [ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], "risk_rating": "low", "suffix": "suffix", + "third_party_verification": { + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + "ticker_symbol": "ticker_symbol", "wealth_and_employment_details": { "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, @@ -619,6 +658,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea ], "legal_entity_type": "business", "legal_structure": "corporation", + "listed_exchange": "listed_exchange", "metadata": { "key": "value", "foo": "bar", @@ -631,8 +671,20 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "preferred_name": "preferred_name", "prefix": "prefix", "primary_social_media_sites": ["string"], + "regulators": [ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], "risk_rating": "low", "suffix": "suffix", + "third_party_verification": { + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + "ticker_symbol": "ticker_symbol", "wealth_and_employment_details": { "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, diff --git a/tests/api_resources/test_counterparties.py b/tests/api_resources/test_counterparties.py index e03b7d81..63e7fb01 100644 --- a/tests/api_resources/test_counterparties.py +++ b/tests/api_resources/test_counterparties.py @@ -247,6 +247,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "legal_entity_associations": [], "legal_entity_type": "business", "legal_structure": "corporation", + "listed_exchange": "listed_exchange", "metadata": { "key": "value", "foo": "bar", @@ -259,8 +260,20 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "preferred_name": "preferred_name", "prefix": "prefix", "primary_social_media_sites": ["string"], + "regulators": [ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], "risk_rating": "low", "suffix": "suffix", + "third_party_verification": { + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + "ticker_symbol": "ticker_symbol", "wealth_and_employment_details": { "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, @@ -289,6 +302,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: } ], "legal_structure": "corporation", + "listed_exchange": "listed_exchange", "metadata": { "key": "value", "foo": "bar", @@ -301,8 +315,20 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "preferred_name": "preferred_name", "prefix": "prefix", "primary_social_media_sites": ["string"], + "regulators": [ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], "risk_rating": "low", "suffix": "suffix", + "third_party_verification": { + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + "ticker_symbol": "ticker_symbol", "wealth_and_employment_details": { "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, @@ -812,6 +838,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "legal_entity_associations": [], "legal_entity_type": "business", "legal_structure": "corporation", + "listed_exchange": "listed_exchange", "metadata": { "key": "value", "foo": "bar", @@ -824,8 +851,20 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "preferred_name": "preferred_name", "prefix": "prefix", "primary_social_media_sites": ["string"], + "regulators": [ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], "risk_rating": "low", "suffix": "suffix", + "third_party_verification": { + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + "ticker_symbol": "ticker_symbol", "wealth_and_employment_details": { "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, @@ -854,6 +893,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea } ], "legal_structure": "corporation", + "listed_exchange": "listed_exchange", "metadata": { "key": "value", "foo": "bar", @@ -866,8 +906,20 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "preferred_name": "preferred_name", "prefix": "prefix", "primary_social_media_sites": ["string"], + "regulators": [ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], "risk_rating": "low", "suffix": "suffix", + "third_party_verification": { + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + "ticker_symbol": "ticker_symbol", "wealth_and_employment_details": { "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, diff --git a/tests/api_resources/test_legal_entities.py b/tests/api_resources/test_legal_entities.py index a5245798..fc22b522 100644 --- a/tests/api_resources/test_legal_entities.py +++ b/tests/api_resources/test_legal_entities.py @@ -182,6 +182,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "legal_entity_associations": [], "legal_entity_type": "business", "legal_structure": "corporation", + "listed_exchange": "listed_exchange", "metadata": { "key": "value", "foo": "bar", @@ -194,8 +195,20 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "preferred_name": "preferred_name", "prefix": "prefix", "primary_social_media_sites": ["string"], + "regulators": [ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], "risk_rating": "low", "suffix": "suffix", + "third_party_verification": { + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + "ticker_symbol": "ticker_symbol", "wealth_and_employment_details": { "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, @@ -224,6 +237,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: } ], legal_structure="corporation", + listed_exchange="listed_exchange", metadata={ "key": "value", "foo": "bar", @@ -236,8 +250,20 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: preferred_name="preferred_name", prefix="prefix", primary_social_media_sites=["string"], + regulators=[ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], risk_rating="low", suffix="suffix", + third_party_verification={ + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + ticker_symbol="ticker_symbol", wealth_and_employment_details={ "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, @@ -406,6 +432,7 @@ def test_method_update_with_all_params(self, client: ModernTreasury) -> None: intended_use="intended_use", last_name="last_name", legal_structure="corporation", + listed_exchange="listed_exchange", metadata={ "key": "value", "foo": "bar", @@ -418,8 +445,20 @@ def test_method_update_with_all_params(self, client: ModernTreasury) -> None: preferred_name="preferred_name", prefix="prefix", primary_social_media_sites=["string"], + regulators=[ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], risk_rating="low", suffix="suffix", + third_party_verification={ + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + ticker_symbol="ticker_symbol", wealth_and_employment_details={ "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, @@ -679,6 +718,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "legal_entity_associations": [], "legal_entity_type": "business", "legal_structure": "corporation", + "listed_exchange": "listed_exchange", "metadata": { "key": "value", "foo": "bar", @@ -691,8 +731,20 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "preferred_name": "preferred_name", "prefix": "prefix", "primary_social_media_sites": ["string"], + "regulators": [ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], "risk_rating": "low", "suffix": "suffix", + "third_party_verification": { + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + "ticker_symbol": "ticker_symbol", "wealth_and_employment_details": { "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, @@ -721,6 +773,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea } ], legal_structure="corporation", + listed_exchange="listed_exchange", metadata={ "key": "value", "foo": "bar", @@ -733,8 +786,20 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea preferred_name="preferred_name", prefix="prefix", primary_social_media_sites=["string"], + regulators=[ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], risk_rating="low", suffix="suffix", + third_party_verification={ + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + ticker_symbol="ticker_symbol", wealth_and_employment_details={ "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, @@ -910,6 +975,7 @@ async def test_method_update_with_all_params(self, async_client: AsyncModernTrea intended_use="intended_use", last_name="last_name", legal_structure="corporation", + listed_exchange="listed_exchange", metadata={ "key": "value", "foo": "bar", @@ -922,8 +988,20 @@ async def test_method_update_with_all_params(self, async_client: AsyncModernTrea preferred_name="preferred_name", prefix="prefix", primary_social_media_sites=["string"], + regulators=[ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], risk_rating="low", suffix="suffix", + third_party_verification={ + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + ticker_symbol="ticker_symbol", wealth_and_employment_details={ "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, diff --git a/tests/api_resources/test_legal_entity_associations.py b/tests/api_resources/test_legal_entity_associations.py index 618b2562..27768f9b 100644 --- a/tests/api_resources/test_legal_entity_associations.py +++ b/tests/api_resources/test_legal_entity_associations.py @@ -114,6 +114,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: ], "legal_entity_type": "business", "legal_structure": "corporation", + "listed_exchange": "listed_exchange", "metadata": { "key": "value", "foo": "bar", @@ -126,8 +127,20 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "preferred_name": "preferred_name", "prefix": "prefix", "primary_social_media_sites": ["string"], + "regulators": [ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], "risk_rating": "low", "suffix": "suffix", + "third_party_verification": { + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + "ticker_symbol": "ticker_symbol", "wealth_and_employment_details": { "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, @@ -285,6 +298,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea ], "legal_entity_type": "business", "legal_structure": "corporation", + "listed_exchange": "listed_exchange", "metadata": { "key": "value", "foo": "bar", @@ -297,8 +311,20 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "preferred_name": "preferred_name", "prefix": "prefix", "primary_social_media_sites": ["string"], + "regulators": [ + { + "jurisdiction": "jurisdiction", + "name": "name", + "registration_number": "registration_number", + } + ], "risk_rating": "low", "suffix": "suffix", + "third_party_verification": { + "vendor": "persona", + "vendor_verification_id": "vendor_verification_id", + }, + "ticker_symbol": "ticker_symbol", "wealth_and_employment_details": { "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "annual_income": 0, From 81262fe918cf0613b744fc25e49be04e34d578cc Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Wed, 28 Jan 2026 16:36:31 +0000 Subject: [PATCH 05/17] fix(docs): fix mcp installation instructions for remote servers --- README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 1be579cb..20556e27 100644 --- a/README.md +++ b/README.md @@ -13,8 +13,8 @@ https://user-images.githubusercontent.com/704302/216504942-09ed8dd7-7f44-40a6-a5 Use the Modern Treasury MCP Server to enable AI assistants to interact with this API, allowing them to explore endpoints, make test requests, and use documentation to help integrate this SDK into your application. -[![Add to Cursor](https://cursor.com/deeplink/mcp-install-dark.svg)](https://cursor.com/en-US/install-mcp?name=modern-treasury-mcp&config=eyJjb21tYW5kIjoibnB4IiwiYXJncyI6WyIteSIsIm1vZGVybi10cmVhc3VyeS1tY3AiXX0) -[![Install in VS Code](https://img.shields.io/badge/_-Add_to_VS_Code-blue?style=for-the-badge&logo=)](https://vscode.stainless.com/mcp/%7B%22name%22%3A%22modern-treasury-mcp%22%2C%22command%22%3A%22npx%22%2C%22args%22%3A%5B%22-y%22%2C%22modern-treasury-mcp%22%5D%7D) +[![Add to Cursor](https://cursor.com/deeplink/mcp-install-dark.svg)](https://cursor.com/en-US/install-mcp?name=modern-treasury-mcp&config=eyJjb21tYW5kIjoibnB4IiwiYXJncyI6WyIteSIsIm1vZGVybi10cmVhc3VyeS1tY3AiXSwiZW52Ijp7Ik1PREVSTl9UUkVBU1VSWV9BUElfS0VZIjoiTXkgQVBJIEtleSIsIk1PREVSTl9UUkVBU1VSWV9PUkdBTklaQVRJT05fSUQiOiJteS1vcmdhbml6YXRpb24tSUQiLCJNT0RFUk5fVFJFQVNVUllfV0VCSE9PS19LRVkiOiJNeSBXZWJob29rIEtleSJ9fQ) +[![Install in VS Code](https://img.shields.io/badge/_-Add_to_VS_Code-blue?style=for-the-badge&logo=)](https://vscode.stainless.com/mcp/%7B%22name%22%3A%22modern-treasury-mcp%22%2C%22command%22%3A%22npx%22%2C%22args%22%3A%5B%22-y%22%2C%22modern-treasury-mcp%22%5D%2C%22env%22%3A%7B%22MODERN_TREASURY_API_KEY%22%3A%22My%20API%20Key%22%2C%22MODERN_TREASURY_ORGANIZATION_ID%22%3A%22my-organization-ID%22%2C%22MODERN_TREASURY_WEBHOOK_KEY%22%3A%22My%20Webhook%20Key%22%7D%7D) > Note: You may need to set environment variables in your MCP client. From 8e9e7dd9ff628d218581f0ad3b3ab0d4521af898 Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Thu, 29 Jan 2026 16:57:18 +0000 Subject: [PATCH 06/17] feat(client): add custom JSON encoder for extended type support --- src/modern_treasury/_base_client.py | 7 +- src/modern_treasury/_compat.py | 6 +- src/modern_treasury/_utils/_json.py | 35 ++++++++ tests/test_utils/test_json.py | 126 ++++++++++++++++++++++++++++ 4 files changed, 169 insertions(+), 5 deletions(-) create mode 100644 src/modern_treasury/_utils/_json.py create mode 100644 tests/test_utils/test_json.py diff --git a/src/modern_treasury/_base_client.py b/src/modern_treasury/_base_client.py index 1efbd879..2e6cff22 100644 --- a/src/modern_treasury/_base_client.py +++ b/src/modern_treasury/_base_client.py @@ -86,6 +86,7 @@ APIConnectionError, APIResponseValidationError, ) +from ._utils._json import openapi_dumps from ._legacy_response import LegacyAPIResponse log: logging.Logger = logging.getLogger(__name__) @@ -556,8 +557,10 @@ def _build_request( kwargs["content"] = options.content elif isinstance(json_data, bytes): kwargs["content"] = json_data - else: - kwargs["json"] = json_data if is_given(json_data) else None + elif not files: + # Don't set content when JSON is sent as multipart/form-data, + # since httpx's content param overrides other body arguments + kwargs["content"] = openapi_dumps(json_data) if is_given(json_data) and json_data is not None else None kwargs["files"] = files else: headers.pop("Content-Type", None) diff --git a/src/modern_treasury/_compat.py b/src/modern_treasury/_compat.py index bdef67f0..786ff42a 100644 --- a/src/modern_treasury/_compat.py +++ b/src/modern_treasury/_compat.py @@ -139,6 +139,7 @@ def model_dump( exclude_defaults: bool = False, warnings: bool = True, mode: Literal["json", "python"] = "python", + by_alias: bool | None = None, ) -> dict[str, Any]: if (not PYDANTIC_V1) or hasattr(model, "model_dump"): return model.model_dump( @@ -148,13 +149,12 @@ def model_dump( exclude_defaults=exclude_defaults, # warnings are not supported in Pydantic v1 warnings=True if PYDANTIC_V1 else warnings, + by_alias=by_alias, ) return cast( "dict[str, Any]", model.dict( # pyright: ignore[reportDeprecated, reportUnnecessaryCast] - exclude=exclude, - exclude_unset=exclude_unset, - exclude_defaults=exclude_defaults, + exclude=exclude, exclude_unset=exclude_unset, exclude_defaults=exclude_defaults, by_alias=bool(by_alias) ), ) diff --git a/src/modern_treasury/_utils/_json.py b/src/modern_treasury/_utils/_json.py new file mode 100644 index 00000000..60584214 --- /dev/null +++ b/src/modern_treasury/_utils/_json.py @@ -0,0 +1,35 @@ +import json +from typing import Any +from datetime import datetime +from typing_extensions import override + +import pydantic + +from .._compat import model_dump + + +def openapi_dumps(obj: Any) -> bytes: + """ + Serialize an object to UTF-8 encoded JSON bytes. + + Extends the standard json.dumps with support for additional types + commonly used in the SDK, such as `datetime`, `pydantic.BaseModel`, etc. + """ + return json.dumps( + obj, + cls=_CustomEncoder, + # Uses the same defaults as httpx's JSON serialization + ensure_ascii=False, + separators=(",", ":"), + allow_nan=False, + ).encode() + + +class _CustomEncoder(json.JSONEncoder): + @override + def default(self, o: Any) -> Any: + if isinstance(o, datetime): + return o.isoformat() + if isinstance(o, pydantic.BaseModel): + return model_dump(o, exclude_unset=True, mode="json", by_alias=True) + return super().default(o) diff --git a/tests/test_utils/test_json.py b/tests/test_utils/test_json.py new file mode 100644 index 00000000..cd6da3df --- /dev/null +++ b/tests/test_utils/test_json.py @@ -0,0 +1,126 @@ +from __future__ import annotations + +import datetime +from typing import Union + +import pydantic + +from modern_treasury import _compat +from modern_treasury._utils._json import openapi_dumps + + +class TestOpenapiDumps: + def test_basic(self) -> None: + data = {"key": "value", "number": 42} + json_bytes = openapi_dumps(data) + assert json_bytes == b'{"key":"value","number":42}' + + def test_datetime_serialization(self) -> None: + dt = datetime.datetime(2023, 1, 1, 12, 0, 0) + data = {"datetime": dt} + json_bytes = openapi_dumps(data) + assert json_bytes == b'{"datetime":"2023-01-01T12:00:00"}' + + def test_pydantic_model_serialization(self) -> None: + class User(pydantic.BaseModel): + first_name: str + last_name: str + age: int + + model_instance = User(first_name="John", last_name="Kramer", age=83) + data = {"model": model_instance} + json_bytes = openapi_dumps(data) + assert json_bytes == b'{"model":{"first_name":"John","last_name":"Kramer","age":83}}' + + def test_pydantic_model_with_default_values(self) -> None: + class User(pydantic.BaseModel): + name: str + role: str = "user" + active: bool = True + score: int = 0 + + model_instance = User(name="Alice") + data = {"model": model_instance} + json_bytes = openapi_dumps(data) + assert json_bytes == b'{"model":{"name":"Alice"}}' + + def test_pydantic_model_with_default_values_overridden(self) -> None: + class User(pydantic.BaseModel): + name: str + role: str = "user" + active: bool = True + + model_instance = User(name="Bob", role="admin", active=False) + data = {"model": model_instance} + json_bytes = openapi_dumps(data) + assert json_bytes == b'{"model":{"name":"Bob","role":"admin","active":false}}' + + def test_pydantic_model_with_alias(self) -> None: + class User(pydantic.BaseModel): + first_name: str = pydantic.Field(alias="firstName") + last_name: str = pydantic.Field(alias="lastName") + + model_instance = User(firstName="John", lastName="Doe") + data = {"model": model_instance} + json_bytes = openapi_dumps(data) + assert json_bytes == b'{"model":{"firstName":"John","lastName":"Doe"}}' + + def test_pydantic_model_with_alias_and_default(self) -> None: + class User(pydantic.BaseModel): + user_name: str = pydantic.Field(alias="userName") + user_role: str = pydantic.Field(default="member", alias="userRole") + is_active: bool = pydantic.Field(default=True, alias="isActive") + + model_instance = User(userName="charlie") + data = {"model": model_instance} + json_bytes = openapi_dumps(data) + assert json_bytes == b'{"model":{"userName":"charlie"}}' + + model_with_overrides = User(userName="diana", userRole="admin", isActive=False) + data = {"model": model_with_overrides} + json_bytes = openapi_dumps(data) + assert json_bytes == b'{"model":{"userName":"diana","userRole":"admin","isActive":false}}' + + def test_pydantic_model_with_nested_models_and_defaults(self) -> None: + class Address(pydantic.BaseModel): + street: str + city: str = "Unknown" + + class User(pydantic.BaseModel): + name: str + address: Address + verified: bool = False + + if _compat.PYDANTIC_V1: + # to handle forward references in Pydantic v1 + User.update_forward_refs(**locals()) # type: ignore[reportDeprecated] + + address = Address(street="123 Main St") + user = User(name="Diana", address=address) + data = {"user": user} + json_bytes = openapi_dumps(data) + assert json_bytes == b'{"user":{"name":"Diana","address":{"street":"123 Main St"}}}' + + address_with_city = Address(street="456 Oak Ave", city="Boston") + user_verified = User(name="Eve", address=address_with_city, verified=True) + data = {"user": user_verified} + json_bytes = openapi_dumps(data) + assert ( + json_bytes == b'{"user":{"name":"Eve","address":{"street":"456 Oak Ave","city":"Boston"},"verified":true}}' + ) + + def test_pydantic_model_with_optional_fields(self) -> None: + class User(pydantic.BaseModel): + name: str + email: Union[str, None] + phone: Union[str, None] + + model_with_none = User(name="Eve", email=None, phone=None) + data = {"model": model_with_none} + json_bytes = openapi_dumps(data) + assert json_bytes == b'{"model":{"name":"Eve","email":null,"phone":null}}' + + model_with_values = User(name="Frank", email="frank@example.com", phone=None) + data = {"model": model_with_values} + json_bytes = openapi_dumps(data) + assert json_bytes == b'{"model":{"name":"Frank","email":"frank@example.com","phone":null}}' From 80ff1b53fec639b70236541e6f5b9a8e548e5846 Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Tue, 3 Feb 2026 23:23:31 +0000 Subject: [PATCH 07/17] feat(api): api update --- .stats.yml | 4 ++-- .../types/incoming_payment_detail.py | 15 +++++++++++++++ 2 files changed, 17 insertions(+), 2 deletions(-) diff --git a/.stats.yml b/.stats.yml index d70d0999..b20de802 100644 --- a/.stats.yml +++ b/.stats.yml @@ -1,4 +1,4 @@ configured_endpoints: 168 -openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-d8140aaa2f4b9b2fd803a2135c87078d7081b3fdac301913eb1263d0a4ee794d.yml -openapi_spec_hash: b5ff512582cc4da8d4cd625ef651bc84 +openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-3704615933ba38dcde41513f88b894dc101467d2d4baee175a0e4a58774f1343.yml +openapi_spec_hash: e96f06509912fb5fe6dc11a4209e89e6 config_hash: 196d1bf0caae233683efb6abc123941f diff --git a/src/modern_treasury/types/incoming_payment_detail.py b/src/modern_treasury/types/incoming_payment_detail.py index c41b6297..b3a307e5 100644 --- a/src/modern_treasury/types/incoming_payment_detail.py +++ b/src/modern_treasury/types/incoming_payment_detail.py @@ -5,6 +5,7 @@ from typing_extensions import Literal from .._models import BaseModel +from .shared.address import Address from .shared.currency import Currency from .virtual_account import VirtualAccount from .shared.transaction_direction import TransactionDirection @@ -178,3 +179,17 @@ class IncomingPaymentDetail(BaseModel): originating_account_number: Optional[str] = None """The account number of the originating account for the incoming payment detail.""" + + originating_party_address: Optional[Address] = None + """ + The address of the originating party for the incoming payment detail, or `null`. + """ + + originating_party_name: Optional[str] = None + """The name of the originating party for the incoming payment detail.""" + + originating_party_vendor_identifier: Optional[str] = None + """ + The vendor-assigned identifier for the originating party of the incoming payment + detail, or `null`. + """ From c92a9ce0dd768e53518a263241cdef81f1648a56 Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Wed, 4 Feb 2026 20:23:31 +0000 Subject: [PATCH 08/17] feat(api): api update --- .stats.yml | 4 ++-- .../resources/legal_entities.py | 24 +++++++++++++++++++ .../types/child_legal_entity.py | 6 +++++ .../connection_legal_entity_create_params.py | 6 +++++ .../types/counterparty_create_params.py | 6 +++++ src/modern_treasury/types/legal_entity.py | 6 +++++ .../types/legal_entity_create_params.py | 6 +++++ .../types/legal_entity_list_params.py | 2 ++ .../types/legal_entity_update_params.py | 6 +++++ .../types/shared/child_legal_entity_create.py | 6 +++++ .../child_legal_entity_create.py | 6 +++++ .../test_connection_legal_entities.py | 4 ++++ tests/api_resources/test_counterparties.py | 4 ++++ tests/api_resources/test_legal_entities.py | 8 +++++++ .../test_legal_entity_associations.py | 2 ++ 15 files changed, 94 insertions(+), 2 deletions(-) diff --git a/.stats.yml b/.stats.yml index b20de802..720060d9 100644 --- a/.stats.yml +++ b/.stats.yml @@ -1,4 +1,4 @@ configured_endpoints: 168 -openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-3704615933ba38dcde41513f88b894dc101467d2d4baee175a0e4a58774f1343.yml -openapi_spec_hash: e96f06509912fb5fe6dc11a4209e89e6 +openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-2447552f3c4fb0bca7b73774333098a01857ded98c0bd581d02385ee1ef29996.yml +openapi_spec_hash: eae03289efeec45844cd66747f5c782e config_hash: 196d1bf0caae233683efb6abc123941f diff --git a/src/modern_treasury/resources/legal_entities.py b/src/modern_treasury/resources/legal_entities.py index 209a604b..d527f085 100644 --- a/src/modern_treasury/resources/legal_entities.py +++ b/src/modern_treasury/resources/legal_entities.py @@ -85,6 +85,7 @@ def create( primary_social_media_sites: SequenceNotStr[str] | Omit = omit, regulators: Optional[Iterable[legal_entity_create_params.Regulator]] | Omit = omit, risk_rating: Optional[Literal["low", "medium", "high"]] | Omit = omit, + status: Optional[Literal["active", "closed", "pending", "suspended"]] | Omit = omit, suffix: Optional[str] | Omit = omit, third_party_verification: Optional[legal_entity_create_params.ThirdPartyVerification] | Omit = omit, ticker_symbol: Optional[str] | Omit = omit, @@ -165,6 +166,9 @@ def create( risk_rating: The risk rating of the legal entity. One of low, medium, high. + status: The activation status of the legal entity. One of pending, active, suspended, or + closed. + suffix: An individual's suffix. third_party_verification: Information describing a third-party verification run by an external vendor. @@ -219,6 +223,7 @@ def create( "primary_social_media_sites": primary_social_media_sites, "regulators": regulators, "risk_rating": risk_rating, + "status": status, "suffix": suffix, "third_party_verification": third_party_verification, "ticker_symbol": ticker_symbol, @@ -306,6 +311,7 @@ def update( primary_social_media_sites: SequenceNotStr[str] | Omit = omit, regulators: Optional[Iterable[legal_entity_update_params.Regulator]] | Omit = omit, risk_rating: Optional[Literal["low", "medium", "high"]] | Omit = omit, + status: Optional[Literal["active", "closed", "pending", "suspended"]] | Omit = omit, suffix: Optional[str] | Omit = omit, third_party_verification: Optional[legal_entity_update_params.ThirdPartyVerification] | Omit = omit, ticker_symbol: Optional[str] | Omit = omit, @@ -376,6 +382,9 @@ def update( risk_rating: The risk rating of the legal entity. One of low, medium, high. + status: The activation status of the legal entity. One of pending, active, suspended, or + closed. + suffix: An individual's suffix. third_party_verification: Information describing a third-party verification run by an external vendor. @@ -429,6 +438,7 @@ def update( "primary_social_media_sites": primary_social_media_sites, "regulators": regulators, "risk_rating": risk_rating, + "status": status, "suffix": suffix, "third_party_verification": third_party_verification, "ticker_symbol": ticker_symbol, @@ -455,6 +465,7 @@ def list( metadata: Dict[str, str] | Omit = omit, per_page: int | Omit = omit, show_deleted: str | Omit = omit, + status: Literal["pending", "active", "suspended", "closed"] | Omit = omit, # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. # The extra values given here take precedence over values defined on the client or passed to this method. extra_headers: Headers | None = None, @@ -493,6 +504,7 @@ def list( "metadata": metadata, "per_page": per_page, "show_deleted": show_deleted, + "status": status, }, legal_entity_list_params.LegalEntityListParams, ), @@ -559,6 +571,7 @@ async def create( primary_social_media_sites: SequenceNotStr[str] | Omit = omit, regulators: Optional[Iterable[legal_entity_create_params.Regulator]] | Omit = omit, risk_rating: Optional[Literal["low", "medium", "high"]] | Omit = omit, + status: Optional[Literal["active", "closed", "pending", "suspended"]] | Omit = omit, suffix: Optional[str] | Omit = omit, third_party_verification: Optional[legal_entity_create_params.ThirdPartyVerification] | Omit = omit, ticker_symbol: Optional[str] | Omit = omit, @@ -639,6 +652,9 @@ async def create( risk_rating: The risk rating of the legal entity. One of low, medium, high. + status: The activation status of the legal entity. One of pending, active, suspended, or + closed. + suffix: An individual's suffix. third_party_verification: Information describing a third-party verification run by an external vendor. @@ -693,6 +709,7 @@ async def create( "primary_social_media_sites": primary_social_media_sites, "regulators": regulators, "risk_rating": risk_rating, + "status": status, "suffix": suffix, "third_party_verification": third_party_verification, "ticker_symbol": ticker_symbol, @@ -780,6 +797,7 @@ async def update( primary_social_media_sites: SequenceNotStr[str] | Omit = omit, regulators: Optional[Iterable[legal_entity_update_params.Regulator]] | Omit = omit, risk_rating: Optional[Literal["low", "medium", "high"]] | Omit = omit, + status: Optional[Literal["active", "closed", "pending", "suspended"]] | Omit = omit, suffix: Optional[str] | Omit = omit, third_party_verification: Optional[legal_entity_update_params.ThirdPartyVerification] | Omit = omit, ticker_symbol: Optional[str] | Omit = omit, @@ -850,6 +868,9 @@ async def update( risk_rating: The risk rating of the legal entity. One of low, medium, high. + status: The activation status of the legal entity. One of pending, active, suspended, or + closed. + suffix: An individual's suffix. third_party_verification: Information describing a third-party verification run by an external vendor. @@ -903,6 +924,7 @@ async def update( "primary_social_media_sites": primary_social_media_sites, "regulators": regulators, "risk_rating": risk_rating, + "status": status, "suffix": suffix, "third_party_verification": third_party_verification, "ticker_symbol": ticker_symbol, @@ -929,6 +951,7 @@ def list( metadata: Dict[str, str] | Omit = omit, per_page: int | Omit = omit, show_deleted: str | Omit = omit, + status: Literal["pending", "active", "suspended", "closed"] | Omit = omit, # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. # The extra values given here take precedence over values defined on the client or passed to this method. extra_headers: Headers | None = None, @@ -967,6 +990,7 @@ def list( "metadata": metadata, "per_page": per_page, "show_deleted": show_deleted, + "status": status, }, legal_entity_list_params.LegalEntityListParams, ), diff --git a/src/modern_treasury/types/child_legal_entity.py b/src/modern_treasury/types/child_legal_entity.py index 0ff65980..563903b2 100644 --- a/src/modern_treasury/types/child_legal_entity.py +++ b/src/modern_treasury/types/child_legal_entity.py @@ -488,6 +488,12 @@ class ChildLegalEntity(BaseModel): risk_rating: Optional[Literal["low", "medium", "high"]] = None """The risk rating of the legal entity. One of low, medium, high.""" + status: Optional[Literal["active", "closed", "pending", "suspended"]] = None + """The activation status of the legal entity. + + One of pending, active, suspended, or closed. + """ + suffix: Optional[str] = None """An individual's suffix.""" diff --git a/src/modern_treasury/types/connection_legal_entity_create_params.py b/src/modern_treasury/types/connection_legal_entity_create_params.py index ba92a00d..f4826964 100644 --- a/src/modern_treasury/types/connection_legal_entity_create_params.py +++ b/src/modern_treasury/types/connection_legal_entity_create_params.py @@ -391,6 +391,12 @@ class LegalEntity(TypedDict, total=False): risk_rating: Optional[Literal["low", "medium", "high"]] """The risk rating of the legal entity. One of low, medium, high.""" + status: Optional[Literal["active", "closed", "pending", "suspended"]] + """The activation status of the legal entity. + + One of pending, active, suspended, or closed. + """ + suffix: Optional[str] """An individual's suffix.""" diff --git a/src/modern_treasury/types/counterparty_create_params.py b/src/modern_treasury/types/counterparty_create_params.py index bca2353f..008a13f1 100644 --- a/src/modern_treasury/types/counterparty_create_params.py +++ b/src/modern_treasury/types/counterparty_create_params.py @@ -609,6 +609,12 @@ class LegalEntity(TypedDict, total=False): risk_rating: Optional[Literal["low", "medium", "high"]] """The risk rating of the legal entity. One of low, medium, high.""" + status: Optional[Literal["active", "closed", "pending", "suspended"]] + """The activation status of the legal entity. + + One of pending, active, suspended, or closed. + """ + suffix: Optional[str] """An individual's suffix.""" diff --git a/src/modern_treasury/types/legal_entity.py b/src/modern_treasury/types/legal_entity.py index 21299226..2509356e 100644 --- a/src/modern_treasury/types/legal_entity.py +++ b/src/modern_treasury/types/legal_entity.py @@ -485,6 +485,12 @@ class LegalEntity(BaseModel): risk_rating: Optional[Literal["low", "medium", "high"]] = None """The risk rating of the legal entity. One of low, medium, high.""" + status: Optional[Literal["active", "closed", "pending", "suspended"]] = None + """The activation status of the legal entity. + + One of pending, active, suspended, or closed. + """ + suffix: Optional[str] = None """An individual's suffix.""" diff --git a/src/modern_treasury/types/legal_entity_create_params.py b/src/modern_treasury/types/legal_entity_create_params.py index 83b49944..cba8ee5d 100644 --- a/src/modern_treasury/types/legal_entity_create_params.py +++ b/src/modern_treasury/types/legal_entity_create_params.py @@ -135,6 +135,12 @@ class LegalEntityCreateParams(TypedDict, total=False): risk_rating: Optional[Literal["low", "medium", "high"]] """The risk rating of the legal entity. One of low, medium, high.""" + status: Optional[Literal["active", "closed", "pending", "suspended"]] + """The activation status of the legal entity. + + One of pending, active, suspended, or closed. + """ + suffix: Optional[str] """An individual's suffix.""" diff --git a/src/modern_treasury/types/legal_entity_list_params.py b/src/modern_treasury/types/legal_entity_list_params.py index 19178adc..d87e43bd 100644 --- a/src/modern_treasury/types/legal_entity_list_params.py +++ b/src/modern_treasury/types/legal_entity_list_params.py @@ -23,3 +23,5 @@ class LegalEntityListParams(TypedDict, total=False): per_page: int show_deleted: str + + status: Literal["pending", "active", "suspended", "closed"] diff --git a/src/modern_treasury/types/legal_entity_update_params.py b/src/modern_treasury/types/legal_entity_update_params.py index 4d083675..a1a63753 100644 --- a/src/modern_treasury/types/legal_entity_update_params.py +++ b/src/modern_treasury/types/legal_entity_update_params.py @@ -120,6 +120,12 @@ class LegalEntityUpdateParams(TypedDict, total=False): risk_rating: Optional[Literal["low", "medium", "high"]] """The risk rating of the legal entity. One of low, medium, high.""" + status: Optional[Literal["active", "closed", "pending", "suspended"]] + """The activation status of the legal entity. + + One of pending, active, suspended, or closed. + """ + suffix: Optional[str] """An individual's suffix.""" diff --git a/src/modern_treasury/types/shared/child_legal_entity_create.py b/src/modern_treasury/types/shared/child_legal_entity_create.py index fc6a3b43..3026bb26 100644 --- a/src/modern_treasury/types/shared/child_legal_entity_create.py +++ b/src/modern_treasury/types/shared/child_legal_entity_create.py @@ -366,6 +366,12 @@ class ChildLegalEntityCreate(BaseModel): risk_rating: Optional[Literal["low", "medium", "high"]] = None """The risk rating of the legal entity. One of low, medium, high.""" + status: Optional[Literal["active", "closed", "pending", "suspended"]] = None + """The activation status of the legal entity. + + One of pending, active, suspended, or closed. + """ + suffix: Optional[str] = None """An individual's suffix.""" diff --git a/src/modern_treasury/types/shared_params/child_legal_entity_create.py b/src/modern_treasury/types/shared_params/child_legal_entity_create.py index e33e3a6c..7d0286cc 100644 --- a/src/modern_treasury/types/shared_params/child_legal_entity_create.py +++ b/src/modern_treasury/types/shared_params/child_legal_entity_create.py @@ -377,6 +377,12 @@ class ChildLegalEntityCreate(TypedDict, total=False): risk_rating: Optional[Literal["low", "medium", "high"]] """The risk rating of the legal entity. One of low, medium, high.""" + status: Optional[Literal["active", "closed", "pending", "suspended"]] + """The activation status of the legal entity. + + One of pending, active, suspended, or closed. + """ + suffix: Optional[str] """An individual's suffix.""" diff --git a/tests/api_resources/test_connection_legal_entities.py b/tests/api_resources/test_connection_legal_entities.py index c4c2705a..c95fa608 100644 --- a/tests/api_resources/test_connection_legal_entities.py +++ b/tests/api_resources/test_connection_legal_entities.py @@ -203,6 +203,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: } ], "risk_rating": "low", + "status": "active", "suffix": "suffix", "third_party_verification": { "vendor": "persona", @@ -259,6 +260,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: } ], "risk_rating": "low", + "status": "active", "suffix": "suffix", "third_party_verification": { "vendor": "persona", @@ -623,6 +625,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea } ], "risk_rating": "low", + "status": "active", "suffix": "suffix", "third_party_verification": { "vendor": "persona", @@ -679,6 +682,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea } ], "risk_rating": "low", + "status": "active", "suffix": "suffix", "third_party_verification": { "vendor": "persona", diff --git a/tests/api_resources/test_counterparties.py b/tests/api_resources/test_counterparties.py index 63e7fb01..3f3433d0 100644 --- a/tests/api_resources/test_counterparties.py +++ b/tests/api_resources/test_counterparties.py @@ -268,6 +268,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: } ], "risk_rating": "low", + "status": "active", "suffix": "suffix", "third_party_verification": { "vendor": "persona", @@ -323,6 +324,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: } ], "risk_rating": "low", + "status": "active", "suffix": "suffix", "third_party_verification": { "vendor": "persona", @@ -859,6 +861,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea } ], "risk_rating": "low", + "status": "active", "suffix": "suffix", "third_party_verification": { "vendor": "persona", @@ -914,6 +917,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea } ], "risk_rating": "low", + "status": "active", "suffix": "suffix", "third_party_verification": { "vendor": "persona", diff --git a/tests/api_resources/test_legal_entities.py b/tests/api_resources/test_legal_entities.py index fc22b522..a78aa232 100644 --- a/tests/api_resources/test_legal_entities.py +++ b/tests/api_resources/test_legal_entities.py @@ -203,6 +203,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: } ], "risk_rating": "low", + "status": "active", "suffix": "suffix", "third_party_verification": { "vendor": "persona", @@ -258,6 +259,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: } ], risk_rating="low", + status="active", suffix="suffix", third_party_verification={ "vendor": "persona", @@ -453,6 +455,7 @@ def test_method_update_with_all_params(self, client: ModernTreasury) -> None: } ], risk_rating="low", + status="active", suffix="suffix", third_party_verification={ "vendor": "persona", @@ -527,6 +530,7 @@ def test_method_list_with_all_params(self, client: ModernTreasury) -> None: metadata={"foo": "string"}, per_page=0, show_deleted="show_deleted", + status="pending", ) assert_matches_type(SyncPage[LegalEntity], legal_entity, path=["response"]) @@ -739,6 +743,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea } ], "risk_rating": "low", + "status": "active", "suffix": "suffix", "third_party_verification": { "vendor": "persona", @@ -794,6 +799,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea } ], risk_rating="low", + status="active", suffix="suffix", third_party_verification={ "vendor": "persona", @@ -996,6 +1002,7 @@ async def test_method_update_with_all_params(self, async_client: AsyncModernTrea } ], risk_rating="low", + status="active", suffix="suffix", third_party_verification={ "vendor": "persona", @@ -1072,6 +1079,7 @@ async def test_method_list_with_all_params(self, async_client: AsyncModernTreasu metadata={"foo": "string"}, per_page=0, show_deleted="show_deleted", + status="pending", ) assert_matches_type(AsyncPage[LegalEntity], legal_entity, path=["response"]) diff --git a/tests/api_resources/test_legal_entity_associations.py b/tests/api_resources/test_legal_entity_associations.py index 27768f9b..b54eea7b 100644 --- a/tests/api_resources/test_legal_entity_associations.py +++ b/tests/api_resources/test_legal_entity_associations.py @@ -135,6 +135,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: } ], "risk_rating": "low", + "status": "active", "suffix": "suffix", "third_party_verification": { "vendor": "persona", @@ -319,6 +320,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea } ], "risk_rating": "low", + "status": "active", "suffix": "suffix", "third_party_verification": { "vendor": "persona", From a36277e15343038decd3bf610f9e1ae68235a86a Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Sat, 7 Feb 2026 00:23:04 +0000 Subject: [PATCH 09/17] feat(api): api update --- .stats.yml | 4 ++-- .../resources/ledger_account_categories.py | 8 ++++++++ src/modern_treasury/resources/ledger_accounts.py | 8 ++++++++ .../types/ledger_account_category_create_params.py | 3 +++ src/modern_treasury/types/ledger_account_create_params.py | 3 +++ .../types/shared/ledger_account_create_request.py | 3 +++ .../types/shared_params/ledger_account_create_request.py | 3 +++ tests/api_resources/test_bulk_requests.py | 2 ++ tests/api_resources/test_counterparties.py | 2 ++ tests/api_resources/test_external_accounts.py | 2 ++ tests/api_resources/test_ledger_account_categories.py | 2 ++ tests/api_resources/test_ledger_accounts.py | 2 ++ tests/api_resources/test_payment_orders.py | 6 ++++++ tests/api_resources/test_virtual_accounts.py | 2 ++ 14 files changed, 48 insertions(+), 2 deletions(-) diff --git a/.stats.yml b/.stats.yml index 720060d9..32b59e14 100644 --- a/.stats.yml +++ b/.stats.yml @@ -1,4 +1,4 @@ configured_endpoints: 168 -openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-2447552f3c4fb0bca7b73774333098a01857ded98c0bd581d02385ee1ef29996.yml -openapi_spec_hash: eae03289efeec45844cd66747f5c782e +openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-01390b6789af65c5b8e71531455f173bda9633dbf7e8dca0c71b41da4807ca70.yml +openapi_spec_hash: 2e7ae98bd7950304cd08889380f532ab config_hash: 196d1bf0caae233683efb6abc123941f diff --git a/src/modern_treasury/resources/ledger_account_categories.py b/src/modern_treasury/resources/ledger_account_categories.py index 8f5a6f9e..a3274078 100644 --- a/src/modern_treasury/resources/ledger_account_categories.py +++ b/src/modern_treasury/resources/ledger_account_categories.py @@ -55,6 +55,7 @@ def create( normal_balance: TransactionDirection, currency_exponent: Optional[int] | Omit = omit, description: Optional[str] | Omit = omit, + external_id: Optional[str] | Omit = omit, ledger_account_category_ids: SequenceNotStr[str] | Omit = omit, metadata: Dict[str, str] | Omit = omit, # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. @@ -81,6 +82,8 @@ def create( description: The description of the ledger account category. + external_id: An optional user-defined 180 character unique identifier. + ledger_account_category_ids: The array of ledger account category ids that this ledger account category should be a child of. @@ -107,6 +110,7 @@ def create( "normal_balance": normal_balance, "currency_exponent": currency_exponent, "description": description, + "external_id": external_id, "ledger_account_category_ids": ledger_account_category_ids, "metadata": metadata, }, @@ -552,6 +556,7 @@ async def create( normal_balance: TransactionDirection, currency_exponent: Optional[int] | Omit = omit, description: Optional[str] | Omit = omit, + external_id: Optional[str] | Omit = omit, ledger_account_category_ids: SequenceNotStr[str] | Omit = omit, metadata: Dict[str, str] | Omit = omit, # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. @@ -578,6 +583,8 @@ async def create( description: The description of the ledger account category. + external_id: An optional user-defined 180 character unique identifier. + ledger_account_category_ids: The array of ledger account category ids that this ledger account category should be a child of. @@ -604,6 +611,7 @@ async def create( "normal_balance": normal_balance, "currency_exponent": currency_exponent, "description": description, + "external_id": external_id, "ledger_account_category_ids": ledger_account_category_ids, "metadata": metadata, }, diff --git a/src/modern_treasury/resources/ledger_accounts.py b/src/modern_treasury/resources/ledger_accounts.py index 74fe64a8..1d97c083 100644 --- a/src/modern_treasury/resources/ledger_accounts.py +++ b/src/modern_treasury/resources/ledger_accounts.py @@ -57,6 +57,7 @@ def create( normal_balance: TransactionDirection, currency_exponent: Optional[int] | Omit = omit, description: Optional[str] | Omit = omit, + external_id: Optional[str] | Omit = omit, ledger_account_category_ids: SequenceNotStr[str] | Omit = omit, ledgerable_id: str | Omit = omit, ledgerable_type: Literal["counterparty", "external_account", "internal_account", "virtual_account"] @@ -86,6 +87,8 @@ def create( description: The description of the ledger account. + external_id: An optional user-defined 180 character unique identifier. + ledger_account_category_ids: The array of ledger account category ids that this ledger account should be a child of. @@ -119,6 +122,7 @@ def create( "normal_balance": normal_balance, "currency_exponent": currency_exponent, "description": description, + "external_id": external_id, "ledger_account_category_ids": ledger_account_category_ids, "ledgerable_id": ledgerable_id, "ledgerable_type": ledgerable_type, @@ -415,6 +419,7 @@ async def create( normal_balance: TransactionDirection, currency_exponent: Optional[int] | Omit = omit, description: Optional[str] | Omit = omit, + external_id: Optional[str] | Omit = omit, ledger_account_category_ids: SequenceNotStr[str] | Omit = omit, ledgerable_id: str | Omit = omit, ledgerable_type: Literal["counterparty", "external_account", "internal_account", "virtual_account"] @@ -444,6 +449,8 @@ async def create( description: The description of the ledger account. + external_id: An optional user-defined 180 character unique identifier. + ledger_account_category_ids: The array of ledger account category ids that this ledger account should be a child of. @@ -477,6 +484,7 @@ async def create( "normal_balance": normal_balance, "currency_exponent": currency_exponent, "description": description, + "external_id": external_id, "ledger_account_category_ids": ledger_account_category_ids, "ledgerable_id": ledgerable_id, "ledgerable_type": ledgerable_type, diff --git a/src/modern_treasury/types/ledger_account_category_create_params.py b/src/modern_treasury/types/ledger_account_category_create_params.py index 329d1600..3d8ee37f 100644 --- a/src/modern_treasury/types/ledger_account_category_create_params.py +++ b/src/modern_treasury/types/ledger_account_category_create_params.py @@ -30,6 +30,9 @@ class LedgerAccountCategoryCreateParams(TypedDict, total=False): description: Optional[str] """The description of the ledger account category.""" + external_id: Optional[str] + """An optional user-defined 180 character unique identifier.""" + ledger_account_category_ids: SequenceNotStr[str] """ The array of ledger account category ids that this ledger account category diff --git a/src/modern_treasury/types/ledger_account_create_params.py b/src/modern_treasury/types/ledger_account_create_params.py index 09f33a2c..0e56366e 100644 --- a/src/modern_treasury/types/ledger_account_create_params.py +++ b/src/modern_treasury/types/ledger_account_create_params.py @@ -30,6 +30,9 @@ class LedgerAccountCreateParams(TypedDict, total=False): description: Optional[str] """The description of the ledger account.""" + external_id: Optional[str] + """An optional user-defined 180 character unique identifier.""" + ledger_account_category_ids: SequenceNotStr[str] """ The array of ledger account category ids that this ledger account should be a diff --git a/src/modern_treasury/types/shared/ledger_account_create_request.py b/src/modern_treasury/types/shared/ledger_account_create_request.py index aa9c560f..4143da49 100644 --- a/src/modern_treasury/types/shared/ledger_account_create_request.py +++ b/src/modern_treasury/types/shared/ledger_account_create_request.py @@ -28,6 +28,9 @@ class LedgerAccountCreateRequest(BaseModel): description: Optional[str] = None """The description of the ledger account.""" + external_id: Optional[str] = None + """An optional user-defined 180 character unique identifier.""" + ledger_account_category_ids: Optional[List[str]] = None """ The array of ledger account category ids that this ledger account should be a diff --git a/src/modern_treasury/types/shared_params/ledger_account_create_request.py b/src/modern_treasury/types/shared_params/ledger_account_create_request.py index f90ae769..cc87ceaf 100644 --- a/src/modern_treasury/types/shared_params/ledger_account_create_request.py +++ b/src/modern_treasury/types/shared_params/ledger_account_create_request.py @@ -30,6 +30,9 @@ class LedgerAccountCreateRequest(TypedDict, total=False): description: Optional[str] """The description of the ledger account.""" + external_id: Optional[str] + """An optional user-defined 180 character unique identifier.""" + ledger_account_category_ids: SequenceNotStr[str] """ The array of ledger account category ids that this ledger account should be a diff --git a/tests/api_resources/test_bulk_requests.py b/tests/api_resources/test_bulk_requests.py index c5ff0d73..ba49fd84 100644 --- a/tests/api_resources/test_bulk_requests.py +++ b/tests/api_resources/test_bulk_requests.py @@ -139,6 +139,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", @@ -440,6 +441,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", diff --git a/tests/api_resources/test_counterparties.py b/tests/api_resources/test_counterparties.py index 3f3433d0..b63a685b 100644 --- a/tests/api_resources/test_counterparties.py +++ b/tests/api_resources/test_counterparties.py @@ -57,6 +57,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", @@ -650,6 +651,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", diff --git a/tests/api_resources/test_external_accounts.py b/tests/api_resources/test_external_accounts.py index abea9189..64913012 100644 --- a/tests/api_resources/test_external_accounts.py +++ b/tests/api_resources/test_external_accounts.py @@ -53,6 +53,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", @@ -428,6 +429,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", diff --git a/tests/api_resources/test_ledger_account_categories.py b/tests/api_resources/test_ledger_account_categories.py index 4d92f6e6..d8038ba9 100644 --- a/tests/api_resources/test_ledger_account_categories.py +++ b/tests/api_resources/test_ledger_account_categories.py @@ -40,6 +40,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: normal_balance="credit", currency_exponent=0, description="description", + external_id="external_id", ledger_account_category_ids=["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], metadata={ "key": "value", @@ -477,6 +478,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea normal_balance="credit", currency_exponent=0, description="description", + external_id="external_id", ledger_account_category_ids=["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], metadata={ "key": "value", diff --git a/tests/api_resources/test_ledger_accounts.py b/tests/api_resources/test_ledger_accounts.py index 80845d0f..c24c08be 100644 --- a/tests/api_resources/test_ledger_accounts.py +++ b/tests/api_resources/test_ledger_accounts.py @@ -40,6 +40,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: normal_balance="credit", currency_exponent=0, description="description", + external_id="external_id", ledger_account_category_ids=["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], ledgerable_id="182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", ledgerable_type="counterparty", @@ -321,6 +322,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea normal_balance="credit", currency_exponent=0, description="description", + external_id="external_id", ledger_account_category_ids=["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], ledgerable_id="182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", ledgerable_type="counterparty", diff --git a/tests/api_resources/test_payment_orders.py b/tests/api_resources/test_payment_orders.py index 751e4eb5..db077223 100644 --- a/tests/api_resources/test_payment_orders.py +++ b/tests/api_resources/test_payment_orders.py @@ -140,6 +140,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", @@ -332,6 +333,7 @@ def test_method_update_with_all_params(self, client: ModernTreasury) -> None: "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", @@ -570,6 +572,7 @@ def test_method_create_async_with_all_params(self, client: ModernTreasury) -> No "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", @@ -773,6 +776,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", @@ -965,6 +969,7 @@ async def test_method_update_with_all_params(self, async_client: AsyncModernTrea "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", @@ -1203,6 +1208,7 @@ async def test_method_create_async_with_all_params(self, async_client: AsyncMode "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", diff --git a/tests/api_resources/test_virtual_accounts.py b/tests/api_resources/test_virtual_accounts.py index 9b8e440e..035cedd4 100644 --- a/tests/api_resources/test_virtual_accounts.py +++ b/tests/api_resources/test_virtual_accounts.py @@ -50,6 +50,7 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", @@ -293,6 +294,7 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "normal_balance": "credit", "currency_exponent": 0, "description": "description", + "external_id": "external_id", "ledger_account_category_ids": ["182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e"], "ledgerable_id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", "ledgerable_type": "counterparty", From f21a8b106ca2bd401fc9d5782574d11d700e6e4c Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Mon, 9 Feb 2026 14:34:44 +0000 Subject: [PATCH 10/17] chore(internal): bump dependencies --- requirements-dev.lock | 20 ++++++++++---------- requirements.lock | 8 ++++---- 2 files changed, 14 insertions(+), 14 deletions(-) diff --git a/requirements-dev.lock b/requirements-dev.lock index 9c531347..739f62e1 100644 --- a/requirements-dev.lock +++ b/requirements-dev.lock @@ -12,14 +12,14 @@ -e file:. aiohappyeyeballs==2.6.1 # via aiohttp -aiohttp==3.13.2 +aiohttp==3.13.3 # via httpx-aiohttp # via modern-treasury aiosignal==1.4.0 # via aiohttp annotated-types==0.7.0 # via pydantic -anyio==4.12.0 +anyio==4.12.1 # via httpx # via modern-treasury argcomplete==3.6.3 @@ -31,7 +31,7 @@ attrs==25.4.0 # via nox backports-asyncio-runner==1.2.0 # via pytest-asyncio -certifi==2025.11.12 +certifi==2026.1.4 # via httpcore # via httpx colorlog==6.10.1 @@ -61,7 +61,7 @@ httpx==0.28.1 # via httpx-aiohttp # via modern-treasury # via respx -httpx-aiohttp==0.1.9 +httpx-aiohttp==0.1.12 # via modern-treasury humanize==4.13.0 # via nox @@ -69,7 +69,7 @@ idna==3.11 # via anyio # via httpx # via yarl -importlib-metadata==8.7.0 +importlib-metadata==8.7.1 iniconfig==2.1.0 # via pytest markdown-it-py==3.0.0 @@ -82,14 +82,14 @@ multidict==6.7.0 mypy==1.17.0 mypy-extensions==1.1.0 # via mypy -nodeenv==1.9.1 +nodeenv==1.10.0 # via pyright nox==2025.11.12 packaging==25.0 # via dependency-groups # via nox # via pytest -pathspec==0.12.1 +pathspec==1.0.3 # via mypy platformdirs==4.4.0 # via virtualenv @@ -115,13 +115,13 @@ python-dateutil==2.9.0.post0 # via time-machine respx==0.22.0 rich==14.2.0 -ruff==0.14.7 +ruff==0.14.13 six==1.17.0 # via python-dateutil sniffio==1.3.1 # via modern-treasury time-machine==2.19.0 -tomli==2.3.0 +tomli==2.4.0 # via dependency-groups # via mypy # via nox @@ -141,7 +141,7 @@ typing-extensions==4.15.0 # via virtualenv typing-inspection==0.4.2 # via pydantic -virtualenv==20.35.4 +virtualenv==20.36.1 # via nox yarl==1.22.0 # via aiohttp diff --git a/requirements.lock b/requirements.lock index d7ea0864..de46d637 100644 --- a/requirements.lock +++ b/requirements.lock @@ -12,21 +12,21 @@ -e file:. aiohappyeyeballs==2.6.1 # via aiohttp -aiohttp==3.13.2 +aiohttp==3.13.3 # via httpx-aiohttp # via modern-treasury aiosignal==1.4.0 # via aiohttp annotated-types==0.7.0 # via pydantic -anyio==4.12.0 +anyio==4.12.1 # via httpx # via modern-treasury async-timeout==5.0.1 # via aiohttp attrs==25.4.0 # via aiohttp -certifi==2025.11.12 +certifi==2026.1.4 # via httpcore # via httpx distro==1.9.0 @@ -43,7 +43,7 @@ httpcore==1.0.9 httpx==0.28.1 # via httpx-aiohttp # via modern-treasury -httpx-aiohttp==0.1.9 +httpx-aiohttp==0.1.12 # via modern-treasury idna==3.11 # via anyio From f2a9d02bab75a30b9c614fe7c7369466ce2839d0 Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Wed, 11 Feb 2026 14:21:36 +0000 Subject: [PATCH 11/17] chore(internal): fix lint error on Python 3.14 --- src/modern_treasury/_utils/_compat.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/modern_treasury/_utils/_compat.py b/src/modern_treasury/_utils/_compat.py index dd703233..2c70b299 100644 --- a/src/modern_treasury/_utils/_compat.py +++ b/src/modern_treasury/_utils/_compat.py @@ -26,7 +26,7 @@ def is_union(tp: Optional[Type[Any]]) -> bool: else: import types - return tp is Union or tp is types.UnionType + return tp is Union or tp is types.UnionType # type: ignore[comparison-overlap] def is_typeddict(tp: Type[Any]) -> bool: From 447158528a5c121ed3040901e6cb7b1117210b46 Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Wed, 11 Feb 2026 16:20:02 +0000 Subject: [PATCH 12/17] chore(internal): codegen related update --- .../resources/ledger_account_categories.py | 10 ++-------- src/modern_treasury/resources/ledger_entries.py | 6 +++--- .../types/ledger_account_category_list_params.py | 6 +----- src/modern_treasury/types/ledger_entry_list_params.py | 4 ++-- tests/api_resources/test_ledger_account_categories.py | 4 ++-- tests/api_resources/test_ledger_entries.py | 4 ++-- 6 files changed, 12 insertions(+), 22 deletions(-) diff --git a/src/modern_treasury/resources/ledger_account_categories.py b/src/modern_treasury/resources/ledger_account_categories.py index a3274078..1540d418 100644 --- a/src/modern_treasury/resources/ledger_account_categories.py +++ b/src/modern_treasury/resources/ledger_account_categories.py @@ -240,7 +240,7 @@ def list( ledger_account_id: str | Omit = omit, ledger_id: str | Omit = omit, metadata: Dict[str, str] | Omit = omit, - name: SequenceNotStr[str] | Omit = omit, + name: str | Omit = omit, parent_ledger_account_category_id: str | Omit = omit, per_page: int | Omit = omit, # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. @@ -269,9 +269,6 @@ def list( `Loan`, the query would be `metadata%5BType%5D=Loan`. This encodes the query parameters. - name: If you have specific names to retrieve in bulk, you can pass them as query - parameters delimited with `name[]=`, for example `?name[]=123&name[]=abc`. - parent_ledger_account_category_id: Query categories that are nested underneath a parent category extra_headers: Send extra headers @@ -741,7 +738,7 @@ def list( ledger_account_id: str | Omit = omit, ledger_id: str | Omit = omit, metadata: Dict[str, str] | Omit = omit, - name: SequenceNotStr[str] | Omit = omit, + name: str | Omit = omit, parent_ledger_account_category_id: str | Omit = omit, per_page: int | Omit = omit, # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. @@ -770,9 +767,6 @@ def list( `Loan`, the query would be `metadata%5BType%5D=Loan`. This encodes the query parameters. - name: If you have specific names to retrieve in bulk, you can pass them as query - parameters delimited with `name[]=`, for example `?name[]=123&name[]=abc`. - parent_ledger_account_category_id: Query categories that are nested underneath a parent category extra_headers: Send extra headers diff --git a/src/modern_treasury/resources/ledger_entries.py b/src/modern_treasury/resources/ledger_entries.py index dac115d6..7a818d4a 100644 --- a/src/modern_treasury/resources/ledger_entries.py +++ b/src/modern_treasury/resources/ledger_entries.py @@ -2,7 +2,7 @@ from __future__ import annotations -from typing import Dict, List, Union, Optional +from typing import Dict, Union, Optional from datetime import date, datetime from typing_extensions import Literal @@ -153,7 +153,7 @@ def list( per_page: int | Omit = omit, show_balances: bool | Omit = omit, show_deleted: bool | Omit = omit, - status: List[Literal["pending", "posted", "archived"]] | Omit = omit, + status: Literal["pending", "posted", "archived"] | Omit = omit, updated_at: Dict[str, Union[str, datetime]] | Omit = omit, # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. # The extra values given here take precedence over values defined on the client or passed to this method. @@ -396,7 +396,7 @@ def list( per_page: int | Omit = omit, show_balances: bool | Omit = omit, show_deleted: bool | Omit = omit, - status: List[Literal["pending", "posted", "archived"]] | Omit = omit, + status: Literal["pending", "posted", "archived"] | Omit = omit, updated_at: Dict[str, Union[str, datetime]] | Omit = omit, # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. # The extra values given here take precedence over values defined on the client or passed to this method. diff --git a/src/modern_treasury/types/ledger_account_category_list_params.py b/src/modern_treasury/types/ledger_account_category_list_params.py index 8855b3bc..804e356d 100644 --- a/src/modern_treasury/types/ledger_account_category_list_params.py +++ b/src/modern_treasury/types/ledger_account_category_list_params.py @@ -48,11 +48,7 @@ class LedgerAccountCategoryListParams(TypedDict, total=False): parameters. """ - name: SequenceNotStr[str] - """ - If you have specific names to retrieve in bulk, you can pass them as query - parameters delimited with `name[]=`, for example `?name[]=123&name[]=abc`. - """ + name: str parent_ledger_account_category_id: str """Query categories that are nested underneath a parent category""" diff --git a/src/modern_treasury/types/ledger_entry_list_params.py b/src/modern_treasury/types/ledger_entry_list_params.py index ad931bd0..0e179f75 100644 --- a/src/modern_treasury/types/ledger_entry_list_params.py +++ b/src/modern_treasury/types/ledger_entry_list_params.py @@ -2,7 +2,7 @@ from __future__ import annotations -from typing import Dict, List, Union, Optional +from typing import Dict, Union, Optional from datetime import date, datetime from typing_extensions import Literal, TypedDict @@ -106,7 +106,7 @@ class LedgerEntryListParams(TypedDict, total=False): previous entries are deleted. """ - status: List[Literal["pending", "posted", "archived"]] + status: Literal["pending", "posted", "archived"] """Get all ledger entries that match the status specified. One of `pending`, `posted`, or `archived`. For multiple statuses, use diff --git a/tests/api_resources/test_ledger_account_categories.py b/tests/api_resources/test_ledger_account_categories.py index d8038ba9..05b16795 100644 --- a/tests/api_resources/test_ledger_account_categories.py +++ b/tests/api_resources/test_ledger_account_categories.py @@ -197,7 +197,7 @@ def test_method_list_with_all_params(self, client: ModernTreasury) -> None: ledger_account_id="ledger_account_id", ledger_id="ledger_id", metadata={"foo": "string"}, - name=["string"], + name="name", parent_ledger_account_category_id="parent_ledger_account_category_id", per_page=0, ) @@ -635,7 +635,7 @@ async def test_method_list_with_all_params(self, async_client: AsyncModernTreasu ledger_account_id="ledger_account_id", ledger_id="ledger_id", metadata={"foo": "string"}, - name=["string"], + name="name", parent_ledger_account_category_id="parent_ledger_account_category_id", per_page=0, ) diff --git a/tests/api_resources/test_ledger_entries.py b/tests/api_resources/test_ledger_entries.py index 8b21dda2..cbbbe3ac 100644 --- a/tests/api_resources/test_ledger_entries.py +++ b/tests/api_resources/test_ledger_entries.py @@ -153,7 +153,7 @@ def test_method_list_with_all_params(self, client: ModernTreasury) -> None: per_page=0, show_balances=True, show_deleted=True, - status=["pending"], + status="pending", updated_at={"foo": parse_datetime("2019-12-27T18:11:19.117Z")}, ) assert_matches_type(SyncPage[LedgerEntry], ledger_entry, path=["response"]) @@ -316,7 +316,7 @@ async def test_method_list_with_all_params(self, async_client: AsyncModernTreasu per_page=0, show_balances=True, show_deleted=True, - status=["pending"], + status="pending", updated_at={"foo": parse_datetime("2019-12-27T18:11:19.117Z")}, ) assert_matches_type(AsyncPage[LedgerEntry], ledger_entry, path=["response"]) From 586eba00e21d0ff37997d7ef257a23a042f42a21 Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Thu, 12 Feb 2026 16:50:54 +0000 Subject: [PATCH 13/17] chore: format all `api.md` files --- pyproject.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pyproject.toml b/pyproject.toml index d1289f6d..8bcf65d3 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -69,7 +69,7 @@ format = { chain = [ # run formatting again to fix any inconsistencies when imports are stripped "format:ruff", ]} -"format:docs" = "python scripts/utils/ruffen-docs.py README.md api.md" +"format:docs" = "bash -c 'python scripts/utils/ruffen-docs.py README.md $(find . -type f -name api.md)'" "format:ruff" = "ruff format" "lint" = { chain = [ From 1894bdef23f2afc6d0e2e5b3e968838bce0c8130 Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Thu, 12 Feb 2026 22:28:31 +0000 Subject: [PATCH 14/17] feat(api): api update --- .stats.yml | 4 +- api.md | 1 - .../resources/legal_entities.py | 9 -- src/modern_treasury/types/__init__.py | 1 - .../types/child_legal_entity.py | 3 +- .../connection_legal_entity_create_params.py | 3 - .../types/counterparty_create_params.py | 3 - src/modern_treasury/types/legal_entity.py | 3 +- .../types/legal_entity_create_params.py | 3 - .../types/legal_entity_update_params.py | 3 - src/modern_treasury/types/payment_order.py | 6 ++ src/modern_treasury/types/shared/__init__.py | 1 - .../types/shared/child_legal_entity_create.py | 3 - .../shared/legal_entity_compliance_detail.py | 44 ---------- .../types/shared_params/__init__.py | 1 - .../child_legal_entity_create.py | 3 - .../legal_entity_compliance_detail.py | 47 ----------- .../test_connection_legal_entities.py | 56 ------------- tests/api_resources/test_counterparties.py | 56 ------------- tests/api_resources/test_legal_entities.py | 84 ------------------- .../test_legal_entity_associations.py | 28 ------- 21 files changed, 10 insertions(+), 352 deletions(-) delete mode 100644 src/modern_treasury/types/shared/legal_entity_compliance_detail.py delete mode 100644 src/modern_treasury/types/shared_params/legal_entity_compliance_detail.py diff --git a/.stats.yml b/.stats.yml index 32b59e14..ef3682f0 100644 --- a/.stats.yml +++ b/.stats.yml @@ -1,4 +1,4 @@ configured_endpoints: 168 -openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-01390b6789af65c5b8e71531455f173bda9633dbf7e8dca0c71b41da4807ca70.yml -openapi_spec_hash: 2e7ae98bd7950304cd08889380f532ab +openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-a78ca984074c091219e7b10aefe1d72fbbd4f4297fb70b2a49bed1cb5999f27a.yml +openapi_spec_hash: c15c4f96e77008a4b2947be54c3def9a config_hash: 196d1bf0caae233683efb6abc123941f diff --git a/api.md b/api.md index 59f3b76a..23df3500 100644 --- a/api.md +++ b/api.md @@ -18,7 +18,6 @@ from modern_treasury.types import ( LedgerTransactionCreateRequest, LegalEntityAddressCreateRequest, LegalEntityAssociationInlineCreate, - LegalEntityComplianceDetail, LegalEntityIndustryClassification, TransactionDirection, ) diff --git a/src/modern_treasury/resources/legal_entities.py b/src/modern_treasury/resources/legal_entities.py index d527f085..1c12c51e 100644 --- a/src/modern_treasury/resources/legal_entities.py +++ b/src/modern_treasury/resources/legal_entities.py @@ -19,7 +19,6 @@ from .._base_client import AsyncPaginator, make_request_options from ..types.legal_entity import LegalEntity from ..types.shared_params.identification_create_request import IdentificationCreateRequest -from ..types.shared_params.legal_entity_compliance_detail import LegalEntityComplianceDetail from ..types.shared_params.legal_entity_address_create_request import LegalEntityAddressCreateRequest from ..types.shared_params.legal_entity_industry_classification import LegalEntityIndustryClassification from ..types.shared_params.legal_entity_association_inline_create import LegalEntityAssociationInlineCreate @@ -56,7 +55,6 @@ def create( business_description: Optional[str] | Omit = omit, business_name: Optional[str] | Omit = omit, citizenship_country: Optional[str] | Omit = omit, - compliance_details: Optional[LegalEntityComplianceDetail] | Omit = omit, connection_id: Optional[str] | Omit = omit, country_of_incorporation: Optional[str] | Omit = omit, date_formed: Union[str, date, None] | Omit = omit, @@ -197,7 +195,6 @@ def create( "business_description": business_description, "business_name": business_name, "citizenship_country": citizenship_country, - "compliance_details": compliance_details, "connection_id": connection_id, "country_of_incorporation": country_of_incorporation, "date_formed": date_formed, @@ -284,7 +281,6 @@ def update( business_description: Optional[str] | Omit = omit, business_name: Optional[str] | Omit = omit, citizenship_country: Optional[str] | Omit = omit, - compliance_details: Optional[LegalEntityComplianceDetail] | Omit = omit, country_of_incorporation: Optional[str] | Omit = omit, date_formed: Union[str, date, None] | Omit = omit, date_of_birth: Union[str, date, None] | Omit = omit, @@ -414,7 +410,6 @@ def update( "business_description": business_description, "business_name": business_name, "citizenship_country": citizenship_country, - "compliance_details": compliance_details, "country_of_incorporation": country_of_incorporation, "date_formed": date_formed, "date_of_birth": date_of_birth, @@ -542,7 +537,6 @@ async def create( business_description: Optional[str] | Omit = omit, business_name: Optional[str] | Omit = omit, citizenship_country: Optional[str] | Omit = omit, - compliance_details: Optional[LegalEntityComplianceDetail] | Omit = omit, connection_id: Optional[str] | Omit = omit, country_of_incorporation: Optional[str] | Omit = omit, date_formed: Union[str, date, None] | Omit = omit, @@ -683,7 +677,6 @@ async def create( "business_description": business_description, "business_name": business_name, "citizenship_country": citizenship_country, - "compliance_details": compliance_details, "connection_id": connection_id, "country_of_incorporation": country_of_incorporation, "date_formed": date_formed, @@ -770,7 +763,6 @@ async def update( business_description: Optional[str] | Omit = omit, business_name: Optional[str] | Omit = omit, citizenship_country: Optional[str] | Omit = omit, - compliance_details: Optional[LegalEntityComplianceDetail] | Omit = omit, country_of_incorporation: Optional[str] | Omit = omit, date_formed: Union[str, date, None] | Omit = omit, date_of_birth: Union[str, date, None] | Omit = omit, @@ -900,7 +892,6 @@ async def update( "business_description": business_description, "business_name": business_name, "citizenship_country": citizenship_country, - "compliance_details": compliance_details, "country_of_incorporation": country_of_incorporation, "date_formed": date_formed, "date_of_birth": date_of_birth, diff --git a/src/modern_treasury/types/__init__.py b/src/modern_treasury/types/__init__.py index b0ab0559..155475c7 100644 --- a/src/modern_treasury/types/__init__.py +++ b/src/modern_treasury/types/__init__.py @@ -30,7 +30,6 @@ LedgerEntryCreateRequest as LedgerEntryCreateRequest, LedgerAccountCreateRequest as LedgerAccountCreateRequest, IdentificationCreateRequest as IdentificationCreateRequest, - LegalEntityComplianceDetail as LegalEntityComplianceDetail, LedgerTransactionCreateRequest as LedgerTransactionCreateRequest, LegalEntityAddressCreateRequest as LegalEntityAddressCreateRequest, LegalEntityIndustryClassification as LegalEntityIndustryClassification, diff --git a/src/modern_treasury/types/child_legal_entity.py b/src/modern_treasury/types/child_legal_entity.py index 563903b2..9ab36dd9 100644 --- a/src/modern_treasury/types/child_legal_entity.py +++ b/src/modern_treasury/types/child_legal_entity.py @@ -8,7 +8,6 @@ from .._models import BaseModel from .document import Document -from .shared.legal_entity_compliance_detail import LegalEntityComplianceDetail from .shared.legal_entity_industry_classification import LegalEntityIndustryClassification __all__ = [ @@ -388,7 +387,7 @@ class ChildLegalEntity(BaseModel): citizenship_country: Optional[str] = None """The country of citizenship for an individual.""" - compliance_details: Optional[LegalEntityComplianceDetail] = None + compliance_details: Optional[object] = None country_of_incorporation: Optional[str] = None """ diff --git a/src/modern_treasury/types/connection_legal_entity_create_params.py b/src/modern_treasury/types/connection_legal_entity_create_params.py index f4826964..c7961030 100644 --- a/src/modern_treasury/types/connection_legal_entity_create_params.py +++ b/src/modern_treasury/types/connection_legal_entity_create_params.py @@ -9,7 +9,6 @@ from .._types import SequenceNotStr from .._utils import PropertyInfo from .shared_params.identification_create_request import IdentificationCreateRequest -from .shared_params.legal_entity_compliance_detail import LegalEntityComplianceDetail from .shared_params.legal_entity_address_create_request import LegalEntityAddressCreateRequest from .shared_params.legal_entity_industry_classification import LegalEntityIndustryClassification @@ -296,8 +295,6 @@ class LegalEntity(TypedDict, total=False): citizenship_country: Optional[str] """The country of citizenship for an individual.""" - compliance_details: Optional[LegalEntityComplianceDetail] - connection_id: Optional[str] """The connection ID for the connection the legal entity is associated with. diff --git a/src/modern_treasury/types/counterparty_create_params.py b/src/modern_treasury/types/counterparty_create_params.py index 008a13f1..37ff8482 100644 --- a/src/modern_treasury/types/counterparty_create_params.py +++ b/src/modern_treasury/types/counterparty_create_params.py @@ -13,7 +13,6 @@ from .contact_detail_create_request_param import ContactDetailCreateRequestParam from .shared_params.identification_create_request import IdentificationCreateRequest from .shared_params.ledger_account_create_request import LedgerAccountCreateRequest -from .shared_params.legal_entity_compliance_detail import LegalEntityComplianceDetail from .shared_params.legal_entity_address_create_request import LegalEntityAddressCreateRequest from .shared_params.legal_entity_industry_classification import LegalEntityIndustryClassification @@ -517,8 +516,6 @@ class LegalEntity(TypedDict, total=False): citizenship_country: Optional[str] """The country of citizenship for an individual.""" - compliance_details: Optional[LegalEntityComplianceDetail] - connection_id: Optional[str] """The connection ID for the connection the legal entity is associated with. diff --git a/src/modern_treasury/types/legal_entity.py b/src/modern_treasury/types/legal_entity.py index 2509356e..a596a2ca 100644 --- a/src/modern_treasury/types/legal_entity.py +++ b/src/modern_treasury/types/legal_entity.py @@ -8,7 +8,6 @@ from .._models import BaseModel from .document import Document -from .shared.legal_entity_compliance_detail import LegalEntityComplianceDetail from .shared.legal_entity_industry_classification import LegalEntityIndustryClassification __all__ = [ @@ -388,7 +387,7 @@ class LegalEntity(BaseModel): citizenship_country: Optional[str] = None """The country of citizenship for an individual.""" - compliance_details: Optional[LegalEntityComplianceDetail] = None + compliance_details: Optional[object] = None country_of_incorporation: Optional[str] = None """ diff --git a/src/modern_treasury/types/legal_entity_create_params.py b/src/modern_treasury/types/legal_entity_create_params.py index cba8ee5d..c404f095 100644 --- a/src/modern_treasury/types/legal_entity_create_params.py +++ b/src/modern_treasury/types/legal_entity_create_params.py @@ -9,7 +9,6 @@ from .._types import SequenceNotStr from .._utils import PropertyInfo from .shared_params.identification_create_request import IdentificationCreateRequest -from .shared_params.legal_entity_compliance_detail import LegalEntityComplianceDetail from .shared_params.legal_entity_address_create_request import LegalEntityAddressCreateRequest from .shared_params.legal_entity_industry_classification import LegalEntityIndustryClassification @@ -43,8 +42,6 @@ class LegalEntityCreateParams(TypedDict, total=False): citizenship_country: Optional[str] """The country of citizenship for an individual.""" - compliance_details: Optional[LegalEntityComplianceDetail] - connection_id: Optional[str] """The connection ID for the connection the legal entity is associated with. diff --git a/src/modern_treasury/types/legal_entity_update_params.py b/src/modern_treasury/types/legal_entity_update_params.py index a1a63753..fdcba691 100644 --- a/src/modern_treasury/types/legal_entity_update_params.py +++ b/src/modern_treasury/types/legal_entity_update_params.py @@ -9,7 +9,6 @@ from .._types import SequenceNotStr from .._utils import PropertyInfo from .shared_params.identification_create_request import IdentificationCreateRequest -from .shared_params.legal_entity_compliance_detail import LegalEntityComplianceDetail from .shared_params.legal_entity_address_create_request import LegalEntityAddressCreateRequest from .shared_params.legal_entity_industry_classification import LegalEntityIndustryClassification @@ -40,8 +39,6 @@ class LegalEntityUpdateParams(TypedDict, total=False): citizenship_country: Optional[str] """The country of citizenship for an individual.""" - compliance_details: Optional[LegalEntityComplianceDetail] - country_of_incorporation: Optional[str] """ The country code where the business is incorporated in the ISO 3166-1 alpha-2 or diff --git a/src/modern_treasury/types/payment_order.py b/src/modern_treasury/types/payment_order.py index 480f999a..382f080e 100644 --- a/src/modern_treasury/types/payment_order.py +++ b/src/modern_treasury/types/payment_order.py @@ -232,6 +232,12 @@ class PaymentOrder(BaseModel): allowed by the network is $100,000. """ + batch_id: Optional[str] = None + """The ID of the batch in which the payment order is included. + + Only populated after the payment order begins processing. + """ + charge_bearer: Optional[Literal["shared", "sender", "receiver"]] = None """The party that will pay the fees for the payment order. diff --git a/src/modern_treasury/types/shared/__init__.py b/src/modern_treasury/types/shared/__init__.py index 32d066c6..f854d293 100644 --- a/src/modern_treasury/types/shared/__init__.py +++ b/src/modern_treasury/types/shared/__init__.py @@ -14,7 +14,6 @@ from .ledger_entry_create_request import LedgerEntryCreateRequest as LedgerEntryCreateRequest from .identification_create_request import IdentificationCreateRequest as IdentificationCreateRequest from .ledger_account_create_request import LedgerAccountCreateRequest as LedgerAccountCreateRequest -from .legal_entity_compliance_detail import LegalEntityComplianceDetail as LegalEntityComplianceDetail from .ledger_transaction_create_request import LedgerTransactionCreateRequest as LedgerTransactionCreateRequest from .legal_entity_address_create_request import LegalEntityAddressCreateRequest as LegalEntityAddressCreateRequest from .legal_entity_industry_classification import LegalEntityIndustryClassification as LegalEntityIndustryClassification diff --git a/src/modern_treasury/types/shared/child_legal_entity_create.py b/src/modern_treasury/types/shared/child_legal_entity_create.py index 3026bb26..b201f605 100644 --- a/src/modern_treasury/types/shared/child_legal_entity_create.py +++ b/src/modern_treasury/types/shared/child_legal_entity_create.py @@ -8,7 +8,6 @@ from ..._models import BaseModel from .identification_create_request import IdentificationCreateRequest -from .legal_entity_compliance_detail import LegalEntityComplianceDetail from .legal_entity_address_create_request import LegalEntityAddressCreateRequest from .legal_entity_industry_classification import LegalEntityIndustryClassification @@ -271,8 +270,6 @@ class ChildLegalEntityCreate(BaseModel): citizenship_country: Optional[str] = None """The country of citizenship for an individual.""" - compliance_details: Optional[LegalEntityComplianceDetail] = None - connection_id: Optional[str] = None """The connection ID for the connection the legal entity is associated with. diff --git a/src/modern_treasury/types/shared/legal_entity_compliance_detail.py b/src/modern_treasury/types/shared/legal_entity_compliance_detail.py deleted file mode 100644 index dc74a910..00000000 --- a/src/modern_treasury/types/shared/legal_entity_compliance_detail.py +++ /dev/null @@ -1,44 +0,0 @@ -# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. - -from typing import Optional -from datetime import datetime - -from ..._models import BaseModel - -__all__ = ["LegalEntityComplianceDetail"] - - -class LegalEntityComplianceDetail(BaseModel): - id: str - - created_at: datetime - - discarded_at: Optional[datetime] = None - - issuer: str - """The issuer of the compliance token.""" - - live_mode: bool - """ - This field will be true if this object exists in the live environment or false - if it exists in the test environment. - """ - - object: str - - token_expires_at: Optional[datetime] = None - """The timestamp when the compliance token expires.""" - - token_issued_at: Optional[datetime] = None - """The timestamp when the compliance token was issued.""" - - token_url: Optional[str] = None - """The URL to the compliance token. (ex. provider portal URL)""" - - updated_at: datetime - - validated: bool - """Whether entity corresponding to the compliance token has been validated.""" - - validated_at: Optional[datetime] = None - """The timestamp when the entity was validated.""" diff --git a/src/modern_treasury/types/shared_params/__init__.py b/src/modern_treasury/types/shared_params/__init__.py index 7b343174..871f8184 100644 --- a/src/modern_treasury/types/shared_params/__init__.py +++ b/src/modern_treasury/types/shared_params/__init__.py @@ -9,7 +9,6 @@ from .ledger_entry_create_request import LedgerEntryCreateRequest as LedgerEntryCreateRequest from .identification_create_request import IdentificationCreateRequest as IdentificationCreateRequest from .ledger_account_create_request import LedgerAccountCreateRequest as LedgerAccountCreateRequest -from .legal_entity_compliance_detail import LegalEntityComplianceDetail as LegalEntityComplianceDetail from .ledger_transaction_create_request import LedgerTransactionCreateRequest as LedgerTransactionCreateRequest from .legal_entity_address_create_request import LegalEntityAddressCreateRequest as LegalEntityAddressCreateRequest from .legal_entity_industry_classification import LegalEntityIndustryClassification as LegalEntityIndustryClassification diff --git a/src/modern_treasury/types/shared_params/child_legal_entity_create.py b/src/modern_treasury/types/shared_params/child_legal_entity_create.py index 7d0286cc..e4fd9c1f 100644 --- a/src/modern_treasury/types/shared_params/child_legal_entity_create.py +++ b/src/modern_treasury/types/shared_params/child_legal_entity_create.py @@ -9,7 +9,6 @@ from ..._types import SequenceNotStr from ..._utils import PropertyInfo from .identification_create_request import IdentificationCreateRequest -from .legal_entity_compliance_detail import LegalEntityComplianceDetail from .legal_entity_address_create_request import LegalEntityAddressCreateRequest from .legal_entity_industry_classification import LegalEntityIndustryClassification @@ -282,8 +281,6 @@ class ChildLegalEntityCreate(TypedDict, total=False): citizenship_country: Optional[str] """The country of citizenship for an individual.""" - compliance_details: Optional[LegalEntityComplianceDetail] - connection_id: Optional[str] """The connection ID for the connection the legal entity is associated with. diff --git a/src/modern_treasury/types/shared_params/legal_entity_compliance_detail.py b/src/modern_treasury/types/shared_params/legal_entity_compliance_detail.py deleted file mode 100644 index edc1d1f3..00000000 --- a/src/modern_treasury/types/shared_params/legal_entity_compliance_detail.py +++ /dev/null @@ -1,47 +0,0 @@ -# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. - -from __future__ import annotations - -from typing import Union, Optional -from datetime import datetime -from typing_extensions import Required, Annotated, TypedDict - -from ..._utils import PropertyInfo - -__all__ = ["LegalEntityComplianceDetail"] - - -class LegalEntityComplianceDetail(TypedDict, total=False): - id: Required[str] - - created_at: Required[Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]] - - discarded_at: Required[Annotated[Union[str, datetime, None], PropertyInfo(format="iso8601")]] - - issuer: Required[str] - """The issuer of the compliance token.""" - - live_mode: Required[bool] - """ - This field will be true if this object exists in the live environment or false - if it exists in the test environment. - """ - - object: Required[str] - - token_expires_at: Required[Annotated[Union[str, datetime, None], PropertyInfo(format="iso8601")]] - """The timestamp when the compliance token expires.""" - - token_issued_at: Required[Annotated[Union[str, datetime, None], PropertyInfo(format="iso8601")]] - """The timestamp when the compliance token was issued.""" - - token_url: Required[Optional[str]] - """The URL to the compliance token. (ex. provider portal URL)""" - - updated_at: Required[Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]] - - validated: Required[bool] - """Whether entity corresponding to the compliance token has been validated.""" - - validated_at: Required[Annotated[Union[str, datetime, None], PropertyInfo(format="iso8601")]] - """The timestamp when the entity was validated.""" diff --git a/tests/api_resources/test_connection_legal_entities.py b/tests/api_resources/test_connection_legal_entities.py index c95fa608..f2247c1a 100644 --- a/tests/api_resources/test_connection_legal_entities.py +++ b/tests/api_resources/test_connection_legal_entities.py @@ -59,20 +59,6 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "business_description": "business_description", "business_name": "business_name", "citizenship_country": "citizenship_country", - "compliance_details": { - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), @@ -134,20 +120,6 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "business_description": "business_description", "business_name": "business_name", "citizenship_country": "citizenship_country", - "compliance_details": { - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), @@ -481,20 +453,6 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "business_description": "business_description", "business_name": "business_name", "citizenship_country": "citizenship_country", - "compliance_details": { - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), @@ -556,20 +514,6 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "business_description": "business_description", "business_name": "business_name", "citizenship_country": "citizenship_country", - "compliance_details": { - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), diff --git a/tests/api_resources/test_counterparties.py b/tests/api_resources/test_counterparties.py index b63a685b..944e8caa 100644 --- a/tests/api_resources/test_counterparties.py +++ b/tests/api_resources/test_counterparties.py @@ -125,20 +125,6 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "business_description": "business_description", "business_name": "business_name", "citizenship_country": "citizenship_country", - "compliance_details": { - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), @@ -200,20 +186,6 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "business_description": "business_description", "business_name": "business_name", "citizenship_country": "citizenship_country", - "compliance_details": { - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), @@ -719,20 +691,6 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "business_description": "business_description", "business_name": "business_name", "citizenship_country": "citizenship_country", - "compliance_details": { - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), @@ -794,20 +752,6 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "business_description": "business_description", "business_name": "business_name", "citizenship_country": "citizenship_country", - "compliance_details": { - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), diff --git a/tests/api_resources/test_legal_entities.py b/tests/api_resources/test_legal_entities.py index a78aa232..e8c93158 100644 --- a/tests/api_resources/test_legal_entities.py +++ b/tests/api_resources/test_legal_entities.py @@ -59,20 +59,6 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: business_description="business_description", business_name="business_name", citizenship_country="citizenship_country", - compliance_details={ - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, connection_id="connection_id", country_of_incorporation="country_of_incorporation", date_formed=parse_date("2019-12-27"), @@ -134,20 +120,6 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "business_description": "business_description", "business_name": "business_name", "citizenship_country": "citizenship_country", - "compliance_details": { - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), @@ -389,20 +361,6 @@ def test_method_update_with_all_params(self, client: ModernTreasury) -> None: business_description="business_description", business_name="business_name", citizenship_country="citizenship_country", - compliance_details={ - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, country_of_incorporation="country_of_incorporation", date_formed=parse_date("2019-12-27"), date_of_birth=parse_date("2019-12-27"), @@ -599,20 +557,6 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea business_description="business_description", business_name="business_name", citizenship_country="citizenship_country", - compliance_details={ - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, connection_id="connection_id", country_of_incorporation="country_of_incorporation", date_formed=parse_date("2019-12-27"), @@ -674,20 +618,6 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "business_description": "business_description", "business_name": "business_name", "citizenship_country": "citizenship_country", - "compliance_details": { - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), @@ -936,20 +866,6 @@ async def test_method_update_with_all_params(self, async_client: AsyncModernTrea business_description="business_description", business_name="business_name", citizenship_country="citizenship_country", - compliance_details={ - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, country_of_incorporation="country_of_incorporation", date_formed=parse_date("2019-12-27"), date_of_birth=parse_date("2019-12-27"), diff --git a/tests/api_resources/test_legal_entity_associations.py b/tests/api_resources/test_legal_entity_associations.py index b54eea7b..2b9c099f 100644 --- a/tests/api_resources/test_legal_entity_associations.py +++ b/tests/api_resources/test_legal_entity_associations.py @@ -59,20 +59,6 @@ def test_method_create_with_all_params(self, client: ModernTreasury) -> None: "business_description": "business_description", "business_name": "business_name", "citizenship_country": "citizenship_country", - "compliance_details": { - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), @@ -244,20 +230,6 @@ async def test_method_create_with_all_params(self, async_client: AsyncModernTrea "business_description": "business_description", "business_name": "business_name", "citizenship_country": "citizenship_country", - "compliance_details": { - "id": "182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e", - "created_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "discarded_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "issuer": "issuer", - "live_mode": True, - "object": "object", - "token_expires_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_issued_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "token_url": "token_url", - "updated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - "validated": True, - "validated_at": parse_datetime("2019-12-27T18:11:19.117Z"), - }, "connection_id": "connection_id", "country_of_incorporation": "country_of_incorporation", "date_formed": parse_date("2019-12-27"), From ab0c565b4220c6c9236181b4e1699dfe3d542147 Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Fri, 13 Feb 2026 17:28:28 +0000 Subject: [PATCH 15/17] feat(api): api update --- .stats.yml | 4 ++-- src/modern_treasury/types/payment_order.py | 2 -- src/modern_treasury/types/payment_reference.py | 2 -- src/modern_treasury/types/return_object.py | 2 -- 4 files changed, 2 insertions(+), 8 deletions(-) diff --git a/.stats.yml b/.stats.yml index ef3682f0..abe29a7a 100644 --- a/.stats.yml +++ b/.stats.yml @@ -1,4 +1,4 @@ configured_endpoints: 168 -openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-a78ca984074c091219e7b10aefe1d72fbbd4f4297fb70b2a49bed1cb5999f27a.yml -openapi_spec_hash: c15c4f96e77008a4b2947be54c3def9a +openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-e282dfeb7416cbb65fe2a845a0d486933c710dbe4a0d3147cc3f4795ac6e27ad.yml +openapi_spec_hash: bc74fd834f3270e8791f37e81368a409 config_hash: 196d1bf0caae233683efb6abc123941f diff --git a/src/modern_treasury/types/payment_order.py b/src/modern_treasury/types/payment_order.py index 382f080e..08a719cd 100644 --- a/src/modern_treasury/types/payment_order.py +++ b/src/modern_treasury/types/payment_order.py @@ -175,8 +175,6 @@ class ReferenceNumber(BaseModel): "silvergate_payment_id", "svb_end_to_end_id", "svb_payment_id", - "svb_transaction_cleared_for_sanctions_review", - "svb_transaction_held_for_sanctions_review", "swift_mir", "swift_uetr", "umb_product_partner_account_number", diff --git a/src/modern_treasury/types/payment_reference.py b/src/modern_treasury/types/payment_reference.py index 60650a6a..7b532c9c 100644 --- a/src/modern_treasury/types/payment_reference.py +++ b/src/modern_treasury/types/payment_reference.py @@ -99,8 +99,6 @@ class PaymentReference(BaseModel): "silvergate_payment_id", "svb_end_to_end_id", "svb_payment_id", - "svb_transaction_cleared_for_sanctions_review", - "svb_transaction_held_for_sanctions_review", "swift_mir", "swift_uetr", "umb_product_partner_account_number", diff --git a/src/modern_treasury/types/return_object.py b/src/modern_treasury/types/return_object.py index 48ee14a8..325a0918 100644 --- a/src/modern_treasury/types/return_object.py +++ b/src/modern_treasury/types/return_object.py @@ -147,8 +147,6 @@ class ReferenceNumber(BaseModel): "silvergate_payment_id", "svb_end_to_end_id", "svb_payment_id", - "svb_transaction_cleared_for_sanctions_review", - "svb_transaction_held_for_sanctions_review", "swift_mir", "swift_uetr", "umb_product_partner_account_number", From 57147304a9154b8d716af32f17575db8c5d4a1c0 Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Fri, 13 Feb 2026 18:28:27 +0000 Subject: [PATCH 16/17] codegen metadata --- .stats.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.stats.yml b/.stats.yml index abe29a7a..95ee6247 100644 --- a/.stats.yml +++ b/.stats.yml @@ -1,4 +1,4 @@ configured_endpoints: 168 -openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-e282dfeb7416cbb65fe2a845a0d486933c710dbe4a0d3147cc3f4795ac6e27ad.yml -openapi_spec_hash: bc74fd834f3270e8791f37e81368a409 +openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/modern-treasury%2Fmodern-treasury-e4fb4d2325c0fbb78e23f4695b974e00d81dc4480789478dbdd0e077152cd623.yml +openapi_spec_hash: 218b6e6d70e344395adc2fc5ff4c8f66 config_hash: 196d1bf0caae233683efb6abc123941f From 57f6864ad1efdf4d98aec85adb54a4debff7fc6a Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Fri, 13 Feb 2026 18:28:53 +0000 Subject: [PATCH 17/17] release: 1.64.0 --- .release-please-manifest.json | 2 +- CHANGELOG.md | 30 ++++++++++++++++++++++++++++++ pyproject.toml | 2 +- src/modern_treasury/_version.py | 2 +- 4 files changed, 33 insertions(+), 3 deletions(-) diff --git a/.release-please-manifest.json b/.release-please-manifest.json index 7b243c59..7ef7bb77 100644 --- a/.release-please-manifest.json +++ b/.release-please-manifest.json @@ -1,3 +1,3 @@ { - ".": "1.63.0" + ".": "1.64.0" } \ No newline at end of file diff --git a/CHANGELOG.md b/CHANGELOG.md index 2ea3d7ab..a21809ec 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,35 @@ # Changelog +## 1.64.0 (2026-02-13) + +Full Changelog: [v1.63.0...v1.64.0](https://github.com/Modern-Treasury/modern-treasury-python/compare/v1.63.0...v1.64.0) + +### Features + +* **api:** api update ([ab0c565](https://github.com/Modern-Treasury/modern-treasury-python/commit/ab0c565b4220c6c9236181b4e1699dfe3d542147)) +* **api:** api update ([1894bde](https://github.com/Modern-Treasury/modern-treasury-python/commit/1894bdef23f2afc6d0e2e5b3e968838bce0c8130)) +* **api:** api update ([a36277e](https://github.com/Modern-Treasury/modern-treasury-python/commit/a36277e15343038decd3bf610f9e1ae68235a86a)) +* **api:** api update ([c92a9ce](https://github.com/Modern-Treasury/modern-treasury-python/commit/c92a9ce0dd768e53518a263241cdef81f1648a56)) +* **api:** api update ([80ff1b5](https://github.com/Modern-Treasury/modern-treasury-python/commit/80ff1b53fec639b70236541e6f5b9a8e548e5846)) +* **api:** api update ([a8c7d8d](https://github.com/Modern-Treasury/modern-treasury-python/commit/a8c7d8d62b7ab86c8cbd940b6a66905d218a2002)) +* **api:** api update ([59421e9](https://github.com/Modern-Treasury/modern-treasury-python/commit/59421e99d18c022caeeae69b34b21c3ad4d44311)) +* **client:** add custom JSON encoder for extended type support ([8e9e7dd](https://github.com/Modern-Treasury/modern-treasury-python/commit/8e9e7dd9ff628d218581f0ad3b3ab0d4521af898)) + + +### Bug Fixes + +* **docs:** fix mcp installation instructions for remote servers ([81262fe](https://github.com/Modern-Treasury/modern-treasury-python/commit/81262fe918cf0613b744fc25e49be04e34d578cc)) + + +### Chores + +* **ci:** upgrade `actions/github-script` ([b019b1f](https://github.com/Modern-Treasury/modern-treasury-python/commit/b019b1f45f89acebdfb3cd77e9485403c2671f8f)) +* format all `api.md` files ([586eba0](https://github.com/Modern-Treasury/modern-treasury-python/commit/586eba00e21d0ff37997d7ef257a23a042f42a21)) +* **internal:** bump dependencies ([f21a8b1](https://github.com/Modern-Treasury/modern-treasury-python/commit/f21a8b106ca2bd401fc9d5782574d11d700e6e4c)) +* **internal:** codegen related update ([4471585](https://github.com/Modern-Treasury/modern-treasury-python/commit/447158528a5c121ed3040901e6cb7b1117210b46)) +* **internal:** fix lint error on Python 3.14 ([f2a9d02](https://github.com/Modern-Treasury/modern-treasury-python/commit/f2a9d02bab75a30b9c614fe7c7369466ce2839d0)) +* **internal:** update `actions/checkout` version ([7e8aa74](https://github.com/Modern-Treasury/modern-treasury-python/commit/7e8aa742c35f82615786e9f3d70597b08dc9ca1d)) + ## 1.63.0 (2026-01-13) Full Changelog: [v1.62.0...v1.63.0](https://github.com/Modern-Treasury/modern-treasury-python/compare/v1.62.0...v1.63.0) diff --git a/pyproject.toml b/pyproject.toml index 8bcf65d3..a662419c 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [project] name = "modern-treasury" -version = "1.63.0" +version = "1.64.0" description = "The official Python library for the Modern Treasury API" dynamic = ["readme"] license = "MIT" diff --git a/src/modern_treasury/_version.py b/src/modern_treasury/_version.py index 729c45eb..43e8064c 100644 --- a/src/modern_treasury/_version.py +++ b/src/modern_treasury/_version.py @@ -1,4 +1,4 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. __title__ = "modern_treasury" -__version__ = "1.63.0" # x-release-please-version +__version__ = "1.64.0" # x-release-please-version