Integrating a commerce solution, such as commercetools, with an Enterprise Resource Planning (ERP) system is often a central aspect of a commerce project. An ERP system typically holds the key master data crucial for a business. This data includes product information, customer data, and inventory levels. To ensure smooth operations, the data, as well as core business processes, such as order replication, must be effectively managed and synchronized between the commerce solution and the ERP system.
Choose the right integration solution
- Scalability and performance: the middleware should be able to accommodate the growth of the business, handling increased data volumes and more complex operations without compromising performance.
- Security: given the sensitive nature of the data exchanged, the middleware must provide robust security features to protect against data breaches and unauthorized access.
- Flexibility: the chosen middleware should be adaptable to the business's specific requirements and capable of integrating with various systems and technologies as needed.
- Team skillset: the technical expertise required to implement and maintain the middleware should match the team's skillset.
- Cost: the overall cost of the middleware, including initial setup, maintenance, and potential scalability needs, should be evaluated against the budget and the expected return on investment.
-
SAP Cloud Integration (SAP CI): a centralized solution for linking various systems and applications, acting as middleware to connect ERP and commerce systems. It allows you to create and manage integration flows, including data mapping and transformation, using APIs for smooth data exchange between commercetools and SAP ERP. It's best suited for customers already using SAP CI to connect various other systems with SAP ERP.
-
Best-of-breed middleware: a platform as a service solution for integrations that comes with pre-built connectors. They allow you to connect commercetools and SAP ERP quickly and easily, without extensive development work. Recommended for customers looking for full flexibility and custom integration flows to meet specific requirements.
Typical data flow for B2C and B2B transactions
The following table outlines the data flow and data mapping between SAP ERP and commercetools, and the recommended integration method:
SAP data type | Data flow for replicating data | Data mapping details | Integration method |
---|---|---|---|
Products and Material | SAP ERP -> commercetools | MATMAS IDOCs -> Product and Product Variant | Asynchronous: batch and delta |
Product Classification | SAP ERP -> commercetools | CHRMAS, CLFMAS, and CLSMAS IDocs -> Product Type, Product Attribute, and Product Variant | Asynchronous: batch and delta |
Price Row and Discount Row | SAP ERP -> commercetools | (COND_A) IDocs -> Embedded or Standalone Prices | Asynchronous: batch and delta |
B2C Customer | commercetools -> SAP ERP | Customer -> Customer profiles and transaction histories | Asynchronous |
B2B Customer | SAP ERP -> commercetools | B2B Customer and B2B Units -> Business Units and Associates | Asynchronous: batch and delta |
B2B Customer | commercetools -> SAP ERP | Associates -> Accounts | Asynchronous |
Stock Levels | SAP ERP -> commercetools | LOISTD IDOCs -> Inventory | Asynchronous: batch and delta |
Orders | commercetools -> SAP ERP | Orders -> Sales Orders | Asynchronous |
Invoice | SAP ERP -> commercetools | Invoice IDOCs -> Order | Asynchronous |
The provided data exchange framework between SAP ERP and commercetools covers key elements of commerce operations like product information, pricing, customer data, inventory, and order management. This integration ensures that both systems are synchronized, maintaining data consistency, and streamlining business processes across the B2C and B2B spectrum. The asynchronous nature of these integrations, often incorporating both batch and delta methods, ensures timely and efficient data transfer and synchronization between the two systems.
Integration architecture using middleware

Inbound data flow
The inbound portion of the architecture diagram highlights the inbound data replication flow from SAP S4/HANA or SAP ERP to commercetools, using SAP Cloud Integration. This process is a critical architectural component where SAP CI plays a key role. At this step, the integration and data mapping to the commercetools APIs takes place.
Inbound data replication scenarios
The inbound integration from SAP systems to commercetools using SAP CI requires additional cloud services to push data synchronously and asynchronously from SAP CI to commercetools. These processes include:
- Customer replication (B2C/B2B): use API Extensions to ensure that the successful response from SAP CI is relayed to the frontend.
- Order creation and replication: use Subscriptions and a queue with underlying services. The aim is to efficiently push the order payload into SAP CI.
Outbound data flow
The outbound portion of the architecture diagram illustrates the outbound data replication scenarios from commercetools to SAP S4/HANA or SAP ERP, using SAP CI.
Outbound data replication scenarios
Integration best practices
To ensure a seamless flow of data and maintain the highest standards of security and reliability, prioritize the following aspects:
-
Accurate data mapping and transformation: ensure that the data remains consistent and compatible across both systems, preserving its integrity and relevance.
-
Authentication and security: secure data transmission is key. Implementing reliable authentication mechanisms safeguards data during transfer. Additionally, adherence to the security best practices of both commercetools and SAP ERP is crucial for maintaining data confidentiality.
-
Error handling and logging: develop strong error-handling protocols to manage any discrepancies or failures that might occur during the integration process. Coupled with comprehensive logging, these measures provide valuable insights for troubleshooting and enable continuous monitoring of the system's performance.
Cloud-based integration options
An alternative option to middleware solutions like SAP CI, MuleSoft, and Boomi, is building the integration with cloud services offered by AWS, Google Cloud, or Azure. For this approach, we recommend the following:
- Use SAP Gateway for data accessibility: SAP Gateway provides access to SAP data through APIs using the OData protocol. OData, an Open Data Protocol, adheres to OASIS standards and is ISO/IEC approved. Running data over HTTPS ensures secure internet connectivity and supports hybrid, multi-cloud environments with scalability for varying data volumes. SAP Gateway offers extensive options for extracting SAP data, moving beyond traditional protocols like RFC or IDOC.
- Expose SAP data endpoints over APIs: specific versions of SAP ERP and SAP S/4HANA expose various data endpoints and services over APIs through the SAP Gateway using the OData protocol. This setup enables data extraction, such as product information, from SAP systems to cloud-based services or storage solutions like Amazon S3 or Azure Data Lake Storage.
- Integrate with cloud provider services: cloud providers offer built-in services that support the OData protocol, simplifying communication with the SAP backend. This includes importing OData metadata for streamlined API and schema creation. Within the cloud provider's environment, OData APIs are mapped to the provider-specific API layer (like Azure API Management or Amazon API Gateway), which then manages communication with the SAP backend. This layer also addresses critical aspects such as authentication, authorization, and security.
- Transform and integrate data into commercetools: post-extraction, the data must be transformed from the OData XML format to the JSON format used by commercetools APIs. This transformation can be accomplished using various libraries and cloud functions like AWS Lambdas or GCP Cloud Functions. The transformed data is then integrated into commercetools Composable Commerce using APIs, such as the Import API. This logical layer also handles errors, retries, and timeouts during the integration process.
This alternative cloud-based integration approach offers flexibility and scalability, providing a robust solution for linking SAP ERP systems with commercetools without relying on traditional middleware platforms.
Build an integration on Connect
With Connect, on the other hand, developers can make use of the event type Connectors. By specifying the queue name and its properties, Connect can handle getting all the components set up. Developers can then focus on handling event logic and data mapping.
Overall, Connect can help reduce the operational overhead and risk of building, hosting, and maintaining integrations between Composable Commerce and the ERP.