Data payloads for PubNub Chat Components for React
Migrate to Chat SDK
PubNub will stop supporting Chat Components on January 1, 2025 but you are welcome to contribute. Learn how to migrate to the Chat SDK here.
PubNub Chat Components for React enforce you to use the unified JSON schemas (data models) for such common entity types as users, channels, and messages when transferring data over the PubNub network. These common data payloads allow you to create cross-platform applications and ensure that such applications developed in different technologies (Swift, Kotlin, or JavaScript) communicate with one another properly, avoiding any unexpected errors.
Data payload validation
To avoid any parsing errors, validate the data payload you prepared for users, channels, and messages in an online validator.
Users
Follow this schema for the user data in your apps:
1{
2  "$schema": "https://json-schema.org/draft/2020-12/schema",
3  "title": "User",
4  "description": "User of a chat application",
5  "properties": {
6    "id": {
7      "description": "Unique identifier for a user",
8      "type": "string"
9    },
10    "name": {
11      "description": "Name of the user that you can display in the UI",
12      "type": "string"
13    },
14    "email": {
15      "description": "User's email address",
Example:
1{
2  "id": "some-user-id",
3  "name": "Jane Doe",
4  "email": "jane.doe@example.com",
5  "externalId": "some-external-user-id",
6  "profileUrl": "https://randomuser.me/api/portraits/men/1.jpg",
7  "custom": {
8    "description": "Office Assistant"
9  },
10  "eTag": "AYGyoY3gre71eA",
11  "updated": "2020-09-23T09:23:34.598494Z"
12}
Channels
Follow this schema for the channel data in your apps:
1{
2  "$schema": "https://json-schema.org/draft/2020-12/schema",
3  "title": "Channel",
4  "description": "Channel in the chat application",
5  "properties": {
6    "id": {
7      "description": "Unique identifier for a channel",
8      "type": "string"
9    },
10    "name": {
11      "description": "Name of the channel that you can display in the UI",
12      "type": "string"
13    },
14    "description": {
15      "description": "Description of the channel that you can display in the UI",
Example:
1{
2  "id": "some-channel-id",
3  "name": "Off-topic",
4  "description": "Off-topic channel for random chatter and fun",
5  "custom": {
6    "profileUrl": "https://www.gravatar.com/avatar/149e60f311749f2a7c6515f7b34?s=256&d=identicon"
7  },
8  "eTag": "AbOx6N+6vu3zoAE",
9  "updated": "2020-09-23T09:23:37.175764Z"
10}
Messages
Follow this schema for the message data in your apps:
Supported data types
PubNub Chat Components for React support only text message data types.
1{
2  "$schema": "https://json-schema.org/draft/2020-12/schema",
3  "title": "Message Content",
4  "description": "Message content in the chat application",
5  "type": "object",
6  "properties": {
7    "id": {
8      "description": "Unique identifier for a message. Use the UUID v4 algorithm.",
9      "type": "string"
10    },
11    "text": {
12      "description": "Text of the message that you can display in the UI",
13      "type": "string"
14    },
15    "contentType": {
Example:
1{
2  "id": "6da72b98-e211-4724-aad4-e0fb9f08999f",
3  "text": "Let's sync on the topic in this thread.",
4  "contentType": "none",
5  "content": {},
6  "custom": {},
7  "createdAt": "2022-05-10T14:48:00.000Z"
8}