val channelClient = client.channel("messaging", "general")
val pageSize = 10
// Request the first page
val request = QueryChannelRequest()
.withMessages(pageSize)
channelClient.query(request).enqueue { result ->
if (result is Result.Success) {
val messages: List<Message> = result.value.messages
if (messages.size < pageSize) {
// All messages loaded
} else {
// Load next page using the oldest message ID
val nextRequest = QueryChannelRequest()
.withMessages(Pagination.LESS_THAN, messages.last().id, pageSize)
// ...
}
} else {
// Handle Result.Failure
}
}Channel Pagination
The channel query endpoint allows you to paginate messages, watchers, and members for a channel. Messages use ID-based pagination for consistency, while members and watchers use offset-based pagination.
Message Pagination
Message pagination uses ID-based parameters rather than simple offset/limit. This approach improves performance and prevents issues when the message list changes while paginating.
For example, if you fetched the first 100 messages and want to load the next 100, pass the ID of the oldest message (when paginating in descending order) or the newest message (when paginating in ascending order).
Pagination Parameters
| Parameter | Description |
|---|---|
id_lt | Retrieve messages older than (less than) the ID |
id_gt | Retrieve messages newer than (greater than) the ID |
id_lte | Retrieve messages older than or equal to the ID |
id_gte | Retrieve messages newer than or equal to the ID |
id_around | Retrieve messages around a specific message ID |
// Get the ID of the oldest message on the current page
const lastMessageId = messages[0].id;
// Fetch older messages
const result = await channel.query({
messages: { limit: 20, id_lt: lastMessageId },
});
// Fetch messages around a specific message
const result = await channel.query({
messages: { limit: 20, id_around: messageId },
});Member and Watcher Pagination
Members and watchers use limit and offset parameters for pagination.
| Parameter | Description | Maximum |
|---|---|---|
limit | Number of records to return | 300 |
offset | Number of records to skip | 10000 |
// Paginate members and watchers
const result = await channel.query({
members: { limit: 20, offset: 0 },
watchers: { limit: 20, offset: 0 },
});
const result = await channel.query({
state: true,
members: { limit: 110, offset: 0 },
});To retrieve filtered and sorted members in a channel use the Query Members API