Get topics in a channel
GET https://theway.zulipchat.com/api/v1/users/me/{stream_id}/topics
Get all topics the user has access to in a specific channel.
Note that for private channels with
protected history,
the user will only have access to topics of messages sent after they
subscribed to the channel. Similarly, a user's
bot will only have access to messages
sent after the bot was subscribed to the channel, instead of when the
user subscribed.
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)
print(result)
 
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 channel with ID 1
    console.log(await client.streams.topics.retrieve({stream_id: 1}));
})();
 
curl -sSX GET -G https://theway.zulipchat.com/api/v1/users/me/1/topics \
    -u BOT_EMAIL_ADDRESS:BOT_API_KEY \
    --data-urlencode allow_empty_topic_name=true
 
 
 
Parameters
    stream_id integer required in path  
    
        Example: 1
    
    The ID of the channel to access.
 
    allow_empty_topic_name boolean optional  
    
        Example: true
    
    Whether the client supports processing the empty string as
a topic name in the returned data.
If false, the value of realm_empty_topic_display_name
found in the POST /register response is
returned replacing the empty string as the topic name.
Changes: New in Zulip 10.0 (feature level 334). Previously,
the empty string was not a valid topic.
Defaults to false.
 
Response
Return values
Example response(s)
Changes: As of Zulip 7.0 (feature level 167), if any
parameters sent in the request are not supported by this
endpoint, a successful JSON response will include an
ignored_parameters_unsupported array.
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 channel (or also a private channel they don't have access to):
{
    "code": "BAD_REQUEST",
    "msg": "Invalid channel ID",
    "result": "error"
}