From 48abf3c98dfe0f1aad6740e09366372136fccc69 Mon Sep 17 00:00:00 2001 From: Ian Duffy Date: Fri, 12 Jul 2013 15:10:48 +0100 Subject: [PATCH] Change ldap docs to suit new implementation --- docs/en-US/LDAP-for-user-authentication.xml | 42 ++++++++++++ .../LDAPserver-for-user-authentication.xml | 39 ------------ docs/en-US/accounts.xml | 6 +- .../example-LDAP-configuration-commands.xml | 47 -------------- .../example-activedirectory-configuration.xml | 43 +++++++++++++ docs/en-US/example-openldap-configuration.xml | 44 +++++++++++++ .../images/add-ldap-configuration-ad.png | Bin 0 -> 31803 bytes .../add-ldap-configuration-openldap.png | Bin 0 -> 30176 bytes docs/en-US/query-filter.xml | 60 ------------------ docs/en-US/search-user-bind-dn.xml | 47 -------------- 10 files changed, 132 insertions(+), 196 deletions(-) create mode 100644 docs/en-US/LDAP-for-user-authentication.xml delete mode 100644 docs/en-US/LDAPserver-for-user-authentication.xml delete mode 100644 docs/en-US/example-LDAP-configuration-commands.xml create mode 100644 docs/en-US/example-activedirectory-configuration.xml create mode 100644 docs/en-US/example-openldap-configuration.xml create mode 100644 docs/en-US/images/add-ldap-configuration-ad.png create mode 100644 docs/en-US/images/add-ldap-configuration-openldap.png delete mode 100644 docs/en-US/query-filter.xml delete mode 100644 docs/en-US/search-user-bind-dn.xml diff --git a/docs/en-US/LDAP-for-user-authentication.xml b/docs/en-US/LDAP-for-user-authentication.xml new file mode 100644 index 00000000000..61f204cf8f6 --- /dev/null +++ b/docs/en-US/LDAP-for-user-authentication.xml @@ -0,0 +1,42 @@ + + +%BOOK_ENTITIES; +]> + + +
+ Using an LDAP Server for User Authentication + You can use an external LDAP server such as Microsoft Active Directory or OpenLDAP to authenticate &PRODUCT; end-users. + To set up LDAP authentication in &PRODUCT;, open the global settings page and set: + + ldap.basedn - The base directory you want to search within for uses + ldap.bind.password - The password you wish to use to bind, this can be blank if the server supports anonymous binding + ldap.bind.principal - The account you wish to use to bind, this can be blank if the server supports anonymous binding + ldap.email.attribute - The attribute within your LDAP server that holds a value for users email address + ldap.realname.attribute - The attribute within your LDAP server that holds a value users realname + ldap.user.object - The object class that identifies a user + ldap.username.attribute - The attribute within your LDAP server that has a value that will match the cloudstack accounts username field + + Finally you can add LDAP servers from Global Settings -> Select View -> LDAP Configuration. This requires a hostname and port + + + + +
diff --git a/docs/en-US/LDAPserver-for-user-authentication.xml b/docs/en-US/LDAPserver-for-user-authentication.xml deleted file mode 100644 index 376631cbbc2..00000000000 --- a/docs/en-US/LDAPserver-for-user-authentication.xml +++ /dev/null @@ -1,39 +0,0 @@ - - -%BOOK_ENTITIES; -]> - - -
- Using an LDAP Server for User Authentication - You can use an external LDAP server such as Microsoft Active Directory or ApacheDS to authenticate &PRODUCT; end-users. Just map &PRODUCT; accounts to the corresponding LDAP accounts using a query filter. The query filter is written using the query syntax of the particular LDAP server, and can include special wildcard characters provided by &PRODUCT; for matching common values such as the user’s email address and name. &PRODUCT; will search the external LDAP directory tree starting at a specified base directory and return the distinguished name (DN) and password of the matching user. This information along with the given password is used to authenticate the user.. - To set up LDAP authentication in &PRODUCT;, call the &PRODUCT; API command ldapConfig and provide the following: - - Hostname or IP address and listening port of the LDAP server - Base directory and query filter - Search user DN credentials, which give &PRODUCT; permission to search on the LDAP server - SSL keystore and password, if SSL is used - - - - - - -
diff --git a/docs/en-US/accounts.xml b/docs/en-US/accounts.xml index aa62f680452..1c4454c6a3f 100644 --- a/docs/en-US/accounts.xml +++ b/docs/en-US/accounts.xml @@ -11,9 +11,9 @@ to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at - + http://www.apache.org/licenses/LICENSE-2.0 - + Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY @@ -25,5 +25,5 @@ Accounts - + diff --git a/docs/en-US/example-LDAP-configuration-commands.xml b/docs/en-US/example-LDAP-configuration-commands.xml deleted file mode 100644 index e557386c3ca..00000000000 --- a/docs/en-US/example-LDAP-configuration-commands.xml +++ /dev/null @@ -1,47 +0,0 @@ - - -%BOOK_ENTITIES; -]> - - - -
- Example LDAP Configuration Commands - To understand the examples in this section, you need to know the basic concepts behind calling the &PRODUCT; API, which are explained in the Developer’s Guide. - The following shows an example invocation of ldapConfig with an ApacheDS LDAP server - http://127.0.0.1:8080/client/api?command=ldapConfig&hostname=127.0.0.1&searchbase=ou%3Dtesting%2Co%3Dproject&queryfilter=%28%26%28uid%3D%25u%29%29&binddn=cn%3DJohn+Singh%2Cou%3Dtesting%2Co%project&bindpass=secret&port=10389&ssl=true&truststore=C%3A%2Fcompany%2Finfo%2Ftrusted.ks&truststorepass=secret&response=json&apiKey=YourAPIKey&signature=YourSignatureHash - The command must be URL-encoded. Here is the same example without the URL encoding: - http://127.0.0.1:8080/client/api?command=ldapConfig -&hostname=127.0.0.1 -&searchbase=ou=testing,o=project -&queryfilter=(&(%uid=%u)) -&binddn=cn=John+Singh,ou=testing,o=project -&bindpass=secret -&port=10389 -&ssl=true -&truststore=C:/company/info/trusted.ks -&truststorepass=secret -&response=json -&apiKey=YourAPIKey&signature=YourSignatureHash - - The following shows a similar command for Active Directory. Here, the search base is the testing group within a company, and the users are matched up based on email address. -http://10.147.29.101:8080/client/api?command=ldapConfig&hostname=10.147.28.250&searchbase=OU%3Dtesting%2CDC%3Dcompany&queryfilter=%28%26%28mail%3D%25e%29%29 &binddn=CN%3DAdministrator%2COU%3Dtesting%2CDC%3Dcompany&bindpass=1111_aaaa&port=389&response=json&apiKey=YourAPIKey&signature=YourSignatureHash - The next few sections explain some of the concepts you will need to know when filling out the ldapConfig parameters. -
diff --git a/docs/en-US/example-activedirectory-configuration.xml b/docs/en-US/example-activedirectory-configuration.xml new file mode 100644 index 00000000000..98ab5dae681 --- /dev/null +++ b/docs/en-US/example-activedirectory-configuration.xml @@ -0,0 +1,43 @@ + + +%BOOK_ENTITIES; +]> + + + +
+ Example LDAP Configuration for Active Directory + This shows the configuration settings required for using ActiveDirectory + + samAccountName - Logon name + mail - Email Address + cn - Real name + + Along with this the ldap.user.object name needs to be modified, by default ActiveDirectory uses the value "user" for this. + Map the following attributes accordingly as shown below within the cloudstack ldap configuration: + + + + + + add-ldap-configuration-ad.png: example configuration for active directory. + + +
diff --git a/docs/en-US/example-openldap-configuration.xml b/docs/en-US/example-openldap-configuration.xml new file mode 100644 index 00000000000..2b28032dfe4 --- /dev/null +++ b/docs/en-US/example-openldap-configuration.xml @@ -0,0 +1,44 @@ + + +%BOOK_ENTITIES; +]> + + + +
+ Example LDAP Configuration for OpenLdap + This shows the configuration settings required for using OpenLDAP + The default values supplied are suited for OpenLDAP + + uid - Logon name + mail - Email Address + cn - Real name + + Along with this the ldap.user.object name needs to be modified, by default OpenLDAP uses the value "inetOrgPerson" for this. + Map the following attributes accordingly as shown below within the cloudstack ldap configuration: + + + + + + add-ldap-configuration-openldap.png: example configuration for OpenLdap. + + +
diff --git a/docs/en-US/images/add-ldap-configuration-ad.png b/docs/en-US/images/add-ldap-configuration-ad.png new file mode 100644 index 0000000000000000000000000000000000000000..7d0aa0f44f994fe7a6539527ef42fc68b2d333f6 GIT binary patch literal 31803 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 G@V^1k2Nkve literal 0 HcmV?d00001 diff --git a/docs/en-US/query-filter.xml b/docs/en-US/query-filter.xml deleted file mode 100644 index 1c0e493972d..00000000000 --- a/docs/en-US/query-filter.xml +++ /dev/null @@ -1,60 +0,0 @@ - - -%BOOK_ENTITIES; -]> - - - -
-Query Filter -The query filter is used to find a mapped user in the external LDAP server. The query filter should uniquely map the &PRODUCT; user to LDAP user for a meaningful authentication. For more information about query filter syntax, consult the documentation for your LDAP server. -The &PRODUCT; query filter wildcards are: - - - - - Query Filter Wildcard - Description - - - - - %u - User name - - - %e - Email address - - - %n - First and last name - - - - -The following examples assume you are using Active Directory, and refer to user attributes from the Active Directory schema. -If the &PRODUCT; user name is the same as the LDAP user ID: -(uid=%u) -If the &PRODUCT; user name is the LDAP display name: -(displayName=%u) -To find a user by email address: -(mail=%e) -
diff --git a/docs/en-US/search-user-bind-dn.xml b/docs/en-US/search-user-bind-dn.xml deleted file mode 100644 index a2d8b6a339c..00000000000 --- a/docs/en-US/search-user-bind-dn.xml +++ /dev/null @@ -1,47 +0,0 @@ - - -%BOOK_ENTITIES; -]> - - - -
- Search User Bind DN - The bind DN is the user on the external LDAP server permitted to search the LDAP directory within the defined search base. When the DN is returned, the DN and passed password are used to authenticate the &PRODUCT; user with an LDAP bind. A full discussion of bind DNs is outside the scope of our documentation. The following table shows some examples of bind DNs. - - - - - LDAP Server - Example Bind DN - - - - - ApacheDS - cn=Administrator,dc=testing,ou=project,ou=org - - - Active Directory - CN=Administrator, OU=testing, DC=company, DC=com - - - -