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