X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2Fcust_payby.pm;h=704741f3dc4304f2cc1b12cdafad805c27221756;hb=e95a28ea14289ffcfa652bff9b179d3820b56242;hp=e25d73ecd34ebd3bb121d62a63e58aa325386cbe;hpb=375b84b1dcca3fb2f71aa3ac63281164501acc1e;p=freeside.git diff --git a/FS/FS/cust_payby.pm b/FS/FS/cust_payby.pm index e25d73ecd..704741f3d 100644 --- a/FS/FS/cust_payby.pm +++ b/FS/FS/cust_payby.pm @@ -159,8 +159,9 @@ sub insert { local $FS::UID::AutoCommit = 0; my $dbh = dbh; - my $error = $self->check_payinfo_cardtype - || $self->SUPER::insert; + my $error = $self->check_payinfo_cardtype if $self->payby =~/^(CARD|DCRD)$/; + $self->SUPER::insert unless $error; + if ( $error ) { $dbh->rollback if $oldAutoCommit; return $error; @@ -349,7 +350,7 @@ sub check { my $payinfo = $self->payinfo; $payinfo =~ s/\D//g; - $payinfo =~ /^(\d{13,16}|\d{8,9})$/ + $payinfo =~ /^(\d{13,19}|\d{8,9})$/ or return gettext('invalid_card'); #. ": ". $self->payinfo; $payinfo = $1; $self->payinfo($payinfo); @@ -357,14 +358,15 @@ sub check { or return gettext('invalid_card'); # . ": ". $self->payinfo; # see parallel checks in check_payinfo_cardtype & payinfo_Mixin::payinfo_check - my $cardtype = ''; + my $cardtype = $self->paycardtype; if ( $self->tokenized ) { + $self->set('is_tokenized', 'Y'); #so we don't try to do it again if ( $self->paymask =~ /^\d+x/ ) { $cardtype = cardtype($self->paymask); } else { - $cardtype = ''; #return "paycardtype required ". - # "(can't derive from a token and no paymask w/prefix provided)"; + # "(can't derive from a token and no paymask w/prefix provided)" + # unless $cardtype; } } else { $cardtype = cardtype($self->payinfo); @@ -559,6 +561,7 @@ sub check_payinfo_cardtype { # see parallel checks in cust_payby::check & payinfo_Mixin::payinfo_check if ( $self->tokenized($payinfo) ) { + $self->set('is_tokenized', 'Y'); #so we don't try to do it again if ( $self->paymask =~ /^\d+x/ ) { $self->set('paycardtype', cardtype($self->paymask)); } else {