ldif.h 4.56 KB
Newer Older
Kurt Zeilenga's avatar
Kurt Zeilenga committed
1
/* $OpenLDAP$ */
2
3
/* This work is part of OpenLDAP Software <http://www.openldap.org/>.
 *
Kurt Zeilenga's avatar
Kurt Zeilenga committed
4
 * Copyright 1998-2011 The OpenLDAP Foundation.
5
6
 * All rights reserved.
 *
7
8
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted only as authorized by the OpenLDAP
9
10
11
12
13
 * Public License.
 *
 * A copy of this license is available in file LICENSE in the
 * top-level directory of the distribution or, alternatively, at
 * <http://www.OpenLDAP.org/license.html>.
14
 */
15
/* Portions Copyright (c) 1996 Regents of the University of Michigan.
Kurt Zeilenga's avatar
Kurt Zeilenga committed
16
17
18
19
20
21
22
23
24
25
26
27
28
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms are permitted
 * provided that this notice is preserved and that due credit is given
 * to the University of Michigan at Ann Arbor. The name of the University
 * may not be used to endorse or promote products derived from this
 * software without specific prior written permission. This software
 * is provided ``as is'' without express or implied warranty.
 */

#ifndef _LDIF_H
#define _LDIF_H

Kurt Zeilenga's avatar
Kurt Zeilenga committed
29
30
31
#include <ldap_cdefs.h>

LDAP_BEGIN_DECL
Kurt Zeilenga's avatar
Kurt Zeilenga committed
32

Howard Chu's avatar
Howard Chu committed
33
/* This is NOT a bogus extern declaration (unlike ldap_debug) */
Kurt Zeilenga's avatar
Kurt Zeilenga committed
34
LDAP_LDIF_V (int) ldif_debug;
35

36
37
38
#define LDIF_LINE_WIDTH      76      /* default maximum length of LDIF lines */
#define LDIF_LINE_WIDTH_MAX  ((ber_len_t)-1) /* maximum length of LDIF lines */
#define LDIF_LINE_WIDTH_WRAP(wrap) ((wrap) == 0 ? LDIF_LINE_WIDTH : (wrap))
Kurt Zeilenga's avatar
Kurt Zeilenga committed
39
40
41

/*
 * Macro to calculate maximum number of bytes that the base64 equivalent
Kurt Zeilenga's avatar
Kurt Zeilenga committed
42
 * of an item that is "len" bytes long will take up.  Base64 encoding
Kurt Zeilenga's avatar
Kurt Zeilenga committed
43
44
 * uses one byte for every six bits in the value plus up to two pad bytes.
 */
Kurt Zeilenga's avatar
Kurt Zeilenga committed
45
#define LDIF_BASE64_LEN(len)	(((len) * 4 / 3 ) + 3)
Kurt Zeilenga's avatar
Kurt Zeilenga committed
46
47
48
49
50
51
52

/*
 * Macro to calculate maximum size that an LDIF-encoded type (length
 * tlen) and value (length vlen) will take up:  room for type + ":: " +
 * first newline + base64 value + continued lines.  Each continued line
 * needs room for a newline and a leading space character.
 */
Kurt Zeilenga's avatar
Kurt Zeilenga committed
53
54
55
#define LDIF_SIZE_NEEDED(nlen,vlen) \
    ((nlen) + 4 + LDIF_BASE64_LEN(vlen) \
    + ((LDIF_BASE64_LEN(vlen) + (nlen) + 3) / LDIF_LINE_WIDTH * 2 ))
Kurt Zeilenga's avatar
Kurt Zeilenga committed
56

57
58
59
60
61
#define LDIF_SIZE_NEEDED_WRAP(nlen,vlen,wrap) \
    ((nlen) + 4 + LDIF_BASE64_LEN(vlen) \
    + ((wrap) == 0 ? ((LDIF_BASE64_LEN(vlen) + (nlen) + 3) / ( LDIF_LINE_WIDTH ) * 2 ) : \
	((wrap) == LDIF_LINE_WIDTH_MAX ? 0 : ((LDIF_BASE64_LEN(vlen) + (nlen) + 3) / (wrap) * 2 ))))

62
LDAP_LDIF_F( int )
Kurt Zeilenga's avatar
Kurt Zeilenga committed
63
64
ldif_parse_line LDAP_P((
	LDAP_CONST char *line,
Kurt Zeilenga's avatar
Kurt Zeilenga committed
65
66
	char **name,
	char **value,
67
68
	ber_len_t *vlen ));

69
70
LDAP_LDIF_F( int )
ldif_parse_line2 LDAP_P((
71
72
73
74
	char *line,
	struct berval *type,
	struct berval *value,
	int *freeval ));
