// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import { KeyPairType, SessionRecordType, SignedPreKeyType, StorageType, } from './libsignal.d'; import Crypto from './textsecure/Crypto'; import MessageReceiver from './textsecure/MessageReceiver'; import MessageSender from './textsecure/SendMessage'; import EventTarget from './textsecure/EventTarget'; import { ByteBufferClass } from './window.d'; import SendMessage, { SendOptionsType } from './textsecure/SendMessage'; import { WebAPIType } from './textsecure/WebAPI'; import utils from './textsecure/Helpers'; import { CallingMessage as CallingMessageClass } from 'ringrtc'; import { WhatIsThis } from './window.d'; type AttachmentType = any; export type UnprocessedType = { attempts: number; decrypted?: string; envelope?: string; id: string; serverTimestamp?: number; source?: string; sourceDevice?: number; sourceUuid?: string; version: number; }; export type StorageServiceCallOptionsType = { credentials?: StorageServiceCredentials; greaterThanVersion?: string; }; export type StorageServiceCredentials = { username: string; password: string; }; export type TextSecureType = { createTaskWithTimeout: ( task: () => Promise | any, id?: string, options?: { timeout?: number } ) => () => Promise; crypto: typeof Crypto; storage: { user: { getNumber: () => string; getUuid: () => string | undefined; getDeviceId: () => number | string; getDeviceName: () => string; getDeviceNameEncrypted: () => boolean; setDeviceNameEncrypted: () => Promise; getSignalingKey: () => ArrayBuffer; setNumberAndDeviceId: ( number: string, deviceId: number, deviceName?: string | null ) => Promise; setUuidAndDeviceId: (uuid: string, deviceId: number) => Promise; }; unprocessed: { batchAdd: (dataArray: Array) => Promise; remove: (id: string | Array) => Promise; getCount: () => Promise; removeAll: () => Promise; getAll: () => Promise>; updateAttempts: (id: string, attempts: number) => Promise; addDecryptedDataToList: ( array: Array> ) => Promise; }; get: (key: string, defaultValue?: any) => any; put: (key: string, value: any) => Promise; remove: (key: string | Array) => Promise; protocol: StorageProtocolType; }; messageReceiver: MessageReceiver; messageSender: MessageSender; messaging: SendMessage; protobuf: ProtobufCollectionType; utils: typeof utils; EventTarget: typeof EventTarget; MessageReceiver: typeof MessageReceiver; AccountManager: WhatIsThis; MessageSender: WhatIsThis; SyncRequest: WhatIsThis; }; type StoredSignedPreKeyType = SignedPreKeyType & { confirmed?: boolean; created_at: number; }; type IdentityKeyRecord = { publicKey: ArrayBuffer; firstUse: boolean; timestamp: number; verified: number; nonblockingApproval: boolean; }; export type StorageProtocolType = StorageType & { VerifiedStatus: { DEFAULT: number; VERIFIED: number; UNVERIFIED: number; }; archiveSiblingSessions: (identifier: string) => Promise; removeSession: (identifier: string) => Promise; getDeviceIds: (identifier: string) => Promise>; getIdentityRecord: (identifier: string) => IdentityKeyRecord | undefined; getVerified: (id: string) => Promise; hydrateCaches: () => Promise; clearPreKeyStore: () => Promise; clearSignedPreKeysStore: () => Promise; clearSessionStore: () => Promise; isTrustedIdentity: () => void; isUntrusted: (id: string) => Promise; storePreKey: (keyId: number, keyPair: KeyPairType) => Promise; storeSignedPreKey: ( keyId: number, keyPair: KeyPairType, confirmed?: boolean ) => Promise; loadIdentityKey: (identifier: string) => Promise; loadSignedPreKeys: () => Promise>; processVerifiedMessage: ( identifier: string, verifiedStatus: number, publicKey: ArrayBuffer ) => Promise; removeIdentityKey: (identifier: string) => Promise; saveIdentityWithAttributes: ( number: string, options: IdentityKeyRecord ) => Promise; setApproval: (id: string, something: boolean) => void; setVerified: ( encodedAddress: string, verifiedStatus: number, publicKey?: ArrayBuffer ) => Promise; removeSignedPreKey: (keyId: number) => Promise; removeAllData: () => Promise; on: (key: string, callback: () => void) => WhatIsThis; removeAllConfiguration: () => Promise; }; // Protobufs type DeviceMessagesProtobufTypes = { ProvisioningUuid: typeof ProvisioningUuidClass; ProvisionEnvelope: typeof ProvisionEnvelopeClass; ProvisionMessage: typeof ProvisionMessageClass; }; type DeviceNameProtobufTypes = { DeviceName: typeof DeviceNameClass; }; type GroupsProtobufTypes = { AvatarUploadAttributes: typeof AvatarUploadAttributesClass; Member: typeof MemberClass; PendingMember: typeof PendingMemberClass; AccessControl: typeof AccessControlClass; Group: typeof GroupClass; GroupChange: typeof GroupChangeClass; GroupChanges: typeof GroupChangesClass; GroupAttributeBlob: typeof GroupAttributeBlobClass; GroupExternalCredential: typeof GroupExternalCredentialClass; }; type SignalServiceProtobufTypes = { AttachmentPointer: typeof AttachmentPointerClass; ContactDetails: typeof ContactDetailsClass; Content: typeof ContentClass; DataMessage: typeof DataMessageClass; Envelope: typeof EnvelopeClass; GroupContext: typeof GroupContextClass; GroupContextV2: typeof GroupContextV2Class; GroupDetails: typeof GroupDetailsClass; NullMessage: typeof NullMessageClass; ReceiptMessage: typeof ReceiptMessageClass; SyncMessage: typeof SyncMessageClass; TypingMessage: typeof TypingMessageClass; Verified: typeof VerifiedClass; }; type SignalStorageProtobufTypes = { AccountRecord: typeof AccountRecordClass; ContactRecord: typeof ContactRecordClass; GroupV1Record: typeof GroupV1RecordClass; GroupV2Record: typeof GroupV2RecordClass; ManifestRecord: typeof ManifestRecordClass; ReadOperation: typeof ReadOperationClass; StorageItem: typeof StorageItemClass; StorageItems: typeof StorageItemsClass; StorageManifest: typeof StorageManifestClass; StorageRecord: typeof StorageRecordClass; WriteOperation: typeof WriteOperationClass; }; type SubProtocolProtobufTypes = { WebSocketMessage: typeof WebSocketMessageClass; WebSocketRequestMessage: typeof WebSocketRequestMessageClass; WebSocketResponseMessage: typeof WebSocketResponseMessageClass; }; type ProtobufCollectionType = { onLoad: (callback: () => unknown) => void; } & DeviceMessagesProtobufTypes & DeviceNameProtobufTypes & GroupsProtobufTypes & SignalServiceProtobufTypes & SignalStorageProtobufTypes & SubProtocolProtobufTypes; // Note: there are a lot of places in the code that overwrite a field like this // with a type that the app can use. Being more rigorous with these // types would require code changes, out of scope for now. export type ProtoBinaryType = any; type ProtoBigNumberType = any; // Groups.proto export declare class AvatarUploadAttributesClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => AvatarUploadAttributesClass; key?: string; credential?: string; acl?: string; algorithm?: string; date?: string; policy?: string; signature?: string; } export declare class MemberClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => MemberClass; userId?: ProtoBinaryType; role?: MemberRoleEnum; profileKey?: ProtoBinaryType; presentation?: ProtoBinaryType; joinedAtVersion?: number; // Note: only role and presentation are required when creating a group } export type MemberRoleEnum = number; // Note: we need to use namespaces to express nested classes in Typescript export declare namespace MemberClass { class Role { static UNKNOWN: number; static DEFAULT: number; static ADMINISTRATOR: number; } } export declare class PendingMemberClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => PendingMemberClass; member?: MemberClass; addedByUserId?: ProtoBinaryType; timestamp?: ProtoBigNumberType; } export declare class AccessControlClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => AccessControlClass; attributes?: AccessRequiredEnum; members?: AccessRequiredEnum; } export type AccessRequiredEnum = number; // Note: we need to use namespaces to express nested classes in Typescript export declare namespace AccessControlClass { class AccessRequired { static ANY: number; static UNKNOWN: number; static MEMBER: number; static ADMINISTRATOR: number; } } export declare class GroupClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => GroupClass; toArrayBuffer: () => ArrayBuffer; publicKey?: ProtoBinaryType; title?: ProtoBinaryType; avatar?: string; disappearingMessagesTimer?: ProtoBinaryType; accessControl?: AccessControlClass; version?: number; members?: Array; pendingMembers?: Array; } export declare class GroupChangeClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => GroupChangeClass; toArrayBuffer: () => ArrayBuffer; actions?: ProtoBinaryType; serverSignature?: ProtoBinaryType; changeEpoch?: number; } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace GroupChangeClass { class Actions { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => Actions; toArrayBuffer: () => ArrayBuffer; sourceUuid?: ProtoBinaryType; version?: number; addMembers?: Array; deleteMembers?: Array; modifyMemberRoles?: Array; modifyMemberProfileKeys?: Array< GroupChangeClass.Actions.ModifyMemberProfileKeyAction >; addPendingMembers?: Array; deletePendingMembers?: Array< GroupChangeClass.Actions.DeletePendingMemberAction >; promotePendingMembers?: Array< GroupChangeClass.Actions.PromotePendingMemberAction >; modifyTitle?: GroupChangeClass.Actions.ModifyTitleAction; modifyAvatar?: GroupChangeClass.Actions.ModifyAvatarAction; modifyDisappearingMessagesTimer?: GroupChangeClass.Actions.ModifyDisappearingMessagesTimerAction; modifyAttributesAccess?: GroupChangeClass.Actions.ModifyAttributesAccessControlAction; modifyMemberAccess?: GroupChangeClass.Actions.ModifyMembersAccessControlAction; } } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace GroupChangeClass.Actions { class AddMemberAction { added?: MemberClass; } class DeleteMemberAction { deletedUserId?: ProtoBinaryType; } class ModifyMemberRoleAction { userId?: ProtoBinaryType; role?: MemberRoleEnum; } class ModifyMemberProfileKeyAction { presentation?: ProtoBinaryType; // The result of decryption profileKey: ArrayBuffer; uuid: string; } class AddPendingMemberAction { added?: PendingMemberClass; } class DeletePendingMemberAction { deletedUserId?: ProtoBinaryType; } class PromotePendingMemberAction { presentation?: ProtoBinaryType; // The result of decryption profileKey: ArrayBuffer; uuid: string; } class ModifyTitleAction { title?: ProtoBinaryType; } class ModifyAvatarAction { avatar?: string; } class ModifyDisappearingMessagesTimerAction { timer?: ProtoBinaryType; } class ModifyAttributesAccessControlAction { attributesAccess?: AccessRequiredEnum; } class ModifyMembersAccessControlAction { membersAccess?: AccessRequiredEnum; } } export declare class GroupChangesClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => GroupChangesClass; groupChanges?: Array; } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace GroupChangesClass { class GroupChangeState { groupChange?: GroupChangeClass; groupState?: GroupClass; } } export declare class GroupExternalCredentialClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => GroupExternalCredentialClass; token?: string; } export declare class GroupAttributeBlobClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => GroupAttributeBlobClass; toArrayBuffer(): ArrayBuffer; title?: string; avatar?: ProtoBinaryType; disappearingMessagesDuration?: number; // Note: this isn't part of the proto, but our protobuf library tells us which // field has been set with this prop. content: 'title' | 'avatar' | 'disappearingMessagesDuration'; } // Previous protos export declare class AttachmentPointerClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => AttachmentPointerClass; static Flags: { VOICE_MESSAGE: number; }; cdnId?: ProtoBigNumberType; cdnKey?: string; contentType?: string; key?: ProtoBinaryType; size?: number; thumbnail?: ProtoBinaryType; digest?: ProtoBinaryType; fileName?: string; flags?: number; width?: number; height?: number; caption?: string; blurHash?: string; uploadTimestamp?: ProtoBigNumberType; cdnNumber?: number; } export type DownloadAttachmentType = { data: ArrayBuffer; cdnId?: ProtoBigNumberType; cdnKey?: string; contentType?: string; size?: number; thumbnail?: ProtoBinaryType; fileName?: string; flags?: number; width?: number; height?: number; caption?: string; blurHash?: string; uploadTimestamp?: ProtoBigNumberType; cdnNumber?: number; }; export declare class ContactDetailsClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => ContactDetailsClass; number?: string; uuid?: string; name?: string; avatar?: ContactDetailsClass.Avatar; color?: string; verified?: VerifiedClass; profileKey?: ProtoBinaryType; blocked?: boolean; expireTimer?: number; inboxPosition?: number; } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace ContactDetailsClass { class Avatar { contentType?: string; length?: number; } } export declare class ContentClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => ContentClass; toArrayBuffer: () => ArrayBuffer; dataMessage?: DataMessageClass; syncMessage?: SyncMessageClass; callingMessage?: CallingMessageClass; nullMessage?: NullMessageClass; receiptMessage?: ReceiptMessageClass; typingMessage?: TypingMessageClass; } export declare class DataMessageClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => DataMessageClass; toArrayBuffer(): ArrayBuffer; body?: string | null; attachments?: Array; group?: GroupContextClass | null; groupV2?: GroupContextV2Class | null; flags?: number; expireTimer?: number; profileKey?: ProtoBinaryType; timestamp?: ProtoBigNumberType; quote?: DataMessageClass.Quote; contact?: Array; preview?: Array; sticker?: DataMessageClass.Sticker; requiredProtocolVersion?: number; isViewOnce?: boolean; reaction?: DataMessageClass.Reaction; delete?: DataMessageClass.Delete; bodyRanges?: Array; groupCallUpdate?: DataMessageClass.GroupCallUpdate; } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace DataMessageClass { // Note: deep nesting class Contact { name: any; number: any; email: any; address: any; avatar: any; organization?: string; } class Flags { static END_SESSION: number; static EXPIRATION_TIMER_UPDATE: number; static PROFILE_KEY_UPDATE: number; } class Preview { url?: string; title?: string; image?: AttachmentPointerClass; description?: string; date?: ProtoBigNumberType; } class ProtocolVersion { static INITIAL: number; static MESSAGE_TIMERS: number; static VIEW_ONCE: number; static VIEW_ONCE_VIDEO: number; static REACTIONS: number; static MENTIONS: number; static CURRENT: number; } // Note: deep nesting class Quote { id: ProtoBigNumberType | null; author: string | null; authorUuid: string | null; text: string | null; attachments?: Array; bodyRanges?: Array; } class BodyRange { start?: number; length?: number; mentionUuid?: string; } class Reaction { emoji: string | null; remove: boolean; targetAuthorE164: string | null; targetAuthorUuid: string | null; targetTimestamp: ProtoBigNumberType | null; } class Delete { targetSentTimestamp?: ProtoBigNumberType; } class Sticker { packId?: ProtoBinaryType; packKey?: ProtoBinaryType; stickerId?: number; data?: AttachmentPointerClass; } class GroupCallUpdate { eraId?: string; } } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace DataMessageClass.Quote { class QuotedAttachment { contentType?: string; fileName?: string; thumbnail?: AttachmentPointerClass; } } declare class DeviceNameClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => DeviceNameClass; encode: () => DeviceNameClass; toArrayBuffer: () => ArrayBuffer; ephemeralPublic: ProtoBinaryType; syntheticIv: ProtoBinaryType; ciphertext: ProtoBinaryType; } export declare class EnvelopeClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => EnvelopeClass; type?: number; source?: string; sourceUuid?: string; sourceDevice?: number; relay?: string; timestamp?: ProtoBigNumberType; legacyMessage?: ProtoBinaryType; content?: ProtoBinaryType; serverGuid?: string; serverTimestamp?: ProtoBigNumberType; // Note: these additional properties are added in the course of processing id: string; unidentifiedDeliveryReceived?: boolean; messageAgeSec?: number; } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace EnvelopeClass { class Type { static CIPHERTEXT: number; static PREKEY_BUNDLE: number; static RECEIPT: number; static UNIDENTIFIED_SENDER: number; } } export declare class GroupContextClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => GroupContextClass; id?: ProtoBinaryType; type?: number; name?: string | null; membersE164?: Array; avatar?: AttachmentPointerClass | null; // Note: these additional properties are added in the course of processing derivedGroupV2Id?: string; } export declare class GroupContextV2Class { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => GroupContextV2Class; masterKey?: ProtoBinaryType; revision?: number; groupChange?: ProtoBinaryType; // Note: these additional properties are added in the course of processing id?: string; secretParams?: string; publicParams?: string; } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace GroupContextClass { class Member { uuid?: string; e164?: string; } class Type { static UNKNOWN: number; static UPDATE: number; static DELIVER: number; static QUIT: number; static REQUEST_INFO: number; } } export declare class GroupDetailsClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => GroupDetailsClass; id?: ProtoBinaryType; name?: string; membersE164?: Array; members?: Array; avatar?: GroupDetailsClass.Avatar; active?: boolean; expireTimer?: number; color?: string; blocked?: boolean; inboxPosition?: number; } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace GroupDetailsClass { class Avatar { contentType?: string; length?: string; } class Member { uuid?: string; e164?: string; } } declare enum ManifestType { UNKNOWN, CONTACT, GROUPV1, GROUPV2, ACCOUNT, } export declare class ManifestRecordIdentifierClass { static Type: typeof ManifestType; raw: ProtoBinaryType; type: ManifestType; toArrayBuffer: () => ArrayBuffer; } export declare class ManifestRecordClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => ManifestRecordClass; toArrayBuffer: () => ArrayBuffer; static Identifier: typeof ManifestRecordIdentifierClass; version: ProtoBigNumberType; keys: ManifestRecordIdentifierClass[]; } export declare class NullMessageClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => NullMessageClass; padding?: ProtoBinaryType; } declare class ProvisioningUuidClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => ProvisioningUuidClass; encode: () => ProvisioningUuidClass; toArrayBuffer: () => ArrayBuffer; uuid?: string; } export declare class ProvisionEnvelopeClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => ProvisionEnvelopeClass; encode: () => ProvisionEnvelopeClass; toArrayBuffer: () => ArrayBuffer; publicKey?: ProtoBinaryType; body?: ProtoBinaryType; } declare class ProvisionMessageClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => ProvisionMessageClass; encode: () => ProvisionMessageClass; toArrayBuffer: () => ArrayBuffer; identityKeyPrivate?: ProtoBinaryType; number?: string; uuid?: string; provisioningCode?: string; userAgent?: string; profileKey?: ProtoBinaryType; readReceipts?: boolean; ProvisioningVersion?: number; } export declare class ReceiptMessageClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => ReceiptMessageClass; type?: number; timestamp?: ProtoBigNumberType; } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace ReceiptMessageClass { class Type { static DELIVERY: number; static READ: number; } } // Storage Service related types export declare class StorageManifestClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => StorageManifestClass; version?: ProtoBigNumberType | null; value?: ProtoBinaryType; } export declare class StorageRecordClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => StorageRecordClass; toArrayBuffer: () => ArrayBuffer; contact?: ContactRecordClass | null; groupV1?: GroupV1RecordClass | null; groupV2?: GroupV2RecordClass | null; account?: AccountRecordClass | null; } export declare class StorageItemClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => StorageItemClass; key?: ProtoBinaryType; value?: ProtoBinaryType; } export declare class StorageItemsClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => StorageItemsClass; items?: StorageItemClass[] | null; } export declare enum ContactRecordIdentityState { DEFAULT = 0, VERIFIED = 1, UNVERIFIED = 2, } export declare class ContactRecordClass { static IdentityState: typeof ContactRecordIdentityState; static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => ContactRecordClass; toArrayBuffer: () => ArrayBuffer; serviceUuid?: string | null; serviceE164?: string | null; profileKey?: ProtoBinaryType; identityKey?: ProtoBinaryType; identityState?: ContactRecordIdentityState | null; givenName?: string | null; familyName?: string | null; username?: string | null; blocked?: boolean | null; whitelisted?: boolean | null; archived?: boolean | null; markedUnread?: boolean; __unknownFields?: ArrayBuffer; } export declare class GroupV1RecordClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => GroupV1RecordClass; toArrayBuffer: () => ArrayBuffer; id?: ProtoBinaryType; blocked?: boolean | null; whitelisted?: boolean | null; archived?: boolean | null; markedUnread?: boolean; __unknownFields?: ArrayBuffer; } export declare class GroupV2RecordClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => GroupV2RecordClass; toArrayBuffer: () => ArrayBuffer; masterKey?: ProtoBinaryType | null; blocked?: boolean | null; whitelisted?: boolean | null; archived?: boolean | null; markedUnread?: boolean; __unknownFields?: ArrayBuffer; } export declare class PinnedConversationClass { toArrayBuffer: () => ArrayBuffer; // identifier is produced by the oneof field in the PinnedConversation protobuf // and determined which one of the following optional fields are in use identifier: 'contact' | 'legacyGroupId' | 'groupMasterKey'; contact?: { uuid?: string; e164?: string; }; legacyGroupId?: ProtoBinaryType; groupMasterKey?: ProtoBinaryType; } export declare class AccountRecordClass { static PinnedConversation: typeof PinnedConversationClass; static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => AccountRecordClass; toArrayBuffer: () => ArrayBuffer; profileKey?: ProtoBinaryType; givenName?: string | null; familyName?: string | null; avatarUrl?: string | null; noteToSelfArchived?: boolean | null; readReceipts?: boolean | null; sealedSenderIndicators?: boolean | null; typingIndicators?: boolean | null; linkPreviews?: boolean | null; pinnedConversations?: PinnedConversationClass[]; noteToSelfMarkedUnread?: boolean; __unknownFields?: ArrayBuffer; } declare class ReadOperationClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => ReadOperationClass; readKey: ArrayBuffer[] | ByteBufferClass[]; toArrayBuffer: () => ArrayBuffer; } declare class WriteOperationClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => WriteOperationClass; toArrayBuffer: () => ArrayBuffer; manifest: StorageManifestClass; insertItem: StorageItemClass[]; deleteKey: ArrayBuffer[] | ByteBufferClass[]; clearAll: boolean; } export declare class SyncMessageClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => SyncMessageClass; sent?: SyncMessageClass.Sent; contacts?: SyncMessageClass.Contacts; groups?: SyncMessageClass.Groups; request?: SyncMessageClass.Request; read?: Array; blocked?: SyncMessageClass.Blocked; verified?: VerifiedClass; configuration?: SyncMessageClass.Configuration; padding?: ProtoBinaryType; stickerPackOperation?: Array; viewOnceOpen?: SyncMessageClass.ViewOnceOpen; messageRequestResponse?: SyncMessageClass.MessageRequestResponse; fetchLatest?: SyncMessageClass.FetchLatest; keys?: SyncMessageClass.Keys; } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace SyncMessageClass { class Configuration { readReceipts?: boolean; unidentifiedDeliveryIndicators?: boolean; typingIndicators?: boolean; linkPreviews?: boolean; provisioningVersion?: number; } class Contacts { blob?: AttachmentPointerClass; complete?: boolean; } class Groups { blob?: AttachmentPointerClass; } class Blocked { numbers?: Array; uuids?: Array; groupIds?: Array; } class Read { sender?: string; senderUuid?: string; timestamp?: ProtoBigNumberType; } class Request { type?: number; } class Sent { destination?: string; destinationUuid?: string; timestamp?: ProtoBigNumberType; message?: DataMessageClass; expirationStartTimestamp?: ProtoBigNumberType; unidentifiedStatus?: Array< SyncMessageClass.Sent.UnidentifiedDeliveryStatus >; isRecipientUpdate?: boolean; } class StickerPackOperation { packId?: ProtoBinaryType; packKey?: ProtoBinaryType; type?: number; } class ViewOnceOpen { sender?: string; senderUuid?: string; timestamp?: ProtoBinaryType; } class FetchLatest { static Type: { UNKNOWN: number; LOCAL_PROFILE: number; STORAGE_MANIFEST: number; }; type?: number; } class Keys { storageService?: ByteBufferClass; } class MessageRequestResponse { threadE164: string | null; threadUuid: string | null; groupId: ProtoBinaryType | null; type: number | null; } } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace SyncMessageClass.Request { class Type { static UNKNOWN: number; static BLOCKED: number; static CONFIGURATION: number; static CONTACTS: number; static GROUPS: number; static KEYS: number; } } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace SyncMessageClass.Sent { class UnidentifiedDeliveryStatus { destination?: string; destinationUuid?: string; unidentified?: boolean; } } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace SyncMessageClass.StickerPackOperation { class Type { static INSTALL: number; static REMOVE: number; } } export declare namespace SyncMessageClass.MessageRequestResponse { class Type { static UNKNOWN: number; static ACCEPT: number; static DELETE: number; static BLOCK: number; static BLOCK_AND_DELETE: number; } } export declare class TypingMessageClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => TypingMessageClass; timestamp?: ProtoBigNumberType; action?: number; groupId?: ProtoBinaryType; } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace TypingMessageClass { class Action { static STARTED: number; static STOPPED: number; } } export declare class VerifiedClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => VerifiedClass; static State: WhatIsThis; destination?: string; destinationUuid?: string; identityKey?: ProtoBinaryType; state?: number; nullMessage?: ProtoBinaryType; } export declare class WebSocketMessageClass { constructor(data: any); encode: () => WebSocketMessageClass; toArrayBuffer: () => ArrayBuffer; static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => WebSocketMessageClass; type?: number; request?: WebSocketRequestMessageClass; response?: WebSocketResponseMessageClass; } // Note: we need to use namespaces to express nested classes in Typescript export declare namespace WebSocketMessageClass { class Type { static UNKNOWN: number; static REQUEST: number; static RESPONSE: number; } } export declare class WebSocketRequestMessageClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => WebSocketRequestMessageClass; verb?: string; path?: string; body?: ProtoBinaryType; headers?: Array; id?: ProtoBigNumberType; } export declare class WebSocketResponseMessageClass { static decode: ( data: ArrayBuffer | ByteBufferClass, encoding?: string ) => WebSocketResponseMessageClass; id?: ProtoBigNumberType; status?: number; message?: string; headers?: Array; body?: ProtoBinaryType; } export { CallingMessageClass };