Added comment option when generating key

This commit is contained in:
Alex Lavallee 2020-11-29 21:15:59 -08:00
parent 4fb637eb11
commit 350ecffdc7
No known key found for this signature in database
GPG Key ID: 8F315EDD6F62C73B
2 changed files with 26 additions and 2 deletions

View File

@ -5,9 +5,10 @@ struct CreateSecretView<StoreType: SecretStoreModifiable>: View {
@ObservedObject var store: StoreType
@Binding var showing: Bool
@State private var comment = ""
@State private var name = ""
@State private var requiresAuthentication = true
let defaults = UserDefaults.standard
var body: some View {
VStack {
@ -25,6 +26,10 @@ struct CreateSecretView<StoreType: SecretStoreModifiable>: View {
Text("Name:")
TextField("Shhhhh", text: $name).focusable()
}
HStack {
Text("Comment:")
TextField("\(dashedUserName)@\(dashedHostName)", text: $comment).focusable()
}
HStack {
Toggle(isOn: $requiresAuthentication) {
Text("Requires Authentication (Biometrics or Password)")
@ -45,9 +50,22 @@ struct CreateSecretView<StoreType: SecretStoreModifiable>: View {
}
}.padding()
}
var dashedUserName: String {
NSUserName().replacingOccurrences(of: " ", with: "-")
}
var dashedHostName: String {
[Host.current().localizedName, "local"]
.compactMap { $0 }
.joined(separator: ".")
.replacingOccurrences(of: " ", with: "-")
}
func save() {
try! store.create(name: name, requiresAuthentication: requiresAuthentication)
if comment != "" {
defaults.set(comment, forKey: name)
}
defaults.set(comment, forKey: name)
showing = false
}
}

View File

@ -5,6 +5,8 @@ struct SecretDetailView<SecretType: Secret>: View {
@State var secret: SecretType
let defaults = UserDefaults.standard
private let keyWriter = OpenSSHKeyWriter()
var body: some View {
@ -33,7 +35,11 @@ struct SecretDetailView<SecretType: Secret>: View {
}
var keyString: String {
keyWriter.openSSHString(secret: secret, comment: "\(dashedUserName)@\(dashedHostName)")
if defaults.string(forKey: secret.name) != "" {
return keyWriter.openSSHString(secret: secret, comment: defaults.string(forKey: secret.name))
} else {
return keyWriter.openSSHString(secret: secret, comment: "\(dashedUserName)@\(dashedHostName)")
}
}
func copy() {