Sitecore OrderCloud Documentation

docs

Portal login

Delivery Configuration

Published by Marc Bednar on June 28, 2023

Overview

Delivery configuration allows you to determine where messages are to be delivered.  Two types of delivery configurations exists: Custom and Known integrations.

Custom integrations allow you to have 100% control over the integration and allows you to deliver these messages to:

  • A Kafka instance

  • An EventHub instance

  • An Http endpoint

  • An Azure Blob

  • Azure Tables

  • A CosmosDb database

  • A Message Sender

To leverage out-of-the-box integrations, you make use of the following Known integrations.

  • The SearchIngestion API

  • The Discover Event API

  • The Send Event API

  • The Mandrill API

Known integrations can only be used with specific OrderCloud integrations points.  For example:

  • The Search Ingestion API can only be used with the ProductSync feature.

  • The Discover and Send Event API can only be used with the TrackingEvent feature.

All Custom integrations can be used with any of the above integrations.

When defining a delivery configuration you can send messages to multiple Custom Integrations with a single known integration.  For example, you could send the Send Event message to the Send collector API and also decide to send it to none, all or any of the custom integration endpoints.

The delivery configuration will be expanded in the future to support other known OrderCloud integrations.

Delivery Configuration Endpoints

Models

DeliveryConfig

1{
2 "ID": "",
3 "Name":"",
4 "Enabled": true | false,
5 "DeliveryTargets": { }
6}

 DeliveryTargets

1{
2 "Kafka": { },
3 "Http": { },
4 "EventHub": { },
5 "SendEvent": { },
6 "DiscoverEvent": { },
7 "AzureBlob": { }
8}

Kafka

1{
2 "BootstrapServers" : "",
3 "SaslUsername" : "",
4 "SaslPassword" : "",
5 "Topic" : ""
6}

Http

1{
2 "Endpoint": "",
3 "Secret": ""
4}

The Secret enables the same functionality as defined for Webhooks.

EventHub

1{
2 "ConnectionString": "",
3 "EventHubName": ""
4}

AzureBlob

1{
2 "ConnectionString": "",
3 "OverrideContainerName": ""
4}

The ConnectionString represents the storage account connection string.

AzureTable

1{
2 "ConnectionString": "",
3 "OverrideTableName": ""
4}

The ConnectionString represents the storage account connection string.

CosmosDB

1{
2 "ConnectionString": "",
3 "OverrideDatabaseName": ""
4}

MessageSender

1{
2 "Secret": "",
3 "EndPoint": ""
4}

The Secret enables the same functionality as defined for Webhooks.

SearchIngestion

1{
2 "Domain": "",
3 "Source": "",
4 "Endpoint": "",
5 "Entity": "",
6 "ApiKey": ""
7}

SendEvent

1{
2 "SiteID" : "",
3 "ServiceEndpoint": ""
4}

 DiscoverEvent

1{
2 "ApiKey" : ""
3 "ClientID": "",
4 "ServiceEndpoint":  ""
5}

Mandrill

1{
2 "ApiKey": ""
3}

New Endpoints

  • GET integrations/deliveryconfig

  • GET integrations/deliveryconfig/{deliveryConfigId}

  • POST integrations/deliveryconfig

  • PUT integrations/deliveryconfig/{deliveryConfigId}

  • PATCH integrations/deliveryconfig/{deliveryConfigId}

  • DELETE integrations/deliveryconfig/{deliveryConfigId}

Custom Implementation Payloads and Models

If you decide to handle the integration, you will need to know what you will be receiving from OrderCloud. Each of the custom configurations used to trigger custom integrations will be composed of protocol specific information along with Common Models depending on the operation that triggered the event.

The event type is also transmitted as part of the data. This tells you what operation triggered the event and is also key to determine the type of model that is included in the payload. In OrderCloud the event type is represented as a namespace with the following values:

Namespace

Description

sitecore.ordercloud.messages.product.updated

Sent when a product has been created or updated.

