Nulls embedded in Cisco-AVPairs
Alan DeKok
aland at deployingradius.com
Sun Jun 11 22:11:56 CEST 2017
On Jun 10, 2017, at 3:09 PM, Brian Weis (bew) <bew at cisco.com> wrote:
> However, some of the Cisco-AVPairs we’re wanting to parse contain zeros in the value, such as
>
> Cisco-AVPair = "lldp-tlv=\000\005\000\013raspberrypi"
While embedded zeros are allowed in string attributes, they do cause problems.
The best solution here would be to decode the lldp-tlv into LLDP attributes. But it looks like (from a cursory google search) that "lldp-tlv=..." can contain pretty much anything, and not just binary LLDP TLVs.
> Looking in the code, I see that both the full and trunctated log entries are the output of fr_pair_value_snprint(). The call that display the full value specifies ‘“‘ as a quote value, which results in it representing the non-printable characters as octal values. But the call that creates a string for regular expression processing (the EXPAND X string) specifies no quote value, which results in a string truncated at the first zero byte. Note that not only is the value shorted in the log above, but the regular expression processing uses this string as well. This effectively doesn’t allow regular expression processing matching strings following the zero in the value.
Yeah. The string expansion works on C strings. The whole API is missing a "length" parameter. Fixing that is non-trivial.
> This truncation seems to be because some regular expression libraries do not safely process nulls. These are messages I received when changing the quote variable to ‘“' for debugging purposes:
>
> ERROR : (57) regex failed: Found null in subject at offset 9. String unsafe for evaluation
At least the server figured out what's wrong and told you, instead of allowing a bad regex library to crash the system.
Yes, that's why the checks are there. :(
> ERROR : (57) Condition evaluation failed because the value of an operand could not be determined
>
> I’ve tried many different string representations in the code snippet above and nothing changes this behavior. But I also can’t find a way to transform Foreach-Variable-0 such that it can be given to another module for processing … always the fr_pair_value_snprint() call with a zero quote value in is used, which truncates the string. This is the call in in xlat_foreach().
I think there should be a way to fix that...the main thing would be to treat the Foreach-Variable-... attribute as the correct type, instead of printing it.
> There is a FreeRADIUS compile option to use regex code where nulls are safe within the value (i.e., regnexec), which would seem to avoid the message above. But that does not seem sufficient as the current code in xlat_foreach() would still provide a truncated string to the regex library.
Yeah...
> Suggestions for a workaround?
>
> I’m using FreeRADIUS 3.1.0.
Use the v4.0.x branch. It is (or should be) stable on a day to day basis. The test framework ensures that every individual piece of the server works.
But the internal API is being massively re-architected. In order to fix this, and many other little issues.
The short way in 3.1.0 to fix this is to just write a C module to look for this attribute, and do the right thing.
We're looking at adding native Lua support into v4, which should make all of this much, much, easier.
Alan DeKok.
More information about the Freeradius-Users
mailing list