Skip to main content
Build the future with Agentforce at TDX in San Francisco or on Salesforce+ on March 5–6. Register now.

Create a Data Processing Engine Definition

Create a DPE Definition

It’s time to create the new DPE definition and add the data source nodes, join nodes, and filter nodes. You can create a DPE definition in two ways: by adding nodes in the builder or by uploading a JSON file to the builder. For this project, you use the builder to create and define each node.

Note

For guidance on using a JSON file to define or update a DPE definition, see Create or Edit a Data Processing Engine Definition in a JSON File.

Now, access your Developer Edition org and use it to complete all the steps in this project.

  1. Click Setup , and select Setup.
  2. Enter Data Processing Engine in the Quick Find Box.
  3. Under Workflow Services, click Data Processing Engine.
  4. Click New.
  5. Add the following details.
    • Name: Create Transaction Journals From Orders
    • API Name: This field auto-populates with Create_Transaction_Journals_From_Orders
    • Process Type: Loyalty
      This helps you group all loyalty-related definitions.
      The New Data Processing Engine Definition window where you enter the definition details.
  1. Click Next.
  2. Select CRM Analytics at the runtime platform.
  3. Click Done.
    The New Data Processing Engine Definition window where you select the runtime platform.

The DPE builder opens with the newly created definition. Next, Linda adds all the required nodes to this definition.

Add the Data Sources

Linda has identified three objects to use as data sources: Order, Loyalty Program Member, and Contact. She creates a data source node for each object.

Data Source: Order

The Order object contains the order amount, status, start date, account name, program partner, and more. This object has a few custom fields.

  • ActivatedDate: This date field is used to filter orders after a specified date.
  • Loyalty Program Partner: This field provides partner details, which the loyalty program uses to process rewards.
  • Order Status Copy: The order status can be Pending or Processed. The definition only considers orders that are pending.

Here’s how to create a data source for orders.

  1. Click New Data Source Node.
  2. Enter these details:
    • Name: Orders
    • API Name: Auto-populates with Orders
  3. Click Save.
    The New Node window where you enter a name for the node.
  4. Select Source Object as Order.
  5. Click Select Fields, and select:
    • Account Name
    • Activated Date
    • ActivatedDate
    • Loyalty Program Partner
    • Order Amount
    • Order ID
    • Order Number
    • Order Start Date
    • Order Status Copy
    • Status
  6. Change the alias for Account Name to Order_AccountId
  7. Change the alias for Order ID to Order_Id
  8. Click Save twice.
  9. Save your work.

Data Source: Loyalty Program Member

Now add the Loyalty Program Member object as a data source to fetch details about program members.

  1. Click New Node.
  2. Select Node Type as Data Source.
  3. Enter these details:
    • Name: Loyalty Program Members
    • API Name: Auto-populates with Loyalty_Program_Members
  4. Click Save.
  5. Select Source Object as Loyalty Program Member.
  6. Click Select Fields, and select:
    • Contact
    • Loyalty Program
    • Loyalty Program Member ID
    • Member Status
    • Membership Number
  7. Click Save twice.
  8. Save your work.

Data Source: Contact

Next, add the Contact object as a third data source.

  1. Click New Node.
  2. Select Node Type as Data Source.
  3. Enter these details:
    • Name: Contacts
    • API Name: Auto-populates with Contacts
  4. Click Save.
  5. Select Source Object as Contact.
  6. Click Select Fields, and select:
    • Account Name
    • Contact
    • Contact ID
    • First Name
    • Last Name
    • Name
  7. Click Save twice.
  8. Save your work.

You now have information about all orders, contacts, and loyalty program members. Next, join the information about members and contacts.

Join Program Members and Contacts

