Files
libsignal/swift/Sources/LibSignalClient/zkgroup/ClientZkGroupCipher.swift
Jordan Rose 6a547bf3f2 zkgroup: Use ServiceId and Aci in public APIs instead of UidBytes
Some of these APIs have to match up with UuidCiphertexts, and so we
convert them all for consistency.
2023-07-20 12:26:46 -07:00

88 lines
3.1 KiB
Swift

//
// Copyright 2020-2022 Signal Messenger, LLC.
// SPDX-License-Identifier: AGPL-3.0-only
//
import Foundation
import SignalFfi
public class ClientZkGroupCipher {
let groupSecretParams: GroupSecretParams
public init(groupSecretParams: GroupSecretParams) {
self.groupSecretParams = groupSecretParams
}
public func encrypt(_ serviceId: ServiceId) throws -> UuidCiphertext {
return try groupSecretParams.withUnsafePointerToSerialized { groupSecretParams in
try serviceId.withPointerToFixedWidthBinary { serviceId in
try invokeFnReturningSerialized {
signal_group_secret_params_encrypt_service_id($0, groupSecretParams, serviceId)
}
}
}
}
public func decrypt(_ uuidCiphertext: UuidCiphertext) throws -> ServiceId {
return try groupSecretParams.withUnsafePointerToSerialized { groupSecretParams in
try uuidCiphertext.withUnsafePointerToSerialized { uuidCiphertext in
try invokeFnReturningServiceId {
signal_group_secret_params_decrypt_service_id($0, groupSecretParams, uuidCiphertext)
}
}
}
}
public func encryptProfileKey(profileKey: ProfileKey, userId: Aci) throws -> ProfileKeyCiphertext {
return try groupSecretParams.withUnsafePointerToSerialized { groupSecretParams in
try profileKey.withUnsafePointerToSerialized { profileKey in
try userId.withPointerToFixedWidthBinary { userId in
try invokeFnReturningSerialized {
signal_group_secret_params_encrypt_profile_key($0, groupSecretParams, profileKey, userId)
}
}
}
}
}
public func decryptProfileKey(profileKeyCiphertext: ProfileKeyCiphertext, userId: Aci) throws -> ProfileKey {
return try groupSecretParams.withUnsafePointerToSerialized { groupSecretParams in
try profileKeyCiphertext.withUnsafePointerToSerialized { profileKeyCiphertext in
try userId.withPointerToFixedWidthBinary { userId in
try invokeFnReturningSerialized {
signal_group_secret_params_decrypt_profile_key($0, groupSecretParams, profileKeyCiphertext, userId )
}
}
}
}
}
public func encryptBlob(plaintext: [UInt8]) throws -> [UInt8] {
return try encryptBlob(randomness: Randomness.generate(), plaintext: plaintext)
}
public func encryptBlob(randomness: Randomness, plaintext: [UInt8]) throws -> [UInt8] {
return try groupSecretParams.withUnsafePointerToSerialized { groupSecretParams in
try randomness.withUnsafePointerToBytes { randomness in
try plaintext.withUnsafeBorrowedBuffer { plaintext in
try invokeFnReturningArray {
signal_group_secret_params_encrypt_blob_with_padding_deterministic($0, groupSecretParams, randomness, plaintext, 0)
}
}
}
}
}
public func decryptBlob(blobCiphertext: [UInt8]) throws -> [UInt8] {
return try groupSecretParams.withUnsafePointerToSerialized { groupSecretParams in
try blobCiphertext.withUnsafeBorrowedBuffer { blobCiphertext in
try invokeFnReturningArray {
signal_group_secret_params_decrypt_blob_with_padding($0, groupSecretParams, blobCiphertext)
}
}
}
}
}