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
(Swift 3,4,5...) 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.
func chilkatTest() { // This example assumes the Chilkat HTTP API to have been previously unlocked. // See Global Unlock Sample for sample code. let http = CkoHttp()! http.oAuth1 = true http.oAuthVerifier = "" http.oAuthConsumerKey = "ETRADE_CONSUMER_KEY" http.oAuthConsumerSecret = "ETRADE_CONSUMER_SECRET" // Load the access token previously obtained via the OAuth1 3-Legged Authorization let jsonToken = CkoJsonObject()! var success: Bool = jsonToken.loadFile("qa_data/tokens/etrade.json") if success != true { print("Failed to load OAuth1 token") return } http.oAuthToken = jsonToken.string(of: "oauth_token") http.oAuthTokenSecret = jsonToken.string(of: "oauth_token_secret") // Build the JSON request body let json = CkoJsonObject()! json.update("PlaceEquityOrder.-xmlns", value: "http://order.etws.etrade.com") // The accountId should be an 8-digit number such as "83405188" json.update("PlaceEquityOrder.EquityOrderRequest.accountId", value: "MY_ETRADE_ACCOUNT_ID") json.update("PlaceEquityOrder.EquityOrderRequest.clientOrderId", value: "45") json.update("PlaceEquityOrder.EquityOrderRequest.limitPrice", value: "3") json.update("PlaceEquityOrder.EquityOrderRequest.quantity", value: "4") json.update("PlaceEquityOrder.EquityOrderRequest.symbol", value: "ETFC") json.update("PlaceEquityOrder.EquityOrderRequest.orderAction", value: "BUY") json.update("PlaceEquityOrder.EquityOrderRequest.priceType", value: "LIMIT") json.update("PlaceEquityOrder.EquityOrderRequest.marketSession", value: "REGULAR") json.update("PlaceEquityOrder.EquityOrderRequest.orderTerm", value: "GOOD_FOR_DAY") json.emitCompact = false print("\(json.emit()!)") // 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 = true // 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" var resp: CkoHttpResponse? = http.postJson2("https://etwssandbox.etrade.com/order/sandbox/rest/placeequityorder", contentType: "application/json", jsonText: json.emit()) if http.lastMethodSuccess != true { print("\(http.lastErrorText!)") return } // Examine the response status code. var statusCode: Int = resp!.statusCode.intValue print("Status Code = \(statusCode)") // Load the JSON response body: json.load(resp!.bodyStr) json.emitCompact = false // If the status code was not 200, then it was an error.. if statusCode != 200 { print("\(json.emit()!)") print("Equity order failed.") return } print("\(json.emit()!)") resp = nil // To examine some information from the JSON: print("quantity: \(json.int(of: "PlaceEquityOrderResponse.EquityOrderResponse.quantity").intValue)") print("msgDesc: \(json.string(of: "PlaceEquityOrderResponse.EquityOrderResponse.messageList.msgDesc")!)") // 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.