On this page

Message history

PubNub APIs let you effectively fetch historical messages from direct, group, or public conversations.

While App Context API lets you manage metadata and relationships between users and channels, enabling efficient tracking of which channels are associated with a given user, Message Persistence API lets you retrieve messages from those channels. Together, these APIs enable you to gather all conversations involving a user and easily fetch specific message histories for any interactions between users.

Chat SDK lets you fetch historical messages from one channel using the getHistory() method.

Due to current PubNub API limitations, you cannot filter the results by type, so you'll get all messages that happened on a given channel in a given timeframe.

icon

Under the hood

Method signature

This method takes the following parameters:

1channel.getHistory({
2 startTimetoken?: string,
3 endTimetoken?: string,
4 count?: number
5}): Promise<{
6 messages: Message[],
7 isMore: boolean
8}>

Input

* required
ParameterDescription
startTimetoken
Type: string
Default:
n/a
Timetoken delimiting the start of a time slice (exclusive) to pull messages from. For details, refer to the Fetch History section.
endTimetoken
Type: string
Default:
n/a
Timetoken delimiting the end of a time slice (inclusive) to pull messages from. For details, refer to the Fetch History section.
count
Type: number
Default:
25
Number of historical messages to return for the channel in a single call. Since each call returns all attached message reactions by default, the maximum number of returned messages is 25. For more details, refer to the description of the includeMessageActions parameter in the JavaScript SDK docs.

Output

ParameterDescription
Promise<>
Type: object
Returned object containing two fields: messages and isMore.
 → messages
Type: Message[]
Array listing the requested number of historical Message objects.
 → isMore
Type: boolean
Whether there are any more historical messages to pull.

By default, each call returns all message actions and metadata attached to the retrieved messages.

Sample code

From the support channel, fetch 10 historical messages older than the timetoken 15343325214676133.

1// reference the "channel" object
2const channel = await chat.getChannel("support")
3// invoke the "getHistory()" method on the "channel" object
4await channel.getHistory(
5 {
6 startTimetoken: "15343325214676133",
7 count: 10
8 }
9)
Last updated on