8982 Support building with OpenSSL 1.1
[unleashed.git] / usr / src / lib / libnisdb / ldap_print.c
bloba1dfd501632d323a9220d7ae80816c865815e535
1 /*
2 * CDDL HEADER START
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License, Version 1.0 only
6 * (the "License"). You may not use this file except in compliance
7 * with the License.
9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 * or http://www.opensolaris.org/os/licensing.
11 * See the License for the specific language governing permissions
12 * and limitations under the License.
14 * When distributing Covered Code, include this CDDL HEADER in each
15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 * If applicable, add the following below this CDDL HEADER, with the
17 * fields enclosed by brackets "[]" replaced with your own identifying
18 * information: Portions Copyright [yyyy] [name of copyright owner]
20 * CDDL HEADER END
23 * Copyright 2001-2003 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
27 #pragma ident "%Z%%M% %I% %E% SMI"
29 #include "ldap_util.h"
30 #include "ldap_print.h"
33 void
34 printMappingFormat(__nis_mapping_format_t *f) {
35 __nis_value_t *val = getMappingFormat(f, 0, fa_any, 0, 0);
36 int i;
37 char *myself = "printMappingFormat";
39 if (val == 0)
40 return;
42 for (i = 0; i < val->numVals; i++) {
43 c2buf(myself, val->val[i].value, val->val[i].length);
45 freeValue(val, 1);
48 void
49 printMappingFormatArray(__nis_mapping_format_t *a) {
50 __nis_value_t *val = getMappingFormatArray(a, 0, fa_any, 0, 0);
51 char *myself = "printMappingFormatArray";
53 if (val != 0) {
54 if (val->type == vt_string) {
55 int i;
57 if (a[0].type != mmt_begin)
58 p2buf(myself, "\"");
59 for (i = 0; i < val->numVals; i++) {
60 sc2buf(myself, val->val[i].value,
61 val->val[i].length);
63 } else {
64 p2buf(myself, "<illegal>");
66 freeValue(val, 1);
67 } else {
68 p2buf(myself, "<novals>");
72 void
73 printIndex(__nis_index_t *i) {
74 int len = 0;
75 char *str = getIndex(i, &len);
76 char *myself = "printIndex";
78 sc2buf(myself, str, len);
79 sfree(str);
82 void
83 printObjSpec(__nis_obj_spec_t *o) {
84 int len = 0;
85 char *str = getObjSpec(o, &len);
86 char *myself = "printObjSpec";
88 sc2buf(myself, str, len);
89 sfree(str);
92 void
93 printSearchTriple(__nis_search_triple_t *s) {
94 int len = 0;
95 char *str = getSearchTriple(s, &len);
96 char *myself = "printSearchTriple";
98 sc2buf(myself, str, len);
99 sfree(str);
102 void
103 printMappingItem(__nis_mapping_item_t *i, __nis_mapping_item_type_t native) {
104 __nis_value_t *val = getMappingItem(i, native, 0, 0, NULL);
105 int j;
106 char *myself = "printMappingItem";
108 if (val == 0)
109 return;
111 if (i->repeat)
112 p2buf(myself, "(");
113 for (j = 0; j < val->numVals; j++) {
114 c2buf(myself, val->val[j].value, val->val[j].length);
116 if (i->repeat)
117 p2buf(myself, ")");
118 freeValue(val, 1);
121 void
122 printMappingSubElement(__nis_mapping_sub_element_t *e,
123 __nis_mapping_item_type_t native) {
124 int i;
125 char *myself = "printMappingSubElement";
127 switch (e->type) {
128 case me_item:
129 printMappingItem(&e->element.item, native);
130 break;
131 case me_print:
132 p2buf(myself, "(");
133 printMappingFormatArray(e->element.print.fmt);
134 for (i = 0; i < e->element.print.numItems; i++) {
135 p2buf(myself, ", ");
136 printMappingItem(&e->element.print.item[i], native);
138 if (e->element.print.doElide) {
139 p2buf(myself, ", \"%c\"", e->element.print.elide);
141 p2buf(myself, ")");
142 break;
143 case me_split:
144 p2buf(myself, "(");
145 printMappingItem(&e->element.split.item, native);
146 p2buf(myself, ", \"%c\")", e->element.split.delim);
147 break;
148 case me_match:
149 p2buf(myself, "<me_match>");
150 break;
151 case me_extract:
152 p2buf(myself, "(");
153 printMappingItem(&e->element.extract.item, native);
154 p2buf(myself, ", ");
155 printMappingFormatArray(e->element.extract.fmt);
156 p2buf(myself, ")");
157 break;
158 default:
159 p2buf(myself, "(<unknown>)");
160 break;
164 void
165 printMappingElement(__nis_mapping_element_t *e,
166 __nis_mapping_item_type_t native) {
167 int i;
168 char *myself = "printMappingElement";
170 switch (e->type) {
171 case me_item:
172 printMappingItem(&e->element.item, native);
173 break;
174 case me_print:
175 p2buf(myself, "(");
176 printMappingFormatArray(e->element.print.fmt);
177 for (i = 0; i < e->element.print.numSubElements; i++) {
178 p2buf(myself, ", ");
179 printMappingSubElement(
180 &e->element.print.subElement[i], native);
182 if (e->element.print.doElide) {
183 p2buf(myself, ", \"%c\"", e->element.print.elide);
185 p2buf(myself, ")");
186 break;
187 case me_split:
188 p2buf(myself, "(");
189 printMappingItem(&e->element.split.item, native);
190 p2buf(myself, ", \"%c\")", e->element.split.delim);
191 break;
192 case me_match:
193 p2buf(myself, "(");
194 printMappingFormatArray(e->element.match.fmt);
195 for (i = 0; i < e->element.match.numItems; i++) {
196 p2buf(myself, ", ");
197 printMappingItem(&e->element.match.item[i], native);
199 p2buf(myself, ")");
200 break;
201 case me_extract:
202 p2buf(myself, "(");
203 printMappingItem(&e->element.extract.item, native);
204 p2buf(myself, ", ");
205 printMappingFormatArray(e->element.extract.fmt);
206 p2buf(myself, ")");
207 break;
208 default:
209 p2buf(myself, "(<unknown>)");
210 break;
214 void
215 printMappingRLHS(__nis_mapping_rlhs_t *m, __nis_mapping_item_type_t native) {
216 int i;
217 char *myself = "printMappingRLHS";
219 if (m->numElements > 1)
220 p2buf(myself, "(");
221 for (i = 0; i < m->numElements; i++) {
222 printMappingElement(&m->element[i], native);
224 if (m->numElements > 1)
225 p2buf(myself, ")");
228 void
229 printMappingRule(__nis_mapping_rule_t *r,
230 __nis_mapping_item_type_t nativeLhs,
231 __nis_mapping_item_type_t nativeRhs) {
232 char *myself = "printMappingRule";
234 printMappingRLHS(&r->lhs, nativeLhs);
235 p2buf(myself, "=");
236 printMappingRLHS(&r->rhs, nativeRhs);
239 void
240 printObjName(__nis_index_t *index, char *name) {
241 char *myself = "printObjName";
243 printIndex(index);
244 p2buf(myself, "%s", NIL(name));
247 void
248 printobjectDN(__nis_object_dn_t *o) {
249 char *myself = "printobjectDN";
250 int i;
252 p2buf(myself, "\t");
253 printSearchTriple(&o->read);
254 p2buf(myself, ":\n\t");
255 printSearchTriple(&o->write);
256 switch (o->delDisp) {
257 case dd_always:
258 p2buf(myself, ":\n\t\talways");
259 break;
260 case dd_perDbId:
261 p2buf(myself, ":\n\t\tdbid=%s\n", NIL(o->dbIdName));
262 for (i = 0; i < o->numDbIds; i++) {
263 p2buf(myself, "\t\t\t");
264 printMappingRule(o->dbId[i], mit_ldap, mit_nisplus);
266 break;
267 case dd_never:
268 p2buf(myself, ":\n\t\tnever");
269 break;
270 default:
271 p2buf(myself, ":\n\t\t<unknown>");
275 void
276 printTableMapping(__nis_table_mapping_t *t) {
277 __nis_object_dn_t *o;
278 int i;
279 char *myself = "printTableMapping";
281 p2buf(myself, "\n%s:", NIL(t->dbId));
282 printObjName(&t->index, t->objName);
283 p2buf(myself, "\n\t%s \t%s", NIL(t->objName), NIL(t->objPath));
284 p2buf(myself, "\n\tTTL = (%d - %d) -> %d\n",
285 t->initTtlLo, t->initTtlHi, t->ttl);
287 for (o = t->objectDN; o != 0; o = o->next) {
288 printobjectDN(o);
289 p2buf(myself, "\n");
292 p2buf(myself, "\tLDAP -> NIS+\n");
293 p2buf(myself, "\tRules:\n");
294 for (i = 0; i < t->numRulesFromLDAP; i++) {
295 p2buf(myself, "\t\t");
296 printMappingRule(t->ruleFromLDAP[i], mit_nisplus, mit_ldap);
297 p2buf(myself, "\n");
300 p2buf(myself, "\tNIS+ -> LDAP\n");
301 p2buf(myself, "\tRules:\n");
302 for (i = 0; i < t->numRulesToLDAP; i++) {
303 p2buf(myself, "\t\t");
304 printMappingRule(t->ruleToLDAP[i], mit_ldap, mit_nisplus);
305 p2buf(myself, "\n");
309 void
310 printRuleValue(__nis_rule_value_t *rv) {
311 int i, j;
312 __nis_buffer_t b = {0, 0};
313 char *myself = "printRuleValue";
315 if (rv == 0)
316 return;
318 if (rv->colName != 0) {
319 bp2buf(myself, &b, "Columns:\n");
320 for (i = 0; i < rv->numColumns; i++) {
321 bp2buf(myself, &b, "\t%s", NIL(rv->colName[i]));
322 if (rv->colVal[i].numVals == 1) {
323 bp2buf(myself, &b, "=");
324 if (rv->colVal[i].type == vt_string)
325 sbc2buf(myself,
326 rv->colVal[i].val[0].value,
327 rv->colVal[i].val[0].length, &b);
328 else
329 bc2buf(myself,
330 rv->colVal[i].val[0].value,
331 rv->colVal[i].val[0].length, &b);
332 bp2buf(myself, &b, "\n");
333 } else {
334 bp2buf(myself, &b, "\n");
335 for (j = 0; j < rv->colVal[i].numVals; j++) {
336 bp2buf(myself, &b, "\t\t");
337 if (rv->colVal[i].type == vt_string)
338 sbc2buf(myself,
339 rv->colVal[i].val[j].value,
340 rv->colVal[i].val[j].length,
341 &b);
342 else
343 bc2buf(myself,
344 rv->colVal[i].val[j].value,
345 rv->colVal[i].val[j].length,
346 &b);
347 bp2buf(myself, &b, "\n");
353 if (rv->attrName != 0) {
354 bp2buf(myself, &b, "Attributes:\n");
355 for (i = 0; i < rv->numAttrs; i++) {
356 bp2buf(myself, &b, "\t%s", NIL(rv->attrName[i]));
357 if (rv->attrVal[i].numVals == 1) {
358 bp2buf(myself, &b, "=");
359 if (rv->attrVal[i].type == vt_string)
360 sbc2buf(myself,
361 rv->attrVal[i].val[0].value,
362 rv->attrVal[i].val[0].length,
363 &b);
364 else
365 bc2buf(myself,
366 rv->attrVal[i].val[0].value,
367 rv->attrVal[i].val[0].length,
368 &b);
369 bp2buf(myself, &b, "\n");
370 } else {
371 bp2buf(myself, &b, "\n");
372 for (j = 0; j < rv->attrVal[i].numVals; j++) {
373 bp2buf(myself, &b, "\t\t");
374 if (rv->attrVal[i].type == vt_string)
375 sbc2buf(myself,
376 rv->attrVal[i].val[j].value,
377 rv->attrVal[i].val[j].length,
378 &b);
379 else
380 bc2buf(myself,
381 rv->attrVal[i].val[j].value,
382 rv->attrVal[i].val[j].length,
383 &b);
384 bp2buf(myself, &b, "\n");
390 c2buf(myself, b.buf, b.len);
391 sfree(b.buf);
392 printbuf();
395 void
396 printLdapMod(LDAPMod **mods, __nis_buffer_t *b) {
397 LDAPMod *m;
398 char *s;
399 char *myself = "printLdapMod";
401 if (mods == 0)
402 return;
404 if (b == 0)
405 b = &pb;
407 while ((m = *mods) != 0) {
408 if ((m->mod_op & LDAP_MOD_ADD) != 0 ||
409 (m->mod_op & ~LDAP_MOD_BVALUES) == 0) {
410 s = "ADD ";
411 } else if ((m->mod_op & LDAP_MOD_DELETE) != 0) {
412 s = "DELETE ";
413 } else if ((m->mod_op & LDAP_MOD_REPLACE) != 0) {
414 s = "REPLACE";
415 } else {
416 s = "UNKNOWN";
418 bp2buf(myself, b, "%s: %s\n", s, m->mod_type);
419 if ((m->mod_op & LDAP_MOD_BVALUES) == 0) {
420 char **v = m->mod_values;
422 if (v != 0) {
423 while (*v != 0) {
424 bp2buf(myself, b, "\t%s\n", *v);
425 v++;
428 } else {
429 struct berval **bv = m->mod_bvalues;
431 if (bv != 0) {
432 while (*bv != 0) {
433 bp2buf(myself, b, "\t<ber> %d bytes\n",
434 (*bv)->bv_len);
435 bv++;
439 mods++;
443 static void
444 printObjRights(char *msg, void *access) {
445 uchar_t *a = access;
446 int i;
448 if (a == 0)
449 return;
451 for (i = 0; i < 4; i++) {
452 p2buf(msg, "%s", (a[i] & NIS_READ_ACC) ? "r" : "-");
453 p2buf(msg, "%s", (a[i] & NIS_MODIFY_ACC) ? "m" : "-");
454 p2buf(msg, "%s", (a[i] & NIS_CREATE_ACC) ? "c" : "-");
455 p2buf(msg, "%s", (a[i] & NIS_DESTROY_ACC) ? "d" : "-");
459 void
460 printObjAttr(__nis_obj_attr_t *attr) {
461 char *myself = "printObjAttr";
463 if (attr == 0)
464 return;
466 p2buf(myself, "\tzo_owner = %s\n", NIL(attr->zo_owner));
467 p2buf(myself, "\tzo_group = %s\n", NIL(attr->zo_group));
468 p2buf(myself, "\tzo_domain = %s\n", NIL(attr->zo_domain));
469 p2buf(myself, "\tzo_access = ");
470 printObjRights(myself, &attr->zo_access);
471 p2buf(myself, " (0x%08x)\n", attr->zo_access);
472 p2buf(myself, "\tzo_ttl = %d\n", attr->zo_ttl);