[RADIATOR] Getting attributes in hooks
Heikki Vatiainen
hvn at open.com.au
Tue Aug 20 09:48:52 UTC 2019
On 16/08/2019 23.10, David Rose wrote:
> For example I found these for getting user names:
>
> - $p->getUserName
> - $p->get_attr('User-Name')
> - $p->getAttrByNum($Radius::Radius::USER_NAME)
>
> All seem to be capable of doing the same thing. Even in our hooks there
> are differences in which is used and I would prefer to change this so
> that our hooks are at least consistent (unless there is reason not to do
> so).
For user name, I recommend using getUserName just as Frank suggested.
User-Name is often rewritten and modified and thus has its own helper
function. Related functions are getOriginalUserName and changeUserName.
If you need to update User-Name, changeUserName should be used.
> Are there reasons to use one over the other? For example, do some have
> better performance or take up fewer resources? Perhaps there are
> specific use cases when one should be used over another? Or maybe some
> are decprecated and should be avoided?
getAttrByNum Hugh mentioned works for the limited number of attributed
listed by their numbers in Radius.pm. A cache is looked up first. If
there's a miss then number is resolved to name before doing
get_attr('Attrib-Name') and caching the value.
In short, $p->get_attr('Attrib-Name') for any attribute is the most
consistent method. It works for getting the value or values of all
standard and vendor-specific attributes.
The exception is User-Name which should be modified and accessed as above.
Some attribute lookups, such as Acct-Session-Id and Acct-Status-Type can
get looked up multiple times during processing and caching can be useful
for those. The *AttrByNum call, for example get_attr(), but they also
maintain the cached values.
If you need to add new attributes, use add_attr(). If you need to change
or delete existing the attribues listed in Radius.pm and accessed by any
of *AttrByNum functions, then more care is needed. Those should be
changed and deleted with the respective *AttrByNum functions. Modifying
these may not often be needed in hooks, except of User-Name which has
its own accessors.
> I just want to make sure that I make the best choices while cleaning up
> our own code and couldn't find anything documenting the differences.
> Thank you in advance for any information you provide.
I hope the above and what the others wrote clarifies this.
Thanks,
Heikki
--
Heikki Vatiainen <hvn at open.com.au>
Radiator: the most portable, flexible and configurable RADIUS server
anywhere. SQL, proxy, DBM, files, LDAP, TACACS+, PAM, Active Directory,
EAP, TLS, TTLS, PEAP, WiMAX, RSA, Vasco, Yubikey, HOTP, TOTP,
DIAMETER etc. Full source on Unix, Windows, MacOSX, Solaris, VMS, etc.
More information about the radiator
mailing list