75

76
77
78
LDAP_LDIF_F( FILE * )
ldif_open_url LDAP_P(( LDAP_CONST char *urlstr ));

79
LDAP_LDIF_F( int )
80
81
82
83
ldif_fetch_url LDAP_P((
	LDAP_CONST char *line,
	char **value,
	ber_len_t *vlen ));
84

85
LDAP_LDIF_F( char * )
86
87
ldif_getline LDAP_P(( char **next ));

Howard Chu's avatar
Howard Chu committed
88
89
90
LDAP_LDIF_F( int )
ldif_countlines LDAP_P(( LDAP_CONST char *line ));

91
92
93
94
95
96
97
98
99
/* ldif_ropen, rclose, read_record - just for reading LDIF files,
 * no special open/close needed to write LDIF files.
 */
typedef struct LDIFFP {
	FILE *fp;
	struct LDIFFP *prev;
} LDIFFP;

LDAP_LDIF_F( LDIFFP * )
Hallvard Furuseth's avatar
Hallvard Furuseth committed
100
ldif_open LDAP_P(( LDAP_CONST char *file, LDAP_CONST char *mode ));
101
102
103
104

LDAP_LDIF_F( void )
ldif_close LDAP_P(( LDIFFP * ));

105
LDAP_LDIF_F( int )
106
ldif_read_record LDAP_P((
107
	LDIFFP *fp,
108
109
110
111
	int *lineno,
	char **bufp,
	int *buflen ));

112
113
114
115
116
117
118
LDAP_LDIF_F( int )
ldif_must_b64_encode_register LDAP_P((
	LDAP_CONST char *name,
	LDAP_CONST char *oid ));

LDAP_LDIF_F( void )
ldif_must_b64_encode_release LDAP_P(( void ));
119

Kurt Zeilenga's avatar
Kurt Zeilenga committed
120
121
122
123
124
125
126
127
128
129
#define LDIF_PUT_NOVALUE	0x0000	/* no value */
#define LDIF_PUT_VALUE		0x0001	/* value w/ auto detection */
#define LDIF_PUT_TEXT		0x0002	/* assume text */
#define	LDIF_PUT_BINARY		0x0004	/* assume binary (convert to base64) */
#define LDIF_PUT_B64		0x0008	/* pre-converted base64 value */

#define LDIF_PUT_COMMENT	0x0010	/* comment */
#define LDIF_PUT_URL		0x0020	/* url */
#define LDIF_PUT_SEP		0x0040	/* separator */

130
LDAP_LDIF_F( void )
Kurt Zeilenga's avatar
Kurt Zeilenga committed
131
ldif_sput LDAP_P((
Kurt Zeilenga's avatar
Kurt Zeilenga committed
132
	char **out,
Kurt Zeilenga's avatar
Kurt Zeilenga committed
133
134
	int type,
	LDAP_CONST char *name,
Kurt Zeilenga's avatar
Kurt Zeilenga committed
135
	LDAP_CONST char *val,
Kurt Zeilenga's avatar
Kurt Zeilenga committed
136
	ber_len_t vlen ));
137

138
139
140
141
142
143
144
145
146
LDAP_LDIF_F( void )
ldif_sput_wrap LDAP_P((
	char **out,
	int type,
	LDAP_CONST char *name,
	LDAP_CONST char *val,
	ber_len_t vlen,
        ber_len_t wrap ));

147
LDAP_LDIF_F( char * )
Kurt Zeilenga's avatar
Kurt Zeilenga committed
148
149
150
ldif_put LDAP_P((
	int type,
	LDAP_CONST char *name,
Kurt Zeilenga's avatar
Kurt Zeilenga committed
151
	LDAP_CONST char *val,
Kurt Zeilenga's avatar
Kurt Zeilenga committed
152
	ber_len_t vlen ));
Kurt Zeilenga's avatar
Kurt Zeilenga committed
153

154
155
156
157
158
159
160
161
LDAP_LDIF_F( char * )
ldif_put_wrap LDAP_P((
	int type,
	LDAP_CONST char *name,
	LDAP_CONST char *val,
	ber_len_t vlen,
	ber_len_t wrap ));

162
LDAP_LDIF_F( int )
Kurt Zeilenga's avatar
Kurt Zeilenga committed
163
164
165
ldif_is_not_printable LDAP_P((
	LDAP_CONST char *val,
	ber_len_t vlen ));
166

Kurt Zeilenga's avatar
Kurt Zeilenga committed
167
LDAP_END_DECL
Kurt Zeilenga's avatar
Kurt Zeilenga committed
168
169

#endif /* _LDIF_H */