Sesame-iOS/Sesame/History/HistoryItem.swift

113 lines
3.1 KiB
Swift
Raw Normal View History

import Foundation
2023-12-12 17:33:42 +01:00
import SwiftData
2023-12-12 17:33:42 +01:00
@Model
final class HistoryItem {
2023-12-12 17:33:42 +01:00
let startDate: Date
2023-12-27 21:57:17 +01:00
let message: HistoryMessage
2023-12-12 17:33:42 +01:00
let route: TransmissionType
2023-12-12 17:33:42 +01:00
let finishDate: Date
2023-12-12 17:33:42 +01:00
init(message: Message, startDate: Date, route: TransmissionType, finishDate: Date) {
self.startDate = startDate
2023-12-27 21:57:17 +01:00
self.message = .init(
messageType: message.messageType,
clientChallenge: Int(message.clientChallenge),
serverChallenge: Int(message.serverChallenge),
result: message.result)
2023-12-12 17:33:42 +01:00
self.finishDate = finishDate
self.route = route
}
2023-12-12 17:33:42 +01:00
var roundTripTime: TimeInterval {
finishDate.timeIntervalSince(startDate)
}
2023-12-12 17:33:42 +01:00
var response: MessageResult {
message.result
}
}
2023-12-27 21:57:17 +01:00
struct HistoryMessage {
/// The type of message being sent.
let messageType: MessageType
/**
* The random nonce created by the remote
*
* This nonce is a random number created by the remote, different for each unlock request.
* It is set for all message types.
*/
let clientChallenge: Int
/**
* A random number to sign by the remote
*
* This nonce is set by the server after receiving an initial message.
* It is set for the message types `challenge`, `request`, and `response`.
*/
let serverChallenge: Int
/**
* The response status for the previous message.
*
* It is set only for messages from the server, e.g. the `challenge` and `response` message types.
* Must be set to `MessageAccepted` for other messages.
*/
let result: MessageResult
}
extension HistoryMessage: Encodable {
func encode(to encoder: Encoder) throws {
var container = encoder.unkeyedContainer()
try container.encode(messageType)
try container.encode(clientChallenge)
try container.encode(serverChallenge)
try container.encode(result)
}
}
extension HistoryMessage: Decodable {
init(from decoder: Decoder) throws {
var container = try decoder.unkeyedContainer()
self.messageType = try container.decode(MessageType.self)
self.clientChallenge = try container.decode(Int.self)
self.serverChallenge = try container.decode(Int.self)
self.result = try container.decode(MessageResult.self)
}
}
extension HistoryItem: Identifiable {
2023-12-12 17:33:42 +01:00
var id: Double {
startDate.timeIntervalSince1970
}
}
extension HistoryItem: Comparable {
2023-12-12 17:33:42 +01:00
static func < (lhs: HistoryItem, rhs: HistoryItem) -> Bool {
2023-12-12 17:33:42 +01:00
lhs.startDate < rhs.startDate
}
}
extension HistoryItem {
2023-12-12 17:33:42 +01:00
static var mock: HistoryItem {
2023-12-12 17:33:42 +01:00
let message = Message(messageType: .request, clientChallenge: 123, serverChallenge: 234, result: .unlocked)
2023-08-14 10:39:29 +02:00
return .init(
2023-12-12 17:33:42 +01:00
message: message,
startDate: Date.now.addingTimeInterval(-5),
route: .throughServer,
finishDate: Date.now)
}
}