C# UWP/WinRT Stripe: Create a Bank Account Token

Back to Index

Creates a single use token that wraps the details of a bank account. This token can be used in place of a bank account dictionary with any API method.

Documentation: https://stripe.com/docs/api/curl#create_bank_account_token

CURL Command

curl https://api.stripe.com/v1/tokens \
   -u STRIPE_SECRET_KEY: \
   -d bank_account[country]=US \
   -d bank_account[currency]=usd \
   -d bank_account[account_holder_name]="Chloe White" \
   -d bank_account[account_holder_type]=individual \
   -d bank_account[routing_number]=110000000 \
   -d bank_account[account_number]=000123456789 \
   -X POST

C# UWP/WinRT Example

Chilkat.Rest rest = new Chilkat.Rest();
bool success;

//  URL: https://api.stripe.com/v1/tokens
bool bTls = true;
int port = 443;
bool bAutoReconnect = true;
success = await rest.ConnectAsync("api.stripe.com",port,bTls,bAutoReconnect);
if (success != true) {
    Debug.WriteLine("ConnectFailReason: " + Convert.ToString(rest.ConnectFailReason));
    Debug.WriteLine(rest.LastErrorText);
    return;
}

rest.SetAuthBasic("STRIPE_SECRET_KEY","");

rest.AddQueryParam("bank_account[country]","US");
rest.AddQueryParam("bank_account[currency]","usd");
rest.AddQueryParam("bank_account[account_holder_name]","Chloe White");
rest.AddQueryParam("bank_account[account_holder_type]","individual");
rest.AddQueryParam("bank_account[routing_number]","110000000");
rest.AddQueryParam("bank_account[account_number]","000123456789");

string strResponseBody = await rest.FullRequestFormUrlEncodedAsync("POST","/v1/tokens");
if (rest.LastMethodSuccess != true) {
    Debug.WriteLine(rest.LastErrorText);
    return;
}

Chilkat.JsonObject jsonResponse = new Chilkat.JsonObject();
jsonResponse.Load(strResponseBody);

string id;
string object;
string bank_accountId;
string bank_accountObject;
string bank_accountAccount_holder_name;
string bank_accountAccount_holder_type;
string bank_accountBank_name;
string bank_accountCountry;
string bank_accountCurrency;
string bank_accountFingerprint;
string bank_accountLast4;
string bank_accountRouting_number;
string bank_accountStatus;
bool client_ip;
int created;
bool livemode;
string type;
bool used;

id = jsonResponse.StringOf("id");
object = jsonResponse.StringOf("object");
bank_accountId = jsonResponse.StringOf("bank_account.id");
bank_accountObject = jsonResponse.StringOf("bank_account.object");
bank_accountAccount_holder_name = jsonResponse.StringOf("bank_account.account_holder_name");
bank_accountAccount_holder_type = jsonResponse.StringOf("bank_account.account_holder_type");
bank_accountBank_name = jsonResponse.StringOf("bank_account.bank_name");
bank_accountCountry = jsonResponse.StringOf("bank_account.country");
bank_accountCurrency = jsonResponse.StringOf("bank_account.currency");
bank_accountFingerprint = jsonResponse.StringOf("bank_account.fingerprint");
bank_accountLast4 = jsonResponse.StringOf("bank_account.last4");
bank_accountRouting_number = jsonResponse.StringOf("bank_account.routing_number");
bank_accountStatus = jsonResponse.StringOf("bank_account.status");
client_ip = jsonResponse.IsNullOf("client_ip");
created = jsonResponse.IntOf("created");
livemode = jsonResponse.BoolOf("livemode");
type = jsonResponse.StringOf("type");
used = jsonResponse.BoolOf("used");

Sample JSON Response Body

{
  "id": "btok_1BnETKGswQrCoh0X86abg4gM",
  "object": "token",
  "bank_account": {
    "id": "ba_1BnETKGswQrCoh0XptCSwzal",
    "object": "bank_account",
    "account_holder_name": "Jane Austen",
    "account_holder_type": "individual",
    "bank_name": "STRIPE TEST BANK",
    "country": "US",
    "currency": "usd",
    "fingerprint": "L2j4aSuWk1MZMDZ5",
    "last4": "6789",
    "routing_number": "110000000",
    "status": "new"
  },
  "client_ip": null,
  "created": 1516662782,
  "livemode": false,
  "type": "bank_account",
  "used": false
}