X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2Fcontact.pm;fp=FS%2FFS%2Fcontact.pm;h=568d46f07d230494315e916c64f916a28e84d761;hb=59776b97e0d82e30e9a50c76d16f302309fff76d;hp=a873fda472d854e0d4b5ac185a1901af3923eb43;hpb=53427a0d7b74c16d646196e70c95971471e1fae8;p=freeside.git diff --git a/FS/FS/contact.pm b/FS/FS/contact.pm index a873fda47..568d46f07 100644 --- a/FS/FS/contact.pm +++ b/FS/FS/contact.pm @@ -577,6 +577,15 @@ sub replace { } } + if ( $self->get('password') ) { + my $error = $self->is_password_allowed($self->get('password')) + || $self->change_password($self->get('password')); + if ( $error ) { + $dbh->rollback if $oldAutoCommit; + return $error; + } + } + $dbh->commit or die $dbh->errstr if $oldAutoCommit; ''; @@ -663,7 +672,7 @@ and replace methods. sub check { my $self = shift; - if ( $self->selfservice_access eq 'R' ) { + if ( $self->selfservice_access eq 'R' || $self->selfservice_access eq 'P' ) { $self->selfservice_access('Y'); $self->_resend('Y'); } @@ -945,7 +954,7 @@ sub cgi_contact_fields { my @contact_fields = qw( classnum first last title comment emailaddress selfservice_access - invoice_dest + invoice_dest password ); push @contact_fields, 'phonetypenum'. $_->phonetypenum