A conversation is a place where two or more people write messages to each other. Some messaging apps use words like chat, chatroom or channel for this concept. Any sort of conversation, from a brief 1-on-1 chat to a continuously active 20-person chat room, is called a conversation in TalkJS.
TalkJS does not fundamentally differentiate between one-on-one conversations and group conversations. They're all just conversations.
Any conversation with more than two participants is treated as a group conversation. TalkJS treats these conversations slightly different. For example, sender names are shown in the message bubbles in group conversations and not in one-on-one conversations.
If you add a third participant to a one-on-one conversation, then it automatically turns into a group conversation.
Every conversation needs to have a unique ID that you choose. Choosing your own conversation ID keeps you firmly in control of the granularity of a conversation. For example, should any two people who chat have a single, continuous conversation? Or should there be a new, separate conversation for every purchase or transaction, even if two given users may have multiple transactions?
Here are three ways in which TalkJS customers often choose a conversation ID:
If your app tracks purchases or transactions or something similar, and you want to have a single conversation for every purchase, then it may be very effective to use your internal purchase ID as a conversation ID. One purchase, one conversation. Simple!
However, if you just want to create a conversation between two specific users, then inventing and storing a conversation ID might be cumbersome. In that case, it might be better to use a conversation ID that is derived from the user IDs that will participate in the conversation.
Our JS SDK provides a helper function,
Talk.oneOnOneId that does exactly that:
it orders two user IDs alphabetically, combines them, and hashes the result.
This way, invoking it for any two users will always yield the same conversation ID.
See its page on the JS SDK reference for detailed information about how it works. If you also use the REST API, then you may need to replicate its behavior in your backend language.
oneOnOneId has been designed to be easy to replicate in all popular languages and if it's not then we'll gladly help.
If you use TalkJS to make (semi-)public chat rooms that are divided based on the topic of conversation,
then you can use a short description of the conversation's purpose as the conversation ID.
For example, a public conversation to discuss software development could have the conversation ID 'dev'.
setParticipant or the REST API to add the current user to 'dev'.
It might be easy for users to guess other users' conversation IDs. That's a risk, because it means that they may be able to join conversations they're not supposed to be a part of.
For example, if you take approach 1 above, and purchase IDs are auto-incrementing, then a user who gets added to conversation
12345 about purchase
12345 may be able to deduct that there's also a conversation
12344. If they're tech savvy, they could enter some TalkJS calls in the browser developer tools and join conversation
A pragmatic approach to prevent this is to make the conversation ID hard to predict. You can do this easily and securely by computing an HMAC of the logical conversation ID. This is similar to how you generate the Identity Verification signature. You'd then use the result of the HMAC signature as the real conversation ID.
For example, if your backend is written in Ruby:
RUBYrequire 'openssl'# assume that `purchase` is some database record about the current purchasepredictable_conversation_id = purchase.idconversation_id = OpenSSL::HMAC.hexdigest('sha256', "SOMERANDOMSECRET", predictable_conversation_id)
SOMERANDOMSECRET string can be any secret, just a random sequence of characters is fine. Securely store it in the backend as you would any other secret. Our GitHub examples repository has code samples that demonstrate how to do this in other languages.
If you need more control over who can access conversations, you can also disable synchronizing conversation data via the browser entirely. If you do this, then you can only create or modify conversations via the REST API, so then it does not matter if conversation IDs are easy to predict.
A conversation only shows up in the conversation list in the Inbox pre-built chat UI, if the conversation contains at least one message. This is to ensure that the conversation list only shows conversations in which there is activity, and to avoid overwhelming the user with empty conversations.
To make a conversation show up in the conversation list, you can send either a system message or a user message on behalf of a user to that conversation. An automatic welcome message set at the user level doesn't make the conversation show up in the conversation list of an inbox.
|As described above.
|Optional. Describes the conversation in a human-friendly way. TalkJS will display it above the conversation and optionally in the Inbox's conversation feed. You can include some limited wiki-style formatting here.
"House by the sea",
"House <https://example.comǀby the sea>"
|Optional. The URL of a photo or icon for this conversation. Displayed in the chat UI instead of a user photo. Recommended in group conversations, because otherwise TalkJS falls back to a placeholder picture.
|Optional. An array of strings which will be rendered as System Messages at the start of this conversation.
["Hey there!", "We're usually online during office hours"]
|object of strings
|JSON-structured custom data that you wish to associate to this conversation. TalkJS does nothing with this data except make it available in the events that we send to your code and in your Email/SMS notification templates. You can use custom data for all kinds of purposes, such as customizing a user's email notification text, or transmitting contextual conversation data such as internal database IDs that this conversation relates to.
Must be an object with string keys and string values; arbitrarily deeply nested JSON is not supported. If you need structured data for one of your custom fields, consider serializing it yourself (using e.g.
JSON.stringify or similar functions). See also User.custom.