Get topics in a stream

Get all the topics in a specific stream


Usage examples

#!/usr/bin/env python3

import zulip

# Pass the path to your zuliprc file here.
client = zulip.Client(config_file="~/zuliprc")

result = client.get_stream_topics(stream_id)

More examples and documentation can be found here.

const zulipInit = require("zulip-js");

// Pass the path to your zuliprc file here.
const config = { zuliprc: "zuliprc" };

(async () => {
    const client = await zulipInit(config);

    // Get all the topics in stream with ID 1
    console.log(await client.streams.topics.retrieve({stream_id: 1}));

curl -sSX GET -G \


stream_id integer required in path

Example: 1

The ID of the stream to access.


Return values

  • topics: (object)[] An array of topic objects.

    • max_id: integer The message ID of the last message sent to this topic.

    • name: string The name of the topic.

Example response

A typical successful JSON response may look like:

    "msg": "",
    "result": "success",
    "topics": [
            "max_id": 26,
            "name": "Denmark3"
            "max_id": 23,
            "name": "Denmark1"
            "max_id": 6,
            "name": "Denmark2"

An example JSON response for when the user is attempting to fetch the topics of a non-existing stream (or also a private stream they don't have access to):

    "code": "BAD_REQUEST",
    "msg": "Invalid stream id",
    "result": "error"