Polish the Password class

- About "additions", remove "additionKeys"
This commit is contained in:
Yishi Lin 2017-06-28 00:18:06 +08:00
parent 62136b0cfd
commit 69b58e686d
2 changed files with 35 additions and 38 deletions

View file

@ -278,17 +278,12 @@ class PasswordDetailTableViewController: UITableViewController, UIGestureRecogni
} }
// show additional information // show additional information
let filteredAdditionKeys = password.additionKeys.filter { let filteredAdditionKeys = password.getFilteredAdditions()
$0.lowercased() != "username" &&
$0.lowercased() != "password" &&
(!$0.hasPrefix("unknown") || !SharedDefaults[.isHideUnknownOn]) &&
(!Password.otpKeywords.contains($0) || !SharedDefaults[.isHideOTPOn]) }
if filteredAdditionKeys.count > 0 { if filteredAdditionKeys.count > 0 {
section = TableSection(type: .addition, header: "additions") section = TableSection(type: .addition, header: "additions")
for additionKey in filteredAdditionKeys { filteredAdditionKeys.forEach({ (key: String, value: String) in
section.item.append(TableCell(title: additionKey, content: password.additions[additionKey]!)) section.item.append(TableCell(title: key, content: value))
} })
tableData.append(section) tableData.append(section)
} }

View file

@ -36,11 +36,10 @@ public class Password {
} }
} }
public var password = "" public var password = ""
public var additions = [String: String]()
public var additionKeys = [String]()
public var changed: Int = 0 public var changed: Int = 0
public var plainText = "" public var plainText = ""
private var additions = [String: String]()
private var firstLineIsOTPField = false private var firstLineIsOTPField = false
private var otpToken: Token? private var otpToken: Token?
@ -82,16 +81,29 @@ public class Password {
self.name = name self.name = name
self.url = url self.url = url
self.plainText = plainText self.plainText = plainText
self.additions.removeAll() additions.removeAll()
self.additionKeys.removeAll()
// get password and additional fields // split the plain text
let plainTextSplit = plainText.characters.split(maxSplits: 1, omittingEmptySubsequences: false) { let plainTextSplit = plainText.characters.split(maxSplits: 1, omittingEmptySubsequences: false) {
$0 == "\n" || $0 == "\r\n" $0 == "\n" || $0 == "\r\n"
}.map(String.init) }.map(String.init)
self.password = plainTextSplit.first ?? ""
// get password
password = plainTextSplit.first ?? ""
// get additonal fields
if plainTextSplit.count == 2 { if plainTextSplit.count == 2 {
(self.additions, self.additionKeys) = Password.getAdditionFields(from: plainTextSplit[1]) var unknownIndex = 0
plainTextSplit[1].enumerateLines() { line, _ in
if !line.isEmpty {
var (key, value) = Password.getKeyValuePair(from: line)
if key == nil {
unknownIndex += 1
key = "unknown \(unknownIndex)"
}
self.additions[key!] = value
}
}
} }
// check whether the first line of the plainText looks like an otp entry // check whether the first line of the plainText looks like an otp entry
@ -99,7 +111,6 @@ public class Password {
if Password.otpKeywords.contains(key ?? "") { if Password.otpKeywords.contains(key ?? "") {
firstLineIsOTPField = true firstLineIsOTPField = true
self.additions[key!] = value self.additions[key!] = value
self.additionKeys.insert(key!, at: 0)
} else { } else {
firstLineIsOTPField = false firstLineIsOTPField = false
} }
@ -108,6 +119,18 @@ public class Password {
self.updateOtpToken() self.updateOtpToken()
} }
public func getFilteredAdditions() -> [String: String] {
var filteredAdditions = [String: String]()
additions.forEach { (key: String, value: String) in
if key.lowercased() != "username" && key.lowercased() != "password" &&
(!key.hasPrefix("unknown") || !SharedDefaults[.isHideUnknownOn]) &&
(!Password.otpKeywords.contains(key) || !SharedDefaults[.isHideOTPOn]) {
filteredAdditions[key] = value
}
}
return filteredAdditions
}
public func getUsername() -> String? { public func getUsername() -> String? {
return getAdditionValue(withKey: "Username") ?? getAdditionValue(withKey: "username") return getAdditionValue(withKey: "Username") ?? getAdditionValue(withKey: "username")
} }
@ -138,27 +161,6 @@ public class Password {
return (key, value) return (key, value)
} }
private static func getAdditionFields(from additionFieldsPlainText: String) -> ([String: String], [String]){
var additions = [String: String]()
var additionKeys = [String]()
var unknownIndex = 0
additionFieldsPlainText.enumerateLines() { line, _ in
if line == "" {
return
}
var (key, value) = getKeyValuePair(from: line)
if key == nil {
unknownIndex += 1
key = "unknown \(unknownIndex)"
}
additions[key!] = value
additionKeys.append(key!)
}
return (additions, additionKeys)
}
public func getAdditionsPlainText() -> String { public func getAdditionsPlainText() -> String {
// lines starting from the second // lines starting from the second
let plainTextSplit = plainText.characters.split(maxSplits: 1, omittingEmptySubsequences: false) { let plainTextSplit = plainText.characters.split(maxSplits: 1, omittingEmptySubsequences: false) {