Get a message's edit history

GET https://xi.zulipchat.com/api/v1/messages/{message_id}/history

Fetch the message edit history of a previously edited message.

Note that edit history may be disabled in some organizations; see the Zulip help center documentation on editing messages.

Usage examples

#!/usr/bin/env python3

import zulip

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

# Get the edit history for a message, given the message's ID.
result = client.get_message_history(message_id)
print(result)

curl -sSX GET -G https://xi.zulipchat.com/api/v1/messages/43/history \
    -u BOT_EMAIL_ADDRESS:BOT_API_KEY \
    --data-urlencode allow_empty_topic_name=true

Parameters

message_id integer required in path

Example: 43

The target message's ID.


allow_empty_topic_name boolean optional

Example: true

Whether the topic names i.e. topic and prev_topic fields in the message_history objects returned can be empty string.

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).

Defaults to false.


Response

Return values

  • message_history: (object)[]

    A chronologically sorted, oldest to newest, array of snapshot objects, each one with the values of the message after the edit.

    • topic: string

      The topic of the message immediately after this edit event.

    • prev_topic: string

      Only present if message's topic was edited.

      The topic of the message immediately prior to this edit event.

    • stream: integer

      Only present if message's channel was edited.

      The ID of the channel containing the message immediately after this edit event.

      Changes: New in Zulip 5.0 (feature level 118).

    • prev_stream: integer

      Only present if message's channel was edited.

      The ID of the channel containing the message immediately prior to this edit event.

      Changes: New in Zulip 3.0 (feature level 1).

    • content: string

      The raw Zulip-flavored Markdown content of the message immediately after this edit event.

    • rendered_content: string

      The rendered HTML representation of content.

      See Markdown message formatting for details on Zulip's HTML format.

    • prev_content: string

      Only present if message's content was edited.

      The raw Zulip-flavored Markdown content of the message immediately prior to this edit event.

    • prev_rendered_content: string

      Only present if message's content was edited.

      The rendered HTML representation of prev_content.

      See Markdown message formatting for details on Zulip's HTML format.

    • user_id: integer | null

      The ID of the user that made the edit.

      Will be null only for edit history events predating March 2017.

      Clients can display edit history events where this is null as modified by either the sender (for content edits) or an unknown user (for topic edits).

    • content_html_diff: string

      Only present if message's content was edited.

      An HTML diff between this version of the message and the previous one.

    • timestamp: integer

      The UNIX timestamp for this edit.

Please note that the original message's snapshot only contains the fields topic, content, rendered_content, timestamp and user_id. This snapshot will be the only one present if the message has never been edited.

Also note that each snapshot object will only contain additional data for the modified fields for that particular edit (e.g. if only the topic or channel was edited, prev_content, prev_rendered_content, and content_html_diff will not appear).

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:

{
    "message_history": [
        {
            "content": "Hello!",
            "rendered_content": "<p>Hello!</p>",
            "timestamp": 1530129122,
            "topic": "party at my houz",
            "user_id": 5
        },
        {
            "content": "Howdy!",
            "content_html_diff": "<div><p><span class=\"highlight_text_inserted\">Howdy!</span></p> <p><span class=\"highlight_text_deleted\">Hello!</span></p></div>",
            "prev_content": "Hello!",
            "prev_rendered_content": "<p>Hello!</p>",
            "prev_topic": "party at my houz",
            "rendered_content": "<p>Howdy!</p>",
            "timestamp": 1530129134,
            "topic": "party at my house",
            "user_id": 5
        }
    ],
    "msg": "",
    "result": "success"
}

An example JSON response for when the specified message does not exist:

{
    "code": "BAD_REQUEST",
    "msg": "Invalid message(s)",
    "result": "error"
}