Skip to main content

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:

  1. division - strom všech organizačních jednotek, kam uživatel spadá
  2. 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sysnet-directory-1.1.7.tar.gz (19.1 kB view details)

Uploaded Source

Built Distribution

sysnet_directory-1.1.7-py3-none-any.whl (16.9 kB view details)

Uploaded Python 3

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

Hashes for sysnet-directory-1.1.7.tar.gz
Algorithm Hash digest
SHA256 1c499e1b65cc4f923266aa12861654a12d9f5f0185e3e1abf812278ea8b137d5
MD5 9de75b71916b1fa646c6e2f01709caf8
BLAKE2b-256 6e6b309877d10281b0eb6eab79d790fdd65bb075c60031cec7175e8fa3cd0db7

See more details on using hashes here.

File details

Details for the file sysnet_directory-1.1.7-py3-none-any.whl.

File metadata

File hashes

Hashes for sysnet_directory-1.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 ee676f701599658f411da9c92c402648bc5a8cb2b06b59fb7263c70350c4b5dc
MD5 f5a1d0ba8fa93bbe150a8c49e8395d31
BLAKE2b-256 d4a8b1b28f9f6d8f6290d86b626ff0d01adb4f95ec09c76caf243bad3ec7a306

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page