| 
									
										
										
										
											2009-11-17 13:00:45 -05:00
										 |  |  | The LDAP Authentication plugin allows for StatusNet to handle authentication | 
					
						
							|  |  |  | through LDAP. | 
					
						
							| 
									
										
										
										
											2009-11-05 13:59:19 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | Installation | 
					
						
							|  |  |  | ============ | 
					
						
							| 
									
										
										
										
											2009-11-17 13:00:45 -05:00
										 |  |  | add "addPlugin('ldapAuthentication', | 
					
						
							|  |  |  |     array('setting'=>'value', 'setting2'=>'value2', ...);" | 
					
						
							|  |  |  | to the bottom of your config.php | 
					
						
							| 
									
										
										
										
											2009-11-05 13:59:19 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 16:27:20 -05:00
										 |  |  | Settings | 
					
						
							|  |  |  | ======== | 
					
						
							| 
									
										
										
										
											2010-02-24 22:29:46 -05:00
										 |  |  | provider_name*: This is a identifier designated to the connection. | 
					
						
							|  |  |  |     It's how StatusNet will refer to the authentication source. | 
					
						
							|  |  |  |     For the most part, any name can be used, so long as each authentication source has a different identifier. | 
					
						
							|  |  |  |     In most cases there will be only one authentication source used. | 
					
						
							| 
									
										
										
										
											2009-11-17 13:00:45 -05:00
										 |  |  | authoritative (false): Set to true if LDAP's responses are authoritative | 
					
						
							|  |  |  |     (if authorative and LDAP fails, no other password checking will be done). | 
					
						
							|  |  |  | autoregistration (false): Set to true if users should be automatically created | 
					
						
							|  |  |  |     when they attempt to login. | 
					
						
							|  |  |  | email_changeable (true): Are users allowed to change their email address? | 
					
						
							|  |  |  |     (true or false) | 
					
						
							|  |  |  | password_changeable (true): Are users allowed to change their passwords? | 
					
						
							|  |  |  |     (true or false) | 
					
						
							| 
									
										
										
										
											2009-11-17 23:22:19 -05:00
										 |  |  | password_encoding: required if users are to be able to change their passwords | 
					
						
							|  |  |  |     Possible values are: crypt, ext_des, md5crypt, blowfish, md5, sha, ssha, | 
					
						
							|  |  |  |         smd5, ad, clear | 
					
						
							| 
									
										
										
										
											2009-11-17 13:00:45 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | host*: LDAP server name to connect to. You can provide several hosts in an | 
					
						
							|  |  |  |     array in which case the hosts are tried from left to right. | 
					
						
							|  |  |  |     See http://pear.php.net/manual/en/package.networking.net-ldap2.connecting.php | 
					
						
							|  |  |  | port: Port on the server. | 
					
						
							|  |  |  |     See http://pear.php.net/manual/en/package.networking.net-ldap2.connecting.php | 
					
						
							|  |  |  | version: LDAP version. | 
					
						
							|  |  |  |     See http://pear.php.net/manual/en/package.networking.net-ldap2.connecting.php | 
					
						
							|  |  |  | starttls: TLS is started after connecting. | 
					
						
							|  |  |  |     See http://pear.php.net/manual/en/package.networking.net-ldap2.connecting.php | 
					
						
							|  |  |  | binddn: The distinguished name to bind as (username). | 
					
						
							|  |  |  |     See http://pear.php.net/manual/en/package.networking.net-ldap2.connecting.php | 
					
						
							|  |  |  | bindpw: Password for the binddn. | 
					
						
							|  |  |  |     See http://pear.php.net/manual/en/package.networking.net-ldap2.connecting.php | 
					
						
							|  |  |  | basedn*: LDAP base name (root directory). | 
					
						
							|  |  |  |     See http://pear.php.net/manual/en/package.networking.net-ldap2.connecting.php | 
					
						
							| 
									
										
										
										
											2009-11-10 16:27:20 -05:00
										 |  |  | options: See http://pear.php.net/manual/en/package.networking.net-ldap2.connecting.php | 
					
						
							| 
									
										
										
										
											2009-11-17 13:00:45 -05:00
										 |  |  | filter: Default search filter. | 
					
						
							|  |  |  |     See http://pear.php.net/manual/en/package.networking.net-ldap2.connecting.php | 
					
						
							|  |  |  | scope: Default search scope. | 
					
						
							|  |  |  |     See http://pear.php.net/manual/en/package.networking.net-ldap2.connecting.php | 
					
						
							| 
									
										
										
										
											2009-12-18 18:27:45 -06:00
										 |  |  | schema_cachefile: File location to store ldap schema. | 
					
						
							|  |  |  | schema_maxage: TTL for cache file. | 
					
						
							| 
									
										
										
										
											2009-11-05 13:59:19 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-17 13:00:45 -05:00
										 |  |  | attributes: an array that relates StatusNet user attributes to LDAP ones | 
					
						
							|  |  |  |     username*: LDAP attribute value entered when authenticating to StatusNet | 
					
						
							|  |  |  |     nickname*: LDAP attribute value shown as the user's nickname | 
					
						
							| 
									
										
										
										
											2009-11-10 16:27:20 -05:00
										 |  |  |     email | 
					
						
							|  |  |  |     fullname | 
					
						
							|  |  |  |     homepage | 
					
						
							|  |  |  |     location | 
					
						
							| 
									
										
										
										
											2009-11-17 23:22:19 -05:00
										 |  |  |     password: required if users are to be able to change their passwords | 
					
						
							| 
									
										
										
										
											2009-11-17 13:00:45 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 16:27:20 -05:00
										 |  |  | * required | 
					
						
							| 
									
										
										
										
											2009-11-10 17:54:24 -05:00
										 |  |  | default values are in (parenthesis) | 
					
						
							| 
									
										
										
										
											2009-11-10 16:27:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-17 13:00:45 -05:00
										 |  |  | For most LDAP installations, the "nickname" and "username" attributes should | 
					
						
							|  |  |  |     be the same. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 16:27:20 -05:00
										 |  |  | Example | 
					
						
							|  |  |  | ======= | 
					
						
							| 
									
										
										
										
											2009-11-17 13:00:45 -05:00
										 |  |  | Here's an example of an LDAP plugin configuration that connects to | 
					
						
							|  |  |  |     Microsoft Active Directory. | 
					
						
							| 
									
										
										
										
											2009-11-10 16:27:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-11 12:16:58 -05:00
										 |  |  | addPlugin('ldapAuthentication', array( | 
					
						
							| 
									
										
										
										
											2009-11-12 20:12:00 -05:00
										 |  |  |     'provider_name'=>'Example', | 
					
						
							| 
									
										
										
										
											2009-11-11 12:16:58 -05:00
										 |  |  |     'authoritative'=>true, | 
					
						
							| 
									
										
										
										
											2009-11-10 17:54:24 -05:00
										 |  |  |     'autoregistration'=>true, | 
					
						
							| 
									
										
										
										
											2009-11-10 16:27:20 -05:00
										 |  |  |     'binddn'=>'username', | 
					
						
							|  |  |  |     'bindpw'=>'password', | 
					
						
							|  |  |  |     'basedn'=>'OU=Users,OU=StatusNet,OU=US,DC=americas,DC=global,DC=loc', | 
					
						
							|  |  |  |     'host'=>array('server1', 'server2'), | 
					
						
							| 
									
										
										
										
											2009-11-17 23:22:19 -05:00
										 |  |  |     'password_encoding'=>'ad', | 
					
						
							| 
									
										
										
										
											2009-11-10 16:27:20 -05:00
										 |  |  |     'attributes'=>array( | 
					
						
							| 
									
										
										
										
											2009-11-17 13:00:45 -05:00
										 |  |  |         'username'=>'sAMAccountName', | 
					
						
							| 
									
										
										
										
											2009-11-10 16:27:20 -05:00
										 |  |  |         'nickname'=>'sAMAccountName', | 
					
						
							|  |  |  |         'email'=>'mail', | 
					
						
							| 
									
										
										
										
											2009-11-17 23:22:19 -05:00
										 |  |  |         'fullname'=>'displayName', | 
					
						
							|  |  |  |         'password'=>'unicodePwd') | 
					
						
							| 
									
										
										
										
											2009-11-10 16:27:20 -05:00
										 |  |  | )); | 
					
						
							| 
									
										
										
										
											2009-11-17 13:00:45 -05:00
										 |  |  | 
 |