Delphi ActiveX Stripe: List all Customers

Back to Index

Returns a list of your customers. The customers are returned sorted by creation date, with the most recent customers appearing first.

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

CURL Command

curl https://api.stripe.com/v1/customers?limit=3 \
   -u STRIPE_SECRET_KEY: \
   -G

Delphi ActiveX Example

var
rest: TChilkatRest;
success: Integer;
bTls: Integer;
port: Integer;
bAutoReconnect: Integer;
sbResponseBody: TChilkatStringBuilder;
jsonResponse: TChilkatJsonObject;
object: WideString;
url: WideString;
has_more: Integer;
i: Integer;
count_i: Integer;
id: WideString;
account_balance: Integer;
created: Integer;
currency: WideString;
default_source: Integer;
delinquent: Integer;
description: Integer;
discount: Integer;
email: Integer;
livemode: Integer;
shipping: Integer;
sourcesObject: WideString;
sourcesHas_more: Integer;
sourcesTotal_count: Integer;
sourcesUrl: WideString;
subscriptionsObject: WideString;
subscriptionsHas_more: Integer;
subscriptionsTotal_count: Integer;
subscriptionsUrl: WideString;
j: Integer;
count_j: Integer;

begin
rest := TChilkatRest.Create(Self);

//  URL: https://api.stripe.com/v1/customers?limit=3
bTls := 1;
port := 443;
bAutoReconnect := 1;
success := rest.Connect('api.stripe.com',port,bTls,bAutoReconnect);
if (success <> 1) then
  begin
    Memo1.Lines.Add('ConnectFailReason: ' + IntToStr(rest.ConnectFailReason));
    Memo1.Lines.Add(rest.LastErrorText);
    Exit;
  end;

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

sbResponseBody := TChilkatStringBuilder.Create(Self);
success := rest.FullRequestNoBodySb('GET','/v1/customers?limit=3',sbResponseBody.ControlInterface);
if (success <> 1) then
  begin
    Memo1.Lines.Add(rest.LastErrorText);
    Exit;
  end;

jsonResponse := TChilkatJsonObject.Create(Self);
jsonResponse.LoadSb(sbResponseBody.ControlInterface);

object := jsonResponse.StringOf('object');
url := jsonResponse.StringOf('url');
has_more := jsonResponse.BoolOf('has_more');
i := 0;
count_i := jsonResponse.SizeOfArray('data');
while i < count_i do
  begin
    jsonResponse.I := i;
    id := jsonResponse.StringOf('data[i].id');
    object := jsonResponse.StringOf('data[i].object');
    account_balance := jsonResponse.IntOf('data[i].account_balance');
    created := jsonResponse.IntOf('data[i].created');
    currency := jsonResponse.StringOf('data[i].currency');
    default_source := jsonResponse.IsNullOf('data[i].default_source');
    delinquent := jsonResponse.BoolOf('data[i].delinquent');
    description := jsonResponse.IsNullOf('data[i].description');
    discount := jsonResponse.IsNullOf('data[i].discount');
    email := jsonResponse.IsNullOf('data[i].email');
    livemode := jsonResponse.BoolOf('data[i].livemode');
    shipping := jsonResponse.IsNullOf('data[i].shipping');
    sourcesObject := jsonResponse.StringOf('data[i].sources.object');
    sourcesHas_more := jsonResponse.BoolOf('data[i].sources.has_more');
    sourcesTotal_count := jsonResponse.IntOf('data[i].sources.total_count');
    sourcesUrl := jsonResponse.StringOf('data[i].sources.url');
    subscriptionsObject := jsonResponse.StringOf('data[i].subscriptions.object');
    subscriptionsHas_more := jsonResponse.BoolOf('data[i].subscriptions.has_more');
    subscriptionsTotal_count := jsonResponse.IntOf('data[i].subscriptions.total_count');
    subscriptionsUrl := jsonResponse.StringOf('data[i].subscriptions.url');
    j := 0;
    count_j := jsonResponse.SizeOfArray('data[i].sources.data');
    while j < count_j do
      begin
        jsonResponse.J := j;
        j := j + 1;
      end;

    j := 0;
    count_j := jsonResponse.SizeOfArray('data[i].subscriptions.data');
    while j < count_j do
      begin
        jsonResponse.J := j;
        j := j + 1;
      end;

    i := i + 1;
  end;

Sample JSON Response Body

{
  "object": "list",
  "url": "/v1/customers",
  "has_more": false,
  "data": [
    {
      "id": "cus_CBbgVLJqv487Oq",
      "object": "customer",
      "account_balance": 0,
      "created": 1516662781,
      "currency": "usd",
      "default_source": null,
      "delinquent": false,
      "description": null,
      "discount": null,
      "email": null,
      "livemode": false,
      "metadata": {},
      "shipping": null,
      "sources": {
        "object": "list",
        "data": [
        ],
        "has_more": false,
        "total_count": 0,
        "url": "/v1/customers/cus_CBbgVLJqv487Oq/sources"
      },
      "subscriptions": {
        "object": "list",
        "data": [
        ],
        "has_more": false,
        "total_count": 0,
        "url": "/v1/customers/cus_CBbgVLJqv487Oq/subscriptions"
      }
    }
  ]
}