support edit password
This commit is contained in:
parent
41d45bfbf9
commit
b2ee8c429f
14 changed files with 459 additions and 72 deletions
|
|
@ -19,43 +19,34 @@ class Password {
|
|||
var password = ""
|
||||
var additions = [String: String]()
|
||||
var additionKeys = [String]()
|
||||
var plainText = ""
|
||||
var changed = false
|
||||
|
||||
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, password: String, additionsArray: [AdditionField]) {
|
||||
init(name: String, plainText: String) {
|
||||
let plainTextSplit = plainText.characters.split(maxSplits: 1, omittingEmptySubsequences: false) {
|
||||
$0 == "\n" || $0 == "\r\n"
|
||||
}.map(String.init)
|
||||
let password = plainTextSplit[0]
|
||||
let additionFieldsArray = Password.getAdditionFields(from: plainTextSplit[1])
|
||||
// self.init(name: name, password: password, additionsArray: additionFieldsArray)
|
||||
self.name = name
|
||||
self.password = password
|
||||
for additionField in additionsArray {
|
||||
self.plainText = plainText
|
||||
for additionField in additionFieldsArray {
|
||||
self.additions[additionField.title] = additionField.content
|
||||
self.additionKeys.append(additionField.title)
|
||||
}
|
||||
}
|
||||
|
||||
// private convenience init(name: String, password: String, additionsArray: [AdditionField]) {
|
||||
// self.name = name
|
||||
// self.password = password
|
||||
// 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")
|
||||
}
|
||||
|
|
@ -64,9 +55,53 @@ class Password {
|
|||
return getAdditionValue(withKey: "URL") ?? getAdditionValue(withKey: "url") ?? getAdditionValue(withKey: "Url")
|
||||
}
|
||||
|
||||
func getPlainText() -> String {
|
||||
static func getAdditionFields(from additionFieldsPlainText: String) -> [AdditionField]{
|
||||
var additionFieldsArray = [AdditionField]()
|
||||
var unkownIndex = 0
|
||||
|
||||
additionFieldsPlainText.enumerateLines() { line, _ in
|
||||
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))
|
||||
}
|
||||
return additionFieldsArray
|
||||
}
|
||||
|
||||
func updatePassword(name: String, plainText: String) {
|
||||
self.name = name
|
||||
if self.plainText != plainText {
|
||||
let plainTextSplit = plainText.characters.split(maxSplits: 1, omittingEmptySubsequences: false) {
|
||||
$0 == "\n" || $0 == "\r\n"
|
||||
}.map(String.init)
|
||||
let password = plainTextSplit[0]
|
||||
let additionFieldsArray = 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
|
||||
}
|
||||
}
|
||||
|
||||
func getAdditionsPlainText() -> String {
|
||||
let plainAdditionsText = self.additionKeys.map { "\($0): \(self.additions[$0]!)" }.joined(separator: "\n")
|
||||
return "\(self.password)\n\(plainAdditionsText)"
|
||||
return plainAdditionsText
|
||||
}
|
||||
|
||||
func getPlainText() -> String {
|
||||
return "\(self.password)\n\(getAdditionsPlainText())"
|
||||
}
|
||||
|
||||
func getPlainData() -> Data {
|
||||
|
|
|
|||
|
|
@ -22,7 +22,6 @@ extension PasswordEntity {
|
|||
|
||||
func encrypt(password: Password) throws -> Data {
|
||||
name = password.name
|
||||
rawPath = ""
|
||||
let plainData = password.getPlainData()
|
||||
let pgp = PasswordStore.shared.pgp
|
||||
let encryptedData = try pgp.encryptData(plainData, usingPublicKey: pgp.getKeysOf(.public)[0], armored: false)
|
||||
|
|
|
|||
|
|
@ -124,7 +124,7 @@ class PasswordStore {
|
|||
]
|
||||
let remote = try GTRemote(name: "origin", in: storeRepository!)
|
||||
try storeRepository?.pull((storeRepository?.currentBranch())!, from: remote, withOptions: options, progress: transferProgressBlock)
|
||||
updatePasswordEntityCoreData()
|
||||
// updatePasswordEntityCoreData()
|
||||
}
|
||||
|
||||
func updatePasswordEntityCoreData() {
|
||||
|
|
@ -214,7 +214,8 @@ class PasswordStore {
|
|||
func updateRemoteRepo() {
|
||||
}
|
||||
|
||||
func createCommitInRepository(message: String, fileData: Data, filename: String, progressBlock: (_ progress: Float) -> Void) -> GTCommit? {
|
||||
|
||||
func addEntryToGTTree(fileData: Data, filename: String) -> GTTree {
|
||||
do {
|
||||
let head = try storeRepository!.headReference()
|
||||
let branch = GTBranch(reference: head, repository: storeRepository!)
|
||||
|
|
@ -224,6 +225,50 @@ class PasswordStore {
|
|||
try treeBulider.addEntry(with: fileData, fileName: filename, fileMode: GTFileMode.blob)
|
||||
|
||||
let newTree = try treeBulider.writeTree()
|
||||
return newTree
|
||||
} catch {
|
||||
fatalError("Failed to add entries to GTTree: \(error)")
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
func removeEntryFromGTTree(filename: String) -> GTTree {
|
||||
do {
|
||||
let head = try storeRepository!.headReference()
|
||||
let branch = GTBranch(reference: head, repository: storeRepository!)
|
||||
let headCommit = try branch?.targetCommit()
|
||||
|
||||
let treeBulider = try GTTreeBuilder(tree: headCommit?.tree, repository: storeRepository!)
|
||||
try treeBulider.removeEntry(withFileName: filename)
|
||||
|
||||
let newTree = try treeBulider.writeTree()
|
||||
return newTree
|
||||
} catch {
|
||||
fatalError("Failed to remove entries to GTTree: \(error)")
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
func createAddCommitInRepository(message: String, fileData: Data, filename: String, progressBlock: (_ progress: Float) -> Void) -> GTCommit? {
|
||||
do {
|
||||
let newTree = addEntryToGTTree(fileData: fileData, filename: filename)
|
||||
let headReference = try storeRepository!.headReference()
|
||||
let commitEnum = try GTEnumerator(repository: storeRepository!)
|
||||
try commitEnum.pushSHA(headReference.targetOID.sha)
|
||||
let parent = commitEnum.nextObject() as! GTCommit
|
||||
progressBlock(0.5)
|
||||
let commit = try storeRepository!.createCommit(with: newTree, message: message, parents: [parent], updatingReferenceNamed: headReference.name)
|
||||
progressBlock(0.7)
|
||||
return commit
|
||||
} catch {
|
||||
print(error)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func createRemoveCommitInRepository(message: String, filename: String, progressBlock: (_ progress: Float) -> Void) -> GTCommit? {
|
||||
do {
|
||||
let newTree = removeEntryFromGTTree(filename: filename)
|
||||
let headReference = try storeRepository!.headReference()
|
||||
let commitEnum = try GTEnumerator(repository: storeRepository!)
|
||||
try commitEnum.pushSHA(headReference.targetOID.sha)
|
||||
|
|
@ -272,13 +317,26 @@ class PasswordStore {
|
|||
passwordEntity.synced = false
|
||||
try context.save()
|
||||
print(saveURL.path)
|
||||
let _ = createCommitInRepository(message: "Add new password by pass for iOS", fileData: encryptedData, filename: saveURL.lastPathComponent, progressBlock: progressBlock)
|
||||
let _ = createAddCommitInRepository(message: "Add new password by pass for iOS", fileData: encryptedData, filename: saveURL.lastPathComponent, progressBlock: progressBlock)
|
||||
progressBlock(1.0)
|
||||
} catch {
|
||||
print(error)
|
||||
}
|
||||
}
|
||||
|
||||
func update(passwordEntity: PasswordEntity, password: Password, progressBlock: (_ progress: Float) -> Void) {
|
||||
do {
|
||||
let encryptedData = try passwordEntity.encrypt(password: password)
|
||||
let saveURL = storeURL.appendingPathComponent(passwordEntity.rawPath!)
|
||||
try encryptedData.write(to: saveURL)
|
||||
passwordEntity.synced = false
|
||||
let _ = createAddCommitInRepository(message: "Update password by pass for iOS", fileData: encryptedData, filename: saveURL.lastPathComponent, progressBlock: progressBlock)
|
||||
try context.save()
|
||||
} catch {
|
||||
fatalError("Failed to fetch employees: \(error)")
|
||||
}
|
||||
}
|
||||
|
||||
func deleteCoreData(entityName: String) {
|
||||
let deleteFetchRequest = NSFetchRequest<NSFetchRequestResult>(entityName: entityName)
|
||||
let deleteRequest = NSBatchDeleteRequest(fetchRequest: deleteFetchRequest)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue