1999-08-31 09:17:01 +08:00
|
|
|
/* $OpenLDAP$ */
|
2003-11-26 15:16:36 +08:00
|
|
|
/* This work is part of OpenLDAP Software <http://www.openldap.org/>.
|
|
|
|
*
|
2004-01-02 03:15:16 +08:00
|
|
|
* Copyright 1998-2004 The OpenLDAP Foundation.
|
1999-07-29 04:31:41 +08:00
|
|
|
* All rights reserved.
|
|
|
|
*
|
2001-05-29 11:29:53 +08:00
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted only as authorized by the OpenLDAP
|
2003-11-26 15:16:36 +08:00
|
|
|
* 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>.
|
1998-12-29 03:51:35 +08:00
|
|
|
*/
|
|
|
|
|
1998-09-03 05:31:35 +08:00
|
|
|
#ifndef _LUTIL_H
|
|
|
|
#define _LUTIL_H 1
|
|
|
|
|
1998-10-25 09:41:42 +08:00
|
|
|
#include <ldap_cdefs.h>
|
1999-08-31 13:18:06 +08:00
|
|
|
#include <lber_types.h>
|
|
|
|
|
1998-09-03 05:31:35 +08:00
|
|
|
/*
|
|
|
|
* Include file for LDAP utility routine
|
|
|
|
*/
|
|
|
|
|
1999-10-28 15:28:53 +08:00
|
|
|
LDAP_BEGIN_DECL
|
|
|
|
|
1999-10-25 09:44:47 +08:00
|
|
|
/* n octets encode into ceiling(n/3) * 4 bytes */
|
2002-09-10 11:13:37 +08:00
|
|
|
/* Avoid floating point math through extra padding */
|
1999-10-25 09:44:47 +08:00
|
|
|
|
2002-09-10 11:13:37 +08:00
|
|
|
#define LUTIL_BASE64_ENCODE_LEN(n) (((n)+2)/3 * 4)
|
2003-12-11 21:24:06 +08:00
|
|
|
#define LUTIL_BASE64_DECODE_LEN(n) ((n)/4*3)
|
1999-10-25 09:44:47 +08:00
|
|
|
|
Protoized, moved extern definitions to .h files, fixed related bugs.
Most function and variable definitions are now preceded by its extern
definition, for error checking. Retyped a number of functions, usually
to return void. Fixed a number of printf format errors.
API changes (in ldap/include):
Added avl_dup_ok, avl_prefixapply, removed ber_fatten (probably typo
for ber_flatten), retyped ldap_sort_strcasecmp, grew lutil.h.
A number of `extern' declarations are left (some added by protoize), to
be cleaned away later. Mostly strdup(), strcasecmp(), mktemp(), optind,
optarg, errno.
1998-11-16 06:40:11 +08:00
|
|
|
/* ISC Base64 Routines */
|
|
|
|
/* base64.c */
|
1999-05-19 09:12:33 +08:00
|
|
|
|
2000-06-19 03:48:07 +08:00
|
|
|
LDAP_LUTIL_F( int )
|
1999-05-19 09:12:33 +08:00
|
|
|
lutil_b64_ntop LDAP_P((
|
|
|
|
unsigned char const *,
|
|
|
|
size_t,
|
|
|
|
char *,
|
|
|
|
size_t));
|
|
|
|
|
2000-06-19 03:48:07 +08:00
|
|
|
LDAP_LUTIL_F( int )
|
1999-05-19 09:12:33 +08:00
|
|
|
lutil_b64_pton LDAP_P((
|
|
|
|
char const *,
|
|
|
|
unsigned char *,
|
|
|
|
size_t));
|
|
|
|
|
Protoized, moved extern definitions to .h files, fixed related bugs.
Most function and variable definitions are now preceded by its extern
definition, for error checking. Retyped a number of functions, usually
to return void. Fixed a number of printf format errors.
API changes (in ldap/include):
Added avl_dup_ok, avl_prefixapply, removed ber_fatten (probably typo
for ber_flatten), retyped ldap_sort_strcasecmp, grew lutil.h.
A number of `extern' declarations are left (some added by protoize), to
be cleaned away later. Mostly strdup(), strcasecmp(), mktemp(), optind,
optarg, errno.
1998-11-16 06:40:11 +08:00
|
|
|
/* detach.c */
|
2000-06-19 03:48:07 +08:00
|
|
|
LDAP_LUTIL_F( void )
|
1999-05-19 09:12:33 +08:00
|
|
|
lutil_detach LDAP_P((
|
|
|
|
int debug,
|
|
|
|
int do_close));
|
|
|
|
|
1999-10-27 06:57:39 +08:00
|
|
|
/* entropy.c */
|
2000-06-19 03:48:07 +08:00
|
|
|
LDAP_LUTIL_F( int )
|
1999-11-24 07:02:46 +08:00
|
|
|
lutil_entropy LDAP_P((
|
2000-10-14 10:14:38 +08:00
|
|
|
unsigned char *buf,
|
1999-12-13 12:53:59 +08:00
|
|
|
ber_len_t nbytes ));
|
1999-10-27 06:57:39 +08:00
|
|
|
|
Patch: 'ldapmodify -y file' reads password from file (ITS#2031)
================
Written by Hallvard B. Furuseth and placed into the public domain.
This software is not subject to any license of the University of Oslo.
================
Adapted by Kurt Zeilenga for inclusion in OpenLDAP. My comments are
marked with enclosed with square brackets (e.g. [Kurt's comment] below.
================
If I run ldapmodify & co from a script, I don't want to use '-W password'
because the password shows up in the output of 'ps' for everyone,
and I can't pipe the password to 'ldapmodify -w' because -w uses
getpassphrase() which reads from the tty instead of stdin.
So I added '-y file' which reads the password from file. The programs
exit if the file cannot be read.
[Complete contents of file is used as password. Use:
echo -n "secret" > password
to create a file with "secret" as the password. The -n avoids
adding a newline (which would invalidate the password). Note
that echo is a builtin and hence its arguments are not visible
to 'ps'.]
I changed ldapmodify, ldapmodrdn, ldapdelete, ldapsearch, ldapcompare.
I did not bother to change ldappasswd and ldapwhoami, because they
prompt for many passwords. [I fixed up ldapwhoami.]
Rerun autoconf after applying this patch. [Done.]
Note: I do not know if Windows NT has fstat(), so I set HAVE_FSTAT to
undef in portable.nt. (fstat() is used to warn if the file is publicly
readable or writeable.) [I used fstat() to set the buffer size to
read.]
[Note: using the contents of a file extends the tools to support
passwords which could not normally be provided using getpassphrase()
or via the command line.]
Hallvard B. Furuseth <h.b.furuseth@usit.uio.no>, Aug 2002.
[Kurt D. Zeilenga <kurt@openldap.org>, Aug 2002.]
2002-08-24 13:47:17 +08:00
|
|
|
/* passfile.c */
|
2003-03-13 07:07:09 +08:00
|
|
|
struct berval; /* avoid pulling in lber.h */
|
1999-12-09 09:11:16 +08:00
|
|
|
|
Patch: 'ldapmodify -y file' reads password from file (ITS#2031)
================
Written by Hallvard B. Furuseth and placed into the public domain.
This software is not subject to any license of the University of Oslo.
================
Adapted by Kurt Zeilenga for inclusion in OpenLDAP. My comments are
marked with enclosed with square brackets (e.g. [Kurt's comment] below.
================
If I run ldapmodify & co from a script, I don't want to use '-W password'
because the password shows up in the output of 'ps' for everyone,
and I can't pipe the password to 'ldapmodify -w' because -w uses
getpassphrase() which reads from the tty instead of stdin.
So I added '-y file' which reads the password from file. The programs
exit if the file cannot be read.
[Complete contents of file is used as password. Use:
echo -n "secret" > password
to create a file with "secret" as the password. The -n avoids
adding a newline (which would invalidate the password). Note
that echo is a builtin and hence its arguments are not visible
to 'ps'.]
I changed ldapmodify, ldapmodrdn, ldapdelete, ldapsearch, ldapcompare.
I did not bother to change ldappasswd and ldapwhoami, because they
prompt for many passwords. [I fixed up ldapwhoami.]
Rerun autoconf after applying this patch. [Done.]
Note: I do not know if Windows NT has fstat(), so I set HAVE_FSTAT to
undef in portable.nt. (fstat() is used to warn if the file is publicly
readable or writeable.) [I used fstat() to set the buffer size to
read.]
[Note: using the contents of a file extends the tools to support
passwords which could not normally be provided using getpassphrase()
or via the command line.]
Hallvard B. Furuseth <h.b.furuseth@usit.uio.no>, Aug 2002.
[Kurt D. Zeilenga <kurt@openldap.org>, Aug 2002.]
2002-08-24 13:47:17 +08:00
|
|
|
LDAP_LUTIL_F( int )
|
|
|
|
lutil_get_filed_password LDAP_P((
|
|
|
|
const char *filename,
|
|
|
|
struct berval * ));
|
|
|
|
|
|
|
|
/* passwd.c */
|
2003-03-11 13:58:53 +08:00
|
|
|
struct lutil_pw_scheme;
|
|
|
|
|
2003-03-13 07:07:09 +08:00
|
|
|
typedef int (LUTIL_PASSWD_CHK_FUNC)(
|
|
|
|
const struct berval *scheme,
|
2003-03-11 13:58:53 +08:00
|
|
|
const struct berval *passwd,
|
2003-04-30 15:52:05 +08:00
|
|
|
const struct berval *cred,
|
|
|
|
const char **text );
|
2003-03-11 13:58:53 +08:00
|
|
|
|
2003-03-13 07:07:09 +08:00
|
|
|
typedef struct berval * (LUTIL_PASSWD_HASH_FUNC) (
|
|
|
|
const struct berval *scheme,
|
2003-04-30 15:52:05 +08:00
|
|
|
const struct berval *passwd,
|
|
|
|
const char **text );
|
2003-03-11 13:58:53 +08:00
|
|
|
|
|
|
|
LDAP_LUTIL_F( int )
|
2003-03-13 07:07:09 +08:00
|
|
|
lutil_passwd_add LDAP_P((
|
|
|
|
struct berval *scheme,
|
|
|
|
LUTIL_PASSWD_CHK_FUNC *chk_fn,
|
|
|
|
LUTIL_PASSWD_HASH_FUNC *hash_fn ));
|
2003-03-11 13:58:53 +08:00
|
|
|
|
|
|
|
LDAP_LUTIL_F( void )
|
|
|
|
lutil_passwd_init LDAP_P(( void ));
|
|
|
|
|
|
|
|
LDAP_LUTIL_F( void )
|
|
|
|
lutil_passwd_destroy LDAP_P(( void ));
|
|
|
|
|
2000-06-19 03:48:07 +08:00
|
|
|
LDAP_LUTIL_F( int )
|
2000-04-25 21:28:03 +08:00
|
|
|
lutil_authpasswd LDAP_P((
|
|
|
|
const struct berval *passwd, /* stored password */
|
|
|
|
const struct berval *cred, /* user supplied value */
|
|
|
|
const char **methods ));
|
|
|
|
|
2000-06-19 03:48:07 +08:00
|
|
|
LDAP_LUTIL_F( int )
|
2000-04-25 21:28:03 +08:00
|
|
|
lutil_authpasswd_hash LDAP_P((
|
|
|
|
const struct berval *cred,
|
|
|
|
struct berval **passwd, /* password to store */
|
|
|
|
struct berval **salt, /* salt to store */
|
|
|
|
const char *method ));
|
|
|
|
|
2000-05-10 12:29:51 +08:00
|
|
|
#if defined( SLAPD_SPASSWD ) && defined( HAVE_CYRUS_SASL )
|
|
|
|
/* cheat to avoid pulling in <sasl.h> */
|
2001-12-07 12:03:25 +08:00
|
|
|
LDAP_LUTIL_V( struct sasl_conn * ) lutil_passwd_sasl_conn;
|
2000-05-10 12:29:51 +08:00
|
|
|
#endif
|
|
|
|
|
2000-06-19 03:48:07 +08:00
|
|
|
LDAP_LUTIL_F( int )
|
1999-05-19 09:12:33 +08:00
|
|
|
lutil_passwd LDAP_P((
|
1999-12-09 09:11:16 +08:00
|
|
|
const struct berval *passwd, /* stored password */
|
|
|
|
const struct berval *cred, /* user supplied value */
|
2003-04-30 15:52:05 +08:00
|
|
|
const char **methods,
|
|
|
|
const char **text )); /* error message */
|
Protoized, moved extern definitions to .h files, fixed related bugs.
Most function and variable definitions are now preceded by its extern
definition, for error checking. Retyped a number of functions, usually
to return void. Fixed a number of printf format errors.
API changes (in ldap/include):
Added avl_dup_ok, avl_prefixapply, removed ber_fatten (probably typo
for ber_flatten), retyped ldap_sort_strcasecmp, grew lutil.h.
A number of `extern' declarations are left (some added by protoize), to
be cleaned away later. Mostly strdup(), strcasecmp(), mktemp(), optind,
optarg, errno.
1998-11-16 06:40:11 +08:00
|
|
|
|
2000-06-19 03:48:07 +08:00
|
|
|
LDAP_LUTIL_F( struct berval * )
|
1999-12-13 12:53:59 +08:00
|
|
|
lutil_passwd_generate LDAP_P(( ber_len_t ));
|
1999-12-10 12:52:32 +08:00
|
|
|
|
2000-06-19 03:48:07 +08:00
|
|
|
LDAP_LUTIL_F( struct berval * )
|
1999-12-10 12:52:32 +08:00
|
|
|
lutil_passwd_hash LDAP_P((
|
1999-12-09 09:11:16 +08:00
|
|
|
const struct berval *passwd,
|
2003-04-30 15:52:05 +08:00
|
|
|
const char *method,
|
|
|
|
const char **text ));
|
1999-12-08 12:37:59 +08:00
|
|
|
|
2000-06-19 03:48:07 +08:00
|
|
|
LDAP_LUTIL_F( int )
|
1999-12-09 09:11:16 +08:00
|
|
|
lutil_passwd_scheme LDAP_P((
|
|
|
|
const char *scheme ));
|
1999-09-26 06:13:25 +08:00
|
|
|
|
2001-06-13 11:47:17 +08:00
|
|
|
LDAP_LUTIL_F( int )
|
|
|
|
lutil_salt_format LDAP_P((
|
|
|
|
const char *format ));
|
|
|
|
|
1999-08-18 03:00:59 +08:00
|
|
|
/* utils.c */
|
2000-06-19 03:48:07 +08:00
|
|
|
LDAP_LUTIL_F( char* )
|
1999-08-18 03:00:59 +08:00
|
|
|
lutil_progname LDAP_P((
|
|
|
|
const char* name,
|
|
|
|
int argc,
|
|
|
|
char *argv[] ));
|
|
|
|
|
2002-07-27 08:26:27 +08:00
|
|
|
LDAP_LUTIL_F( char* )
|
|
|
|
lutil_strcopy LDAP_P(( char *dst, const char *src ));
|
|
|
|
|
|
|
|
LDAP_LUTIL_F( char* )
|
|
|
|
lutil_strncopy LDAP_P(( char *dst, const char *src, size_t n ));
|
|
|
|
|
2002-07-27 10:10:02 +08:00
|
|
|
struct tm;
|
|
|
|
|
2002-08-31 18:48:02 +08:00
|
|
|
/* use this macro to statically allocate buffer for lutil_gentime */
|
|
|
|
#define LDAP_LUTIL_GENTIME_BUFSIZE 22
|
2003-05-15 09:18:45 +08:00
|
|
|
#define lutil_gentime(s,m,t) lutil_localtime((s),(m),(t),0)
|
2002-07-27 08:26:27 +08:00
|
|
|
LDAP_LUTIL_F( size_t )
|
2003-05-15 09:18:45 +08:00
|
|
|
lutil_localtime LDAP_P(( char *s, size_t smax, const struct tm *tm,
|
|
|
|
long delta ));
|
2002-07-27 08:26:27 +08:00
|
|
|
|
2001-12-18 06:40:10 +08:00
|
|
|
#ifndef HAVE_MKSTEMP
|
|
|
|
LDAP_LUTIL_F( int )
|
|
|
|
mkstemp LDAP_P (( char * template ));
|
|
|
|
#endif
|
|
|
|
|
1999-08-31 13:18:06 +08:00
|
|
|
/* sockpair.c */
|
2000-06-19 03:48:07 +08:00
|
|
|
LDAP_LUTIL_F( int )
|
2000-10-18 08:32:35 +08:00
|
|
|
lutil_pair( ber_socket_t sd[2] );
|
1999-08-18 03:00:59 +08:00
|
|
|
|
2001-12-09 10:34:45 +08:00
|
|
|
/* uuid.c */
|
2002-08-31 18:48:02 +08:00
|
|
|
/* use this macro to allocate buffer for lutil_uuidstr */
|
|
|
|
#define LDAP_LUTIL_UUIDSTR_BUFSIZE 40
|
2001-12-09 10:34:45 +08:00
|
|
|
LDAP_LUTIL_F( size_t )
|
|
|
|
lutil_uuidstr( char *buf, size_t len );
|
|
|
|
|
|
|
|
/* csn.c */
|
2002-08-31 18:48:02 +08:00
|
|
|
/* use this macro to allocate buffer for lutil_csnstr */
|
|
|
|
#define LDAP_LUTIL_CSNSTR_BUFSIZE 64
|
2001-12-09 10:34:45 +08:00
|
|
|
LDAP_LUTIL_F( size_t )
|
|
|
|
lutil_csnstr( char *buf, size_t len, unsigned int replica, unsigned int mod );
|
|
|
|
|
2001-12-07 12:03:25 +08:00
|
|
|
/*
|
|
|
|
* Sometimes not all declarations in a header file are needed.
|
|
|
|
* An indicator to this is whether or not the symbol's type has
|
|
|
|
* been defined. Thus, we don't need to include a symbol if
|
|
|
|
* its type has not been defined through another header file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef HAVE_NT_SERVICE_MANAGER
|
|
|
|
LDAP_LUTIL_V (int) is_NT_Service;
|
|
|
|
|
|
|
|
#ifdef _LDAP_PVT_THREAD_H
|
|
|
|
LDAP_LUTIL_V (ldap_pvt_thread_cond_t) started_event;
|
|
|
|
#endif /* _LDAP_PVT_THREAD_H */
|
|
|
|
|
2001-12-18 06:40:10 +08:00
|
|
|
/* macros are different between Windows and Mingw */
|
|
|
|
#if defined(_WINSVC_H) || defined(_WINSVC_)
|
2003-03-03 19:42:12 +08:00
|
|
|
LDAP_LUTIL_V (SERVICE_STATUS) lutil_ServiceStatus;
|
|
|
|
LDAP_LUTIL_V (SERVICE_STATUS_HANDLE) hlutil_ServiceStatus;
|
2001-12-07 12:03:25 +08:00
|
|
|
#endif /* _WINSVC_H */
|
|
|
|
|
2003-03-03 19:42:12 +08:00
|
|
|
LDAP_LUTIL_F (void)
|
|
|
|
lutil_CommenceStartupProcessing( char *serverName, void (*stopper)(int)) ;
|
|
|
|
|
|
|
|
LDAP_LUTIL_F (void)
|
|
|
|
lutil_ReportShutdownComplete( void );
|
|
|
|
|
|
|
|
LDAP_LUTIL_F (void *)
|
|
|
|
lutil_getRegParam( char *svc, char *value );
|
|
|
|
|
|
|
|
LDAP_LUTIL_F (int)
|
|
|
|
lutil_srv_install( char* service, char * displayName, char* filename,
|
|
|
|
int auto_start );
|
|
|
|
LDAP_LUTIL_F (int)
|
|
|
|
lutil_srv_remove ( char* service, char* filename );
|
|
|
|
|
2001-12-07 12:03:25 +08:00
|
|
|
#endif /* HAVE_NT_SERVICE_MANAGER */
|
|
|
|
|
2003-03-03 19:42:12 +08:00
|
|
|
#ifdef HAVE_NT_EVENT_LOG
|
|
|
|
LDAP_LUTIL_F (void)
|
|
|
|
lutil_LogStartedEvent( char *svc, int slap_debug, char *configfile, char *urls );
|
|
|
|
|
|
|
|
LDAP_LUTIL_F (void)
|
|
|
|
lutil_LogStoppedEvent( char *svc );
|
|
|
|
#endif
|
|
|
|
|
2002-07-27 08:26:27 +08:00
|
|
|
#ifdef HAVE_EBCDIC
|
|
|
|
/* Generally this has only been used to put '\n' to stdout. We need to
|
|
|
|
* make sure it is output in EBCDIC.
|
|
|
|
*/
|
|
|
|
#undef putchar
|
|
|
|
#undef putc
|
|
|
|
#define putchar(c) putc((c), stdout)
|
|
|
|
#define putc(c,fp) do { char x=(c); __atoe_l(&x,1); putc(x,fp); } while(0)
|
|
|
|
#endif
|
|
|
|
|
1998-10-25 09:41:42 +08:00
|
|
|
LDAP_END_DECL
|
1998-09-03 05:31:35 +08:00
|
|
|
|
|
|
|
#endif /* _LUTIL_H */
|