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 2) CardConnect AuthorizationDemonstrates how to send an Authorization request. Authorization is the initial step in accepting payment from a cardholder. This action "authorizes" or requests permission from the bank to transfer money from the cardholder to the merchant. See https://developer.cardconnect.com/cardconnect-api#authorization
func chilkatTest() { // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. let http = CkoHttp() var success: Bool http.BasicAuth = true http.Login = "API_USERNAME" http.Password = "API_PASSWORD" // Build and send the following JSON: // Note: The CardConnect online documentation might use an expiry that is in the past, such as "1218". // This causes the request to fail. Use a month/year that is in the future.. // (Likewise, this example will have an invalid month/year after Dec 2021) // { // "merchid": "MERCHANT_ID", // "accttype": "VISA", // "orderid": "AB-11-9876", // "account": "4111111111111111", // "expiry": "1221", // "amount": "0", // "currency": "USD", // "name": "TOM JONES", // "address": "123 MAIN STREET", // "city": "anytown", // "region": "NY", // "country": "US", // "postal": "55555", // "profile": "Y", // "ecomind": "E", // "cvv2": "123", // "track": null, // "capture": "Y" // } // Use this online tool to generate the code from sample JSON: // Generate Code to Create JSON let json = CkoJsonObject() json.UpdateString("merchid", value: "MERCHANT_ID") json.UpdateString("accttype", value: "VISA") json.UpdateString("orderid", value: "AB-11-9876") json.UpdateString("account", value: "4111111111111111") json.UpdateString("expiry", value: "1221") json.UpdateString("amount", value: "20") json.UpdateString("currency", value: "USD") json.UpdateString("name", value: "TOM JONES") json.UpdateString("address", value: "123 MAIN STREET") json.UpdateString("city", value: "anytown") json.UpdateString("region", value: "NY") json.UpdateString("country", value: "US") json.UpdateString("postal", value: "55555") json.UpdateString("profile", value: "Y") json.UpdateString("ecomind", value: "E") json.UpdateString("cvv2", value: "123") json.UpdateNull("track") json.UpdateString("capture", value: "Y") var url: String? = "https://<site>.cardconnect.com:<port>/cardconnect/rest/auth" var responseStr: String? = http.PutText(url, textData: json.Emit(), charset: "utf-8", contentType: "application/json", md5: false, gzip: false) if http.LastMethodSuccess == false { print("\(http.LastErrorText)") return } // A response status of 200 indicates potential success. The JSON response body // must be examined to determine if it was truly successful or an error. print("response status code = \(http.LastStatus.intValue)") let jsonResp = CkoJsonObject() jsonResp.Load(responseStr) jsonResp.EmitCompact = false print("response JSON:") print("\(jsonResp.Emit())") // Sample error: // { // "respproc": "PPS", // "amount": "0.00", // "resptext": "Invalid amount", // "cardproc": "FNOR", // "acctid": "1", // "retref": "112804260418", // "respstat": "C", // "respcode": "43", // "account": "41XXXXXXXXXX1111", // "defaultacct": "Y", // "merchid": "MERCHANT_ID", // "token": "9418594164541111" // } // A successful response looks like this: // { // "amount": "0.20", // "resptext": "Approval", // "acctid": "1", // "commcard": " C ", // "cvvresp": "M", // "respcode": "00", // "batchid": "1900942291", // "avsresp": "Z", // "entrymode": "ECommerce", // "defaultacct": "Y", // "merchid": "MERCHANT_ID", // "token": "9418594164541111", // "authcode": "PPS158", // "respproc": "FNOR", // "bintype": "", // "profileid": "16618402968441604028", // "retref": "112989260941", // "respstat": "A", // "account": "41XXXXXXXXXX1111" // } // Use this online tool to generate parsing code from sample JSON: // Generate Parsing Code from JSON var amount: String? = jsonResp.StringOf("amount") var resptext: String? = jsonResp.StringOf("resptext") var acctid: String? = jsonResp.StringOf("acctid") var commcard: String? = jsonResp.StringOf("commcard") var cvvresp: String? = jsonResp.StringOf("cvvresp") var respcode: String? = jsonResp.StringOf("respcode") var batchid: String? = jsonResp.StringOf("batchid") var avsresp: String? = jsonResp.StringOf("avsresp") var entrymode: String? = jsonResp.StringOf("entrymode") var defaultacct: String? = jsonResp.StringOf("defaultacct") var merchid: String? = jsonResp.StringOf("merchid") var token: String? = jsonResp.StringOf("token") var authcode: String? = jsonResp.StringOf("authcode") var respproc: String? = jsonResp.StringOf("respproc") var bintype: String? = jsonResp.StringOf("bintype") var profileid: String? = jsonResp.StringOf("profileid") var retref: String? = jsonResp.StringOf("retref") var respstat: String? = jsonResp.StringOf("respstat") var account: String? = jsonResp.StringOf("account") } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.