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.
120 lines
6.0 KiB
Swift
120 lines
6.0 KiB
Swift
import Sodium
|
|
|
|
extension Storage {
|
|
|
|
// MARK: Encryption Key Pairs
|
|
private static func getClosedGroupEncryptionKeyPairCollection(for groupPublicKey: String) -> String {
|
|
return "SNClosedGroupEncryptionKeyPairCollection-\(groupPublicKey)"
|
|
}
|
|
|
|
public func getClosedGroupEncryptionKeyPairs(for groupPublicKey: String) -> [ECKeyPair] {
|
|
let collection = Storage.getClosedGroupEncryptionKeyPairCollection(for: groupPublicKey)
|
|
var timestampsAndKeyPairs: [(timestamp: Double, keyPair: ECKeyPair)] = []
|
|
Storage.read { transaction in
|
|
transaction.enumerateKeysAndObjects(inCollection: collection) { key, object, _ in
|
|
guard let timestamp = Double(key), let keyPair = object as? ECKeyPair else { return }
|
|
timestampsAndKeyPairs.append((timestamp, keyPair))
|
|
}
|
|
}
|
|
return timestampsAndKeyPairs.sorted { $0.timestamp < $1.timestamp }.map { $0.keyPair }
|
|
}
|
|
|
|
public func getLatestClosedGroupEncryptionKeyPair(for groupPublicKey: String) -> ECKeyPair? {
|
|
return getClosedGroupEncryptionKeyPairs(for: groupPublicKey).last
|
|
}
|
|
|
|
public func addClosedGroupEncryptionKeyPair(_ keyPair: ECKeyPair, for groupPublicKey: String, using transaction: Any) -> String {
|
|
let collection = Storage.getClosedGroupEncryptionKeyPairCollection(for: groupPublicKey)
|
|
let timestamp = String(Date().timeIntervalSince1970)
|
|
(transaction as! YapDatabaseReadWriteTransaction).setObject(keyPair, forKey: timestamp, inCollection: collection)
|
|
return timestamp
|
|
}
|
|
|
|
public func removeAllClosedGroupEncryptionKeyPairs(for groupPublicKey: String, using transaction: Any) {
|
|
let collection = Storage.getClosedGroupEncryptionKeyPairCollection(for: groupPublicKey)
|
|
(transaction as! YapDatabaseReadWriteTransaction).removeAllObjects(inCollection: collection)
|
|
}
|
|
|
|
// MARK: Authentication Key Pairs
|
|
private static func getClosedGroupAuthenticationKeyPairCollection(for groupPublicKey: String) -> String {
|
|
return "SNClosedGroupAuthenticationKeyPairCollection-\(groupPublicKey)"
|
|
}
|
|
|
|
public func getClosedGroupAuthenticationKeyPairs(for groupPublicKey: String) -> [Sign.KeyPair] {
|
|
let collection = Storage.getClosedGroupAuthenticationKeyPairCollection(for: groupPublicKey)
|
|
var timestampsAndKeyPairs: [(timestamp: Double, keyPair: Sign.KeyPair)] = []
|
|
Storage.read { transaction in
|
|
transaction.enumerateKeysAndObjects(inCollection: collection) { key, object, _ in
|
|
guard let timestamp = Double(key), let keyPair = object as? Sign.KeyPair else { return }
|
|
timestampsAndKeyPairs.append((timestamp, keyPair))
|
|
}
|
|
}
|
|
return timestampsAndKeyPairs.sorted { $0.timestamp < $1.timestamp }.map { $0.keyPair }
|
|
}
|
|
|
|
public func getLatestClosedGroupAuthenticationKeyPair(for groupPublicKey: String) -> Sign.KeyPair? {
|
|
return getClosedGroupAuthenticationKeyPairs(for: groupPublicKey).last
|
|
}
|
|
|
|
public func addClosedGroupAuthenticationKeyPair(_ keyPair: Sign.KeyPair, for groupPublicKey: String, timestamp: String, using transaction: Any) {
|
|
let collection = Storage.getClosedGroupAuthenticationKeyPairCollection(for: groupPublicKey)
|
|
(transaction as! YapDatabaseReadWriteTransaction).setObject(keyPair, forKey: timestamp, inCollection: collection)
|
|
}
|
|
|
|
// MARK: Public Keys
|
|
private static let closedGroupPublicKeyCollection = "SNClosedGroupPublicKeyCollection"
|
|
|
|
public func getUserClosedGroupPublicKeys() -> Set<String> {
|
|
var result: Set<String> = []
|
|
Storage.read { transaction in
|
|
result = Set(transaction.allKeys(inCollection: Storage.closedGroupPublicKeyCollection))
|
|
}
|
|
return result
|
|
}
|
|
|
|
public func addClosedGroupPublicKey(_ groupPublicKey: String, using transaction: Any) {
|
|
(transaction as! YapDatabaseReadWriteTransaction).setObject(groupPublicKey, forKey: groupPublicKey, inCollection: Storage.closedGroupPublicKeyCollection)
|
|
}
|
|
|
|
public func removeClosedGroupPublicKey(_ groupPublicKey: String, using transaction: Any) {
|
|
(transaction as! YapDatabaseReadWriteTransaction).removeObject(forKey: groupPublicKey, inCollection: Storage.closedGroupPublicKeyCollection)
|
|
}
|
|
|
|
// MARK: Formation Timestamps
|
|
private static let closedGroupFormationTimestampCollection = "SNClosedGroupFormationTimestampCollection"
|
|
|
|
public func getClosedGroupFormationTimestamp(for groupPublicKey: String) -> UInt64? {
|
|
var result: UInt64?
|
|
Storage.read { transaction in
|
|
result = transaction.object(forKey: groupPublicKey, inCollection: Storage.closedGroupFormationTimestampCollection) as? UInt64
|
|
}
|
|
return result
|
|
}
|
|
|
|
public func setClosedGroupFormationTimestamp(to timestamp: UInt64, for groupPublicKey: String, using transaction: Any) {
|
|
(transaction as! YapDatabaseReadWriteTransaction).setObject(timestamp, forKey: groupPublicKey, inCollection: Storage.closedGroupFormationTimestampCollection)
|
|
}
|
|
|
|
// MARK: Zombie Members
|
|
private static let closedGroupZombieMembersCollection = "SNClosedGroupZombieMembersCollection"
|
|
|
|
public func getZombieMembers(for groupPublicKey: String) -> Set<String> {
|
|
var result: Set<String> = []
|
|
Storage.read { transaction in
|
|
if let zombies = transaction.object(forKey: groupPublicKey, inCollection: Storage.closedGroupZombieMembersCollection) as? Set<String> {
|
|
result = zombies
|
|
}
|
|
}
|
|
return result
|
|
}
|
|
|
|
public func setZombieMembers(for groupPublicKey: String, to zombies: Set<String>, using transaction: Any) {
|
|
(transaction as! YapDatabaseReadWriteTransaction).setObject(zombies, forKey: groupPublicKey, inCollection: Storage.closedGroupZombieMembersCollection)
|
|
}
|
|
|
|
// MARK: Convenience
|
|
public func isClosedGroup(_ publicKey: String) -> Bool {
|
|
getUserClosedGroupPublicKeys().contains(publicKey)
|
|
}
|
|
}
|