What you are saying is absolutely correct, and it is entirely possible to do.
It should be included in the distribution.
The -correct- way to do this would be to write a sasl pam module. :) however..
If SASL_IPREMOTEPORT actually gets set by the application, it is
callback to the application through the sasl2 library. IE the data is
not actually passed to the sasl library when the authentication
process starts. It is grabbed at a later point in time if needed.
The sasl2 library sends a data string to saslauthd to do the authentication.
As stated before the string that gets sent only contains 4 values and
there is no interface for the callback to get the data.
The other issue which I am not sure if it has been resolved or not, is
in the definition of PAM_RHOST. Last I checked (a long while ago) it
wasn't specified as to whether it should be an IP# or a hostname.
I -believe- the SASL_IPREMOTEPORT data doesnt actually get sent to
saslauthd for performance reasons. If you do a hostname lookup on the
data, it tends to slow things down. I believe it is also one of the
original reasons why the 4 arguments weren't hardcoded like they are
now.
Quoting fmma@xxxxxx:
In the man pages for the function sasl_getprop
(http://linux.die.net/man/3/sasl_getprop) it mentions that it is possible
to get the remote address string by using SASL_IPREMOTEPORT as input to
the function. I assume that the remote address string would contain a
value suitable for PAM_RHOST. Is this wrong?
If not, then surely it should be possible for saslauthd to assign a value
to RHOST (and maybe other items) before the PAM authentication procedure
commences by calling sasl_getprop and pam_set_item. This may be the code
twiddling you are referring to, but to me it seems rather fundamental and
it is my opinion that this should be included in the distributed packages.
- Frederik
The saslauthd doesnt have an argument for RHOST or any of the other
pam arguments.
It only has 4 arguments available. username, password, realm and mech
(i think).
You can get it to work but you have to twiddle with the code a little bit.
Quoting fmma@xxxxxx:
Why does Cyrus-SASL not populate the PAM environment items (such as
PAM_RHOST) when using the PAM authentication mechanism ? Am I missing
something?
- Frederik