Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Build seamless, engaging applications across platforms with our integrated SDK.
Sariska is a powerful and versatile platform that empowers to build innovative applications across a wide range of platforms, from IoT to Web to VR and beyond. Our integrated cross-platform SDK, coupled with our comprehensive APIs, provides the tools you need to create seamless and engaging user experiences.
Integrated Platform: Sariska's media transport layer seamlessly connects devices across various platforms, enabling hassle-free development for IoT, Web, VR, and more.
Unified Development: Our unified SDK facilitates single-click deployment and debugging, streamlining the development process for cross-platform applications.
Unparalleled Efficiency: Sariska delivers high-quality, low-latency media transport even in remote locations and on low-end devices, allowing you to scale to millions of users without compromising performance.
Embark on your Sariska journey, select your preferred programming language and dive right in. With just a few lines of code, integrate our services into your application within minutes. Our platform provides a comprehensive suite of APIs, SDKs, and helper tools to simplify the process.
Sign up: Create an account.
Authenticate: Obtain your API key.
Build: Integrate the SDK into your application.
To access, modify private information, or create any meaningful interaction with the Sariska API requires proper authentication. This is achieved through API keys, which are associated with your account. When making requests to the Sariska API, your application will need to provide an access token, which is used to identify the user. Each request your application sends to Sariska must also include an authorization token, which serves as a verification of your identity.
API keys are always visible in your account dashboard. If you are not logged in, randomly generated API keys will be included in code examples. Replace these with your own API keys to ensure your application is using the correct credentials.
If you are unable to locate your API keys within the dashboard, it indicates that you lack the necessary permissions to access them. To gain access, reach out to the administrator of your Sariska account and request to be added to their team as a developer.
Authentication in Sariska is handled using ID tokens, which are in JSON Web Token (JWT) format. ID tokens contain information that helps Sariska identify you as a user and confirms that you are authorized to access and modify information.
Your Sariska API keys are directly linked to your account and must be authorized before they can be used to make requests on your behalf.
Never share your API keys with anyone you don't trust. This includes friends, family, and even co-workers.
Store your API keys in a secure place. Don't write them down on paper or save them in a file that is easily accessible.
Monitor your API usage regularly. This will help you to identify any unauthorized activity.
If your keys or tokens are compromised, they could be used to make unauthorized requests to Sariska endpoints, potentially leading to unexpected rate limits, depletion of your access quota, or even cause your Sariska account to be disabled.
If you believe your API keys or tokens have been compromised, you should regenerate them immediately from the admin dashboard.
Only grant access to API keys to those who need them. Do not include them in any version control systems you may be using.
You can revoke API keys at any time if you no longer need them or suspect they have been compromised. You can also edit API keys to change their level of access.
Welcome to the Sariska documentation!
Sariska enables seamless access to development tools around messaging, real-time video, audio, streaming, and interactive capabilities across platforms and devices. With this, we aim to build a new communication layer for a world that is centered around mixed reality such that digital and physical identities can coincide naturally.
From communication to streaming to interactivity, Sariska offers a comprehensive tech stack to build everything from tiny applications to endless worlds through simple, fast, and secure APIs and SDKs helping you to get from development to launch in a week.
Some of the core features we think you might be interested in are:
Simplicity: Unified, easy-to-understand, and integrated SDKs, help you get live with your application in less than a day.
Flexibility: Complete control over the features and development with fully modular components to make your application as lightweight as possible.
Adaptive Relay: Real-time video and audio quality switching accounting for bandwidth and device capabilities with edge case handling delivering the best experience.
Transparency: Real-time visibility from usage to bugs with powerful backend logging allows for fully dynamic pricing and error anticipation.
If you are new to Sariska, the following documentation can help you get started:
On how to obtain an API Key
Integrating RTM(Real Time Messaging), Media, and Interactive services into your own code
Code samples to get you up and running in no time
Build things you love and enjoy. You bring creativity. We bring you tools that deliver high-quality performance every time.
If this is your first time using our APIs, please check out our getting started guide. If you already have your API key, our code samples could help you refine the results.
Choose your language
Real-Time Messaging SDK for Seamless Communication
Real-time messaging (RTM) has become an integral part of modern communication, enabling seamless and instantaneous interactions between individuals and groups. Sariska's Real-Time Messaging API provides a powerful and versatile platform for incorporating RTM capabilities into your applications and systems.
At the core of Sariska RTM is the utilization of the Erlang programming language, renowned for its concurrency model, process isolation, and fault-tolerant design. Erlang's capabilities make it an ideal foundation for real-time messaging systems, ensuring high availability and reliability even in the face of unexpected failures. Erlang's process isolation strengthens the system's resilience by preventing the failure of one component from affecting others. Additionally, Erlang's unique hot reload capabilities allow for seamless updates and modifications to the system without interruption, ensuring continuous operation.
Sariska RTM's architecture is not only robust but also distributed, allowing for scalable and efficient communication across a network of interconnected nodes. This distributed nature enhances its ability to handle large volumes of traffic seamlessly.
Real-time communication: Deliver messages to users in real time, fostering continuous engagement and interaction.
Scalable architecture: Handle millions of connected clients simultaneously, ensuring seamless communication even at large scale.
Flexible channel management: Create and manage channels to organize and categorize messages effectively.
Multi-platform support: Integrate RTM functionality into web, mobile, and game development environments.
One of the standout features of Sariska RTM is its integration with Phoenix Channels. Phoenix, built on top of the Erlang ecosystem, leverages the power of Erlang's concurrency, process isolation, and fault-tolerance to facilitate soft real-time communication among millions of connected clients. This makes Phoenix Channels an essential component of Sariska RTM, enabling the efficient and scalable exchange of messages between users and applications.
Sariska's Real-Time Messaging API caters to a wide range of applications, including:
Chat rooms and messaging apps: Build real-time chat features for personal and professional communication.
Breaking news and alerts: Deliver real-time notifications for urgent updates and critical events.
Real-time tracking: Monitor the movement of objects, vehicles, or participants in real time.
Multiplayer game interactions: Facilitate real-time communication and synchronization in multiplayer games.
IoT device monitoring and control: Receive real-time sensor data and send control commands to IoT devices.
Browser notifications: Notify users of page updates or changes in web applications.
Channels are a way to organize and manage real-time communication between clients and a server in Socket.IO. They allow you to send and receive events to specific groups of clients, and they can be used to create a variety of applications, such as chat rooms, multiplayer games, and collaborative editing tools.
Each channel name starts with a prefix that determines the message serialization format and persistence behavior.
chat:
Use this prefix for persisting messages to the database. This prefix requires a fixed schema and is ideal for chat applications.
rtc:
Use this prefix for scenarios where message persistence is not necessary. This prefix allows sending arbitrary JSON data, making it suitable for events in multiplayer games, IoT applications, and others.
sariska:
Use this prefix for performance-critical applications that utilize Flatbuffers as the serialization format and do not require message persistence. This prefix provides zero-copy serialization/deserialization, significantly enhancing performance.
To establish a socket connection for real-time messaging, use the following URL:
For performance-critical applications, consider using Flatbuffers, which offers near-zero serialization/deserialization time compared to JSON on both the device and server ends. Flatbuffers is particularly well-suited for use with mmap (or streaming), as it requires only a portion of the buffer to be in memory. Access speed is comparable to raw struct access, with only one additional indirection (a Vtable) to accommodate format evolution and optional fields. For more details, refer to the Flatbuffers documentation.
To establish a connection for real-time messaging (RTM) with Flatbuffers enabled, use the following URL:
Sariska's real-time messaging SDK offers versatile cross-platform communication across browsers, Android, iOS, Mac, Windows, Linux, and gaming consoles.
Server-side Phoenix Channel Implementations: Server-side implementations for Phoenix channels facilitate seamless message exchange from the server.
Unity Integration: Integration with the Unity game engine enables bidirectional messaging within Unity's cross-platform environment.
Godot Integration: Integration with the Godot game engine ensures bidirectional messaging within Godot's open-source ecosystem.
Sariska provides a JavaScript API and easy-to-integrate SDKs for web, mobile, front-end, and cloud infrastructure to add real-time features in your applications.
Real-time messaging for in-app chats and instant messaging
Support for various JavaScript frameworks (Vanilla, React, Angular, Vue, Electron, React Native)
Easy installation using NPM or CDN
Socket creation and management
Channel creation, joining, and leaving
Sending messages, poll votes, and message replies
Presence management (track: typing, joining and leaving users)
History management (fetching chat history and specific messages)
Install the Phoenix library by running the following command in your project directory using NPM.
Alternatively, install the Phoenix library by adding the following script to your website's HTML <head>
tag for seamless API access.
Establish a WebSocket connection to the Sariska server to join channels, receive events, and send messages.
Close the WebSocket connection to the Sariska server. This will terminate all active channels and prevent further communication with the server.
Channels cannot be created directly; instead, they are created through the socket object by calling socket.channel(topic)
with the topic of the channel. The topic is a string that identifies the channel, and it can be any string you like.
Each channel name starts with a prefix that determines the message serialization format and persistence behavior.
chat:
Use this prefix for persisting messages to the database. This prefix requires a fixed schema and is ideal for chat applications.
rtc:
Use this prefix for scenarios where message persistence is not necessary. This prefix allows sending arbitrary JSON data, making it suitable for events in multiplayer games, IoT applications, and others.
sariska:
Use this prefix for performance-critical applications that utilize Flatbuffers as the serialization format and do not require message persistence. This prefix provides zero-copy serialization/deserialization, significantly enhancing performance.
When an error occurs on the channel, the onError
callback is triggered. The callback receives the error information in payload, if available.
When the channel is closed, the onClose
callback is invoked. This signifies that the communication on the channel has ended and no further data can be exchanged.
To join a channel, call the join()
method on the channel object. The join()
method returns a promise that resolves when the client has successfully joined the channel. When sending data, you can utilize the .receive()
hook to monitor the status of the outgoing push message.
Once you've established a connection to a channel, you can start sending messages to other connected clients. To send a message, use the push()
method on the channel object.
Attaching media files to chat messages involves obtaining a presigned URL, uploading the file to the presigned URL, and then sending the file information to the chat server.
To obtain a presigned URL, make a POST request to the API endpoint. The request payload should be empty, and the Authorization
header should contain your bearer token.
After obtaining the presigned URL, the file can be uploaded to the URL using the PUT method.
Retrieve the chat history using two methods:
By Subscribing to Events
Subscribe to the archived_message
event to receive the last 1000 messages in reverse chronological order.
Subscribe to the archived_message_count
event to get the total number of messages in the chat history.
To retrieve a list of messages in the chat history, trigger the archived_message
event to obtain the messages. Specify the size
parameter to determine the number of messages you wish to fetch, and set the offset
parameter as the starting index of the messages and group_by_day
to group messages by day.
To receive the total count of messages at any given time, initiate the archived_message_count trigger and subscribe to the corresponding event by listening for archived_message_count
.
Using the Messages API
Make a GET request to the API endpoint to fetch the chat history for a specific room.
Fetch Specific Message
Retrieve any specific message from a room. It takes the room ID
and message ID
as parameters and sends a GET request to the Sariska API to fetch the specified message.
Delete chat history for a specific room.
The Presence object facilitates real-time synchronization of presence information between the server and the client, enabling the detection of user join and leave events.
Create a Presence Instance
To establish presence synchronization, instantiate a Presence object and provide the channel to track presence lifecycle events:
State Synchronization
Utilize the presence.onSync
callback to respond to state changes initiated by the server. For instance, to dynamically render the user list upon every list modification, implement the following:
Handle Individual Join and Leave Events
The presence.onJoin
and presence.onLeave
callbacks allow for handling individual user join and leave events. Here is an instance:
Retrieve Presence Information
The presence.list(by:)
method retrieves a list of presence information based on the local metadata state. By default, it returns the entire presence metadata. Alternatively, a listBy
function can be provided to filter the metadata for each presence.
For instance, if a user is online from multiple devices, each with a metadata status of "online," but their status is set to "away" on another device, the application might prefer to display the "away" status in the UI.
The following example defines a listBy
function that prioritizes the first metadata registered for each user, representing the first tab or device they used to connect:
Send information about a user who is typing. This information can be used to update the chat interface, such as displaying a "user is typing" indicator next to the user's name.
Send User Typing Event
When a user starts typing, the following code sends a typing event to other peers.
Receive User Typing Event
Other peers in the chat can listen for the typing event on the same channel.
For detailed real-time messaging API's, refer to Phoenix documentation.
For detailed management of chat and room APIs, refer to Sariska Swagger documentation.
Sariska utilizes JSON Web Tokens (JWTs) to securely authenticate users and devices. JWTs are a standardized, structured, and self-contained method for conveying information between clients as JSON objects. They serve as a mechanism for asserting claims exchanged between two parties. In the context of a JWT, a claim is a declaration about a company or user, accompanied by additional metadata about the token itself. The payload, which is maintained in JSON format, contains a set of claims. JWTs are digitally signed and encrypted for enhanced security.
Sariska generates these tokens on its servers. A single token can be used to access all Sariska services.
apiKey
Required
Your Sariska.io API key.
user
Optional
A unique identifier for the user. If not provided, Sariska will generate one automatically.
exp
Optional
The expiration time of the token. The default is 24 hours. You can specify a custom expiration time using the following formats: 2 seconds
, 2 minutes
, 2 hours
, 2 days
, 2 weeks
, or 2 years
.
nbf
Optional
The time before which the token is not valid. The token will not be accepted for processing until the current date/time is after or equal to the value of this field. You can specify a custom nbf value using the following formats: 2 seconds
, 2 minutes
, 2 hours
, 2 days
, 2 weeks
, or 2 years
.
scope
Optional
The scope of the token. By default, tokens can be used for integrating media, messaging, and collaboration services. You can restrict the scope to one or more of these services using the following values: messaging
, co-browsing
, or media
. Leave this field blank to use all services.
Sariska provides a Swift API and easy-to-integrate SDKs for building real-time features into your iOS, macOS, watchOS, and tvOS applications. Easily add in-app chats, instant messaging, and other real-time functionalities to your apps.
Real-time messaging for in-app chats and instant messaging
Easy installation using Cocoa Pods or Carthage
Socket creation and management
Channel creation, joining, and leaving
Sending messages, poll votes, and message replies
Presence management (track: typing, joining and leaving users)
History management (fetching chat history and specific messages)
To install SwiftPhoenixClient using CocoaPods, add the following line to your Podfile:
If you are using RxSwift extensions, add the following line to your Podfile:
If your version requirements require iOS 13 and below, add the following line to your Podfile:
To install SwiftPhoenixClient using Carthage, add the following line to your Cartfile:
To establish a connection with Sariska's real-time messaging platform, you'll need to create a socket instance. This socket will handle joining channels, receiving events, and sending messages.
Close the WebSocket connection to the Sariska server. This will terminate all active channels and prevent further communication with the server.
Channels cannot be created directly; instead, they are created through the socket object by calling socket.channel(topic)
with the topic of the channel. The topic is a string that identifies the channel, and it can be any string you like.
Each channel name starts with a prefix that determines the message serialization format and persistence behavior.
chat:
Use this prefix for persisting messages to the database. This prefix requires a fixed schema and is ideal for chat applications.
rtc:
Use this prefix for scenarios where message persistence is not necessary. This prefix allows sending arbitrary JSON data, making it suitable for events in multiplayer games, IoT applications, and others.
sariska:
Use this prefix for performance-critical applications that utilize Flatbuffers as the serialization format and do not require message persistence. This prefix provides zero-copy serialization/deserialization, significantly enhancing performance.
When an error occurs on the channel, the onError
callback is triggered. The callback receives the error information in payload, if available.
When the channel is closed, the onClose
callback is invoked. This signifies that the communication on the channel has ended and no further data can be exchanged.
To join a channel, call the join()
method on the channel object. The join()
method returns a promise that resolves when the client has successfully joined the channel. When sending data, you can utilize the .receive()
hook to monitor the status of the outgoing push message.
Once you've established a connection to a channel, you can start sending messages to other connected clients. To send a message, use the push()
method on the channel object.
Attaching media files to chat messages involves obtaining a presigned URL, uploading the file to the presigned URL, and then sending the file information to the chat server.
To obtain a presigned URL, make a POST request to the API endpoint. The request payload should be empty, and the Authorization
header should contain your bearer token. The bearer token authenticates the request and returns a URL that can be used to upload content.
After obtaining the presigned URL, the file can be uploaded to the URL using the PUT method.
Retrieve the chat history using two methods:
By Subscribing to Events
Subscribe to the archived_message
event to receive the last 1000 archived messages in reverse chronological order.
Subscribe to the archived_message_count
event to get the total number of messages in the chat history.
To retrieve a list of messages in the chat history, trigger the archived_message
event to obtain the messages. Specify the size
parameter to determine the number of messages you wish to fetch, and set the offset
parameter as the starting index of the messages and group_by_day
to group messages by day.
To receive the total count of messages at any given time, initiate the archived_message_count trigger and subscribe to the corresponding event by listening for archived_message_count
.
Using the Messages API
Make a GET request to the API endpoint to fetch the chat history for a specific room.
Fetch Specific Message
Retrieve any specific message from a room. It takes the room ID
and message ID
as parameters and sends a GET request to the Sariska API to fetch the specified message.
The Presence object facilitates real-time synchronization of presence information between the server and the client, enabling the detection of user join and leave events.
Create a Presence Instance
To establish presence synchronization, instantiate a Presence object and provide the channel to track presence lifecycle events:
Custom Event Options
By default, the Presence
object uses built-in events for syncing state changes. However, you can configure the Presence object to use custom events instead. This allows you to better integrate with your existing application logic.
State Synchronization
The presence.onSync
callback triggers whenever the server updates the presence list. This allows you to update your UI based on the latest presence information, such as dynamically generating a user list.
Handle Individual Join and Leave Events
To handle individual join and leave events, use the presence.onJoin
and presence.onLeave
callbacks. These provide information about the user and their presence state. Here is an instance:
Retrieve Presence Information
The presence.list(by:)
method retrieves a list of presence information based on the local metadata state. By default, it returns the entire presence metadata. Alternatively, a listBy
function can be provided to filter the metadata for each presence.
For instance, if a user is online from multiple devices, each with a metadata status of "online," but their status is set to "away" on another device, the application might prefer to display the "away" status in the UI.
The following example defines a listBy
function that prioritizes the first metadata registered for each user, representing the first tab or device they used to connect:
Send information about a user who is typing. This information can be used to update the chat interface, such as displaying a "user is typing" indicator next to the user's name.
Send User Typing Event
When a user starts typing, the following code sends a typing event to other peers.
Receive User Typing Event
Other peers in the chat can listen for the typing event on the same channel.
The Sariska client library offers an optional API to automatically manage retain cycles for event hooks, simplifying your code and preventing memory leaks.
How it works:
Each event hook has a corresponding delegate*(to:)
method.
This method takes a reference to an owner object and passes it back to the event hook.
When the owner object is deinitialized, the associated event hook is automatically dereferenced, preventing retain cycles.
Benefits:
Cleaner API: Eliminates the need for [weak self]
capture lists, making your code more concise and readable.
Reduced memory leaks: Automatic retain cycle management ensures efficient memory usage and avoids potential crashes.
For detailed real-time messaging API's, refer to Phoenix documentation.
For detailed management of chat and room APIs, refer to Sariska Swagger documentation.
The growing network of broadband connections, paired with the arrival of 4G and now 5G services, has provided a unique opportunity to look beyond the bandwidth savings model for video conferencing, and rather focus on optimizing the cost of media delivery through intelligent systems over standard configurations.
From communication to streaming to interactivity, SARISKA offers a comprehensive tech stack to build everything from tiny applications to endless worlds through simple, fast, and secure APIs and SDKs helping you to get from development to launch in a week.
Jitsi’s architecture allows for dynamic scaling in real time. In addition to being powerful and optimized, JVBs are built to scale, which makes them more dynamic for media transport.
Scaling the audio/video conferencing architecture is made easier with the usage of Jisti Videobridges due to the separation of the signaling layer from the transport layer.
Sariska lets you also live-stream your video conference. Sariska addresses the challenges of concurrent streaming and latency by using a media server called SRS (Simple Realtime Server), which is a simple, high-efficiency, and real-time video server supporting RTMP/WebRTC/HLS/DASH/HTTP-FLV/SRT protocols.
SRS is used as a real-time media delivery server on top of our video conferencing architecture. This enables you to push your streams through multiple outlets in a single click with simulcast-enabled live streaming and reach your audience across every platform.
If you are using Sariska then media is routed through the Jitsi Video bridge. If you have your own WebRTC set up and you need only stun/turn servers for NAT Traversal. Please check out the details below.
SARISKA also provides DNS-based load balanced turn servers, DNS-based load balancing is a specific type of load balancing that uses the DNS to distribute traffic across several servers. It does this by providing different IP addresses in response to DNS queries which are highly available and available to near your location.
you can fetch usernames and passwords to use with turn servers.
A TURN server is a media relay/proxy that allows peers to exchange UDP or TCP media traffic whenever one or both parties are behind NAT.
with UDP:
with TCP:
The STUN server allows clients to find out their public address, the type of NAT they are behind, and the Internet side port associated by the NAT with a particular local port
✅ Runs on port 80 and 443 to penetrate most restricted firewalls in the world
✅ For the lowest-latency P2P calls and to support users with restricted connectivity
✅ Enterprise-grade reliability (99.99% uptime)
✅ Support STUN
✅ Supports both TCP and UDP
✅ Dynamic routing to the nearest server
✅ Production Ready
Welcome to the Awesome Chat API documentation! This API offers a robust set of endpoints for creating and managing chat platforms. Features include Room Management, Message Handling, Polls, Chat History, Message Replies, Room Role-Based Access Control (RBAC), Admin Moderation, User Management, Attachments, Emojis and Efficient Search Capabilities.
Get started by obtaining your API key and referring to detailed documentation for each endpoint. Ensure proper authentication and authorization for secure integration. Create a dynamic and feature-rich chat platform with the Awesome Chat API!
Sariska provides a Kotlin API and easy-to-integrate SDKs for building real-time features into your android applications. Easily add in-app chats, instant messaging, and other real-time functionalities to your apps.
Real-time messaging for in-app chats and instant messaging
Easy installation
Socket creation and management
Channel creation, joining, and leaving
Sending messages, poll votes, and message replies
Presence management (track: typing, joining and leaving users)
History management (fetching chat history and specific messages)
JavaPhoenixClient
is hosted on MavenCentral. To install it, you'll need to add the following repositories and dependencies to your project's build configuration:
Repositories
Dependencies
Establish a WebSocket connection to the Sariska server to join channels, receive events, and send messages.
Close the WebSocket connection to the Sariska server. This will terminate all active channels and prevent further communication with the server.
Channels cannot be created directly; instead, they are created through the socket object by calling socket.channel(topic)
with the topic of the channel. The topic is a string that identifies the channel, and it can be any string you like.
Each channel name starts with a prefix that determines the message serialization format and persistence behavior.
chat:
Use this prefix for persisting messages to the database. This prefix requires a fixed schema and is ideal for chat applications.
rtc:
Use this prefix for scenarios where message persistence is not necessary. This prefix allows sending arbitrary JSON data, making it suitable for events in multiplayer games, IoT applications, and others.
sariska:
Use this prefix for performance-critical applications that utilize Flatbuffers as the serialization format and do not require message persistence. This prefix provides zero-copy serialization/deserialization, significantly enhancing performance.
To join a channel, call the join()
method on the channel object. The join()
method returns a promise that resolves when the client has successfully joined the channel. When sending data, you can utilize the .receive()
hook to monitor the status of the outgoing push message.
Once you've established a connection to a channel, you can start sending messages to other connected clients. To send a message, use the push()
method on the channel object.
Attaching media files to chat messages involves obtaining a presigned URL, uploading the file to the presigned URL, and then sending the file information to the chat server.
To obtain a presigned URL, make a POST request to the API endpoint.
After obtaining the presigned URL, the file can be uploaded to the URL using the PUT method.
Retrieve the chat history using two methods:
By Subscribing to Events
Subscribe to the archived_message
event to receive the last 1000 messages in reverse chronological order.
Subscribe to the archived_message_count
event to get the total number of messages in the chat history.
To retrieve a list of messages from the chat history, trigger the archived_message
event to obtain the messages. Specify the size
parameter to determine the number of messages you wish to fetch, and set the offset
parameter as the starting index of the messages.
To receive the total count of messages at any given time, initiate the archived_message_count
trigger and subscribe to the corresponding event by listening for archived_message_count
By Using the Messages API
Make a GET request to the API endpoint to fetch the chat history for a specific room.
Fetch Specific Message
Retrieve any specific message from a room. It takes the room ID
and message ID
as parameters and sends a GET request to the Sariska API to fetch the specified message.
Delete chat history for a specific room.
The Presence
object facilitates real-time synchronization of presence information between the server and the client, enabling the detection of user join and leave events.
Create a Presence Instance
To establish presence synchronization, instantiate a Presence object and provide the channel to track presence lifecycle events:
State Synchronization
Utilize the presence.onSync
callback to respond to state changes initiated by the server. For instance, to dynamically render the user list upon every list modification, implement the following:
Handle Individual Join and Leave Events
The presence.onJoin
and presence.onLeave
callbacks allow for handling individual user join and leave events. Here is an instance:
Retrieve Presence Information
The presence.list(by:)
method retrieves a list of presence information based on the local metadata state. By default, it returns the entire presence metadata. Alternatively, a listBy
function can be provided to filter the metadata for each presence.
For instance, if a user is online from multiple devices, each with a metadata status of "online," but their status is set to "away" on another device, the application might prefer to display the "away" status in the UI.
The following example defines a listBy
function that prioritizes the first metadata registered for each user, representing the first tab or device they used to connect:
Send information about a user who is typing. This information can be used to update the chat interface, such as displaying a "user is typing" indicator next to the user's name.
Send User Typing Event
When a user starts typing, the following code sends a typing event to other peers.
Receive User Typing Event
Other peers in the chat can listen for the typing event on the same channel.
Sariska provides a Dart API and easy-to-integrate SDKs for building real-time features into your applications. Easily add in-app chats, instant messaging, and other real-time functionalities to your apps.
Real-time messaging for in-app chats and instant messaging
Easy installation
Socket creation and management
Channel creation, joining, and leaving
Sending messages, poll votes, and message replies
Presence management (track: typing, joining and leaving users)
History management (fetching chat history and specific messages)
With Dart
With Flutter
Establish a WebSocket connection to the Sariska server to join channels, receive events, and send messages.
Close the WebSocket connection to the Sariska server. This will terminate all active channels and prevent further communication with the server.
Channels cannot be created directly; instead, they are created through the socket object by calling socket.channel(topic)
with the topic of the channel. The topic is a string that identifies the channel, and it can be any string you like.
Each channel name starts with a prefix that determines the message serialization format and persistence behavior.
chat:
Use this prefix for persisting messages to the database. This prefix requires a fixed schema and is ideal for chat applications.
rtc:
Use this prefix for scenarios where message persistence is not necessary. This prefix allows sending arbitrary JSON data, making it suitable for events in multiplayer games, IoT applications, and others.
sariska:
Use this prefix for performance-critical applications that utilize Flatbuffers as the serialization format and do not require message persistence. This prefix provides zero-copy serialization/deserialization, significantly enhancing performance.
When an error occurs on the channel, the onError
callback is triggered. The callback receives the error information in payload, if available.
When the channel is closed, the onClose
callback is invoked. This signifies that the communication on the channel has ended and no further data can be exchanged.
To join a channel, call the join()
method on the channel object. The join()
method returns a promise that resolves when the client has successfully joined the channel. When sending data, you can utilize the .receive()
hook to monitor the status of the outgoing push message.
Receive all events for specialized message processing prior to dispatching to channel-specific callbacks. Ensure the payload is returned, regardless of modification status.
Once you've established a connection to a channel, you can start sending messages to other connected clients. To send a message, use the push()
method on the channel object.
Attaching media files to chat messages involves obtaining a presigned URL, uploading the file to the presigned URL, and then sending the file information to the chat server.
To obtain a presigned URL, make a POST request to the API endpoint. The request payload should be empty, and the Authorization
header should contain your bearer token.
After obtaining the presigned URL, the file can be uploaded to the URL using the PUT method.
Retrieve the chat history using two methods:
By Subscribing to Events
Subscribe to the archived_message
event to receive the last 1000 messages in reverse chronological order.
Subscribe to the archived_message_count
event to get the total number of messages in the chat history.
To retrieve a list of messages in the chat history, trigger the archived_message
event to obtain the messages. Specify the size
parameter to determine the number of messages you wish to fetch, and set the offset
parameter as the starting index of the messages and group_by_day
to group messages by day.
To receive the total count of messages at any given time, initiate the archived_message_count trigger and subscribe to the corresponding event by listening for archived_message_count
.
Using the Messages API
Make a GET request to the API endpoint to fetch the chat history for a specific room.
Fetch Specific Message
Retrieve any specific message from a room. It takes the room ID
and message ID
as parameters and sends a GET request to the Sariska API to fetch the specified message.
Delete chat history for a specific room.
The Presence object facilitates real-time synchronization of presence information between the server and the client, enabling the detection of user join and leave events.
Create a Presence Instance
To establish presence synchronization, instantiate a Presence object and provide the channel to track presence lifecycle events:
State Synchronization
Utilize the presence.onSync
callback to respond to state changes initiated by the server. For instance, to dynamically render the user list upon every list modification, implement the following:
Handle Individual Join and Leave Events
The presence.onJoin
and presence.onLeave
callbacks allow for handling individual user join and leave events. Here is an instance:
Retrieve Presence Information
The presence.list(by:)
method retrieves a list of presence information based on the local metadata state. By default, it returns the entire presence metadata. Alternatively, a listBy
function can be provided to filter the metadata for each presence.
For instance, if a user is online from multiple devices, each with a metadata status of "online," but their status is set to "away" on another device, the application might prefer to display the "away" status in the UI.
The following example defines a listBy
function that prioritizes the first metadata registered for each user, representing the first tab or device they used to connect:
Send information about a user who is typing. This information can be used to update the chat interface, such as displaying a "user is typing" indicator next to the user's name.
Send User Typing Event
When a user starts typing, the following code sends a typing event to other peers.
Receive User Typing Event
Other peers in the chat can listen for the typing event on the same channel.
For a full list of APIs go to:
For other polls APIs, please refer to documentation
For more detailed information on the APIs, check out the
For detailed real-time messaging API's, refer to .
For detailed management of chat and room APIs, refer to Sariska
For other polls APIs, please refer to documentation
For detailed real-time messaging API's, refer to .
For detailed management of chat and room APIs, refer to Sariska .
Sariska provides a Java API and easy-to-integrate SDKs for web, mobile, front-end, and cloud infrastructure to add real-time features in your applications.
Real-time messaging for in-app chats and instant messaging
Easy installation
Socket creation and management
Channel creation, joining, and leaving
Sending messages, poll votes, and message replies
Presence management (track: typing, joining and leaving users)
History management (fetching chat history and specific messages)
JavaPhoenixChannels
is hosted on jitpack.io, so you'll need to add it as a repository to your project.
Add Jitpack to your repositories
Add JavaPhoenixChannels
dependency
Establish a WebSocket connection to the Sariska server to join channels, receive events, and send messages.
Close the WebSocket connection to the Sariska server. This will terminate all active channels and prevent further communication with the server.
Channels cannot be created directly; instead, they are created through the socket object by calling socket.channel(topic)
with the topic of the channel. The topic is a string that identifies the channel, and it can be any string you like.
Each channel name starts with a prefix that determines the message serialization format and persistence behavior.
chat:
Use this prefix for persisting messages to the database. This prefix requires a fixed schema and is ideal for chat applications.
rtc:
Use this prefix for scenarios where message persistence is not necessary. This prefix allows sending arbitrary JSON data, making it suitable for events in multiplayer games, IoT applications, and others.
sariska:
Use this prefix for performance-critical applications that utilize Flatbuffers as the serialization format and do not require message persistence. This prefix provides zero-copy serialization/deserialization, significantly enhancing performance.
When an error occurs on the channel, the ERROR
callback is triggered. The callback receives the error information in payload, if available.
When the channel is closed, the CLOSE
callback is invoked. This signifies that the communication on the channel has ended and no further data can be exchanged.
To join a channel, call the join()
method on the channel object. The join()
method returns a promise that resolves when the client has successfully joined the channel. When sending data, you can utilize the .receive()
hook to monitor the status of the outgoing push message.
Once you've established a connection to a channel, you can start sending messages to other connected clients. To send a message, use the push()
method on the channel object.
Attaching media files to chat messages involves obtaining a presigned URL, uploading the file to the presigned URL, and then sending the file information to the chat server.
To obtain a presigned URL, make a POST request to the API endpoint. The request payload should be empty, and the Authorization
header should contain your bearer token.
After obtaining the presigned URL, the file can be uploaded to the URL using the PUT method.
Retrieve the chat history using two methods:
By Subscribing to Events
Subscribe to the archived_message
event to receive the last 1000 messages in reverse chronological order.
Subscribe to the archived_message_count
event to get the total number of messages in the chat history.
To retrieve a list of messages in the chat history, trigger the archived_message
event to obtain the messages. Specify the size
parameter to determine the number of messages you wish to fetch, and set the offset
parameter as the starting index of the messages and group_by_date
to group messages by date.
To receive the total count of messages at any given time, initiate the archived_message_count
trigger and subscribe to the corresponding event by listening for archived_message_count
.
Using the Messages API
Make a GET request to the API endpoint to fetch the chat history for a specific room.
Fetch Specific Message
Retrieve any specific message from a room. It takes the room ID
and message ID
as parameters and sends a GET request to the Sariska API to fetch the specified message.
Delete chat history for a specific room.
Create a Presence Instance
To establish presence synchronization, instantiate a Presence object and provide the channel to track presence lifecycle events:
State Synchronization
Utilize the presence.onSync
callback to respond to state changes initiated by the server. For instance, to dynamically render the user list upon every list modification, implement the following:
Handle Individual Join and Leave Events
The presence.onJoin
and presence.onLeave
callbacks allow for handling individual user join and leave events. Here is an instance:
Retrieve Presence Information
The presence.list(by:)
method retrieves a list of presence information based on the local metadata state. By default, it returns the entire presence metadata. Alternatively, a listBy
function can be provided to filter the metadata for each presence.
For instance, if a user is online from multiple devices, each with a metadata status of "online," but their status is set to "away" on another device, the application might prefer to display the "away" status in the UI.
The following example defines a listBy
function that prioritizes the first metadata registered for each user, representing the first tab or device they used to connect:
Send information about a user who is typing. This information can be used to update the chat interface, such as displaying a "user is typing" indicator next to the user's name.
Send User Typing Event
When a user starts typing, the following code sends a typing event to other peers.
Receive User Typing Event
Other peers in the chat can listen for the typing event on the same channel.
For more detailed information on the APIs, check out the Github repository.
For detailed real-time messaging API's, refer to Phoenix documentation.
For detailed management of chat and room APIs, refer to Sariska Swagger documentation.
Introduction to Call Directory Record APIs
Welcome to the documentation for Call Directory Records APIs, designed to enhance and manage call directory information within your applications. These APIs provide developers with the capability to seamlessly integrate, update, and retrieve call directory records, contributing to an improved and customized calling experience for users.
This API is used to get the Video CDR Usage Report across all rooms or selected rooms
API Route: https://api.sariska.io/api/v1/pricing/cdr
HTTP Request: POST
Access Mechanism: HTTP Basic Authentication
Headers:
Content-Type
: To have application/json
.
Authorization
: Bearer JWT Token for authentication
Body:
room_name: Optional, returns all rooms if left empty or not mentioned
start_date: Optional, if nil, default value is 7 days before the current date time
end_date: Optional, if nil, default value is the current date time
Sample Curl Request:
Sample Response:
Conference Mapper: Bridging Phone Accessibility
Conference Mapper facilitates seamless access to Sariska conferences for phone callers(joining conference without internet), addressing the challenge of inputting lengthy conference names via phone keypads.
To call someone from the Sariska Meet application within the Sariska environment.
Jigasi plays a crucial role in handling incoming calls within Sariska Meet. Once configured, it registers on the SIP server with a designated identity and is ready to accept incoming calls. When Jigasi receives a call, it expects to find a 'Jitsi-Conference-Room' header in the SIP INVITE request. This header contains the name of the Jitsi Meet conference to which the call is to be patched through.
If no 'Jitsi-Conference-Room' header is present, Jigasi will automatically join the room specified under the 'org.jitsi.jigasi.DEFAULT_JVB_ROOM_NAME' config property. Administrators can customize this default room by editing the 'jigasi-home/sipcommunicator.properties' file.
This seamless integration streamlines the process for both outgoing and incoming calls, ensuring a user-friendly experience for Sariska conference participants, particularly when accessed through phone systems. The Conference Mapper's translation of memorable conference names to concise numeric identifiers further enhances accessibility and convenience for phone callers.
Sariska provides a C# API and easy-to-integrate SDKs for Unity and Blazor to add real-time features in your applications.
Real-time messaging for in-app chats and instant messaging
Easy installation
Socket creation and management
Channel creation, joining, and leaving
Sending messages, poll votes, and message replies
Presence management (track: typing, joining and leaving users)
History management (fetching chat history and specific messages)
In your Unity project, navigate to Assets -> Import Package -> Custom Package
Select the downloaded "NugetForUnity.3.0.4.unitypackage" and click Import All
Access NuGet Package Manager: Click NuGet (at the top of your Unity Editor) -> Manage NuGet Packages
Search for "io.sariska.sariskacsharp"
Click Install to add the Phoenix Client package to your project.
Establish a WebSocket connection to the Sariska server to join channels, receive events, and send messages.
Close the WebSocket connection to the Sariska server. This will terminate all active channels and prevent further communication with the server.
Channels cannot be created directly; instead, they are created through the socket object by calling socket.channel(topic)
with the topic of the channel. The topic is a string that identifies the channel, and it can be any string you like.
Each channel name starts with a prefix that determines the message serialization format and persistence behavior.
chat:
Use this prefix for persisting messages to the database. This prefix requires a fixed schema and is ideal for chat applications.
rtc:
Use this prefix for scenarios where message persistence is not necessary. This prefix allows sending arbitrary JSON data, making it suitable for events in multiplayer games, IoT applications, and others.
sariska:
Use this prefix for performance-critical applications that utilize Flatbuffers as the serialization format and do not require message persistence. This prefix provides zero-copy serialization/deserialization, significantly enhancing performance.
When an error occurs on the channel, the ERROR
callback is triggered. The callback receives the error information in payload, if available.
When the channel is closed, the CLOSE
callback is invoked. This signifies that the communication on the channel has ended and no further data can be exchanged.
To join a channel, call the join()
method on the channel object. The join()
method returns a promise that resolves when the client has successfully joined the channel. When sending data, you can utilize the .receive()
hook to monitor the status of the outgoing push message.
Once you've established a connection to a channel, you can start sending messages to other connected clients. To send a message, use the push()
method on the channel object.
Unity is a cross-platform game engine developed by Unity Technologies.
The (C#)Phoenix Channel client can be used to build real time messaging apps for:
Unity
Blazor
The first step is to install NuGetForUnity Package manager in your Unity project. The Package Manager is used to import Phoenix Client into your project.
In your unity project, go to Assets -> Import-Package -> Custom Package
Select "NugetForUnity.3.0.4.unitypackage" from your download folder and import all.
Once imported, click on NuGet (top of your Unity Editor) -> Manage Nuget Packages.
Search for "io.sariska.sariskacsharp" and install.
First, you need to create the socket that will join channels, receive events, and send messages. A single connection is established to the server and channels are multiplexed over the connection.
Once your socket is created, you can join
channel topics that listen for specific events and allow for sending data to do a topic. Whenever sending data, you can use the .receive()
hook to get the status of the outbound push message. Channels cannot be created directly but instead are created through the socket
object by calling socket.channel(topic)
with the topic
of the channel.
Sending user typing event to other peers
other peers now can listen for message typing event
The Presence
object provides features for syncing presence information from the server with the client and handling presences of joining and leaving.
To sync presence state from the server, first instantiate an object and pass your channel in to track lifecycle events:
Next, use the presence.onSync callback to react to state changes from the server. For example, to render the list of users every time the list changes, you could write:
presence.list(by:) is used to return a list of presence information based on the local state of metadata. By default, all presence metadata is returned, but a listBy function can be supplied to allow the client to select which metadata to use for a given presence. For example, you may have a user online from different devices with a metadata status of "online", but they have set themselves to "away" on another device. In this case, the app may choose to use the "away" status for what appears on the UI. The example below defines a listBy function that prioritizes the first metadata which was registered for each user. This could be the first tab they opened or the first device they came online from:
The presence.onJoin and presence.onLeave callbacks can be used to react to individual presences joining and leaving the app.
Retrieve the chat history using two methods:
By Subscribing to Events
Subscribe to the archived_message
event to receive the last 1000 messages in reverse chronological order.
Subscribe to the archived_message_count
event to get the total number of messages in the chat history.
To retrieve a list of messages in the chat history, trigger the "archived_message" event to obtain the messages. Specify the "size" parameter to determine the number of messages you wish to fetch, and set the "offset" parameter as the starting index of the messages and group_by_day to group messages by date.
If you desire to receive the total count of messages at any given time, initiate the "archived_message_count" trigger and subscribe to the corresponding event by listening for "archived_message_count."
Using the Messages API
Make a GET request to the API endpoint to fetch the chat history for a specific room.
Fetch Specific Message
Retrieve any specific message from a room. It takes the room ID
and message ID
as parameters and sends a GET request to the Sariska API to fetch the specified message.
Delete chat history for a specific room.
You can attach media files to chat as follows:
Unreal Engine (UE) is a 3D computer graphics game engine developed by Epic Games, first showcased in the 1998 first-person shooter game Unreal. Written in C++, the Unreal Engine features a high degree of portability, supporting a wide range of desktop, mobile, console, and virtual reality platforms.
Sariska provides plugins to support media streaming for Unreal Gaming Engine. This documentation walks you through setting up the Sariska Unreal plugin for your Unreal project.
Configure Android Platform
Click Edit > Project Settings to bring up the Project Settings window.
Inside the Project Settings window, navigate to Platforms > Android.
Under APK Packaging, there will be a warning that reads "Project is not configured for the Android platform". Click the Configure Now button to automatically set up your project to write the required platform files.
Fill in the Android Package Name with an appropriate company and project name.
If the Accept SDK License button is enabled, click it in order to accept Android's SDK license agreement. If you have previously accepted this agreement, then you will not need to complete this step.
Configuring Editor and PIE for Mobile Previews
In the Toolbar, click Settings > Preview Rendering Level, then select one of the available rendering levels for Android.
Click the dropdown next to the Play button in the Toolbar. Choose one of the available Mobile Preview modes corresponding to the rendering level you selected.
Configure Android SDK
You'd sometimes need to add the location of the Android SDK and NDK manually.
Click Edit > Project Settings to bring up the Project Settings window.
Inside the Project Settings window, navigate to Platforms > Android-SDK.
Make changes to the SDK Config accordingly.
Launching on an Android Device
From the Launch menu under the Devices section select your Android device from the list by clicking on it.
While your level is being launched on your device, the progress will be displayed in the bottom right-hand corner of the screen like in the following image.
When the deployment has finished, the project should automatically start running on your Android device. If the project fails to automatically start, you can start it by finding the App on your device and tapping on it to launch it.
You can clone the repository to <Game>/Plugins/
or if you want you can use git submodules to your own git repository. Alternatively, you can copy to the Engine/Plugins/
if you wish to make the plugin available to all of your projects.
Once the plugin is added to your project under the plugins folder(you can create one if you don't have a plugins folder already), you can generate project files and enable the plugin to use it.
If you are using UE version 4.26, you might need AndroidX support to run Sariska's media services. You can clone the following repo into <Game>/Plugins/
A demo app showing Sariska Media usage for Unreal can be found here:
Every Sariska project gets the following for free:
50GB data transfer
60 minutes of transcoding
If you think you'll need more concurrent connections for your project, an admin for your project can request an increase for the particular limit in your project settings.
APIs for managing conferences
Welcome to the Scheduler API, a powerful tool that enables seamless integration for scheduling meetings and conferences within your applications.
This API empowers developers to incorporate advanced scheduling functionalities, automating the process and enhancing the user experience for meeting coordination.
For a full list of APIs, please visit:
Welcome to the new era of collaboration!
Co-browsing is your one-stop destination to make any website in the world collaborative. With the click of a button, you can now transform any website into a shareable environment amongst colleagues, friends & family. It permits you to take any existing website and share it within teams or across the whole organization to collaboratively annotate, discuss, enhance, and otherwise bring it to life – all within your browser.
Co-browsing can be used for including but not limited to:
Productivity
Support
Business & Corporate
Movies & Streaming
Social Networking
Art and Entertainment
Demo:
Move past screen sharing and add a new dimension of Interactivity in your web apps with Sariska’s multi-user SDK for a collaborative world
With our SDK, you can create a co-browsing experience for any web page with a 95% smaller payload than screen sharing, allowing for multiple cursors. Co-browsing annotates both parties' cursors as you navigate the website together with your team.
Note: Please checkout Setup Section to get our chrome extension.
In order to integrate Sariska's Co-Browsing SDK into your website, you can either import the SDK from the npm registry or get the bundled file from our CDN. Both methods are described below.
If you are facing dependency conflict related issues, add --legacy-peer-deps as follows: $ npm i sariska-cobrowsing --legacy-peer-deps
You could also install the Sariska Co-Browsing library by adding the following script to your website's HTML head tag. Now you can access Co-Browsing API through the CoBrowse global object. This enables you to use the SDK from the browser. The script needs to be added at the bottom of your index.html file in order to work.
To import the SDK, add the following command to your code.
To initiate co-browsing, you need to provide either your API Key or JWT Token. Please provide different JWT tokens as Sariska utilizes JWT ID tokens for user authentication and verification.
In order to start co-browsing, call its startCoBrowsing method as shown below. Following parameters can be passed.
Please ensure that the sessionName or roomName consists of alphanumeric characters without using hyphens."
In order to stop co-browsing, call its stopCoBrowsing method as shown below.
In order to quickly test the SDK on your website, you can add the bundle file into your html head tab from our CDN. Once your website is running on a local or remote server, you can do the following to start co-browsing.
Open the console on your browser and write the following command
"user1" is the name of the first user and "room" is the room name for them to co-browse together. You'd see the following response in your console.
On a second tab or window, do the same operation again, for a second user.
"user2" is the name of the first user and "room" is the room name for them to co-browse together. You'd see the following response in your console.
Once both sessions are connected, you'd be able to see both mouse pointers on your webpage as shown.
Publish-Subscribe Messaging Pattern with Phoenix PubSub Adapter:
The Publish-Subscribe messaging pattern operates by enabling a group of consumers to subscribe to events based on specific topics. When an event is published into a topic channel, copies of the message are delivered to each subscriber, allowing for seamless communication without direct knowledge between producers and consumers.
In the context of Phoenix PubSub, which is based on pg , it operates on Distributed Erlang nodes following the principles of the CAP theorem. The underlying pg system is AP (Available and Partition Tolerant), ensuring availability even in the face of network partitions.
This adapter provides a seamless solution for sending and receiving Pub/Sub messages in Node.js applications. Notably, the Server version of the Phoenix channel allows for server-side channel joining. By subscribing to a set of "topics," applications can efficiently obtain messages published under those topics. This decoupling of producers and consumers enhances system flexibility and scalability.
This is only intended for back-end applications running on Node.js.
The first step is to install the Phonenix channel library by running the following command in your project directory using NPM.
Sariska's approach to pricing and billing our customers.
When you use Sariska's APIs to build your applications, the major resource consumption is bandwidth. Things like publishing a stream, starting a multi-party conference, messaging, sending or receiving streams, or sharing your screen, those offerings use bandwidth. The billing is done on the basis of how much bandwidth has been consumed by each user.
Secondly, Importing streams in other formats, like RTMP, recording rooms, or exporting tracks to third-party live streaming services, consumes bandwidth in a data center but also a significant amount of CPU cycles to transcode streams.
Bandwidth is metered in gigabytes (GB = 1000 MB). Our system tracks the amount of data transmitted from your application to our SFU (upstream), and data transmitted from our SFU back down to your application (downstream). When it comes time to tally your bill, we apply the following logic:
Take the greater of the upstream and downstream bandwidth.
Subtract the project's monthly free bandwidth allotment from the value determined in (1).
The result from (2) is your bandwidth overage in GB. If this number is greater than or equal to 1, the amount you owe is your overrage multiplied by your price-per-GB.
Metered in minutes of audio and video being transcoded. The minutes are the length of the video being transcoded and not the time is taken for the transcoding to get over.
When it comes time to tally your bill, we apply the following logic:
Take the total audio-only minutes transcoded and multiply by the price-per-minute.
Take the total video minutes transcoded and multiply by the price-per-minute.
Bandwidth
Transcoding
Empower your mobile applications with seamless real-time communication and media functionalities using the powerful Sariska Media Swift APIs. Integrate features like audio/video calling, live streaming, cloud recording, transcriptions, and language translation effortlessly into your iOS, macOS, watchOS, and tvOS apps.
With CocoaPods
Media Services utilizes WebSockets to establish a continuous, two-way communication channel between your application and the server. This persistent connection offers significant advantages over traditional HTTP requests, particularly in terms of responsiveness.
Create a Jitsi-powered conference for real-time audio and video.
Media Stream
A MediaStream is a collection of audio or video tracks, represented by MediaStreamTrack objects.
Each MediaStreamTrack can have multiple channels (e.g., left and right channels in a stereo audio track).
Capture Local Tracks
Define options:
Specify desired devices ("audio", "video", or "desktop").
Set preferred video resolution.
Optionally configure specific devices, frame rates, screen sharing options, and facing mode.
This event is triggered when a new user joins the conference. Moderators have exclusive control over meetings and can manage participants. To assign a moderator, set the moderator
value to true
when generating the token.
Make audio and video streams visible to others in the conference by publishing them using the following code:
Sariska-media-transport offers pre-configured events to help you track and analyze user interactions, media usage, and overall performance. This data can be used to enhance your product, improve user experience, and make informed decisions.
Available Events
Here are some of the key events you can track:
User Actions:
User joined
User left
Media Usage:
Conference duration
Camera duration
Audio track duration
Video track duration
Recording:
Recording started
Recording stopped
Local recording started
Local recording stopped
Transcription:
Transcription started
Transcription stopped
Performance:
Speaker stats
Connection stats
Performance stats
Add Event Listener to Track Events
Sariska offers powerful features to enhance your application's capabilities. Find your desired feature using the search bar or explore below!
Identify the main speaker: Easily detect the active or dominant speaker in a conference. Choose to stream only their video for improved resolution and reduced bandwidth usage. Ideal for one-way streaming scenarios like virtual concerts.
Dynamically showcase recent speakers: Focus on the active conversation by displaying video only for the last N participants who spoke. This automatically adjusts based on speech activity, offering a more efficient and relevant view.
Set local participant properties: Define additional information about participants beyond the default settings. This can include screen-sharing status, custom roles, or any other relevant attributes.
Get the total number of participants: Retrieve the complete participant count, including both visible and hidden members.
Access all participants: Obtain a list of all participants, including their IDs and detailed information.
Pin a single participant: Give a participant higher video quality (if simulcast is enabled).
Pin multiple participants: Give multiple participants higher video quality.
Retrieve information about the local user directly from the conference object.
Set the subject of the meeting.
Get all remote tracks: Retrieve a list of all remote tracks (audio and video) in the conference.
Get all local tracks: Retrieve a list of all local tracks (audio and video)
Listen for participant kick events
Kick a participant
Kick a moderator
The room creator has a moderator role, while other users have a participatory role.
Grant owner rights
Listen for role changes
Revoke owner rights
Setting a new display name
Listen for display name changes
Lock room: Moderators can restrict access to the room with a password.
Unlock room: Removes any existing password restriction.
Request subtitles: Enable subtitles for spoken content.
Request language translation: Translate subtitles into a specific language.
Receive subtitles: Listen for incoming subtitles.
Stop subtitles: Disable subtitles.
Each participant can contribute two types of data to a meeting: audio and video. Screen sharing counts as a video track. If you want to share your screen while also showing your own video (like when presenting), you need to enable "Presenter mode". This mode hides the gallery of other participants' videos and gives you more control over the meeting layout.
Start screen share: Share your screen with other participants.
Sariska offers robust messaging capabilities for both private and group communication scenarios.
Send a group message to all participants
Send a private message to a specific participant
Listen for incoming messages
Start Transcription: Initiate transcription for the ongoing conference.
Stop Transcription: Stop transcription and get a download link for the transcript.
Mute Remote Participant
Mute/Unmute Local Participant
Local Connection Statistics Received
Remote Connection Statistics Received
The SDK features intelligent auto-join/leave functionality based on internet connectivity status. This helps optimize network resources and improve user experience.
Designed for efficient communication between two participants.
Start Peer-to-Peer Mode
Sariska automatically activates Peer-to-Peer mode when your conference has exactly two participants. This mode bypasses the central server and directly connects participants, maximizing bandwidth efficiency and reducing latency. However, even with more than two participants, you can forcefully start Peer-to-Peer mode.
Stop Peer-to-Peer Mode
If you need to revert to server-mediated communication, you can easily stop Peer-to-Peer mode.
Monitor your WebRTC application performance using CallStats (or build your own). See the "RTC Stats" section for details.
Join conferences with audio and video already muted, or in a silent mode where no audio is transmitted or received. This ensures a seamless experience and respects participant preferences.
Join with Muted Audio and Video
Join in Silent Mode
Broadcast your conference to multiple platforms simultaneously. Embed live streams directly into your app or website using various formats.
Stream to YouTube
Stream to Facebook
Stream to Twitch
Stream to any RTMP Server
Listen for RECORDER_STATE_CHANGED
event to track streaming status
Stop Live Stream
Store your recordings and transcriptions in various cloud storage services.
Dial-in(PSTN)
Dial-out(PSTN)
This allows synchronous phone calls, similar to WhatsApp, even if the receiver's app is closed or in the background.
Initiating Calls:
Make a call even if the callee's app is closed or in the background.
Play a busy tone if the callee is on another call or disconnects your call.
Play ringtone/ringback/DTMF tones.
Step 1 : Caller Initiates Call
HTTP Call to Sariska Server
{API Method}
Push Notification to callee using Firebase or APNS
This notifies the receiver even if their app is closed or in the background.
Step 2 : Callee Responds to Call
Reads Push Notification
Processes the notification even if the app is closed or in the background.
HTTP Call to Update Status
{API Method}
No need to join conference via SDK
Status update through the HTTP call suffices.
Step 3 : Caller Receives Response
Listens for USER_STATUS_CHANGED event
Step 4 : After Connection Established
The call proceeds like a normal conference call.
Sariska Media provides a robust suite of Kotlin APIs designed to streamline the development of real-time android applications. With Sariska, you can seamlessly integrate a variety of features.
With Pre-built Artifacts
For older Android Studio versions:
In your project's root directory, locate the build.gradle
file.
Add the following code block within the repositories
section:
For newer Android Studio versions:
In your project's root directory, locate the settings.gradle
file.
Add the following code block within the repositories
section:
With Maven
Add the dependency:
After installing the Sariska Media Transport SDK, begin by initializing it.
Media Services utilizes WebSockets to establish a continuous, two-way communication channel between your application and the server. This persistent connection offers significant advantages over traditional HTTP requests, particularly in terms of responsiveness.
Create a Jitsi-powered conference for real-time audio and video.
A MediaStream consists of various audio or video tracks represented by MediaStreamTrack objects. Each track can have multiple channels, which are the smallest units of the stream (e.g., left and right audio channels in stereo).
This event is triggered when a new user joins the conference. Moderators have exclusive control over meetings and can manage participants. To assign a moderator, set the moderator
value to true
when generating the token.
Make audio and video streams visible to others in the conference by publishing them using the following code:
Sariska-media-transport offers pre-configured events to help you track and analyze user interactions, media usage, and overall performance. This data can be used to enhance your product, improve user experience, and make informed decisions.
Available Events
Here are some of the key events you can track:
User Actions:
User joined
User left
Media Usage:
Conference duration
Camera duration
Audio track duration
Video track duration
Recording:
Recording started
Recording stopped
Local recording started
Local recording stopped
Transcription:
Transcription started
Transcription stopped
Performance:
Speaker stats
Connection stats
Performance stats
Add Event Listener to Track Events
Sariska offers powerful features to enhance your application's capabilities. Find your desired feature using the search bar or explore below!
Identify the main speaker: Easily detect the active or dominant speaker in a conference. Choose to stream only their video for improved resolution and reduced bandwidth usage. Ideal for one-way streaming scenarios like virtual concerts.
Dynamically showcase recent speakers: Focus on the active conversation by displaying video only for the last N participants who spoke. This automatically adjusts based on speech activity, offering a more efficient and relevant view.
Set local participant properties: Define additional information about participants beyond the default settings. This can include screen-sharing status, custom roles, or any other relevant attributes.
Get the total number of participants: Retrieve the complete participant count, including both visible and hidden members.
Access all participants: Obtain a list of all participants, including their IDs and detailed information.
Pin a single participant: Give a participant higher video quality (if simulcast is enabled).
Pin multiple participants: Give multiple participants higher video quality.
Retrieve information about the local user directly from the conference object.
Set the subject of the meeting.
Get all remote tracks: Retrieve a list of all remote tracks (audio and video) in the conference.
Get all local tracks: Retrieve a list of all local tracks (audio and video)
Listen for participant kick events
Kick a participant
The room creator has a moderator role, while other users have a participatory role.
Grant owner rights
Listen for role changes
Revoke owner rights
Setting a new display name
Listen for display name changes
Lock room: Moderators can restrict access to the room with a password.
Unlock room: Removes any existing password restriction.
Request subtitles: Enable subtitles for spoken content.
Request language translation: Translate subtitles into a specific language.
Receive subtitles: Listen for incoming subtitles.
Stop subtitles: Disable subtitles.
Each participant can contribute two types of data to a meeting: audio and video. Screen sharing counts as a video track. If you want to share your screen while also showing your own video (like when presenting), you need to enable "Presenter mode". This mode hides the gallery of other participants' videos and gives you more control over the meeting layout.
Start screen share: Share your screen with other participants.
Sariska offers robust messaging capabilities for both private and group communication scenarios.
Send a group message to all participants
Send a private message to a specific participant
Listen for incoming messages
Start Transcription: Initiate transcription for the ongoing conference.
Stop Transcription: Stop transcription and get a download link for the transcript.
Mute Remote Participant
Mute/Unmute Local Participant
Local Connection Statistics Received
Remote Connection Statistics Received
The SDK features intelligent auto-join/leave functionality based on internet connectivity status. This helps optimize network resources and improve user experience.
Designed for efficient communication between two participants.
Start Peer-to-Peer Mode
Sariska automatically activates Peer-to-Peer mode when your conference has exactly two participants. This mode bypasses the central server and directly connects participants, maximizing bandwidth efficiency and reducing latency. However, even with more than two participants, you can forcefully start Peer-to-Peer mode.
Stop Peer-to-Peer Mode
If you need to revert to server-mediated communication, you can easily stop Peer-to-Peer mode.
Monitor your WebRTC application performance using CallStats (or build your own). See the "RTC Stats" section for details.
Join conferences with audio and video already muted, or in a silent mode where no audio is transmitted or received. This ensures a seamless experience and respects participant preferences.
Join with Muted Audio and Video
Join in Silent Mode
Broadcast your conference to multiple platforms simultaneously. Embed live streams directly into your app or website using various formats.
Stream to YouTube
Stream to Facebook
Stream to Twitch
Stream to any RTMP Server
Listen for RECORDER_STATE_CHANGED
event to track streaming status
Stop Live Stream
Store your recordings and transcriptions in various cloud storage services.
Dial-in(PSTN)
Dial-out(PSTN)
This allows synchronous phone calls, similar to WhatsApp, even if the receiver's app is closed or in the background.
Initiating Calls:
Make a call even if the callee's app is closed or in the background.
Play a busy tone if the callee is on another call or disconnects your call.
Play ringtone/ringback/DTMF tones.
Step 1 : Caller Initiates Call
HTTP Call to Sariska Server
{API Method}
Push Notification to callee using Firebase or APNS
This notifies the receiver even if their app is closed or in the background.
Step 2 : Callee Responds to Call
Reads Push Notification
Processes the notification even if the app is closed or in the background.
HTTP Call to Update Status
{API Method}
No need to join conference via SDK
Status update through the HTTP call suffices.
Step 3 : Caller Receives Response
Listens for USER_STATUS_CHANGED event
Step 4 : After Connection Established
The call proceeds like a normal conference call.
Unleash real-time audio/video, live streaming, cloud recording, transcriptions, language translation, and more in your web and mobile apps with the versatile Sariska Media JavaScript APIs.
Seamlessly integrate with various JavaScript frameworks (Vanilla, React, Angular, Vue, Electron, NW, React Native, and more).
Access a rich set of features for audio/video conferencing, live streaming, cloud recording, transcriptions, language translation, virtual backgrounds, and more.
Maintain persistent, low-latency connections for real-time data exchange.
With NPM
With CDN
Add a script tag to your HTML head
At the very beginning of your index.js
file, insert the following import statement:
Kickstart the SDK with this simple command:
Create a persistent connection for real-time communication.
Create a Jitsi-powered conference for real-time audio and video
Media Stream
A MediaStream is a collection of audio or video tracks, represented by MediaStreamTrack objects.
Each MediaStreamTrack can have multiple channels (e.g., left and right channels in a stereo audio track).
Capture Local Tracks
Define options:
Specify desired devices ("audio", "video", or "desktop").
Set preferred video resolution.
Optionally configure specific devices, frame rates, screen sharing options, and facing mode.
Create Local Tracks
This event is triggered when a new user joins the conference. Moderators have exclusive control over meetings and can manage participants. To assign a moderator, set the moderator
value to true
when generating the token.
Make audio and video streams visible to others in the conference by publishing them using the following code:
Additional methods for remote tracks:
getType():
Returns the track type (audio, video, or desktop)
stream.toURL():
Returns the stream URL
getId():
Returns the track ID
isMuted():
Checks if the track is muted
getParticipantId():
Returns the participant ID associated with the track
isLocal():
Checks if the track is local
attach():
Attaches the track to an audio or video element
detach():
Detaches the track from an audio or video element
Additional methods for remote tracks:
getType():
Returns the track type (audio, video, or desktop)
getStreamURL():
Returns the URL of the stream
getId():
Returns the ID of the track
isMuted():
Checks if the track is muted
getParticipantId():
Returns the ID of the participant who owns the track
isLocal():
Checks if the track is local
Additional RTCView properties for styling:
mirror:
Mirrors the video horizontally (true or false)
cover:
Controls how the video fills the view ("contain" or "cover")
zOrder:
Sets the stacking order of the view (0 or 1)
Sariska-media-transport offers pre-configured events to help you track and analyze user interactions, media usage, and overall performance. This data can be used to enhance your product, improve user experience, and make informed decisions.
Available Events
Here are some of the key events you can track:
User Actions:
User joined
User left
Media Usage:
Conference duration
Camera duration
Audio track duration
Video track duration
Recording:
Recording started
Recording stopped
Local recording started
Local recording stopped
Transcription:
Transcription started
Transcription stopped
Performance:
Speaker stats
Connection stats
Browser performance stats
Add Event Listener to Track Events
Sariska offers powerful features to enhance your application's capabilities. Find your desired feature using the search bar or explore below!
Identify the main speaker: Easily detect the active or dominant speaker in a conference. Choose to stream only their video for improved resolution and reduced bandwidth usage. Ideal for one-way streaming scenarios like virtual concerts.
Dynamically showcase recent speakers: Focus on the active conversation by displaying video only for the last N participants who spoke. This automatically adjusts based on speech activity, offering a more efficient and relevant view.
Set local participant properties: Define additional information about participants beyond the default settings. This can include screen-sharing status, custom roles, or any other relevant attributes.
Get the total number of participants: Retrieve the complete participant count, including both visible and hidden members.
Access all participants: Obtain a list of all participants, including their IDs and detailed information.
Advanced manipulation: You can directly access the conference
object for more granular control over conference behavior.
Pin a single participant: Pin a specific participant to always receive their video, even when "last n" is enabled.
Pin multiple participants: Pin an array of participants to always receive their videos.
Retrieve the local user's ID: Get the ID of the local user.
Retrieve the local user's information: Get comprehensive details about the local user, including name, email, ID, and avatar.
Retrieve the local user's role: Get the role of the local user (For example, participant, moderator, owner).
Get all remote tracks: Retrieve a list of all remote tracks (audio and video) in the conference.
Get all local tracks: Retrieve a list of all local tracks (audio and video)
Split your conference meeting into smaller, focused groups with unique audio and video. Moderators can create rooms, assign participants, and reunite everyone seamlessly.
Access breakout rooms: Get an instance to manage breakout rooms.
Create a breakout room: Create a new breakout room with the specified subject.
Remove a breakout room: Remove the current breakout room (if applicable).
Check for breakout room status: Determine if the current room is a breakout room.
Send a participant to a breakout room: Move a participant to a specific breakout room.
Listen for participant kick events
Kick a participant
Kick a moderator
The room creator has a moderator role, while other users have a participatory role.
Grant owner rights
Listen for role changes
Revoke owner rights:
Setting a new display name
Listen for display name changes
Lock room: Moderators can restrict access to the room with a password.
Unlock room: Removes any existing password restriction.
Request subtitles: Enable subtitles for spoken content.
Request language translation: Translate subtitles into a specific language.
Receive subtitles: Listen for incoming subtitles.
Stop subtitles: Disable subtitles.
Start screen share: Share your screen with other participants.
Stop screen share: Stop sharing your screen.
Sariska offers robust messaging capabilities for both private and group communication scenarios.
Send and Receive Private Text Messages
Send and Receive Private Payload
Send and Receive Group Text Messages
Send and Receive Group Payload
Start Transcription: Initiate transcription for the ongoing conference.
Stop Transcription: Stop transcription and get a download link for the transcript.
Mute Remote Participant
Mute/Unmute Local Participant
Local Connection Statistics Received
Remote Connection Statistics Received
No Audio Signal
Audio Input State Changed
Audio Level Indicator
Noise Detection
Detect excessive noise from the microphone used in the conference.
Talk While Muted Detection
Noise Suppression/Cancellation
Reduces background noise from audio signals using a recurrent neural network (RNN).
Change the background behind you in video calls with various options:
Image: Define a static image as the background
Blur: Blur the background for a subtle effect
Screen Share: Show your computer screen as the background
Start: Apply the effect to your local video track
Stop: Remove the effect from your video track
Periodically capture screenshots of your screen share (e.g., every 30 seconds) and upload them to your server for analysis.
Start capturing
Stop capturing
Monitor your WebRTC application performance using CallStats (or build your own). See the "RTC Stats" section for details.
This ensures seamless connectivity even in the face of fluctuating internet connections. It automatically manages connections and disconnections as needed.
Get valuable insights into the current conversation, specifically focusing on speaker dominance. It analyzes the interaction and estimates how long each participant has held the dominant speaker role.
Gain insights into the connection quality of conference participants.
Combine multiple audio tracks into a single, unified audio stream.
Empower your application with robust end-to-end encryption, ensuring secure communication for your users.
Enable End-to-End Encryption
Disable End-to-End Encryption
Join conferences with audio and video already muted, or in a silent mode where no audio is transmitted or received. This ensures a seamless experience and respects participant preferences.
Join with Muted Audio and Video
Join in Silent Mode
Broadcast your conference to multiple platforms simultaneously. Embed live streams directly into your app or website using various formats.
Store your recordings and transcriptions in various cloud storage services.
Dial-in(PSTN)
Dial-out(PSTN)
Designed for efficient communication between two participants.
Sariska automatically activates Peer-to-Peer mode when your conference has exactly two participants. This mode bypasses the central server and directly connects participants, maximizing bandwidth efficiency and reducing latency. However, even with more than two participants, you can forcefully start Peer-to-Peer mode.
This allows synchronous phone calls, similar to WhatsApp, even if the receiver's app is closed or in the background.
Initiating Calls:
Make a call even if the callee's app is closed or in the background.
Play a busy tone if the callee is on another call or disconnects your call.
Play ringtone/ringback/DTMF tones.
Step 1 : Caller Initiates Call
HTTP Call to Sariska Server
{API Method}
Push Notification to callee using Firebase or APNS
This notifies the receiver even if their app is closed or in the background.
Step 2 : Callee Responds to Call
Reads Push Notification (using react-native-callkeep)
Processes the notification even if the app is closed or in the background.
HTTP Call to Update Status
{API Method}
No need to join conference via SDK
Status update through the HTTP call suffices.
Step 3 : Caller Receives Response
Listens for USER_STATUS_CHANGED event
Step 4 : After Connection Established
The call proceeds like a normal conference call.
React Native Libraries:
react-native-callkeep: Handles notifications and call events even when the app is closed or in the background.
react-native-incall-manager: Manages device events like headset state, proximity sensors, and audio routing.
For instance, a received SIP INVITE with a 'Jitsi-Conference-Room' header containing 'room1234' will prompt Jigasi to join the conference '.' Here, 'meet.example.com' is assumed to be the domain of the Sariska Meet environment.
For a full list of APIs go to:
Download the package manager from
For other polls APIs, please refer to documentation
The package manager can be downloaded by clicking on the following link.
For other polls apis checkout
For more detailed information on the APIs, check out the
For detailed real-time messaging API's , follow . For detailed management of chat and room APIs, refer to Sariska
The development of an android project in unreal requires changes to your unreal editor preferences. Follow the steps below to quickly start up with a project or you can follow the official quick start guide by Unreal .
Sariska's Media Plugin for Unreal can be cloned from
More details on pricing and benchmarking can be found at
In order to get started with using the Co-Browsing SDK, you will need your API key which you generated in console.sariska.io. For more details, follow this .
With CDN:
With NPM:
Hosted Demo:
Sariska's pricing model is based on the fundamentals that users should only pay for what has been used. Our gives you a detailed breakdown of how we approach pricing and how it differentiates us from per-minute-based offerings.
uses a powerful RNN to silence unwanted noise in your audio. This open-source library can significantly enhance audio quality.
$0.18
--
1,000 GB
$0.16
11.11%
10,000 GB
$0.14
22.2%
50,000 GB
$0.12
33%
100,000 GB
Audio-Only
$ 0.005
Video
$0.02
af
Afrikaans
ar
Arabic
bg
Bulgarian
ca
Catalan
cs
Czech
da
Danish
de
German
el
Greek
en
English
enGB
English (United Kingdom)
eo
Esperanto
es
Spanish
esUS
Spanish (Latin America)
et
Estonian
eu
Basque
fi
Finnish
fr
French
frCA
French (Canadian)
he
Hebrew
hi
Hindi
hr
Croatian
hu
Hungarian
hy
Armenian
id
Indonesian
it
Italian
ja
Japanese
kab
Kabyle
ko
Korean
lt
Lithuanian
ml
Malayalam
lv
Latvian
nl
Dutch
oc
Occitan
fa
Persian
pl
Polish
pt
Portuguese
ptBR
Portuguese (Brazil)
ru
Russian
ro
Romanian
sc
Sardinian
sk
Slovak
sl
Slovenian
sr
Serbian
sq
Albanian
sv
Swedish
te
Telugu
th
Thai
tr
Turkish
uk
Ukrainian
vi
Vietnamese
zhCN
Chinese (China)
zhTW
Chinese (Taiwan)
mr
Marathi
af
Afrikaans
ar
Arabic
bg
Bulgarian
ca
Catalan
cs
Czech
da
Danish
de
German
el
Greek
en
English
enGB
English (United Kingdom)
eo
Esperanto
es
Spanish
esUS
Spanish (Latin America)
et
Estonian
eu
Basque
fi
Finnish
fr
French
frCA
French (Canadian)
he
Hebrew
hi
Hindi
hr
Croatian
hu
Hungarian
hy
Armenian
id
Indonesian
it
Italian
ja
Japanese
kab
Kabyle
ko
Korean
lt
Lithuanian
ml
Malayalam
lv
Latvian
nl
Dutch
oc
Occitan
fa
Persian
pl
Polish
pt
Portuguese
ptBR
Portuguese (Brazil)
ru
Russian
ro
Romanian
sc
Sardinian
sk
Slovak
sl
Slovenian
sr
Serbian
sq
Albanian
sv
Swedish
te
Telugu
th
Thai
tr
Turkish
uk
Ukrainian
vi
Vietnamese
zhCN
Chinese (China)
zhTW
Chinese (Taiwan)
mr
Marathi
af
Afrikaans
ar
Arabic
bg
Bulgarian
ca
Catalan
cs
Czech
da
Danish
de
German
el
Greek
en
English
enGB
English (United Kingdom)
eo
Esperanto
es
Spanish
esUS
Spanish (Latin America)
et
Estonian
eu
Basque
fi
Finnish
fr
French
frCA
French (Canadian)
he
Hebrew
hi
Hindi
hr
Croatian
hu
Hungarian
hy
Armenian
id
Indonesian
it
Italian
ja
Japanese
kab
Kabyle
ko
Korean
lt
Lithuanian
ml
Malayalam
lv
Latvian
nl
Dutch
oc
Occitan
fa
Persian
pl
Polish
pt
Portuguese
ptBR
Portuguese (Brazil)
ru
Russian
ro
Romanian
sc
Sardinian
sk
Slovak
sl
Slovenian
sr
Serbian
sq
Albanian
sv
Swedish
te
Telugu
th
Thai
tr
Turkish
uk
Ukrainian
vi
Vietnamese
zhCN
Chinese (China)
zhTW
Chinese (Taiwan)
mr
Marathi
audioSsrc
The audio SSRC (Synchronization Source identifier)
bandwidth
The estimated available bandwidth in bits per second
bitrate
The current media bitrate in bits per second
bridgeCount
The number of bridges in use
codec
The codec being used for media transmission
connectionSummary
A brief summary of the connection quality (e.g., "Good", "Fair", "Poor")
e2eRtt
The estimated end-to-end round-trip time in milliseconds
participantId
The ID of the participant
framerate
The current media framerate in frames per second
isLocalVideo
Indicates whether the stats are for the local participant's video
maxEnabledResolution
The maximum resolution enabled for the participant
packetLoss
The percentage of packet loss
region
The region where the participant is located
resolution
The current resolution of the media stream
serverRegion
The region of the server handling the connection
shouldShowMore
Indicates whether more detailed connection stats are available
videoSsrc
The video SSRC
transport
The transport protocol being used (e.g., "UDP", "TCP")
Sariska Media provides powerful Java API's for developing real-time applications.
You can integrate audio/video, live streaming cloud recording, transcriptions, language translation and many other services on the fly.
This API documentation describes all possible features supported by sariska-media-transport which possibly covers any of your use cases.
In your project, add the Maven repository https://github.com/SariskaIO/sariska-maven-repository/raw/master/releases
and the dependency io.sariska:sariska-media-transport
into your build.gradle
files.
The repository typically goes into the build.gradle
file in the root of your project:
In recent versions of Android Studios, allprojects{}
might not be found in build.gradle
. In that case, the repository goes into the settings.gradle
file in the root of your project:
Dependency definitions belong in the individual module build.gradle
files:
After you install the SDK, perform initial setup tasks by running initializeSdk()
.
WebSockets are ideal to keep a single, persistent session. Unlike HTTPS, WebSocket requests are updated almost immediately. To start using the media services, the primary step is to create a Media WebSocket connection.
Once you have your connection established, the next step is to create a conference. Sariska is backed by the Jitsi architecture.
A MediaStream consists of zero or more MediaStreamTrack objects, representing various audio or video tracks.
Each MediaStreamTrack may have one or more channels. The channel represents the smallest unit of a media stream, such as an audio signal associated with a given speaker, like left or right in a stereo audio track. Here we mostly talk about track.
This will be your most basic conference call. However, we recommend following up with the two further steps to add customized features to enhance your experience.
Note: You don't any audio element to play sound as it plays in conjunction with video stream.
The moderator of the meeting controls and gatekeeps the participants. The moderator has exclusive control of the meeting.
If you wish to have a moderator, pass the moderator
value as true while generating your token. Moderator has the following permissions:
Ability to add a password to a room
Ability to grant the moderator role to non-moderators
Ability to kick non-moderators or other moderators
Ability to mute participates
Ability to make everyone see the moderator video (Everyone follows me)
Ability to make participants join muted (Everyone starts muted)
Ability to make participants join without video (Everyone starts hidden)
Ability to enable/disable the lobby room
Ability to approve join/knocking requests (when the lobby is enabled)
When the moderator leaves, a new one is selected automatically
Use the following code to now publish your call.
That's it you are done with a basic conference call, Follow the guide below for more features.
Sariska-media-transport comes with pre-configured top events used to help improvise your product and overall consumer experience.
Few popular events:
User left
User joined
Conference duration
Camera duration
Audio track duration
Video track duration
Recording started
Recording stopped
Transcription started
Transcription stopped
Local Recording started
Local Recording stopped
Speaker Stats
We will be updating the list of features soon.
You can easily detect the active or the dominant speaker. You could choose to stream only their video, thereby saving on the costs and better resolution to others. This is could be a use case for one-way streaming; such as virtual concerts.
The idea is that we select a subset of N participants, whose video to show, and we stop the video from others. We dynamically and automatically adjust the set of participants that we show according to who speaks – effectively we only show video for the last N people to have spoken.
Set Local Participant Property
Get participant count
Note: Hidden participants are generally bots join the conference along with actual participants. For example: recorder, transcriber, pricing agent.
Get all participants in conference
Get all participants in conference without hidden participants
Pin/Select participant
Select/Pin Multiple Participants
Access local user details directly from conference
Get all remote tracks
Get all local tracks
Grant Owner
Except for the room creator, the rest of the users have a participatory role. You can grant them owner rights with the following code.
Revoke Owner
To revoke owner rights from a participant, use the following code.
Lock room
A moderator can lock a room with a password. Use the code as follows.
Unlock room
Start Screen Sharing
A participant supports 2 tracks at a type: audio and video. Screen sharing(desktop) is also a type of video track. If you need screen sharing along with the speaker video you need to have Presenter mode enabled.
Start Transcription
Stop Transcription
Mute/Unmute Local participant
Mute Remote participant
The moderator can mute any remote participant.
SDK is already configured to auto-join/leave when the internet connection fluctuates.
Start peer-to-peer mode
Sariska automatically switches to peer peer-to-peer mode if participants in the conference exactly 2. You can, however, still, you can forcefully switch to peer-to-peer mode.
Note: Conferences started on peer-to-peer mode will not be charged until the turn server is not used.
Stop peer-to-peer mode
To monitor your WebRTC application, simply integrate the call stats or build your own by checking out the RTC Stats section.
Join Silent( no audio will be sent/receive)
join conference with silent mode no audio sent/receive
Join Muted
To start a conference with already muted options.
Stream to YouTube
You can get youtube stream key manually by login to your youtube account or use google OAuth API
Stream to Facebook
You can get facebook streamId manually by login to your facebook account or use Facebook OAuth API.
Stream to Twitch
Stream to any RTMP server
Listen for RECORDER_STATE_CHANGED event to know live streaming status
Stop Live Streaming
Stop Cloud Recording
Dial-in(PSTN)
Dial-out(PSTN)
To enable the feature for waiting room/lobby checkout APIs below
One-to-one calling is more of the synchronous way of calling where you deal with things like
Calling someone even if his app is closed or background
Play a busy tone if a user is busy on another call or disconnected your call
Play ringtone/ringback/dtmftone
This is similar to how WhatsApp works.
Make an HTTP call to the Sariska server
Send push notifications to callee using your Firebase or APNS account
Callee now reads the push notification using ConnectionService or CallKit even if the app is closed or in the background
Callee can update his status back to the caller just by making an updated HTTP Call, no needs to join the conference via SDK
Since, the Caller has already joined the conference using SDK he can easily get the status just by listening USER_STATUS_CHANGED event
After the callee has joined the conference rest of the steps are the same as the normal conference call
Calendar Sync
Now you can programmatically start scheduling a meeting with google/microsoft calendar.
This integration adds the /sariska slash command for your team so that you can start a video conference in your channel, making it easy for everyone to just jump on the call. The slash command, /sariska, will drop a conference link in the channel for all to join.
Mentioning one or more teammates, after /sariska, will send personalized invites to each user mentioned. Check out how it is integrated here.
Low-level logging on peer connection API calls and periodic getStats calls for analytics/debugging purposes. Make sure you have passed RTCstats WebSocket URL while initializing the conference. Check out how to configure RTCStats WebSocket Server here.
Sariska supports building browser (accessed from a browser like Google Chrome, Safari either via laptop/PC or mobile) applications involving media (Transmission of images, videos and audio) through:
React
AngularJS
Swift (iOs)
TIP: Follow the detailed written instructions in READ.ME section of the repository.
Simply clone the repository in your project directory.
Conference calling:
Simply clone the repository in your project directory.
Conference calling:
Simply clone the repository in your project directory.
One-to-one calling:
Simply clone the repository in your project directory.
Conference calling:
Sariska Media provides powerful Dart API's for developing real-time applications.
You can integrate audio/video, live streaming cloud recording, transcriptions, language translation, virtual background and many other services on the fly.
This API documentation describes all possible features supported by sariska-media-transport which possibly covers any of your use cases.
The command above will add this to the pubspec.yaml
file in your project (you can do this manually):
After you install the SDK, perform initial setup tasks by running initializeSdk()
.
WebSockets are ideal to keep a single, persistent session. Unlike HTTPS, WebSocket requests are updated almost immediately. To start using the media services, the primary step is to create a Media WebSocket connection.
Once you have your connection established, the next step is to create a conference. Sariska is backed by the Jitsi architecture.
A MediaStream consists of zero or more MediaStreamTrack objects, representing various audio or video tracks.
Each MediaStreamTrack may have one or more channels. The channel represents the smallest unit of a media stream, such as an audio signal associated with a given speaker, like left or right in a stereo audio track. Here we mostly talk about track.
This will be your most basic conference call. However, we recommend following up with the two further steps to add customized features to enhance your experience.
Note: You don't any audio element to play sound as it is in conjunction with video the stream.
The moderator of the meeting controls and gatekeeps the participants. The moderator has exclusive control of the meeting.
If you wish to have a moderator, pass the moderator
value as true while generating your token. Moderator has the following permissions:
Ability to add a password to a room
Ability to grant the moderator role to non-moderators
Ability to kick non-moderators or other moderators
Ability to mute participates
Ability to make everyone see the moderator video (Everyone follows me)
Ability to make participants join muted (Everyone starts muted)
Ability to make participants join without video (Everyone starts hidden)
Ability to enable/disable the lobby room
Ability to approve join/knocking requests (when the lobby is enabled)
When the moderator leaves, a new one is selected automatically.
Use the following code to now publish your call.
That's it you are done with a basic conference call, Follow the guide below for more features.
Sariska-media-transport comes with pre-configured top events used to help improvise your product and overall consumer experience.
Few popular events:
User left
User joined
Conference duration
Camera duration
Audio track duration
Video track duration
Recording started
Recording stopped
Transcription started
Transcription stopped
Local Recording started
Local Recording stopped
Speaker Stats
We will be updating the list of features soon.
You can easily detect the active or the dominant speaker. You could choose to stream only their video, thereby saving on the costs and better resolution to others. This is could be a use case for one-way streaming; such as virtual concerts.
The idea is that we select a subset of N participants, whose video to show, and we stop the video from others. We dynamically and automatically adjust the set of participants that we show according to who speaks – effectively we only show video for the last N people to have spoken.
Set Local Participant Property
Get participant count
Note: Hidden participants are generally bots join the conference along with actual participants. For example: recorder, transcriber, pricing agent.
Get all participants in conference
Get all participants in conference without hidden participants
Pin/Select participant
Select/Pin Multiple Participants
Access local user details directly from conference
Get all remote tracks
Get all local tracks
Grant Owner
Except for the room creator, the rest of the users have a participatory role. You can grant them owner rights with the following code.
Revoke Owner
To revoke owner rights from a participant, use the following code.
Lock room
A moderator can lock a room with a password. Use the code as follows.
Unlock room
Start Screen Sharing
A participant supports 2 tracks at a type: audio and video. Screen sharing(desktop) is also a type of video track. If you need screen sharing along with the speaker video you need to have Presenter mode enabled.
Start Transcription
Stop Transcription
Mute/Unmute Local participant
Mute Remote participant
The moderator can mute any remote participant.
SDK is already configured to auto join/leave when internet connection fluctuates.
Start peer-to-peer mode
Sariska automatically switches to peer peer-to-peer mode if participants in the conference exactly 2. You can, however, still you can forcefully switch to peer-to-peer mode.
Note: Conferences started on peer-to-peer mode will not be charged until the turn server is not used.
Stop peer-to-peer mode
To monitor your WebRTC application, simply integrate the callstats or build your own by checking out the RTC Stats section.
Join Silent( no audio will be sent/receive)
join conference with silent mode no audio sent/receive
Join Muted
To start a conference with already muted options.
Stream to YouTube
You can get the youtube stream key manually by login to your youtube account or using google OAuth API
Stream to Facebook
You can get facebook streamId manually by login int to your facebook account or using Facebook OAuth API.
Stream to Twitch
Stream to any RTMP server
Listen for RECORDER_STATE_CHANGED event to know live streaming status
Stop Live Streaming
Stop Cloud Recording
Dial-in(PSTN)
Dial-out(PSTN)
To enable the feature for waiting room/lobby checkout API's below
One to one calling is more of synchronous way of calling where you deal with things like
Calling someone even if his app is closed or background
Play a busy tone if a user is busy on another call or disconnected your call
Play ringtone/ringback/dtmftone
This is similar to how WhatsApp works.
Make an HTTP call to the Sariska server
Send push notifications to callee using your Firebase or APNS account
Callee now reads the push notification using ConnectionService or CallKit even if the app is closed or in the background
Callee can update his status back to the caller just by making an updated HTTP Call, no needs to join the conference via SDK
Since the Caller has already joined the conference using SDK he can easily get the status just by listening USER_STATUS_CHANGED event
After the callee has joined the conference rest of the steps are the same as the normal conference call
Calendar Sync
Now you can programmatically start scheduling a meeting with google/microsoft calendar.
This integration adds the /sariska slash command for your team so that you can start a video conference in your channel, making it easy for everyone to just jump on the call. The slash command, /sariska, will drop a conference link in the channel for all to join.
Mentioning one or more teammates, after /sariska, will send personalized invites to each user mentioned. Check out how it is integrated here.
Low-level logging on peer connection API calls and periodic getStats calls for analytics/debugging purposes. Make sure you have passed RTCstats WebSocket URL while initializing the conference. Check out how to configure RTCStats WebSocket Server here.
Sariska supports building mobile applications involving media (Transmission of images, videos and audio) through:
Kotlin (Android)
Java (Android)
Swift (iOs)
React Native
Flutter
TIP: Follow the detailed written instructions in READ.ME section of the repository.
Simply clone the repository in your project directory.
Conference Call:
Simply clone the repository in your project directory.
Conference Call:
Simply clone the repository in your project directory.
For Conference Call:
Simply clone the repository in your project directory.
Conference Call:
One-to-one call:
Simply clone the repository in your project directory.
Conference Call:
Simply clone the repository in your project directory.
One-to-one call (Android):
Simply clone the repository in your project directory.
Conference Call:
Sariska supports building Desktop Apps involving media (Transmission of images, videos and audio) through:
Electron.js
NW.js
Electron is an open-source software framework developed and maintained by GitHub. It allows for the development of desktop GUI applications using web technologies: it combines the Chromium rendering engine and the Node.js runtime.
Available on Linux, Mac OS X, and Windows
Simply clone the repository in your project directory.
NW.js (previously known as Node-WebKit) lets you call all Node.js modules directly from DOM and enables a new way of writing applications with all Web technologies.
A new way of writing native applications using web technologies: HTML5, CSS3, and WebGL
Available on Linux, Mac OS X, and Windows
Full support for the features in the browser
JavaScript Source Protection
Call Node.js modules directly from the DOM and Web Workers
Simply clone the repository in your project directory.
Sariska supports building mobile applications involving messaging (Chat) through:
Kotlin (Android)
Java (Android)
Swift (iOs)
React Native
Flutter
TIP: Follow the detailed written instructions in READ.ME section of the repository.
Simply clone the repository in your project directory.
Conference calling:
Simply clone the repository in your project directory. Conference calling:
Simply clone the repository in your project directory.
Conference calling:
Simply clone the repository in your project directory.
Conference calling:
Simply clone the repository in your project directory.
Conference calling:
Sariska supports building Desktop Apps involving messaging (Chat) through:
Electron.js
NW.js
TIP: Follow the detailed written instructions in READ.ME section of the repository.
Electron is an open-source software framework developed and maintained by GitHub. It allows for the development of desktop GUI applications using web technologies. Electron combines the Chromium rendering engine and the Node.js runtime.
Available on Linux, Mac OS X and Windows
Simply clone the repository in your project directory.
TIP: Follow the detailed written instructions in READ.ME section of the repository. Please refer to their official website for further details here.
NW.js (previously known as node-webkit) lets you call all the Node.js modules directly from DOM and enables a new way of writing applications with all Web technologies.
New way of writing native applications using web technologies: HTML5, CSS3, and WebGL
Available on Linux, Mac OS X and Windows
Full support for the features in browser
JavaScript Source Protection
Call Node.js modules directly from the DOM and Web Workers
Simply clone the repository in your project directory.
Sariska supports building browser (accessed from a browser like Google Chrome, Safari either via laptop/PC or mobile) applications involving messaging (Chat) through:
React
AngularJS
Swift (iOs)
Pub/Sub
Flatbuffers
TIP: Follow the detailed written instructions in READ.ME section of the repository.
Simply clone the repository in your project directory.
For Conference calling:
Simply clone the repository in your project directory.
For Conference calling:
Simply clone the repository in your project directory.
For one-to-one calling:
Simply clone the repository in your project directory.
Simply clone the repository in your project directory.
The Sariska Video SDK for Unity lets you quickly add real-time communication to your Unity script. The SDK includes the following features to create seamless unity applications for Android and iOS.
Platforms: Android and iOS
Real-time communication: Bring audio and video communication to your users at ultra-low latency.
Open Source: Based on the extremely popular Jitsi Architecture, bring the power and constant innovation of open source into your project.
The SDK is written in the Adapter pattern, which makes it extremely lightweight, with reusable code written in languages native to the platform, it lets developers have enormous flexibility on what features to cherry-pick.
Co-browsing enables you to share your screen with multiple cursors. Co-browsing is exactly like our tool Colly, but without the packaging! This allows you to have fun with it and blend it seamlessly within your application/website. Check out how to install Colly here.
Simply clone the repository in your project directory.
Colly is a lightweight enabler allowing you to transform any website into a shareable environment amongst colleagues, friends & family. Check out how to install Colly here.
Simply clone the repository in your project directory.
Unity is a cross-platform game engine developed by Unity Technologies.
It is particularly popular for iOS and Android mobile game development and used for games such as Pokémon Go, Monument Valley, Call of Duty: Mobile, Beat Saber, and Cuphead.
Sariska Media provides powerful Unity APIs for developing real-time applications.
You can integrate audio/video, live streaming cloud recording, transcriptions, language translation, and many other services on the fly.
Switch Platform to either Android, iOS, or WebGL
Got to Player Settings and disable Multi-Threaded Rendering
Add OpenGLES2 and OpenGLES3 in Graphics APIs
Set Minimum API Level to Android 5.1 ‘Lollipop’ (API level 22)
Clone Unity Jar Resolver from https://github.com/SariskaIO/Sariska-Unity-Jar-Resolver
In your unity project, go to Assets -> Import-Package -> Custom Package
Select "external-dependency-manager-1.2.169.unitypackage" from the cloned repo and import all.
Add the external-dependency-manager-*.unitypackage to your plugin project (assuming you are developing a plugin).
Copy and rename the SampleDependencies.xml file into your plugin and add the dependencies your plugin requires.
Below is an example of the xml file used to import Sariksa Media Transport SDK for Android and iOS.
The latest stable version is “io.sariska:sariska-media-transport:5.2.1-exp”
Create two canvases in a scene one for each local and remote client
Create a script to access Sariska Media Transport plugin functions.
Declare Raw images wherein the video will be embedded
Declare Textures and Texture pointers for the two video streams:
Get the texture pointers from the declared Textures, and attach the textures to the declared raw images:
After the SDK is added to your project, first initialize the SDK before proceeding with the setting up for the video call.
The SetupLocalStream method in SariskaMediaUnitySdk gives you the option to set up a stream with a set of parameters, which lets you choose between an audio or a video call, and the resolution of the video in case of a video call.
Additionally, the method requires the user to send texture pointers for both textures defined by the user.
In order to enter the room and start a call, the create connection method lets you give a room name and user name as parameters. Once these parameters are sent to the SDK, it automatically creates a JWT token for the user and establishes a conference for people to join it.
A local participant can mute or unMute their audio by using the following methods.
A local participant can mute or unMute their video by using the following methods.
A participant can switch the camera between the front and back by calling the switch camera method. By default, the video call initializes with the front camera open.
A moderator can lock and unlock a room by calling the below two methods. While locking the room, the moderator has to provide a password in the form of a string.
The audio output can be changed to the speaker and turned off by calling the OnSpeaker method for switching to speaker and OffSpeaker for switching to the default output.
The GetParticipantCount method returns the number of participants present in the meeting at the time the method is called.
The GetDominantSpeaker method returns the id in form of a string of the dominant speaker of the meeting.
A basic demo of drawing remote video tracks from sariska-media-transport on objects in Unity can be found at https://github.com/SariskaIO/sariska-media-unity-webgl.
Create a script to access Sariska Media Transport plugin functions.
Declare external method “UpdateTextureFromVideoElement” which takes textureId generated by Unity as a argument.
The script's Start function creates a texture and attaches it to a material on the object. The script's Update function calls a JS plugin method, passing a pointer to the texture.
The .jslib plugin files are responsible for acting as a bridge between Javascript and Unity C# scripts.
The JS plugin method uses texSubImage2D to copy pixels from the video element of the track onto the texture. In a real application, you would identify the remote tracks (e.g. by participant ID) and paint each one on a separate object.
The demo application showcases the usage of three participants.
Example code of the plugin file.
Sariska provides ready to-be-shipped and easy-to-integrate Video Conferencing setup for web allowing developers to provide their apps with real-time features such as in-app chats, video conferencing and instant messaging.
Video Conferencing Setup includes following features:
Live Streaming
Flexible Speaker and Grid Layout
End-to-end encryption
Recording
Chat along with file attachments
Google/Microsoft/Calendly and custom calendar scheduling
Caption
Virtual Background
Personalising Speaker and Video Settings.
Collaborative Whiteboard
Shared Documents editing
Noise Cancellation
Screen Sharing
Slack Integration
Participant, Meeting analytics and Facial expression detections
The first step is to clone the ready-to-be-shipped Sariska Meet Repository by running the following command in your project directory using git.
Move to the root folder of the repository & install the dependencies as under.
Run the following command to launch the video conference
For a live demo click on the below link:
Unity is a cross-platform game engine developed by Unity Technologies.
It is particularly popular for iOS and Android mobile game development and used for games such as Pokémon Go, Monument Valley, Call of Duty: Mobile, Beat Saber and Cuphead.
Sariska provides demos build for different platforms in order to give you a head start.
The first step is to clone the Sariska Media Unity Webgl Repository by running the following command in your project directory using git.
The demo can be run directly from unity, you can choose any room name by editing the room name at the following line in the code.
The demo app can be cloned by running the following command in your project directory using git.
The code generated a token for you by using the room name and user name of your choice.
Create a New Project by clicking on the "New Project" Button on the top right.
Once the project is created, you should see an API key generated on your dashboard.
Keep the API Key with you to include it in your project.
An API key is required for you to run the demo. Please generate the key using the instruction on the given link
Sariska's Media Artifacts Android are stored in GitHub Packages, in order for you to download these packages, a Personal Access Token(PAT) is required by Github.
The packages are public, so you can generate and use a PAT from your own GitHub account. The instructions on how to generate a PAT can be found in this publically available youtube video Link. In order to run this demo, you only need read_packages access for your token.
To Generate a Personal Access Token:
Go to your profile on GitHub -> Developer Settings -> Personal Access Tokens -> Tokens(Classic) -> Generate new Tokens Then while creating a token, click on the following checkbox.
Open the root folder of the repo in your terminal. Then follow the instructions to build the Android Plugin.
Navigate to the Android Plugin Project
Open local.properties
Add the following two lines to the local.properties file.
Run the Build Script
The build Script will automatically build the Android Plugin for you, and paste it into the unity project.
API Key
Replace the API key Generated from console.sariska.io into the demo code: Move to your demo code and replace the API key in the file Sariska-Media-Unity-Demo/Assets/Scripts/TokenAPIHelp.cs
Add GitHub Credentials to the Unity Project
Navigate to the Android folder inside the Unity project and replace Github Username and Password in mainTemplate.gradle
Switch to Android
You will need to sign the application, go to Player Settings and sign the application using Keystore.
Unreal Engine (UE) is a 3D computer graphics game engine developed by Epic Games, first showcased in the 1998 first-person shooter game Unreal. Written in C++, the Unreal Engine features a high degree of portability, supporting a wide range of desktop, mobile, console, and virtual reality platforms.
Sariska provides plugins to support media streaming for Unreal Gaming Engine.
The first step is to clone the Sariska Media Unreal Demo Repository by running the following command in your project directory using git.
The demo runs the native Sariska code using a plugin. The Sariska Media Unreal Plugin can be cloned and placed in your plugins folder of the demo app by running the following command using git.
Guide to Uploading Streams to Sariska
Welcome to the comprehensive guide on uploading content to Sariska. Whether you're connecting your backend to Sariska for sports streaming cameras, utilizing HTTP backend servers, or integrating with OTT platforms and surveillance systems, this guide has got you covered. If you have use cases such as server-side ad ingestion or adding interactivity within the stream for the mentioned scenarios, you'll need to incorporate the conferencing SDK to achieve the same. This is the reason we have divided all live streaming use cases into two buckets: interactive and non-interactive. This categorization can quickly provide you with ideas on which method to use for your specific use cases.
Follow this concise guide to achieve everything in minutes.
1. Start streaming api call:
2. Output of the API:
3. Stop streaming api call: There is no api call for stop streaming call, stop streaming hook auto detected in the backend in case direct ingestion method.
Now, let's delve into the reasons behind having multiple player and ingestion URLs, examining each of them in detail. Understanding these elements is crucial as they directly impact the experience of live streams and integration time.
Players URL's:
HLS (HTTP Live Streaming): Widely adopted globally, HLS operates over HTTP, offering compatibility with various devices and CDNs. By employing in-memory transcoding and optimized distribution( also called low-latency HLS), latency has been reduced to remarkable levels, reaching 1-2 seconds. You can use the low-latency HLS URL for the most optimal performance, as it falls back to normal when low latency is not supported by players.
SRT: Boasting a low latency of 100 ms, SRT is not widely supported for video playback, limiting its usage in comparison to other protocols.
RTMP: With a latency of 1-3 seconds, RTMP is well-suited for backend use cases and flash based devices, providing a reliable streaming solution.
FLV: Featuring a latency of 3-5 seconds, FLV is suitable for backend use cases and flash based devices, catering to specific streaming needs.
Ingestion URL's:
FLV Ingestion: Effortlessly upload FLV files to the Sariska streaming server via simple HTTP post calls, making the process as straightforward as posting your file through HTTP.
RTMP Ingestion: RTMP (Real-Time Messaging Protocol) stands out as a well-established choice for live streaming, especially with Adobe Flash players. Note its limitations for newer applications and HEVC-encoded content due to the discontinuation of Adobe Flash.
SRT Ingestion: SRT (Secure Reliable Transport) is an open-source, codec-agnostic protocol offering codec flexibility and gaining prominence as an RTMP successor. Its enhanced security features and improved reliability make it a preferred choice for content creators, broadcasters, and streaming platforms.
RTSP Ingestion: RTSP (Real-Time Streaming Protocol) is ideal for ingesting streams from IP cameras to the Sariska server. This standard protocol ensures real-time control and delivery of audio and video data, making it suitable for diverse streaming applications.
Note: For RTSP, minimal manual effort is required, as the streaming process involves providing the RTSP server URL for configuration. Once configured, the system seamlessly pulls streams from IP cameras.
For a comprehensive understanding of API flags and enhanced features, please refer to the Swagger URL provided below. Enabling each feature is straightforward, requiring a simple 'true' parameter.
Sariska provides ready to-be-shipped and easy-to-integrate Audio Conferencing setup for the web allowing developers to provide their apps with real-time features such as in-app audio calls.
Audio Conferencing Setup includes the following features:
Starting a stage by Host
Adding up to 2 co-hosts.
Adding up to 10 speakers.
Adding unlimited numbers of listeners.
Changing roles and permission dynamically
End-to-end encryption
Mute all
Hand Raise
Muting a single participant.
Terminating a stage
Noise Cancellation
Participant and Meeting analytics
The first step is to clone the ready-to-be-shipped Sariska Meet Repository by running the following command in your project directory using git.
Move to the root folder of the repository & install the dependencies as under.
Run the following command to launch the audio conference
For a live demo click on the below link:
Interactive Live Streaming Overview:
Let's familiarize ourselves with a few terms related to media operations
Audio Encoding:
Analog signals, representing continuous waveforms, are converted into digital signals consisting of discrete 0s and 1s.
This conversion is typically performed by audio codecs such as MP3, AAC, Opus, and Lyra.
The goal is to represent the audio information in a digital format suitable for storage, transmission, and processing by digital devices, in audio there is no concept of frame it's just called bitrate typical encoding varies from 96 to 320Kbps.
Video Encoding:
Video encoding involves compressing video frames into a more compact form to facilitate efficient transmission or storage.
Common video codecs include H.264, H.265 (also known as HEVC), VP9, and AV1.
The compressed data can be efficiently transmitted or stored, but decoding is required to retrieve the original frames.
Remuxing:
Remuxing is the process of changing the container format of a multimedia file without altering the actual media content.
This is different from transcoding, which involves changing the encoding format itself.
Remuxing is often done to switch between different container formats without re-encoding the audio or video data.
Frame:
In the context of video, a frame is a 2D matrix of pixels that represents a single image in a video sequence.
Video codecs compress and decompress these frames to reduce file sizes and facilitate efficient transmission and storage.
Technical Implementation:
The technical implementation involves the use of WebRTC for publishing multiple streams, both from live sources and local files. GStreamer, a powerful multimedia framework, is employed to stitch these streams together into a single stream output. This is achieved by leveraging the capabilities of GStreamer to handle real-time processing and merging of video and audio sources.
Sariska Implementation(via Conferencing SDK ):
We start a conference where multiple participants join the conference along with the recorder. Participants send their audio and video streams to GStreamer through a videobridge. GStreamer, functioning as an interceptor and transcoder library, enables the re-encoding of these streams ( Multiple video streams are superimposed within a larger frame, producing a single stream as the output).
As the server (or recorder ) participates as a conference member, it can contribute its own audio and video tracks. This functionality enables dynamic server-side ad ingestion and personalized capabilities within the live streaming.
Since publishing occurs over WebRTC with latencies typically within the range of 100 to 300 milliseconds, it enables nearly instantaneous host interactivity. This low latency ensures a responsive and real-time experience for the host in interactive scenarios.
Lets understand this with basic example:
Let's consider a simple conference call scenario with two users. Each user publishes a stream with a resolution of 240 x 180 pixels. The process involves decoding of streams, followed by re-encoding them into a larger frame. This larger frame combines the individual audio and video streams, resulting in a single audio and video stream with dimension of 240 x 360 pixels.
The subsequent phase involves encapsulating the audio and video streams within a digital container format for transmission and storage. This process is distinct from the existing encoding, as each audio and video stream has already undergone suitable encoding before integration into the digital container format.Common formats for this purpose include TS (Transport Stream) or FLV (Flash Video). RTMP (Real-Time Messaging Protocol) uses FLV as its container format, while HLS (Hypertext Transfer Protocol Live Streaming) typically employs TS. Both protocols are designed for streaming media over the internet. RTMP delivers content in a continuous flow, while HLS divides the stream into smaller segments for transmission via HTTP.
We have presented this information from a technical standpoint, emphasizing the versatility of this approach, given the myriad potential use cases. Explore the for a detailed overview of API flags and enhanced functionalities
For more detailed information on the APIs, check out the
Interactive live streaming involves the real-time transmission of audio and video content over the internet, facilitating direct engagement between content creators and their audience. Achieving this interactivity can be accomplished by incorporating , such as SuperChat, to enhance user engagement and support various use cases, particularly in the realm of stream monetization. It's important to note that in this context, we are primarily focused on enhancing interactivity within the audio and video streams rather than through text-based chat.
Channel ID
channel123
Number of messages to retrieve
10
Offset for pagination
0
List of message IDs
[2001,2002]
messages group by day
false
Please pass apiKey tied to your sariska account
iufwenufewifweifiuTbddhbdjhjfbjfjwfjwfj
Pass exp claim of JWT token
24 hours
Pass nbf claim of JWT token
Pass scope of token (messaging, media, sariska, or leave it blank)
Please pass apiKey tied to your sariska account
iufwenufewifweifiuTbddhbdjhjfbjfjwfjwfj
Pass exp claim of JWT token
24 hours
Pass nbf claim of JWT token
Pass scope of token (messaging, media, sariska, or leave it blank)
The email address of the conference owner.
owner_user_id@sariska.io
The name of the conference room.
myroom123
The duration of the conference in minutes.
60
The start time of the conference in ISO 8601 format.
2023-09-28T15:08
The timezone of the conference.
America/New York
Example: America/New York
The PIN for accessing the conference (optional).
1234
Channel ID
channel123
Parameters for deleting messages
If true, delete all messages in the channel
list of messages ids to delete
[2001,2002]
Channel ID
channel123
Message ID
1001
Parameters for deleting message replies
List of reply message IDs to delete
[2001,2002]
Generate a JWT token based on provided parameters.
Parameters for generating a token
API key tied to the Sariska account
Exp claim of JWT token
Nbf claim of JWT token
Scope of the token (messaging, media, sariska, or leave it blank)
User information
Get S3 presigned url and upload media to directly your s3 as you have configured in console
request for presigned url to upload and attach media
File name
some-s3-folder/file-name.jpeg
File extension
jpeg
Audio/Video Quality Analysis: Delve into detailed metrics to assess the quality of audio and video streams during calls, For example, the percentage of audio/video freeze.
User Location Tracking: Gain insights into the geographical locations of users, enhancing your understanding of the global reach of your platform.
Facial Landmarks Analysis: The system takes snapshots of the participant's facial expressions at intervals during the call, facilitating a more precise analysis of their expression
IP Address Analysis: Identify and track IP addresses to enhance security and troubleshoot potential issues.
System Speed Metrics: Analyze the speed of user systems to optimize the performance of your application.
Conference Drop Reasons: Understand and address conference drop issues with comprehensive data on drop reasons.
Call Quality Score: The call quality score is determined by taking a weighted average of parameters such as audio/video quality analysis, user location tracking, IP address analysis, system speed metrics, connection health, and conference drops.
Note: If you want analytics to be enabled, you need to enable it via the console dashboard when creating the project, or you can update it later on. By default, it is enabled.
Please find attached a screenshot showing a few metrics:
This guides explains you on how to build interactive live streaming apps via conferencing SDK.
Generate an API Key for your project
Generate a Bearer Token
Creating a Conference Room
Alternative to Creating a Conference Room
Start Live Streaming
Stop Live Streaming
Streaming to Multiple Outlets
You can generate your API key for your project by visiting console.sariska.io and signing up.
The full instruction on how to do it can be found here: Link
We generate these authentication tokens on our own servers. You can use the same token for all the services offered by Sariska.
To generate a token, follow the instruction on the page here
“user” data in the above curl command is optional and the bearer token is generated regardless of it.
In order to start a multi host live stream, all the hosts need to join a common room. The name for this common room can be anything the hosts choose to. This part details on how to create a simple conference for your hosts to live stream.
The first step is to install the sariska-media-transport library by running the following command in your project directory using NPM.
After installing the SDK, perform initial setup tasks by running initialize()
.
To establish a connection, you would need to generate a token. You’d also need to specify a room name, this is the room your hosts will join to live stream together.
Once you have your connection established, the next step is to create a conference.
Now, the conference
object will have all events and methods that you would possibly need for any feature that you wish to supplement your application with.
A MediaStream consists of zero or more MediaStreamTrack objects, representing various audio or video tracks. Each MediaStreamTrack may have one or more channels. The channel represents the smallest unit of a media stream, such as an audio signal associated with a given speaker, like left or right in a stereo audio track. Here we mostly talk about track.
Play Local stream:
The moderator of the meeting controls and gate keeps the participants. The moderator has exclusive control of the meeting.
If you’d like to quickly test the live streams without having to create a conference, you can use Sariska’s meet application.
let’s say the room name for our case is “streamtest”. Since we are using Sariska’s meet app to run this demo, you can go to meet.sariska.io/streamtest
With Sariska, starting a live stream is just a simple API call away. Generate another bearer token and then follow the curl command.
For example, the curl command will look something like this for a room “streamtest”.
The sample response for such a request will be
Sample Response:
If you’d like to stream to platforms such as Youtube, Facebook, or Twitch. You can send a request like shown below.
streamKeys (optional): Streaming keys for all the platforms you want to stream at
streamUrls (optional): RTMP Url Endpoints
is_recording (optional): Flag to state if you’d like to record the meeting
is_vod (optional): Flag to state if you’d like to provide this stream as a VOD
audio_only (optional): Flag true if you’d like it to be an audio only stream
For detailed information, please refer to the Swagger documentation.
Full JID (room@conference.server.domain) for the conference to create or return existing conference mapping. Used preferentially over all other input parameters (search by conference)
ID to search for an existing conference mapping. Only used when provided alone (search by ID)
please pass apiKey with tied with your sariska account
iufwenufewifweifiuTbddhbdjhjfbjfjwfjwfj
pass exp claim of jwt token
24 hours
pass nbf claim of jwt token
pass scope of token it can be messaging or media or sariska or leave it blank
List of RTMP server keys for simulcast live streaming to all platforms, including Instagram, YouTube, Twitch, Vimeo, Periscope, Facebook, DLive, Mixcloud, and Restream.
[{"key":"youtube","value":"youtube_stream_key"},{"key":"facebook","value":"facebook_stream_key"},{"key":"twitch","value":"twitch_stream_key"},{"key":"vimeo","value":"vimeo_stream_key"},{"key":"instagram","value":"instagram_stream_key"}]
This is a list of additional RTMP URLs for platforms not included in the above-listed platforms or host URL is dynamic
The room name recorder needs to join.
room1234
Whether the live streaming needs to be in low latency
true
The player side codec default is H264
H265
Please set this flag to true if you want MP4 recordings of the live stream.
true
If true
is passed, the stream will be transcoded into 5 different variants: 720p (HD), 480p (HD_MID), 360p (MID), 240p (MID_LOW), and 240p (LOW) with bitrates of 2628kbps, 1128kbps, 878kbps, 528kbps, and 264kbps, respectively. This will ensure the best possible viewing experience, regardless of the user's network or device.
true
Please set this flag to true if you want to access the Video on Demand (VOD) URL. The VOD will be available after the live streaming has finished.
true
Please set this flag to true if you want the participant name to appear in the video tiles.
true
Please set this flag to true if you want the streaming to be audio-only.
true
By default, the live streaming layout is optimized for desktop
. If you want it to be optimized for mobile, you can pass the flag mobile
mobile
By default, adaptive
bitrate streaming is enabled between the videobridge and recorder for each participant's stream. However, if you want to record and stream each participant's original quality, you can pass the flag as HD
HD
The default time interval for the recorder is 1 minute. If a different time interval is set, the recorder will remain active for that duration, and if all participants leave before the interval ends, a new streaming API call must be made to restart the recording.
6000 equivalent to 1 min
please pass apiKey with tied with your sariska account
iufwenufewifweifiuTbddhbdjhjfbjfjwfjwfj
pass exp claim of jwt token
24 hours
pass nbf claim of jwt token
pass scope of token it can be messaging or media or sariska or leave it blank
Whether the live streaming needs to be in low latency
true
Instead of a room, we use direct ingestion to start a live stream, for e.g. from obs
true
If true
is passed, the stream will be transcoded into 5 different variants: 720p (HD), 480p (HD_MID), 360p (MID), 240p (MID_LOW), and 240p (LOW) with bitrates of 2628kbps, 1128kbps, 878kbps, 528kbps, and 264kbps, respectively. This will ensure the best possible viewing experience, regardless of the user's network or device.
true
Please set this flag to true if you want to access the Video on Demand (VOD) URL. The VOD will be available after the live streaming has finished.
true
Retrieve call directory records based on specified criteria.
Bearer token for authorization
Content type
Array of room names [optional]
Start date and time for filtering records [optional]
End date and time for filtering records [optional]