Perl 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

Perl Example

use chilkat();

$rest = chilkat::CkRest->new();

#  URL: https://api.stripe.com/v1/tokens
$bTls = 1;
$port = 443;
$bAutoReconnect = 1;
$success = $rest->Connect("api.stripe.com",$port,$bTls,$bAutoReconnect);
if ($success != 1) {
    print "ConnectFailReason: " . $rest->get_ConnectFailReason() . "\r\n";
    print $rest->lastErrorText() . "\r\n";
    exit;
}

$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");

$strResponseBody = $rest->fullRequestFormUrlEncoded("POST","/v1/tokens");
if ($rest->get_LastMethodSuccess() != 1) {
    print $rest->lastErrorText() . "\r\n";
    exit;
}

$jsonResponse = chilkat::CkJsonObject->new();
$jsonResponse->Load($strResponseBody);

$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
}