passforios/pass/Models/Password.swift

86 lines
2.7 KiB
Swift
Raw Normal View History

//
// Password.swift
// pass
//
// Created by Mingshen Sun on 2/2/2017.
// Copyright © 2017 Bob Sun. All rights reserved.
//
import Foundation
import SwiftyUserDefaults
2017-02-06 22:14:42 +08:00
struct AdditionField {
var title: String
var content: String
}
class Password {
2017-02-06 14:28:57 +08:00
var name: String
2017-02-06 22:14:42 +08:00
var username: String
2017-02-06 14:28:57 +08:00
var password: String
2017-02-09 13:17:11 +08:00
var url: String
2017-02-06 22:14:42 +08:00
var additions: [AdditionField]
2017-02-06 14:28:57 +08:00
init() {
name = ""
password = ""
2017-02-06 22:14:42 +08:00
username = ""
2017-02-09 13:17:11 +08:00
url = ""
2017-02-06 22:14:42 +08:00
additions = []
2017-02-06 14:28:57 +08:00
}
2017-02-06 22:14:42 +08:00
init(name: String, username: String, password: String, additions: [AdditionField]) {
self.name = name
2017-02-06 22:14:42 +08:00
self.username = username
self.password = password
self.additions = additions
2017-02-09 13:17:11 +08:00
self.url = ""
}
init(name: String, username: String, password: String, url: String, additions: [AdditionField]) {
self.name = name
self.username = username
self.password = password
self.url = url
self.additions = additions
}
}
extension PasswordEntity {
2017-02-06 14:28:57 +08:00
func decrypt() throws -> Password? {
var password: Password?
2017-02-08 10:15:38 +08:00
let encryptedDataPath = URL(fileURLWithPath: "\(Globals.documentPath)/\(rawPath!)")
2017-02-06 14:28:57 +08:00
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 = ""
2017-02-06 22:14:42 +08:00
var username = ""
var decrypted_addtions = [AdditionField]()
2017-02-07 15:40:23 +08:00
var i = 0
2017-02-06 14:28:57 +08:00
plain.enumerateLines(invoking: { line, _ in
2017-02-07 15:40:23 +08:00
if i == 0 {
decrypted_password = line
2017-02-06 14:28:57 +08:00
} else {
2017-02-07 15:40:23 +08:00
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)
2017-02-06 22:14:42 +08:00
} else {
2017-02-07 15:40:23 +08:00
var key = ""
var value = ""
if items.count == 1 {
key = "unknown"
value = items[0]
} else {
key = items[0]
value = items[1].trimmingCharacters(in: .whitespaces)
}
2017-02-06 22:14:42 +08:00
decrypted_addtions.append(AdditionField(title: key, content: value))
}
2017-02-06 14:28:57 +08:00
}
2017-02-07 15:40:23 +08:00
i += 1
2017-02-06 14:28:57 +08:00
})
2017-02-06 22:14:42 +08:00
password = Password(name: name!, username: username, password: decrypted_password, additions: decrypted_addtions)
return password
}
}