Tcl Stripe: Attach a Source

Back to Index

Attaches a Source object to a Customer. The source must be in a chargeable state.

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

CURL Command

curl https://api.stripe.com/v1/customers/cus_CBbg9PmQ9sLbmo/sources \
   -u STRIPE_SECRET_KEY: \
   -d source=src_1BnETLGswQrCoh0X5KOorXEP \
   -X POST

Tcl Example


load ./chilkat.dll

set rest [new_CkRest]

#  URL: https://api.stripe.com/v1/customers/cus_CBbg9PmQ9sLbmo/sources
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 "source" "src_1BnETLGswQrCoh0X5KOorXEP"

set strResponseBody [CkRest_fullRequestFormUrlEncoded $rest "POST" "/v1/customers/cus_CBbg9PmQ9sLbmo/sources"]
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 amount [CkJsonObject_IntOf $jsonResponse "amount"]
set client_secret [CkJsonObject_stringOf $jsonResponse "client_secret"]
set created [CkJsonObject_IntOf $jsonResponse "created"]
set currency [CkJsonObject_stringOf $jsonResponse "currency"]
set flow [CkJsonObject_stringOf $jsonResponse "flow"]
set livemode [CkJsonObject_BoolOf $jsonResponse "livemode"]
set ownerAddress [CkJsonObject_IsNullOf $jsonResponse "owner.address"]
set ownerEmail [CkJsonObject_stringOf $jsonResponse "owner.email"]
set ownerName [CkJsonObject_IsNullOf $jsonResponse "owner.name"]
set ownerPhone [CkJsonObject_IsNullOf $jsonResponse "owner.phone"]
set ownerVerified_address [CkJsonObject_IsNullOf $jsonResponse "owner.verified_address"]
set ownerVerified_email [CkJsonObject_IsNullOf $jsonResponse "owner.verified_email"]
set ownerVerified_name [CkJsonObject_IsNullOf $jsonResponse "owner.verified_name"]
set ownerVerified_phone [CkJsonObject_IsNullOf $jsonResponse "owner.verified_phone"]
set receiverAddress [CkJsonObject_stringOf $jsonResponse "receiver.address"]
set receiverAmount_charged [CkJsonObject_IntOf $jsonResponse "receiver.amount_charged"]
set receiverAmount_received [CkJsonObject_IntOf $jsonResponse "receiver.amount_received"]
set receiverAmount_returned [CkJsonObject_IntOf $jsonResponse "receiver.amount_returned"]
set receiverRefund_attributes_method [CkJsonObject_stringOf $jsonResponse "receiver.refund_attributes_method"]
set receiverRefund_attributes_status [CkJsonObject_stringOf $jsonResponse "receiver.refund_attributes_status"]
set statement_descriptor [CkJsonObject_IsNullOf $jsonResponse "statement_descriptor"]
set status [CkJsonObject_stringOf $jsonResponse "status"]
set type [CkJsonObject_stringOf $jsonResponse "type"]
set usage [CkJsonObject_stringOf $jsonResponse "usage"]
set bitcoinAddress [CkJsonObject_stringOf $jsonResponse "bitcoin.address"]
set bitcoinAmount [CkJsonObject_IntOf $jsonResponse "bitcoin.amount"]
set bitcoinAmount_charged [CkJsonObject_IntOf $jsonResponse "bitcoin.amount_charged"]
set bitcoinAmount_received [CkJsonObject_IntOf $jsonResponse "bitcoin.amount_received"]
set bitcoinAmount_returned [CkJsonObject_IntOf $jsonResponse "bitcoin.amount_returned"]
set bitcoinUri [CkJsonObject_stringOf $jsonResponse "bitcoin.uri"]
set customer [CkJsonObject_stringOf $jsonResponse "customer"]

delete_CkRest $rest
delete_CkJsonObject $jsonResponse

Sample JSON Response Body

{
  "id": "src_1BnETLGswQrCoh0X5KOorXEP",
  "object": "source",
  "amount": 1000,
  "client_secret": "src_client_secret_CBbgdvc1AflN5jN0wQevA2jA",
  "created": 1516662783,
  "currency": "usd",
  "flow": "receiver",
  "livemode": false,
  "metadata": {},
  "owner": {
    "address": null,
    "email": "jenny.rosen@example.com",
    "name": null,
    "phone": null,
    "verified_address": null,
    "verified_email": null,
    "verified_name": null,
    "verified_phone": null
  },
  "receiver": {
    "address": "test_1MBhWS3uv4ynCfQXF3xQjJkzFPukr4K56N",
    "amount_charged": 0,
    "amount_received": 0,
    "amount_returned": 0,
    "refund_attributes_method": "email",
    "refund_attributes_status": "missing"
  },
  "statement_descriptor": null,
  "status": "chargeable",
  "type": "bitcoin",
  "usage": "single_use",
  "bitcoin": {
    "address": "test_1MBhWS3uv4ynCfQXF3xQjJkzFPukr4K56N",
    "amount": 2371000,
    "amount_charged": 0,
    "amount_received": 0,
    "amount_returned": 0,
    "uri": "bitcoin:test_1MBhWS3uv4ynCfQXF3xQjJkzFPukr4K56N?amount=0.02371000"
  },
  "customer": "cus_CBbg9PmQ9sLbmo"
}