Ruby / Commercetools / SetShippingAddress
Back to Collection Items
require 'chilkat'
# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
http = Chilkat::CkHttp.new()
# Use this online tool to generate code from sample JSON: Generate Code to Create JSON
# The following JSON is sent in the request body.
# {
# "version": "{{version}}",
# "actions": [
# {
# "action": "setShippingAddress",
# "address": {
# "id": "exampleAddress",
# "key": "exampleKey",
# "title": "My Address",
# "salutation": "Mr.",
# "firstName": "Example",
# "lastName": "Person",
# "streetName": "Examplary Street",
# "streetNumber": "4711",
# "additionalStreetInfo": "Backhouse",
# "postalCode": "80933",
# "city": "Exemplary City",
# "region": "Exemplary Region",
# "state": "Exemplary State",
# "country": "DE",
# "company": "My Company Name",
# "department": "Sales",
# "building": "Hightower 1",
# "apartment": "247",
# "pOBox": "2471",
# "phone": "+49 89 12345678",
# "mobile": "+49 171 2345678",
# "email": "mail@mail.com",
# "fax": "+49 89 12345679",
# "additionalAddressInfo": "no additional Info",
# "externalId": "Information not needed"
# }
# }
# ]
# }
json = Chilkat::CkJsonObject.new()
json.UpdateString("version","{{version}}")
json.UpdateString("actions[0].action","setShippingAddress")
json.UpdateString("actions[0].address.id","exampleAddress")
json.UpdateString("actions[0].address.key","exampleKey")
json.UpdateString("actions[0].address.title","My Address")
json.UpdateString("actions[0].address.salutation","Mr.")
json.UpdateString("actions[0].address.firstName","Example")
json.UpdateString("actions[0].address.lastName","Person")
json.UpdateString("actions[0].address.streetName","Examplary Street")
json.UpdateString("actions[0].address.streetNumber","4711")
json.UpdateString("actions[0].address.additionalStreetInfo","Backhouse")
json.UpdateString("actions[0].address.postalCode","80933")
json.UpdateString("actions[0].address.city","Exemplary City")
json.UpdateString("actions[0].address.region","Exemplary Region")
json.UpdateString("actions[0].address.state","Exemplary State")
json.UpdateString("actions[0].address.country","DE")
json.UpdateString("actions[0].address.company","My Company Name")
json.UpdateString("actions[0].address.department","Sales")
json.UpdateString("actions[0].address.building","Hightower 1")
json.UpdateString("actions[0].address.apartment","247")
json.UpdateString("actions[0].address.pOBox","2471")
json.UpdateString("actions[0].address.phone","+49 89 12345678")
json.UpdateString("actions[0].address.mobile","+49 171 2345678")
json.UpdateString("actions[0].address.email","mail@mail.com")
json.UpdateString("actions[0].address.fax","+49 89 12345679")
json.UpdateString("actions[0].address.additionalAddressInfo","no additional Info")
json.UpdateString("actions[0].address.externalId","Information not needed")
# Adds the "Authorization: Bearer <access_token>" header.
http.put_AuthToken("<access_token>")
http.SetRequestHeader("Content-Type","application/json")
sbRequestBody = Chilkat::CkStringBuilder.new()
json.EmitSb(sbRequestBody)
# resp is a CkHttpResponse
resp = http.PTextSb("post","https://domain.com/{{project-key}}/in-store/key={{store-key}}/carts/{{cart-id}}",sbRequestBody,"utf-8","application/json",false,false)
if (http.get_LastMethodSuccess() == false)
print http.lastErrorText() + "\n";
exit
end
print resp.get_StatusCode().to_s() + "\n";
print resp.bodyStr() + "\n";
Curl Command
curl -X post
-H "Authorization: Bearer <access_token>"
-H "Content-Type: application/json"
-d '{
"version": {{cart-version}},
"actions": [
{
"action" : "setShippingAddress",
"address" : {
"id" : "exampleAddress",
"key" : "exampleKey",
"title" : "My Address",
"salutation" : "Mr.",
"firstName" : "Example",
"lastName" : "Person",
"streetName" : "Examplary Street",
"streetNumber" : "4711",
"additionalStreetInfo" : "Backhouse",
"postalCode" : "80933",
"city" : "Exemplary City",
"region" : "Exemplary Region",
"state" : "Exemplary State",
"country" : "DE",
"company" : "My Company Name",
"department" : "Sales",
"building" : "Hightower 1",
"apartment" : "247",
"pOBox" : "2471",
"phone" : "+49 89 12345678",
"mobile" : "+49 171 2345678",
"email" : "mail@mail.com",
"fax" : "+49 89 12345679",
"additionalAddressInfo" : "no additional Info",
"externalId" : "Information not needed"
}
}
]
}'
https://domain.com/{{project-key}}/in-store/key={{store-key}}/carts/{{cart-id}}
Postman Collection Item JSON
{
"name": "SetShippingAddress",
"event": [
{
"listen": "test",
"script": {
"type": "text/javascript",
"exec": [
"tests[\"Status code \" + responseCode.code] = responseCode.code === 200 || responseCode.code === 201;",
"var data = JSON.parse(responseBody);",
"if(data.results && data.results[0] && data.results[0].id && data.results[0].version){",
" pm.environment.set(\"cart-id\", data.results[0].id); ",
" pm.environment.set(\"cart-version\", data.results[0].version);",
"}",
"if(data.results && data.results[0] && data.results[0].key){",
" pm.environment.set(\"cart-key\", data.results[0].key); ",
"}",
"if(data.version){",
" pm.environment.set(\"cart-version\", data.version);",
"}",
"if(data.id){",
" pm.environment.set(\"cart-id\", data.id); ",
"}",
"if(data.key){",
" pm.environment.set(\"cart-key\", data.key);",
"}",
""
]
}
}
],
"request": {
"auth": {
"type": "oauth2",
"oauth2": {
"accessToken": "{{ctp_access_token}}",
"addTokenTo": "header",
"tokenType": "Bearer"
}
},
"method": "post",
"body": {
"mode": "raw",
"raw": "{\n \"version\": {{cart-version}},\n \"actions\": [\n {\n \"action\" : \"setShippingAddress\",\n \"address\" : {\n \"id\" : \"exampleAddress\",\n \"key\" : \"exampleKey\",\n \"title\" : \"My Address\",\n \"salutation\" : \"Mr.\",\n \"firstName\" : \"Example\",\n \"lastName\" : \"Person\",\n \"streetName\" : \"Examplary Street\",\n \"streetNumber\" : \"4711\",\n \"additionalStreetInfo\" : \"Backhouse\",\n \"postalCode\" : \"80933\",\n \"city\" : \"Exemplary City\",\n \"region\" : \"Exemplary Region\",\n \"state\" : \"Exemplary State\",\n \"country\" : \"DE\",\n \"company\" : \"My Company Name\",\n \"department\" : \"Sales\",\n \"building\" : \"Hightower 1\",\n \"apartment\" : \"247\",\n \"pOBox\" : \"2471\",\n \"phone\" : \"+49 89 12345678\",\n \"mobile\" : \"+49 171 2345678\",\n \"email\" : \"mail@mail.com\",\n \"fax\" : \"+49 89 12345679\",\n \"additionalAddressInfo\" : \"no additional Info\",\n \"externalId\" : \"Information not needed\"\n }\n }\n ]\n}"
},
"header": [
{
"key": "Content-Type",
"value": "application/json"
}
],
"url": {
"raw": "{{host}}/{{project-key}}/in-store/key={{store-key}}/carts/{{cart-id}}",
"host": [
"{{host}}"
],
"path": [
"{{project-key}}",
"in-store",
"key={{store-key}}",
"carts",
"{{cart-id}}"
],
"query": [
{
"key": "expand",
"value": "",
"equals": true,
"disabled": true
}
]
},
"description": "Updates a cart in the store specified by {storeKey}. The {storeKey} path parameter maps to a Store's key.\nIf the cart exists in the commercetools project but does not have the store field,\nor the store field references a different store, this method returns a ResourceNotFound error.\n"
},
"response": [
]
}