WebSockets (Socket.IO)
🔔 Connect your scenarios and web-app in real-time
What is WebSocket
The WebSocket API, built on socket.io technology, is an advanced feature that makes it possible to open a two-way interactive communication session between a user's browser and a server. Through this API, you can send messages to the server and receive event-driven responses, all without the need to continuously poll the server for replies.
How to Add WebSockets to Your App:
1) Select the app you want to add a WebSocket to
2) Go to the Plugins section and install the Socket.io plugin.
Where Can You Use WebSocket API (Socket.IO)?
If you use Directual web-page builder:
Refresh the page (e.g. update the content after submitting the form — that is an alternative to synchronous scenarios)
Alert users with Toast notifications
If you use external front-end (e.g., ReactJS):
Receive signals about changes in systems and refresh data instantly
Build interactive messengers 💬
Build scenarios with messages for specific users (alerts, notifications and etc.).
How to Use Sockets for user notifications
Create a scenario that calls socket plugin (send PUSH-message step)
Configure your message.
There are two options for configuring the message: simple and complex.
Simple notification:
Complex notification (with notification settings like position, duration, etc.)
Notifications are based on React-hot-toast. Find the full list of parameters here
Example of a message:
Message in the app:
How to Use Sockets in Web-page Builder as a refresher
Create a scenario that calls socket plugin (send PUSH-message step)
Add a refresher to the page (if needed)
The Refresher web-plugin (indicate the event_name
):
Scenario with the same event_name
:
Message: no need here (although you can combine refresher and user notifications)
Event name: the same
event_name
UserID: set
*
if you want to broadcast the message. set user's ID if you want to send a message to a certain user.
Here is how it works:
How to Use WebSockets in React Apps
You can find an example template with Socket.IO support in Directual and React JS section.
Create a user and log in (for example, the user's ID is
testUser
)Go to
WebSocket Page
Create a scenario, add Send PUSH-message step (it is a part of Socket.io plugin):
Configuring the step:
UserID: set
*
if you want to broadcast the message. set user's ID if you want to send a message to a certain user (in our case — testUser)
Event name: the first parameter of socket event (
eventName
)Message: the second parameter of socket event (
args
)
Have a look at the boilerplate, websocket.js:
Here is how it works (we send objects to the scenario, the web-page is refreshed without reload):
How to Use WebSocket API in Any Apps
You can use any WebSocket API (Socket.IO) client in any app.
Directual offers a standard endpoint for connection to WebSockets: https://api.directual.com
You can see how to connect and receive messages from the Platform in the code below:
Last updated