Issue with EAP authentication on packet loss

Arran Cudbard-Bell a.cudbardb at freeradius.org
Wed Apr 25 12:39:47 CEST 2018



> On Apr 25, 2018, at 8:45 PM, Stefan Winter <stefan.winter at RESTENA.LU> wrote:
> 
> Hi,
> 
>> We have a problem when packet loss occurs at step #4 of the EAP dialogue:
>> 1) Access-Request
>> 2) Access-Challenge
>> 3) Access-Request
>> 4) Accept or Reject (in this case: Access-Accept)
>> 5) Access-Request (duplicate)
>> 6) Reject
>> 
>> In this case, #4 is sent by the server but gets lost on its way to the
>> NAS. I've managed to reproduce using iptables dropping the packet. So
>> after some time the NAS sends packet #3 again. At that point I am
>> getting "No EAP session matching state" from the eap module in the
>> "authenticate" section and the request is rejected.
> 
> To be fair, this is not limited to packet loss.
> 
> We've seen this in normal operations - the story goes like:
> - server sends Access-Accept with an attribute X via a chain of proxies
> - some proxy takes offence by the presence of attribute X, discards
> - client times out and re-sends
> - server has forgotten all about the session state, rejects
> 
> I believe the underlying issue is that FreeRADIUS thinks "fire and
> forget" when the final packet is out.

It should cache the response for the duration of cleanup_delay.  If it's not, then that's a bug.

-Arran


More information about the Freeradius-Users mailing list