Skip to content

Make it easy for Process Builder to post Chatter messages authored as any user with rich-text and @mentions.

License

Notifications You must be signed in to change notification settings

mhumpolec/salesforce-chatter-bot-feeds

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Salesforce Chatter Bot for Feeds

image

Overview

Chatter Bot for Feeds enables you to post Chatter messages authored by any user. The best part is that you can automate these messages with Process Builder or Flow! Although there are many ways to post Chatter messages in Salesforce using Process Builder, Flow, Apex, or API, no one approach satisfied all of my requirements:

  1. Must be easy to use and launchable by Process Builder or Flow (declarative)
  2. Must support setting the author to someone other than the running user
  3. Must support rich-text
  4. Must support @ mentions

To learn more about my design decisions, please read my blog post introducing Chatter Bot for Feeds.

Installation & Getting Started

Video Tutorial getting-started-video

  1. Follow the Getting Started steps and deploy Chatter Bot for Groups. (the examples depend on this)
  2. Deploy Chatter Bot for Feeds.
  3. In Setup, create an Email Service using apex class ChatterBotPostMessageEmailHandler then create an Email Address. Set the Context User for the email service address to an administrator user. Take note of the generated email address as we will use it in a future step.
  4. Assign the Chatter Bot Feeds Admin permission set to the Context User you chose. This allows setting the author for new Chatter posts to someone other than the current user.
  5. Create a Chatter Free user and set their email address to be the same as the Email Service Address from Step 3.
  6. Create a default organization default value for the Chatter Bot Feeds Setting custom setting and copy into the Email Service Address User ID field the ID of the Chatter Free user from Step 5.
  7. To test, add yourself or another user to a Chatter Group monitored by Chatter Bot for Groups (see Step 1). Within a couple seconds you should be able to refresh that group's feed and see the welcome post. Congratulations!

Next Steps

Now that you have all the configuration in place, now it's time to focus on your actual use cases for automating Chatter posts and deciding who you want the author to be in each of those scenarios.

Email Templates: Fancy Messages

Refer to the Chatter Bot Post Message Template email template for examples of supported rich-text in Chatter posts and the syntax for @ mentions. Your messages can also include merge fields from a record identified by the variable Record ID (Template Merge Fields) when invoking the CB: Post Message Apex method in Process Builder.

Alternatively, rather than specify values for Email Template Unique Name and Record ID( Template Merge Fields variables, you can use the Message variable to specify your Chatter message right within Process Builder. Sometimes that is an easy option for simple messages.

Process Builder

Refer to the example process named Chatter Bot - Welcome New Group Member. There is one Immediate Action that demonstrates how to invoke the CB: Post Message Apex method. By default, the Author User ID is set the $User.Id, the current user who causes the process to fire. For your purposes, you will want to change that to your desired Chatter post author such as a community manager, the CEO, a comical Chatter Free user, whatever.

image

Responsibility

As the #AwesomeAdmin that you are, you understand that with great power comes great responsibility. Impersonate other users on Chatter with care and always have consent from the intended author before automating posts by them. Thanks!

image

FAQ

Why do I get error "The object named Chatter_Bot_Group_Member__c can't be found." during deployment?

The example Process Builder included in Chatter Bot for Feeds is designed for the use case when users join a group. That capability is only provided through Chatter Bot for Groups. See also question Can Chatter Bot for Feeds be used without Chatter Bot for Groups?.

Can Chatter Bot for Feeds be used without Chatter Bot for Groups?

In practice, yes. For deployment, not at this time. The example Process Builder included in Chatter Bot for Feeds is designed for the use case when users join a group. That capability is only provided through Chatter Bot for Groups. Once deployed, you can begin automating Chatter posts for any reason you want using Process Builder or Flow. The dependency on Chatter Bot for Groups is just for the example Process Builder.

Why do I need an Email Service to make Chatter posts?

The Email Service is only so that we can get code to execute as an administrator and not the current user. Technically, you don't need it to post Chatter messages unless you have these three requirements:

  1. You want to set the author to someone other than the running user
  2. You want to post a rich-text message
  3. You want to @ mention users or groups

To learn more about my design decisions, please read my blog post introducing Chatter Bot for Feeds.

Why is a Chatter Free user necessary for the Email Service?

Not for any technical reason to get this solution to work but rather to avoid using up any of your org's daily email quota. Apex can send a certain number of emails to external addresses each day, but an unlimited number of emails can be sent to internal users. Using a Chatter Free user for this purpose is a free and easy way around the Apex limitation.

Where will the Chatter post be made to?

You can specify a User ID, Chatter Group ID, or record ID where you would like the Chatter post to be made. If you specify a FeedItem ID (a Chatter post ID) then a FeedComment will be created for that Chatter conversation instead of a whole new Chatter post.

About

Make it easy for Process Builder to post Chatter messages authored as any user with rich-text and @mentions.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Apex 100.0%