Skip to content

Latest commit

 

History

History
51 lines (47 loc) · 1.77 KB

File metadata and controls

51 lines (47 loc) · 1.77 KB

Integrate a third-party customer group created event with Adobe Commerce.

This runtime action is responsible for notifying the integration with Adobe Commerce after a customer is created in the 3rd party.

Alt text

Incoming event payload

The incoming event payload depends on the third party API and entity model. Here is a payload example of the data received in the event:

{
  "name": "A Group Name",
  "taxClassId": 25
}

Data validation

The incoming data is validated against a JSON schema defined in the schema.json file. Here's an example:

{
  "type": "object",
  "properties": {
    "name": { "type": "string" },
    "taxClassId": { "type": "number" }
  },
  "required": ["name", "taxClassId"],
  "additionalProperties": true
}

Interact with the Adobe Commerce API

The sendData function in the sender.js file defines the interaction with the Adobe Commerce API. This function delegates to the createCustomerGroup method in the actions/customer/commerce-customer-group-api-client.js interaction with the Commerce API. Any parameters needed from the execution environment could be accessed from params. These parameters can be passed on the action by configuring them in the actions/customer/external/actions.config.yaml under group-created -> inputs as follows:

group-created:
  function: group/created/index.js
  web: 'no'
  runtime: nodejs:20
  inputs:
    LOG_LEVEL: debug
    COMMERCE_BASE_URL: $COMMERCE_BASE_URL
    COMMERCE_CONSUMER_KEY: $COMMERCE_CONSUMER_KEY
    COMMERCE_CONSUMER_SECRET: $COMMERCE_CONSUMER_SECRET
    COMMERCE_ACCESS_TOKEN: $COMMERCE_ACCESS_TOKEN
    COMMERCE_ACCESS_TOKEN_SECRET: $COMMERCE_ACCESS_TOKEN_SECRET
  annotations:
    require-adobe-auth: true
    final: true