Sample code for 30+ languages & platforms
Visual FoxPro

ETrade v1 List Transactions

See more HTTP Misc Examples

Get information about the transactions in an ETrade brokerage account.

Chilkat Visual FoxPro Downloads

Visual FoxPro
LOCAL lnSuccess
LOCAL loHttp
LOCAL loJson
LOCAL lcRespStr
LOCAL lnStatusCode
LOCAL loXml
LOCAL i
LOCAL lnCount_i
LOCAL lcTagPath
LOCAL lcTransactionId
LOCAL lnAccountId
LOCAL lcTransactionDate
LOCAL lcPostDate
LOCAL lnAmount
LOCAL lcDescription
LOCAL lnDescription2
LOCAL lcTransactionType
LOCAL lcImageFlag
LOCAL lcInstType
LOCAL lnQuantity
LOCAL lnPrice
LOCAL lcSettlementCurrency
LOCAL lcPaymentCurrency
LOCAL lnFee
LOCAL lcSettlementDate
LOCAL lcDetailsURI
LOCAL lcPageMarkers
LOCAL lcMoreTransactions
LOCAL lnTransactionCount
LOCAL lnTotalCount

lnSuccess = 0

* This example requires the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.

loHttp = CreateObject('Chilkat.Http')

loHttp.OAuth1 = 1
loHttp.OAuthVerifier = ""
loHttp.OAuthConsumerKey = "ETRADE_CONSUMER_KEY"
loHttp.OAuthConsumerSecret = "ETRADE_CONSUMER_SECRET"

* Load the access token previously obtained via the OAuth1 3-Legged Authorization examples Step1 and Step2.
loJson = CreateObject('Chilkat.JsonObject')
lnSuccess = loJson.LoadFile("qa_data/tokens/etrade.json")
IF (lnSuccess <> 1) THEN
    ? "Failed to load OAuth1 token"
    RELEASE loHttp
    RELEASE loJson
    CANCEL
ENDIF

loHttp.OAuthToken = loJson.StringOf("oauth_token")
loHttp.OAuthTokenSecret = loJson.StringOf("oauth_token_secret")

* See the ETrade v1 API documentation HERE.

loHttp.SetUrlVar("accountIdKey","vsnhtF7d9jXxBy6HyaAC4vQ")
lcRespStr = loHttp.QuickGetStr("https://apisb.etrade.com/v1/accounts/{$accountIdKey}/transactions")
IF (loHttp.LastMethodSuccess <> 1) THEN
    ? loHttp.LastErrorText
    RELEASE loHttp
    RELEASE loJson
    CANCEL
ENDIF

* A 200 status code indicates success.
lnStatusCode = loHttp.LastStatus
? "statusCode = " + STR(lnStatusCode)

* Use the following online tool to generate parsing code from sample XML: 
* Generate Parsing Code from XML

* A sample XML response is shown below...

loXml = CreateObject('Chilkat.Xml')
loXml.LoadXml(lcRespStr)

i = 0
lnCount_i = loXml.NumChildrenHavingTag("Transaction")
DO WHILE i < lnCount_i
    loXml.I = i
    lcTransactionId = loXml.GetChildContent("Transaction[i]|transactionId")
    lnAccountId = loXml.GetChildIntValue("Transaction[i]|accountId")
    lcTransactionDate = loXml.GetChildContent("Transaction[i]|transactionDate")
    lcPostDate = loXml.GetChildContent("Transaction[i]|postDate")
    lnAmount = loXml.GetChildIntValue("Transaction[i]|amount")
    lcDescription = loXml.GetChildContent("Transaction[i]|description")
    lnDescription2 = loXml.GetChildIntValue("Transaction[i]|description2")
    lcTransactionType = loXml.GetChildContent("Transaction[i]|transactionType")
    lcImageFlag = loXml.GetChildContent("Transaction[i]|imageFlag")
    lcInstType = loXml.GetChildContent("Transaction[i]|instType")
    lnQuantity = loXml.GetChildIntValue("Transaction[i]|brokerage|quantity")
    lnPrice = loXml.GetChildIntValue("Transaction[i]|brokerage|price")
    lcSettlementCurrency = loXml.GetChildContent("Transaction[i]|brokerage|settlementCurrency")
    lcPaymentCurrency = loXml.GetChildContent("Transaction[i]|brokerage|paymentCurrency")
    lnFee = loXml.GetChildIntValue("Transaction[i]|brokerage|fee")
    lcSettlementDate = loXml.GetChildContent("Transaction[i]|brokerage|settlementDate")
    lcDetailsURI = loXml.GetChildContent("Transaction[i]|detailsURI")
    i = i + 1
ENDDO
lcPageMarkers = loXml.GetChildContent("pageMarkers")
lcMoreTransactions = loXml.GetChildContent("moreTransactions")
lnTransactionCount = loXml.GetChildIntValue("transactionCount")
lnTotalCount = loXml.GetChildIntValue("totalCount")

* <?xml version="1.0" encoding="UTF-8"?>
* <TransactionListResponse>
*    <Transaction>
*       <transactionId>18165100001766</transactionId>
*       <accountId>83564979</accountId>
*       <transactionDate>1528948800000</transactionDate>
*       <postDate>1528948800000</postDate>
*       <amount>-2</amount>
*       <description>ACH WITHDRAWL REFID:109187276;</description>
*       <description2>109187276</description2>
*       <transactionType>Transfer</transactionType>
*       <memo />
*       <imageFlag>false</imageFlag>
*       <instType>BROKERAGE</instType>
*       <brokerage>
*          <product />
*          <quantity>0</quantity>
*          <price>0</price>
*          <settlementCurrency>USD</settlementCurrency>
*          <paymentCurrency>USD</paymentCurrency>
*          <fee>0</fee>
*          <settlementDate>1528948800000</settlementDate>
*       </brokerage>
*       <detailsURI>https://api.etrade.com/v1/accounts/yIFaUoJ81qyAhgxLWRQ42g/transactions/18165100001766</detailsURI>
*    </Transaction>
*    <Transaction>
*       <transactionId>18158100000983</transactionId>
*       <accountId>83564979</accountId>
*       <transactionDate>1528344000000</transactionDate>
*       <postDate>1528344000000</postDate>
*       <amount>-2</amount>
*       <description>ACH WITHDRAWL REFID:98655276;</description>
*       <description2>98655276</description2>
*       <transactionType>Transfer</transactionType>
*       <memo />
*       <imageFlag>false</imageFlag>
*       <instType>BROKERAGE</instType>
*       <brokerage>
*          <product />
*          <quantity>0</quantity>
*          <price>0</price>
*          <settlementCurrency>USD</settlementCurrency>
*          <paymentCurrency>USD</paymentCurrency>
*          <fee>0</fee>
*          <settlementDate>1528344000000</settlementDate>
*       </brokerage>
*       <detailsURI>https://api.etrade.com/v1/accounts/yIFaUoJ81qyAhgxLWRQ42g/transactions/18158100000983</detailsURI>
*    </Transaction>
*    <pageMarkers>eNpTsAlITE91zi%2FNK%2FHMc04syi8tTs2xM7TRxybMpWATkl%2BSmBOUmpxflAKWtTO10ccQg6mDmwEyEE0EqAbE8SvNTUotCk4tLE3NS061M9Ax0DEEYgOIA9BkuRQgmjxTfDKLQUYoQAV8E4uyU4vsDC0MzUwNDYDA0NzMrKamBmIKVJYLphpiKsyTUB7IbH1kwwFa7F0D</pageMarkers>
*    <moreTransactions>false</moreTransactions>
*    <transactionCount>5</transactionCount>
*    <totalCount>5</totalCount>
* </TransactionListResponse

RELEASE loHttp
RELEASE loJson
RELEASE loXml