Skip to main content
POST
/
wallets
/
{wallet_id}
/
smart_contracts
/
delegates
import cobo_waas2
from cobo_waas2.models.cobo_safe_delegate import CoboSafeDelegate
from cobo_waas2.models.safe_wallet_delegates import SafeWalletDelegates
from cobo_waas2.rest import ApiException
from pprint import pprint

# See configuration.py for a list of all supported configurations.
configuration = cobo_waas2.Configuration(
    # Replace `<YOUR_PRIVATE_KEY>` with your private key
    api_private_key="<YOUR_PRIVATE_KEY>",
    # Select the development environment. To use the production environment, change the URL to https://api.cobo.com/v2.
    host="https://api.dev.cobo.com/v2",
)
# Enter a context with an instance of the API client
with cobo_waas2.ApiClient(configuration) as api_client:
    # Create an instance of the API class
    api_instance = cobo_waas2.WalletsSmartContractWalletsApi(api_client)
    wallet_id = "f47ac10b-58cc-4372-a567-0e02b2c3d479"
    safe_wallet_delegates = cobo_waas2.SafeWalletDelegates(
        cobo_waas2.SafeWalletDelegatesContractCall(request_type="Transfer")
    )

    try:
        # List Delegates
        api_response = api_instance.list_safe_wallet_delegates(
            wallet_id, safe_wallet_delegates=safe_wallet_delegates
        )
        print(
            "The response of WalletsSmartContractWalletsApi->list_safe_wallet_delegates:\n"
        )
        pprint(api_response)
    except Exception as e:
        print(
            "Exception when calling WalletsSmartContractWalletsApi->list_safe_wallet_delegates: %s\n"
            % e
        )

[
  {
    "delegate_type": "Org-Controlled",
    "wallet_id": "123e4567-e89b-12d3-a456-426614174000",
    "address": "0x1234567890123456789012345678901234567890"
  }
]
import cobo_waas2
from cobo_waas2.models.cobo_safe_delegate import CoboSafeDelegate
from cobo_waas2.models.safe_wallet_delegates import SafeWalletDelegates
from cobo_waas2.rest import ApiException
from pprint import pprint

# See configuration.py for a list of all supported configurations.
configuration = cobo_waas2.Configuration(
    # Replace `<YOUR_PRIVATE_KEY>` with your private key
    api_private_key="<YOUR_PRIVATE_KEY>",
    # Select the development environment. To use the production environment, change the URL to https://api.cobo.com/v2.
    host="https://api.dev.cobo.com/v2",
)
# Enter a context with an instance of the API client
with cobo_waas2.ApiClient(configuration) as api_client:
    # Create an instance of the API class
    api_instance = cobo_waas2.WalletsSmartContractWalletsApi(api_client)
    wallet_id = "f47ac10b-58cc-4372-a567-0e02b2c3d479"
    safe_wallet_delegates = cobo_waas2.SafeWalletDelegates(
        cobo_waas2.SafeWalletDelegatesContractCall(request_type="Transfer")
    )

    try:
        # List Delegates
        api_response = api_instance.list_safe_wallet_delegates(
            wallet_id, safe_wallet_delegates=safe_wallet_delegates
        )
        print(
            "The response of WalletsSmartContractWalletsApi->list_safe_wallet_delegates:\n"
        )
        pprint(api_response)
    except Exception as e:
        print(
            "Exception when calling WalletsSmartContractWalletsApi->list_safe_wallet_delegates: %s\n"
            % e
        )

Authorizations

BIZ-API-KEY
string
header
required

The API key. For more details, refer to API key.

In the API playground, enter your API secret, and your API key will be accordingly calculated.

Path Parameters

wallet_id
string<uuid>
required

The wallet ID.

Body

application/json

The request body to query the Delegates of a Safe{Wallet}.

  • Contract Call by Delegates
  • Transfer by Delegates
request_type
enum<string>
required

The request type. Possible values include:

  • Transfer: A request to transfer tokens.
  • ContractCall: A request to interact with a smart contract.
Available options:
Transfer,
ContractCall
Example:

"Transfer"

address
string

The destination address.

Example:

"0x0406db8351aa6839169bb363f63c2c808fee8f99"

value
string

The transfer amount. For example, if you trade 1.5 ETH, then the value is 1.5.

Example:

"1.5"

calldata
string

The data used to invoke a specific function or method within the specified contract at the destination address, with a maximum length of 65,000 characters.

Example:

"0xa22cb4650000000000000000000000001e0049783f008a0085193e00003d00cd54003c71000000000000000000000000000000000000000000000000000000000000DEMO"

Response

Delegates successfully retrieved.

delegate_type
enum<string>
default:Org-Controlled
required

The wallet subtype of the Delegate. Possible values include:

  • Org-Controlled: MPC Wallets (Organization-Controlled Wallets).
  • User-Controlled: MPC Wallets (User-Controlled Wallets).
Available options:
Org-Controlled,
User-Controlled
Example:

"Org-Controlled"

wallet_id
string<uuid>
required

The wallet ID of the Delegate. This is required when initiating a transfer or contract call from Smart Contract Wallets (Safe{Wallet}).

Example:

"123e4567-e89b-12d3-a456-426614174000"

address
string
required

The wallet address of the Delegate. This is required when initiating a transfer or contract call from Smart Contract Wallets (Safe{Wallet}).

Example:

"0x1234567890123456789012345678901234567890"