Sunday, 10 May 2020

Subscribe platform event from an external app using EMP Connector


Subscribe Platform Event from an External app using EMP Connector

      External apps can subscribe to platform events with CometD and perform long polling. CometD is a scalable HTTP-based event routing bus that uses an AJAX push technology

   Salesforce provides a Java library, EMP Connector, which implements all the details of connecting to CometD and listening on a channel. You can use EMP Connector to subscribe easily to platform events.


EMP Connector is a free, open-source, community-supported tool. Salesforce provides this tool as an example of how to subscribe to events using CometD. EMP Connector is based on Java 8 and uses CometD version 3.1.0. It supports username and password authentication and OAuth bearer token authentication. This walkthrough shows steps only for username and password authentication.



Let's look at an example:

Step1: Create a platform Event Object


As you can see in the screenshot I created one PE and added a custom  text field "Account_Name__c"

Step2: Create a process builder on Account to publish Platform Event 




when an account record is created or edited this process builder will create a record in Platform Event Object(publish a PE)

Step3: Subscribe Platform Event from an external application

1. You can download the EMP Connector project from:
https://github.com/forcedotcom/EMP-Connector
and then extract the zip to a local folder.  

2. In Eclipse, import the Maven project from the folder where you cloned or extracted the project. The dependencies that are specified in the Maven’s pom.xml file, such as CometD, are added in the Java project in Eclipse.   


3. You Subscribe to an event channel by running the LoginExample class(/src/main/java/com/salesforce/emp/connector/example folder)

Related Post:


Sunday, 3 May 2020

Publish platform events from an external application


Publish platform events from an external application using Salesforce API

External apps use an API to publish platform event messages. You can publish events by creating records of your event in the same way that you insert sobjects. You can use Salesforce APIs to create platform event records.

Let's look at one example:

Step1: Create a platform Event Object


As you can see in the screenshot I created one PE and added a custom  text field "Account_Name__c"

Step2: Create a trigger on PE object to subscribe to Platform Event 




This after trigger will subscribe to Platform Event and create accounts with the event message name.

Step3: Publish Platform Event

You can use sobject REST endpoint to publish:


/services/data/v48.0/sobjects/Account_Event__e/


Request body for a POST request will be like this :


{
  "Account_Name__c":"New PE Test Account"
}






Like this, you can publish a platform event from outside salesforce and you add your all logic in PE trigger.

Related Post:


Saturday, 2 May 2020

Integrating with Salesforce using Platform Events


Integrating with Salesforce using Platform Events

     
        If you want to integrate Salesforce with multiple External Systems, and that you only want the External Systems to receive data from Salesforce. let’s say you want to notify an external system(s) whenever a record changed in salesforce. In this case, you can use callouts/outbound messaging but that will mean Salesforce takes care of every callout and callout logic. This is where you can use Platform Events. In this case, whenever there’s an update, you just Publish an Event and then Subscribers(external system) keep on listening to the Salesforce Event bus.

      You can also use Platform Events when you want an External System notifies Salesforce, where the External System Publish the change on the Salesforce Event Bus and then Salesforce listens to those Events and salesforce can perform actions using the platform event trigger as required whenever get the notification.

Platform Event:

The Salesforce enterprise messaging platform offers the benefits of event-driven software architecture. Platform events are the event messages that your apps send and receive. They simplify the process of communicating changes and responding to them without requiring you to write complex logic. Publishers and subscribers communicate with each other through platform events. One or more subscribers can listen to the same event and carry out actions.

Publishing Platform Event: 
  • Using APEX you can Publish Platform Events.
  • Publish Events using Declarative tools (Process Builder/flow).
  • Publish Events Messaging using Salesforce API from an external app.
Subscription of Platform Event: 
  • Apex trigger on the event object to subscribe to incoming events.
  • Lightning component apps and Visualforce can receive events through CometD.
  • In an external app, you can subscribe to events using CometD as well. 
Replay Option(ReplayID) for Event Retention:

Each event record contains a system field, called ReplayID, that the system populates after the event is published.
                    
Platform event setup
PE Setup


Usage: Catch up on missed events after a certain event message, for example, after a connection failure. To subscribe with a specific replay ID, save the replay ID of the event message after which you want to retrieve stored events. Then use this replay ID when you re-subscribe.
               ReplayID refers to the position of the event in the event stream. Replay ID values are not guaranteed to be contiguous for consecutive events(-2 option to receive events from the beginning and –1 option to receive new events). You can retrieve stored event messages as long as they are within the retention window of 72 hours.


ReplayID Stream


Publish Events using Salesforce API from an external app(External App to Platform app)


       External apps use an API to publish platform event messages. You can publish events by creating records of your event in the same way that you insert sobjects. You can use Salesforce APIs to create platform event records.

Usecase: Let’s say someone wants to return purchased merchandise to a vendor. An external system sends merchandise return requests to Salesforce for processing. The external system publishes a platform event to alert Salesforce to the merchandise return. An event listener (a trigger) in Salesforce receives the event and performs some actions. For example, the trigger might alert the sales representative to the return, and send a confirmation email to the customer.

Subscribe events from an external app (Platform to an external app)

External apps subscribe to platform events with CometD and perform long polling. CometD is a scalable HTTP-based event routing bus that uses an AJAX push technology

   Salesforce provides a Java library, EMP Connector, which implements all the details of connecting to CometD and listening on a channel. You can use EMP Connector to subscribe easily to platform events.

Usecase: When an opportunity closes in Salesforce, your company has won a deal with a customer. Let’s say you use vendors to ship products associated with an opportunity. Each vendor has an external app that processes shipment orders. The external app listens to platform events. When an opportunity closes, a trigger, which is part of a product order app in Salesforce, fires and publishes a platform event message. Each vendor app is notified of the event and creates a shipment order for a specific product.
Subscribe events from an external application


Key points to remember when you considering the platform event for your integration:

  • PE is designed for Pub/Sub integration model
  • PE is not supported to transfer a lot of data(The maximum event message size that you can publish is 1 MB).
  • You can use PE when you only want to “notify” the external system(s) with an event or message with minimal information for them to act upon.