sitecore.ordercloud.messages.product.deleted

Sent when a product is deleted.

sitecore.ordercloud.messages.orders.lines.added

Sent when a line item is added to an order.

sitecore.ordercloud.messages.orders.lines.updated

Sent when a line item is updated in an order.

sitecore.ordercloud.messages.orders.submitted

Sent when an order is submitted.

sitecore.ordercloud.messages.sessions.identified

Sent when a user logs in and has been identified.

sitecore.ordercloud.messages.ordersync.updated

Sent when an order is updated and OrderSync has been enabled.

sitecore.ordercloud.messages.ordersync.deleted

Sent when an order is deleted and OrderSync has been enabled.

sitecore.ordercloud.messages.entitysync.category.updated

Sent with a category has been updated.

sitecore.ordercloud.messages.entitysync.category.deleted

Sent when a category is deleted.

sitecore.ordercloud.messages.entitysync.adminuser.updated

Sent when an admin user is updated.

sitecore.ordercloud.messages.entitysync.adminuser.deleted

Sent when an admin user is deleted.

sitecore.ordercloud.messages.entitysync.buyeruser.updated

Sent when a buyer user is updated.

sitecore.ordercloud.messages.entitysync.buyeruser.deleted

Sent when a buyer user is deleted.

sitecore.ordercloud.messages.entitysync.inventoryrecord.updated

Sent when a single inventory record has been changed.

sitecore.ordercloud.messages.entitysync.inventoryrecord.full.updated

Sent when a full inventory record sync has been initiated.

sitecore.ordercloud.messages.entitysync.supplieruser.updated

Sent when a supplier user is updated.

sitecore.ordercloud.messages.entitysync.supplieruser.deleted

Sent when a supplier user is updated.

sitecore.ordercloud.messages.entitysync.supplier.updated

Sent when a supplier is updated.

sitecore.ordercloud.messages.entitysync.supplier.deleted

Sent when a supplier is deleted.

sitecore.ordercloud.messages.messagesender.{MessageType}

Send when a message sender is triggered. Represents one of the message types defined in the Message Sender documentation.

Delivery Target Payloads Structure

Http

1{
2 "Headers": {"type":"<value>"},
3 "ConfigData": {},
4 "Payload": {}
5}

This configuration will transmit the payload and models to your implementation via a HTTP(s) post.

The ‘type’ can be found in the Header section of the body of the message.

The “ConfigData” represents any additional information you provided when you enabled the event to be published.

The Payload is dependent on the given ‘type’ as per the table described before.

The http header will contain the following:

  • X-oc-hash - computed hash value using the provided secret as described for Webhooks.

EventHub

Enabling the EventHub config will transmit the payload via an EventData structure defined by Microsoft.

The ‘Properties’ collection contains the following information:

  • type

  • sitecoreorg

  • marketplace

  • tenant

The Payload is dependent on the given ‘type’ and is found in the EventBody of the EventData.

Kafka

Enabling the Kafka config will transmit the payload via a Kafka structure.

The libraries will prefix the extended properties with “ce_” and are the following:

  • ce_type

  • ce_sitecoreorg

  • ce_marketplace

  • ce_tenant

The Payload is dependent on the given ‘type’ and the name of the property is base on the Kafka library you use.

MessageSender

The payload is identical to the one described in the Message Sender documentation.

AzureBlob Containers

 The following containers are used when an AzureBlob delivery configuration target has been specified.

Container

Description

entitysync

Entities synched via EntitySync located.  Sub folders are created for the various entity types.

logs

ErrorConfig logs.

orders

OrderSync orders.

products

ProductSync products.

trackingevents

TrackingEvents events.

webhooks

Webhook payloads when webhooks are configured to use delivery configurations to deliver messages.

 


Still have questions?
Ask in our Community Channel

Content Powered By
Sitecore Logo

© Copyright 2024, Sitecore OrderCloud®. All rights reserved.

Contact Us
Privacy Policy
Sitecore