passforios/pass/Models/Password.swift

87 lines
3 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-11 14:30:35 +08:00
var name = ""
var username = ""
var password = ""
var url = ""
var additions = [AdditionField]()
2017-02-11 14:30:35 +08:00
init() { }
2017-02-06 14:28:57 +08:00
2017-02-11 14:30:35 +08:00
convenience init(name: String, username: String, password: String, additions: [AdditionField]) {
self.init(name: name, username: username, password: password, url: "", additions: additions)
2017-02-09 13:17:11 +08:00
}
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-10 22:15:01 +08:00
let encryptedDataPath = URL(fileURLWithPath: "\(Globals.repositoryPath)/\(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
}
2017-02-10 22:15:01 +08:00
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 pgp = PasswordStore.shared.pgp
let encryptedData = try pgp.encryptData(plainData, usingPublicKey: pgp.getKeysOf(.public)[0], armored: false)
return encryptedData
}
}