Fix a bug about TOTP refresh

This commit is contained in:
Yishi Lin 2017-03-07 09:50:18 +08:00
parent af1ea3ee3e
commit 3cf88dcbc8
2 changed files with 26 additions and 10 deletions

View file

@ -239,4 +239,24 @@ class Password {
}
self.updatePassword(name: self.name, plainText: lines.joined(separator: "\n"))
}
// return the description and the password strings
func getOtpStrings() -> (description: String, otp: String)? {
guard let token = self.otpToken else {
return nil
}
var description : String
switch token.generator.factor {
case .counter:
// htop
description = "HMAC-based"
case .timer(let period):
// totp
let timeSinceEpoch = Date().timeIntervalSince1970
let validTime = Int(period - timeSinceEpoch.truncatingRemainder(dividingBy: period))
description = "time-based (expiring in \(validTime)s)"
}
let otp = self.otpToken?.currentPassword ?? "error"
return (description, otp)
}
}