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.
		
		
		
		
		
			
		
			
	
	
		
			109 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
		
		
			
		
	
	
			109 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
| 
								 
											5 years ago
										 
									 | 
							
								//
							 | 
						||
| 
								 | 
							
								//  Copyright (c) 2018 Open Whisper Systems. All rights reserved.
							 | 
						||
| 
								 | 
							
								//
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#import <Mantle/MTLModel.h>
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								#import <SessionUtilitiesKit/TSYapDatabaseObject.h>
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								NS_ASSUME_NONNULL_BEGIN
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								@class SNProtoDataMessage;
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								@class TSAttachment;
							 | 
						||
| 
								 | 
							
								@class TSAttachmentStream;
							 | 
						||
| 
								 | 
							
								@class TSQuotedMessage;
							 | 
						||
| 
								 | 
							
								@class TSThread;
							 | 
						||
| 
								 | 
							
								@class YapDatabaseReadWriteTransaction;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								@interface OWSAttachmentInfo : MTLModel
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								@property (nonatomic, readonly, nullable) NSString *contentType;
							 | 
						||
| 
								 | 
							
								@property (nonatomic, readonly, nullable) NSString *sourceFilename;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// This is only set when sending a new attachment so we have a way
							 | 
						||
| 
								 | 
							
								// to reference the original attachment when generating a thumbnail.
							 | 
						||
| 
								 | 
							
								// We don't want to do this until the message is saved, when the user sends
							 | 
						||
| 
								 | 
							
								// the message so as not to end up with an orphaned file.
							 | 
						||
| 
								 | 
							
								@property (nonatomic, readonly, nullable) NSString *attachmentId;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// References a yet-to-be downloaded thumbnail file
							 | 
						||
| 
								 | 
							
								@property (atomic, nullable) NSString *thumbnailAttachmentPointerId;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// References an already downloaded or locally generated thumbnail file
							 | 
						||
| 
								 | 
							
								@property (atomic, nullable) NSString *thumbnailAttachmentStreamId;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								- (instancetype)init NS_UNAVAILABLE;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								- (instancetype)initWithAttachmentId:(nullable NSString *)attachmentId
							 | 
						||
| 
								 | 
							
								                         contentType:(NSString *)contentType
							 | 
						||
| 
								 | 
							
								                      sourceFilename:(NSString *)sourceFilename NS_DESIGNATED_INITIALIZER;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								- (instancetype)initWithAttachmentStream:(TSAttachmentStream *)attachmentStream;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								@end
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								typedef NS_ENUM(NSUInteger, TSQuotedMessageContentSource) {
							 | 
						||
| 
								 | 
							
								    TSQuotedMessageContentSourceUnknown,
							 | 
						||
| 
								 | 
							
								    TSQuotedMessageContentSourceLocal,
							 | 
						||
| 
								 | 
							
								    TSQuotedMessageContentSourceRemote
							 | 
						||
| 
								 | 
							
								};
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								@interface TSQuotedMessage : MTLModel
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								@property (nonatomic, readonly) uint64_t timestamp;
							 | 
						||
| 
								 | 
							
								@property (nonatomic, readonly) NSString *authorId;
							 | 
						||
| 
								 | 
							
								@property (nonatomic, readonly) TSQuotedMessageContentSource bodySource;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// This property should be set IFF we are quoting a text message
							 | 
						||
| 
								 | 
							
								// or attachment with caption.
							 | 
						||
| 
								 | 
							
								@property (nullable, nonatomic, readonly) NSString *body;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#pragma mark - Attachments
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// This is a MIME type.
							 | 
						||
| 
								 | 
							
								//
							 | 
						||
| 
								 | 
							
								// This property should be set IFF we are quoting an attachment message.
							 | 
						||
| 
								 | 
							
								- (nullable NSString *)contentType;
							 | 
						||
| 
								 | 
							
								- (nullable NSString *)sourceFilename;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// References a yet-to-be downloaded thumbnail file
							 | 
						||
| 
								 | 
							
								- (nullable NSString *)thumbnailAttachmentPointerId;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// References an already downloaded or locally generated thumbnail file
							 | 
						||
| 
								 | 
							
								- (nullable NSString *)thumbnailAttachmentStreamId;
							 | 
						||
| 
								 | 
							
								- (void)setThumbnailAttachmentStream:(TSAttachment *)thumbnailAttachmentStream;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// currently only used by orphan attachment cleaner
							 | 
						||
| 
								 | 
							
								- (NSArray<NSString *> *)thumbnailAttachmentStreamIds;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								@property (atomic, readonly) NSArray<OWSAttachmentInfo *> *quotedAttachments;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// Before sending, persist a thumbnail attachment derived from the quoted attachment
							 | 
						||
| 
								 | 
							
								- (NSArray<TSAttachmentStream *> *)createThumbnailAttachmentsIfNecessaryWithTransaction:
							 | 
						||
| 
								 | 
							
								    (YapDatabaseReadWriteTransaction *)transaction;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								- (instancetype)init NS_UNAVAILABLE;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// used when receiving quoted messages
							 | 
						||
| 
								 | 
							
								- (instancetype)initWithTimestamp:(uint64_t)timestamp
							 | 
						||
| 
								 | 
							
								                         authorId:(NSString *)authorId
							 | 
						||
| 
								 | 
							
								                             body:(NSString *_Nullable)body
							 | 
						||
| 
								 | 
							
								                       bodySource:(TSQuotedMessageContentSource)bodySource
							 | 
						||
| 
								 | 
							
								    receivedQuotedAttachmentInfos:(NSArray<OWSAttachmentInfo *> *)attachmentInfos;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// used when sending quoted messages
							 | 
						||
| 
								 | 
							
								- (instancetype)initWithTimestamp:(uint64_t)timestamp
							 | 
						||
| 
								 | 
							
								                         authorId:(NSString *)authorId
							 | 
						||
| 
								 | 
							
								                             body:(NSString *_Nullable)body
							 | 
						||
| 
								 | 
							
								      quotedAttachmentsForSending:(NSArray<TSAttachment *> *)attachments;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								+ (nullable instancetype)quotedMessageForDataMessage:(SNProtoDataMessage *)dataMessage
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								                                              thread:(TSThread *)thread
							 | 
						||
| 
								 | 
							
								                                         transaction:(YapDatabaseReadWriteTransaction *)transaction;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								@end
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#pragma mark -
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								NS_ASSUME_NONNULL_END
							 |