|
|
@@ -1,5 +1,6 @@
|
|
|
__package__ = 'archivebox.plugins_auth.ldap'
|
|
|
|
|
|
+
|
|
|
import inspect
|
|
|
|
|
|
from typing import List, Dict
|
|
|
@@ -12,14 +13,27 @@ from abx.archivebox.base_plugin import BasePlugin
|
|
|
from abx.archivebox.base_hook import BaseHook
|
|
|
from abx.archivebox.base_binary import BaseBinary, BaseBinProvider, apt
|
|
|
|
|
|
-from plugins_pkg.pip.apps import SYS_PIP_BINPROVIDER, VENV_PIP_BINPROVIDER, LIB_PIP_BINPROVIDER
|
|
|
+from plugins_pkg.pip.apps import SYS_PIP_BINPROVIDER, VENV_PIP_BINPROVIDER, LIB_PIP_BINPROVIDER, VENV_SITE_PACKAGES, LIB_SITE_PACKAGES, USER_SITE_PACKAGES, SYS_SITE_PACKAGES
|
|
|
from .settings import LDAP_CONFIG, get_ldap_lib
|
|
|
|
|
|
|
|
|
###################### Config ##########################
|
|
|
|
|
|
-LDAP_LIB = lambda: get_ldap_lib()[0] # lazy load to avoid slow ldap lib import on startup
|
|
|
-
|
|
|
+def get_LDAP_LIB_path(paths):
|
|
|
+ LDAP_LIB = get_ldap_lib()[0]
|
|
|
+ if not LDAP_LIB:
|
|
|
+ return None
|
|
|
+
|
|
|
+ # check that LDAP_LIB path is in one of the specified site packages dirs
|
|
|
+ lib_path = Path(inspect.getfile(LDAP_LIB))
|
|
|
+ for site_packges_dir in paths:
|
|
|
+ if str(lib_path.parent.parent.resolve()) == str(Path(site_packges_dir).resolve()):
|
|
|
+ return lib_path
|
|
|
+ return None
|
|
|
+
|
|
|
+def get_LDAP_LIB_version():
|
|
|
+ LDAP_LIB = get_ldap_lib()[0]
|
|
|
+ return LDAP_LIB and SemVer(LDAP_LIB.__version__)
|
|
|
|
|
|
class LdapBinary(BaseBinary):
|
|
|
name: str = 'ldap'
|
|
|
@@ -27,24 +41,24 @@ class LdapBinary(BaseBinary):
|
|
|
binproviders_supported: List[InstanceOf[BaseBinProvider]] = [VENV_PIP_BINPROVIDER, SYS_PIP_BINPROVIDER, LIB_PIP_BINPROVIDER, apt]
|
|
|
|
|
|
provider_overrides: Dict[BinProviderName, ProviderLookupDict] = {
|
|
|
- VENV_PIP_BINPROVIDER.name: {
|
|
|
- "abspath": lambda: LDAP_LIB() and Path(inspect.getfile(LDAP_LIB())), # type: ignore
|
|
|
- "version": lambda: LDAP_LIB() and SemVer(LDAP_LIB().__version__), # type: ignore
|
|
|
+ LIB_PIP_BINPROVIDER.name: {
|
|
|
+ "abspath": lambda: get_LDAP_LIB_path(LIB_SITE_PACKAGES),
|
|
|
+ "version": lambda: get_LDAP_LIB_version(),
|
|
|
"packages": lambda: ['python-ldap>=3.4.3', 'django-auth-ldap>=4.1.0'],
|
|
|
},
|
|
|
- SYS_PIP_BINPROVIDER.name: {
|
|
|
- "abspath": lambda: LDAP_LIB() and Path(inspect.getfile(LDAP_LIB())), # type: ignore
|
|
|
- "version": lambda: LDAP_LIB() and SemVer(LDAP_LIB().__version__), # type: ignore
|
|
|
+ VENV_PIP_BINPROVIDER.name: {
|
|
|
+ "abspath": lambda: get_LDAP_LIB_path(VENV_SITE_PACKAGES),
|
|
|
+ "version": lambda: get_LDAP_LIB_version(),
|
|
|
"packages": lambda: ['python-ldap>=3.4.3', 'django-auth-ldap>=4.1.0'],
|
|
|
},
|
|
|
- LIB_PIP_BINPROVIDER.name: {
|
|
|
- "abspath": lambda: LDAP_LIB() and Path(inspect.getfile(LDAP_LIB())), # type: ignore
|
|
|
- "version": lambda: LDAP_LIB() and SemVer(LDAP_LIB().__version__), # type: ignore
|
|
|
+ SYS_PIP_BINPROVIDER.name: {
|
|
|
+ "abspath": lambda: get_LDAP_LIB_path((*USER_SITE_PACKAGES, *SYS_SITE_PACKAGES)),
|
|
|
+ "version": lambda: get_LDAP_LIB_version(),
|
|
|
"packages": lambda: ['python-ldap>=3.4.3', 'django-auth-ldap>=4.1.0'],
|
|
|
},
|
|
|
apt.name: {
|
|
|
- "abspath": lambda: LDAP_LIB() and Path(inspect.getfile(LDAP_LIB())), # type: ignore
|
|
|
- "version": lambda: LDAP_LIB() and SemVer(LDAP_LIB().__version__), # type: ignore
|
|
|
+ "abspath": lambda: get_LDAP_LIB_path(SYS_SITE_PACKAGES),
|
|
|
+ "version": lambda: get_LDAP_LIB_version(),
|
|
|
"packages": lambda: ['libssl-dev', 'libldap2-dev', 'libsasl2-dev', 'python3-ldap', 'python3-msgpack', 'python3-mutagen'],
|
|
|
},
|
|
|
}
|