Polish class Password
This commit is contained in:
parent
c1da27ae04
commit
71cb9a02c0
1 changed files with 38 additions and 31 deletions
|
|
@ -23,18 +23,15 @@ class Password {
|
||||||
var changed = false
|
var changed = false
|
||||||
|
|
||||||
init(name: String, plainText: String) {
|
init(name: String, plainText: String) {
|
||||||
|
self.name = name
|
||||||
|
self.plainText = plainText
|
||||||
|
|
||||||
|
// get password and additional fields
|
||||||
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)
|
||||||
let password = plainTextSplit[0]
|
self.password = plainTextSplit[0]
|
||||||
let additionFieldsArray = Password.getAdditionFields(from: plainTextSplit[1])
|
(self.additions, self.additionKeys) = Password.getAdditionFields(from: plainTextSplit[1])
|
||||||
self.name = name
|
|
||||||
self.password = password
|
|
||||||
self.plainText = plainText
|
|
||||||
for additionField in additionFieldsArray {
|
|
||||||
self.additions[additionField.title] = additionField.content
|
|
||||||
self.additionKeys.append(additionField.title)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func getUsername() -> String? {
|
func getUsername() -> String? {
|
||||||
|
|
@ -45,45 +42,55 @@ class Password {
|
||||||
return getAdditionValue(withKey: "URL") ?? getAdditionValue(withKey: "url") ?? getAdditionValue(withKey: "Url")
|
return getAdditionValue(withKey: "URL") ?? getAdditionValue(withKey: "url") ?? getAdditionValue(withKey: "Url")
|
||||||
}
|
}
|
||||||
|
|
||||||
static func getAdditionFields(from additionFieldsPlainText: String) -> [AdditionField]{
|
// return a key-value pair from the line
|
||||||
var additionFieldsArray = [AdditionField]()
|
// key might be nil, if there is no ":" in the line
|
||||||
|
static func getKeyValuePair(from line: String) -> (key: String?, value: String) {
|
||||||
|
let items = line.characters.split(separator: ":", maxSplits: 1, omittingEmptySubsequences: true).map(String.init)
|
||||||
|
var key : String?
|
||||||
|
var value = ""
|
||||||
|
if items.count == 1 {
|
||||||
|
value = items[0]
|
||||||
|
} else if items.count == 2 {
|
||||||
|
key = items[0]
|
||||||
|
value = items[1].trimmingCharacters(in: .whitespaces)
|
||||||
|
}
|
||||||
|
return (key, value)
|
||||||
|
}
|
||||||
|
|
||||||
|
static func getAdditionFields(from additionFieldsPlainText: String) -> ([String: String], [String]){
|
||||||
|
var additions = [String: String]()
|
||||||
|
var additionKeys = [String]()
|
||||||
var unknownIndex = 0
|
var unknownIndex = 0
|
||||||
|
|
||||||
additionFieldsPlainText.enumerateLines() { line, _ in
|
additionFieldsPlainText.enumerateLines() { line, _ in
|
||||||
if line == "" {
|
if line == "" {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
let items = line.characters.split(separator: ":", maxSplits: 1, omittingEmptySubsequences: true).map(String.init)
|
var (key, value) = getKeyValuePair(from: line)
|
||||||
var key = ""
|
if key == nil {
|
||||||
var value = ""
|
|
||||||
if items.count == 1 {
|
|
||||||
unknownIndex += 1
|
unknownIndex += 1
|
||||||
key = "unknown \(unknownIndex)"
|
key = "unknown \(unknownIndex)"
|
||||||
value = items[0]
|
|
||||||
} else if items.count == 2 {
|
|
||||||
key = items[0]
|
|
||||||
value = items[1].trimmingCharacters(in: .whitespaces)
|
|
||||||
}
|
}
|
||||||
additionFieldsArray.append(AdditionField(title: key, content: value))
|
additions[key!] = value
|
||||||
|
additionKeys.append(key!)
|
||||||
}
|
}
|
||||||
return additionFieldsArray
|
|
||||||
|
return (additions, additionKeys)
|
||||||
}
|
}
|
||||||
|
|
||||||
func updatePassword(name: String, plainText: String) {
|
func updatePassword(name: String, plainText: String) {
|
||||||
self.name = name
|
self.name = name
|
||||||
if self.plainText != plainText {
|
if self.plainText != plainText {
|
||||||
|
self.name = name
|
||||||
|
self.plainText = plainText
|
||||||
|
|
||||||
|
// get password and additional fields
|
||||||
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)
|
||||||
let password = plainTextSplit[0]
|
self.password = plainTextSplit[0]
|
||||||
let additionFieldsArray = Password.getAdditionFields(from: plainTextSplit[1])
|
(self.additions, self.additionKeys) = Password.getAdditionFields(from: plainTextSplit[1])
|
||||||
self.password = password
|
|
||||||
self.additions = [String: String]()
|
|
||||||
self.additionKeys = []
|
|
||||||
for additionField in additionFieldsArray {
|
|
||||||
self.additions[additionField.title] = additionField.content
|
|
||||||
self.additionKeys.append(additionField.title)
|
|
||||||
}
|
|
||||||
changed = true
|
changed = true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue