Initialization & Users
Confused about "Initialization & Users"?
Let us know how we can improve our documentation:
The code below creates a chat client instance for interacting with Stream APIs. Additional options, such as API base URL, can be configured when creating the instance.
Connecting the User
Copied!Confused about "Connecting the User"?
Let us know how we can improve our documentation:
Once initialized, you must specify the current user with connectUser
:
Note how we are waiting for the connectUser
API call to be completed before moving forward. You should always make sure to have the user set before making any more calls. All SDKs make this very easy and wait or queue requests until then.
Connect User Parameters
Copied!Confused about "Connect User Parameters"?
Let us know how we can improve our documentation:
name | type | description | default | optional |
---|---|---|---|---|
user | object | The user object. Must have an id field. User Ids can only contain characters a-z, 0-9, and special characters @ _ and - It can have as many custom fields as you want, as long as the total size of the object is less than 5KB | ||
userToken | string | The user authentication token. See Tokens & Authentication for details | default |
WebSocket Connections
Copied!Confused about "WebSocket Connections"?
Let us know how we can improve our documentation:
The connectUser
(or SDK equivalent) function performs several operations when used. Please note that this method should never be used server-side.
Creates a new user if the
user_id
is not already registered with the application, incrementing the monthly active usersUpdates the user in the application (will add/modify existing fields but will not overwrite/delete previously set fields unless the key is used)
Opens a WebSocket connection and increments the Concurrent Connections for the application
The React-native, iOS, Android, and Flutter SDK's handle WebSocket disconnection logic, but if a manual disconnect is required in your application, then there are the following options
XHR Fallback
Copied!Confused about "XHR Fallback"?
Let us know how we can improve our documentation:
Most browsers support WebSocket connections as an efficient mode of real-time data transfer. However, sometimes the connection cannot be established due to network or a corporate firewall. In such cases, the client will establish or switch to XHR fallback mechanisms and gently poll our service to keep the client up-to-date.
The fallback mechanism can be enabled with the flag enableWSFallback
Privacy Settings
Copied!Confused about "Privacy Settings "?
Let us know how we can improve our documentation:
Additionally, when connecting the user, you can include the privacy_settings
as part of the user object.
Let's have a closer look on the parameters:
name | type | description | default | optional |
---|---|---|---|---|
typing_indicators | object | if enabled is set to false, then typing.start and typing.stop events will be ignored for this user and these events will not be sent to others | enabled: true | ✓ |
read_receipts | object | If enabled is set to false, then the read_state of this user will not be exposed to others. Additionally, read_state related events will not be delivered to others when this user reads messages. | enabled: true | ✓ |