|
|
@ -18,11 +18,15 @@ public final class ClosedGroupControlMessage : ControlMessage {
|
|
|
|
case new(publicKey: Data, name: String, encryptionKeyPair: ECKeyPair, members: [Data], admins: [Data])
|
|
|
|
case new(publicKey: Data, name: String, encryptionKeyPair: ECKeyPair, members: [Data], admins: [Data])
|
|
|
|
/// - Note: Deprecated in favor of more explicit group updates.
|
|
|
|
/// - Note: Deprecated in favor of more explicit group updates.
|
|
|
|
case update(name: String, members: [Data])
|
|
|
|
case update(name: String, members: [Data])
|
|
|
|
case encryptionKeyPair([KeyPairWrapper]) // The new encryption key pair encrypted for each member individually
|
|
|
|
/// An encryption key pair encrypted for each member individually.
|
|
|
|
|
|
|
|
///
|
|
|
|
|
|
|
|
/// - Note: `publicKey` is only set when an encryption key pair is sent in a one-to-one context (i.e. not in a group).
|
|
|
|
|
|
|
|
case encryptionKeyPair(publicKey: Data?, wrappers: [KeyPairWrapper])
|
|
|
|
case nameChange(name: String)
|
|
|
|
case nameChange(name: String)
|
|
|
|
case membersAdded(members: [Data])
|
|
|
|
case membersAdded(members: [Data])
|
|
|
|
case membersRemoved(members: [Data])
|
|
|
|
case membersRemoved(members: [Data])
|
|
|
|
case memberLeft
|
|
|
|
case memberLeft
|
|
|
|
|
|
|
|
case encryptionKeyPairRequest
|
|
|
|
|
|
|
|
|
|
|
|
public var description: String {
|
|
|
|
public var description: String {
|
|
|
|
switch self {
|
|
|
|
switch self {
|
|
|
@ -33,6 +37,7 @@ public final class ClosedGroupControlMessage : ControlMessage {
|
|
|
|
case .membersAdded: return "membersAdded"
|
|
|
|
case .membersAdded: return "membersAdded"
|
|
|
|
case .membersRemoved: return "membersRemoved"
|
|
|
|
case .membersRemoved: return "membersRemoved"
|
|
|
|
case .memberLeft: return "memberLeft"
|
|
|
|
case .memberLeft: return "memberLeft"
|
|
|
|
|
|
|
|
case .encryptionKeyPairRequest: return "encryptionKeyPairRequest"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -98,6 +103,7 @@ public final class ClosedGroupControlMessage : ControlMessage {
|
|
|
|
case .membersAdded(let members): return !members.isEmpty
|
|
|
|
case .membersAdded(let members): return !members.isEmpty
|
|
|
|
case .membersRemoved(let members): return !members.isEmpty
|
|
|
|
case .membersRemoved(let members): return !members.isEmpty
|
|
|
|
case .memberLeft: return true
|
|
|
|
case .memberLeft: return true
|
|
|
|
|
|
|
|
case .encryptionKeyPairRequest: return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -118,8 +124,9 @@ public final class ClosedGroupControlMessage : ControlMessage {
|
|
|
|
let members = coder.decodeObject(forKey: "members") as? [Data] else { return nil }
|
|
|
|
let members = coder.decodeObject(forKey: "members") as? [Data] else { return nil }
|
|
|
|
self.kind = .update(name: name, members: members)
|
|
|
|
self.kind = .update(name: name, members: members)
|
|
|
|
case "encryptionKeyPair":
|
|
|
|
case "encryptionKeyPair":
|
|
|
|
|
|
|
|
let publicKey = coder.decodeObject(forKey: "publicKey") as? Data
|
|
|
|
guard let wrappers = coder.decodeObject(forKey: "wrappers") as? [KeyPairWrapper] else { return nil }
|
|
|
|
guard let wrappers = coder.decodeObject(forKey: "wrappers") as? [KeyPairWrapper] else { return nil }
|
|
|
|
self.kind = .encryptionKeyPair(wrappers)
|
|
|
|
self.kind = .encryptionKeyPair(publicKey: publicKey, wrappers: wrappers)
|
|
|
|
case "nameChange":
|
|
|
|
case "nameChange":
|
|
|
|
guard let name = coder.decodeObject(forKey: "name") as? String else { return nil }
|
|
|
|
guard let name = coder.decodeObject(forKey: "name") as? String else { return nil }
|
|
|
|
self.kind = .nameChange(name: name)
|
|
|
|
self.kind = .nameChange(name: name)
|
|
|
@ -131,6 +138,8 @@ public final class ClosedGroupControlMessage : ControlMessage {
|
|
|
|
self.kind = .membersRemoved(members: members)
|
|
|
|
self.kind = .membersRemoved(members: members)
|
|
|
|
case "memberLeft":
|
|
|
|
case "memberLeft":
|
|
|
|
self.kind = .memberLeft
|
|
|
|
self.kind = .memberLeft
|
|
|
|
|
|
|
|
case "encryptionKeyPairRequest":
|
|
|
|
|
|
|
|
self.kind = .encryptionKeyPairRequest
|
|
|
|
default: return nil
|
|
|
|
default: return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -150,8 +159,9 @@ public final class ClosedGroupControlMessage : ControlMessage {
|
|
|
|
coder.encode("update", forKey: "kind")
|
|
|
|
coder.encode("update", forKey: "kind")
|
|
|
|
coder.encode(name, forKey: "name")
|
|
|
|
coder.encode(name, forKey: "name")
|
|
|
|
coder.encode(members, forKey: "members")
|
|
|
|
coder.encode(members, forKey: "members")
|
|
|
|
case .encryptionKeyPair(let wrappers):
|
|
|
|
case .encryptionKeyPair(let publicKey, let wrappers):
|
|
|
|
coder.encode("encryptionKeyPair", forKey: "kind")
|
|
|
|
coder.encode("encryptionKeyPair", forKey: "kind")
|
|
|
|
|
|
|
|
coder.encode(publicKey, forKey: "publicKey")
|
|
|
|
coder.encode(wrappers, forKey: "wrappers")
|
|
|
|
coder.encode(wrappers, forKey: "wrappers")
|
|
|
|
case .nameChange(let name):
|
|
|
|
case .nameChange(let name):
|
|
|
|
coder.encode("nameChange", forKey: "kind")
|
|
|
|
coder.encode("nameChange", forKey: "kind")
|
|
|
@ -164,6 +174,8 @@ public final class ClosedGroupControlMessage : ControlMessage {
|
|
|
|
coder.encode(members, forKey: "members")
|
|
|
|
coder.encode(members, forKey: "members")
|
|
|
|
case .memberLeft:
|
|
|
|
case .memberLeft:
|
|
|
|
coder.encode("memberLeft", forKey: "kind")
|
|
|
|
coder.encode("memberLeft", forKey: "kind")
|
|
|
|
|
|
|
|
case .encryptionKeyPairRequest:
|
|
|
|
|
|
|
|
coder.encode("encryptionKeyPairRequest", forKey: "kind")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -187,8 +199,9 @@ public final class ClosedGroupControlMessage : ControlMessage {
|
|
|
|
guard let name = closedGroupControlMessageProto.name else { return nil }
|
|
|
|
guard let name = closedGroupControlMessageProto.name else { return nil }
|
|
|
|
kind = .update(name: name, members: closedGroupControlMessageProto.members)
|
|
|
|
kind = .update(name: name, members: closedGroupControlMessageProto.members)
|
|
|
|
case .encryptionKeyPair:
|
|
|
|
case .encryptionKeyPair:
|
|
|
|
|
|
|
|
let publicKey = closedGroupControlMessageProto.publicKey
|
|
|
|
let wrappers = closedGroupControlMessageProto.wrappers.compactMap { KeyPairWrapper.fromProto($0) }
|
|
|
|
let wrappers = closedGroupControlMessageProto.wrappers.compactMap { KeyPairWrapper.fromProto($0) }
|
|
|
|
kind = .encryptionKeyPair(wrappers)
|
|
|
|
kind = .encryptionKeyPair(publicKey: publicKey, wrappers: wrappers)
|
|
|
|
case .nameChange:
|
|
|
|
case .nameChange:
|
|
|
|
guard let name = closedGroupControlMessageProto.name else { return nil }
|
|
|
|
guard let name = closedGroupControlMessageProto.name else { return nil }
|
|
|
|
kind = .nameChange(name: name)
|
|
|
|
kind = .nameChange(name: name)
|
|
|
@ -198,6 +211,8 @@ public final class ClosedGroupControlMessage : ControlMessage {
|
|
|
|
kind = .membersRemoved(members: closedGroupControlMessageProto.members)
|
|
|
|
kind = .membersRemoved(members: closedGroupControlMessageProto.members)
|
|
|
|
case .memberLeft:
|
|
|
|
case .memberLeft:
|
|
|
|
kind = .memberLeft
|
|
|
|
kind = .memberLeft
|
|
|
|
|
|
|
|
case .encryptionKeyPairRequest:
|
|
|
|
|
|
|
|
kind = .encryptionKeyPairRequest
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ClosedGroupControlMessage(kind: kind)
|
|
|
|
return ClosedGroupControlMessage(kind: kind)
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -227,8 +242,11 @@ public final class ClosedGroupControlMessage : ControlMessage {
|
|
|
|
closedGroupControlMessage = SNProtoDataMessageClosedGroupControlMessage.builder(type: .update)
|
|
|
|
closedGroupControlMessage = SNProtoDataMessageClosedGroupControlMessage.builder(type: .update)
|
|
|
|
closedGroupControlMessage.setName(name)
|
|
|
|
closedGroupControlMessage.setName(name)
|
|
|
|
closedGroupControlMessage.setMembers(members)
|
|
|
|
closedGroupControlMessage.setMembers(members)
|
|
|
|
case .encryptionKeyPair(let wrappers):
|
|
|
|
case .encryptionKeyPair(let publicKey, let wrappers):
|
|
|
|
closedGroupControlMessage = SNProtoDataMessageClosedGroupControlMessage.builder(type: .encryptionKeyPair)
|
|
|
|
closedGroupControlMessage = SNProtoDataMessageClosedGroupControlMessage.builder(type: .encryptionKeyPair)
|
|
|
|
|
|
|
|
if let publicKey = publicKey {
|
|
|
|
|
|
|
|
closedGroupControlMessage.setPublicKey(publicKey)
|
|
|
|
|
|
|
|
}
|
|
|
|
closedGroupControlMessage.setWrappers(wrappers.compactMap { $0.toProto() })
|
|
|
|
closedGroupControlMessage.setWrappers(wrappers.compactMap { $0.toProto() })
|
|
|
|
case .nameChange(let name):
|
|
|
|
case .nameChange(let name):
|
|
|
|
closedGroupControlMessage = SNProtoDataMessageClosedGroupControlMessage.builder(type: .nameChange)
|
|
|
|
closedGroupControlMessage = SNProtoDataMessageClosedGroupControlMessage.builder(type: .nameChange)
|
|
|
@ -241,6 +259,8 @@ public final class ClosedGroupControlMessage : ControlMessage {
|
|
|
|
closedGroupControlMessage.setMembers(members)
|
|
|
|
closedGroupControlMessage.setMembers(members)
|
|
|
|
case .memberLeft:
|
|
|
|
case .memberLeft:
|
|
|
|
closedGroupControlMessage = SNProtoDataMessageClosedGroupControlMessage.builder(type: .memberLeft)
|
|
|
|
closedGroupControlMessage = SNProtoDataMessageClosedGroupControlMessage.builder(type: .memberLeft)
|
|
|
|
|
|
|
|
case .encryptionKeyPairRequest:
|
|
|
|
|
|
|
|
closedGroupControlMessage = SNProtoDataMessageClosedGroupControlMessage.builder(type: .encryptionKeyPairRequest)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
let contentProto = SNProtoContent.builder()
|
|
|
|
let contentProto = SNProtoContent.builder()
|
|
|
|
let dataMessageProto = SNProtoDataMessage.builder()
|
|
|
|
let dataMessageProto = SNProtoDataMessage.builder()
|
|
|
|