Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Perl) ETrade - Place Equity Order (JSON version)Shows how to place an equity order using ETrade with OAuth1 authorization. See https://developer.etrade.com/ctnt/dev-portal/getDetail?contentUri=V0_Documentation-OrderAPI-PlaceEquityOrder for more information.
use chilkat(); # This example assumes the Chilkat HTTP API to have been previously unlocked. # See Global Unlock Sample for sample code. $http = chilkat::CkHttp->new(); $http->put_OAuth1(1); $http->put_OAuthVerifier(""); $http->put_OAuthConsumerKey("ETRADE_CONSUMER_KEY"); $http->put_OAuthConsumerSecret("ETRADE_CONSUMER_SECRET"); # Load the access token previously obtained via the OAuth1 3-Legged Authorization $jsonToken = chilkat::CkJsonObject->new(); $success = $jsonToken->LoadFile("qa_data/tokens/etrade.json"); if ($success != 1) { print "Failed to load OAuth1 token" . "\r\n"; exit; } $http->put_OAuthToken($jsonToken->stringOf("oauth_token")); $http->put_OAuthTokenSecret($jsonToken->stringOf("oauth_token_secret")); # Build the JSON request body $json = chilkat::CkJsonObject->new(); $json->UpdateString("PlaceEquityOrder.-xmlns","http://order.etws.etrade.com"); # The accountId should be an 8-digit number such as "83405188" $json->UpdateString("PlaceEquityOrder.EquityOrderRequest.accountId","MY_ETRADE_ACCOUNT_ID"); $json->UpdateString("PlaceEquityOrder.EquityOrderRequest.clientOrderId","45"); $json->UpdateString("PlaceEquityOrder.EquityOrderRequest.limitPrice","3"); $json->UpdateString("PlaceEquityOrder.EquityOrderRequest.quantity","4"); $json->UpdateString("PlaceEquityOrder.EquityOrderRequest.symbol","ETFC"); $json->UpdateString("PlaceEquityOrder.EquityOrderRequest.orderAction","BUY"); $json->UpdateString("PlaceEquityOrder.EquityOrderRequest.priceType","LIMIT"); $json->UpdateString("PlaceEquityOrder.EquityOrderRequest.marketSession","REGULAR"); $json->UpdateString("PlaceEquityOrder.EquityOrderRequest.orderTerm","GOOD_FOR_DAY"); $json->put_EmitCompact(0); print $json->emit() . "\r\n"; # The above code builds the following JSON: # { # "PlaceEquityOrder": { # "-xmlns": "http://order.etws.etrade.com", # "EquityOrderRequest": { # "accountId": "83405188", # "clientOrderId": "45", # "limitPrice": "3", # "quantity": "4", # "symbol": "ETFC", # "orderAction": "BUY", # "priceType": "LIMIT", # "marketSession": "REGULAR", # "orderTerm": "GOOD_FOR_DAY" # } # } # } # POST the JSON and get the response. $json->put_EmitCompact(1); # Set the Accept property to get a JSON response. $http->put_Accept("application/json"); # This example uses the sandbox URL. The live URL is "https://etws.etrade.com/order/rest/placeequityorder" # resp is a HttpResponse $resp = $http->PostJson2("https://etwssandbox.etrade.com/order/sandbox/rest/placeequityorder","application/json",$json->emit()); if ($http->get_LastMethodSuccess() != 1) { print $http->lastErrorText() . "\r\n"; exit; } # Examine the response status code. $statusCode = $resp->get_StatusCode(); print "Status Code = " . $statusCode . "\r\n"; # Load the JSON response body: $json->Load($resp->bodyStr()); $json->put_EmitCompact(0); # If the status code was not 200, then it was an error.. if ($statusCode != 200) { print $json->emit() . "\r\n"; print "Equity order failed." . "\r\n"; exit; } print $json->emit() . "\r\n"; # To examine some information from the JSON: print "quantity: " . $json->IntOf("PlaceEquityOrderResponse.EquityOrderResponse.quantity") . "\r\n"; print "msgDesc: " . $json->stringOf("PlaceEquityOrderResponse.EquityOrderResponse.messageList.msgDesc") . "\r\n"; # etc .. # This is a sample response: # { # "PlaceEquityOrderResponse": { # "EquityOrderResponse": { # "accountId": 83310056, # "allOrNone": false, # "estimatedCommission": 9.99, # "estimatedTotalAmount": 1909.99, # "messageList": { # "msgDesc": "Your order was successfully entered during market hours.", # "msgCode": 1026 # }, # "orderNum": 277, # "orderTime": 1240982042179, # "quantity": 100, # "reserveOrder": false, # "reserveQuantity": 0, # "orderTerm": "GOOD_UNTIL_CANCEL", # "limitPrice": 18, # "stopPrice": 0, # "symbolDesc": "CISCO SYS INC COM", # "symbol": "CSCO", # "orderAction": "BUY", # "priceType": "LIMIT" # } # } # } # |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.