Directory client library
Project description
sysnet-directory
Tento balíček obsahuje procedury pro prohledávání osob a skupin na serveru LDAP (AD) a extrakci údajů organizační struktury ze získaných hodnot. Je určen primárně pro projekt eSMLOUVY MŽP.
Požadavky
Python 3.9+
Instalace a použití
pip install sysnet-directory
(pokud potřebujete ke spuštění pip
with oprávnění rool: sudo pip install sysnet-directory
)
Pak importujte balíček:
import sysnet_directory
Setuptools
Instalace via Setuptools.
python setup.py install --user sysnet-sysnet_directory
(nebo sudo python setup.py install sysnet-directory
pro instalaci balíčku pro všechny uživatele)
A import balíčku:
import sysnet_directory
Použití v programu
Balíček poskytuje singleton DIRECTORY_FACTORY
, který obsahuje veškerou funkcionalitu.
Implicitně je singleton ve stavu disabled. Jeho použití lze povolit pomocí příkazu reset.
DIRECTORY_FACTORY.reset(..., enabled=True)
Vyhledání osoby
Klíčové slovo
KLíčovým slovem pro hledání osoby může být jméno, adresa elektronické pošty, osobní číslo nebo název funkce (to vše včetně zástupných znaků). Vrací seznam (list) slovníků (dictinary).
from sysnet_directory.factory import DIRECTORY_FACTORY
...
user_list = DIRECTORY_FACTORY.get_user('Jos*')
user_list = DIRECTORY_FACTORY.get_all_users()
Pro případ potřeby lze tuto funkci zavolat jako "raw". Pak vrací surovou odpověď LDAP serveru.
user_list = DIRECTORY_FACTORY.get_user_raw('Jos*')
Mapa uživatelů
Pro účely snadného mapování osobních čísel na uživatele je tu funkce get_user_map. Vrací slovník (dictionary) obsahující jako klíč osobní číslo uživatele a v kodnotě je slovník s daty uživatele.
from sysnet_directory.factory import DIRECTORY_FACTORY
...
user_map = DIRECTORY_FACTORY.get_user_map()
Organizační jednotka
Osoby lze vyhledávat rovněž podle kódu organizační jednotky:
user_list = DIRECTORY_FACTORY.get_user(ou='210')
vrací všechny osoby z organizační jednotky 210.
Vedoucí funkce
Lze vyhledávat osoby podle vedoucí funkce:
user_list = DIRECTORY_FACTORY.get_user(head=True)
Vrátí všechny vedoucí v organizaci
user_list = DIRECTORY_FACTORY.get_user(ou='210', head=True)
Vrátí vedoucí v organizační jednotce 210
Informace o zařazení do organizační struktury
Vrácený slovník pro uživatele obsahuje kromě identifikačních a popisných údajů tyto struktury:
- division - strom všech organizačních jednotek, kam uživatel spadá
- org_info - příznak vedoucí funkce, kód aktuální organizační jednotky a kód nadřízené organizační jednotky
Vyhledání skupiny
KLíčovým slovem pro hledání skupiny je její název včetně zástupných znaků. Vrací seznam (list) slovníků (dictinary).
...
group_list = DIRECTORY_FACTORY.get_group('*3')
group_list = DIRECTORY_FACTORY.get_all_groups()
Pro případ potřeby lze tuto funkci zavolat jako "raw". Pak vrací surovou odpověď LDAP serveru.
user_list = DIRECTORY_FACTORY.get_group_raw('Jos*')
Organizační struktura
Factory obsahuje funkcionalitu, která dokáže z LDAP dat extrahovat organizační strukturu. Organizační struktura je ve stromové formě. Uzly jsou propojeny oběma směry.
...
os = DIRECTORY_FACTORY.get_org_structure()
Ošetření chyb
Pokud se nepodaří připojit k LDAP serveru, modul nahlásí chybu a příznak ready u DIRECTORY_FACTORY je nastaven na False
DIRECTORY_FACTORY.ready
Systémové proměnné
Nastavení factory je řízeno systémovými proměnnými
- LDAP_ENABLE - True/False (implicitně True): Vypne modul. Zabraňuje timeoutu při hledání LDAP serveru.
- LDAP_SERVER_URI - ve formátu např
ldap://localhost:389
- LDAP_BIND_DN - přihlašovací jméno k serveru
- LDAP_BIND_PASSWORD - heslo k přihlašovacímu jménu
- LDAP_BASE_DN - základní kontext. Např.
OU=eSML,DC=ad,DC=mzp,DC=cz
Implicitní nastavení nebo nastavení přes systémové proměnné lze vždy přebít ruční operací reset
DIRECTORY_FACTORY.reset(uri=<uri>, bind_dn=<name>, bind_password=<password>, base_dn=<context>, enabled=<enabled>)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file sysnet-directory-1.1.7.tar.gz
.
File metadata
- Download URL: sysnet-directory-1.1.7.tar.gz
- Upload date:
- Size: 19.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1c499e1b65cc4f923266aa12861654a12d9f5f0185e3e1abf812278ea8b137d5 |
|
MD5 | 9de75b71916b1fa646c6e2f01709caf8 |
|
BLAKE2b-256 | 6e6b309877d10281b0eb6eab79d790fdd65bb075c60031cec7175e8fa3cd0db7 |
File details
Details for the file sysnet_directory-1.1.7-py3-none-any.whl
.
File metadata
- Download URL: sysnet_directory-1.1.7-py3-none-any.whl
- Upload date:
- Size: 16.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ee676f701599658f411da9c92c402648bc5a8cb2b06b59fb7263c70350c4b5dc |
|
MD5 | f5a1d0ba8fa93bbe150a8c49e8395d31 |
|
BLAKE2b-256 | d4a8b1b28f9f6d8f6290d86b626ff0d01adb4f95ec09c76caf243bad3ec7a306 |