refactor Password class
This commit is contained in:
parent
d0f31e3db0
commit
49b26f0276
2 changed files with 69 additions and 55 deletions
|
|
@ -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
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue