mirror of https://github.com/oxen-io/session-ios
				
				
				
			
			You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			90 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Objective-C
		
	
			
		
		
	
	
			90 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Objective-C
		
	
| //
 | |
| //  Copyright (c) 2019 Open Whisper Systems. All rights reserved.
 | |
| //
 | |
| 
 | |
| #import <SignalUtilitiesKit/OWSReadTracking.h>
 | |
| #import <SignalUtilitiesKit/TSMessage.h>
 | |
| 
 | |
| NS_ASSUME_NONNULL_BEGIN
 | |
| 
 | |
| @class TSContactThread;
 | |
| @class TSGroupThread;
 | |
| 
 | |
| @interface TSIncomingMessage : TSMessage <OWSReadTracking>
 | |
| 
 | |
| @property (nonatomic, readonly, nullable) NSNumber *serverTimestamp;
 | |
| 
 | |
| @property (nonatomic, readonly) BOOL wasReceivedByUD;
 | |
| 
 | |
| - (instancetype)initMessageWithTimestamp:(uint64_t)timestamp
 | |
|                                 inThread:(nullable TSThread *)thread
 | |
|                              messageBody:(nullable NSString *)body
 | |
|                            attachmentIds:(NSArray<NSString *> *)attachmentIds
 | |
|                         expiresInSeconds:(uint32_t)expiresInSeconds
 | |
|                          expireStartedAt:(uint64_t)expireStartedAt
 | |
|                            quotedMessage:(nullable TSQuotedMessage *)quotedMessage
 | |
|                             contactShare:(nullable OWSContact *)contactShare
 | |
|                              linkPreview:(nullable OWSLinkPreview *)linkPreview NS_UNAVAILABLE;
 | |
| 
 | |
| /**
 | |
|  *  Inits an incoming group message that expires.
 | |
|  *
 | |
|  *  @param timestamp
 | |
|  *    When the message was created in milliseconds since epoch
 | |
|  *  @param thread
 | |
|  *    Thread to which the message belongs
 | |
|  *  @param authorId
 | |
|  *    Signal ID (i.e. e164) of the user who sent the message
 | |
|  *  @param sourceDeviceId
 | |
|  *    Numeric ID of the device used to send the message. Used to detect duplicate messages.
 | |
|  *  @param body
 | |
|  *    Body of the message
 | |
|  *  @param attachmentIds
 | |
|  *    The uniqueIds for the message's attachments, possibly an empty list.
 | |
|  *  @param expiresInSeconds
 | |
|  *    Seconds from when the message is read until it is deleted.
 | |
|  *  @param quotedMessage
 | |
|  *    If this message is a quoted reply to another message, contains data about that message.
 | |
|  *
 | |
|  *  @return initiated incoming group message
 | |
|  */
 | |
| - (instancetype)initWithTimestamp:(uint64_t)timestamp
 | |
|                          inThread:(TSThread *)thread
 | |
|                          authorId:(NSString *)authorId
 | |
|                    sourceDeviceId:(uint32_t)sourceDeviceId
 | |
|                       messageBody:(nullable NSString *)body
 | |
|                     attachmentIds:(NSArray<NSString *> *)attachmentIds
 | |
|                  expiresInSeconds:(uint32_t)expiresInSeconds
 | |
|                     quotedMessage:(nullable TSQuotedMessage *)quotedMessage
 | |
|                       linkPreview:(nullable OWSLinkPreview *)linkPreview
 | |
|                   serverTimestamp:(nullable NSNumber *)serverTimestamp
 | |
|                   wasReceivedByUD:(BOOL)wasReceivedByUD NS_DESIGNATED_INITIALIZER;
 | |
| 
 | |
| - (instancetype)initWithCoder:(NSCoder *)coder NS_DESIGNATED_INITIALIZER;
 | |
| 
 | |
| /*
 | |
|  * Find a message matching the senderId and timestamp, if any.
 | |
|  *
 | |
|  * @param authorId
 | |
|  *   Signal ID (i.e. e164) of the user who sent the message
 | |
|  * @params timestamp
 | |
|  *   When the message was created in milliseconds since epoch
 | |
|  *
 | |
|  */
 | |
| + (nullable instancetype)findMessageWithAuthorId:(NSString *)authorId
 | |
|                                        timestamp:(uint64_t)timestamp
 | |
|                                      transaction:(YapDatabaseReadWriteTransaction *)transaction;
 | |
| 
 | |
| // This will be 0 for messages created before we were tracking sourceDeviceId
 | |
| @property (nonatomic, readonly) UInt32 sourceDeviceId;
 | |
| 
 | |
| @property (nonatomic, readonly) NSString *authorId;
 | |
| 
 | |
| // convenience method for expiring a message which was just read
 | |
| - (void)markAsReadNowWithSendReadReceipt:(BOOL)sendReadReceipt
 | |
|                              transaction:(YapDatabaseReadWriteTransaction *)transaction;
 | |
| 
 | |
| @end
 | |
| 
 | |
| NS_ASSUME_NONNULL_END
 |