Files
libsignal/swift/Sources/LibSignalClient/PublicKey.swift
Jordan Rose 0542686e70 Update artifact/package/module names across all three app languages
- Java: org.whispersystems:signal-client-java ->
    org.signal:libsignal-client
- Java: org.whispersystems:signal-client-android ->
    org.signal:libsignal-android
- Java: org.whispersystems:libsignal-server ->
    org.signal:libsignal-server
- Swift: SignalClient -> LibSignalClient
- NPM: @signalapp/signal-client -> @signalapp/libsignal-client
- Repository: github.com/signalapp/libsignal-client ->
    github.com/signalapp/libsignal
2022-03-23 10:49:09 -07:00

80 lines
2.6 KiB
Swift

//
// Copyright 2020-2022 Signal Messenger, LLC.
// SPDX-License-Identifier: AGPL-3.0-only
//
import SignalFfi
import Foundation
public class PublicKey: ClonableHandleOwner {
public convenience init<Bytes: ContiguousBytes>(_ bytes: Bytes) throws {
let handle: OpaquePointer? = try bytes.withUnsafeBorrowedBuffer {
var result: OpaquePointer?
try checkError(signal_publickey_deserialize(&result, $0))
return result
}
self.init(owned: handle!)
}
internal override class func destroyNativeHandle(_ handle: OpaquePointer) -> SignalFfiErrorRef? {
return signal_publickey_destroy(handle)
}
internal override class func cloneNativeHandle(_ newHandle: inout OpaquePointer?, currentHandle: OpaquePointer?) -> SignalFfiErrorRef? {
return signal_publickey_clone(&newHandle, currentHandle)
}
public var keyBytes: [UInt8] {
return withNativeHandle { nativeHandle in
failOnError {
try invokeFnReturningArray {
signal_publickey_get_public_key_bytes($0, $1, nativeHandle)
}
}
}
}
public func serialize() -> [UInt8] {
return withNativeHandle { nativeHandle in
failOnError {
try invokeFnReturningArray {
signal_publickey_serialize($0, $1, nativeHandle)
}
}
}
}
public func verifySignature<MessageBytes, SignatureBytes>(message: MessageBytes, signature: SignatureBytes) throws -> Bool
where MessageBytes: ContiguousBytes, SignatureBytes: ContiguousBytes {
var result: Bool = false
try withNativeHandle { nativeHandle in
try message.withUnsafeBorrowedBuffer { messageBuffer in
try signature.withUnsafeBorrowedBuffer { signatureBuffer in
try checkError(signal_publickey_verify(&result, nativeHandle, messageBuffer, signatureBuffer))
}
}
}
return result
}
public func compare(_ other: PublicKey) -> Int32 {
var result: Int32 = 0
withNativeHandles(self, other) { selfHandle, otherHandle in
failOnError(signal_publickey_compare(&result, selfHandle, otherHandle))
}
return result
}
}
extension PublicKey: Equatable {
public static func == (lhs: PublicKey, rhs: PublicKey) -> Bool {
return lhs.compare(rhs) == 0
}
}
extension PublicKey: Comparable {
public static func < (lhs: PublicKey, rhs: PublicKey) -> Bool {
return lhs.compare(rhs) < 0
}
}