On Wed, Mar 23, 2005 at 05:13:14AM +0200, Chris Knipe wrote:
> Lo all,
>
> This has been to the perl mailing lists as well, there is nothing wrong
> with the code as far as every one knows... rlm_perl just doesn't like this
> for some reason....
>
> Snipets of the script in question:
> $RAD_REPLY{'Acct-Interim-Interval'} = "300";
> $RAD_REPLY{'MS-MPPE-Encryption-Policy'} = "1";
> $RAD_REPLY{'MS-MPPE-Encryption-Types'} = "LS";
> $RAD_REPLY{'Rate-Limit'} = "256k/512k";
> $RAD_REPLY{'Recv-Limit'} = $BytesAvail - $BytesUsed;
> $RAD_REPLY{'Xmit-Limit'} = $BytesAvail - $BytesUsed;
> $RAD_REPLY{'Reply-Message'} = "You have " .
> $za->format_bytes($BytesAvail - $BytesUsed) . " available.";
> $RAD_REPLY{'Session-Timeout'} = "86400";
>
> Righty. From the above, EVERYTHING gets returned (radiusd -X reports that
> rlm_perl added the values) with the EXCEPTION of Recv-Limit and Xmit-Limit.
> *IF* I add physical values to Recv-Limit, Xmit-Limit, then radiusd -X finds
> the attributes and add them to the reply packet.
>
Basically rlm_perl expects in a hash value - string not number. for
example '1' instead 1. It is well known issue and will be fixed soon.
> So basically:
> $RAD_REPLY{'Recv-Limit'} = $BytesAvail - $BytesUsed;
> $RAD_REPLY{'Xmit-Limit'} = $BytesAvail - $BytesUsed;
> doesn't work
> $RAD_REPLY{'Recv-Limit'} = 23423424;
> $RAD_REPLY{'Xmit-Limit'} = 23234242;
> works
>
> Strange as well, is that format_bytes successfully completes the formating
> and the calculation. Thus, there is also nothing wrong in my code. A
> further test I did to verify my code, which also worked (and not on FR -
> rlm_perl):
>
> <snip>
> #!/usr/bin/perl
>
> use strict;
> use warnings;
>
> use Data::Dumper 'Dumper';
>
> my( $BytesAvail, $BytesUsed ) = (20971521, 1);
>
> {
> my %RAD_REPLY;
> $RAD_REPLY{'Recv-Limit'} = "20971520";
> $RAD_REPLY{'Xmit-Limit'} = "20971520";
> print Dumper \%RAD_REPLY;
> }
>
>
>
> {
> my %RAD_REPLY;
> $RAD_REPLY{'Recv-Limit'} = $BytesAvail - $BytesUsed;
> $RAD_REPLY{'Xmit-Limit'} = $BytesAvail - $BytesUsed;
> print Dumper \%RAD_REPLY;
> }
>
> __END__
> </snip>
>
> also works flawlessly.....
>
> Hope someone can give me some clarification.....
>
> --
> Chris.
>
>
> -
> List info/subscribe/unsubscribe? See
> http://www.freeradius.org/list/users.html
--
Best Regards,
Boian Jordanov
SNE
Orbitel - the Internet Company
tel. +359 2 4004 723
-
List info/subscribe/unsubscribe? See http://www.freeradius.org/list/users.html