| Summary | Create the possibility of two alternative authentication modules | 
| Queue | Horde Framework Packages | 
| Queue Version | Git master | 
| Type | Enhancement | 
| State | Feedback | 
| Priority | 1. Low | 
| Owners | ralf.lang (at) ralf-lang (dot) de | 
| Requester | c.denis (at) mrduck (dot) fr | 
| Created | 02/11/2012 (5004 days ago) | 
| Due | |
| Updated | 05/29/2025 (148 days ago) | 
| Assigned | |
| Resolved | |
| Milestone | |
| Patch | Yes | 
Assigned to Ralf Lang
authentication backends.
different base DN in an LDAP DIT! please feel free to contact me if I
can do some testing.
array for example) appeals to me:
$conf['auth']['driver'] = 'multiple_auth';
$conf['auth']['params']['subriver'] = array('module1' , 'module2' ,
'module3', ... )
But I see a Problem to nicely define the parameters to the subsequent
modules, which would need to look something like the following
incredibly long and complex line (nothing like the usual config style):
$conf['auth']['params']['subriver-conf'] = array('module1' =>
array('table' => horde_users', 'username_field' => 'user',... ),
'module2' => array(), 'module3' => array());
Something like this can be realised by using this module multiple
times and adding one authentication module per layer.
'single_validation' config could not be a part of this.
it more general :) If there was to be a driver to choose from multiple
authentication modules, one might as well want to validate the login
in the local password cache, but get it confirmed by a befriended
organisation. (external co-worker, who quits the organisation which
dispatched him to my organisation, would see his account revoked or
blocked)
The one-time-password module I am working on, will only be published
here soon. Though it would be possible to force users to always use a
single-use password, I picture the use-case, where I have the
permanent password saved in my browser on a trusted machine at home
and only use the otp scheme when I am at an airport terminal. Using
such an 'alternative' module would allow to use either authentication
module without modifying the flow of the login mechanism.
admin auth methods would work)
functionality: composite
My previous configuration example illustrates how these two modules
would be combined to provide for admin methods and additionally allow
multiple authentication modules.
I concede this could as well be implemented as an extention of the
existing composite module. Would that seem more useful to you?
authentication driver would be a feature useful to others too, if
implemented like Michael suggested. This could work similar to PAM
allowing multiple authentication backends. Well, you could probably
implement this if you used PAM authentication in Horde. :)
Priority ⇒ 1. Low
State ⇒ Feedback
useful to maintain/distribute in the main code base.
I would be more receptive to a driver that allows a queue of
authentication backends and would traverse the list of backends until
authenticated. But this would be a very simple looping idea: the
'single_validation' config could not be a part of this. That is the
part that is too site-specific (not to mention that this driver is
lacking all details on how the admin auth methods would work).
The good news - this should be easy enough for you to maintain
locally. You just need to name your Auth class to something that can
be autoloaded, and then just set $conf['auth']['driver'] in
horde/config/conf.php to the full name of your Auth class (e.g.
'Horde_Auth_Foo').
Priority ⇒ 2. Medium
Type ⇒ Enhancement
Summary ⇒ Create the possibility of two alternative authentication modules
Queue ⇒ Horde Framework Packages
Milestone ⇒
Patch ⇒ Yes
New Attachment: 0001-dual-auth-module.patch
State ⇒ New
if the format of my request/patch does not comply, please be patient
with someone new to it. I will be happy to correct any mistakes
pointed out.
This is a stacking auth module (cf. Horde_Auth_Composite), which
allows to use two authentication modules. The main usecase is to
either validate the pwd against two different backends, or to validate
against at least one backend. (patch attached)
This is to facilitate the integration of a one-time-password scheme
under development. The user would choose which password to enter
(permanent vs. otp) and it could be processed.
An example configuration usecase would look like this:
$conf['auth']['driver'] = 'composite';
$conf['auth']['params']['admin_driver']['driver'] = 'sql';
$conf['auth']['params']['auth_driver']['driver'] = 'dual';
$conf['auth']['params']['auth_driver']['params']['single_validation'] = true;
$conf['auth']['params']['auth_driver']['params']['auth1_driver']['driver'] =
'sql';
$conf['auth']['params']['auth_driver']['params']['auth2_driver']['driver'] =
'one-time-password-mechanism'
Any feedback on implementations and/or enhancements very appreciated.
Best regards,
Carl
PS: Priority is medium, as I would like to build other features on top
of this one. Please correct it, if it is too high.