mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-06-16 05:55:20 +00:00
168 lines
10 KiB
Swift
168 lines
10 KiB
Swift
import Foundation
|
|
#if os(macOS)
|
|
import PostboxMac
|
|
import SwiftSignalKitMac
|
|
import TelegramApiMac
|
|
#else
|
|
import Postbox
|
|
import TelegramApi
|
|
import SwiftSignalKit
|
|
#endif
|
|
|
|
import SyncCore
|
|
|
|
public func markMessageContentAsConsumedInteractively(postbox: Postbox, messageId: MessageId) -> Signal<Void, NoError> {
|
|
return postbox.transaction { transaction -> Void in
|
|
if let message = transaction.getMessage(messageId), message.flags.contains(.Incoming) {
|
|
var updateMessage = false
|
|
var updatedAttributes = message.attributes
|
|
|
|
for i in 0 ..< updatedAttributes.count {
|
|
if let attribute = updatedAttributes[i] as? ConsumableContentMessageAttribute {
|
|
if !attribute.consumed {
|
|
updatedAttributes[i] = ConsumableContentMessageAttribute(consumed: true)
|
|
updateMessage = true
|
|
|
|
if message.id.peerId.namespace == Namespaces.Peer.SecretChat {
|
|
if let state = transaction.getPeerChatState(message.id.peerId) as? SecretChatState {
|
|
var layer: SecretChatLayer?
|
|
switch state.embeddedState {
|
|
case .terminated, .handshake:
|
|
break
|
|
case .basicLayer:
|
|
layer = .layer8
|
|
case let .sequenceBasedLayer(sequenceState):
|
|
layer = sequenceState.layerNegotiationState.activeLayer.secretChatLayer
|
|
}
|
|
if let layer = layer {
|
|
var globallyUniqueIds: [Int64] = []
|
|
if let globallyUniqueId = message.globallyUniqueId {
|
|
globallyUniqueIds.append(globallyUniqueId)
|
|
let updatedState = addSecretChatOutgoingOperation(transaction: transaction, peerId: message.id.peerId, operation: SecretChatOutgoingOperationContents.readMessagesContent(layer: layer, actionGloballyUniqueId: arc4random64(), globallyUniqueIds: globallyUniqueIds), state: state)
|
|
if updatedState != state {
|
|
transaction.setPeerChatState(message.id.peerId, state: updatedState)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
} else {
|
|
addSynchronizeConsumeMessageContentsOperation(transaction: transaction, messageIds: [message.id])
|
|
}
|
|
}
|
|
} else if let attribute = updatedAttributes[i] as? ConsumablePersonalMentionMessageAttribute, !attribute.consumed {
|
|
transaction.setPendingMessageAction(type: .consumeUnseenPersonalMessage, id: messageId, action: ConsumePersonalMessageAction())
|
|
updatedAttributes[i] = ConsumablePersonalMentionMessageAttribute(consumed: attribute.consumed, pending: true)
|
|
}
|
|
}
|
|
|
|
let timestamp = Int32(CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970)
|
|
for i in 0 ..< updatedAttributes.count {
|
|
if let attribute = updatedAttributes[i] as? AutoremoveTimeoutMessageAttribute {
|
|
if attribute.countdownBeginTime == nil || attribute.countdownBeginTime == 0 {
|
|
var timeout = attribute.timeout
|
|
if let duration = message.secretMediaDuration {
|
|
timeout = max(timeout, duration)
|
|
}
|
|
updatedAttributes[i] = AutoremoveTimeoutMessageAttribute(timeout: timeout, countdownBeginTime: timestamp)
|
|
updateMessage = true
|
|
|
|
transaction.addTimestampBasedMessageAttribute(tag: 0, timestamp: timestamp + timeout, messageId: messageId)
|
|
|
|
if messageId.peerId.namespace == Namespaces.Peer.SecretChat {
|
|
var layer: SecretChatLayer?
|
|
let state = transaction.getPeerChatState(message.id.peerId) as? SecretChatState
|
|
if let state = state {
|
|
switch state.embeddedState {
|
|
case .terminated, .handshake:
|
|
break
|
|
case .basicLayer:
|
|
layer = .layer8
|
|
case let .sequenceBasedLayer(sequenceState):
|
|
layer = sequenceState.layerNegotiationState.activeLayer.secretChatLayer
|
|
}
|
|
}
|
|
|
|
if let state = state, let layer = layer, let globallyUniqueId = message.globallyUniqueId {
|
|
let updatedState = addSecretChatOutgoingOperation(transaction: transaction, peerId: messageId.peerId, operation: .readMessagesContent(layer: layer, actionGloballyUniqueId: arc4random64(), globallyUniqueIds: [globallyUniqueId]), state: state)
|
|
if updatedState != state {
|
|
transaction.setPeerChatState(messageId.peerId, state: updatedState)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
break
|
|
}
|
|
}
|
|
|
|
if updateMessage {
|
|
transaction.updateMessage(message.id, update: { currentMessage in
|
|
var storeForwardInfo: StoreMessageForwardInfo?
|
|
if let forwardInfo = currentMessage.forwardInfo {
|
|
storeForwardInfo = StoreMessageForwardInfo(authorId: forwardInfo.author?.id, sourceId: forwardInfo.source?.id, sourceMessageId: forwardInfo.sourceMessageId, date: forwardInfo.date, authorSignature: forwardInfo.authorSignature)
|
|
}
|
|
return .update(StoreMessage(id: currentMessage.id, globallyUniqueId: currentMessage.globallyUniqueId, groupingKey: currentMessage.groupingKey, timestamp: currentMessage.timestamp, flags: StoreMessageFlags(currentMessage.flags), tags: currentMessage.tags, globalTags: currentMessage.globalTags, localTags: currentMessage.localTags, forwardInfo: storeForwardInfo, authorId: currentMessage.author?.id, text: currentMessage.text, attributes: updatedAttributes, media: currentMessage.media))
|
|
})
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func markMessageContentAsConsumedRemotely(transaction: Transaction, messageId: MessageId) {
|
|
if let message = transaction.getMessage(messageId) {
|
|
var updateMessage = false
|
|
var updatedAttributes = message.attributes
|
|
var updatedMedia = message.media
|
|
var updatedTags = message.tags
|
|
|
|
for i in 0 ..< updatedAttributes.count {
|
|
if let attribute = updatedAttributes[i] as? ConsumableContentMessageAttribute {
|
|
if !attribute.consumed {
|
|
updatedAttributes[i] = ConsumableContentMessageAttribute(consumed: true)
|
|
updateMessage = true
|
|
}
|
|
} else if let attribute = updatedAttributes[i] as? ConsumablePersonalMentionMessageAttribute, !attribute.consumed {
|
|
if attribute.pending {
|
|
transaction.setPendingMessageAction(type: .consumeUnseenPersonalMessage, id: messageId, action: nil)
|
|
}
|
|
updatedAttributes[i] = ConsumablePersonalMentionMessageAttribute(consumed: true, pending: false)
|
|
updatedTags.remove(.unseenPersonalMessage)
|
|
updateMessage = true
|
|
}
|
|
}
|
|
|
|
let timestamp = Int32(CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970)
|
|
for i in 0 ..< updatedAttributes.count {
|
|
if let attribute = updatedAttributes[i] as? AutoremoveTimeoutMessageAttribute {
|
|
if (attribute.countdownBeginTime == nil || attribute.countdownBeginTime == 0) && message.containsSecretMedia {
|
|
updatedAttributes[i] = AutoremoveTimeoutMessageAttribute(timeout: attribute.timeout, countdownBeginTime: timestamp)
|
|
updateMessage = true
|
|
|
|
if message.id.peerId.namespace == Namespaces.Peer.SecretChat {
|
|
transaction.addTimestampBasedMessageAttribute(tag: 0, timestamp: timestamp + attribute.timeout, messageId: messageId)
|
|
} else {
|
|
for i in 0 ..< updatedMedia.count {
|
|
if let _ = updatedMedia[i] as? TelegramMediaImage {
|
|
updatedMedia[i] = TelegramMediaExpiredContent(data: .image)
|
|
} else if let _ = updatedMedia[i] as? TelegramMediaFile {
|
|
updatedMedia[i] = TelegramMediaExpiredContent(data: .file)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
break
|
|
}
|
|
}
|
|
|
|
if updateMessage {
|
|
transaction.updateMessage(message.id, update: { currentMessage in
|
|
var storeForwardInfo: StoreMessageForwardInfo?
|
|
if let forwardInfo = currentMessage.forwardInfo {
|
|
storeForwardInfo = StoreMessageForwardInfo(authorId: forwardInfo.author?.id, sourceId: forwardInfo.source?.id, sourceMessageId: forwardInfo.sourceMessageId, date: forwardInfo.date, authorSignature: forwardInfo.authorSignature)
|
|
}
|
|
return .update(StoreMessage(id: currentMessage.id, globallyUniqueId: currentMessage.globallyUniqueId, groupingKey: currentMessage.groupingKey, timestamp: currentMessage.timestamp, flags: StoreMessageFlags(currentMessage.flags), tags: updatedTags, globalTags: currentMessage.globalTags, localTags: currentMessage.localTags, forwardInfo: storeForwardInfo, authorId: currentMessage.author?.id, text: currentMessage.text, attributes: updatedAttributes, media: updatedMedia))
|
|
})
|
|
}
|
|
}
|
|
}
|
|
|