mirror of
https://git.FreeBSD.org/ports.git
synced 2025-01-15 07:56:36 +00:00
py-ldap1: from ldapmodule,
py-ldap2: import CVS snapshoot. Fix Makefile
This commit is contained in:
parent
0a2c4bd032
commit
d81c80bd23
Notes:
svn2git
2021-03-31 03:12:20 +00:00
svn path=/head/; revision=55328
@ -205,7 +205,6 @@
|
||||
SUBDIR += kxicq2
|
||||
SUBDIR += lam
|
||||
SUBDIR += lambdamoo
|
||||
SUBDIR += ldapmodule
|
||||
SUBDIR += ldapsdk
|
||||
SUBDIR += libfreenet
|
||||
SUBDIR += libicq
|
||||
@ -376,6 +375,8 @@
|
||||
SUBDIR += py-adns
|
||||
SUBDIR += py-ipy
|
||||
SUBDIR += py-jabber
|
||||
SUBDIR += py-ldap1
|
||||
SUBDIR += py-ldap2
|
||||
SUBDIR += py-libnet
|
||||
SUBDIR += py-pcap
|
||||
SUBDIR += py-smb
|
||||
|
@ -4,24 +4,39 @@
|
||||
#
|
||||
# $FreeBSD$
|
||||
|
||||
PORTNAME= ldapmodule
|
||||
PORTVERSION= 1.10alpha3
|
||||
PORTREVISION= 4
|
||||
CATEGORIES= net python
|
||||
PORTNAME= ldap2
|
||||
PORTVERSION= CVS200201041716
|
||||
CATEGORIES= net
|
||||
MASTER_SITES= ${MASTER_SITE_SOURCEFORGE}
|
||||
MASTER_SITE_SUBDIR= python-ldap
|
||||
DISTNAME= python-ldap-${PORTVERSION}-src
|
||||
PKGNAMEPREFIX= ${PYTHON_PKGNAMEPREFIX}
|
||||
DISTNAME= Python-LDAP-${PORTVERSION}
|
||||
|
||||
MAINTAINER= dinoex@FreeBSD.org
|
||||
|
||||
LIB_DEPENDS= ldap.1:${PORTSDIR}/net/openldap
|
||||
LIB_DEPENDS= ldap.2:${PORTSDIR}/net/openldap2
|
||||
BUILD_DEPENDS= python:${PORTSDIR}/lang/python
|
||||
RUN_DEPENDS= python:${PORTSDIR}/lang/python
|
||||
|
||||
USE_PYTHON= yes
|
||||
GNU_CONFIGURE= yes
|
||||
CONFIGURE_ARGS+=--with-ldap=${LOCALBASE} --with-python=${PYTHON_CMD}
|
||||
WRKSRC= ${WRKDIR}/${DISTNAME:S=-src==}
|
||||
|
||||
pre-configure:
|
||||
@${CP} ${FILESDIR}/Makefile.pre.in ${WRKSRC}/Misc/Makefile.python-1.4
|
||||
#class = OpenLDAP2
|
||||
#library_dirs = /usr/local/openldap2/lib
|
||||
#include_dirs = /usr/local/openldap2/include
|
||||
#libs = lber ldap resolv
|
||||
do-configure:
|
||||
@${PERL5} -pi -e "s=/usr/local/openldap2/lib=${LOCALBASE}/lib=" \
|
||||
${WRKSRC}/setup.cfg
|
||||
@${PERL5} -pi \
|
||||
-e "s=/usr/local/openldap2/include=${LOCALBASE}/include=" \
|
||||
${WRKSRC}/setup.cfg
|
||||
@${PERL5} -pi -e "s=lber ldap resolv=lber ldap=" ${WRKSRC}/setup.cfg
|
||||
|
||||
do-build:
|
||||
cd ${WRKSRC} && python setup.py build
|
||||
|
||||
do-install:
|
||||
cd ${WRKSRC} && python setup.py install
|
||||
|
||||
.include <bsd.port.mk>
|
||||
|
@ -1 +1 @@
|
||||
MD5 (python-ldap-1.10alpha3-src.tar.gz) = a4e95cf9edec1b7952a5decbc8080372
|
||||
MD5 (Python-LDAP-CVS200201041716.tar.gz) = 2ab1887f971fdbfac1c58d343398f674
|
||||
|
@ -1,304 +0,0 @@
|
||||
# Universal Unix Makefile for Python extensions
|
||||
# =============================================
|
||||
|
||||
# Short Instructions
|
||||
# ------------------
|
||||
|
||||
# 1. Build and install Python (1.5 or newer).
|
||||
# 2. "make -f Makefile.pre.in boot"
|
||||
# 3. "make"
|
||||
# You should now have a shared library.
|
||||
|
||||
# Long Instructions
|
||||
# -----------------
|
||||
|
||||
# Build *and install* the basic Python 1.5 distribution. See the
|
||||
# Python README for instructions. (This version of Makefile.pre.in
|
||||
# only withs with Python 1.5, alpha 3 or newer.)
|
||||
|
||||
# Create a file Setup.in for your extension. This file follows the
|
||||
# format of the Modules/Setup.dist file; see the instructions there.
|
||||
# For a simple module called "spam" on file "spammodule.c", it can
|
||||
# contain a single line:
|
||||
# spam spammodule.c
|
||||
# You can build as many modules as you want in the same directory --
|
||||
# just have a separate line for each of them in the Setup.in file.
|
||||
|
||||
# If you want to build your extension as a shared library, insert a
|
||||
# line containing just the string
|
||||
# *shared*
|
||||
# at the top of your Setup.in file.
|
||||
|
||||
# Note that the build process copies Setup.in to Setup, and then works
|
||||
# with Setup. It doesn't overwrite Setup when Setup.in is changed, so
|
||||
# while you're in the process of debugging your Setup.in file, you may
|
||||
# want to edit Setup instead, and copy it back to Setup.in later.
|
||||
# (All this is done so you can distribute your extension easily and
|
||||
# someone else can select the modules they actually want to build by
|
||||
# commenting out lines in the Setup file, without editing the
|
||||
# original. Editing Setup is also used to specify nonstandard
|
||||
# locations for include or library files.)
|
||||
|
||||
# Copy this file (Misc/Makefile.pre.in) to the directory containing
|
||||
# your extension.
|
||||
|
||||
# Run "make -f Makefile.pre.in boot". This creates Makefile
|
||||
# (producing Makefile.pre and sedscript as intermediate files) and
|
||||
# config.c, incorporating the values for sys.prefix, sys.exec_prefix
|
||||
# and sys.version from the installed Python binary. For this to work,
|
||||
# the python binary must be on your path. If this fails, try
|
||||
# make -f Makefile.pre.in Makefile VERSION=1.5 installdir=<prefix>
|
||||
# where <prefix> is the prefix used to install Python for installdir
|
||||
# (and possibly similar for exec_installdir=<exec_prefix>).
|
||||
|
||||
# Note: "make boot" implies "make clobber" -- it assumes that when you
|
||||
# bootstrap you may have changed platforms so it removes all previous
|
||||
# output files.
|
||||
|
||||
# If you are building your extension as a shared library (your
|
||||
# Setup.in file starts with *shared*), run "make" or "make sharedmods"
|
||||
# to build the shared library files. If you are building a statically
|
||||
# linked Python binary (the only solution of your platform doesn't
|
||||
# support shared libraries, and sometimes handy if you want to
|
||||
# distribute or install the resulting Python binary), run "make
|
||||
# python".
|
||||
|
||||
# Note: Each time you edit Makefile.pre.in or Setup, you must run
|
||||
# "make Makefile" before running "make".
|
||||
|
||||
# Hint: if you want to use VPATH, you can start in an empty
|
||||
# subdirectory and say (e.g.):
|
||||
# make -f ../Makefile.pre.in boot srcdir=.. VPATH=..
|
||||
|
||||
|
||||
# === Bootstrap variables (edited through "make boot") ===
|
||||
|
||||
# The prefix used by "make inclinstall libainstall" of core python
|
||||
installdir= /usr/local
|
||||
|
||||
# The exec_prefix used by the same
|
||||
exec_installdir=$(installdir)
|
||||
|
||||
# Source directory and VPATH in case you want to use VPATH.
|
||||
# (You will have to edit these two lines yourself -- there is no
|
||||
# automatic support as the Makefile is not generated by
|
||||
# config.status.)
|
||||
srcdir= .
|
||||
VPATH= .
|
||||
|
||||
# === Variables that you may want to customize (rarely) ===
|
||||
|
||||
# (Static) build target
|
||||
TARGET= python
|
||||
|
||||
# Installed python binary (used only by boot target)
|
||||
PYTHON?= python
|
||||
|
||||
# Add more -I and -D options here
|
||||
CFLAGS= $(OPT) -I$(INCLUDEPY) -I$(EXECINCLUDEPY) $(DEFS)
|
||||
|
||||
# These two variables can be set in Setup to merge extensions.
|
||||
# See example[23].
|
||||
BASELIB=
|
||||
BASESETUP=
|
||||
|
||||
# === Variables set by makesetup ===
|
||||
|
||||
MODOBJS= _MODOBJS_
|
||||
MODLIBS= _MODLIBS_
|
||||
|
||||
# === Definitions added by makesetup ===
|
||||
|
||||
# === Variables from configure (through sedscript) ===
|
||||
|
||||
VERSION= @VERSION@
|
||||
CC= @CC@
|
||||
LINKCC= @LINKCC@
|
||||
SGI_ABI= @SGI_ABI@
|
||||
OPT= @OPT@
|
||||
LDFLAGS= @LDFLAGS@
|
||||
LDLAST= @LDLAST@
|
||||
DEFS= @DEFS@
|
||||
LIBS= @LIBS@
|
||||
LIBM= @LIBM@
|
||||
LIBC= @LIBC@
|
||||
RANLIB= @RANLIB@
|
||||
MACHDEP= @MACHDEP@
|
||||
SO= @SO@
|
||||
LDSHARED= @LDSHARED@
|
||||
CCSHARED= @CCSHARED@
|
||||
LINKFORSHARED= @LINKFORSHARED@
|
||||
CXX= @CXX@
|
||||
|
||||
# Install prefix for architecture-independent files
|
||||
prefix= /usr/local
|
||||
|
||||
# Install prefix for architecture-dependent files
|
||||
exec_prefix= $(prefix)
|
||||
|
||||
# Uncomment the following two lines for AIX
|
||||
#LINKCC= $(LIBPL)/makexp_aix $(LIBPL)/python.exp "" $(LIBRARY); $(PURIFY) $(CC)
|
||||
#LDSHARED= $(LIBPL)/ld_so_aix $(CC) -bI:$(LIBPL)/python.exp
|
||||
|
||||
# === Fixed definitions ===
|
||||
|
||||
# Shell used by make (some versions default to the login shell, which is bad)
|
||||
SHELL= /bin/sh
|
||||
|
||||
# Expanded directories
|
||||
BINDIR= $(exec_installdir)/bin
|
||||
LIBDIR= $(exec_prefix)/lib
|
||||
MANDIR= $(installdir)/man
|
||||
INCLUDEDIR= $(installdir)/include
|
||||
SCRIPTDIR= $(prefix)/lib
|
||||
|
||||
# Detailed destination directories
|
||||
BINLIBDEST= $(LIBDIR)/python$(VERSION)
|
||||
LIBDEST= $(SCRIPTDIR)/python$(VERSION)
|
||||
INCLUDEPY= $(INCLUDEDIR)/python$(VERSION)
|
||||
EXECINCLUDEPY= $(exec_installdir)/include/python$(VERSION)
|
||||
LIBP= $(exec_installdir)/lib/python$(VERSION)
|
||||
DESTSHARED= $(BINLIBDEST)/site-packages
|
||||
|
||||
LIBPL= $(LIBP)/config
|
||||
|
||||
PYTHONLIBS= $(LIBPL)/libpython$(VERSION).a
|
||||
|
||||
MAKESETUP= $(LIBPL)/makesetup
|
||||
MAKEFILE= $(LIBPL)/Makefile
|
||||
CONFIGC= $(LIBPL)/config.c
|
||||
CONFIGCIN= $(LIBPL)/config.c.in
|
||||
SETUP= $(LIBPL)/Setup.config $(LIBPL)/Setup.local $(LIBPL)/Setup
|
||||
|
||||
SYSLIBS= $(LIBM) $(LIBC)
|
||||
|
||||
ADDOBJS= $(LIBPL)/python.o config.o
|
||||
|
||||
# Portable install script (configure doesn't always guess right)
|
||||
INSTALL= $(LIBPL)/install-sh -c
|
||||
# Shared libraries must be installed with executable mode on some systems;
|
||||
# rather than figuring out exactly which, we always give them executable mode.
|
||||
# Also, making them read-only seems to be a good idea...
|
||||
INSTALL_SHARED= ${INSTALL} -m 555
|
||||
|
||||
# === Fixed rules ===
|
||||
|
||||
# Default target. This builds shared libraries only
|
||||
default: sharedmods
|
||||
|
||||
# Build everything
|
||||
all: static sharedmods
|
||||
|
||||
# Build shared libraries from our extension modules
|
||||
sharedmods: $(SHAREDMODS)
|
||||
|
||||
# Build a static Python binary containing our extension modules
|
||||
static: $(TARGET)
|
||||
$(TARGET): $(ADDOBJS) lib.a $(PYTHONLIBS) Makefile $(BASELIB)
|
||||
$(LINKCC) $(LDFLAGS) $(LINKFORSHARED) \
|
||||
$(ADDOBJS) lib.a $(PYTHONLIBS) \
|
||||
$(LINKPATH) $(BASELIB) $(MODLIBS) $(LIBS) $(SYSLIBS) \
|
||||
-o $(TARGET) $(LDLAST)
|
||||
|
||||
install: sharedmods
|
||||
if test ! -d $(DESTSHARED) ; then \
|
||||
mkdir $(DESTSHARED) ; else true ; fi
|
||||
-for i in X $(SHAREDMODS); do \
|
||||
if test $$i != X; \
|
||||
then $(INSTALL_SHARED) $$i $(DESTSHARED)/$$i; \
|
||||
fi; \
|
||||
done
|
||||
|
||||
# Build the library containing our extension modules
|
||||
lib.a: $(MODOBJS)
|
||||
-rm -f lib.a
|
||||
ar cr lib.a $(MODOBJS)
|
||||
-$(RANLIB) lib.a
|
||||
|
||||
# This runs makesetup *twice* to use the BASESETUP definition from Setup
|
||||
config.c Makefile: Makefile.pre Setup $(BASESETUP) $(MAKESETUP)
|
||||
$(MAKESETUP) \
|
||||
-m Makefile.pre -c $(CONFIGCIN) Setup -n $(BASESETUP) $(SETUP)
|
||||
$(MAKE) -f Makefile do-it-again
|
||||
|
||||
# Internal target to run makesetup for the second time
|
||||
do-it-again:
|
||||
$(MAKESETUP) \
|
||||
-m Makefile.pre -c $(CONFIGCIN) Setup -n $(BASESETUP) $(SETUP)
|
||||
|
||||
# Make config.o from the config.c created by makesetup
|
||||
config.o: config.c
|
||||
$(CC) $(CFLAGS) -c config.c
|
||||
|
||||
# Setup is copied from Setup.in *only* if it doesn't yet exist
|
||||
Setup:
|
||||
cp $(srcdir)/Setup.in Setup
|
||||
|
||||
# Make the intermediate Makefile.pre from Makefile.pre.in
|
||||
Makefile.pre: Makefile.pre.in sedscript
|
||||
sed -f sedscript $(srcdir)/Makefile.pre.in >Makefile.pre
|
||||
|
||||
# Shortcuts to make the sed arguments on one line
|
||||
P=prefix
|
||||
E=exec_prefix
|
||||
H=Generated automatically from Makefile.pre.in by sedscript.
|
||||
L=LINKFORSHARED
|
||||
|
||||
# Make the sed script used to create Makefile.pre from Makefile.pre.in
|
||||
sedscript: $(MAKEFILE)
|
||||
sed -n \
|
||||
-e '1s/.*/1i\\/p' \
|
||||
-e '2s%.*%# $H%p' \
|
||||
-e '/^VERSION=/s/^VERSION=[ ]*\(.*\)/s%@VERSION[@]%\1%/p' \
|
||||
-e '/^CC=/s/^CC=[ ]*\(.*\)/s%@CC[@]%\1%/p' \
|
||||
-e '/^CXX=/s/^CXX=[ ]*\(.*\)/s%@CXX[@]%\1%/p' \
|
||||
-e '/^LINKCC=/s/^LINKCC=[ ]*\(.*\)/s%@LINKCC[@]%\1%/p' \
|
||||
-e '/^OPT=/s/^OPT=[ ]*\(.*\)/s%@OPT[@]%\1%/p' \
|
||||
-e '/^LDFLAGS=/s/^LDFLAGS=[ ]*\(.*\)/s%@LDFLAGS[@]%\1%/p' \
|
||||
-e '/^LDLAST=/s/^LDLAST=[ ]*\(.*\)/s%@LDLAST[@]%\1%/p' \
|
||||
-e '/^DEFS=/s/^DEFS=[ ]*\(.*\)/s%@DEFS[@]%\1%/p' \
|
||||
-e '/^LIBS=/s/^LIBS=[ ]*\(.*\)/s%@LIBS[@]%\1%/p' \
|
||||
-e '/^LIBM=/s/^LIBM=[ ]*\(.*\)/s%@LIBM[@]%\1%/p' \
|
||||
-e '/^LIBC=/s/^LIBC=[ ]*\(.*\)/s%@LIBC[@]%\1%/p' \
|
||||
-e '/^RANLIB=/s/^RANLIB=[ ]*\(.*\)/s%@RANLIB[@]%\1%/p' \
|
||||
-e '/^MACHDEP=/s/^MACHDEP=[ ]*\(.*\)/s%@MACHDEP[@]%\1%/p' \
|
||||
-e '/^SO=/s/^SO=[ ]*\(.*\)/s%@SO[@]%\1%/p' \
|
||||
-e '/^LDSHARED=/s/^LDSHARED=[ ]*\(.*\)/s%@LDSHARED[@]%\1%/p' \
|
||||
-e '/^CCSHARED=/s/^CCSHARED=[ ]*\(.*\)/s%@CCSHARED[@]%\1%/p' \
|
||||
-e '/^SGI_ABI=/s/^SGI_ABI=[ ]*\(.*\)/s%@SGI_ABI[@]%\1%/p' \
|
||||
-e '/^$L=/s/^$L=[ ]*\(.*\)/s%@$L[@]%\1%/p' \
|
||||
-e '/^$P=/s/^$P=\(.*\)/s%^$P=.*%$P=\1%/p' \
|
||||
-e '/^$E=/s/^$E=\(.*\)/s%^$E=.*%$E=\1%/p' \
|
||||
$(MAKEFILE) >sedscript
|
||||
echo "/^installdir=/s%=.*%= $(installdir)%" >>sedscript
|
||||
echo "/^exec_installdir=/s%=.*%=$(exec_installdir)%" >>sedscript
|
||||
echo "/^srcdir=/s%=.*%= $(srcdir)%" >>sedscript
|
||||
echo "/^VPATH=/s%=.*%= $(VPATH)%" >>sedscript
|
||||
echo "/^LINKPATH=/s%=.*%= $(LINKPATH)%" >>sedscript
|
||||
echo "/^BASELIB=/s%=.*%= $(BASELIB)%" >>sedscript
|
||||
echo "/^BASESETUP=/s%=.*%= $(BASESETUP)%" >>sedscript
|
||||
|
||||
# Bootstrap target
|
||||
boot: clobber
|
||||
VERSION=`$(PYTHON) -c "import sys; print sys.version[:3]"`; \
|
||||
installdir=`$(PYTHON) -c "import sys; print sys.prefix"`; \
|
||||
exec_installdir=`$(PYTHON) -c "import sys; print sys.exec_prefix"`; \
|
||||
$(MAKE) -f $(srcdir)/Makefile.pre.in VPATH=$(VPATH) srcdir=$(srcdir) \
|
||||
VERSION=$$VERSION \
|
||||
installdir=$$installdir \
|
||||
exec_installdir=$$exec_installdir \
|
||||
Makefile
|
||||
|
||||
# Handy target to remove intermediate files and backups
|
||||
clean:
|
||||
-rm -f *.o *~
|
||||
|
||||
# Handy target to remove everything that is easily regenerated
|
||||
clobber: clean
|
||||
-rm -f *.a tags TAGS config.c Makefile.pre $(TARGET) sedscript
|
||||
-rm -f *.so *.sl so_locations
|
||||
|
||||
|
||||
# Handy target to remove everything you don't want to distribute
|
||||
distclean: clobber
|
||||
-rm -f Makefile Setup
|
@ -1,11 +0,0 @@
|
||||
--- Makefile.in.orig Wed May 23 09:11:33 2001
|
||||
+++ Makefile.in Wed May 23 09:12:10 2001
|
||||
@@ -26,6 +26,8 @@
|
||||
$(INSTALL_DIR) $(DESTDIR)$(LIBDEST)/site-packages/python-ldap
|
||||
$(INSTALL_DATA) $(srcdir)/Misc/ldap.pth \
|
||||
$(DESTDIR)$(LIBDEST)/site-packages/ldap.pth
|
||||
+ $(INSTALL_DATA) $(srcdir)/Modules/_ldapmodule.so \
|
||||
+ $(DESTDIR)$(LIBDEST)/site-packages/_ldapmodule.so
|
||||
for f in $(srcdir)/Lib/*.py; do \
|
||||
$(INSTALL_DATA) $$f $(DESTDIR)$(LIBDEST)/site-packages/python-ldap/;\
|
||||
done
|
@ -1,156 +0,0 @@
|
||||
--- Modules/constants.c.orig Sun Aug 13 16:00:59 2000
|
||||
+++ Modules/constants.c Mon Nov 6 11:02:43 2000
|
||||
@@ -66,7 +66,6 @@
|
||||
add_int(d,VERSION1);
|
||||
add_int(d,VERSION2);
|
||||
add_int(d,VERSION);
|
||||
- add_int(d,MAX_ATTR_LEN);
|
||||
add_int(d,TAG_MESSAGE);
|
||||
add_int(d,TAG_MSGID);
|
||||
|
||||
@@ -79,9 +78,27 @@
|
||||
add_int(d,REQ_MODRDN);
|
||||
add_int(d,REQ_COMPARE);
|
||||
add_int(d,REQ_ABANDON);
|
||||
+
|
||||
+#if defined(LDAP_API_VERSION)
|
||||
+ /* OpenLDAPv2 */
|
||||
+ add_int(d,VERSION3);
|
||||
+ add_int(d,VERSION_MIN);
|
||||
+ add_int(d,VERSION_MAX);
|
||||
+ add_int(d,TAG_LDAPDN);
|
||||
+ add_int(d,TAG_LDAPCRED);
|
||||
+ add_int(d,TAG_CONTROLS);
|
||||
+ add_int(d,TAG_REFERRAL);
|
||||
+
|
||||
+ add_int(d,REQ_MODDN);
|
||||
+ add_int(d,REQ_RENAME);
|
||||
+#else
|
||||
+ /* OpenLDAPv1 */
|
||||
+ add_int(d,MAX_ATTR_LEN);
|
||||
+
|
||||
add_int(d,REQ_UNBIND_30);
|
||||
add_int(d,REQ_DELETE_30);
|
||||
add_int(d,REQ_ABANDON_30);
|
||||
+#endif
|
||||
|
||||
/* reversibles */
|
||||
|
||||
@@ -89,6 +106,14 @@
|
||||
PyDict_SetItem( reverse, zero, Py_None );
|
||||
Py_DECREF( zero );
|
||||
|
||||
+#if defined(LDAP_API_VERSION)
|
||||
+ /* OpenLDAPv2 */
|
||||
+ add_int_r(d,RES_SEARCH_REFERENCE);
|
||||
+ add_int_r(d,RES_MODDN); /* Aliases for RES_MODRDN; */
|
||||
+ add_int_r(d,RES_RENAME); /* init them before the main name */
|
||||
+ add_int(d,RES_UNSOLICITED);
|
||||
+#endif
|
||||
+
|
||||
add_int_r(d,RES_BIND);
|
||||
add_int_r(d,RES_SEARCH_ENTRY);
|
||||
add_int_r(d,RES_SEARCH_RESULT);
|
||||
@@ -106,9 +131,6 @@
|
||||
add_int(d,AUTH_KRBV4);
|
||||
add_int(d,AUTH_KRBV41);
|
||||
add_int(d,AUTH_KRBV42);
|
||||
- add_int(d,AUTH_SIMPLE_30);
|
||||
- add_int(d,AUTH_KRBV41_30);
|
||||
- add_int(d,AUTH_KRBV42_30);
|
||||
add_int(d,FILTER_AND);
|
||||
add_int(d,FILTER_OR);
|
||||
add_int(d,FILTER_NOT);
|
||||
@@ -118,13 +140,9 @@
|
||||
add_int(d,FILTER_LE);
|
||||
add_int(d,FILTER_PRESENT);
|
||||
add_int(d,FILTER_APPROX);
|
||||
- add_int(d,FILTER_PRESENT_30);
|
||||
add_int(d,SUBSTRING_INITIAL);
|
||||
add_int(d,SUBSTRING_ANY);
|
||||
add_int(d,SUBSTRING_FINAL);
|
||||
- add_int(d,SUBSTRING_INITIAL_30);
|
||||
- add_int(d,SUBSTRING_ANY_30);
|
||||
- add_int(d,SUBSTRING_FINAL_30);
|
||||
add_int(d,SCOPE_BASE);
|
||||
add_int(d,SCOPE_ONELEVEL);
|
||||
add_int(d,SCOPE_SUBTREE);
|
||||
@@ -133,6 +151,16 @@
|
||||
add_int(d,MOD_REPLACE);
|
||||
add_int(d,MOD_BVALUES);
|
||||
|
||||
+#if !defined(LDAP_API_VERSION)
|
||||
+ /* OpenLDAPv1 */
|
||||
+ add_int(d,AUTH_SIMPLE_30);
|
||||
+ add_int(d,AUTH_KRBV41_30);
|
||||
+ add_int(d,AUTH_KRBV42_30);
|
||||
+ add_int(d,FILTER_PRESENT_30);
|
||||
+ add_int(d,SUBSTRING_INITIAL_30);
|
||||
+ add_int(d,SUBSTRING_ANY_30);
|
||||
+ add_int(d,SUBSTRING_FINAL_30);
|
||||
+
|
||||
/* (errors.c contains the error constants) */
|
||||
|
||||
add_int(d,DEFAULT_REFHOPLIMIT);
|
||||
@@ -145,15 +173,36 @@
|
||||
#ifdef LDAP_CACHE_OPT_CACHEALLERRS
|
||||
add_int(d,CACHE_OPT_CACHEALLERRS);
|
||||
#endif
|
||||
+
|
||||
+#endif /* !defined(LDAP_API_VERSION) */
|
||||
add_int(d,FILT_MAXSIZ);
|
||||
add_int(d,DEREF_NEVER);
|
||||
add_int(d,DEREF_SEARCHING);
|
||||
add_int(d,DEREF_FINDING);
|
||||
add_int(d,DEREF_ALWAYS);
|
||||
add_int(d,NO_LIMIT);
|
||||
+#if defined(LDAP_API_VERSION)
|
||||
+ /* OpenLDAPv2 */
|
||||
+ add_int(d,OPT_API_INFO);
|
||||
+ add_int(d,OPT_DESC);
|
||||
+ add_int(d,OPT_DEREF);
|
||||
+ add_int(d,OPT_SIZELIMIT);
|
||||
+ add_int(d,OPT_TIMELIMIT);
|
||||
+ add_int(d,OPT_PROTOCOL_VERSION);
|
||||
+ add_int(d,OPT_SERVER_CONTROLS);
|
||||
+ add_int(d,OPT_CLIENT_CONTROLS);
|
||||
+ add_int(d,OPT_API_FEATURE_INFO);
|
||||
+ add_int(d,OPT_HOST_NAME);
|
||||
+ add_int(d,OPT_ERROR_NUMBER);
|
||||
+ add_int(d,OPT_ERROR_STRING);
|
||||
+ add_int(d,OPT_MATCHED_DN);
|
||||
+ add_int(d,OPT_PRIVATE_EXTENSION_BASE);
|
||||
+#else
|
||||
+ /* OpenLDAPv1 */
|
||||
#ifdef LDAP_OPT_DNS
|
||||
add_int(d,OPT_DNS);
|
||||
#endif
|
||||
+#endif /* defined(LDAP_API_VERSION) */
|
||||
#ifdef LDAP_OPT_REFERRALS
|
||||
add_int(d,OPT_REFERRALS);
|
||||
#endif
|
||||
@@ -161,9 +210,24 @@
|
||||
|
||||
/* XXX - these belong in errors.c */
|
||||
|
||||
+#if defined(LDAP_API_VERSION)
|
||||
+ /* OpenLDAPv2 */
|
||||
+ add_int(d,URL_SUCCESS);
|
||||
+ add_int(d,URL_ERR_PARAM);
|
||||
+ add_int(d,URL_ERR_BADSCHEME);
|
||||
+ add_int(d,URL_ERR_BADENCLOSURE);
|
||||
+ add_int(d,URL_ERR_BADURL);
|
||||
+ add_int(d,URL_ERR_BADHOST);
|
||||
+ add_int(d,URL_ERR_BADATTRS);
|
||||
+ add_int(d,URL_ERR_BADSCOPE);
|
||||
+ add_int(d,URL_ERR_BADFILTER);
|
||||
+ add_int(d,URL_ERR_BADEXTS);
|
||||
+#else
|
||||
+ /* OpenLDAPv1 */
|
||||
add_int(d,URL_ERR_NOTLDAP);
|
||||
add_int(d,URL_ERR_NODN);
|
||||
add_int(d,URL_ERR_BADSCOPE);
|
||||
+#endif /* defined(LDAP_API_VERSION) */
|
||||
add_int(d,URL_ERR_MEM);
|
||||
|
||||
/* author */
|
@ -1,115 +0,0 @@
|
||||
--- Modules/errors.c.orig Wed Nov 15 10:41:35 2000
|
||||
+++ Modules/errors.c Wed Nov 15 14:17:15 2000
|
||||
@@ -17,7 +17,13 @@
|
||||
|
||||
/* list of error objects */
|
||||
|
||||
+#if defined(LDAP_API_VERSION)
|
||||
+/* OpenLDAPv2 */
|
||||
+#define NUM_LDAP_ERRORS LDAP_REFERRAL_LIMIT_EXCEEDED+1
|
||||
+#else
|
||||
+/* OpenLDAPv1 */
|
||||
#define NUM_LDAP_ERRORS LDAP_NO_MEMORY+1
|
||||
+#endif
|
||||
static PyObject*
|
||||
errobjects[ NUM_LDAP_ERRORS ];
|
||||
|
||||
@@ -30,21 +36,26 @@
|
||||
PyErr_SetFromErrno( LDAPexception_class );
|
||||
return NULL;
|
||||
}
|
||||
-#ifdef LDAP_TYPE_IS_OPAQUE
|
||||
+#if defined(LDAP_TYPE_IS_OPAQUE) && !defined(LDAP_API_VERSION)
|
||||
else {
|
||||
PyErr_SetString(LDAPexception_class,
|
||||
"unknown error (C API does not expose error)");
|
||||
return NULL;
|
||||
}
|
||||
-#else
|
||||
+#else /* defined(LDAP_TYPE_IS_OPAQUE) && !defined(LDAP_API_VERSION) */
|
||||
else {
|
||||
int errnum;
|
||||
PyObject *errobj;
|
||||
PyObject *info;
|
||||
PyObject *str;
|
||||
|
||||
+#if defined(LDAP_API_VERSION)
|
||||
+ char *matched, *error;
|
||||
+ if (ldap_get_option(l, LDAP_OPT_ERROR_NUMBER, &errnum) < 0)
|
||||
+#else
|
||||
errnum = l->ld_errno;
|
||||
if (errnum<0 || errnum>=NUM_LDAP_ERRORS)
|
||||
+#endif /* defined(LDAP_API_VERSION) */
|
||||
errobj = LDAPexception_class; /* unknown error XXX */
|
||||
else
|
||||
errobj = errobjects[errnum];
|
||||
@@ -61,6 +72,35 @@
|
||||
PyDict_SetItemString( info, "desc", str );
|
||||
Py_XDECREF(str);
|
||||
|
||||
+#if defined(LDAP_API_VERSION)
|
||||
+ if (ldap_get_option(l, LDAP_OPT_MATCHED_DN, &matched) >= 0
|
||||
+ && matched != NULL) {
|
||||
+ if (*matched != '\0') {
|
||||
+ str = PyString_FromString(matched);
|
||||
+ if (str)
|
||||
+ PyDict_SetItemString( info, "matched", str );
|
||||
+ Py_XDECREF(str);
|
||||
+ }
|
||||
+ ldap_memfree(matched);
|
||||
+ }
|
||||
+
|
||||
+ if (errnum == LDAP_REFERRAL) {
|
||||
+ str = PyString_FromString(msg);
|
||||
+ if (str)
|
||||
+ PyDict_SetItemString( info, "info", str );
|
||||
+ Py_XDECREF(str);
|
||||
+ } else if (ldap_get_option(l, LDAP_OPT_ERROR_STRING, &error) >= 0
|
||||
+ && error != NULL) {
|
||||
+ if (error != '\0') {
|
||||
+ str = PyString_FromString(error);
|
||||
+ if (str)
|
||||
+ PyDict_SetItemString( info, "info", str );
|
||||
+ Py_XDECREF(str);
|
||||
+ }
|
||||
+ ldap_memfree(error);
|
||||
+ }
|
||||
+
|
||||
+#else /* defined(LDAP_API_VERSION) */
|
||||
if (l->ld_matched != NULL && *l->ld_matched != '\0')
|
||||
{
|
||||
str = PyString_FromString(l->ld_matched);
|
||||
@@ -76,11 +116,12 @@
|
||||
PyDict_SetItemString( info, "info", str );
|
||||
Py_XDECREF(str);
|
||||
}
|
||||
+#endif /* defined(LDAP_API_VERSION) */
|
||||
PyErr_SetObject( errobj, info );
|
||||
Py_DECREF(info);
|
||||
return NULL;
|
||||
}
|
||||
-#endif
|
||||
+#endif /* defined(LDAP_TYPE_IS_OPAQUE) && !defined(LDAP_API_VERSION) */
|
||||
}
|
||||
|
||||
|
||||
@@ -163,4 +204,19 @@
|
||||
seterrobj(USER_CANCELLED);
|
||||
seterrobj(PARAM_ERROR);
|
||||
seterrobj(NO_MEMORY);
|
||||
+#if defined(LDAP_API_VERSION)
|
||||
+ seterrobj(REFERRAL);
|
||||
+ seterrobj(ADMINLIMIT_EXCEEDED);
|
||||
+ seterrobj(UNAVAILABLE_CRITICAL_EXTENSION);
|
||||
+ seterrobj(CONFIDENTIALITY_REQUIRED);
|
||||
+ seterrobj(SASL_BIND_IN_PROGRESS);
|
||||
+ seterrobj(AFFECTS_MULTIPLE_DSAS);
|
||||
+ seterrobj(CONNECT_ERROR);
|
||||
+ seterrobj(NOT_SUPPORTED);
|
||||
+ seterrobj(CONTROL_NOT_FOUND);
|
||||
+ seterrobj(NO_RESULTS_RETURNED);
|
||||
+ seterrobj(MORE_RESULTS_TO_RETURN);
|
||||
+ seterrobj(CLIENT_LOOP);
|
||||
+ seterrobj(REFERRAL_LIMIT_EXCEEDED);
|
||||
+#endif
|
||||
}
|
@ -1,43 +0,0 @@
|
||||
--- Modules/message.c.orig Wed Nov 15 10:41:35 2000
|
||||
+++ Modules/message.c Wed Nov 15 16:51:18 2000
|
||||
@@ -114,6 +114,40 @@
|
||||
PyList_Append(result, entrytuple);
|
||||
Py_DECREF(entrytuple);
|
||||
}
|
||||
+#if defined(LDAP_API_VERSION)
|
||||
+ for(entry = ldap_first_reference(ld,m);
|
||||
+ entry != NULL;
|
||||
+ entry = ldap_next_reference(ld,entry))
|
||||
+ {
|
||||
+ char **refs = NULL;
|
||||
+ PyObject* entrytuple;
|
||||
+ PyObject* reflist = PyList_New(0);
|
||||
+
|
||||
+ if (reflist == NULL) {
|
||||
+ Py_DECREF(result);
|
||||
+ ldap_msgfree( m );
|
||||
+ return NULL;
|
||||
+ }
|
||||
+ if (ldap_parse_reference(ld, entry, &refs, NULL, 0) != LDAP_SUCCESS) {
|
||||
+ Py_DECREF(result);
|
||||
+ ldap_msgfree( m );
|
||||
+ return LDAPerror( ld, "ldap_parse_reference" );
|
||||
+ }
|
||||
+ if (refs) {
|
||||
+ int i;
|
||||
+ for (i=0; refs[i] != NULL; i++) {
|
||||
+ PyObject *refstr = PyString_FromString(refs[i]);
|
||||
+ PyList_Append(reflist, refstr);
|
||||
+ Py_DECREF(refstr);
|
||||
+ }
|
||||
+ ber_memvfree( (void **) refs );
|
||||
+ }
|
||||
+ entrytuple = Py_BuildValue("(sO)", NULL, reflist);
|
||||
+ Py_DECREF(reflist);
|
||||
+ PyList_Append(result, entrytuple);
|
||||
+ Py_DECREF(entrytuple);
|
||||
+ }
|
||||
+#endif
|
||||
ldap_msgfree( m );
|
||||
return result;
|
||||
}
|
@ -1 +1 @@
|
||||
An LDAP module for python
|
||||
An LDAP module for python, for OpenLDAP2
|
||||
|
@ -1,12 +1,16 @@
|
||||
lib/%%PYTHON_VERSION%%/site-packages/python-ldap/ldap.py
|
||||
lib/%%PYTHON_VERSION%%/site-packages/python-ldap/ldap.pyc
|
||||
lib/%%PYTHON_VERSION%%/site-packages/python-ldap/ldap.pyo
|
||||
lib/%%PYTHON_VERSION%%/site-packages/python-ldap/ldif.py
|
||||
lib/%%PYTHON_VERSION%%/site-packages/python-ldap/ldif.pyc
|
||||
lib/%%PYTHON_VERSION%%/site-packages/python-ldap/ldif.pyo
|
||||
lib/%%PYTHON_VERSION%%/site-packages/python-ldap/perldap.py
|
||||
lib/%%PYTHON_VERSION%%/site-packages/python-ldap/perldap.pyc
|
||||
lib/%%PYTHON_VERSION%%/site-packages/python-ldap/perldap.pyo
|
||||
lib/%%PYTHON_VERSION%%/site-packages/_ldapmodule.so
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldap.pth
|
||||
@dirrm lib/%%PYTHON_VERSION%%/site-packages/python-ldap
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldap/__init__.py
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldap/__init__.pyc
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldap/async.py
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldap/async.pyc
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldap/functions.py
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldap/functions.pyc
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldap/ldapobject.py
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldap/ldapobject.pyc
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldap/modlist.py
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldap/modlist.pyc
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldapurl.py
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldapurl.pyc
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldif.py
|
||||
lib/%%PYTHON_VERSION%%/site-packages/ldif.pyc
|
||||
lib/%%PYTHON_VERSION%%/site-packages/_ldap.so
|
||||
@dirrm lib/%%PYTHON_VERSION%%/site-packages/ldap
|
||||
|
Loading…
Reference in New Issue
Block a user