1 package App::EzPz::UserStore;
3 use Module::Runtime qw(use_module);
4 use Scalar::Util 'blessed';
10 return $_[0] if blessed($_[0]);
11 return use_module('App::EzPz::EzmlmConfig')->new($_[0]);
15 has htpasswd_file => (is => 'ro', required => 1);
17 has _htpasswd => (is => 'lazy');
19 sub _build__htpasswd {
21 return use_module('Authen::Htpasswd')->new($self->htpasswd_file);
26 return map $self->_inflate_user($_), $self->_htpasswd->all_users;
30 my ($self, $name) = @_;
31 if (my $htp_user = $self->_htpasswd->lookup_user($name)) {
32 return $self->_inflate_user($htp_user);
39 my ($self, $user) = @_;
40 unless (blessed($user)) {
41 $user = use_module('App::EzPz::User')->new($user);
43 my $htp_file = $self->_htpasswd;
44 my $htp_user = $user->_htpasswd_user;
45 $htp_file->add_user($htp_user);
46 $htp_user->file($htp_file);
47 $user->_set_ezmlm_config($self->ezmlm_config);
52 my ($self, $user) = @_;
53 $self->_htpasswd->remove_user($user->_htpasswd_user);
58 my ($self, $htp_user) = @_;
59 return use_module('App::EzPz::User')->new(
60 htpasswd_user => $htp_user,
61 ezmlm_config => $self->ezmlm_config,
66 my ($self, $name, $password) = @_;
67 return unless my $user = $self->get($name);
68 return $user->check_password($password);