This simple app uses the Salesforce Streaming API to listen for events in Salesforce and then sends them to Kafka.
-
In Salesforce, create a PushTopic using the Execute Anonymous Apex feature in the Developer Console:
PushTopic pushTopic = new PushTopic(); pushTopic.Name = 'ContactUpdates'; pushTopic.Query = 'SELECT Id, Name FROM Contact'; pushTopic.ApiVersion = 36.0; pushTopic.NotifyForOperationCreate = true; pushTopic.NotifyForOperationUpdate = true; pushTopic.NotifyForOperationUndelete = true; pushTopic.NotifyForOperationDelete = true; pushTopic.NotifyForFields = 'Referenced'; insert pushTopic;
-
Add the Heroku Kafka Addon to the app
heroku addons:add heroku-kafka -a YOUR_APP
-
Install the Kafka plugin into the Heroku CLI
heroku plugins:install heroku-kafka
-
Wait for Kafka to be provisioned:
heroku kafka:wait -a YOUR_APP
-
Add a new Kafka topic:
heroku kafka:topics:create ContactUpdates --partitions 32 -a YOUR_APP
-
Watch the Kafka log
heroku kafka:topics:tail ContactUpdates -a YOUR_APP
-
Make a change to a Contact in Salesforce and you should see the event in the Kafka log.
This uses the same Kafka system as above.
-
Clone the source:
git clone https://github.com/jamesward/hello-kafka-salesforce
-
Setup a
.env
file with the necessary info:heroku config -s > .env echo "SALESFORCE_USERNAME=<YOUR SALESFORCE USERNAME>" >> .env echo "SALESFORCE_PASSWORD=<YOUR SALESFORCE PASSWORD>" >> .env set -o allexport source .env set +o allexport
-
Run the app:
./activator ~run