Polish the Password class
- About "additions", remove "additionKeys"
This commit is contained in:
parent
62136b0cfd
commit
69b58e686d
2 changed files with 35 additions and 38 deletions
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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) {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue