Sample code for 30+ languages & platforms
Visual FoxPro

ETrade v1 List Accounts

See more HTTP Misc Examples

List ETrade accounts using the ETrade v1 API.

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 lnAccountId
LOCAL lcAccountIdKey
LOCAL lcAccountMode
LOCAL lcAccountDesc
LOCAL lcAccountName
LOCAL lcAccountType
LOCAL lcInstitutionType
LOCAL lcAccountStatus
LOCAL lnClosedDate

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.

lcRespStr = loHttp.QuickGetStr("https://apisb.etrade.com/v1/accounts/list")
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("Accounts|Account")
DO WHILE i < lnCount_i
    loXml.I = i
    lnAccountId = loXml.GetChildIntValue("Accounts|Account[i]|accountId")
    lcAccountIdKey = loXml.GetChildContent("Accounts|Account[i]|accountIdKey")
    lcAccountMode = loXml.GetChildContent("Accounts|Account[i]|accountMode")
    lcAccountDesc = loXml.GetChildContent("Accounts|Account[i]|accountDesc")
    lcAccountName = loXml.GetChildContent("Accounts|Account[i]|accountName")
    lcAccountType = loXml.GetChildContent("Accounts|Account[i]|accountType")
    lcInstitutionType = loXml.GetChildContent("Accounts|Account[i]|institutionType")
    lcAccountStatus = loXml.GetChildContent("Accounts|Account[i]|accountStatus")
    lnClosedDate = loXml.GetChildIntValue("Accounts|Account[i]|closedDate")
    i = i + 1
ENDDO

* <?xml version="1.0" encoding="UTF-8"?>
* <AccountListResponse>
*    <Accounts>
*       <Account>
*          <accountId>84010429</accountId>
*          <accountIdKey>JIdOIAcSpwR1Jva7RQBraQ</accountIdKey>
*          <accountMode>MARGIN</accountMode>
*          <accountDesc>INDIVIDUAL</accountDesc>
*          <accountName>Individual Brokerage</accountName>
*          <accountType>INDIVIDUAL</accountType>
*          <institutionType>BROKERAGE</institutionType>
*          <accountStatus>ACTIVE</accountStatus>
*          <closedDate>0</closedDate>
*       </Account>
*       <Account>
*          <accountId>84010430</accountId>
*          <accountIdKey>JAAOIAcSpwR1Jva7RQBraQ</accountIdKey>
*          <accountMode>MARGIN</accountMode>
*          <accountDesc>INDIVIDUAL</accountDesc>
*          <accountName>Individual Brokerage</accountName>
*          <accountType>INDIVIDUAL</accountType>
*          <institutionType>BROKERAGE</institutionType>
*          <accountStatus>ACTIVE</accountStatus>
*          <closedDate>0</closedDate>
*       </Account>
*    </Accounts>
* </AccountListResponse>

RELEASE loHttp
RELEASE loJson
RELEASE loXml