ruby-ldap 0.9.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/COPYING +24 -0
- data/ChangeLog +762 -0
- data/FAQ +62 -0
- data/NOTES +77 -0
- data/README +266 -0
- data/TODO +15 -0
- data/conn.c +1810 -0
- data/entry.c +215 -0
- data/extconf.rb +268 -0
- data/ldap.c +577 -0
- data/lib/ldap/control.rb +50 -0
- data/lib/ldap/ldif.rb +569 -0
- data/lib/ldap/schema.rb +129 -0
- data/misc.c +512 -0
- data/mod.c +355 -0
- data/rbldap.h +194 -0
- data/saslconn.c +176 -0
- data/sslconn.c +377 -0
- data/test/add.rb +31 -0
- data/test/add2.rb +31 -0
- data/test/add3.rb +33 -0
- data/test/bind-ldaps.rb +25 -0
- data/test/bind-sasl.rb +17 -0
- data/test/bind-ssl.rb +25 -0
- data/test/bind.rb +34 -0
- data/test/compare.rb +17 -0
- data/test/conf.rb +12 -0
- data/test/delete.rb +13 -0
- data/test/ext.rb +49 -0
- data/test/misc1.rb +49 -0
- data/test/misc2.rb +40 -0
- data/test/modrdn.rb +23 -0
- data/test/search.rb +20 -0
- data/test/search2.rb +34 -0
- data/test/search3.rb +23 -0
- data/test/setup.rb +38 -0
- data/test/subschema.rb +21 -0
- data/test/tc_conn.rb +124 -0
- data/test/tc_ldif.rb +174 -0
- data/test/tc_schema.rb +32 -0
- data/test/tc_search.rb +137 -0
- data/test/ts_ldap.rb +8 -0
- data/win/winlber.h +21 -0
- data/win/winldap.h +324 -0
- metadata +100 -0
data/mod.c
ADDED
@@ -0,0 +1,355 @@
|
|
1
|
+
/*
|
2
|
+
* mod.c
|
3
|
+
* $Id: mod.c,v 1.14 2005/03/07 22:57:34 ianmacd Exp $
|
4
|
+
*/
|
5
|
+
|
6
|
+
#include "ruby.h"
|
7
|
+
#include "rbldap.h"
|
8
|
+
|
9
|
+
VALUE rb_cLDAP_Mod;
|
10
|
+
|
11
|
+
|
12
|
+
void
|
13
|
+
rb_ldap_mod_free (RB_LDAPMOD_DATA * data)
|
14
|
+
{
|
15
|
+
if (data->mod)
|
16
|
+
{
|
17
|
+
struct berval **bvals;
|
18
|
+
char **svals;
|
19
|
+
int i;
|
20
|
+
|
21
|
+
if (data->mod->mod_op & LDAP_MOD_BVALUES)
|
22
|
+
{
|
23
|
+
bvals = data->mod->mod_vals.modv_bvals;
|
24
|
+
for (i = 0; bvals[i] != NULL; i++)
|
25
|
+
{
|
26
|
+
xfree (bvals[i]);
|
27
|
+
}
|
28
|
+
xfree (bvals);
|
29
|
+
}
|
30
|
+
else
|
31
|
+
{
|
32
|
+
svals = data->mod->mod_vals.modv_strvals;
|
33
|
+
for (i = 0; svals[i] != NULL; i++)
|
34
|
+
{
|
35
|
+
xfree (svals[i]);
|
36
|
+
}
|
37
|
+
xfree (svals);
|
38
|
+
}
|
39
|
+
xfree (data->mod);
|
40
|
+
}
|
41
|
+
}
|
42
|
+
|
43
|
+
static LDAPMod *
|
44
|
+
rb_ldap_new_mod (int mod_op, char *mod_type, char **modv_strvals)
|
45
|
+
{
|
46
|
+
LDAPMod *mod;
|
47
|
+
|
48
|
+
if (mod_op & LDAP_MOD_BVALUES)
|
49
|
+
{
|
50
|
+
rb_bug ("rb_ldap_mod_new: illegal mod_op");
|
51
|
+
}
|
52
|
+
|
53
|
+
mod = ALLOC_N (LDAPMod, 1);
|
54
|
+
mod->mod_op = mod_op;
|
55
|
+
mod->mod_type = mod_type;
|
56
|
+
mod->mod_vals.modv_strvals = modv_strvals;
|
57
|
+
|
58
|
+
return mod;
|
59
|
+
}
|
60
|
+
|
61
|
+
VALUE
|
62
|
+
rb_ldap_mod_new (int mod_op, char *mod_type, char **modv_strvals)
|
63
|
+
{
|
64
|
+
VALUE obj;
|
65
|
+
RB_LDAPMOD_DATA *moddata;
|
66
|
+
|
67
|
+
obj = Data_Make_Struct (rb_cLDAP_Mod, RB_LDAPMOD_DATA,
|
68
|
+
0, rb_ldap_mod_free, moddata);
|
69
|
+
moddata->mod = rb_ldap_new_mod (mod_op, mod_type, modv_strvals);
|
70
|
+
|
71
|
+
return obj;
|
72
|
+
}
|
73
|
+
|
74
|
+
static LDAPMod *
|
75
|
+
rb_ldap_new_mod2 (int mod_op, char *mod_type, struct berval **modv_bvals)
|
76
|
+
{
|
77
|
+
LDAPMod *mod;
|
78
|
+
|
79
|
+
if (!(mod_op & LDAP_MOD_BVALUES))
|
80
|
+
{
|
81
|
+
rb_bug ("rb_ldap_mod_new: illegal mod_op");
|
82
|
+
}
|
83
|
+
|
84
|
+
mod = ALLOC_N (LDAPMod, 1);
|
85
|
+
mod->mod_op = mod_op;
|
86
|
+
mod->mod_type = mod_type;
|
87
|
+
mod->mod_vals.modv_bvals = modv_bvals;
|
88
|
+
|
89
|
+
return mod;
|
90
|
+
}
|
91
|
+
|
92
|
+
VALUE
|
93
|
+
rb_ldap_mod_new2 (int mod_op, char *mod_type, struct berval ** modv_bvals)
|
94
|
+
{
|
95
|
+
VALUE obj;
|
96
|
+
RB_LDAPMOD_DATA *moddata;
|
97
|
+
|
98
|
+
obj = Data_Make_Struct (rb_cLDAP_Mod, RB_LDAPMOD_DATA,
|
99
|
+
0, rb_ldap_mod_free, moddata);
|
100
|
+
moddata->mod = rb_ldap_new_mod2 (mod_op, mod_type, modv_bvals);
|
101
|
+
|
102
|
+
return obj;
|
103
|
+
}
|
104
|
+
|
105
|
+
static VALUE
|
106
|
+
rb_ldap_mod_s_allocate (VALUE klass)
|
107
|
+
{
|
108
|
+
RB_LDAPMOD_DATA *moddata;
|
109
|
+
VALUE obj;
|
110
|
+
|
111
|
+
obj =
|
112
|
+
Data_Make_Struct (klass, RB_LDAPMOD_DATA, 0, rb_ldap_mod_free, moddata);
|
113
|
+
moddata->mod = NULL;
|
114
|
+
|
115
|
+
return obj;
|
116
|
+
}
|
117
|
+
|
118
|
+
/*
|
119
|
+
* call-seq:
|
120
|
+
* Mod.new(mod_type, attr, vals) => LDAP::Mod
|
121
|
+
*
|
122
|
+
* Create a new LDAP::Mod object of type +mod_type+. This is most commonly
|
123
|
+
* *LDAP_MOD_ADD*, *LDAP_MOD_REPLACE* or *LDAP_MOD_DELETE*, although some LDAP
|
124
|
+
* servers may offer extension types.
|
125
|
+
*
|
126
|
+
* +attr+ should be the name of the attribute on which to operate, whilst
|
127
|
+
* +vals+ is an array of values pertaining to +attr+. If +vals+ contains
|
128
|
+
* binary data, +mod_type+ should be logically OR'ed (|) with
|
129
|
+
* *LDAP_MOD_BVALUES*.
|
130
|
+
*
|
131
|
+
* LDAP::Mod objects can be passed to methods in the LDAP::Conn class, such as
|
132
|
+
* Conn#add, Conn#add_ext, Conn#modify and Conn#modify_ext.
|
133
|
+
*/
|
134
|
+
static VALUE
|
135
|
+
rb_ldap_mod_initialize (int argc, VALUE argv[], VALUE self)
|
136
|
+
{
|
137
|
+
struct berval **bvals;
|
138
|
+
char **strvals;
|
139
|
+
int mod_op;
|
140
|
+
char *mod_type;
|
141
|
+
int i;
|
142
|
+
VALUE op, type, vals;
|
143
|
+
RB_LDAPMOD_DATA *moddata;
|
144
|
+
|
145
|
+
rb_scan_args (argc, argv, "3", &op, &type, &vals);
|
146
|
+
Data_Get_Struct (self, RB_LDAPMOD_DATA, moddata);
|
147
|
+
if (moddata->mod)
|
148
|
+
return Qnil;
|
149
|
+
|
150
|
+
mod_op = NUM2INT (op);
|
151
|
+
mod_type = StringValueCStr (type);
|
152
|
+
Check_Type (vals, T_ARRAY);
|
153
|
+
|
154
|
+
if (mod_op & LDAP_MOD_BVALUES)
|
155
|
+
{
|
156
|
+
bvals = ALLOC_N (struct berval *, RARRAY_LEN (vals) + 1);
|
157
|
+
for (i = 0; i < RARRAY_LEN (vals); i++)
|
158
|
+
{
|
159
|
+
VALUE str;
|
160
|
+
struct berval *bval;
|
161
|
+
str = RARRAY_PTR (vals)[i];
|
162
|
+
Check_Type (str, T_STRING);
|
163
|
+
bval = ALLOC_N (struct berval, 1);
|
164
|
+
bval->bv_len = RSTRING_LEN (str);
|
165
|
+
RB_LDAP_SET_STR (bval->bv_val, str);
|
166
|
+
bvals[i] = bval;
|
167
|
+
}
|
168
|
+
bvals[i] = NULL;
|
169
|
+
moddata->mod = rb_ldap_new_mod2 (mod_op, mod_type, bvals);
|
170
|
+
}
|
171
|
+
else
|
172
|
+
{
|
173
|
+
strvals = ALLOC_N (char *, RARRAY_LEN (vals) + 1);
|
174
|
+
for (i = 0; i < RARRAY_LEN (vals); i++)
|
175
|
+
{
|
176
|
+
VALUE str;
|
177
|
+
char *sval;
|
178
|
+
str = RARRAY_PTR (vals)[i];
|
179
|
+
RB_LDAP_SET_STR (sval, str);
|
180
|
+
strvals[i] = sval;
|
181
|
+
}
|
182
|
+
strvals[i] = NULL;
|
183
|
+
moddata->mod = rb_ldap_new_mod (mod_op, mod_type, strvals);
|
184
|
+
}
|
185
|
+
|
186
|
+
return Qnil;
|
187
|
+
}
|
188
|
+
|
189
|
+
/*
|
190
|
+
* call-seq:
|
191
|
+
* mod.mod_op => Fixnum
|
192
|
+
*
|
193
|
+
* Return the type of modification associated with the LDAP::Mod object.
|
194
|
+
* Standard types are *LDAP_MOD_ADD*, *LDAP_MOD_REPLACE* and
|
195
|
+
* *LDAP_MOD_DELETE*, although any of these may be logically OR'ed with
|
196
|
+
* *LDAP_MOD_BVALUES* to indicate that the values of the Mod object contain
|
197
|
+
* binary data.
|
198
|
+
*/
|
199
|
+
VALUE
|
200
|
+
rb_ldap_mod_op (VALUE self)
|
201
|
+
{
|
202
|
+
RB_LDAPMOD_DATA *moddata;
|
203
|
+
|
204
|
+
GET_LDAPMOD_DATA (self, moddata);
|
205
|
+
return INT2NUM (moddata->mod->mod_op);
|
206
|
+
}
|
207
|
+
|
208
|
+
/*
|
209
|
+
* call-seq:
|
210
|
+
* mod.mod_type => String
|
211
|
+
*
|
212
|
+
* Return the name of the attribute associated with the LDAP::Mod object.
|
213
|
+
*/
|
214
|
+
VALUE
|
215
|
+
rb_ldap_mod_type (VALUE self)
|
216
|
+
{
|
217
|
+
RB_LDAPMOD_DATA *moddata;
|
218
|
+
|
219
|
+
GET_LDAPMOD_DATA (self, moddata);
|
220
|
+
return rb_tainted_str_new2 (moddata->mod->mod_type);
|
221
|
+
}
|
222
|
+
|
223
|
+
/*
|
224
|
+
* call-seq:
|
225
|
+
* mod.mod_vals => Array of String
|
226
|
+
*
|
227
|
+
* Return the values associated with the Mod object.
|
228
|
+
*/
|
229
|
+
VALUE
|
230
|
+
rb_ldap_mod_vals (VALUE self)
|
231
|
+
{
|
232
|
+
RB_LDAPMOD_DATA *moddata;
|
233
|
+
struct berval **bvals;
|
234
|
+
char **svals;
|
235
|
+
int i;
|
236
|
+
VALUE val;
|
237
|
+
|
238
|
+
GET_LDAPMOD_DATA (self, moddata);
|
239
|
+
|
240
|
+
if (moddata->mod->mod_op & LDAP_MOD_BVALUES)
|
241
|
+
{
|
242
|
+
bvals = moddata->mod->mod_vals.modv_bvals;
|
243
|
+
val = rb_ary_new ();
|
244
|
+
for (i = 0; bvals[i] != NULL; i++)
|
245
|
+
{
|
246
|
+
VALUE str;
|
247
|
+
str = rb_tainted_str_new (bvals[i]->bv_val, bvals[i]->bv_len);
|
248
|
+
rb_ary_push (val, str);
|
249
|
+
}
|
250
|
+
}
|
251
|
+
else
|
252
|
+
{
|
253
|
+
svals = moddata->mod->mod_vals.modv_strvals;
|
254
|
+
val = rb_ary_new ();
|
255
|
+
for (i = 0; svals[i] != NULL; i++)
|
256
|
+
{
|
257
|
+
VALUE str;
|
258
|
+
str = rb_tainted_str_new2 (svals[i]);
|
259
|
+
rb_ary_push (val, str);
|
260
|
+
}
|
261
|
+
}
|
262
|
+
|
263
|
+
return val;
|
264
|
+
}
|
265
|
+
|
266
|
+
/* call-seq:
|
267
|
+
* mod.inspect => String
|
268
|
+
*
|
269
|
+
* Produce a concise representation of the Mod object.
|
270
|
+
*/
|
271
|
+
VALUE
|
272
|
+
rb_ldap_mod_inspect (VALUE self)
|
273
|
+
{
|
274
|
+
VALUE str;
|
275
|
+
VALUE hash = rb_hash_new ();
|
276
|
+
const char *c;
|
277
|
+
|
278
|
+
c = rb_obj_classname (self);
|
279
|
+
str = rb_str_new (0, strlen (c) + 10 + 16 + 1); /* 10:tags 16:addr 1:nul */
|
280
|
+
sprintf (RSTRING_PTR (str), "#<%s:0x%lx ", c, self);
|
281
|
+
|
282
|
+
#if RUBY_VERSION_CODE < 190
|
283
|
+
RSTRING(str)->len = strlen (RSTRING_PTR (str));
|
284
|
+
#else
|
285
|
+
rb_str_set_len(str, strlen (RSTRING_PTR (str)));
|
286
|
+
#endif
|
287
|
+
|
288
|
+
switch (FIX2INT (rb_ldap_mod_op (self)) & ~LDAP_MOD_BVALUES)
|
289
|
+
{
|
290
|
+
case LDAP_MOD_ADD:
|
291
|
+
rb_str_cat2 (str, "LDAP_MOD_ADD");
|
292
|
+
break;
|
293
|
+
case LDAP_MOD_DELETE:
|
294
|
+
rb_str_cat2 (str, "LDAP_MOD_DELETE");
|
295
|
+
break;
|
296
|
+
case LDAP_MOD_REPLACE:
|
297
|
+
rb_str_cat2 (str, "LDAP_MOD_REPLACE");
|
298
|
+
break;
|
299
|
+
#ifdef LDAP_MOD_INCREMENT
|
300
|
+
case LDAP_MOD_INCREMENT:
|
301
|
+
rb_str_cat2 (str, "LDAP_MOD_INCREMENT");
|
302
|
+
break;
|
303
|
+
#endif
|
304
|
+
#ifdef LDAP_MOD_OP
|
305
|
+
case LDAP_MOD_OP:
|
306
|
+
rb_str_cat2 (str, "LDAP_MOD_OP");
|
307
|
+
break;
|
308
|
+
#endif
|
309
|
+
default:
|
310
|
+
/* We shouldn't end up here. */
|
311
|
+
rb_str_cat2 (str, "unknown");
|
312
|
+
break;
|
313
|
+
}
|
314
|
+
if (FIX2INT (rb_ldap_mod_op (self)) & LDAP_MOD_BVALUES)
|
315
|
+
rb_str_cat2 (str, "|LDAP_MOD_BVALUES");
|
316
|
+
rb_str_cat2 (str, "\n");
|
317
|
+
|
318
|
+
rb_hash_aset (hash, rb_ldap_mod_type (self), rb_ldap_mod_vals (self));
|
319
|
+
rb_str_concat (str, rb_inspect (hash));
|
320
|
+
rb_str_cat2 (str, ">");
|
321
|
+
|
322
|
+
return str;
|
323
|
+
}
|
324
|
+
|
325
|
+
/* Document-class: LDAP::Mod
|
326
|
+
*
|
327
|
+
* Create and manipulate LDAP::Mod objects, which can then be passed to methods
|
328
|
+
* in the LDAP::Conn class, such as Conn#add, Conn#add_ext, Conn#modify and
|
329
|
+
* Conn#modify_ext.
|
330
|
+
*/
|
331
|
+
void
|
332
|
+
Init_ldap_mod ()
|
333
|
+
{
|
334
|
+
rb_cLDAP_Mod = rb_define_class_under (rb_mLDAP, "Mod", rb_cObject);
|
335
|
+
#if RUBY_VERSION_CODE < 170
|
336
|
+
rb_define_singleton_method (rb_cLDAP_Mod, "new", rb_ldap_class_new, -1);
|
337
|
+
#endif
|
338
|
+
#if RUBY_VERSION_CODE >= 173
|
339
|
+
rb_define_alloc_func (rb_cLDAP_Mod, rb_ldap_mod_s_allocate);
|
340
|
+
#else
|
341
|
+
rb_define_singleton_method (rb_cLDAP_Mod, "allocate",
|
342
|
+
rb_ldap_mod_s_allocate, 0);
|
343
|
+
#endif
|
344
|
+
rb_ldap_mod_define_method ("initialize", rb_ldap_mod_initialize, -1);
|
345
|
+
rb_ldap_mod_define_method ("mod_op", rb_ldap_mod_op, 0);
|
346
|
+
rb_ldap_mod_define_method ("mod_type", rb_ldap_mod_type, 0);
|
347
|
+
rb_ldap_mod_define_method ("mod_vals", rb_ldap_mod_vals, 0);
|
348
|
+
rb_ldap_mod_define_method ("inspect", rb_ldap_mod_inspect, 0);
|
349
|
+
|
350
|
+
/*
|
351
|
+
rb_ldap_mod_define_method("mod_op=", rb_ldap_mod_set_op, 1);
|
352
|
+
rb_ldap_mod_define_method("mod_type=", rb_ldap_mod_set_type, 1);
|
353
|
+
rb_ldap_mod_define_method("mod_vals=", rb_ldap_mod_set_vals, 1);
|
354
|
+
*/
|
355
|
+
}
|
data/rbldap.h
ADDED
@@ -0,0 +1,194 @@
|
|
1
|
+
/*
|
2
|
+
* rbldap.h
|
3
|
+
* $Id: rbldap.h,v 1.17 2006/08/09 11:23:04 ianmacd Exp $
|
4
|
+
*/
|
5
|
+
|
6
|
+
#ifndef RB_LDAP_H
|
7
|
+
#define RB_LDAP_H 1
|
8
|
+
|
9
|
+
#ifdef USE_WLDAP32
|
10
|
+
# ifdef HAVE_WINLBER_H
|
11
|
+
# include "winlber.h"
|
12
|
+
# endif
|
13
|
+
# include "winldap.h"
|
14
|
+
#else
|
15
|
+
# include <lber.h>
|
16
|
+
# include <ldap.h>
|
17
|
+
#endif
|
18
|
+
|
19
|
+
#ifdef HAVE_LDAP_SSL_H
|
20
|
+
#include <ldap_ssl.h>
|
21
|
+
#endif
|
22
|
+
|
23
|
+
#ifndef LDAP_OPT_SUCCESS
|
24
|
+
# define LDAP_OPT_SUCCESS (0)
|
25
|
+
# define LDAP_OPT_ERROR (-1)
|
26
|
+
#endif
|
27
|
+
|
28
|
+
#define RB_LDAP_MAJOR_VERSION 0
|
29
|
+
#define RB_LDAP_MINOR_VERSION 9
|
30
|
+
#define RB_LDAP_PATCH_VERSION 9
|
31
|
+
#define RB_LDAP_VERSION "0.9.9"
|
32
|
+
|
33
|
+
#define LDAP_GET_OPT_MAX_BUFFER_SIZE (1024) /* >= sizeof(LDAPAPIInfo) */
|
34
|
+
|
35
|
+
#define RB_LDAP_SET_STR(var,val) {\
|
36
|
+
Check_Type(val, T_STRING); \
|
37
|
+
var = ALLOC_N(char, RSTRING_LEN(val) + 1); \
|
38
|
+
memcpy(var, RSTRING_PTR(val), RSTRING_LEN(val) + 1); \
|
39
|
+
}
|
40
|
+
|
41
|
+
#if defined(HAVE_LDAP_SEARCH_EXT_S)
|
42
|
+
# define HAVE_LDAPCONTROL
|
43
|
+
#endif
|
44
|
+
|
45
|
+
typedef struct rb_ldap_data
|
46
|
+
{
|
47
|
+
LDAP *ldap;
|
48
|
+
int bind;
|
49
|
+
int err;
|
50
|
+
} RB_LDAP_DATA;
|
51
|
+
|
52
|
+
#define RLDAP_DATA_PTR(obj) ((RB_LDAP_DATA*)DATA_PTR(obj))
|
53
|
+
|
54
|
+
typedef struct rb_ldapentry_data
|
55
|
+
{
|
56
|
+
LDAP *ldap;
|
57
|
+
LDAPMessage *msg;
|
58
|
+
} RB_LDAPENTRY_DATA;
|
59
|
+
|
60
|
+
typedef struct rb_ldapmod_data
|
61
|
+
{
|
62
|
+
LDAPMod *mod;
|
63
|
+
} RB_LDAPMOD_DATA;
|
64
|
+
|
65
|
+
|
66
|
+
#ifndef HAVE_LDAP_MEMFREE
|
67
|
+
# define ldap_memfree(ptr) free(ptr)
|
68
|
+
#endif
|
69
|
+
|
70
|
+
extern VALUE rb_mLDAP;
|
71
|
+
|
72
|
+
extern VALUE rb_sLDAP_APIInfo;
|
73
|
+
extern VALUE rb_cLDAP_Controls;
|
74
|
+
|
75
|
+
extern VALUE rb_cLDAP_Conn;
|
76
|
+
extern VALUE rb_cLDAP_SSLConn;
|
77
|
+
extern VALUE rb_cLDAP_Entry;
|
78
|
+
extern VALUE rb_cLDAP_Mod;
|
79
|
+
extern VALUE rb_eLDAP_Error;
|
80
|
+
extern VALUE rb_eLDAP_ResultError;
|
81
|
+
extern VALUE rb_eLDAP_InvalidDataError;
|
82
|
+
extern VALUE rb_eLDAP_InvalidEntryError;
|
83
|
+
|
84
|
+
#ifdef LDAP_OPT_API_INFO
|
85
|
+
VALUE rb_ldap_apiinfo_new (LDAPAPIInfo *);
|
86
|
+
LDAPAPIInfo *rb_ldap_get_apiinfo (VALUE);
|
87
|
+
#endif /* LDAP_OPT_API_INFO */
|
88
|
+
|
89
|
+
#ifdef HAVE_LDAPCONTROL
|
90
|
+
VALUE rb_ldap_control_new (LDAPControl *);
|
91
|
+
LDAPControl *rb_ldap_get_control (VALUE);
|
92
|
+
LDAPControl **rb_ldap_get_controls (VALUE);
|
93
|
+
void rb_ldap_free_controls (LDAPControl ** ctrls);
|
94
|
+
#endif
|
95
|
+
|
96
|
+
VALUE rb_ldap_class_new (int, VALUE[], VALUE);
|
97
|
+
VALUE rb_ldap_dummy_method (int, VALUE[], VALUE);
|
98
|
+
VALUE rb_ldap_err2string (VALUE, VALUE);
|
99
|
+
VALUE rb_ldap_dn2ufn (VALUE, VALUE);
|
100
|
+
VALUE rb_ldap_hash2mods (VALUE, VALUE, VALUE);
|
101
|
+
VALUE rb_ldap_entry2hash (VALUE, VALUE);
|
102
|
+
|
103
|
+
VALUE rb_ldap_conn_new (VALUE, LDAP *);
|
104
|
+
VALUE rb_ldap_conn_simple_bind_s (int, VALUE[], VALUE);
|
105
|
+
VALUE rb_ldap_conn_bind_s (int, VALUE[], VALUE);
|
106
|
+
VALUE rb_ldap_conn_start_tls_s (int, VALUE[], VALUE);
|
107
|
+
VALUE rb_ldap_conn_unbind (VALUE);
|
108
|
+
VALUE rb_ldap_conn_set_option (VALUE, VALUE, VALUE);
|
109
|
+
VALUE rb_ldap_conn_get_option (VALUE, VALUE);
|
110
|
+
VALUE rb_ldap_conn_perror (VALUE, VALUE);
|
111
|
+
VALUE rb_ldap_conn_result2error (VALUE, VALUE);
|
112
|
+
VALUE rb_ldap_conn_err2string (VALUE, VALUE);
|
113
|
+
VALUE rb_ldap_conn_search_s (int, VALUE[], VALUE);
|
114
|
+
VALUE rb_ldap_conn_search2_s (int, VALUE[], VALUE);
|
115
|
+
VALUE rb_ldap_conn_add_s (VALUE, VALUE, VALUE);
|
116
|
+
VALUE rb_ldap_conn_modify_s (VALUE, VALUE, VALUE);
|
117
|
+
VALUE rb_ldap_conn_modrdn_s (VALUE, VALUE, VALUE, VALUE);
|
118
|
+
VALUE rb_ldap_conn_delete_s (VALUE, VALUE);
|
119
|
+
VALUE rb_ldap_conn_err (VALUE);
|
120
|
+
VALUE rb_ldap_conn_set_sort (VALUE, VALUE, VALUE);
|
121
|
+
VALUE rb_ldap_conn_get_sort (VALUE);
|
122
|
+
|
123
|
+
VALUE rb_ldap_saslconn_bind (int, VALUE[], VALUE);
|
124
|
+
|
125
|
+
VALUE rb_ldap_entry_new (LDAP *, LDAPMessage *);
|
126
|
+
VALUE rb_ldap_entry_get_dn (VALUE self);
|
127
|
+
VALUE rb_ldap_entry_get_values (VALUE, VALUE);
|
128
|
+
VALUE rb_ldap_entry_get_attributes (VALUE);
|
129
|
+
VALUE rb_ldap_entry_to_hash (VALUE);
|
130
|
+
|
131
|
+
VALUE rb_ldap_mod_new (int, char *, char **);
|
132
|
+
VALUE rb_ldap_mod_new2 (int, char *, struct berval **);
|
133
|
+
VALUE rb_ldap_mod_op (VALUE);
|
134
|
+
VALUE rb_ldap_mod_type (VALUE);
|
135
|
+
VALUE rb_ldap_mod_vals (VALUE);
|
136
|
+
|
137
|
+
#define Check_Kind(obj,klass) {\
|
138
|
+
if(!rb_obj_is_kind_of(obj,klass))\
|
139
|
+
rb_raise(rb_eTypeError,"type mismatch");\
|
140
|
+
};
|
141
|
+
|
142
|
+
#define Check_LDAP_Result(err) { \
|
143
|
+
if( err != LDAP_SUCCESS && err != LDAP_SIZELIMIT_EXCEEDED ){ \
|
144
|
+
rb_raise(rb_eLDAP_ResultError, ldap_err2string(err)); \
|
145
|
+
} \
|
146
|
+
}
|
147
|
+
|
148
|
+
#define Check_LDAP_OPT_Result(err) { \
|
149
|
+
if( err != LDAP_OPT_SUCCESS ){ \
|
150
|
+
rb_raise(rb_eLDAP_ResultError, ldap_err2string(err)); \
|
151
|
+
} \
|
152
|
+
}
|
153
|
+
|
154
|
+
#define GET_LDAP_DATA(obj,ptr) {\
|
155
|
+
Data_Get_Struct(obj, struct rb_ldap_data, ptr); \
|
156
|
+
if( ! ptr->ldap ){ \
|
157
|
+
rb_raise(rb_eLDAP_InvalidDataError, "The LDAP handler has already unbound.");\
|
158
|
+
} \
|
159
|
+
}
|
160
|
+
|
161
|
+
#define Check_LDAPENTRY(obj) {\
|
162
|
+
RB_LDAPENTRY_DATA *ptr; \
|
163
|
+
Data_Get_Struct(obj, struct rb_ldapmsg_data, ptr); \
|
164
|
+
if( ! ptr->msg ){ \
|
165
|
+
rb_raise(rb_eLDAP_InvalidEntryError, "%s is not a valid entry", \
|
166
|
+
STR2CSTR(rb_inspect(obj))); \
|
167
|
+
}; \
|
168
|
+
}
|
169
|
+
|
170
|
+
#define GET_LDAPENTRY_DATA(obj,ptr) { \
|
171
|
+
Data_Get_Struct(obj, struct rb_ldapentry_data, ptr); \
|
172
|
+
if( ! ptr->msg ){ \
|
173
|
+
rb_raise(rb_eLDAP_InvalidEntryError, "%s is not a valid entry", \
|
174
|
+
STR2CSTR(rb_inspect(obj))); \
|
175
|
+
}; \
|
176
|
+
}
|
177
|
+
|
178
|
+
#define GET_LDAPMOD_DATA(obj,ptr) {\
|
179
|
+
Data_Get_Struct(obj, struct rb_ldapmod_data, ptr); \
|
180
|
+
if( ! ptr->mod ) \
|
181
|
+
rb_raise(rb_eLDAP_InvalidDataError, "The Mod data is not ready for use."); \
|
182
|
+
}
|
183
|
+
|
184
|
+
#define rb_ldap_define_class(cname,parent) \
|
185
|
+
rb_define_class_under(rb_mLDAP,cname,parent)
|
186
|
+
|
187
|
+
#define rb_ldap_conn_define_method(method,cfunc,argc) \
|
188
|
+
rb_define_method(rb_cLDAP_Conn,method,cfunc,argc)
|
189
|
+
#define rb_ldap_entry_define_method(method,cfunc,argc) \
|
190
|
+
rb_define_method(rb_cLDAP_Entry,method,cfunc,argc)
|
191
|
+
#define rb_ldap_mod_define_method(method,cfunc,argc) \
|
192
|
+
rb_define_method(rb_cLDAP_Mod,method,cfunc,argc)
|
193
|
+
|
194
|
+
#endif
|