mirror of
https://github.com/oxen-io/session-ios.git
synced 2023-12-13 21:30:14 +01:00
32304ae5dd
Refactored the SignalApp class to Swift Fixed a horizontal alignment issue in the ConversationTitleView Fixed an issue where expiration timer update messages weren't migrated or rendering correctly Fixed an issue where expiring messages weren't migrated correctly Fixed an issue where closed groups which had been left were causing migration failures (due to data incorrectly being assumed to be required) Shifted the Legacy Attachment types into the 'SMKLegacy' namespace Moved all of the NSCoding logic for the TSMessage
91 lines
2.8 KiB
Swift
91 lines
2.8 KiB
Swift
// Copyright © 2022 Rangeproof Pty Ltd. All rights reserved.
|
|
|
|
import Foundation
|
|
import GRDB
|
|
import SessionUtilitiesKit
|
|
|
|
public final class UnsendRequest: ControlMessage {
|
|
private enum CodingKeys: String, CodingKey {
|
|
case timestamp
|
|
case author
|
|
}
|
|
|
|
public var timestamp: UInt64?
|
|
public var author: String?
|
|
|
|
public override var isSelfSendValid: Bool { true }
|
|
|
|
// MARK: - Validation
|
|
|
|
public override var isValid: Bool {
|
|
guard super.isValid else { return false }
|
|
|
|
return timestamp != nil && author != nil
|
|
}
|
|
|
|
// MARK: - Initialization
|
|
|
|
internal init(timestamp: UInt64, author: String) {
|
|
super.init()
|
|
|
|
self.timestamp = timestamp
|
|
self.author = author
|
|
}
|
|
|
|
// MARK: - Codable
|
|
|
|
required init(from decoder: Decoder) throws {
|
|
try super.init(from: decoder)
|
|
|
|
let container: KeyedDecodingContainer<CodingKeys> = try decoder.container(keyedBy: CodingKeys.self)
|
|
|
|
timestamp = try? container.decode(UInt64.self, forKey: .timestamp)
|
|
author = try? container.decode(String.self, forKey: .author)
|
|
}
|
|
|
|
public override func encode(to encoder: Encoder) throws {
|
|
try super.encode(to: encoder)
|
|
|
|
var container: KeyedEncodingContainer<CodingKeys> = encoder.container(keyedBy: CodingKeys.self)
|
|
|
|
try container.encodeIfPresent(timestamp, forKey: .timestamp)
|
|
try container.encodeIfPresent(author, forKey: .author)
|
|
}
|
|
|
|
// MARK: - Proto Conversion
|
|
|
|
public override class func fromProto(_ proto: SNProtoContent, sender: String) -> UnsendRequest? {
|
|
guard let unsendRequestProto = proto.unsendRequest else { return nil }
|
|
let timestamp = unsendRequestProto.timestamp
|
|
let author = unsendRequestProto.author
|
|
return UnsendRequest(timestamp: timestamp, author: author)
|
|
}
|
|
|
|
public override func toProto(_ db: Database) -> SNProtoContent? {
|
|
guard let timestamp = timestamp, let author = author else {
|
|
SNLog("Couldn't construct unsend request proto from: \(self).")
|
|
return nil
|
|
}
|
|
let unsendRequestProto = SNProtoUnsendRequest.builder(timestamp: timestamp, author: author)
|
|
let contentProto = SNProtoContent.builder()
|
|
do {
|
|
contentProto.setUnsendRequest(try unsendRequestProto.build())
|
|
return try contentProto.build()
|
|
} catch {
|
|
SNLog("Couldn't construct unsend request proto from: \(self).")
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// MARK: - Description
|
|
|
|
public var description: String {
|
|
"""
|
|
UnsendRequest(
|
|
timestamp: \(timestamp?.description ?? "null")
|
|
author: \(author?.description ?? "null")
|
|
)
|
|
"""
|
|
}
|
|
}
|