mirror of
https://github.com/oxen-io/session-ios.git
synced 2023-12-13 21:30:14 +01:00
108 lines
3.8 KiB
Objective-C
108 lines
3.8 KiB
Objective-C
//
|
|
// Copyright (c) 2018 Open Whisper Systems. All rights reserved.
|
|
//
|
|
|
|
#import <Mantle/MTLModel.h>
|
|
#import <SignalUtilitiesKit/TSYapDatabaseObject.h>
|
|
|
|
NS_ASSUME_NONNULL_BEGIN
|
|
|
|
@class SSKProtoDataMessage;
|
|
@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;
|
|
|
|
|
|
+ (nullable instancetype)quotedMessageForDataMessage:(SSKProtoDataMessage *)dataMessage
|
|
thread:(TSThread *)thread
|
|
transaction:(YapDatabaseReadWriteTransaction *)transaction;
|
|
|
|
@end
|
|
|
|
#pragma mark -
|
|
|
|
NS_ASSUME_NONNULL_END
|