import Curve25519Kit public extension ECKeyPair { @objc var hexEncodedPrivateKey: String { return privateKey.map { String(format: "%02hhx", $0) }.joined() } @objc var hexEncodedPublicKey: String { // Prefixing with 'IdPrefix.standard' is necessary for what seems to be a sort of Signal public key versioning system return IdPrefix.standard.rawValue + publicKey.map { String(format: "%02hhx", $0) }.joined() } @objc static func isValidHexEncodedPublicKey(candidate: String) -> Bool { // Check that it's a valid hexadecimal encoding guard Hex.isValid(candidate) else { return false } // Check that it has length 66 and a valid prefix guard candidate.count == 66 && IdPrefix.allCases.first(where: { candidate.hasPrefix($0.rawValue) }) != nil else { return false } // It appears to be a valid public key return true } } public extension BlindedECKeyPair { @objc override var hexEncodedPublicKey: String { return IdPrefix.blinded.rawValue + publicKey.map { String(format: "%02hhx", $0) }.joined() } }