Added fixes for machine accounts.
authorJeremy Allison <jra@samba.org>
Mon, 16 Nov 1998 20:19:57 +0000 (20:19 +0000)
committerJeremy Allison <jra@samba.org>
Mon, 16 Nov 1998 20:19:57 +0000 (20:19 +0000)
Jeremy.

source/utils/smbpasswd.c

index a96a1c0f7beac2be6396d593829a260a58545816..902f59b245bf0adcf613ae1dc312d5170f41aaca 100644 (file)
@@ -254,6 +254,12 @@ handle password changing for root
 *************************************************************/
 static int process_root(int argc, char *argv[])
 {
+       /*
+        * Next two lines needed for SunOS and don't
+        * hurt anything else...
+        */
+       extern char *optarg;
+       extern int optind;
        struct passwd  *pwd;
        int ch;
        BOOL joining_domain = False;
@@ -359,29 +365,39 @@ static int process_root(int argc, char *argv[])
                exit(1);
        }
 
-       if (!remote_machine && !Get_Pwnam(user_name, True)) {
-               fprintf(stderr, "User \"%s\" was not found in system password file.\n", 
-                       user_name);
-               exit(1);
-       }
-
-       if (user_name[strlen(user_name)-1] == '$') {
-               user_name[strlen(user_name)-1] = 0;
-       }
-
        if (trust_account) {
                /* add the $ automatically */
                static fstring buf;
 
+               /*
+                * Remove any trailing '$' before we
+                * generate the initial machine password.
+                */
+
+               if (user_name[strlen(user_name)-1] == '$') {
+                       user_name[strlen(user_name)-1] = 0;
+               }
+
                if (add_user) {
                        new_passwd = xstrdup(user_name);
                        strlower(new_passwd);
                }
 
+               /*
+                * Now ensure the username ends in '$' for
+                * the machine add.
+                */
+
                slprintf(buf, sizeof(buf)-1, "%s$", user_name);
                user_name = buf;
        }
 
+       if (!remote_machine && !Get_Pwnam(user_name, True)) {
+               fprintf(stderr, "User \"%s\" was not found in system password file.\n", 
+                       user_name);
+               exit(1);
+       }
+
        if (remote_machine != NULL) {
                old_passwd = get_pass("Old SMB password:",stdin_passwd_get);
        }
@@ -433,6 +449,12 @@ handle password changing for non-root
 *************************************************************/
 static int process_nonroot(int argc, char *argv[])
 {
+       /*
+        * Next two lines needed for SunOS and don't
+        * hurt anything else...
+        */
+    extern char *optarg;
+    extern int optind;
        struct passwd  *pwd = NULL;
        int ch;
        BOOL stdin_passwd_get = False;