mirror of
https://github.com/signalapp/libsignal.git
synced 2026-05-03 04:52:19 +02:00
At this point, the only special behavior of bridge_fn_buffer is to support multiple return values for the C bridge (a pointer/length pair), and that doesn't pull its weight. Remove it in favor of a plain bridge_fn. This did reveal that Username_Hash was using bridge_fn_buffer and now produces a fixed-size array, imported into Swift as a tuple, so this commit also factors out a new helper invokeFnReturningFixedLengthArray.
121 lines
4.0 KiB
Swift
121 lines
4.0 KiB
Swift
//
|
|
// Copyright 2021-2022 Signal Messenger, LLC.
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
//
|
|
|
|
import SignalFfi
|
|
import Foundation
|
|
|
|
public class PlaintextContent: NativeHandleOwner {
|
|
internal override class func destroyNativeHandle(_ handle: OpaquePointer) -> SignalFfiErrorRef? {
|
|
return signal_plaintext_content_destroy(handle)
|
|
}
|
|
|
|
public convenience init<Bytes: ContiguousBytes>(bytes: Bytes) throws {
|
|
var result: OpaquePointer?
|
|
try bytes.withUnsafeBorrowedBuffer {
|
|
try checkError(signal_plaintext_content_deserialize(&result, $0))
|
|
}
|
|
self.init(owned: result!)
|
|
}
|
|
|
|
public convenience init(_ decryptionError: DecryptionErrorMessage) {
|
|
var result: OpaquePointer?
|
|
decryptionError.withNativeHandle { decryptionErrorHandle in
|
|
failOnError(signal_plaintext_content_from_decryption_error_message(&result, decryptionErrorHandle))
|
|
}
|
|
self.init(owned: result!)
|
|
}
|
|
|
|
public func serialize() -> [UInt8] {
|
|
return withNativeHandle { nativeHandle in
|
|
failOnError {
|
|
try invokeFnReturningArray {
|
|
signal_plaintext_content_serialize($0, nativeHandle)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public var body: [UInt8] {
|
|
return withNativeHandle { nativeHandle in
|
|
failOnError {
|
|
try invokeFnReturningArray {
|
|
signal_plaintext_content_get_body($0, nativeHandle)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public class DecryptionErrorMessage: NativeHandleOwner {
|
|
internal override class func destroyNativeHandle(_ handle: OpaquePointer) -> SignalFfiErrorRef? {
|
|
return signal_decryption_error_message_destroy(handle)
|
|
}
|
|
|
|
public convenience init<Bytes: ContiguousBytes>(bytes: Bytes) throws {
|
|
var result: OpaquePointer?
|
|
try bytes.withUnsafeBorrowedBuffer {
|
|
try checkError(signal_decryption_error_message_deserialize(&result, $0))
|
|
}
|
|
self.init(owned: result!)
|
|
}
|
|
|
|
public convenience init<Bytes: ContiguousBytes>(originalMessageBytes bytes: Bytes, type: CiphertextMessage.MessageType, timestamp: UInt64, originalSenderDeviceId: UInt32) throws {
|
|
var result: OpaquePointer?
|
|
try bytes.withUnsafeBorrowedBuffer {
|
|
try checkError(signal_decryption_error_message_for_original_message(&result, $0, type.rawValue, timestamp, originalSenderDeviceId))
|
|
}
|
|
self.init(owned: result!)
|
|
}
|
|
|
|
// For testing
|
|
public static func extractFromSerializedContent<Bytes: ContiguousBytes>(_ bytes: Bytes) throws -> DecryptionErrorMessage {
|
|
return try bytes.withUnsafeBorrowedBuffer { buffer in
|
|
try invokeFnReturningNativeHandle {
|
|
signal_decryption_error_message_extract_from_serialized_content($0, buffer)
|
|
}
|
|
}
|
|
}
|
|
|
|
public func serialize() -> [UInt8] {
|
|
return withNativeHandle { nativeHandle in
|
|
failOnError {
|
|
try invokeFnReturningArray {
|
|
signal_decryption_error_message_serialize($0, nativeHandle)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public var ratchetKey: PublicKey? {
|
|
return withNativeHandle { nativeHandle in
|
|
failOnError {
|
|
try invokeFnReturningOptionalNativeHandle {
|
|
signal_decryption_error_message_get_ratchet_key($0, nativeHandle)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public var timestamp: UInt64 {
|
|
return withNativeHandle { nativeHandle in
|
|
failOnError {
|
|
try invokeFnReturningInteger {
|
|
signal_decryption_error_message_get_timestamp($0, nativeHandle)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public var deviceId: UInt32 {
|
|
return withNativeHandle { nativeHandle in
|
|
failOnError {
|
|
try invokeFnReturningInteger {
|
|
signal_decryption_error_message_get_device_id($0, nativeHandle)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|