Visual FoxPro
Visual FoxPro
ETrade v1 List Accounts
See more HTTP Misc Examples
List ETrade accounts using the ETrade v1 API.Chilkat Visual FoxPro Downloads
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