Step 1: Create a user account
To use Streambird’s APIs, you need to create a user account first. You can use the following curl command to create a user:cURL
$API_KEY with your Streambird secret API key for backend. This will create a user with the provided details.
Step 2: Create a wallet for user
Now that you have created a user account, the next step is to create a wallet for the user. You can use the following curl command to create a wallet:cURL
$API_KEY with your Streambird access token and user_2Cu2uVhYy0OVgRcO913OsqIVaPI with the user ID you created in Step 1. This will create a new wallet for the user with the specified token symbol and name.
Step 3: Fund the wallet
To enable users to make transactions, their wallets need to have sufficient funds. For testing, you can go to an Ethereum faucet and request testnet Ethereum. The testnet Ethereum is not real Ethereum, but it behaves in the same way and is ideal for testing purposes. If you’re developing a live application, you’ll need to integrate an on-ramp such as MoonPay to enable users to purchase cryptocurrency with fiat currencies and fund their wallets. MoonPay allows users to buy a variety of cryptocurrencies using fiat currency and supports multiple payment methods including credit cards, Apple Pay, and bank transfers. Once your users have funded their wallets, they’ll be able to make transactions using the cryptocurrency in their wallets. In the next section, we’ll walk you through how to implement the transfer functionality so that users can send and receive payments using Streambird’s APIs.Step 4: Make transfers between wallets
To create a transfer, you need to use thePOST /v1/transfers/create API endpoint. This endpoint allows you to specify the source wallet, the destination wallet, the amount to transfer, and other details such as notes and whether the transfer amount includes fees.
Here’s an example cURL request to create a transfer:
cURL
unconfirmed Transfer object that contains the source_amount, dest_amount, and total_fees. The dest_amount is the total amount that the recipient will receive after fees have been deducted.
Step 5: Confirm the transfer
To confirm the transfer and actually process the payment, you need to use thePOST /v1/transfers/{transfer_id}/confirm API endpoint. You’ll need to replace {transfer_id} with the ID of the transfer that you created in the previous step.
Here’s an example cURL request to confirm a transfer:
cURL
pending from unconfirmed. The funds will be transferred from the source wallet to the destination wallet.
Note that the user_id parameter is optional, but can be used to trigger a platform validation to ensure that the source wallet is owned by the specified user, which can help prevent usage errors. Once the transfer is confirmed, the specified amount will be moved from the source wallet to the destination wallet.
It’s important to note that before testing, the wallets must be funded with the appropriate amount of tokens. For testing purposes, you can go to an Ethereum faucet to get free testnet ETH, or if it’s a live app, you can use an on-ramp such as MoonPay to fund the wallets.

