Channel Pagination

The channel query endpoint allows you to paginate the list of messages, watchers, and members for one channel. To make sure that you are able to retrieve a consistent list of messages, pagination does not work with simple offset/limit parameters but instead, it relies on passing the ID of the messages from the previous page.

For example: say that you fetched the first 100 messages from a channel and want to load the next 100. To do this you need to make a channel query request and pass the ID of the oldest message if you are paginating in descending order or the ID of the newest message if paginating in ascending order.

Use the id_lt parameter to retrieve messages older than the provided ID and id_gt to retrieve messages newer than the provided ID.

The terms id_lt and id_gt stand for ID less than and ID greater than.

ID-based pagination improves performance and prevents issues related to the list of messages changing while you’re paginating. If needed, you can also use the inclusive versions of those two parameters: id_lte and id_gte.

let messageId: MessageId = "123"
let channelId = ChannelId(type: .messaging, id: "general")
let controller = chatClient.channelController(for: channelId)

// Equals to id_around
controller.loadPageAroundMessageId(messageId) { error in
  if let error = error {
    // handle error
    print(error)
  } else {
    // access messages
    print(controller.messages)

    // Equals to id_gt (where id is the newest fetched message id)
    controller.loadNextMessages(limit: 10) { error in
      // handle error / access messages
      print(error ?? controller.messages)
      // Equals to id_lt (where id is the oldest fetched message id)
      controller.loadPreviousMessages(limit: 10) { error in
        print(error ?? controller.messages)
      }
    }
  }
}

// `Chat` provides more granual access
let chat = chatClient.makeChat(for: channelId)
// Messages for id_gt
let greaterThanPagination = MessagesPagination(
  pageSize: 10,
  parameter: .greaterThan(messageId)
)
let messagesGreaterThan = try await chat.loadMessages(with: greaterThanPagination)

// Messages for id_lt
let lessThanPagination = MessagesPagination(
  pageSize: 10,
  parameter: .lessThan(messageId)
)
let messagesLessThan = try await chat.loadMessages(with: lessThanPagination)

// Message around a message id
let aroundPagination = MessagesPagination(
  pageSize: 10,
  parameter: .around(messageId)
)
let messagesAround = try await chat.loadMessages(with: aroundPagination)

// And also convenience methods
try await chat.loadMessages(before: messageId, limit: 10)
try await chat.loadMessages(around: messageId, limit: 10)
try await chat.loadMessages(after: messageId, limit: 10)
let loadedMessages = chat.state.messages

For members and watchers, we use limit and offset parameters. The maximum limit and offset that can be used is 300 and 10000, respectively.

To retrieve more than 100 members in a single query, you must include state as true in your channel query parameters.

Soon we will create friendlier aliases for id_lt and id_gt. Our best candidates are before_id and after_id, let us know if you have any feedback or suggestion!

The maximum number of messages that can be retrieved at once from the API is 300.

© Getstream.io, Inc. All Rights Reserved.