refactor Password class

This commit is contained in:
Bob Sun 2017-02-11 16:07:59 +08:00
parent d0f31e3db0
commit 49b26f0276
No known key found for this signature in database
GPG key ID: 1F86BA2052FED3B4
2 changed files with 69 additions and 55 deletions

View file

@ -16,23 +16,65 @@ struct AdditionField {
class Password {
var name = ""
var username = ""
var password = ""
var url = ""
var additions = [AdditionField]()
var additions = [String: String]()
var additionKeys = [String]()
init() { }
convenience init(name: String, username: String, password: String, additions: [AdditionField]) {
self.init(name: name, username: username, password: password, url: "", additions: additions)
convenience init(name: String, plainText: String) {
var i = 0
var additionFieldsArray = [AdditionField]()
var password = ""
var unkownIndex = 0
plainText.enumerateLines() { line, _ in
if i == 0 {
password = line
} else {
let items = line.characters.split(separator: ":", maxSplits: 1, omittingEmptySubsequences: true).map(String.init)
var key = ""
var value = ""
if items.count == 1 {
unkownIndex += 1
key = "unkown \(unkownIndex)"
value = items[0]
} else {
key = items[0]
value = items[1].trimmingCharacters(in: .whitespaces)
}
additionFieldsArray.append(AdditionField(title: key, content: value))
}
i += 1
}
self.init(name: name, password: password, additionsArray: additionFieldsArray)
}
init(name: String, username: String, password: String, url: String, additions: [AdditionField]) {
init(name: String, password: String, additionsArray: [AdditionField]) {
self.name = name
self.username = username
self.password = password
self.url = url
self.additions = additions
for additionField in additionsArray {
self.additions[additionField.title] = additionField.content
self.additionKeys.append(additionField.title)
}
}
func getUsername() -> String? {
return getAdditionValue(withKey: "Username") ?? getAdditionValue(withKey: "username")
}
func getURL() -> String? {
return getAdditionValue(withKey: "URL") ?? getAdditionValue(withKey: "url") ?? getAdditionValue(withKey: "Url")
}
func getPlainText() -> String {
let plainAdditionsText = self.additionKeys.map { "\($0): \(self.additions[$0]!)" }.joined(separator: "\n")
return "\(self.password)\n\(plainAdditionsText)"
}
func getPlainData() -> Data {
return getPlainText().data(using: .ascii)!
}
private func getAdditionValue(withKey key: String) -> String? {
return self.additions[key]
}
}
@ -42,43 +84,15 @@ extension PasswordEntity {
let encryptedDataPath = URL(fileURLWithPath: "\(Globals.repositoryPath)/\(rawPath!)")
let encryptedData = try Data(contentsOf: encryptedDataPath)
let decryptedData = try PasswordStore.shared.pgp.decryptData(encryptedData, passphrase: Defaults[.pgpKeyPassphrase])
let plain = String(data: decryptedData, encoding: .ascii) ?? ""
var decrypted_password = ""
var username = ""
var decrypted_addtions = [AdditionField]()
var i = 0
plain.enumerateLines(invoking: { line, _ in
if i == 0 {
decrypted_password = line
} else {
let items = line.characters.split(separator: ":", maxSplits: 1, omittingEmptySubsequences: true).map(String.init)
if items.count == 2 && items[0].lowercased() == "username" {
username = items[1].trimmingCharacters(in: .whitespaces)
} else {
var key = ""
var value = ""
if items.count == 1 {
key = "unknown"
value = items[0]
} else {
key = items[0]
value = items[1].trimmingCharacters(in: .whitespaces)
}
decrypted_addtions.append(AdditionField(title: key, content: value))
}
}
i += 1
})
password = Password(name: name!, username: username, password: decrypted_password, additions: decrypted_addtions)
let plainText = String(data: decryptedData, encoding: .ascii) ?? ""
password = Password(name: name!, plainText: plainText)
return password
}
func encrypt(password: Password) throws -> Data {
name = password.name
rawPath = ""
let plainPassword = password.password
// let plainAdditions = password.additions.map { "\($0.title): \($0.content)" }.joined(separator: "\n")
let plainData = "\(plainPassword)\n".data(using: .ascii)!
let plainData = password.getPlainData()
let pgp = PasswordStore.shared.pgp
let encryptedData = try pgp.encryptData(plainData, usingPublicKey: pgp.getKeysOf(.public)[0], armored: false)
return encryptedData