diff mbox series

Add program name to error output instead of static mount.cifs

Message ID 20191114175551.18805-1-kdsouza@redhat.com
State New
Headers show
Series Add program name to error output instead of static mount.cifs | expand

Commit Message

Kenneth Dsouza Nov. 14, 2019, 5:55 p.m. UTC
As we are supporting mount.smb3 to be invoked, the error output
should contain the called program and not mount.cifs

Signed-off-by: Kenneth D'souza <kdsouza@redhat.com>
---
 mount.cifs.c | 56 ++++++++++++++++++++++++++--------------------------
 1 file changed, 28 insertions(+), 28 deletions(-)

Comments

Pavel Shilovsky Dec. 13, 2019, 12:29 a.m. UTC | #1
чт, 14 нояб. 2019 г. в 09:55, Kenneth D'souza <kdsouza@redhat.com>:
>
> As we are supporting mount.smb3 to be invoked, the error output
> should contain the called program and not mount.cifs
>
> Signed-off-by: Kenneth D'souza <kdsouza@redhat.com>
> ---
>  mount.cifs.c | 56 ++++++++++++++++++++++++++--------------------------
>  1 file changed, 28 insertions(+), 28 deletions(-)
>
> diff --git a/mount.cifs.c b/mount.cifs.c
> index 0ed9d0a..40918c1 100644
> --- a/mount.cifs.c
> +++ b/mount.cifs.c
> @@ -194,7 +194,7 @@ struct parsed_mount_info {
>  static const char *thisprogram;
>  static const char *cifs_fstype;
>
> -static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info);
> +static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info, const char *progname);
>
>  static int check_setuid(void)
>  {
> @@ -206,7 +206,7 @@ static int check_setuid(void)
>
>  #if CIFS_DISABLE_SETUID_CAPABILITY
>         if (getuid() && !geteuid()) {
> -               printf("This mount.cifs program has been built with the "
> +               printf("This program has been built with the "
>                        "ability to run as a setuid root program disabled.\n");
>                 return EX_USAGE;
>         }
> @@ -301,7 +301,7 @@ static int mount_usage(FILE * stream)
>                 "\n\tbsize=<size>");
>         fprintf(stream,
>                 "\n\nOptions are described in more detail in the manual page");
> -       fprintf(stream, "\n\tman 8 mount.cifs\n");
> +       fprintf(stream, "\n\tman 8 %s\n", thisprogram);
>         fprintf(stream, "\nTo display the version number of the mount helper:");
>         fprintf(stream, "\n\t%s -V\n", thisprogram);
>
> @@ -636,7 +636,7 @@ return_i:
>
>  static int
>  get_password_from_file(int file_descript, char *filename,
> -                      struct parsed_mount_info *parsed_info)
> +                      struct parsed_mount_info *parsed_info, const char *program)
>  {
>         int rc = 0;
>         char buf[sizeof(parsed_info->password) + 1];
> @@ -649,8 +649,8 @@ get_password_from_file(int file_descript, char *filename,
>                 rc = access(filename, R_OK);
>                 if (rc) {
>                         fprintf(stderr,
> -                               "mount.cifs failed: access check of %s failed: %s\n",
> -                               filename, strerror(errno));
> +                               "%s failed: access check of %s failed: %s\n",
> +                               program, filename, strerror(errno));
>                         toggle_dac_capability(0, 0);
>                         return EX_SYSERR;
>                 }
> @@ -658,8 +658,8 @@ get_password_from_file(int file_descript, char *filename,
>                 file_descript = open(filename, O_RDONLY);
>                 if (file_descript < 0) {
>                         fprintf(stderr,
> -                               "mount.cifs failed. %s attempting to open password file %s\n",
> -                               strerror(errno), filename);
> +                               "%s failed. %s attempting to open password file %s\n",
> +                               program, strerror(errno), filename);
>                         toggle_dac_capability(0, 0);
>                         return EX_SYSERR;
>                 }
> @@ -675,8 +675,8 @@ get_password_from_file(int file_descript, char *filename,
>         rc = read(file_descript, buf, sizeof(buf) - 1);
>         if (rc < 0) {
>                 fprintf(stderr,
> -                       "mount.cifs failed. Error %s reading password file\n",
> -                       strerror(errno));
> +                       "%s failed. Error %s reading password file\n",
> +                       program, strerror(errno));
>                 rc = EX_SYSERR;
>                 goto get_pw_exit;
>         }
> @@ -923,7 +923,7 @@ parse_options(const char *data, struct parsed_mount_info *parsed_info)
>                                         "invalid path to network resource\n");
>                                 return EX_USAGE;
>                         }
> -                       rc = parse_unc(value, parsed_info);
> +                       rc = parse_unc(value, parsed_info, thisprogram);
>                         if (rc)
>                                 return rc;
>                         break;
> @@ -1280,7 +1280,7 @@ nocopy:
>         return 0;
>  }
>
> -static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info)
> +static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info, const char *progname)
>  {
>         int length = strnlen(unc_name, MAX_UNC_LEN);
>         const char *host, *share, *prepath;
> @@ -1305,26 +1305,26 @@ static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info
>         }
>
>         if (strncmp(unc_name, "//", 2) && strncmp(unc_name, "\\\\", 2)) {
> -               fprintf(stderr, "mount.cifs: bad UNC (%s)\n", unc_name);
> +               fprintf(stderr, "%s: bad UNC (%s)\n", progname, unc_name);
>                 return EX_USAGE;
>         }
>
>         host = unc_name + 2;
>         hostlen = strcspn(host, "/\\");
>         if (!hostlen) {
> -               fprintf(stderr, "mount.cifs: bad UNC (%s)\n", unc_name);
> +               fprintf(stderr, "%s: bad UNC (%s)\n", progname, unc_name);
>                 return EX_USAGE;
>         }
>         share = host + hostlen + 1;
>
>         if (hostlen + 1 > sizeof(parsed_info->host)) {
> -               fprintf(stderr, "mount.cifs: host portion of UNC too long\n");
> +               fprintf(stderr, "%s: host portion of UNC too long\n", progname);
>                 return EX_USAGE;
>         }
>
>         sharelen = strcspn(share, "/\\");
>         if (sharelen + 1 > sizeof(parsed_info->share)) {
> -               fprintf(stderr, "mount.cifs: share portion of UNC too long\n");
> +               fprintf(stderr, "%s: share portion of UNC too long\n", progname);
>                 return EX_USAGE;
>         }
>
> @@ -1335,7 +1335,7 @@ static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info
>         prepathlen = strlen(prepath);
>
>         if (prepathlen + 1 > sizeof(parsed_info->prefix)) {
> -               fprintf(stderr, "mount.cifs: UNC prefixpath too long\n");
> +               fprintf(stderr, "%s: UNC prefixpath too long\n", progname);
>                 return EX_USAGE;
>         }
>
> @@ -1347,7 +1347,7 @@ static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info
>         return 0;
>  }
>
> -static int get_pw_from_env(struct parsed_mount_info *parsed_info)
> +static int get_pw_from_env(struct parsed_mount_info *parsed_info, const char *program)
>  {
>         int rc = 0;
>
> @@ -1355,10 +1355,10 @@ static int get_pw_from_env(struct parsed_mount_info *parsed_info)
>                 rc = set_password(parsed_info, getenv("PASSWD"));
>         else if (getenv("PASSWD_FD"))
>                 rc = get_password_from_file(atoi(getenv("PASSWD_FD")), NULL,
> -                                           parsed_info);
> +                                           parsed_info, program);
>         else if (getenv("PASSWD_FILE"))
>                 rc = get_password_from_file(0, getenv("PASSWD_FILE"),
> -                                           parsed_info);
> +                                           parsed_info, program);
>
>         return rc;
>  }
> @@ -1408,9 +1408,9 @@ static int uppercase_string(char *string)
>         return 1;
>  }
>
> -static void print_cifs_mount_version(void)
> +static void print_cifs_mount_version(const char *progname)
>  {
> -       printf("mount.cifs version: %s\n", VERSION);
> +       printf("%s version: %s\n", progname, VERSION);
>  }
>
>  /*
> @@ -1782,7 +1782,7 @@ assemble_mountinfo(struct parsed_mount_info *parsed_info,
>                 parsed_info->flags |= CIFS_SETUID_FLAGS;
>         }
>
> -       rc = get_pw_from_env(parsed_info);
> +       rc = get_pw_from_env(parsed_info, thisprogram);
>         if (rc)
>                 goto assemble_exit;
>
> @@ -1802,7 +1802,7 @@ assemble_mountinfo(struct parsed_mount_info *parsed_info,
>
>         parsed_info->flags &= ~(MS_USERS | MS_USER);
>
> -       rc = parse_unc(orig_dev, parsed_info);
> +       rc = parse_unc(orig_dev, parsed_info, thisprogram);
>         if (rc)
>                 goto assemble_exit;
>
> @@ -1987,10 +1987,10 @@ int main(int argc, char **argv)
>                 thisprogram = "mount.cifs";
>
>         if(strcmp(thisprogram, "mount.cifs") == 0)
> -               cifs_fstype = "cifs";
> +               cifs_fstype = "cifs";
>
> -        if(strcmp(thisprogram, "mount.smb3") == 0)
> -              cifs_fstype = "smb3";
> +       if(strcmp(thisprogram, "mount.smb3") == 0)
> +               cifs_fstype = "smb3";
>
>         /* allocate parsed_info as shared anonymous memory range */
>         parsed_info = mmap((void *)0, sizeof(*parsed_info), PROT_READ | PROT_WRITE,
> @@ -2027,7 +2027,7 @@ int main(int argc, char **argv)
>                         ++parsed_info->verboseflag;
>                         break;
>                 case 'V':
> -                       print_cifs_mount_version();
> +                       print_cifs_mount_version(thisprogram);
>                         exit(0);
>                 case 'w':
>                         parsed_info->flags &= ~MS_RDONLY;
> --
> 2.21.0
>

Merged, thanks.

I noticed that "thisprogram" variable name is used for static variable
and for assemble_mountinfo() function argument - probably this should
be fixed to avoid confusions.

--
Best regards,
Pavel Shilovsky
diff mbox series

Patch

diff --git a/mount.cifs.c b/mount.cifs.c
index 0ed9d0a..40918c1 100644
--- a/mount.cifs.c
+++ b/mount.cifs.c
@@ -194,7 +194,7 @@  struct parsed_mount_info {
 static const char *thisprogram;
 static const char *cifs_fstype;
 
-static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info);
+static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info, const char *progname);
 
 static int check_setuid(void)
 {
@@ -206,7 +206,7 @@  static int check_setuid(void)
 
 #if CIFS_DISABLE_SETUID_CAPABILITY
 	if (getuid() && !geteuid()) {
-		printf("This mount.cifs program has been built with the "
+		printf("This program has been built with the "
 		       "ability to run as a setuid root program disabled.\n");
 		return EX_USAGE;
 	}
@@ -301,7 +301,7 @@  static int mount_usage(FILE * stream)
 		"\n\tbsize=<size>");
 	fprintf(stream,
 		"\n\nOptions are described in more detail in the manual page");
-	fprintf(stream, "\n\tman 8 mount.cifs\n");
+	fprintf(stream, "\n\tman 8 %s\n", thisprogram);
 	fprintf(stream, "\nTo display the version number of the mount helper:");
 	fprintf(stream, "\n\t%s -V\n", thisprogram);
 
@@ -636,7 +636,7 @@  return_i:
 
 static int
 get_password_from_file(int file_descript, char *filename,
-		       struct parsed_mount_info *parsed_info)
+		       struct parsed_mount_info *parsed_info, const char *program)
 {
 	int rc = 0;
 	char buf[sizeof(parsed_info->password) + 1];
@@ -649,8 +649,8 @@  get_password_from_file(int file_descript, char *filename,
 		rc = access(filename, R_OK);
 		if (rc) {
 			fprintf(stderr,
-				"mount.cifs failed: access check of %s failed: %s\n",
-				filename, strerror(errno));
+				"%s failed: access check of %s failed: %s\n",
+				program, filename, strerror(errno));
 			toggle_dac_capability(0, 0);
 			return EX_SYSERR;
 		}
@@ -658,8 +658,8 @@  get_password_from_file(int file_descript, char *filename,
 		file_descript = open(filename, O_RDONLY);
 		if (file_descript < 0) {
 			fprintf(stderr,
-				"mount.cifs failed. %s attempting to open password file %s\n",
-				strerror(errno), filename);
+				"%s failed. %s attempting to open password file %s\n",
+				program, strerror(errno), filename);
 			toggle_dac_capability(0, 0);
 			return EX_SYSERR;
 		}
@@ -675,8 +675,8 @@  get_password_from_file(int file_descript, char *filename,
 	rc = read(file_descript, buf, sizeof(buf) - 1);
 	if (rc < 0) {
 		fprintf(stderr,
-			"mount.cifs failed. Error %s reading password file\n",
-			strerror(errno));
+			"%s failed. Error %s reading password file\n",
+			program, strerror(errno));
 		rc = EX_SYSERR;
 		goto get_pw_exit;
 	}
@@ -923,7 +923,7 @@  parse_options(const char *data, struct parsed_mount_info *parsed_info)
 					"invalid path to network resource\n");
 				return EX_USAGE;
 			}
-			rc = parse_unc(value, parsed_info);
+			rc = parse_unc(value, parsed_info, thisprogram);
 			if (rc)
 				return rc;
 			break;
@@ -1280,7 +1280,7 @@  nocopy:
 	return 0;
 }
 
-static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info)
+static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info, const char *progname)
 {
 	int length = strnlen(unc_name, MAX_UNC_LEN);
 	const char *host, *share, *prepath;
@@ -1305,26 +1305,26 @@  static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info
 	}
 
 	if (strncmp(unc_name, "//", 2) && strncmp(unc_name, "\\\\", 2)) {
-		fprintf(stderr, "mount.cifs: bad UNC (%s)\n", unc_name);
+		fprintf(stderr, "%s: bad UNC (%s)\n", progname, unc_name);
 		return EX_USAGE;
 	}
 
 	host = unc_name + 2;
 	hostlen = strcspn(host, "/\\");
 	if (!hostlen) {
-		fprintf(stderr, "mount.cifs: bad UNC (%s)\n", unc_name);
+		fprintf(stderr, "%s: bad UNC (%s)\n", progname, unc_name);
 		return EX_USAGE;
 	}
 	share = host + hostlen + 1;
 
 	if (hostlen + 1 > sizeof(parsed_info->host)) {
-		fprintf(stderr, "mount.cifs: host portion of UNC too long\n");
+		fprintf(stderr, "%s: host portion of UNC too long\n", progname);
 		return EX_USAGE;
 	}
 
 	sharelen = strcspn(share, "/\\");
 	if (sharelen + 1 > sizeof(parsed_info->share)) {
-		fprintf(stderr, "mount.cifs: share portion of UNC too long\n");
+		fprintf(stderr, "%s: share portion of UNC too long\n", progname);
 		return EX_USAGE;
 	}
 
@@ -1335,7 +1335,7 @@  static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info
 	prepathlen = strlen(prepath);
 
 	if (prepathlen + 1 > sizeof(parsed_info->prefix)) {
-		fprintf(stderr, "mount.cifs: UNC prefixpath too long\n");
+		fprintf(stderr, "%s: UNC prefixpath too long\n", progname);
 		return EX_USAGE;
 	}
 
@@ -1347,7 +1347,7 @@  static int parse_unc(const char *unc_name, struct parsed_mount_info *parsed_info
 	return 0;
 }
 
-static int get_pw_from_env(struct parsed_mount_info *parsed_info)
+static int get_pw_from_env(struct parsed_mount_info *parsed_info, const char *program)
 {
 	int rc = 0;
 
@@ -1355,10 +1355,10 @@  static int get_pw_from_env(struct parsed_mount_info *parsed_info)
 		rc = set_password(parsed_info, getenv("PASSWD"));
 	else if (getenv("PASSWD_FD"))
 		rc = get_password_from_file(atoi(getenv("PASSWD_FD")), NULL,
-					    parsed_info);
+					    parsed_info, program);
 	else if (getenv("PASSWD_FILE"))
 		rc = get_password_from_file(0, getenv("PASSWD_FILE"),
-					    parsed_info);
+					    parsed_info, program);
 
 	return rc;
 }
