diff options
author | Daniel Friesel <derf@finalrewind.org> | 2011-05-17 14:20:14 +0200 |
---|---|---|
committer | Daniel Friesel <derf@finalrewind.org> | 2011-05-17 14:21:15 +0200 |
commit | 391929448038a478f23cfa28db528e1f4a1e60d9 (patch) | |
tree | 956c28ac7ead9b0852dbe2b716eff4fa8b356a6c /lib/App | |
parent | 86d8310d5724632f2cd54723e9a2ced66bb80ba9 (diff) |
Add "raps2 edit"
Diffstat (limited to 'lib/App')
-rw-r--r-- | lib/App/Raps2.pm | 76 | ||||
-rw-r--r-- | lib/App/Raps2/UI.pm | 4 |
2 files changed, 66 insertions, 14 deletions
diff --git a/lib/App/Raps2.pm b/lib/App/Raps2.pm index 32e46f6..9d43364 100644 --- a/lib/App/Raps2.pm +++ b/lib/App/Raps2.pm @@ -197,6 +197,17 @@ sub load_config { $self->{default}->{cost} //= $cfg{cost}; } +=item $raps2->pw() + +Returns the App::Raps2::Password(3pm) object. + +=cut + +sub pw { + my ($self) = @_; + return $self->{pass}; +} + =item $raps2->ui() Returns the App::Raps2::UI(3pm) object. @@ -230,11 +241,11 @@ sub cmd_add { my $pass = $self->ui->read_pw('Password', 1); my $extra = $self->ui->read_multiline('Additional content'); - $self->{pass}->salt($salt); - my $pass_hash = $self->{pass}->encrypt($pass); + $self->pw->salt($salt); + my $pass_hash = $self->pw->encrypt($pass); my $extra_hash = ( $extra ? - $self->{pass}->encrypt($extra) : + $self->pw->encrypt($extra) : q{} ); @@ -249,9 +260,9 @@ sub cmd_add { ); } -=item $raps2->cmd_dump(I<$name>) +=item $raps2->cmd_dump(I<$account>) -Dumps the content of $name. +Dumps the content of I<account> =cut @@ -267,16 +278,59 @@ sub cmd_dump { $self->get_master_password(); - $self->{pass}->salt($key{salt}); + $self->pw->salt($key{salt}); $self->ui()->output( ['URL', $key{url}], ['Login', $key{login}], - ['Password', $self->{pass}->decrypt($key{hash})], + ['Password', $self->pw->decrypt($key{hash})], ); if ($key{extra}) { - print $self->{pass}->decrypt($key{extra}); + print $self->pw->decrypt($key{extra}); + } +} + +=item $raps2->cmd_edit(I<$acount>) + +Edit I<account>. + +=cut + +sub cmd_edit { + my ($self, $name) = @_; + my $pwfile = $self->{xdg_data} . "/${name}"; + my $pass_hash; + + if (not -e $pwfile) { + confess('Password file does not exist'); + } + + my %key = $self->file_to_hash($pwfile); + + $self->get_master_password(); + $self->pw->salt($key{salt}); + + my $salt = $key{salt}; + my $url = $self->ui->read_line('URL', $key{url}); + my $login = $self->ui->read_line('Login', $key{login}); + my $pass = $self->ui->read_pw('New password (empty to keep old)', 1); + my $extra = $key{extra} // q{}; + + if (length($pass)) { + $pass_hash = $self->pw->encrypt($pass); + } + else { + $pass_hash = $key{hash}; } + + write_file( + $pwfile, + "url ${url}\n", + "login ${login}\n", + "salt ${salt}\n", + "hash ${pass_hash}\n", + "extra ${extra}\n", + ); } =item $raps2->cmd_get(I<$name>) @@ -297,12 +351,12 @@ sub cmd_get { $self->get_master_password(); - $self->{pass}->salt($key{salt}); + $self->pw->salt($key{salt}); - $self->ui()->to_clipboard($self->{pass}->decrypt($key{hash})); + $self->ui()->to_clipboard($self->pw->decrypt($key{hash})); if ($key{extra}) { - print $self->{pass}->decrypt($key{extra}) + print $self->pw->decrypt($key{extra}) } } diff --git a/lib/App/Raps2/UI.pm b/lib/App/Raps2/UI.pm index 089290b..9807f52 100644 --- a/lib/App/Raps2/UI.pm +++ b/lib/App/Raps2/UI.pm @@ -32,9 +32,7 @@ sub list { sub read_line { my ($self, $str, $pre) = @_; - $pre //= q{}; - - my $input = $self->{term_readline}->readline("${str}: ${pre}"); + my $input = $self->{term_readline}->readline("${str}: ", $pre); return $input; } |