X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2Fcdr.pm;h=e40b0921a454e2a5e810b4b8e1947ea3a4f4a98d;hb=9d4be18318e5f4baaaa7fd5f995bc307a8dc7f2b;hp=775c79114a9fc4b06b18021a05fe3dce034a56e7;hpb=2b2dd969f3c18751afc583ad1e836ab8e6f73b5d;p=freeside.git diff --git a/FS/FS/cdr.pm b/FS/FS/cdr.pm index 775c79114..e40b0921a 100644 --- a/FS/FS/cdr.pm +++ b/FS/FS/cdr.pm @@ -216,6 +216,7 @@ sub table_info { #'upstream_rateplanid' => '', #'ratedetailnum' => '', 'rated_price' => 'Rated price', + 'rated_cost' => 'Rated cost', #'distance' => '', #'islocal' => '', #'calltypenum' => '', @@ -468,7 +469,9 @@ Sets the status and rated price. Available options are: inbound, rated_pretty_dst, rated_regionname, rated_seconds, rated_minutes, rated_granularity, rated_ratedetailnum, -rated_classnum, rated_ratename. +rated_classnum, rated_ratename, and set_rate_cost (if true, will set +a recalculated L in the rated_cost field after the other +fields are set; does not work with inbound.) If there is an error, returns the error, otherwise returns false. @@ -506,6 +509,8 @@ sub set_status_and_rated_price { qw( pretty_dst regionname seconds minutes granularity ratedetailnum classnum ratename ); $self->svcnum($svcnum) if $svcnum; + $self->rated_cost($self->rate_cost) if $opt{'set_rate_cost'}; + return $self->replace(); } @@ -1005,6 +1010,7 @@ sub rate_prefix { 'rated_ratedetailnum' => $rate_detail->ratedetailnum, 'rated_classnum' => $rate_detail->classnum, #rated_ratedetailnum? 'rated_ratename' => $ratename, #not rate_detail - Intrastate/Interstate + 'set_rate_cost' => 1, ); }