Listening to Events
In many cases, you’ll want your bot to respond to user interactions such as replies and mentions. The Bot class is preconfigured to emit events whenever the bot account receives a like, mention, follow, reply, repost, or quote post. You can listen to these events by calling the on method on your bot instance.
In this example, the bot listens for replies and responds by liking the reply and replying with a message. The full list of events you can listen to are:
like
: Emitted when the bot receives a like.mention
: Emitted when the bot is mentioned.follow
: Emitted when the bot is followed.reply
: Emitted when the bot receives a reply.repost
: Emitted when the bot receives a repost.quote
: Emitted when one of the bot’s posts is quoted.
You can additionally receive the message
event if you choose to listen for chat events — more on that in Chatting with Users!
The documentation for the Bot#on
method provides more information on the data you can receive for each event.
Configuration
The bot uses a polling mechanism to listen for events. This means that the bot will periodically check for new events via the same endpoint used by client applications to receive notifications. You can configure the polling interval by passing an eventEmitterOptions
object to the Bot constructor.
By default, the bot will poll every 5 seconds. Keep in mind that the total rate limit available to an account, as of writing, is 3000 requests per 5 minutes. Polling for notifications uses 60 requests per 5 minutes under the default interval. If you expect to receive a high volume of events or will be doing several actions for each event, you may want to increase the polling interval to avoid hitting the rate limit.
The eventEmitterOptions
object also takes a processFrom
Date
object, allowing you to ignore notifications that occurred before a certain time. This can be useful if you want to avoid processing old notifications when your bot starts up.
Jetstream
If real-time updates are important to your bot, you can configure your Bot
instance to listen for events directly via a WebSocket connection to Jetstream.
Be aware that this will mean maintaining an open WebSocket connection that will receive a feed of events occurring on the Bluesky network. This can be bandwidth-intensive compared to polling.
To begin, you will need to install the @skyware/jetstream
package:
Then, you’ll need to set the strategy
option accordingly:
Alongside the strategy
option, you can optionally pass a jetstreamOptions
object within eventEmitterOptions
, which will allow you to set a cursor
to resume from a specific time (expressed in microseconds) in the event stream.
After the initial setup, use of the Bot#on
method remains the same.
Shutting Down
When you’re done listening for events, you can call the Bot#off method to remove an event listener, or the Bot#removeAllListeners method to stop listening for events entirely. It is recommended to shut down the bot gracefully using these methods, especially if you are using the Jetstream strategy.
Next Steps
Now that you know how to listen for events, you can start building interactivity into your bot. Continue to the next guide to learn how to chat with users!