Apply patch from Geoffrey D. Bennett to fix handle RADIUS Class attribute.
Bump heartbeat version to handle Class entry in session (v6). Re-arrange session struct to remove padding. Update cluster code to handle v6 packets. Drop compatability for pre-v5.
This commit is contained in:
parent
750e15fc6c
commit
d2848cebc4
6 changed files with 104 additions and 81 deletions
16
radius.c
16
radius.c
|
|
@ -363,6 +363,13 @@ void radiussend(uint16_t r, uint8_t state)
|
|||
}
|
||||
}
|
||||
|
||||
if (session[s].classlen) {
|
||||
*p = 25; // class
|
||||
p[1] = session[s].classlen + 2;
|
||||
memcpy(p + 2, session[s].class, session[s].classlen);
|
||||
p += p[1];
|
||||
}
|
||||
|
||||
{
|
||||
struct param_radius_account acct = { &tunnel[session[s].tunnel], &session[s], &p };
|
||||
run_plugins(PLUGIN_RADIUS_ACCOUNT, &acct);
|
||||
|
|
@ -818,6 +825,15 @@ void processrad(uint8_t *buf, int len, char socket_index)
|
|||
session[s].ipv6prefixlen = prefixlen;
|
||||
}
|
||||
}
|
||||
else if (*p == 25)
|
||||
{
|
||||
// Class
|
||||
if (p[1] < 3) continue;
|
||||
session[s].classlen = p[1] - 2;
|
||||
if (session[s].classlen > MAXCLASS)
|
||||
session[s].classlen = MAXCLASS;
|
||||
memcpy(session[s].class, p + 2, session[s].classlen);
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (r_code == AccessReject)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue