diff options
Diffstat (limited to 'lib/App')
-rw-r--r-- | lib/App/Raps2.pm | 36 | ||||
-rw-r--r-- | lib/App/Raps2/Password.pm | 19 |
2 files changed, 31 insertions, 24 deletions
diff --git a/lib/App/Raps2.pm b/lib/App/Raps2.pm index 9d43364..3b97fa9 100644 --- a/lib/App/Raps2.pm +++ b/lib/App/Raps2.pm @@ -75,23 +75,6 @@ sub new { return bless($ref, $obj); } -=item $raps2->create_salt() - -Returns a 16-character random salt for App::Raps2::Password(3pm). - -=cut - -sub create_salt { - my ($self) = @_; - my $salt = q{}; - - for (1 .. 16) { - $salt .= chr(0x21 + int(rand(90))); - } - - return $salt; -} - =item $raps2->file_to_hash(I<$file>) Reads $file (lines with key/value separated by whitespace) and returns a hash @@ -145,7 +128,7 @@ Asks the user for the master passphrase. sub get_master_password { my ($self) = @_; - my $pass = $self->ui()->read_pw('Master Password', 0); + my $pass = $self->ui->read_pw('Master Password', 0); $self->{pass} = App::Raps2::Password->new( cost => $self->{default}->{cost}, @@ -165,15 +148,14 @@ Creates a default config and asks the user to set a master password. sub create_config { my ($self) = @_; my $cost = 12; - my $salt = $self->create_salt(); - my $pass = $self->ui()->read_pw('Master Password', 1); + my $pass = $self->ui->read_pw('Master Password', 1); $self->{pass} = App::Raps2::Password->new( cost => $cost, - salt => $salt, passphrase => $pass, ); - my $hash = $self->{pass}->crypt(); + my $hash = $self->pw->crypt(); + my $salt = $self->pw->salt(); write_file( $self->{xdg_conf} . '/password', @@ -205,7 +187,13 @@ Returns the App::Raps2::Password(3pm) object. sub pw { my ($self) = @_; - return $self->{pass}; + + if (defined $self->{pass}) { + return $self->{pass}; + } + else { + confess('No App::Raps2::Password object, did you call get_master_password?'); + } } =item $raps2->ui() @@ -235,7 +223,7 @@ sub cmd_add { $self->get_master_password(); - my $salt = $self->create_salt(); + my $salt = $self->pw->create_salt(); my $url = $self->ui->read_line('URL'); my $login = $self->ui->read_line('Login'); my $pass = $self->ui->read_pw('Password', 1); diff --git a/lib/App/Raps2/Password.pm b/lib/App/Raps2/Password.pm index 10431ed..b236b7b 100644 --- a/lib/App/Raps2/Password.pm +++ b/lib/App/Raps2/Password.pm @@ -17,6 +17,10 @@ sub new { $conf{cost} //= 12; + if (not defined $conf{salt}) { + $conf{salt} = create_salt(); + } + if (not (defined $conf{salt} and length($conf{salt}) == 16)) { confess('incorrect salt length'); } @@ -30,9 +34,24 @@ sub new { return bless($ref, $obj); } +sub create_salt { + my ($self) = @_; + my $salt = q{}; + + for (1 .. 16) { + $salt .= chr(0x21 + int(rand(90))); + } + + return $salt; +} + sub salt { my ($self, $salt) = @_; + if (not defined $salt) { + return $self->{salt}; + } + if (not (defined $salt and length($salt) == 16)) { confess('incorrect salt length'); } |