Create orders using SAP Commerce Cloud Restful API

i042416發表於2019-10-26

Recently Jerry is working on an integration project about creating orders in Wechat platform by consuming SAP Commerce Cloud Restful API.

Consultants who didn't touch SAP Commerce before(such as Jerry ) might get confused once they saw the search result by key word "commerce" in  https://help.sap.com:

Create orders using SAP Commerce Cloud Restful API

Several products with similar name are listed in search result.

  • SAP Commerce:SAP commerce solution based on On-Premises deployment approach
  • SAP Commerce Cloud on SAP Infrastructure & SAP Commerce Cloud on Public Cloud: as their names give a very clear hint: both are SAP Commerce solution based on cloud, and differentiated by the underlying cloud infrastructure the solution are running. SAP Commerce Cloud on SAP Infrastructure are sometimes called Commerce Cloud Version One and CCV1 for short, while the latter called CCV2.

There is a nice blog  Two clouds in practice: a comparison of SAP Commerce Cloud v1 and v2in medium comparing both.

Create orders using SAP Commerce Cloud Restful API

Back to my task, it's helpful if we play around in Commerce Cloud storefront UI to create a order manually to get ourselves familar with the process.

Log in to storefront and browse the site:

Create orders using SAP Commerce Cloud Restful API

And identify a favourite product and add it to cart by pressing button "ADD TO CART":

Create orders using SAP Commerce Cloud Restful API

Press CHECK OUT to proceed:

Create orders using SAP Commerce Cloud Restful API

Now we get a cart ID:

Create orders using SAP Commerce Cloud Restful API

Maintain shipping address:

Create orders using SAP Commerce Cloud Restful API

Maintain payment details:

Create orders using SAP Commerce Cloud Restful API

Once Place Order button is clicked, the order is successfully created with an automatically populated order ID:

Create orders using SAP Commerce Cloud Restful API

In summary, the process of order manual creation in SAP Commerce Cloud consists of five steps:

(1) create a Shopping Cart
(2) add products into the cart
(3) maintain shipping address to the cart
(4) maintain payment details to the cart
(5) execution place order action on the cart to get order created

Now we should figure out for each step, what exactly APIs should be called.

Go to  https://api.sap.com, search by keyword "Commerce Cloud", and it's easy to find the supported API list there.

Create orders using SAP Commerce Cloud Restful API

Jerry has written a simple nodejs application to demonstrate how to consume such APIs to create orders in SAP Commerce Cloud. The whole source code is uploaded to my  github.

Execute the application, and we can observe the successflly created order with its ID in callback function in line 20:

Create orders using SAP Commerce Cloud Restful API

Search the ID in Commerce Cloud backoffice UI to check the details of created order.

Create orders using SAP Commerce Cloud Restful API Create orders using SAP Commerce Cloud Restful API

As introduced before, it's necessary to go through five steps to have an order generated. And in Jerry's project there are totally seven "step.js" implementation files, why?

For the additional two step.js, one is for access token retrieve and the other for cart delivery mode set operation. Access token will be appended to the header fields of all the subsequent API calls for authorization purpose. And the cart delivery mode will be set implicitly if performed in storefront UI via browser whereas an explicit API call is necessary in our case. As a result totally seven HTTP roundtrip is needed in API consumption case.

Create orders using SAP Commerce Cloud Restful API

The access token fetch is implemented by following OAuth protocol: send the OAuth Client ID and secret to SAP Commerce Cloud OAuth endpoint to get the issued access token.

First we have to create a new OAuth Client in SAP Commerce Cloud backoffice:

Create orders using SAP Commerce Cloud Restful API

Then in file "step1_get_token.js", send a HTTP POST to Commerce Cloud Authentication endpoint to request access token:

Create orders using SAP Commerce Cloud Restful API

For privacy reason I didn't upload urlconfig.js to github which contains the dedicated url of my own Commerce Cloud API endpoint. Instead I upload the template file: urlconfigTemplate.js. Just replace the place holder marked with "<>" with your actual value there, rename the template file back to urlconfig.js. After that you can create orders in your own Commerce Cloud tenant.

Create orders using SAP Commerce Cloud Restful API

要獲取更多Jerry的原創文章,請關注公眾號"汪子熙":

Create orders using SAP Commerce Cloud Restful API


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/24475491/viewspace-2661539/,如需轉載,請註明出處,否則將追究法律責任。

相關文章