data:image/s3,"s3://crabby-images/c57ee/c57ee5003341688c04a139c259423ab6010cf7d6" alt=""
Event Relay can be used to send Salesforce Platform Events to Amazon EventBridge.
1. Create a Platform Event in Salesforce.
data:image/s3,"s3://crabby-images/e1195/e1195aa11a71eb2ccd3c80a1d9284e5f545a7f4a" alt=""
2. Create a Connected App in Salesforce.
Callback URL should be https://{Your Domain}.my.salesforce.com/services/oauth2/callback
Example:
https://test-ec-dev-ed.develop.my.salesforce.com/services/oauth2/callback
data:image/s3,"s3://crabby-images/a9320/a93200763815b36d931dd444cdce0ccfdccb1b98" alt=""
3. Get the Access token.
Endpoint URL:
https://test-ec-dev-ed.develop.my.salesforce.com/services/oauth2/token
data:image/s3,"s3://crabby-images/170d6/170d60d6586075d9fcd72cbfc6a002bc8bc25ab3" alt=""
4. Use the Access Token from Step 3 and make a POST Request to create PlatformEventChannel.
Endpoint:
Header:
data:image/s3,"s3://crabby-images/9efeb/9efebbe73a7557cfbad7c04e18664fb933f69206" alt=""
Body:
data:image/s3,"s3://crabby-images/2639c/2639c13897078ea4fe3e651c6011734573436e1f" alt=""
5. Make a POST Request to create PlatformEventChannelMember.
Endpoint:
Header:
data:image/s3,"s3://crabby-images/1f476/1f47694592462271e6c40b0ef30ce4d63169e1ef" alt=""
Body:
data:image/s3,"s3://crabby-images/0a904/0a904142ad1acb72f8bf9f407c4a4a8c7b16f817" alt=""
6. Create a Legacy Named credential with URL in the following format.
arn:aws:aws_region:aws_account_number
data:image/s3,"s3://crabby-images/e7f6a/e7f6a6171c5d866456ed9c4a0f796286ccf381ce" alt=""
7. Make a POST Request to create EventRelayConfig.
Endpoint:
Header:
data:image/s3,"s3://crabby-images/91dda/91dda69a837b0b12278b9d2e742252ab240a6ed3" alt=""
Body:
data:image/s3,"s3://crabby-images/f86f7/f86f73cbb8e44e3ff57291e8030ff2d3ec65a435" alt=""
8. Use the following SOQL and execute in your Salesforce Developer Console.
SELECT Id, RemoteResource, Status,
ErrorMessage, ErrorTime, ErrorIdentifier
FROM EventRelayFeedback
WHERE EventRelayConfigId ='7k23t0000008OI5AAM'
Note down the RemoteResource value.
9. Search the RemoteResource in Amazon EventBridge. Use the Associate with event bus button to associate the Salesforce Partner Event Source.
data:image/s3,"s3://crabby-images/d7521/d7521e15d9689afcde2a27d05129ed5da91163b5" alt=""
10. Start the Event Relay by setting the State to RUN. Do a PATCH Request.
Header:
data:image/s3,"s3://crabby-images/ea914/ea914d08f0ed3224f8b06c7316ec762418f19728" alt=""
Body:
data:image/s3,"s3://crabby-images/eaeb4/eaeb4e39f9b956b551aebe1bd8c264189a70b0d7" alt=""
11. Create a Rule in Amazon Eventbridge. Use the following Pattern.
{
"source": [{
"prefix": "aws.partner/salesforce.com"
}],
"detail-type": ["Employee__e"]
}
data:image/s3,"s3://crabby-images/4d1b3/4d1b30b2dfe65c4ee97c505b8ad4cab999e05987" alt=""
12. Use the following code to Publish a Platform Event.
List < Employee__e > listEvents = new List <Employee__e >();
listEvents.add(
new Employee__e(
Employee_Number__c = '12345',
Notes__c = 'Testing'
)
);
List < Database.SaveResult > results = EventBus.publish( listEvents );
for ( Database.SaveResult sr : results ) {
if ( sr.isSuccess() ) {
System.debug( 'Event successfully published event.' );
} else {
for(Database.Error err : sr.getErrors()) {
System.debug( 'Error code: ' + err.getStatusCode() );
System.debug( 'Error message: ' + err.getMessage() );
}
}
}
13. Check in Amazon CloudWatch log group.
data:image/s3,"s3://crabby-images/75c38/75c3874f3f2e8aec3a265f44bb23cccecee25c16" alt=""
data:image/s3,"s3://crabby-images/ee306/ee306e81d34dba1f7468c77f3be886f30d806796" alt=""
data:image/s3,"s3://crabby-images/d9348/d9348e9ff305b8677532f58fcc6b2044256ba5b8" alt=""