TM-SGNL-iOS/SignalServiceKit/SecureValueRecovery/SVRUtil.swift
TeleMessage developers dde0620daf initial commit
2025-05-03 12:28:28 -07:00

51 lines
1.7 KiB
Swift

//
// Copyright 2023 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
//
import Foundation
import LibSignalClient
/// Just a container for simple static helper methods on SVR
/// that can be shared with other classes (incl. objc classes).
@objc
public final class SVRUtil: NSObject {
@objc
public static func normalizePin(_ pin: String) -> String {
// Trim leading and trailing whitespace
var normalizedPin = pin.ows_stripped()
// If this pin contains only numerals, ensure they are arabic numerals.
if pin.digitsOnly() == normalizedPin { normalizedPin = normalizedPin.ensureArabicNumerals }
// NFKD unicode normalization.
return normalizedPin.decomposedStringWithCompatibilityMapping
}
internal enum Constants {
static let pinSaltLengthBytes: UInt = 16
}
internal static func deriveEncodedPINVerificationString(pin: String) throws -> String {
guard let pinData = normalizePin(pin).data(using: .utf8) else { throw SVR.SVRError.assertion }
return try LibSignalClient.hashLocalPin(pinData)
}
internal static func verifyPIN(
pin: String,
againstEncodedPINVerificationString encodedPINVerificationString: String
) -> Bool {
guard let pinData = normalizePin(pin).data(using: .utf8) else {
owsFailDebug("failed to determine pin data")
return false
}
do {
return try LibSignalClient.verifyLocalPin(pinData, againstEncodedHash: encodedPINVerificationString)
} catch {
owsFailDebug("Failed to validate encodedVerificationString with error: \(error)")
return false
}
}
}