Add image content-type

This commit is contained in:
Andrea Maria Piana 2020-04-30 12:25:37 +02:00
parent 1b909c3d9f
commit ca530d9d80
No known key found for this signature in database
GPG Key ID: AA6CCA6DE0E06424

View File

@ -1,14 +1,14 @@
---
permalink: /spec/6
parent: Stable specs
parent: Draft specs
title: 6/PAYLOADS
---
# 6/PAYLOADS
> Version: 0.2
> Version: 0.3
>
> Status: Stable
> Status: Draft
>
> Authors: Adam Babik <adam@status.im>, Andrea Maria Piana <andreap@status.im>, Oskar Thorén <oskar@status.im> (alphabetical order)
@ -35,6 +35,7 @@ as various clients created using different technologies.
- [Payload](#payload-1)
- [Content types](#content-types)
- [Sticker content type](#sticker-content-type)
- [Image content type](#image-content-type)
- [Message types](#message-types)
- [Clock vs Timestamp and message ordering](#clock-vs-timestamp-and-message-ordering)
- [Chats](#chats)
@ -112,6 +113,7 @@ message ChatMessage {
oneof payload {
StickerMessage sticker = 9;
ImageMessage image = 10;
}
enum MessageType {
@ -130,6 +132,7 @@ message ChatMessage {
TRANSACTION_COMMAND = 5;
// Only local
SYSTEM_MESSAGE_CONTENT_PRIVATE_GROUP = 6;
IMAGE = 7;
}
}
```
@ -146,7 +149,7 @@ message ChatMessage {
| 6 | chat_id | `string` | The local ID of the chat the message is sent to |
| 7 | message_type | `MessageType` | The type of message, different for one-to-one, public or group chats |
| 8 | content_type | `ContentType` | The type of the content of the message |
| 9 | payload | `Sticker|nil` | The payload of the message based on the content type |
| 9 | payload | `Sticker|Image|nil` | The payload of the message based on the content type |
#### Content types
@ -160,6 +163,7 @@ There are also other content types that MAY be implemented by the client:
* `STATUS`
* `EMOJI`
* `TRANSACTION_COMMAND`
* `IMAGE`
##### Sticker content type
@ -173,6 +177,26 @@ message StickerMessage {
}
```
##### Image content type
A `ChatMessage` with `IMAGE` `Content/Type` MUST also specify the `payload` of the image
and the `type`
```protobuf
message ImageMessage {
bytes payload = 1;
ImageType type = 2;
}
enum ImageType {
UNKNOWN_IMAGE_TYPE = 0;
IMAGE_JPEG = 1;
IMAGE_PNG = 2;
IMAGE_WEBP = 3;
}
```
#### Message types
Message types are required to decide how a particular message is encrypted and what metadata needs to be attached when passing a message to the transport layer. For more on this, see [3/WHISPER-USAGE](https://specs.status.im/spec/3).