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...) Walmart - Acknowledge OrderSee Acknowledge Orders for more information about this call. Acknowledges an entire order, including all of its order lines. Walmart requires a seller to acknowledge orders within four hours of receipt of the order, except in extenuating circumstances. The response to a successful call contains the acknowledged order. In general, only orders that are in a “Created” state should be acknowledged. As a good practice, acknowledge your orders to avoid underselling. Orders that are in an “Acknowledged” state can be re-acknowledged, possibly in response to an error response from an earlier call to acknowledge order. Orders with line items that are shipped or canceled should not be re-acknowledged.
func chilkatTest() { // --------------------------------------------------------------------------------------------------------- // Note: This example is deprecated. The Walmart API no longer uses the Signature method of authenticating. // Walmart now uses OAuth2. // --------------------------------------------------------------------------------------------------------- // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // Sends the following POST request: // POST https://marketplace.walmartapis.com/v3/orders/{purchaseOrderId}/acknowledge let sbUrl = CkoStringBuilder()! var success: Bool = sbUrl.append("https://marketplace.walmartapis.com/v3/orders/{purchaseOrderId}/acknowledge") var numReplaced: Int = sbUrl.replace("{purchaseOrderId}", replacement: "1111691995111").intValue var requestMethod: String? = "POST" // First we need to generate a signature for our request. // The signature needs to be re-generated for each new Walmart HTTP request. let authUtil = CkoAuthUtil()! var wmConsumerId: String? = "WALMART_CONSUMER_ID" var wmPrivateKey: String? = "WALMART_PRIVATE_KEY" var jsonStr: String? = authUtil.walmartSignature(sbUrl.getAsString(), consumerId: wmConsumerId, privateKey: wmPrivateKey, requestMethod: requestMethod) if authUtil.lastMethodSuccess != true { print("\(authUtil.lastErrorText!)") return } // The JSON returned by WalmartSignature contains the values to be used in the following // header fields: WM_SEC.AUTH_SIGNATURE, WM_SEC.TIMESTAMP, and WM_QOS.CORRELATION_ID let json = CkoJsonObject()! json.load(jsonStr) let http = CkoHttp()! http.setRequestHeader("WM_SVC.NAME", value: "Walmart Marketplace") http.setRequestHeader("WM_QOS.CORRELATION_ID", value: json.string(of: "correlation_id")) http.setRequestHeader("WM_SEC.TIMESTAMP", value: json.string(of: "timestamp")) http.setRequestHeader("WM_SEC.AUTH_SIGNATURE", value: json.string(of: "signature")) http.setRequestHeader("WM_CONSUMER.ID", value: wmConsumerId) // Note: Make sure to replace "WALMART_CHANNEL_TYPE" with the actual value for your seller account... http.setRequestHeader("WM_CONSUMER.CHANNEL.TYPE", value: "WALMART_CHANNEL_TYPE") http.accept = "application/xml" // Note: Do not explicitly set the "Host" header. Chilkat will set it automatically. // Walmart provides the option to send/receive JSON or XML. This example will use JSON. // Note: Please see the online JSON/XML code generation tools at https://tools.chilkat.io/ // The online tools generate code to create/parse XML or JSON. (You copy sample JSON/XML into the online format, // and generate code in your selected programming language. It's a big time saver.) http.setRequestHeader("Accept", value: "application/json") // The body of this particular POST request contains just "{}". (The order ID is already in the URL path.) var resp: CkoHttpResponse? = http.postJson2(sbUrl.getAsString(), contentType: "application/json", jsonText: "{}") if http.lastMethodSuccess != true { print("\(http.lastErrorText!)") return } // Get the JSON response body, which could contain an error, or if successful contains // the acknowledged order. let sbBody = CkoStringBuilder()! resp!.getBodySb(sbBody) // A successful response should have a 200 response status if resp!.statusCode.intValue != 200 { print("\(sbBody.getAsString()!)") print("Response Status Code: \(resp!.statusCode.intValue)") print("Failed.") resp = nil return } resp = nil // Parse the JSON response. // A sample response is shown below this code. (The online tools at https://tools.chilkat.io were used to generate the // fragment of code below using the sample response data at // https://developer.walmart.com/#/apicenter/marketPlace/latest?country=us#acknowledgingOrders json.loadSb(sbBody) var orderPurchaseOrderId: String? var orderCustomerOrderId: String? var orderCustomerEmailId: String? var orderOrderDate: Int var orderShippingInfoPhone: String? var orderShippingInfoEstimatedDeliveryDate: Int var orderShippingInfoEstimatedShipDate: Int var orderShippingInfoMethodCode: String? var orderShippingInfoPostalAddressName: String? var orderShippingInfoPostalAddressAddress1: String? var orderShippingInfoPostalAddressAddress2: String? var orderShippingInfoPostalAddressCity: String? var orderShippingInfoPostalAddressState: String? var orderShippingInfoPostalAddressPostalCode: String? var orderShippingInfoPostalAddressCountry: String? var orderShippingInfoPostalAddressAddressType: String? var i: Int var count_i: Int var lineNumber: String? var itemProductName: String? var itemSku: String? var orderLineQuantityUnitOfMeasurement: String? var orderLineQuantityAmount: String? var statusDate: Int var refundRefundId: Bool var refundRefundComments: Bool var j: Int var count_j: Int var chargeType: String? var chargeName: String? var chargeAmountCurrency: String? var chargeAmountAmount: Int var taxTaxName: String? var taxTaxAmountCurrency: String? var taxTaxAmountAmount: Int var status: String? var statusQuantityUnitOfMeasurement: String? var statusQuantityAmount: String? var cancellationReason: Bool var trackingInfoShipDateTime: Int var trackingInfoCarrierNameOtherCarrier: Bool var trackingInfoCarrierNameCarrier: String? var trackingInfoMethodCode: String? var trackingInfoTrackingNumber: String? var trackingInfoTrackingURL: String? var refundReason: String? var chargeChargeType: String? var chargeChargeName: String? var chargeChargeAmountCurrency: String? var chargeChargeAmountAmount: Int var chargeTax: Bool orderPurchaseOrderId = json.string(of: "order.purchaseOrderId") orderCustomerOrderId = json.string(of: "order.customerOrderId") orderCustomerEmailId = json.string(of: "order.customerEmailId") orderOrderDate = json.int(of: "order.orderDate").intValue orderShippingInfoPhone = json.string(of: "order.shippingInfo.phone") orderShippingInfoEstimatedDeliveryDate = json.int(of: "order.shippingInfo.estimatedDeliveryDate").intValue orderShippingInfoEstimatedShipDate = json.int(of: "order.shippingInfo.estimatedShipDate").intValue orderShippingInfoMethodCode = json.string(of: "order.shippingInfo.methodCode") orderShippingInfoPostalAddressName = json.string(of: "order.shippingInfo.postalAddress.name") orderShippingInfoPostalAddressAddress1 = json.string(of: "order.shippingInfo.postalAddress.address1") orderShippingInfoPostalAddressAddress2 = json.string(of: "order.shippingInfo.postalAddress.address2") orderShippingInfoPostalAddressCity = json.string(of: "order.shippingInfo.postalAddress.city") orderShippingInfoPostalAddressState = json.string(of: "order.shippingInfo.postalAddress.state") orderShippingInfoPostalAddressPostalCode = json.string(of: "order.shippingInfo.postalAddress.postalCode") orderShippingInfoPostalAddressCountry = json.string(of: "order.shippingInfo.postalAddress.country") orderShippingInfoPostalAddressAddressType = json.string(of: "order.shippingInfo.postalAddress.addressType") i = 0 count_i = json.size(ofArray: "order.orderLines.orderLine").intValue while i < count_i { json.i = i lineNumber = json.string(of: "order.orderLines.orderLine[i].lineNumber") itemProductName = json.string(of: "order.orderLines.orderLine[i].item.productName") itemSku = json.string(of: "order.orderLines.orderLine[i].item.sku") orderLineQuantityUnitOfMeasurement = json.string(of: "order.orderLines.orderLine[i].orderLineQuantity.unitOfMeasurement") orderLineQuantityAmount = json.string(of: "order.orderLines.orderLine[i].orderLineQuantity.amount") statusDate = json.int(of: "order.orderLines.orderLine[i].statusDate").intValue refundRefundId = json.isNull(of: "order.orderLines.orderLine[i].refund.refundId") refundRefundComments = json.isNull(of: "order.orderLines.orderLine[i].refund.refundComments") j = 0 count_j = json.size(ofArray: "order.orderLines.orderLine[i].charges.charge").intValue while j < count_j { json.j = j chargeType = json.string(of: "order.orderLines.orderLine[i].charges.charge[j].chargeType") chargeName = json.string(of: "order.orderLines.orderLine[i].charges.charge[j].chargeName") chargeAmountCurrency = json.string(of: "order.orderLines.orderLine[i].charges.charge[j].chargeAmount.currency") chargeAmountAmount = json.int(of: "order.orderLines.orderLine[i].charges.charge[j].chargeAmount.amount").intValue taxTaxName = json.string(of: "order.orderLines.orderLine[i].charges.charge[j].tax.taxName") taxTaxAmountCurrency = json.string(of: "order.orderLines.orderLine[i].charges.charge[j].tax.taxAmount.currency") taxTaxAmountAmount = json.int(of: "order.orderLines.orderLine[i].charges.charge[j].tax.taxAmount.amount").intValue j = j + 1 } j = 0 count_j = json.size(ofArray: "order.orderLines.orderLine[i].orderLineStatuses.orderLineStatus").intValue while j < count_j { json.j = j status = json.string(of: "order.orderLines.orderLine[i].orderLineStatuses.orderLineStatus[j].status") statusQuantityUnitOfMeasurement = json.string(of: "order.orderLines.orderLine[i].orderLineStatuses.orderLineStatus[j].statusQuantity.unitOfMeasurement") statusQuantityAmount = json.string(of: "order.orderLines.orderLine[i].orderLineStatuses.orderLineStatus[j].statusQuantity.amount") cancellationReason = json.isNull(of: "order.orderLines.orderLine[i].orderLineStatuses.orderLineStatus[j].cancellationReason") trackingInfoShipDateTime = json.int(of: "order.orderLines.orderLine[i].orderLineStatuses.orderLineStatus[j].trackingInfo.shipDateTime").intValue trackingInfoCarrierNameOtherCarrier = json.isNull(of: "order.orderLines.orderLine[i].orderLineStatuses.orderLineStatus[j].trackingInfo.carrierName.otherCarrier") trackingInfoCarrierNameCarrier = json.string(of: "order.orderLines.orderLine[i].orderLineStatuses.orderLineStatus[j].trackingInfo.carrierName.carrier") trackingInfoMethodCode = json.string(of: "order.orderLines.orderLine[i].orderLineStatuses.orderLineStatus[j].trackingInfo.methodCode") trackingInfoTrackingNumber = json.string(of: "order.orderLines.orderLine[i].orderLineStatuses.orderLineStatus[j].trackingInfo.trackingNumber") trackingInfoTrackingURL = json.string(of: "order.orderLines.orderLine[i].orderLineStatuses.orderLineStatus[j].trackingInfo.trackingURL") j = j + 1 } j = 0 count_j = json.size(ofArray: "order.orderLines.orderLine[i].refund.refundCharges.refundCharge").intValue while j < count_j { json.j = j refundReason = json.string(of: "order.orderLines.orderLine[i].refund.refundCharges.refundCharge[j].refundReason") chargeChargeType = json.string(of: "order.orderLines.orderLine[i].refund.refundCharges.refundCharge[j].charge.chargeType") chargeChargeName = json.string(of: "order.orderLines.orderLine[i].refund.refundCharges.refundCharge[j].charge.chargeName") chargeChargeAmountCurrency = json.string(of: "order.orderLines.orderLine[i].refund.refundCharges.refundCharge[j].charge.chargeAmount.currency") chargeChargeAmountAmount = json.int(of: "order.orderLines.orderLine[i].refund.refundCharges.refundCharge[j].charge.chargeAmount.amount").intValue chargeTax = json.isNull(of: "order.orderLines.orderLine[i].refund.refundCharges.refundCharge[j].charge.tax") j = j + 1 } i = i + 1 } print("Success!") // Sample Walmart Order Acknowledge Response: // { // "order": { // "purchaseOrderId": "1577684050862", // "customerOrderId": "2861700797280", // "customerEmailId": "jsanthanam@walmartlabs.com", // "orderDate": 1484458949000, // "shippingInfo": { // "phone": "4151234567", // "estimatedDeliveryDate": 1485586800000, // "estimatedShipDate": 1484636400000, // "methodCode": "Value", // "postalAddress": { // "name": "Asha Chakre", // "address1": "860 W California ave", // "address2": null, // "city": "Sunnyvale", // "state": "CA", // "postalCode": "94086", // "country": "USA", // "addressType": "RESIDENTIAL" // } // }, // "orderLines": { // "orderLine": [ // { // "lineNumber": "1", // "item": { // "productName": "Kellogg's Rice Krispies Cereal, 24 oz", // "sku": "MGR_07_21_00100123" // }, // "charges": { // "charge": [ // { // "chargeType": "PRODUCT", // "chargeName": "ItemPrice", // "chargeAmount": { // "currency": "USD", // "amount": 19.99 // }, // "tax": { // "taxName": "Tax1", // "taxAmount": { // "currency": "USD", // "amount": 1.7 // } // } // } // ] // }, // "orderLineQuantity": { // "unitOfMeasurement": "EACH", // "amount": "1" // }, // "statusDate": 1487888747000, // "orderLineStatuses": { // "orderLineStatus": [ // { // "status": "Shipped", // "statusQuantity": { // "unitOfMeasurement": "EACH", // "amount": "1" // }, // "cancellationReason": null, // "trackingInfo": { // "shipDateTime": 1485549015000, // "carrierName": { // "otherCarrier": null, // "carrier": "FedEx" // }, // "methodCode": "Value", // "trackingNumber": "3445435443441221", // "trackingURL": "http://walmart.narvar.com/walmart/tracking/Fedex?&type=MP&seller_id=801&promise_date=01/28/2017&dzip=94086&tracking_numbers=3445435443441221" // } // } // ] // }, // "refund": { // "refundId": null, // "refundComments": null, // "refundCharges": { // "refundCharge": [ // { // "refundReason": "ItemNotReceivedByCustomer", // "charge": { // "chargeType": "PRODUCT", // "chargeName": "Lost in Transit", // "chargeAmount": { // "currency": "USD", // "amount": -0.01 // }, // "tax": null // } // } // ] // } // } // } // ] // } // } // } } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.