@@ -1408,9 +1408,9 @@  static int uppercase_string(char *string)
 	return 1;
 }
 
-static void print_cifs_mount_version(void)
+static void print_cifs_mount_version(const char *progname)
 {
-	printf("mount.cifs version: %s\n", VERSION);
+	printf("%s version: %s\n", progname, VERSION);
 }
 
 /*
@@ -1782,7 +1782,7 @@  assemble_mountinfo(struct parsed_mount_info *parsed_info,
 		parsed_info->flags |= CIFS_SETUID_FLAGS;
 	}
 
-	rc = get_pw_from_env(parsed_info);
+	rc = get_pw_from_env(parsed_info, thisprogram);
 	if (rc)
 		goto assemble_exit;
 
@@ -1802,7 +1802,7 @@  assemble_mountinfo(struct parsed_mount_info *parsed_info,
 
 	parsed_info->flags &= ~(MS_USERS | MS_USER);
 
-	rc = parse_unc(orig_dev, parsed_info);
+	rc = parse_unc(orig_dev, parsed_info, thisprogram);
 	if (rc)
 		goto assemble_exit;
 
@@ -1987,10 +1987,10 @@  int main(int argc, char **argv)
 		thisprogram = "mount.cifs";
 
 	if(strcmp(thisprogram, "mount.cifs") == 0)
-               cifs_fstype = "cifs";
+		cifs_fstype = "cifs";
 
-        if(strcmp(thisprogram, "mount.smb3") == 0)
-              cifs_fstype = "smb3";
+	if(strcmp(thisprogram, "mount.smb3") == 0)
+		cifs_fstype = "smb3";
 
 	/* allocate parsed_info as shared anonymous memory range */
 	parsed_info = mmap((void *)0, sizeof(*parsed_info), PROT_READ | PROT_WRITE,
@@ -2027,7 +2027,7 @@  int main(int argc, char **argv)
 			++parsed_info->verboseflag;
 			break;
 		case 'V':
-			print_cifs_mount_version();
+			print_cifs_mount_version(thisprogram);
 			exit(0);
 		case 'w':
 			parsed_info->flags &= ~MS_RDONLY;