Tcl 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

Tcl Example


load ./chilkat.dll

set rest [new_CkRest]

#  URL: https://api.stripe.com/v1/tokens
set bTls 1
set port 443
set bAutoReconnect 1
set success [CkRest_Connect $rest "api.stripe.com" $port $bTls $bAutoReconnect]
if {[expr $success != 1]} then {
    puts "ConnectFailReason: [CkRest_ConnectFailReason $rest]"
    puts [CkRest_lastErrorText $rest]
    delete_CkRest $rest
    exit
}

CkRest_SetAuthBasic $rest "STRIPE_SECRET_KEY" ""

CkRest_AddQueryParam $rest "bank_account[country]" "US"
CkRest_AddQueryParam $rest "bank_account[currency]" "usd"
CkRest_AddQueryParam $rest "bank_account[account_holder_name]" "Chloe White"
CkRest_AddQueryParam $rest "bank_account[account_holder_type]" "individual"
CkRest_AddQueryParam $rest "bank_account[routing_number]" "110000000"
CkRest_AddQueryParam $rest "bank_account[account_number]" "000123456789"

set strResponseBody [CkRest_fullRequestFormUrlEncoded $rest "POST" "/v1/tokens"]
if {[expr [CkRest_LastMethodSuccess $rest] != 1]} then {
    puts [CkRest_lastErrorText $rest]
    delete_CkRest $rest
    exit
}

set jsonResponse [new_CkJsonObject]

CkJsonObject_Load $jsonResponse $strResponseBody

set id [CkJsonObject_stringOf $jsonResponse "id"]
set object [CkJsonObject_stringOf $jsonResponse "object"]
set bank_accountId [CkJsonObject_stringOf $jsonResponse "bank_account.id"]
set bank_accountObject [CkJsonObject_stringOf $jsonResponse "bank_account.object"]
set bank_accountAccount_holder_name [CkJsonObject_stringOf $jsonResponse "bank_account.account_holder_name"]
set bank_accountAccount_holder_type [CkJsonObject_stringOf $jsonResponse "bank_account.account_holder_type"]
set bank_accountBank_name [CkJsonObject_stringOf $jsonResponse "bank_account.bank_name"]
set bank_accountCountry [CkJsonObject_stringOf $jsonResponse "bank_account.country"]
set bank_accountCurrency [CkJsonObject_stringOf $jsonResponse "bank_account.currency"]
set bank_accountFingerprint [CkJsonObject_stringOf $jsonResponse "bank_account.fingerprint"]
set bank_accountLast4 [CkJsonObject_stringOf $jsonResponse "bank_account.last4"]
set bank_accountRouting_number [CkJsonObject_stringOf $jsonResponse "bank_account.routing_number"]
set bank_accountStatus [CkJsonObject_stringOf $jsonResponse "bank_account.status"]
set client_ip [CkJsonObject_IsNullOf $jsonResponse "client_ip"]
set created [CkJsonObject_IntOf $jsonResponse "created"]
set livemode [CkJsonObject_BoolOf $jsonResponse "livemode"]
set type [CkJsonObject_stringOf $jsonResponse "type"]
set used [CkJsonObject_BoolOf $jsonResponse "used"]

delete_CkRest $rest
delete_CkJsonObject $jsonResponse

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
}