mirror of
https://github.com/matrix-org/matrix-spec
synced 2026-03-25 12:34:10 +01:00
Use body field as media caption
As per MSC2530. Signed-off-by: Kévin Commaille <zecakeh@tedomum.fr>
This commit is contained in:
parent
c4e69d8cb1
commit
4b6e1abc08
|
|
@ -19,6 +19,8 @@ room itself such as a room name and topic.
|
||||||
|
|
||||||
##### m.room.message msgtypes
|
##### m.room.message msgtypes
|
||||||
|
|
||||||
|
{{% changed-in v="1.10" %}}
|
||||||
|
|
||||||
Each [m.room.message](#mroommessage) MUST have a `msgtype` key which identifies the
|
Each [m.room.message](#mroommessage) MUST have a `msgtype` key which identifies the
|
||||||
type of message being sent. Each type has their own required and
|
type of message being sent. Each type has their own required and
|
||||||
optional keys, as outlined below. If a client cannot display the given
|
optional keys, as outlined below. If a client cannot display the given
|
||||||
|
|
@ -27,10 +29,17 @@ instead.
|
||||||
|
|
||||||
Some message types support HTML in the event content that clients should
|
Some message types support HTML in the event content that clients should
|
||||||
prefer to display if available. Currently `m.text`, `m.emote`, `m.notice`,
|
prefer to display if available. Currently `m.text`, `m.emote`, `m.notice`,
|
||||||
and `m.key.verification.request` support an additional `format` parameter of
|
`m.image`, `m.file`, `m.audio`, `m.video` and `m.key.verification.request`
|
||||||
`org.matrix.custom.html`. When this field is present, a `formatted_body`
|
support an additional `format` parameter of `org.matrix.custom.html`. When this
|
||||||
with the HTML must be provided. The plain text version of the HTML
|
field is present, a `formatted_body` with the HTML must be provided. The plain
|
||||||
should be provided in the `body`.
|
text version of the HTML should be provided in the `body`.
|
||||||
|
|
||||||
|
{{% boxes/note %}}
|
||||||
|
Until v1.10 of the spec, the `format` and `formatted` fields were limited to
|
||||||
|
`m.text`, `m.emote`, `m.notice`, and `m.key.verification.request`. As of v1.10
|
||||||
|
this list is now expanded to include `m.image`, `m.file`, `m.audio` and
|
||||||
|
`m.video` for [media captions](#media-captions).
|
||||||
|
{{% /boxes/note %}}
|
||||||
|
|
||||||
Clients should limit the HTML they render to avoid Cross-Site Scripting,
|
Clients should limit the HTML they render to avoid Cross-Site Scripting,
|
||||||
HTML injection, and similar attacks. The strongly suggested set of HTML
|
HTML injection, and similar attacks. The strongly suggested set of HTML
|
||||||
|
|
@ -320,6 +329,49 @@ to the media repository, then reference the `mxc://` URI in a markdown-style lin
|
||||||
Clients SHOULD render spoilers differently with some sort of disclosure. For example, the
|
Clients SHOULD render spoilers differently with some sort of disclosure. For example, the
|
||||||
client could blur the actual text and ask the user to click on it for it to be revealed.
|
client could blur the actual text and ask the user to click on it for it to be revealed.
|
||||||
|
|
||||||
|
##### Media captions
|
||||||
|
|
||||||
|
{{% added-in v="1.10" %}}
|
||||||
|
|
||||||
|
Media messages, comprised of `m.image`, `m.file`, `m.audio` and `m.video`, can
|
||||||
|
include a caption to convey additional information about the media.
|
||||||
|
|
||||||
|
To send captions, clients MUST use the `filename` and the `body`, and optionally
|
||||||
|
the `formatted_body` with the `org.matrix.custom.html` format, described above.
|
||||||
|
|
||||||
|
If the `filename` is present, and its value is different than `body`, then
|
||||||
|
`body` is considered to be a caption, otherwise `body` is a filename. `format`
|
||||||
|
and `formatted_body` are only used for captions.
|
||||||
|
|
||||||
|
{{% boxes/note %}}
|
||||||
|
In previous versions of the specification, `body` was usually used to set the
|
||||||
|
filename of the uploaded file, and `filename` was only present on `m.file` with
|
||||||
|
the same purpose.
|
||||||
|
{{% /boxes/note %}}
|
||||||
|
|
||||||
|
An example of a media message with a caption is:
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"msgtype": "m.image",
|
||||||
|
"url": "mxc://example.org/abc123",
|
||||||
|
"filename": "dog.jpg",
|
||||||
|
"body": "this is a ~~cat~~ picture :3",
|
||||||
|
"format": "org.matrix.custom.html",
|
||||||
|
"formatted_body": "this is a <strike>cat</strike> picture :3",
|
||||||
|
"info": {
|
||||||
|
"w": 479,
|
||||||
|
"h": 640,
|
||||||
|
"mimetype": "image/jpeg",
|
||||||
|
"size": 27253
|
||||||
|
},
|
||||||
|
"m.mentions": {}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Clients MUST render the caption alongside the media and SHOULD prefer its
|
||||||
|
formatted representation.
|
||||||
|
|
||||||
#### Server behaviour
|
#### Server behaviour
|
||||||
|
|
||||||
Homeservers SHOULD reject `m.room.message` events which don't have a
|
Homeservers SHOULD reject `m.room.message` events which don't have a
|
||||||
|
|
|
||||||
|
|
@ -6,8 +6,29 @@ properties:
|
||||||
content:
|
content:
|
||||||
properties:
|
properties:
|
||||||
body:
|
body:
|
||||||
description: "A description of the audio e.g. 'Bee Gees - Stayin' Alive', or some kind of content description for accessibility e.g. 'audio attachment'."
|
description: |-
|
||||||
|
If `filename` is not set or the value of both properties are
|
||||||
|
identical, this is the filename of the original upload. Otherwise,
|
||||||
|
this is a caption for the audio.
|
||||||
type: string
|
type: string
|
||||||
|
x-changedInMatrixVersion:
|
||||||
|
"1.10": This property can act as a caption for the audio.
|
||||||
|
format:
|
||||||
|
description: |-
|
||||||
|
The format used in the `formatted_body`. Currently only
|
||||||
|
`org.matrix.custom.html` is supported.
|
||||||
|
type: string
|
||||||
|
x-addedInMatrixVersion: "1.10"
|
||||||
|
formatted_body:
|
||||||
|
description: |-
|
||||||
|
The formatted version of the `body`, when it acts as a caption. This
|
||||||
|
is required if `format` is specified.
|
||||||
|
type: string
|
||||||
|
x-addedInMatrixVersion: "1.10"
|
||||||
|
filename:
|
||||||
|
description: The original filename of the uploaded file.
|
||||||
|
type: string
|
||||||
|
x-addedInMatrixVersion: "1.10"
|
||||||
info:
|
info:
|
||||||
description: Metadata for the audio clip referred to in `url`.
|
description: Metadata for the audio clip referred to in `url`.
|
||||||
properties:
|
properties:
|
||||||
|
|
|
||||||
|
|
@ -6,8 +6,25 @@ properties:
|
||||||
content:
|
content:
|
||||||
properties:
|
properties:
|
||||||
body:
|
body:
|
||||||
description: A human-readable description of the file. This is recommended to be the filename of the original upload.
|
description: |-
|
||||||
|
If `filename` is not set or the value of both properties are
|
||||||
|
identical, this is the filename of the original upload. Otherwise,
|
||||||
|
this is a caption for the file.
|
||||||
type: string
|
type: string
|
||||||
|
x-changedInMatrixVersion:
|
||||||
|
"1.10": This property can act as a caption for the file.
|
||||||
|
format:
|
||||||
|
description: |-
|
||||||
|
The format used in the `formatted_body`. Currently only
|
||||||
|
`org.matrix.custom.html` is supported.
|
||||||
|
type: string
|
||||||
|
x-addedInMatrixVersion: "1.10"
|
||||||
|
formatted_body:
|
||||||
|
description: |-
|
||||||
|
The formatted version of the `body`, when it acts as a caption. This
|
||||||
|
is required if `format` is specified.
|
||||||
|
type: string
|
||||||
|
x-addedInMatrixVersion: "1.10"
|
||||||
filename:
|
filename:
|
||||||
description: The original filename of the uploaded file.
|
description: The original filename of the uploaded file.
|
||||||
type: string
|
type: string
|
||||||
|
|
|
||||||
|
|
@ -6,8 +6,29 @@ properties:
|
||||||
content:
|
content:
|
||||||
properties:
|
properties:
|
||||||
body:
|
body:
|
||||||
description: "A textual representation of the image. This could be the alt text of the image, the filename of the image, or some kind of content description for accessibility e.g. 'image attachment'."
|
description: |-
|
||||||
|
If `filename` is not set or the value of both properties are
|
||||||
|
identical, this is the filename of the original upload. Otherwise,
|
||||||
|
this is a caption for the image.
|
||||||
type: string
|
type: string
|
||||||
|
x-changedInMatrixVersion:
|
||||||
|
"1.10": This property can act as a caption for the image.
|
||||||
|
format:
|
||||||
|
description: |-
|
||||||
|
The format used in the `formatted_body`. Currently only
|
||||||
|
`org.matrix.custom.html` is supported.
|
||||||
|
type: string
|
||||||
|
x-addedInMatrixVersion: "1.10"
|
||||||
|
formatted_body:
|
||||||
|
description: |-
|
||||||
|
The formatted version of the `body`, when it acts as a caption. This
|
||||||
|
is required if `format` is specified.
|
||||||
|
type: string
|
||||||
|
x-addedInMatrixVersion: "1.10"
|
||||||
|
filename:
|
||||||
|
description: The original filename of the uploaded file.
|
||||||
|
type: string
|
||||||
|
x-addedInMatrixVersion: "1.10"
|
||||||
info:
|
info:
|
||||||
allOf:
|
allOf:
|
||||||
- $ref: core-event-schema/msgtype_infos/image_info.yaml
|
- $ref: core-event-schema/msgtype_infos/image_info.yaml
|
||||||
|
|
|
||||||
|
|
@ -6,8 +6,29 @@ properties:
|
||||||
content:
|
content:
|
||||||
properties:
|
properties:
|
||||||
body:
|
body:
|
||||||
description: "A description of the video e.g. 'Gangnam style', or some kind of content description for accessibility e.g. 'video attachment'."
|
description: |-
|
||||||
|
If `filename` is not set or the value of both properties are
|
||||||
|
identical, this is the filename of the original upload. Otherwise,
|
||||||
|
this is a caption for the video.
|
||||||
type: string
|
type: string
|
||||||
|
x-changedInMatrixVersion:
|
||||||
|
"1.10": This property can act as a caption for the video.
|
||||||
|
format:
|
||||||
|
description: |-
|
||||||
|
The format used in the `formatted_body`. Currently only
|
||||||
|
`org.matrix.custom.html` is supported.
|
||||||
|
type: string
|
||||||
|
x-addedInMatrixVersion: "1.10"
|
||||||
|
formatted_body:
|
||||||
|
description: |-
|
||||||
|
The formatted version of the `body`, when it acts as a caption. This
|
||||||
|
is required if `format` is specified.
|
||||||
|
type: string
|
||||||
|
x-addedInMatrixVersion: "1.10"
|
||||||
|
filename:
|
||||||
|
description: The original filename of the uploaded file.
|
||||||
|
type: string
|
||||||
|
x-addedInMatrixVersion: "1.10"
|
||||||
info:
|
info:
|
||||||
description: Metadata about the video clip referred to in `url`.
|
description: Metadata about the video clip referred to in `url`.
|
||||||
properties:
|
properties:
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue