Initial barebone commit for messages refactor
							parent
							
								
									c7b76dfebb
								
							
						
					
					
						commit
						9bd08ba930
					
				| @ -0,0 +1,4 @@ | |||||||
|  | import * as Outgoing from './outgoing'; | ||||||
|  | 
 | ||||||
|  | // For Audric: Do you think we need to namespace?
 | ||||||
|  | export { Outgoing }; | ||||||
| @ -0,0 +1,25 @@ | |||||||
|  | import { OutgoingMessage } from './OutgoingMessage'; | ||||||
|  | import { AttachmentType } from '../../../types/Attachment'; | ||||||
|  | import { QuotedAttachmentType } from '../../../components/conversation/Quote'; | ||||||
|  | 
 | ||||||
|  | export class OpenGroupMessage implements OutgoingMessage { | ||||||
|  |   public timestamp: number; | ||||||
|  |   public server: string; | ||||||
|  |   public body?: string; | ||||||
|  |   public attachments: [AttachmentType]; // TODO: Not sure if we should only use a subset of this type
 | ||||||
|  |   public quote?: QuotedAttachmentType; | ||||||
|  | 
 | ||||||
|  |   constructor( | ||||||
|  |     timestamp: number, | ||||||
|  |     server: string, | ||||||
|  |     attachments: [AttachmentType], | ||||||
|  |     body?: string, | ||||||
|  |     quote?: QuotedAttachmentType | ||||||
|  |   ) { | ||||||
|  |     this.timestamp = timestamp; | ||||||
|  |     this.server = server; | ||||||
|  |     this.body = body; | ||||||
|  |     this.attachments = attachments; | ||||||
|  |     this.quote = quote; | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -0,0 +1,60 @@ | |||||||
|  | import { OutgoingMessage } from './OutgoingMessage'; | ||||||
|  | import { SignalService } from '../../../protobuf'; | ||||||
|  | 
 | ||||||
|  | export class OutgoingContentMessage implements OutgoingMessage { | ||||||
|  |   public timestamp: number; | ||||||
|  |   public identifier: string; | ||||||
|  |   public category: OutgoingContentMessage.MessageCategory; | ||||||
|  |   public ttl: number; | ||||||
|  |   constructor( | ||||||
|  |     timestamp: number, | ||||||
|  |     identifier: string, | ||||||
|  |     category: OutgoingContentMessage.MessageCategory, | ||||||
|  |     ttl: number | ||||||
|  |   ) { | ||||||
|  |     this.timestamp = timestamp; | ||||||
|  |     this.identifier = identifier; | ||||||
|  |     this.category = category; | ||||||
|  |     this.ttl = ttl; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   public plainTextBuffer(): Uint8Array { | ||||||
|  |     const encoded = SignalService.Content.encode(this.contentProto()).finish(); | ||||||
|  | 
 | ||||||
|  |     return this.processPlainTextBuffer(encoded); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   public contentProto(): SignalService.Content { | ||||||
|  |     throw new Error('contentProto() needs to be implemented.'); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   private processPlainTextBuffer(buffer: Uint8Array): Uint8Array { | ||||||
|  |     const paddedMessageLength = this.getPaddedMessageLength( | ||||||
|  |       buffer.byteLength + 1 | ||||||
|  |     ); | ||||||
|  |     const plainText = new Uint8Array(paddedMessageLength - 1); | ||||||
|  |     plainText.set(new Uint8Array(buffer)); | ||||||
|  |     plainText[buffer.byteLength] = 0x80; | ||||||
|  | 
 | ||||||
|  |     return plainText; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   private getPaddedMessageLength(length: number): number { | ||||||
|  |     const messageLengthWithTerminator = length + 1; | ||||||
|  |     let messagePartCount = Math.floor(messageLengthWithTerminator / 160); | ||||||
|  | 
 | ||||||
|  |     if (messageLengthWithTerminator % 160 !== 0) { | ||||||
|  |       messagePartCount += 1; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     return messagePartCount * 160; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | export namespace OutgoingContentMessage { | ||||||
|  |   export enum MessageCategory { | ||||||
|  |     Secure, | ||||||
|  |     SessionReset, | ||||||
|  |     MediumGroup, | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -0,0 +1,14 @@ | |||||||
|  | import { OutgoingContentMessage } from './OutgoingContentMessage'; | ||||||
|  | import { SignalService } from '../../../protobuf'; | ||||||
|  | 
 | ||||||
|  | export class OutgoingDataMessage extends OutgoingContentMessage { | ||||||
|  |   public contentProto(): SignalService.Content { | ||||||
|  |     return new SignalService.Content({ | ||||||
|  |       dataMessage: this.dataProto(), | ||||||
|  |     }); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   protected dataProto(): SignalService.DataMessage { | ||||||
|  |     throw new Error('dataProto() needs to be implemented.'); | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -0,0 +1,8 @@ | |||||||
|  | export interface OutgoingMessage { | ||||||
|  |   timestamp: number; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // Remove me once this is read
 | ||||||
|  | // Note for Audric, we don't have a `plainText()` function here because i realised that we use Uint8Arrays when encrypting
 | ||||||
|  | // It wouldn't make sense for this then to be `plainTextBuffer(): UInt8Array` as that's specific to OutgoingContentMessage.
 | ||||||
|  | // Thus i've left it out and moved it to outgoing content message
 | ||||||
| @ -0,0 +1,11 @@ | |||||||
|  | import { OutgoingMessage } from './OutgoingMessage'; | ||||||
|  | import { OutgoingContentMessage } from './OutgoingContentMessage'; | ||||||
|  | import { OutgoingDataMessage } from './OutgoingDataMessage'; | ||||||
|  | import { OpenGroupMessage } from './OpenGroupMessage'; | ||||||
|  | 
 | ||||||
|  | export { | ||||||
|  |   OutgoingMessage, | ||||||
|  |   OutgoingContentMessage, | ||||||
|  |   OutgoingDataMessage, | ||||||
|  |   OpenGroupMessage, | ||||||
|  | }; | ||||||
					Loading…
					
					
				
		Reference in New Issue