diff options
| -rw-r--r-- | FS/FS/Conf.pm | 8 | ||||
| -rw-r--r-- | FS/FS/svc_acct.pm | 45 | 
2 files changed, 53 insertions, 0 deletions
| diff --git a/FS/FS/Conf.pm b/FS/FS/Conf.pm index faed4ea12..a25f9403f 100644 --- a/FS/FS/Conf.pm +++ b/FS/FS/Conf.pm @@ -1598,6 +1598,14 @@ worry that config_items is freeside-specific and icky.      'select_enum' => [ 'Framed-IP-Address', 'Framed-Address' ],    }, +  #http://dev.coova.org/svn/coova-chilli/doc/dictionary.chillispot +  { +    'key'         => 'radius-chillispot-max', +    'section'     => '', +    'description' => 'Enable ChilliSpot (and CoovaChilli) Max attributes, specifically ChilliSpot-Max-{Input,Output,Total}-{Octets,Gigawords}.', +    'type'        => 'checkbox', +  }, +    {      'key'         => 'svc_acct-alldomains',      'section'     => '', diff --git a/FS/FS/svc_acct.pm b/FS/FS/svc_acct.pm index 5fdd90088..37eaf4a15 100644 --- a/FS/FS/svc_acct.pm +++ b/FS/FS/svc_acct.pm @@ -16,6 +16,7 @@ use vars qw( @ISA $DEBUG $me $conf $skip_fuzzyfiles               $radius_password $radius_ip               $dirhash               @saltset @pw_set ); +use Math::BigInt;  use Carp;  use Fcntl qw(:flock);  use Date::Format; @@ -1393,6 +1394,28 @@ sub radius_reply {      $reply{'Session-Timeout'} = $self->seconds;    } +  if ( $conf->exists('radius-chillispot-max') ) { +    #http://dev.coova.org/svn/coova-chilli/doc/dictionary.chillispot + +    #hmm.  just because sqlradius.pm says so? +    my %whatis = ( +      'input'  => 'up', +      'output' => 'down', +      'total'  => 'total', +    ); + +    foreach my $what (qw( input output total )) { +      my $is = $whatis{$what}.'bytes'; +      if ( $self->$is() =~ /\d/ ) { +        my $big = new Math::BigInt $self->$is(); +        my $att = "Chillispot-Max-\u$what"; +        $reply{"$att-Octets"}    = $big->copy->band(0xffffffff)->bstr; +        $reply{"$att-Gigawords"} = $big->copy->brsft(32)->bstr; +      } +    } + +  } +    %reply;  } @@ -1687,6 +1710,16 @@ sub _op_usage {    die "Can't update $column for svcnum". $self->svcnum      if $rv == 0; +  #$self->snapshot; #not necessary, we retain the old values +  #create an object with the updated usage values +  my $new = qsearchs('svc_acct', { 'svcnum' => $self->svcnum }); +  #call exports +  my $error = $new->replace($self); +  if ( $error ) { +    $dbh->rollback if $oldAutoCommit; +    return "Error replacing: $error"; +  } +    #overlimit_action eq 'cancel' handling    my $cust_pkg = $self->cust_svc->cust_pkg;    if ( $cust_pkg @@ -1840,6 +1873,16 @@ sub set_usage {        if $rv == 0;    } +  #$self->snapshot; #not necessary, we retain the old values +  #create an object with the updated usage values +  my $new = qsearchs('svc_acct', { 'svcnum' => $self->svcnum }); +  #call exports +  my $error = $new->replace($self); +  if ( $error ) { +    $dbh->rollback if $oldAutoCommit; +    return "Error replacing: $error"; +  } +    if ( $reset ) {      my $error; @@ -2509,6 +2552,8 @@ probably live somewhere else...  insertion of RADIUS group stuff in insert could be done with child_objects now  (would probably clean up export of them too) +_op_usage and set_usage bypass the history... maybe they shouldn't +  =head1 SEE ALSO  L<FS::svc_Common>, edit/part_svc.cgi from an installed web interface, | 
