TalkSession
This is the entry point to the standalone JavaScript Data API. Use TalkSession if you have installed the JavaScript Data API as a separate npm package, @talkjs/core.
If you use the JavaScript Data API as part of the JavaScript SDK, use Session instead, which includes all the methods and properties of TalkSession documented below.
The getTalkSession function returns a TalkSession object for a given app ID and user ID:
The following options are available when calling getTalkSession:
| Name | Type | Description | 
|---|---|---|
| appId Required | string | Your app's unique TalkJS ID. Get it from the Settings page of the dashboard. | 
| userId Required | string | The idof the user you want to connect and act as. Any messages you send will be sent as this user. | 
| token | string | A token to authenticate the session with. Pass tokenif you use standard (non-refreshable) authentication. | 
| tokenFetcher | () => Promise<string> | A callback that fetches a new token from your backend and returns it. Pass tokenFetcherif you use authentication with refreshable tokens. If this callback throws an error or returns a rejected promise, the session will terminate. Your callback should retry failed requests. | 
Calling getTalkSession twice for the same app and user will return the same object both times, rather than creating a new session.
This means that the token and tokenFetcher properties are ignored if there is already an active session for that user.
| Field | Type | Description | 
|---|---|---|
| currentUser | UserRef | A reference to the user whose ID you passed to getTalkSession. | 
The TalkSession object has the following methods.
Returns a reference to the user with the specified ID.
Returns a reference to the conversation with the specified ID.
Subscribes to your most recently active conversations.
The subscription is 'windowed'. Initially, this window contains the 20 most recent conversations.
Conversations are ordered by last activity. The last activity of a conversation is either joinedAt or lastMessage.createdAt, whichever is higher.
If an older conversation receives a new message, or you are added to a conversation, it will appear at the start of the list.
Call loadMore to load additional older conversations.
Whenever Subscription.state.type is "active" and something changes in your conversations, onSnapshot will fire and Subscription.state.latestSnapshot will be updated.
loadedAll is true when the snapshot contains all your conversations.
If the current user does not exist yet, the snapshot will be an empty list.
Returns a ConversationListSubscription.
Attaches a listener which gets called when the TalkSession encounters an unrecoverable error.
For example, if the session cannot authenticate, or if you specify an incorrect app ID.
If the session has already terminated, the handler will be called immediately.
A subscription object. Call Subscription.unsubscribe() to detach the listener.
Uploads a generic file without any additional metadata.
This function does not send any message, it only uploads the file and returns a file token. To send the file in a message, pass the file token in a SendFileBlock when you call ConversationRef.send.
See the documentation for more information about sending files in messages.
If the file is a video, image, audio file, or voice recording, use one of the other functions like uploadImage instead.
| Name | Type | Description | 
|---|---|---|
| data | Blob | The binary file data. Usually a File. | 
| metadata | GenericFileMetadata | Information about the file, see below. | 
| Property | Type | Description | 
|---|---|---|
| filename Required | string | The name of the file, including the extension. | 
A promise that resolves to a FileToken that can be used to send the file in a message.
Uploads an image with image-specific metadata. This is a variant of uploadFile used for images.
| Name | Type | Description | 
|---|---|---|
| data | Blob | The binary file data. Usually a File. | 
| metadata | ImageFileMetadata | Information about the image, see below. | 
| Property | Type | Description | 
|---|---|---|
| filename Required | string | The name of the file, including the extension. | 
| width | number | The width of the image in pixels, if known. | 
| height | number | The height of the image in pixels, if known. | 
A promise that resolves to a FileToken that can be used to send the file in a message.
Uploads a video with video-specific metadata. This is a variant of uploadFile used for videos.
| Name | Type | Description | 
|---|---|---|
| data | Blob | The binary file data. Usually a File. | 
| metadata | VideoFileMetadata | Information about the video, see below. | 
| Property | Type | Description | 
|---|---|---|
| filename Required | string | The name of the file, including the extension. | 
| width | number | The width of the video in pixels, if known. | 
| height | number | The height of the video in pixels, if known. | 
| duration | number | The duration of the video in seconds, if known. | 
A promise that resolves to a FileToken that can be used to send the file in a message.
Uploads an audio file with audio-specific metadata. This is a variant of uploadFile used for audio files.
| Name | Type | Description | 
|---|---|---|
| data | Blob | The binary file data. Usually a File. | 
| metadata | AudioFileMetadata | Information about the audio file, see below. | 
| Property | Type | Description | 
|---|---|---|
| filename Required | string | The name of the file, including the extension. | 
| duration | number | The duration of the audio file in seconds, if known. | 
A promise that resolves to a FileToken that can be used to send the file in a message.
Uploads a voice recording with voice-specific metadata. This is a variant of uploadFile used for voice recordings.
| Name | Type | Description | 
|---|---|---|
| data | Blob | The binary file data. Usually a File. | 
| metadata | VoiceFileMetadata | Information about the audio file, see below. | 
| Property | Type | Description | 
|---|---|---|
| filename Required | string | The name of the file, including the extension. | 
| duration | number | The duration of the voice recording in seconds, if known. | 
| userRef | UserRef | A reference to the user that this session is connected as. | 
A promise that resolves to a FileToken that can be used to send the file in a message.
The TalkSession automatically disconnects and reconnects as needed.
To fully clean up the TalkSession and release all resources, you should unsubscribe from any active subscriptions, throw away any references to the session, and wait.
The session will automatically close its connection to the TalkJS servers, and it will be garbage collected.
You do not need to manually close the TalkSession or do any cleanup.