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.
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
IncludeFile "CkRest.pb"
IncludeFile "CkJsonObject.pb"
Procedure ChilkatExample()
rest.i = CkRest::ckCreate()
If rest.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
success.i
; URL: https://api.stripe.com/v1/tokens
bTls.i = 1
port.i = 443
bAutoReconnect.i = 1
success = CkRest::ckConnect(rest,"api.stripe.com",port,bTls,bAutoReconnect)
If success <> 1
Debug "ConnectFailReason: " + Str(CkRest::ckConnectFailReason(rest))
Debug CkRest::ckLastErrorText(rest)
CkRest::ckDispose(rest)
ProcedureReturn
EndIf
CkRest::ckSetAuthBasic(rest,"STRIPE_SECRET_KEY","")
CkRest::ckAddQueryParam(rest,"bank_account[country]","US")
CkRest::ckAddQueryParam(rest,"bank_account[currency]","usd")
CkRest::ckAddQueryParam(rest,"bank_account[account_holder_name]","Chloe White")
CkRest::ckAddQueryParam(rest,"bank_account[account_holder_type]","individual")
CkRest::ckAddQueryParam(rest,"bank_account[routing_number]","110000000")
CkRest::ckAddQueryParam(rest,"bank_account[account_number]","000123456789")
strResponseBody.s = CkRest::ckFullRequestFormUrlEncoded(rest,"POST","/v1/tokens")
If CkRest::ckLastMethodSuccess(rest) <> 1
Debug CkRest::ckLastErrorText(rest)
CkRest::ckDispose(rest)
ProcedureReturn
EndIf
jsonResponse.i = CkJsonObject::ckCreate()
If jsonResponse.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
CkJsonObject::ckLoad(jsonResponse,strResponseBody)
id.s
object.s
bank_accountId.s
bank_accountObject.s
bank_accountAccount_holder_name.s
bank_accountAccount_holder_type.s
bank_accountBank_name.s
bank_accountCountry.s
bank_accountCurrency.s
bank_accountFingerprint.s
bank_accountLast4.s
bank_accountRouting_number.s
bank_accountStatus.s
client_ip.i
created.i
livemode.i
type.s
used.i
id = CkJsonObject::ckStringOf(jsonResponse,"id")
object = CkJsonObject::ckStringOf(jsonResponse,"object")
bank_accountId = CkJsonObject::ckStringOf(jsonResponse,"bank_account.id")
bank_accountObject = CkJsonObject::ckStringOf(jsonResponse,"bank_account.object")
bank_accountAccount_holder_name = CkJsonObject::ckStringOf(jsonResponse,"bank_account.account_holder_name")
bank_accountAccount_holder_type = CkJsonObject::ckStringOf(jsonResponse,"bank_account.account_holder_type")
bank_accountBank_name = CkJsonObject::ckStringOf(jsonResponse,"bank_account.bank_name")
bank_accountCountry = CkJsonObject::ckStringOf(jsonResponse,"bank_account.country")
bank_accountCurrency = CkJsonObject::ckStringOf(jsonResponse,"bank_account.currency")
bank_accountFingerprint = CkJsonObject::ckStringOf(jsonResponse,"bank_account.fingerprint")
bank_accountLast4 = CkJsonObject::ckStringOf(jsonResponse,"bank_account.last4")
bank_accountRouting_number = CkJsonObject::ckStringOf(jsonResponse,"bank_account.routing_number")
bank_accountStatus = CkJsonObject::ckStringOf(jsonResponse,"bank_account.status")
client_ip = CkJsonObject::ckIsNullOf(jsonResponse,"client_ip")
created = CkJsonObject::ckIntOf(jsonResponse,"created")
livemode = CkJsonObject::ckBoolOf(jsonResponse,"livemode")
type = CkJsonObject::ckStringOf(jsonResponse,"type")
used = CkJsonObject::ckBoolOf(jsonResponse,"used")
CkRest::ckDispose(rest)
CkJsonObject::ckDispose(jsonResponse)
ProcedureReturn
EndProcedure
{
"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
}