xref: /netbsd-src/external/bsd/openldap/dist/include/lutil.h (revision 549b59ed3ccf0d36d3097190a0db27b770f3a839)
1*549b59edSchristos /*	$NetBSD: lutil.h,v 1.3 2021/08/14 16:14:55 christos Exp $	*/
24e6df137Slukem 
3d11b170bStron /* $OpenLDAP$ */
42de962bdSlukem /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
52de962bdSlukem  *
6*549b59edSchristos  * Copyright 1998-2021 The OpenLDAP Foundation.
72de962bdSlukem  * All rights reserved.
82de962bdSlukem  *
92de962bdSlukem  * Redistribution and use in source and binary forms, with or without
102de962bdSlukem  * modification, are permitted only as authorized by the OpenLDAP
112de962bdSlukem  * Public License.
122de962bdSlukem  *
132de962bdSlukem  * A copy of this license is available in file LICENSE in the
142de962bdSlukem  * top-level directory of the distribution or, alternatively, at
152de962bdSlukem  * <http://www.OpenLDAP.org/license.html>.
162de962bdSlukem  */
172de962bdSlukem 
182de962bdSlukem #ifndef _LUTIL_H
192de962bdSlukem #define _LUTIL_H 1
202de962bdSlukem 
212de962bdSlukem #include <ldap_cdefs.h>
222de962bdSlukem #include <lber_types.h>
23*549b59edSchristos #include <ac/socket.h>
24*549b59edSchristos 
25*549b59edSchristos #ifdef HAVE_TCPD
26*549b59edSchristos # include <tcpd.h>
27*549b59edSchristos # define LUTIL_STRING_UNKNOWN	STRING_UNKNOWN
28*549b59edSchristos #else /* ! TCP Wrappers */
29*549b59edSchristos # define LUTIL_STRING_UNKNOWN	"unknown"
30*549b59edSchristos #endif /* ! TCP Wrappers */
312de962bdSlukem 
322de962bdSlukem /*
332de962bdSlukem  * Include file for LDAP utility routine
342de962bdSlukem  */
352de962bdSlukem 
362de962bdSlukem LDAP_BEGIN_DECL
372de962bdSlukem 
382de962bdSlukem /* n octets encode into ceiling(n/3) * 4 bytes */
392de962bdSlukem /* Avoid floating point math through extra padding */
402de962bdSlukem 
412de962bdSlukem #define LUTIL_BASE64_ENCODE_LEN(n)	(((n)+2)/3 * 4)
422de962bdSlukem #define LUTIL_BASE64_DECODE_LEN(n)	((n)/4*3)
432de962bdSlukem 
442de962bdSlukem /* ISC Base64 Routines */
452de962bdSlukem /* base64.c */
462de962bdSlukem 
472de962bdSlukem LDAP_LUTIL_F( int )
482de962bdSlukem lutil_b64_ntop LDAP_P((
492de962bdSlukem 	unsigned char const *,
502de962bdSlukem 	size_t,
512de962bdSlukem 	char *,
522de962bdSlukem 	size_t));
532de962bdSlukem 
542de962bdSlukem LDAP_LUTIL_F( int )
552de962bdSlukem lutil_b64_pton LDAP_P((
562de962bdSlukem 	char const *,
572de962bdSlukem 	unsigned char *,
582de962bdSlukem 	size_t));
592de962bdSlukem 
602de962bdSlukem /* detach.c */
61d11b170bStron LDAP_LUTIL_F( int )
622de962bdSlukem lutil_detach LDAP_P((
632de962bdSlukem 	int debug,
642de962bdSlukem 	int do_close));
652de962bdSlukem 
662de962bdSlukem /* entropy.c */
672de962bdSlukem LDAP_LUTIL_F( int )
682de962bdSlukem lutil_entropy LDAP_P((
692de962bdSlukem 	unsigned char *buf,
702de962bdSlukem 	ber_len_t nbytes ));
712de962bdSlukem 
722de962bdSlukem /* passfile.c */
732de962bdSlukem struct berval;	/* avoid pulling in lber.h */
742de962bdSlukem 
752de962bdSlukem LDAP_LUTIL_F( int )
762de962bdSlukem lutil_get_filed_password LDAP_P((
772de962bdSlukem 	const char *filename,
782de962bdSlukem 	struct berval * ));
792de962bdSlukem 
802de962bdSlukem /* passwd.c */
812de962bdSlukem struct lutil_pw_scheme;
822de962bdSlukem 
832de962bdSlukem #define LUTIL_PASSWD_OK		(0)
842de962bdSlukem #define LUTIL_PASSWD_ERR	(-1)
852de962bdSlukem 
862de962bdSlukem typedef int (LUTIL_PASSWD_CHK_FUNC)(
872de962bdSlukem 	const struct berval *scheme,
882de962bdSlukem 	const struct berval *passwd,
892de962bdSlukem 	const struct berval *cred,
902de962bdSlukem 	const char **text );
912de962bdSlukem 
922de962bdSlukem typedef int (LUTIL_PASSWD_HASH_FUNC) (
932de962bdSlukem 	const struct berval *scheme,
942de962bdSlukem 	const struct berval *passwd,
952de962bdSlukem 	struct berval *hash,
962de962bdSlukem 	const char **text );
972de962bdSlukem 
982de962bdSlukem LDAP_LUTIL_F( int )
992de962bdSlukem lutil_passwd_add LDAP_P((
1002de962bdSlukem 	struct berval *scheme,
1012de962bdSlukem 	LUTIL_PASSWD_CHK_FUNC *chk_fn,
1022de962bdSlukem 	LUTIL_PASSWD_HASH_FUNC *hash_fn ));
1032de962bdSlukem 
1042de962bdSlukem LDAP_LUTIL_F( void )
1052de962bdSlukem lutil_passwd_init LDAP_P(( void ));
1062de962bdSlukem 
1072de962bdSlukem LDAP_LUTIL_F( void )
1082de962bdSlukem lutil_passwd_destroy LDAP_P(( void ));
1092de962bdSlukem 
1102de962bdSlukem LDAP_LUTIL_F( int )
1112de962bdSlukem lutil_authpasswd LDAP_P((
1122de962bdSlukem 	const struct berval *passwd,	/* stored password */
1132de962bdSlukem 	const struct berval *cred,	/* user supplied value */
1142de962bdSlukem 	const char **methods ));
1152de962bdSlukem 
1162de962bdSlukem LDAP_LUTIL_F( int )
1172de962bdSlukem lutil_authpasswd_hash LDAP_P((
1182de962bdSlukem 	const struct berval *cred,
1192de962bdSlukem 	struct berval **passwd,	/* password to store */
1202de962bdSlukem 	struct berval **salt,	/* salt to store */
1212de962bdSlukem 	const char *method ));
1222de962bdSlukem 
1232de962bdSlukem #ifdef SLAPD_CRYPT
1242de962bdSlukem typedef int (lutil_cryptfunc) LDAP_P((
1252de962bdSlukem 	const char *key,
1262de962bdSlukem 	const char *salt,
1272de962bdSlukem 	char **hash ));
1282de962bdSlukem LDAP_LUTIL_V (lutil_cryptfunc *) lutil_cryptptr;
1292de962bdSlukem #endif
1302de962bdSlukem 
1312de962bdSlukem LDAP_LUTIL_F( int )
1322de962bdSlukem lutil_passwd LDAP_P((
1332de962bdSlukem 	const struct berval *passwd,	/* stored password */
1342de962bdSlukem 	const struct berval *cred,	/* user supplied value */
1352de962bdSlukem 	const char **methods,
1362de962bdSlukem 	const char **text ));			/* error message */
1372de962bdSlukem 
1382de962bdSlukem LDAP_LUTIL_F( int )
1392de962bdSlukem lutil_passwd_generate LDAP_P(( struct berval *pw, ber_len_t ));
1402de962bdSlukem 
1412de962bdSlukem LDAP_LUTIL_F( int )
1422de962bdSlukem lutil_passwd_hash LDAP_P((
1432de962bdSlukem 	const struct berval *passwd,
1442de962bdSlukem 	const char *method,
1452de962bdSlukem 	struct berval *hash,
1462de962bdSlukem 	const char **text ));
1472de962bdSlukem 
1482de962bdSlukem LDAP_LUTIL_F( int )
1492de962bdSlukem lutil_passwd_scheme LDAP_P((
1502de962bdSlukem 	const char *scheme ));
1512de962bdSlukem 
1522de962bdSlukem LDAP_LUTIL_F( int )
1532de962bdSlukem lutil_salt_format LDAP_P((
1542de962bdSlukem 	const char *format ));
1552de962bdSlukem 
156d11b170bStron LDAP_LUTIL_F( int )
157d11b170bStron lutil_passwd_string64 LDAP_P((
158d11b170bStron 	const struct berval *sc,
159d11b170bStron 	const struct berval *hash,
160d11b170bStron 	struct berval *b64,
161d11b170bStron 	const struct berval *salt ));
162d11b170bStron 
1632de962bdSlukem /* utils.c */
1642de962bdSlukem LDAP_LUTIL_F( char* )
1652de962bdSlukem lutil_progname LDAP_P((
1662de962bdSlukem 	const char* name,
1672de962bdSlukem 	int argc,
1682de962bdSlukem 	char *argv[] ));
1692de962bdSlukem 
1702de962bdSlukem typedef struct lutil_tm {
1712de962bdSlukem 	int tm_sec;	/* seconds 0-60 (1 leap second) */
1722de962bdSlukem 	int tm_min;	/* minutes 0-59 */
1732de962bdSlukem 	int tm_hour;	/* hours 0-23 */
1742de962bdSlukem 	int tm_mday;	/* day 1-31 */
1752de962bdSlukem 	int tm_mon;	/* month 0-11 */
1762de962bdSlukem 	int tm_year;	/* year - 1900 */
177*549b59edSchristos 	int tm_nsec;	/* nanoseconds */
1782de962bdSlukem 	int tm_usub;	/* submicro */
1792de962bdSlukem } lutil_tm;
1802de962bdSlukem 
1812de962bdSlukem typedef struct lutil_timet {
182*549b59edSchristos 	unsigned int tt_sec;	/* seconds since epoch, 0000 or 1970 */
183*549b59edSchristos 	int tt_gsec;		/* seconds since epoch, high 7 bits, maybe sign-flipped */
184*549b59edSchristos 						/* sign flipped to sort properly as unsigned ints */
185*549b59edSchristos 	unsigned int tt_nsec;	/* nanoseconds */
1862de962bdSlukem } lutil_timet;
1872de962bdSlukem 
1882de962bdSlukem /* Parse a timestamp string into a structure */
1892de962bdSlukem LDAP_LUTIL_F( int )
1902de962bdSlukem lutil_parsetime LDAP_P((
1912de962bdSlukem 	char *atm, struct lutil_tm * ));
1922de962bdSlukem 
193*549b59edSchristos /* Convert structured time to time in seconds since 1970 (Unix epoch) */
1942de962bdSlukem LDAP_LUTIL_F( int )
1952de962bdSlukem lutil_tm2time LDAP_P((
1962de962bdSlukem 	struct lutil_tm *, struct lutil_timet * ));
1972de962bdSlukem 
198*549b59edSchristos /* Convert structured time to time in seconds since 0000 (Proleptic Gregorian) */
199*549b59edSchristos LDAP_LUTIL_F( int )
200*549b59edSchristos lutil_tm2gtime LDAP_P((
201*549b59edSchristos 	struct lutil_tm *, struct lutil_timet * ));
202*549b59edSchristos 
2032de962bdSlukem #ifdef _WIN32
2042de962bdSlukem LDAP_LUTIL_F( void )
2052de962bdSlukem lutil_slashpath LDAP_P(( char* path ));
2062de962bdSlukem #define	LUTIL_SLASHPATH(p)	lutil_slashpath(p)
2072de962bdSlukem #else
2082de962bdSlukem #define	LUTIL_SLASHPATH(p)
2092de962bdSlukem #endif
2102de962bdSlukem 
2112de962bdSlukem LDAP_LUTIL_F( char* )
2122de962bdSlukem lutil_strcopy LDAP_P(( char *dst, const char *src ));
2132de962bdSlukem 
2142de962bdSlukem LDAP_LUTIL_F( char* )
2152de962bdSlukem lutil_strncopy LDAP_P(( char *dst, const char *src, size_t n ));
2162de962bdSlukem 
2174e6df137Slukem LDAP_LUTIL_F( char* )
2184e6df137Slukem lutil_memcopy LDAP_P(( char *dst, const char *src, size_t n ));
2194e6df137Slukem 
2204e6df137Slukem #define lutil_strbvcopy(a, bv) lutil_memcopy((a),(bv)->bv_val,(bv)->bv_len)
2214e6df137Slukem 
2222de962bdSlukem struct tm;
2232de962bdSlukem 
2242de962bdSlukem /* use this macro to statically allocate buffer for lutil_gentime */
2252de962bdSlukem #define LDAP_LUTIL_GENTIME_BUFSIZE	22
2262de962bdSlukem #define lutil_gentime(s,m,t)	lutil_localtime((s),(m),(t),0)
2272de962bdSlukem LDAP_LUTIL_F( size_t )
2282de962bdSlukem lutil_localtime LDAP_P(( char *s, size_t smax, const struct tm *tm,
2292de962bdSlukem 			long delta ));
2302de962bdSlukem 
2312de962bdSlukem #ifndef HAVE_MKSTEMP
2322de962bdSlukem LDAP_LUTIL_F( int )
2332de962bdSlukem mkstemp LDAP_P (( char * template ));
2342de962bdSlukem #endif
2352de962bdSlukem 
2362de962bdSlukem /* sockpair.c */
2372de962bdSlukem LDAP_LUTIL_F( int )
2382de962bdSlukem lutil_pair( ber_socket_t sd[2] );
2392de962bdSlukem 
2402de962bdSlukem /* uuid.c */
2412de962bdSlukem /* use this macro to allocate buffer for lutil_uuidstr */
2422de962bdSlukem #define LDAP_LUTIL_UUIDSTR_BUFSIZE	40
2432de962bdSlukem LDAP_LUTIL_F( size_t )
2442de962bdSlukem lutil_uuidstr( char *buf, size_t len );
2452de962bdSlukem 
2462de962bdSlukem LDAP_LUTIL_F( int )
2472de962bdSlukem lutil_uuidstr_from_normalized(
2482de962bdSlukem 	char		*uuid,
2492de962bdSlukem 	size_t		uuidlen,
2502de962bdSlukem 	char		*buf,
2512de962bdSlukem 	size_t		buflen );
2522de962bdSlukem 
2532de962bdSlukem /*
2542de962bdSlukem  * Sometimes not all declarations in a header file are needed.
2552de962bdSlukem  * An indicator to this is whether or not the symbol's type has
2562de962bdSlukem  * been defined. Thus, we don't need to include a symbol if
2572de962bdSlukem  * its type has not been defined through another header file.
2582de962bdSlukem  */
2592de962bdSlukem 
2602de962bdSlukem #ifdef HAVE_NT_SERVICE_MANAGER
2612de962bdSlukem LDAP_LUTIL_V (int) is_NT_Service;
2622de962bdSlukem 
2632de962bdSlukem #ifdef _LDAP_PVT_THREAD_H
2642de962bdSlukem LDAP_LUTIL_V (ldap_pvt_thread_cond_t) started_event;
2652de962bdSlukem #endif /* _LDAP_PVT_THREAD_H */
2662de962bdSlukem 
2672de962bdSlukem /* macros are different between Windows and Mingw */
2682de962bdSlukem #if defined(_WINSVC_H) || defined(_WINSVC_)
2692de962bdSlukem LDAP_LUTIL_V (SERVICE_STATUS) lutil_ServiceStatus;
2702de962bdSlukem LDAP_LUTIL_V (SERVICE_STATUS_HANDLE) hlutil_ServiceStatus;
2712de962bdSlukem #endif /* _WINSVC_H */
2722de962bdSlukem 
2732de962bdSlukem LDAP_LUTIL_F (void)
2742de962bdSlukem lutil_CommenceStartupProcessing( char *serverName, void (*stopper)(int)) ;
2752de962bdSlukem 
2762de962bdSlukem LDAP_LUTIL_F (void)
2772de962bdSlukem lutil_ReportShutdownComplete( void );
2782de962bdSlukem 
2792de962bdSlukem LDAP_LUTIL_F (void *)
2802de962bdSlukem lutil_getRegParam( char *svc, char *value );
2812de962bdSlukem 
2822de962bdSlukem LDAP_LUTIL_F (int)
2832de962bdSlukem lutil_srv_install( char* service, char * displayName, char* filename,
2842de962bdSlukem 		 int auto_start );
2852de962bdSlukem LDAP_LUTIL_F (int)
2862de962bdSlukem lutil_srv_remove ( char* service, char* filename );
2872de962bdSlukem 
2882de962bdSlukem #endif /* HAVE_NT_SERVICE_MANAGER */
2892de962bdSlukem 
2902de962bdSlukem #ifdef HAVE_NT_EVENT_LOG
2912de962bdSlukem LDAP_LUTIL_F (void)
2922de962bdSlukem lutil_LogStartedEvent( char *svc, int slap_debug, char *configfile, char *urls );
2932de962bdSlukem 
2942de962bdSlukem LDAP_LUTIL_F (void)
2952de962bdSlukem lutil_LogStoppedEvent( char *svc );
2962de962bdSlukem #endif
2972de962bdSlukem 
2982de962bdSlukem #ifdef HAVE_EBCDIC
2992de962bdSlukem /* Generally this has only been used to put '\n' to stdout. We need to
3002de962bdSlukem  * make sure it is output in EBCDIC.
3012de962bdSlukem  */
3022de962bdSlukem #undef putchar
3032de962bdSlukem #undef putc
3042de962bdSlukem #define putchar(c)     putc((c), stdout)
3052de962bdSlukem #define putc(c,fp)     do { char x=(c); __atoe_l(&x,1); putc(x,fp); } while(0)
3062de962bdSlukem #endif
3072de962bdSlukem 
3082de962bdSlukem LDAP_LUTIL_F (int)
3092de962bdSlukem lutil_atoix( int *v, const char *s, int x );
3102de962bdSlukem 
3112de962bdSlukem LDAP_LUTIL_F (int)
3122de962bdSlukem lutil_atoux( unsigned *v, const char *s, int x );
3132de962bdSlukem 
3142de962bdSlukem LDAP_LUTIL_F (int)
3152de962bdSlukem lutil_atolx( long *v, const char *s, int x );
3162de962bdSlukem 
3172de962bdSlukem LDAP_LUTIL_F (int)
3182de962bdSlukem lutil_atoulx( unsigned long *v, const char *s, int x );
3192de962bdSlukem 
3202de962bdSlukem #define lutil_atoi(v, s)	lutil_atoix((v), (s), 10)
3212de962bdSlukem #define lutil_atou(v, s)	lutil_atoux((v), (s), 10)
3222de962bdSlukem #define lutil_atol(v, s)	lutil_atolx((v), (s), 10)
3232de962bdSlukem #define lutil_atoul(v, s)	lutil_atoulx((v), (s), 10)
3242de962bdSlukem 
325d11b170bStron #ifdef HAVE_LONG_LONG
326d11b170bStron #if defined(HAVE_STRTOLL) || defined(HAVE_STRTOQ)
327d11b170bStron LDAP_LUTIL_F (int)
328d11b170bStron lutil_atollx( long long *v, const char *s, int x );
329d11b170bStron #define lutil_atoll(v, s)	lutil_atollx((v), (s), 10)
330d11b170bStron #endif /* HAVE_STRTOLL || HAVE_STRTOQ */
331d11b170bStron 
332d11b170bStron #if defined(HAVE_STRTOULL) || defined(HAVE_STRTOUQ)
333d11b170bStron LDAP_LUTIL_F (int)
334d11b170bStron lutil_atoullx( unsigned long long *v, const char *s, int x );
335d11b170bStron #define lutil_atoull(v, s)	lutil_atoullx((v), (s), 10)
336d11b170bStron #endif /* HAVE_STRTOULL || HAVE_STRTOUQ */
337d11b170bStron #endif /* HAVE_LONG_LONG */
338d11b170bStron 
3392de962bdSlukem LDAP_LUTIL_F (int)
3402de962bdSlukem lutil_str2bin( struct berval *in, struct berval *out, void *ctx );
3412de962bdSlukem 
3422de962bdSlukem /* Parse and unparse time intervals */
3432de962bdSlukem LDAP_LUTIL_F (int)
3442de962bdSlukem lutil_parse_time( const char *in, unsigned long *tp );
3452de962bdSlukem 
3462de962bdSlukem LDAP_LUTIL_F (int)
3472de962bdSlukem lutil_unparse_time( char *buf, size_t buflen, unsigned long t );
3482de962bdSlukem 
3492de962bdSlukem #ifdef timerdiv
3502de962bdSlukem #define lutil_timerdiv timerdiv
3512de962bdSlukem #else /* ! timerdiv */
3522de962bdSlukem /* works inplace (x == t) */
3532de962bdSlukem #define lutil_timerdiv(t,d,x) \
3542de962bdSlukem 	do { \
3552de962bdSlukem 		time_t s = (t)->tv_sec; \
3562de962bdSlukem 		assert( d > 0 ); \
3572de962bdSlukem 		(x)->tv_sec = s / d; \
3582de962bdSlukem 		(x)->tv_usec = ( (t)->tv_usec + 1000000 * ( s % d ) ) / d; \
3592de962bdSlukem 	} while ( 0 )
3602de962bdSlukem #endif /* ! timerdiv */
3612de962bdSlukem 
3622de962bdSlukem #ifdef timermul
3632de962bdSlukem #define lutil_timermul timermul
3642de962bdSlukem #else /* ! timermul */
3652de962bdSlukem /* works inplace (x == t) */
3662de962bdSlukem #define lutil_timermul(t,m,x) \
3672de962bdSlukem 	do { \
3682de962bdSlukem 		time_t u = (t)->tv_usec * m; \
3692de962bdSlukem 		assert( m > 0 ); \
3702de962bdSlukem 		(x)->tv_sec = (t)->tv_sec * m + u / 1000000; \
3712de962bdSlukem 		(x)->tv_usec = u % 1000000; \
3722de962bdSlukem 	} while ( 0 );
3732de962bdSlukem #endif /* ! timermul */
3742de962bdSlukem 
3752de962bdSlukem LDAP_END_DECL
3762de962bdSlukem 
3772de962bdSlukem #endif /* _LUTIL_H */
378