An order has customer information but not member information. To join contact and member information, use an inner join node to ensure only the matching fields from both source nodes are part of the output.

  1. Click New Node and add the following details.
    • Node Type: Join
    • Name: Join Program Members and Contacts
    • API Name: Auto-populates with Join_Program_Members_and_Contacts
  2. Click Save.
  3. Select Join Type as Inner.
  4. Add the following details under First Node.
    • Source Node: Loyalty Program Members
    • Select the following fields:
      • Id
      • MembershipNumber
      • MemberStatus
      • ProgramId
  5. Click Save.
  6. Add the following details under Second Node.
    • Source Node: Contacts
    • Select the following fields:
      • AccountId
      • Name
  7. Click Save.
  8. Add the following details under Mapped Fields.
    • First Node Field: ContactId
    • Second Node Field: Id
  9. Click Save.
    The join node to join program members and contacts.
  10. Save your work.

The join node provides a list of contacts and members that share the same contact ID. Next, to ensure the definition only processes active orders that are associated with active members, you create two filter nodes.

Filter Active Orders

Once an order is created and ready for processing, it has an Activated status. The first filter includes only those orders where the Status is Activated and the Order Status Copy is Pending. After processing the order for loyalty rewards, the DPE definition updates the Order Status Copy to Processed.

To ensure the definition picks up valid orders, create an input variable to set the order activated date as greater than or equal to the start date.

First, create the input variable.

  1. Click Open the Nodes and Input Variables panel .
  2. Click the Input Variables tab.
  3. Click New Input Variable.
  4. Add the following details.
    • Name: StartDate
    • API Name: Auto-populates with StartDate
    • Type: Date
    • Value: 1st January 2024
  5. Click Save.
    The Input Variable window where you configure variables to use in the definition.
  6. Save your work.

Next, create the filter.

  1. Click New Node and add the following details.
    • Node Type: Filter
    • Name: Filter Active Orders
    • API Name: Auto-populates with Filter_Active_Orders
  2. Click Save.
  3. Click the Filter Active Orders node and select Configure.
  4. Select Source Node as Orders.
  5. For Select Records When, ensure All Conditions Are Met (AND) is selected.
  6. Add the following details for the first filter condition.
    • Resource: Status
    • Operator: Equals
    • Type: Field
    • Value: Activated
  7. Click Add Condition.
  8. Repeat steps 6 and 7 with the following details to add the second and third filters.

Resource

Operator

Type

Value

OrderStatusCopy_c

Not Equals

Field

Processed

ActivatedDate_c

Greater Than or Equal

Input Variable

StartDate

  1. Click Save.
  2. Save your work.
    The filter node to filter active orders.

Remember, in addition to active orders, you also need a second filter node to get records for active members.

Filter Active Loyalty Program Members

Keep in mind that the active members must belong to the loyalty program. To ensure the definition filters the correct program name, you need a second input variable to fetch the name.

  1. Click Open the Nodes and Input Variables panel .
  2. Click the Input Variables tab.
  3. Click New Input Variable.
  4. Add the following details.
    • Name: Program ID
    • API Name: Auto-populates with Program_ID
    • Type: Text
  5. Click Save.

Next, create the filter with two conditions.

  1. Click New Node and add the following details.
    • Node Type: Filter
    • Name: Filter Active Loyalty Program Members
    • API Name: Auto-populates with Filter_Active_Loyalty_Program_Members
  2. Click Save.
  3. Click the Filter Active Loyalty Program Members node and select Configure.
  4. Select Source Node as Join Program Members and Contacts.
  5. For Select Records When, ensure All Conditions Are Met (AND) is selected.
  6. Add the following details for the first filter condition.
    • Resource: MemberStatus
    • Operator: Equals
    • Type: Field
    • Value: Active
  7. Click Add Condition.
  8. Add the following details for the second filter condition.
    • Resource: ProgramId
    • Operator: Equals
    • Type: Input Variable
    • Value: Program ID
  9. Click Save.
    The filter node to filter active program members.
  10. Save your work.

You’ve got the relevant program members and the orders. In the next step, you join this information.

Resources

Condividi il tuo feedback su Trailhead dalla Guida di Salesforce.

Conoscere la tua esperienza su Trailhead è importante per noi. Ora puoi accedere al modulo per l'invio di feedback in qualsiasi momento dal sito della Guida di Salesforce.

Scopri di più Continua a condividere il tuo feedback