Visual FoxPro
Visual FoxPro
ETrade v1 Get Account Balances
See more HTTP Misc Examples
Get account balances using the ETrade v1 API.Chilkat Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loHttp
LOCAL loJson
LOCAL lcRespStr
LOCAL lnStatusCode
LOCAL loXml
LOCAL lcTagPath
LOCAL lnAccountId
LOCAL lcAccountType
LOCAL lcOptionLevel
LOCAL lcAccountDescription
LOCAL lnQuoteMode
LOCAL lcDayTraderStatus
LOCAL lcAccountMode
LOCAL lnFundsForOpenOrdersCash
LOCAL lnMoneyMktBalance
LOCAL lnCashAvailableForInvestment
LOCAL lcNetCash
LOCAL lcCashBalance
LOCAL lnSettledCashForInvestment
LOCAL lnUnSettledCashForInvestment
LOCAL lnFundsWithheldFromPurchasePower
LOCAL lnFundsWithheldFromWithdrawal
LOCAL lnMarginBuyingPower
LOCAL lcCashBuyingPower
LOCAL lnDtMarginBuyingPower
LOCAL lnDtCashBuyingPower
LOCAL lnShortAdjustBalance
LOCAL lnRegtEquity
LOCAL lnRegtEquityPercent
LOCAL lnAccountBalance
LOCAL lnDtCashOpenOrderReserve
LOCAL lnDtMarginOpenOrderReserve
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")
loHttp.SetUrlVar("instType","BROKERAGE")
lcRespStr = loHttp.QuickGetStr("https://apisb.etrade.com/v1/accounts/{$accountIdKey}/balance?instType={$instType}&realTimeNAV=true")
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)
lnAccountId = loXml.GetChildIntValue("accountId")
lcAccountType = loXml.GetChildContent("accountType")
lcOptionLevel = loXml.GetChildContent("optionLevel")
lcAccountDescription = loXml.GetChildContent("accountDescription")
lnQuoteMode = loXml.GetChildIntValue("quoteMode")
lcDayTraderStatus = loXml.GetChildContent("dayTraderStatus")
lcAccountMode = loXml.GetChildContent("accountMode")
lnFundsForOpenOrdersCash = loXml.GetChildIntValue("Cash|fundsForOpenOrdersCash")
lnMoneyMktBalance = loXml.GetChildIntValue("Cash|moneyMktBalance")
lnCashAvailableForInvestment = loXml.GetChildIntValue("Computed|cashAvailableForInvestment")
lcNetCash = loXml.GetChildContent("Computed|netCash")
lcCashBalance = loXml.GetChildContent("Computed|cashBalance")
lnSettledCashForInvestment = loXml.GetChildIntValue("Computed|settledCashForInvestment")
lnUnSettledCashForInvestment = loXml.GetChildIntValue("Computed|unSettledCashForInvestment")
lnFundsWithheldFromPurchasePower = loXml.GetChildIntValue("Computed|fundsWithheldFromPurchasePower")
lnFundsWithheldFromWithdrawal = loXml.GetChildIntValue("Computed|fundsWithheldFromWithdrawal")
lnMarginBuyingPower = loXml.GetChildIntValue("Computed|marginBuyingPower")
lcCashBuyingPower = loXml.GetChildContent("Computed|cashBuyingPower")
lnDtMarginBuyingPower = loXml.GetChildIntValue("Computed|dtMarginBuyingPower")
lnDtCashBuyingPower = loXml.GetChildIntValue("Computed|dtCashBuyingPower")
lnShortAdjustBalance = loXml.GetChildIntValue("Computed|shortAdjustBalance")
lnRegtEquity = loXml.GetChildIntValue("Computed|regtEquity")
lnRegtEquityPercent = loXml.GetChildIntValue("Computed|regtEquityPercent")
lnAccountBalance = loXml.GetChildIntValue("Computed|accountBalance")
lnDtCashOpenOrderReserve = loXml.GetChildIntValue("Margin|dtCashOpenOrderReserve")
lnDtMarginOpenOrderReserve = loXml.GetChildIntValue("Margin|dtMarginOpenOrderReserve")
* <?xml version="1.0" encoding="UTF-8"?>
* <BalanceResponse>
* <accountId>83564979</accountId>
* <accountType>PDT_ACCOUNT</accountType>
* <optionLevel>LEVEL_4</optionLevel>
* <accountDescription>KRITHH TT</accountDescription>
* <quoteMode>6</quoteMode>
* <dayTraderStatus>PDT_MIN_EQUITY_RES_1XK</dayTraderStatus>
* <accountMode>PDT ACCOUNT</accountMode>
* <Cash>
* <fundsForOpenOrdersCash>0</fundsForOpenOrdersCash>
* <moneyMktBalance>0</moneyMktBalance>
* </Cash>
* <Computed>
* <cashAvailableForInvestment>0</cashAvailableForInvestment>
* <netCash>93921.44</netCash>
* <cashBalance>93921.44</cashBalance>
* <settledCashForInvestment>0</settledCashForInvestment>
* <unSettledCashForInvestment>0</unSettledCashForInvestment>
* <fundsWithheldFromPurchasePower>0</fundsWithheldFromPurchasePower>
* <fundsWithheldFromWithdrawal>0</fundsWithheldFromWithdrawal>
* <marginBuyingPower>0</marginBuyingPower>
* <cashBuyingPower>93921.44</cashBuyingPower>
* <dtMarginBuyingPower>0</dtMarginBuyingPower>
* <dtCashBuyingPower>0</dtCashBuyingPower>
* <shortAdjustBalance>0</shortAdjustBalance>
* <regtEquity>0</regtEquity>
* <regtEquityPercent>0</regtEquityPercent>
* <accountBalance>0</accountBalance>
* </Computed>
* <Margin>
* <dtCashOpenOrderReserve>0</dtCashOpenOrderReserve>
* <dtMarginOpenOrderReserve>0</dtMarginOpenOrderReserve>
* </Margin>
* </BalanceResponse>
RELEASE loHttp
RELEASE loJson
RELEASE loXml