1
0
mirror of https://github.com/kakwa/ldapcherry synced 2025-01-27 05:47:22 +01:00
ldapcherry/docs/backend_api.rst

73 lines
1.7 KiB
ReStructuredText
Raw Normal View History

2015-07-20 01:30:32 +02:00
Implementing cutom backends
===========================
2015-07-18 11:42:13 +02:00
API
---
2015-07-18 11:42:13 +02:00
2015-07-20 01:30:32 +02:00
The backend modules must respect the following API:
2015-07-20 01:30:32 +02:00
.. autoclass:: ldapcherry.backend.Backend
:members: __init__, auth, add_user, del_user, set_attrs, add_to_groups, del_from_groups, search, get_user, get_groups
:undoc-members:
:show-inheritance:
2015-07-18 11:42:13 +02:00
Configuration
-------------
2015-07-18 11:42:13 +02:00
Configuration for your backend is declared in the main ini file, inside [backends] section:
For example with the configuration:
.. sourcecode:: ini
[backends]
# class path to module
b_id.module = "my.backend.module"
b_id.param1 = "my value 1"
b_id.param2 = "my value 2"
.. note::
One module can be instanciated several times, the prefix b_id permits
to differenciate instances and their specific configuration.
The following hash will be passed as configuration to the module constructor as parameter config:
.. sourcecode:: python
{
'param1': "my value 1",
'param2': "my value 2",
}
2015-07-20 01:30:32 +02:00
After having set **self.config** to **config** in the constructor, parameters can be recovered
by **self.get_param**:
.. autoclass:: ldapcherry.backend.Backend
:members: get_param
:undoc-members:
:show-inheritance:
2015-07-18 11:42:13 +02:00
Exceptions
----------
2015-07-18 11:42:13 +02:00
The following exception can be used in your module
2015-07-20 01:30:32 +02:00
.. automodule:: ldapcherry.exceptions
:members: UserDoesntExist, UserAlreadyExists, GroupDoesntExist
:undoc-members:
:show-inheritance:
2015-07-18 11:42:13 +02:00
These exceptions permit a nicer error handling and avoid a generic message to be thrown at the user.
2015-07-20 01:30:32 +02:00
Example
-------
Here is the ldap backend module that comes with LdapCherry:
.. literalinclude:: ../ldapcherry/backend/backendLdap.py
:language: python