session-android/libsignal/protobuf/SignalService.proto

253 lines
6.7 KiB
Protocol Buffer
Raw Normal View History

2021-01-25 11:27:05 +11:00
syntax = "proto2";
package signalservice;
2021-06-09 11:03:18 +10:00
option java_package = "org.session.libsignal.protos";
2021-01-25 11:27:05 +11:00
option java_outer_classname = "SignalServiceProtos";
message Envelope {
2021-02-18 17:05:34 +11:00
2021-01-25 11:27:05 +11:00
enum Type {
2021-04-26 11:06:00 +10:00
SESSION_MESSAGE = 6;
CLOSED_GROUP_MESSAGE = 7;
2021-01-25 11:27:05 +11:00
}
2021-02-18 17:05:34 +11:00
// @required
required Type type = 1;
2021-01-25 11:27:05 +11:00
optional string source = 2;
optional uint32 sourceDevice = 7;
2021-02-18 17:05:34 +11:00
// @required
2021-04-26 11:06:00 +10:00
required uint64 timestamp = 5;
2021-02-18 17:05:34 +11:00
optional bytes content = 8;
2021-01-25 11:27:05 +11:00
optional uint64 serverTimestamp = 10;
}
2021-02-18 17:05:34 +11:00
message TypingMessage {
2021-01-25 11:27:05 +11:00
2021-04-26 11:06:00 +10:00
enum Action {
STARTED = 0;
STOPPED = 1;
}
2021-01-25 11:27:05 +11:00
2021-04-26 11:06:00 +10:00
// @required
required uint64 timestamp = 1;
// @required
required Action action = 2;
2021-02-18 17:05:34 +11:00
}
2021-01-25 11:27:05 +11:00
2021-08-10 09:36:20 +10:00
message UnsendRequest {
// @required
required uint64 timestamp = 1;
// @required
required string author = 2;
}
2021-02-18 17:05:34 +11:00
message Content {
2021-04-26 11:06:00 +10:00
optional DataMessage dataMessage = 1;
optional ReceiptMessage receiptMessage = 5;
optional TypingMessage typingMessage = 6;
optional ConfigurationMessage configurationMessage = 7;
optional DataExtractionNotification dataExtractionNotification = 8;
2021-08-10 09:36:20 +10:00
optional UnsendRequest unsendRequest = 9;
optional MessageRequestResponse messageRequestResponse = 10;
2021-01-25 11:27:05 +11:00
}
2021-02-18 17:05:34 +11:00
message KeyPair {
// @required
required bytes publicKey = 1;
// @required
required bytes privateKey = 2;
}
message DataExtractionNotification {
enum Type {
SCREENSHOT = 1;
MEDIA_SAVED = 2; // timestamp
}
// @required
required Type type = 1;
optional uint64 timestamp = 2;
}
2021-01-25 11:27:05 +11:00
message DataMessage {
2021-02-18 17:05:34 +11:00
2021-01-25 11:27:05 +11:00
enum Flags {
2021-02-18 17:05:34 +11:00
EXPIRATION_TIMER_UPDATE = 2;
2021-01-25 11:27:05 +11:00
}
message Quote {
2021-02-18 17:05:34 +11:00
2021-01-25 11:27:05 +11:00
message QuotedAttachment {
2021-02-18 17:05:34 +11:00
enum Flags {
VOICE_MESSAGE = 1;
}
2021-01-25 11:27:05 +11:00
optional string contentType = 1;
optional string fileName = 2;
optional AttachmentPointer thumbnail = 3;
2021-02-18 17:05:34 +11:00
optional uint32 flags = 4;
2021-01-25 11:27:05 +11:00
}
2021-02-18 17:05:34 +11:00
// @required
2021-04-26 11:06:00 +10:00
required uint64 id = 1;
2021-02-18 17:05:34 +11:00
// @required
2021-04-26 11:06:00 +10:00
required string author = 2;
2021-02-18 17:05:34 +11:00
optional string text = 3;
repeated QuotedAttachment attachments = 4;
2021-01-25 11:27:05 +11:00
}
message Preview {
2021-02-18 17:05:34 +11:00
// @required
2021-04-26 11:06:00 +10:00
required string url = 1;
2021-01-25 11:27:05 +11:00
optional string title = 2;
optional AttachmentPointer image = 3;
}
2021-02-18 17:05:34 +11:00
message LokiProfile {
optional string displayName = 1;
optional string profilePicture = 2;
2021-01-25 11:27:05 +11:00
}
2021-05-12 08:40:10 +10:00
message OpenGroupInvitation {
// @required
required string url = 1;
// @required
required string name = 3;
}
2021-02-18 17:05:34 +11:00
message ClosedGroupControlMessage {
2021-01-25 11:27:05 +11:00
2021-02-18 17:05:34 +11:00
enum Type {
2021-06-09 11:03:18 +10:00
NEW = 1; // publicKey, name, encryptionKeyPair, members, admins, expireTimer
2021-02-18 17:05:34 +11:00
ENCRYPTION_KEY_PAIR = 3; // publicKey, wrappers
NAME_CHANGE = 4; // name
MEMBERS_ADDED = 5; // members
MEMBERS_REMOVED = 6; // members
MEMBER_LEFT = 7;
}
2021-01-25 11:27:05 +11:00
2021-02-18 17:05:34 +11:00
message KeyPairWrapper {
// @required
required bytes publicKey = 1; // The public key of the user the key pair is meant for
// @required
required bytes encryptedKeyPair = 2; // The encrypted key pair
}
2021-01-25 11:27:05 +11:00
// @required
2021-02-18 17:05:34 +11:00
required Type type = 1;
optional bytes publicKey = 2;
optional string name = 3;
optional KeyPair encryptionKeyPair = 4;
repeated bytes members = 5;
repeated bytes admins = 6;
repeated KeyPairWrapper wrappers = 7;
2021-06-21 14:03:08 +10:00
optional uint32 expirationTimer = 8;
2021-01-25 11:27:05 +11:00
}
2021-02-18 17:05:34 +11:00
optional string body = 1;
repeated AttachmentPointer attachments = 2;
optional GroupContext group = 3;
optional uint32 flags = 4;
optional uint32 expireTimer = 5;
optional bytes profileKey = 6;
optional uint64 timestamp = 7;
optional Quote quote = 8;
repeated Preview preview = 10;
optional LokiProfile profile = 101;
2021-05-12 08:40:10 +10:00
optional OpenGroupInvitation openGroupInvitation = 102;
2021-02-18 17:05:34 +11:00
optional ClosedGroupControlMessage closedGroupControlMessage = 104;
optional string syncTarget = 105;
2021-01-25 11:27:05 +11:00
}
message ConfigurationMessage {
message ClosedGroup {
optional bytes publicKey = 1;
optional string name = 2;
optional KeyPair encryptionKeyPair = 3;
repeated bytes members = 4;
repeated bytes admins = 5;
2021-06-21 14:03:08 +10:00
optional uint32 expirationTimer = 6;
}
message Contact {
// @required
required bytes publicKey = 1;
// @required
required string name = 2;
optional string profilePicture = 3;
optional bytes profileKey = 4;
optional bool isApproved = 5;
optional bool isBlocked = 6;
optional bool didApproveMe = 7;
}
repeated ClosedGroup closedGroups = 1;
repeated string openGroups = 2;
optional string displayName = 3;
optional string profilePicture = 4;
optional bytes profileKey = 5;
repeated Contact contacts = 6;
}
message MessageRequestResponse {
// @required
required bool isApproved = 1; // Whether the request was approved
}
2021-02-18 17:05:34 +11:00
message ReceiptMessage {
2021-01-25 11:27:05 +11:00
2021-02-18 17:05:34 +11:00
enum Type {
DELIVERY = 0;
READ = 1;
2021-01-25 11:27:05 +11:00
}
2021-02-18 17:05:34 +11:00
// @required
2021-04-26 11:06:00 +10:00
required Type type = 1;
2021-02-18 17:05:34 +11:00
repeated uint64 timestamp = 2;
2021-01-25 11:27:05 +11:00
}
message AttachmentPointer {
2021-02-18 17:05:34 +11:00
2021-01-25 11:27:05 +11:00
enum Flags {
VOICE_MESSAGE = 1;
}
2021-02-18 17:05:34 +11:00
// @required
2021-04-26 11:06:00 +10:00
required fixed64 id = 1;
2021-01-25 11:27:05 +11:00
optional string contentType = 2;
optional bytes key = 3;
optional uint32 size = 4;
optional bytes thumbnail = 5;
optional bytes digest = 6;
optional string fileName = 7;
optional uint32 flags = 8;
optional uint32 width = 9;
optional uint32 height = 10;
optional string caption = 11;
optional string url = 101;
}
message GroupContext {
2021-02-18 17:05:34 +11:00
2021-01-25 11:27:05 +11:00
enum Type {
UNKNOWN = 0;
UPDATE = 1;
DELIVER = 2;
QUIT = 3;
REQUEST_INFO = 4;
}
2021-02-18 17:05:34 +11:00
// @required
2021-01-25 11:27:05 +11:00
optional bytes id = 1;
2021-02-18 17:05:34 +11:00
// @required
2021-01-25 11:27:05 +11:00
optional Type type = 2;
optional string name = 3;
repeated string members = 4;
optional AttachmentPointer avatar = 5;
repeated string admins = 6;
2021-02-18 17:05:34 +11:00
}