This is a LDAP Plugin for the Zope2 Pluggable Authentication Service (PAS).
It provides users and/or groups from an LDAP Directory. It works in a plain Zope2 even if it depends on PlonePAS. If Plone is installed an integration layer with a setup-profile and a plone-controlpanel page is available.
pas.plugins.ldap
is not releated to the old LDAPUserFolder/ LDAPMultiPlugins and the packages (i.e. PloneLDAP) stacked on top of it in any way.
It is based on node.ext.ldap, an almost framework independent ldap stack.
For now users and groups can't be added or deleted. But properties on both are read/write. See section TODO.
This package depends on python-ldap
.
In order to build it correctly you need to have some development libraries included in your system.
On a typical Debian-based installation use:
sudo apt install python-dev libldap2-dev libsasl2-dev libssl-dev
Add to the instance section of your buildout:
eggs =
...
pas.plugins.ldap
zcml =
...
pas.plugins.ldap
Run buildout. Restart Zope.
Then got to your acl_users folder and add an LDAP-Plugin.
Configure it using the settings form and activate its features with the activate
tab.
Add to the instance section of your buildout:
eggs =
...
pas.plugins.ldap
Run buildout. Restart Plone.
Then go to the Plone control-panel, select extensions
and install the LDAP Plugin.
A new LDAP Settings icon appear on the left. Click it and configure the plugin there.
To use an own integration-profile, just add to the profiles
metadata.xml
file:
...
<dependencies>
...
<dependency>profile-pas.plugins.ldap.plonecontrolpanel:default</dependency>
</dependencies>
...
Additionally ldap settings can be exported and imported with portal_setup
.
You can place the exported ldapsettings.xml
in your integration profile, so it will be imported with your next install again.
Attention: The ldap-password is in there in plain text!
By default the LDAP-queries are not cached. A must have for a production environment is having memcached server configured as LDAP query cache. Without this this module is slow (as any other module talking to LDAP will be). Cache at least for ~6 seconds, so a page load with all its resources is covered also in worst case.
The UGM tree is cached by default on the request, that means its built up every request from (cached) ldap queries.
There is an alternative adapter available which will cache the ugm tree as volatile attribute on the persistent plugin.
Volatile attributes are not persisted in the ZODB.
If the plugin object vanishes from ZODB cache the atrribute is gone.
The volatile plugin cache can be activated by loading its zcml with <include package="pas.plugins.ldap" file="cache_volatile.zcml"
.
The caching time can be influenced by overriding the value in pas.plugins.ldap.cache.VOLATILE_CACHE_MAXAGE
.
It defaults to 10 and its unit is seconds.
Please keep in mind: Caching the UGM tree longer than one request means it could contain outdated data.
If you plan a different implementation of UGM tree caching:
Just provide your own adapter implementing pas.plugins.ldap.interfaces.IPluginCacheHandler
.
This package works fine for several 10000 users or groups, unless you search or list users.
This is not that much a problem for small amount of users. There is room for future optimization in the underlying node.ext.ldap. It currently does not support paginated queries. Many LDAP servers are having a maximum page size per answer. If the result is larger than this number, the query might fail or be truncated. Contact us if you have resources in time or budget for this development task.
If you want to help with the development (improvement, update, bug-fixing, ...) of pas.plugins.ldap
this is a great idea!
The code is located in the github collective.
You can clone it or get access to the github-collective and work directly on the project.
Maintainers are Robert Niederreiter, Jens Klein and the BlueDynamics Alliance developer team. We appreciate any contribution and if a release is needed to be done on pypi, please just contact one of us: dev@bluedynamics dot com
- Jens W. Klein
- Robert Niederrreiter
- Florian Friesdorf
- Daniel Widerin
- Johannes Raggam
- Luca Fabbri