// Copyright 2014 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only // Source: https://github.com/signalapp/libsignal-service-java/blob/4684a49b2ed8f32be619e0d0eea423626b6cb2cb/protobuf/SignalService.proto package signalservice; option java_package = "org.whispersystems.signalservice.internal.push"; option java_outer_classname = "SignalServiceProtos"; message Envelope { enum Type { UNKNOWN = 0; CIPHERTEXT = 1; KEY_EXCHANGE = 2; PREKEY_BUNDLE = 3; RECEIPT = 5; UNIDENTIFIED_SENDER = 6; // Our parser does not handle reserved in enums: DESKTOP-1569 // reserved 7; PLAINTEXT_CONTENT = 8; } optional Type type = 1; optional string sourceUuid = 11; optional uint32 sourceDevice = 7; optional string destinationUuid = 13; // reserved 3; // formerly optional string relay = 3; optional uint64 timestamp = 5; // reserved 6; // formerly optional bytes legacyMessage = 6; optional bytes content = 8; // Contains an encrypted Content optional string serverGuid = 9; optional uint64 serverTimestamp = 10; optional bool ephemeral = 12; // indicates that the message should not be persisted if the recipient is offline optional bool urgent = 14 [default=true]; // indicates that the content is considered timely by the sender; defaults to true so senders have to opt-out to say something isn't time critical optional string updated_pni = 15; optional bool story = 16; // indicates that the content is a story. optional bytes reporting_token = 17; // next: 18 } message Content { optional DataMessage dataMessage = 1; optional SyncMessage syncMessage = 2; optional CallingMessage callingMessage = 3; optional NullMessage nullMessage = 4; optional ReceiptMessage receiptMessage = 5; optional TypingMessage typingMessage = 6; optional bytes senderKeyDistributionMessage = 7; optional bytes decryptionErrorMessage = 8; optional StoryMessage storyMessage = 9; optional PniSignatureMessage pniSignatureMessage = 10; optional EditMessage editMessage = 11; } // Everything in CallingMessage must be kept in sync with RingRTC (ringrtc-node). // Whenever you change this, make sure you change textsecure.d.ts and RingRTC. message CallingMessage { message Offer { enum Type { OFFER_AUDIO_CALL = 0; OFFER_VIDEO_CALL = 1; } optional uint64 callId = 1; // Legacy/deprecated; replaced by 'opaque' optional string sdp = 2; optional Type type = 3; optional bytes opaque = 4; } message Answer { optional uint64 callId = 1; // Legacy/deprecated; replaced by 'opaque' optional string sdp = 2; optional bytes opaque = 3; } message IceCandidate { optional uint64 callId = 1; // Legacy/deprecated; remove when old clients are gone. optional string mid = 2; // Legacy/deprecated; remove when old clients are gone. optional uint32 line = 3; // Legacy/deprecated; replaced by 'opaque' optional string sdp = 4; optional bytes opaque = 5; } message Busy { optional uint64 callId = 1; } message Hangup { enum Type { HANGUP_NORMAL = 0; HANGUP_ACCEPTED = 1; HANGUP_DECLINED = 2; HANGUP_BUSY = 3; HANGUP_NEED_PERMISSION = 4; } optional uint64 callId = 1; optional Type type = 2; optional uint32 deviceId = 3; } message Opaque { enum Urgency { DROPPABLE = 0; HANDLE_IMMEDIATELY = 1; } optional bytes data = 1; optional Urgency urgency = 2; } optional Offer offer = 1; optional Answer answer = 2; repeated IceCandidate iceCandidates = 3; optional Hangup legacyHangup = 4; optional Busy busy = 5; optional Hangup hangup = 7; optional bool supportsMultiRing = 8; optional uint32 destinationDeviceId = 9; optional Opaque opaque = 10; } message DataMessage { enum Flags { END_SESSION = 1; EXPIRATION_TIMER_UPDATE = 2; PROFILE_KEY_UPDATE = 4; } message Payment { message Amount { message MobileCoin { optional uint64 picoMob = 1; // 1,000,000,000,000 picoMob per Mob } oneof Amount { MobileCoin mobileCoin = 1; } } message RequestId { optional string uuid = 1; } message Request { optional RequestId requestId = 1; optional Amount amount = 2; optional string note = 3; } message Notification { message MobileCoin { optional bytes receipt = 1; } oneof Transaction { MobileCoin mobileCoin = 1; } // Optional, Refers to the PaymentRequest message, if any. optional string note = 2; optional RequestId requestId = 1003; } message Cancellation { optional RequestId requestId = 1; } message Activation { enum Type { REQUEST = 0; ACTIVATED = 1; } optional Type type = 1; } oneof Item { Notification notification = 1; Activation activation = 2; Request request = 1002; Cancellation cancellation = 1003; } } message Quote { enum Type { NORMAL = 0; GIFT_BADGE = 1; } message QuotedAttachment { optional string contentType = 1; optional string fileName = 2; optional AttachmentPointer thumbnail = 3; } optional uint64 id = 1; reserved /* author */ 2; // removed optional string authorUuid = 5; optional string text = 3; repeated QuotedAttachment attachments = 4; repeated BodyRange bodyRanges = 6; optional Type type = 7; } message Contact { message Name { optional string givenName = 1; optional string familyName = 2; optional string prefix = 3; optional string suffix = 4; optional string middleName = 5; optional string displayName = 6; } message Phone { enum Type { HOME = 1; MOBILE = 2; WORK = 3; CUSTOM = 4; } optional string value = 1; optional Type type = 2; optional string label = 3; } message Email { enum Type { HOME = 1; MOBILE = 2; WORK = 3; CUSTOM = 4; } optional string value = 1; optional Type type = 2; optional string label = 3; } message PostalAddress { enum Type { HOME = 1; WORK = 2; CUSTOM = 3; } optional Type type = 1; optional string label = 2; optional string street = 3; optional string pobox = 4; optional string neighborhood = 5; optional string city = 6; optional string region = 7; optional string postcode = 8; optional string country = 9; } message Avatar { optional AttachmentPointer avatar = 1; optional bool isProfile = 2; } optional Name name = 1; repeated Phone number = 3; repeated Email email = 4; repeated PostalAddress address = 5; optional Avatar avatar = 6; optional string organization = 7; } message Preview { optional string url = 1; optional string title = 2; optional AttachmentPointer image = 3; optional string description = 4; optional uint64 date = 5; } message Sticker { optional bytes packId = 1; optional bytes packKey = 2; optional uint32 stickerId = 3; optional AttachmentPointer data = 4; optional string emoji = 5; } message Reaction { optional string emoji = 1; optional bool remove = 2; reserved /* targetAuthorE164 */ 3; // removed optional string targetAuthorUuid = 4; optional uint64 targetTimestamp = 5; } message Delete { optional uint64 targetSentTimestamp = 1; } message BodyRange { enum Style { NONE = 0; BOLD = 1; ITALIC = 2; SPOILER = 3; STRIKETHROUGH = 4; MONOSPACE = 5; } optional uint32 start = 1; optional uint32 length = 2; oneof associatedValue { string mentionUuid = 3; Style style = 4; } } message GroupCallUpdate { optional string eraId = 1; } message StoryContext { optional string authorUuid = 1; optional uint64 sentTimestamp = 2; } enum ProtocolVersion { option allow_alias = true; INITIAL = 0; MESSAGE_TIMERS = 1; VIEW_ONCE = 2; VIEW_ONCE_VIDEO = 3; REACTIONS = 4; CDN_SELECTOR_ATTACHMENTS = 5; MENTIONS = 6; PAYMENTS = 7; CURRENT = 7; } message GiftBadge { optional bytes receiptCredentialPresentation = 1; } optional string body = 1; repeated AttachmentPointer attachments = 2; reserved /*groupV1*/ 3; optional GroupContextV2 groupV2 = 15; optional uint32 flags = 4; optional uint32 expireTimer = 5; optional bytes profileKey = 6; optional uint64 timestamp = 7; optional Quote quote = 8; repeated Contact contact = 9; repeated Preview preview = 10; optional Sticker sticker = 11; optional uint32 requiredProtocolVersion = 12; optional bool isViewOnce = 14; optional Reaction reaction = 16; optional Delete delete = 17; repeated BodyRange bodyRanges = 18; optional GroupCallUpdate groupCallUpdate = 19; optional Payment payment = 20; optional StoryContext storyContext = 21; optional GiftBadge giftBadge = 22; } message NullMessage { optional bytes padding = 1; } message ReceiptMessage { enum Type { DELIVERY = 0; READ = 1; VIEWED = 2; } optional Type type = 1; repeated uint64 timestamp = 2; } message TypingMessage { enum Action { STARTED = 0; STOPPED = 1; } optional uint64 timestamp = 1; optional Action action = 2; optional bytes groupId = 3; } message StoryMessage { optional bytes profileKey = 1; optional GroupContextV2 group = 2; oneof attachment { AttachmentPointer fileAttachment = 3; TextAttachment textAttachment = 4; } optional bool allowsReplies = 5; repeated BodyRange bodyRanges = 6; } message TextAttachment { enum Style { DEFAULT = 0; REGULAR = 1; BOLD = 2; SERIF = 3; SCRIPT = 4; CONDENSED = 5; } message Gradient { optional uint32 startColor = 1; optional uint32 endColor = 2; optional uint32 angle = 3; // degrees } optional string text = 1; optional Style textStyle = 2; optional uint32 textForegroundColor = 3; // integer representation of hex color optional uint32 textBackgroundColor = 4; optional Preview preview = 5; oneof background { Gradient gradient = 6; uint32 color = 7; } } message Verified { enum State { DEFAULT = 0; VERIFIED = 1; UNVERIFIED = 2; } optional string destination = 1; optional string destinationUuid = 5; optional bytes identityKey = 2; optional State state = 3; optional bytes nullMessage = 4; } message SyncMessage { message Sent { message UnidentifiedDeliveryStatus { optional string destination = 1; oneof destinationServiceId { string destinationAci = 3; string destinationPni = 4; } optional bool unidentified = 2; } message StoryMessageRecipient { oneof destinationServiceId { string destinationAci = 1; string destinationPni = 4; } repeated string distributionListIds = 2; optional bool isAllowedToReply = 3; } optional string destination = 1; oneof destinationServiceId { string destinationAci = 7; string destinationPni = 11; } optional uint64 timestamp = 2; optional DataMessage message = 3; optional uint64 expirationStartTimestamp = 4; repeated UnidentifiedDeliveryStatus unidentifiedStatus = 5; optional bool isRecipientUpdate = 6 [default = false]; optional StoryMessage storyMessage = 8; repeated StoryMessageRecipient storyMessageRecipients = 9; optional EditMessage editMessage = 10; } message Contacts { optional AttachmentPointer blob = 1; optional bool complete = 2 [default = false]; } message Groups { optional AttachmentPointer blob = 1; } message Blocked { repeated string numbers = 1; repeated string uuids = 3; repeated bytes groupIds = 2; } message Request { enum Type { UNKNOWN = 0; CONTACTS = 1; GROUPS = 2; BLOCKED = 3; CONFIGURATION = 4; KEYS = 5; PNI_IDENTITY = 6; } optional Type type = 1; } message Keys { optional bytes storageService = 1; } message Read { optional string sender = 1; optional string senderUuid = 3; optional uint64 timestamp = 2; } message Viewed { optional string senderE164 = 1; optional string senderUuid = 3; optional uint64 timestamp = 2; } message Configuration { optional bool readReceipts = 1; optional bool unidentifiedDeliveryIndicators = 2; optional bool typingIndicators = 3; reserved 4; optional uint32 provisioningVersion = 5; optional bool linkPreviews = 6; } message StickerPackOperation { enum Type { INSTALL = 0; REMOVE = 1; } optional bytes packId = 1; optional bytes packKey = 2; optional Type type = 3; } message ViewOnceOpen { optional string sender = 1; optional string senderUuid = 3; optional uint64 timestamp = 2; } message MessageRequestResponse { enum Type { UNKNOWN = 0; ACCEPT = 1; DELETE = 2; BLOCK = 3; BLOCK_AND_DELETE = 4; } optional string threadE164 = 1; optional string threadUuid = 2; optional bytes groupId = 3; optional Type type = 4; } message FetchLatest { enum Type { UNKNOWN = 0; LOCAL_PROFILE = 1; STORAGE_MANIFEST = 2; SUBSCRIPTION_STATUS = 3; } optional Type type = 1; } message PniChangeNumber { optional bytes identityKeyPair = 1; // Serialized libsignal-client IdentityKeyPair optional bytes signedPreKey = 2; // Serialized libsignal-client SignedPreKeyRecord optional bytes lastResortKyberPreKey = 5; // Serialized libsignal-client KyberPreKeyRecord optional uint32 registrationId = 3; optional string newE164 = 4; // The e164 we have changed our number to // Next ID: 6 } message CallEvent { enum Type { UNKNOWN = 0; AUDIO_CALL = 1; VIDEO_CALL = 2; } enum Direction { UNKNOWN = 0; INCOMING = 1; OUTGOING = 2; } enum Event { UNKNOWN = 0; ACCEPTED = 1; NOT_ACCEPTED = 2; } optional bytes peerUuid = 1; optional uint64 callId = 2; optional uint64 timestamp = 3; optional Type type = 4; optional Direction direction = 5; optional Event event = 6; } optional Sent sent = 1; optional Contacts contacts = 2; optional Groups groups = 3; optional Request request = 4; repeated Read read = 5; optional Blocked blocked = 6; optional Verified verified = 7; optional Configuration configuration = 9; optional bytes padding = 8; repeated StickerPackOperation stickerPackOperation = 10; optional ViewOnceOpen viewOnceOpen = 11; optional FetchLatest fetchLatest = 12; optional Keys keys = 13; optional MessageRequestResponse messageRequestResponse = 14; reserved 15; // not yet added repeated Viewed viewed = 16; reserved 17; // pniIdentity optional PniChangeNumber pniChangeNumber = 18; optional CallEvent callEvent = 19; } message AttachmentPointer { enum Flags { VOICE_MESSAGE = 1; BORDERLESS = 2; // Our parser does not handle reserved in enums: DESKTOP-1569 // reserved 4; GIF = 8; } oneof attachment_identifier { fixed64 cdnId = 1; string cdnKey = 15; } 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 blurHash = 12; optional uint64 uploadTimestamp = 13; optional uint32 cdnNumber = 14; // Next ID: 16 } message GroupContextV2 { optional bytes masterKey = 1; optional uint32 revision = 2; optional bytes groupChange = 3; } message ContactDetails { message Avatar { optional string contentType = 1; optional uint32 length = 2; } optional string number = 1; optional string uuid = 9; optional string name = 2; optional Avatar avatar = 3; optional string color = 4; optional Verified verified = 5; optional bytes profileKey = 6; optional bool blocked = 7; optional uint32 expireTimer = 8; optional uint32 inboxPosition = 10; } message GroupDetails { message Avatar { optional string contentType = 1; optional uint32 length = 2; } message Member { optional string uuid = 1; optional string e164 = 2; } optional bytes id = 1; optional string name = 2; repeated string membersE164 = 3; repeated Member members = 9; optional Avatar avatar = 4; optional bool active = 5 [default = true]; optional uint32 expireTimer = 6; optional string color = 7; optional bool blocked = 8; optional uint32 inboxPosition = 10; } message PniSignatureMessage { optional bytes pni = 1; // Signature *by* the PNI identity key *of* the ACI identity key optional bytes signature = 2; } message EditMessage { optional uint64 targetSentTimestamp = 1; optional DataMessage dataMessage = 2; }