]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/slappasswd.c
import typo fix from HEAD
[openldap] / servers / slapd / slappasswd.c
index c90e811d04f881c6a7311f7ed8eb7406f64274b8..1bfdb768f1dda2ecc3108d2447c4e136141ba677 100644 (file)
@@ -1,7 +1,7 @@
 /* $OpenLDAP$ */
 /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
  *
- * Copyright 1998-2004 The OpenLDAP Foundation.
+ * Copyright 1998-2006 The OpenLDAP Foundation.
  * Portions Copyright 1998-2003 Kurt D. Zeilenga.
  * All rights reserved.
  *
@@ -33,6 +33,7 @@
 
 #include <ldap.h>
 #include <lutil.h>
+#include <lutil_sha1.h>
 
 #include "ldap_defaults.h"
 
@@ -57,7 +58,12 @@ usage(const char *s)
 int
 slappasswd( int argc, char *argv[] )
 {
+#ifdef LUTIL_SHA1_BYTES
        char    *scheme = "{SSHA}";
+#else
+       char    *scheme = "{SMD5}";
+#endif
+
        char    *newpw = NULL;
        char    *pwfile = NULL;
        const char *text;
@@ -65,7 +71,7 @@ slappasswd( int argc, char *argv[] )
 
        int             i;
        struct berval passwd;
-       struct berval *hash = NULL;
+       struct berval hash;
 
        while( (i = getopt( argc, argv,
                "c:d:h:s:T:vu" )) != EOF )
@@ -131,20 +137,20 @@ slappasswd( int argc, char *argv[] )
                passwd.bv_len = strlen(passwd.bv_val);
        }
 
-       hash = lutil_passwd_hash( &passwd, scheme, &text );
-       if( hash == NULL || hash->bv_val == NULL ) {
+       lutil_passwd_hash( &passwd, scheme, &hash, &text );
+       if( hash.bv_val == NULL ) {
                fprintf( stderr,
                        "Password generation failed for scheme %s: %s\n",
                        scheme, text ? text : "" );
                return EXIT_FAILURE;
        }
 
-       if( lutil_passwd( hash, &passwd, NULL, &text ) ) {
+       if( lutil_passwd( &hash, &passwd, NULL, &text ) ) {
                fprintf( stderr, "Password verification failed. %s\n",
                        text ? text : "" );
                return EXIT_FAILURE;
        }
 
-       printf( "%s\n" , hash->bv_val );
+       printf( "%s\n" , hash.bv_val );
        return EXIT_SUCCESS;
 }