list name management
[scpubgit/App-EzPz.git] / lib / App / EzPz / UserStore.pm
index 8b0a557..73669c5 100644 (file)
@@ -1,8 +1,7 @@
 package App::EzPz::UserStore;
 
-use App::EzPz::User;
+use Module::Runtime qw(use_module);
 use Scalar::Util 'blessed';
-use Authen::Htpasswd;
 use Moo;
 
 has ezmlm_bindir => (is => 'ro', required => 1);
@@ -13,7 +12,7 @@ has _htpasswd => (is => 'lazy');
 
 sub _build__htpasswd {
   my ($self) = @_;
-  return Authen::Htpasswd->new($self->htpasswd_file);
+  return use_module('Authen::Htpasswd')->new($self->htpasswd_file);
 }
 
 sub all {
@@ -33,12 +32,13 @@ sub get {
 sub add {
   my ($self, $user) = @_;
   unless (blessed($user)) {
-    $user = App::EzPz::User->new($user);
+    $user = use_module('App::EzPz::User')->new($user);
   }
   my $htp_file = $self->_htpasswd;
   my $htp_user = $user->_htpasswd_user;
   $htp_file->add_user($htp_user);
   $htp_user->file($htp_file);
+  $user->_set_ezmlm_bindir($self->ezmlm_bindir);
   return $user;
 }
 
@@ -50,8 +50,9 @@ sub remove {
 
 sub _inflate_user {
   my ($self, $htp_user) = @_;
-  return App::EzPz::User->new(
+  return use_module('App::EzPz::User')->new(
     htpasswd_user => $htp_user,
+    ezmlm_bindir => $self->ezmlm_bindir,
   );
 }