annotate src/eldap.c @ 280:7df0dd720c89 r21-0b38

Import from CVS: tag r21-0b38
author cvs
date Mon, 13 Aug 2007 10:32:22 +0200
parents 90d73dddcdc4
children c42ec1d1cded
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
1 /* LDAP client interface for XEmacs.
265
8efd647ea9ca Import from CVS: tag r20-5b31
cvs
parents: 261
diff changeset
2 Copyright (C) 1998 Free Software Foundation, Inc.
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
3
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
4 This file is part of XEmacs.
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
5
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
6 XEmacs is free software; you can redistribute it and/or modify it
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
7 under the terms of the GNU General Public License as published by the
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
8 Free Software Foundation; either version 2, or (at your option) any
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
9 later version.
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
10
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
11 XEmacs is distributed in the hope that it will be useful, but WITHOUT
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
12 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
14 for more details.
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
15
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
17 along with XEmacs; see the file COPYING. If not, write to
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
19 Boston, MA 02111-1307, USA. */
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
20
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
21 /* Synched up with: Not in FSF. */
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
22
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
23 /* Author: Oscar Figueiredo */
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
24
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
25 /* This file provides lisp primitives for access to an LDAP library
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
26 conforming to the API defined in RFC 1823.
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
27 It has been tested with:
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
28 - UMich LDAP 3.3 (http://www.umich.edu/~dirsvcs/ldap/)
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
29 - Netscape's LDAP SDK 1.0 (http://developer.netscape.com) */
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
30
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
31
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
32 #include <config.h>
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
33 #include "lisp.h"
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
34 #include "opaque.h"
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
35
265
8efd647ea9ca Import from CVS: tag r20-5b31
cvs
parents: 261
diff changeset
36 #include <errno.h>
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
37 #include <lber.h>
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
38 #include <ldap.h>
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
39
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
40 #include "eldap.h"
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
41
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
42 #ifdef HAVE_NS_LDAP
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
43 #define HAVE_LDAP_SET_OPTION 1
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
44 #define HAVE_LDAP_GET_ERRNO 1
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
45 #else
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
46 #undef HAVE_LDAP_SET_OPTION
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
47 #undef HAVE_LDAP_GET_ERRNO
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
48 #endif
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
49
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
50 static int ldap_default_port;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
51 static Lisp_Object Vldap_default_base;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
52
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
53 /* ldap-open plist keywords */
280
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
54 extern Lisp_Object Qport, Qauth, Qbinddn, Qpasswd, Qderef, Qtimelimit,
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
55 Qsizelimit;
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
56 /* Search scope limits */
280
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
57 extern Lisp_Object Qbase, Qonelevel, Qsubtree;
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
58 /* Authentication methods */
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
59 #ifdef LDAP_AUTH_KRBV41
280
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
60 extern Lisp_Object Qkrbv41;
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
61 #endif
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
62 #ifdef LDAP_AUTH_KRBV42
280
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
63 extern Lisp_Object Qkrbv42;
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
64 #endif
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
65 /* Deref policy */
280
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
66 extern Lisp_Object Qnever, Qalways, Qfind;
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
67 /* Connection status */
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
68 extern Lisp_Object Qopen, Qclosed;
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
69
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
70 static Lisp_Object Qldapp;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
71
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
72
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
73 /************************************************************************/
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
74 /* Utility Functions */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
75 /************************************************************************/
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
76
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
77 static void
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
78 signal_ldap_error (LDAP *ld)
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
79 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
80 #if HAVE_LDAP_GET_ERRNO
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
81 signal_simple_error
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
82 ("LDAP error",
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
83 build_string (ldap_err2string (ldap_get_lderrno (ld, NULL, NULL))));
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
84 #else
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
85 signal_simple_error ("LDAP error",
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
86 build_string (ldap_err2string (ld->ld_errno)));
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
87 #endif
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
88 }
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
89
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
90
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
91 /************************************************************************/
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
92 /* The ldap Lisp object */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
93 /************************************************************************/
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
94
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
95 /*
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
96 * Structure records pertinent information about an open LDAP connection.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
97 */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
98
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
99 struct Lisp_LDAP
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
100 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
101 /* lcrecord header */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
102 struct lcrecord_header header;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
103 /* The LDAP connection handle used by the LDAP API */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
104 LDAP *ld;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
105 /* Name of the host we connected to */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
106 Lisp_Object host;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
107 /* Status of the LDAP connection.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
108 This is a symbol: open or closed */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
109 Lisp_Object status_symbol;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
110 };
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
111
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
112
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
113
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
114 static Lisp_Object
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
115 mark_ldap (Lisp_Object obj, void (*markobj) (Lisp_Object))
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
116 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
117 struct Lisp_LDAP *ldap = XLDAP (obj);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
118 ((markobj) (ldap->host));
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
119 return ldap->status_symbol;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
120 }
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
121
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
122 static void
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
123 print_ldap (Lisp_Object obj, Lisp_Object printcharfun, int escapeflag)
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
124 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
125 char buf[16];
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
126
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
127 struct Lisp_LDAP *ldap = XLDAP (obj);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
128
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
129 if (print_readably)
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
130 error ("printing unreadable object #<ldap %s>",
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
131 XSTRING_DATA (ldap->host));
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
132
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
133 write_c_string ("#<ldap ", printcharfun);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
134 print_internal (ldap->host, printcharfun, 1);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
135 write_c_string (" state:",printcharfun);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
136 print_internal (ldap->status_symbol, printcharfun, 1);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
137 sprintf (buf, " 0x%x>", ldap);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
138 write_c_string (buf, printcharfun);
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
139 }
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
140
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
141 static struct Lisp_LDAP *
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
142 allocate_ldap (void)
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
143 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
144 struct Lisp_LDAP *ldap =
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
145 alloc_lcrecord_type (struct Lisp_LDAP, lrecord_ldap);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
146
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
147 ldap->ld = (LDAP *) NULL;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
148 ldap->host = Qnil;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
149 ldap->status_symbol = Qnil;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
150 return ldap;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
151 }
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
152
280
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
153 static void
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
154 finalize_ldap (void *header, int for_disksave)
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
155 {
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
156 struct Lisp_LDAP *ldap = (struct Lisp_LDAP *) header;
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
157
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
158 if (for_disksave)
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
159 {
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
160 Lisp_Object obj;
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
161 XSETLDAP (obj, ldap);
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
162 signal_simple_error
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
163 ("Can't dump an emacs containing LDAP objects", obj);
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
164 }
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
165 if (EQ (ldap->status_symbol, Qopen))
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
166 ldap_unbind (ldap->ld);
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
167 }
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
168
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
169 DEFINE_LRECORD_IMPLEMENTATION ("ldap", ldap,
280
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
170 mark_ldap, print_ldap, finalize_ldap,
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
171 NULL, NULL, struct Lisp_LDAP);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
172
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
173
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
174
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
175
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
176 /************************************************************************/
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
177 /* Basic ldap accessors */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
178 /************************************************************************/
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
179
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
180 DEFUN ("ldapp", Fldapp, 1, 1, 0, /*
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
181 Return t if OBJECT is a LDAP connection.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
182 */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
183 (object))
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
184 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
185 return LDAPP (object) ? Qt : Qnil;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
186 }
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
187
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
188
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
189 DEFUN ("ldap-host", Fldap_host, 1, 1, 0, /*
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
190 Return the server host of the connection LDAP, as a string.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
191 */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
192 (ldap))
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
193 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
194 CHECK_LDAP (ldap);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
195 return (XLDAP (ldap))->host;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
196 }
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
197
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
198
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
199
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
200 DEFUN ("ldap-status", Fldap_status, 1, 1, 0, /*
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
201 Return the status of the connection LDAP.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
202 This is a symbol, one of these:
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
203
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
204 open -- for a LDAP connection that is open.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
205 closed -- for a LDAP connection that is closed.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
206 */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
207 (ldap))
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
208 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
209 CHECK_LDAP (ldap);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
210 return (XLDAP (ldap))->status_symbol;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
211 }
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
212
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
213
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
214
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
215 /************************************************************************/
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
216 /* Opening/Closing a LDAP connection */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
217 /************************************************************************/
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
218
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
219
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
220 DEFUN ("ldap-open", Fldap_open, 1, 2, 0, /*
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
221 Open a LDAP connection to HOST.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
222 PLIST is a plist containing additional parameters for the connection.
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
223 Valid keys in that list are:
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
224 `port' the TCP port to use for the connection if different from
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
225 `ldap-default-port'.
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
226 `auth' is the authentication method to use, possible values depend on
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
227 the LDAP library XEmacs was compiled with: `simple', `krbv41' and `krbv42'.
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
228 `binddn' is the distinguished name of the user to bind as (in RFC 1779 syntax).
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
229 `passwd' is the password to use for simple authentication.
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
230 `deref' is one of the symbols `never', `always', `search' or `find'.
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
231 `timelimit' is the timeout limit for the connection in seconds.
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
232 `sizelimit' is the maximum number of matches to return.
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
233 */
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
234 (host, plist))
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
235 {
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
236 /* This function can call lisp */
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
237
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
238 struct Lisp_LDAP *lisp_ldap;
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
239 LDAP *ld;
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
240 int ldap_port = 0;
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
241 int ldap_auth = LDAP_AUTH_SIMPLE;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
242 char *ldap_binddn = NULL;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
243 char *ldap_passwd = NULL;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
244 int ldap_deref = LDAP_DEREF_NEVER;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
245 int ldap_timelimit = 0;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
246 int ldap_sizelimit = 0;
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
247 int err;
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
248
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
249 Lisp_Object ldap, list, keyword, value;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
250 struct gcpro gcpro1;
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
251
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
252 ldap = Qnil;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
253 GCPRO1 (ldap);
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
254
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
255 CHECK_STRING (host);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
256
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
257 EXTERNAL_PROPERTY_LIST_LOOP(list, keyword, value, plist)
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
258 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
259 /* TCP Port */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
260 if (EQ (keyword, Qport))
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
261 {
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
262 CHECK_INT (value);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
263 ldap_port = XINT (value);
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
264 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
265 /* Authentication method */
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
266 if (EQ (keyword, Qauth))
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
267 {
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
268 CHECK_SYMBOL (value);
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
269
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
270 if (EQ (value, Qsimple))
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
271 ldap_auth = LDAP_AUTH_SIMPLE;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
272 #ifdef LDAP_AUTH_KRBV41
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
273 else if (EQ (value, Qkrbv41))
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
274 ldap_auth = LDAP_AUTH_KRBV41;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
275 #endif
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
276 #ifdef LDAP_AUTH_KRBV42
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
277 else if (EQ (value, Qkrbv42))
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
278 ldap_auth = LDAP_AUTH_KRBV42;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
279 #endif
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
280 else
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
281 signal_simple_error ("Invalid authentication method", value);
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
282 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
283 /* Bind DN */
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
284 else if (EQ (keyword, Qbinddn))
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
285 {
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
286 CHECK_STRING (value);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
287 ldap_binddn = alloca (XSTRING_LENGTH (value) + 1);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
288 strcpy (ldap_binddn, (char *)XSTRING_DATA (value));
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
289 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
290 /* Password */
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
291 else if (EQ (keyword, Qpasswd))
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
292 {
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
293 CHECK_STRING (value);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
294 ldap_passwd = alloca (XSTRING_LENGTH (value) + 1);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
295 strcpy (ldap_passwd, (char *)XSTRING_DATA (value));
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
296 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
297 /* Deref */
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
298 else if (EQ (keyword, Qderef))
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
299 {
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
300 CHECK_SYMBOL (value);
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
301 if (EQ (value, Qnever))
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
302 ldap_deref = LDAP_DEREF_NEVER;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
303 else if (EQ (value, Qsearch))
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
304 ldap_deref = LDAP_DEREF_SEARCHING;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
305 else if (EQ (value, Qfind))
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
306 ldap_deref = LDAP_DEREF_FINDING;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
307 else if (EQ (value, Qalways))
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
308 ldap_deref = LDAP_DEREF_ALWAYS;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
309 else
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
310 signal_simple_error ("Invalid deref value", value);
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
311 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
312 /* Timelimit */
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
313 else if (EQ (keyword, Qtimelimit))
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
314 {
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
315 CHECK_INT (value);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
316 ldap_timelimit = XINT (value);
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
317 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
318 /* Sizelimit */
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
319 else if (EQ (keyword, Qsizelimit))
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
320 {
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
321 CHECK_INT (value);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
322 ldap_sizelimit = XINT (value);
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
323 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
324 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
325
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
326 if (ldap_port == 0)
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
327 {
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
328 ldap_port = ldap_default_port;
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
329 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
330
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
331 /* Connect to the server and bind */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
332 ld = ldap_open ((char *)XSTRING_DATA (host), ldap_port);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
333 if (ld == NULL )
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
334 signal_simple_error_2 ("Failed connecting to host",
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
335 host,
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
336 lisp_strerror (errno));
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
337
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
338
280
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
339 #ifdef HAVE_LDAP_SET_OPTION
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
340 if (ldap_set_option (ld, LDAP_OPT_DEREF, (void *)&ldap_deref) != LDAP_SUCCESS)
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
341 signal_ldap_error (ld);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
342 if (ldap_set_option (ld, LDAP_OPT_TIMELIMIT,
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
343 (void *)&ldap_timelimit) != LDAP_SUCCESS)
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
344 signal_ldap_error (ld);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
345 if (ldap_set_option (ld, LDAP_OPT_SIZELIMIT,
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
346 (void *)&ldap_sizelimit) != LDAP_SUCCESS)
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
347 signal_ldap_error (ld);
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
348 if (ldap_set_option (ld, LDAP_OPT_REFERRALS, LDAP_OPT_ON) != LDAP_SUCCESS)
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
349 signal_ldap_error (ld);
280
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
350 #else /* not HAVE_LDAP_SET_OPTION */
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
351 ld->ld_deref = ldap_deref;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
352 ld->ld_timelimit = ldap_timelimit;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
353 ld->ld_sizelimit = ldap_sizelimit;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
354 #ifdef LDAP_REFERRALS
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
355 ld->ld_options = LDAP_OPT_REFERRALS;
280
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
356 #else /* not LDAP_REFERRALS */
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
357 ld->ld_options = 0;
280
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
358 #endif /* not LDAP_REFERRALS */
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
359 #endif /* not HAVE_LDAP_SET_OPTION */
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
360
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
361 /* ldap_bind_s calls select and may be wedged by spurious signals */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
362 slow_down_interrupts ();
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
363 err = ldap_bind_s (ld, ldap_binddn, ldap_passwd, ldap_auth);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
364 speed_up_interrupts ();
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
365 if (err != LDAP_SUCCESS)
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
366 signal_simple_error ("Failed binding to the server",
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
367 build_string (ldap_err2string (err)));
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
368
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
369 lisp_ldap = allocate_ldap ();
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
370 lisp_ldap->ld = ld;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
371 lisp_ldap->host = host;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
372 lisp_ldap->status_symbol = Qopen;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
373 XSETLDAP (ldap,lisp_ldap);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
374
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
375 UNGCPRO;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
376 return ldap;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
377 }
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
378
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
379
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
380
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
381 DEFUN ("ldap-close", Fldap_close, 1, 1, 0, /*
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
382 Close an LDAP connection.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
383 */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
384 (ldap))
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
385 {
280
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
386 struct Lisp_LDAP *lldap;
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
387 CHECK_LIVE_LDAP (ldap);
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
388 lldap = XLDAP (ldap);
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
389 ldap_unbind (lldap->ld);
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
390 lldap->status_symbol = Qclosed;
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
391 return Qnil;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
392 }
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
393
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
394
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
395
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
396 /************************************************************************/
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
397 /* Working on a LDAP connection */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
398 /************************************************************************/
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
399 struct ldap_unwind_struct
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
400 {
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
401 LDAPMessage *res;
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
402 char **vals;
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
403 };
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
404
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
405
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
406 static Lisp_Object
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
407 ldap_search_unwind (Lisp_Object unwind_obj)
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
408 {
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
409 struct ldap_unwind_struct *unwind =
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
410 (struct ldap_unwind_struct *) get_opaque_ptr (unwind_obj);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
411 if (unwind->res != (LDAPMessage *)NULL)
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
412 ldap_msgfree (unwind->res);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
413 if (unwind->vals != (char **)NULL)
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
414 ldap_value_free (unwind->vals);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
415 }
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
416
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
417 DEFUN ("ldap-search-internal", Fldap_search_internal, 2, 6, 0, /*
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
418 Perform a search on an open LDAP connection.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
419 LDAP is an LDAP connection object created with `ldap-open'.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
420 FILTER is a filter string for the search as described in RFC 1558
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
421 BASE is the distinguished name at which to start the search
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
422 SCOPE is an integer or a symbol indicating the scope of the search
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
423 Possible values are `ldap-scope-base', `ldap-scope-onelevel' or
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
424 `ldap-scope-subtree'
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
425 ATTRS is a list of strings indicating which attributes to retrieve
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
426 for each matching entry. If nil return all available attributes.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
427 If ATTRSONLY is non-nil then only the attributes are retrieved, not
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
428 the associated values
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
429 The function returns a list of matching entries. Each entry is itself
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
430 an alist of attribute/values.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
431 */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
432 (ldap, filter, base, scope, attrs, attrsonly))
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
433 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
434 /* This function can call lisp */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
435
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
436 /* Vars for query */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
437 LDAP *ld;
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
438 LDAPMessage *e;
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
439 BerElement *ptr;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
440 char *a;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
441 int i, rc, err;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
442 int matches;
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
443 struct ldap_unwind_struct unwind;
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
444
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
445 int ldap_scope = LDAP_SCOPE_SUBTREE;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
446 char **ldap_attributes = NULL;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
447
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
448 int speccount = specpdl_depth ();
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
449
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
450 Lisp_Object list, entry, result;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
451 struct gcpro gcpro1, gcpro2, gcpro3;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
452
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
453 list = entry = result = Qnil;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
454 GCPRO3(list, entry, result);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
455
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
456 unwind.res = (LDAPMessage *)NULL;
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
457 unwind.vals = (char **)NULL;
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
458
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
459 /* Do all the parameter checking */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
460 CHECK_LIVE_LDAP (ldap);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
461 ld = (XLDAP (ldap))->ld;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
462
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
463 /* Filter */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
464 CHECK_STRING (filter);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
465
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
466 /* Search base */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
467 if (NILP (base))
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
468 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
469 base = Vldap_default_base;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
470 }
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
471 if (!NILP (base))
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
472 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
473 CHECK_STRING (Vldap_default_base);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
474 }
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
475
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
476 /* Search scope */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
477 if (!NILP (scope))
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
478 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
479 CHECK_SYMBOL (scope);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
480 if (EQ (scope, Qbase))
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
481 ldap_scope = LDAP_SCOPE_BASE;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
482 else if (EQ (scope, Qonelevel))
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
483 ldap_scope = LDAP_SCOPE_ONELEVEL;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
484 else if (EQ (scope, Qsubtree))
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
485 ldap_scope = LDAP_SCOPE_SUBTREE;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
486 else
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
487 signal_simple_error ("Invalid scope", scope);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
488 }
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
489
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
490 /* Attributes to search */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
491 if (!NILP (attrs))
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
492 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
493 CHECK_CONS (attrs);
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
494 ldap_attributes = alloca_array (char *, 1 + XINT (Flength (attrs)));
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
495
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
496 i = 0;
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
497 EXTERNAL_LIST_LOOP (attrs, attrs)
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
498 {
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
499 Lisp_Object current = XCAR (attrs);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
500 CHECK_STRING (current);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
501 ldap_attributes[i] =
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
502 alloca_array (char, 1 + XSTRING_LENGTH (current));
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
503 memcpy (ldap_attributes[i],
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
504 XSTRING_DATA (current), XSTRING_LENGTH (current));
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
505 ++i;
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
506 }
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
507 ldap_attributes[i] = NULL;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
508 }
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
509
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
510 /* Attributes only ? */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
511 CHECK_SYMBOL (attrsonly);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
512
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
513
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
514 /* Perform the search */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
515 if (ldap_search (ld,
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
516 NILP (base) ? "" : (char *) XSTRING_DATA (base),
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
517 ldap_scope,
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
518 NILP (filter) ? "" : (char *) XSTRING_DATA (filter),
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
519 ldap_attributes,
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
520 NILP (attrsonly) ? 0 : 1)
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
521 == -1)
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
522 {
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
523 signal_ldap_error (ld);
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
524 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
525
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
526 /* Ensure we don't exit without cleaning up */
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
527 record_unwind_protect (ldap_search_unwind,
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
528 make_opaque_ptr (&unwind));
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
529
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
530 /* Build the results list */
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
531 matches = 0;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
532
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
533 /* ldap_result calls select() and can get wedged by EINTR signals */
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
534 slow_down_interrupts ();
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
535 rc = ldap_result (ld, LDAP_RES_ANY, 0, NULL, &(unwind.res));
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
536 speed_up_interrupts ();
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
537 while ( rc == LDAP_RES_SEARCH_ENTRY )
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
538 {
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
539 QUIT;
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
540 matches ++;
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
541 e = ldap_first_entry (ld, unwind.res);
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
542 message ("Parsing results... %d", matches);
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
543 entry = Qnil;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
544 for (a= ldap_first_attribute (ld, e, &ptr);
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
545 a != NULL;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
546 a= ldap_next_attribute (ld, e, ptr) )
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
547 {
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
548 list = Fcons (build_string (a), Qnil);
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
549 unwind.vals = ldap_get_values (ld, e, a);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
550 if (unwind.vals != NULL)
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
551 {
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
552 for (i=0; unwind.vals[i]!=NULL; i++)
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
553 {
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
554 list = Fcons (build_string (unwind.vals[i]),
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
555 list);
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
556 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
557 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
558 entry = Fcons (Fnreverse (list),
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
559 entry);
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
560 ldap_value_free (unwind.vals);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
561 unwind.vals = (char **)NULL;
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
562 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
563 result = Fcons (Fnreverse (entry),
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
564 result);
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
565 ldap_msgfree (unwind.res);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
566 unwind.res = (LDAPMessage *)NULL;
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
567
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
568 slow_down_interrupts ();
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
569 rc = ldap_result (ld, LDAP_RES_ANY, 0, NULL, &(unwind.res));
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
570 speed_up_interrupts ();
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
571 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
572
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
573 if (rc == -1)
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
574 {
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
575 signal_ldap_error (ld);
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
576 }
280
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
577 rc = ldap_result2error (ld, unwind.res, 0);
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
578 if ((rc != LDAP_SUCCESS) &&
7df0dd720c89 Import from CVS: tag r21-0b38
cvs
parents: 278
diff changeset
579 (rc != LDAP_SIZELIMIT_EXCEEDED))
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
580 {
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
581 signal_ldap_error (ld);
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
582 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
583
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
584 ldap_msgfree (unwind.res);
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
585 unwind.res = (LDAPMessage *)NULL;
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
586 message ("Done.");
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
587
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
588 result = Fnreverse (result);
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
589 clear_message ();
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
590
278
90d73dddcdc4 Import from CVS: tag r21-0b37
cvs
parents: 276
diff changeset
591 unbind_to (speccount, Qnil);
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
592 UNGCPRO;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
593 return result;
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
594 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
595
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
596
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
597 void
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
598 syms_of_eldap (void)
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
599 {
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
600 defsymbol (&Qldapp, "ldapp");
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
601
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
602 DEFSUBR (Fldapp);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
603 DEFSUBR (Fldap_host);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
604 DEFSUBR (Fldap_status);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
605 DEFSUBR (Fldap_open);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
606 DEFSUBR (Fldap_close);
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
607 DEFSUBR (Fldap_search_internal);
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
608 }
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
609
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
610 void
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
611 vars_of_eldap (void)
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
612 {
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
613 Fprovide (intern ("ldap"));
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
614
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
615 ldap_default_port = LDAP_PORT;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
616 Vldap_default_base = Qnil;
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
617
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
618 DEFVAR_INT ("ldap-default-port", &ldap_default_port /*
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
619 Default TCP port for LDAP connections.
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
620 Initialized from the LDAP library. Default value is 389.
259
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
621 */ );
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
622
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
623 DEFVAR_LISP ("ldap-default-base", &Vldap_default_base /*
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
624 Default base for LDAP searches.
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
625 This is a string using the syntax of RFC 1779.
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
626 For instance, "o=ACME, c=US" limits the search to the
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
627 Acme organization in the United States.
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
628 */ );
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
629
11cf20601dec Import from CVS: tag r20-5b28
cvs
parents:
diff changeset
630 }
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
631
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 272
diff changeset
632