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
		
	
	
	
		
			C
		
	
		
		
			
		
	
	
			90 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C
		
	
| 
											5 years ago
										 | //
 | ||
|  | //  Copyright (c) 2019 Open Whisper Systems. All rights reserved.
 | ||
|  | //
 | ||
|  | 
 | ||
| 
											5 years ago
										 | #import <SessionMessagingKit/OWSReadTracking.h>
 | ||
|  | #import <SessionMessagingKit/TSMessage.h>
 | ||
| 
											5 years ago
										 | 
 | ||
|  | 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 | ||
|  |  */ | ||
| 
											5 years ago
										 | - (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; | ||
| 
											5 years ago
										 | 
 | ||
|  | - (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 |