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
(PHP ActiveX) 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.
<?php // This example assumes the Chilkat HTTP API to have been previously unlocked. // See Global Unlock Sample for sample code. $http = new COM("Chilkat_9_5_0.Http"); $http->OAuth1 = 1; $http->OAuthVerifier = ''; $http->OAuthConsumerKey = 'ETRADE_CONSUMER_KEY'; $http->OAuthConsumerSecret = 'ETRADE_CONSUMER_SECRET'; // Load the access token previously obtained via the OAuth1 3-Legged Authorization $jsonToken = new COM("Chilkat_9_5_0.JsonObject"); $success = $jsonToken->LoadFile('qa_data/tokens/etrade.json'); if ($success != 1) { print 'Failed to load OAuth1 token' . "\n"; exit; } $http->OAuthToken = $jsonToken->stringOf('oauth_token'); $http->OAuthTokenSecret = $jsonToken->stringOf('oauth_token_secret'); // Build the JSON request body $json = new COM("Chilkat_9_5_0.JsonObject"); $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->EmitCompact = 0; print $json->emit() . "\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->EmitCompact = 1; // Set the Accept property to get a JSON response. $http->Accept = 'application/json'; // This example uses the sandbox URL. The live URL is "https://etws.etrade.com/order/rest/placeequityorder" // resp is a Chilkat_9_5_0.HttpResponse $resp = $http->PostJson2('https://etwssandbox.etrade.com/order/sandbox/rest/placeequityorder','application/json',$json->emit()); if ($http->LastMethodSuccess != 1) { print $http->LastErrorText . "\n"; exit; } // Examine the response status code. $statusCode = $resp->StatusCode; print 'Status Code = ' . $statusCode . "\n"; // Load the JSON response body: $json->Load($resp->BodyStr); $json->EmitCompact = 0; // If the status code was not 200, then it was an error.. if ($statusCode != 200) { print $json->emit() . "\n"; print 'Equity order failed.' . "\n"; exit; } print $json->emit() . "\n"; // To examine some information from the JSON: print 'quantity: ' . $json->IntOf('PlaceEquityOrderResponse.EquityOrderResponse.quantity') . "\n"; print 'msgDesc: ' . $json->stringOf('PlaceEquityOrderResponse.EquityOrderResponse.messageList.msgDesc') . "\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.