2fas-ios/TwoFAS/Sync/Other/SecretValidation.swift
2024-03-26 18:29:49 +01:00

36 lines
1.3 KiB
Swift

//
// This file is part of the 2FAS iOS app (https://github.com/twofas/2fas-ios)
// Copyright © 2023 Two Factor Authentication Service, Inc.
// Contributed by Zbigniew Cisiński. All rights reserved.
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>
//
import Foundation
#if os(iOS)
import Common
#elseif os(watchOS)
import CommonWatch
#endif
enum SecretValidation {
private static let maxLenght: Int = 255
private static let forbiddenFirstChar: String = "_"
static func isValid(_ secret: String) -> Bool {
guard let first = secret.first else { return false }
return secret.count <= maxLenght && secret.count > 0 && String(first) != forbiddenFirstChar && secret.isBase32()
}
}