Connly SDK is a client-side JavaScript SDK, designed to facilitate real-time communication features such as messaging, typing indicators, user presence, and more. It provides an easy-to-use interface for developers to integrate real-time functionalities into their applications.
- Real-time Messaging: Send and receive messages instantly.
- User Presence: Track user statuses like online, offline, etc.
- Typing Indicators: Show when a user is typing.
- Read and Delivery Receipts: Confirm message delivery and read status.
- Call Actions: Handle call-related events.
- Error Handling: Capture and handle connection errors.
Install Connly via npm:
npm install connly
Import Connly into your project using ES6 import syntax:
import Connly from 'connly';
If you're using CommonJS modules, you can use:
const Connly = require('connly');
Create an instance of Connly by providing the server URL and an authentication token:
const serverUrl = 'https://your-socket-server.com';
const token = 'your-authentication-token';
const connly = new Connly(serverUrl, token);
To establish a connection, call the connect()
method after initializing the Connly instance:
connly.connect();
This ensures that a new connection is created. If there's an existing connection, it will be disconnected before creating a new one.
Handle connection and disconnection events:
connly.onConnect(({ isConnected }) => {
console.log('Connected:', isConnected);
});
connly.onDisconnect(({ isConnected }) => {
console.log('Disconnected:', isConnected);
});
Set and listen for user status changes:
// Set your status
connly.setStatus('online'); // Status can be 'online', 'offline', etc.
// Listen for status updates
connly.onStatus((data) => {
console.log('User status updated:', data);
});
Send and receive messages:
// Send a message
const messageContent = {
"message_id": "345e6789-g09c-34e5-c678-636819384002",
"receiver_id": "765e4321-g32b-34e5-c678-636819384789",
"service": "text",
"type": "msg",
"content": "Hello, this is a text message via the in-app text service!"
}
connly.sendMessage(messageContent, (ack) => {
console.log('Message sent acknowledgment:', ack);
});
// Listen for incoming messages
connly.onMessage((data) => {
console.log('Received message:', data);
});
The message format varies depending on the service (text
, sms
, whatsapp
) and the type (msg
, image
, video
, etc.). Below are the detailed examples of how to send messages for text and image formats across different services.
For a simple text message, the service
would be sms
, text
, or whatsapp
, and the type
would be msg
. You only need to include the message content and basic fields.
{
"message_id": "123e4567-e89b-12d3-a456-426614174000",
"receiver_id": "987e6543-e21b-12d3-a456-426614174123",
"service": "sms",
"type": "msg",
"content": "Hello, this is a text message via SMS!"
}
{
"message_id": "234e5678-f98b-23d4-b567-526718274001",
"receiver_id": "876e5432-f21b-23d4-b567-526718274456",
"service": "whatsapp",
"type": "msg",
"content": "Hello, this is a text message via WhatsApp!"
}
{
"message_id": "345e6789-g09c-34e5-c678-636819384002",
"receiver_id": "765e4321-g32b-34e5-c678-636819384789",
"service": "text",
"type": "msg",
"content": "Hello, this is a text message via the in-app text service!"
}
For image messages, the service
can be whatsapp
or text
, and the type
would be image
. You need to include the file URL and optionally the file details.
{
"message_id": "456e789a-h10d-45f6-d789-746920495003",
"receiver_id": "654e3210-h43c-45f6-d789-746920495123",
"service": "whatsapp",
"type": "image",
"content": "Here is an image via WhatsApp!",
"file_url": "https://example.com/image.jpg",
"file_details": [
{
"file_name": "image.jpg",
"file_type": "jpg",
"file_size": 2048,
"file_url": "https://example.com/image.jpg"
}
]
}
{
"message_id": "567f89ab-i21e-56g7-e890-857931516004",
"receiver_id": "543f2109-i54d-56g7-e890-857931516456",
"service": "text",
"type": "image",
"content": "Check out this image in our app!",
"file_url": "https://example.com/image.jpg",
"file_details": [
{
"file_name": "image.jpg",
"file_type": "jpg",
"file_size": 1024,
"file_url": "https://example.com/image.jpg"
}
]
}
Send and receive typing status:
// Send typing status
const typingDetails = {
to: 'recipientUserId',
isTyping: true,
};
connly.sendTypingStatus(typingDetails);
// Listen for typing status updates
connly.onTypingStatus((data) => {
console.log('Typing status:', data);
});
Send and receive read receipts:
// Send read receipt
const readReceiptDetails = {
messageId: 'messageId123',
readerId: 'yourUserId',
};
connly.sendReadReceipt(readReceiptDetails);
// Listen for read receipts
connly.onReadReceipt((data) => {
console.log('Read receipt received:', data);
});
Listen for delivery receipts:
connly.onDeliveryReceipt((data) => {
console.log('Delivery receipt received:', data);
});
Handle call-related events:
// Listen for call actions
connly.onCallAction((data) => {
console.log('Call action received:', data);
});
Listen for presence updates:
connly.onPresence((data) => {
console.log('User presence updated:', data);
});
Handle connection errors:
connly.onError((error) => {
console.error('An error occurred:', error);
});
Manually disconnect from the server:
connly.disconnect();
This will terminate the current socket connection and ensure the system is ready for reconnection if needed.
new Connly(serverUrl, token)
serverUrl
: The URL of the Socket.IO server.token
: Authentication token for secure connection.
connect()
: Establishes a new connection. If an existing connection is present, it will first disconnect.onConnect(callback)
callback
: Function called when the connection is established.- Example:
connly.onConnect(({ isConnected }) => { console.log('Connected:', isConnected); });
onDisconnect(callback)
callback
: Function called when the connection is lost.- Example:
connly.onDisconnect(({ isConnected }) => { console.log('Disconnected:', isConnected); });
disconnect()
: Manually disconnects from the server.- Example:
connly.disconnect();
- Example:
setStatus(status)
status
: String representing the user's status (e.g., 'online', 'offline').- Example:
connly.setStatus('online');
onStatus(callback)
callback
: Function called when a status update is received.- Example:
connly.onStatus((data) => { console.log('User status updated:', data); });
sendMessage(messageContent, callback)
messageContent
: Object containing message details. Must include fields liketo
(recipient user ID) andmessage
(message text).callback
: Optional function called upon acknowledgment.- Example:
const messageContent = { to: 'recipientUserId', message: 'Hello, how are you?', }; connly.sendMessage(messageContent, (ack) => { console.log('Message sent acknowledgment:', ack); });
onMessage(callback)
callback
: Function called when a message is received.- Example:
connly.onMessage((data) => { console.log('Received message:', data); });
Here is the reaction-related method in the README format, as requested:
Send a reaction to a specific message. This could be an emoji or any other type of reaction (e.g., like).
- Parameters:
reaction
: An object containing the reaction details such asmessage_id
,user_id
,reaction_type
,content
, andservice
.callback
: An optional function that will be called when the reaction is acknowledged.
const reaction = {
message_id: "123e4567-e89b-12d3-a456-426614174000",
reaction_type: "π"
};
connly.sendReaction(reaction, (ack) => {
console.log('Reaction sent acknowledgment:', ack);
});
Listen for incoming reactions on messages. This method triggers the callback
whenever a new reaction is received.
- Parameters:
callback
: A function that is called with the reaction data when a reaction is received.
connly.onReaction((data) => {
console.log('Reaction received:', data);
});
sendTypingStatus(details)
details
: Object containing typing status information. Must includeto
(recipient user ID) andisTyping
(boolean).- Example:
const typingDetails = { to: 'recipientUserId', isTyping: true, }; connly.sendTypingStatus(typingDetails);
onTypingStatus(callback)
callback
: Function called when typing status is received.- Example:
connly.onTypingStatus((data) => { console.log('Typing status:', data); });
sendReadReceipt(details)
details
: Object containing read receipt details, such asmessageId
andreaderId
.- Example:
const readReceiptDetails = { messageId: 'messageId123', readerId: 'yourUserId', }; connly.sendReadReceipt(readReceiptDetails);
onReadReceipt(callback)
callback
: Function called when a read receipt is received.- Example:
connly.onReadReceipt((data) => { console.log('Read receipt received:', data); });
onDeliveryReceipt(callback)
callback
: Function called when a delivery receipt is received.- Example:
connly.onDeliveryReceipt((data) => { console.log('Delivery receipt received:', data); });
onCallAction(callback)
callback
: Function called when a call action (like a start or end of a call) is received.- Example:
connly.onCallAction((data) => { console.log('Call action received:', data); });
onPresence(callback)
callback
: Function called when presence information (e.g., user is online/offline) is received.- Example:
connly.onPresence((data) => { console.log('User presence updated:', data); });
onError(callback)
callback
: Function called when an error occurs.- Example:
connly.onError((error) => { console.error('An error occurred:', error); });