]> git.ipfire.org Git - thirdparty/shadow.git/commitdiff
lib/idmapping.c: get_map_ranges(): Move range check to a2ul() calls
authorAlejandro Colomar <alx@kernel.org>
Thu, 11 Jan 2024 11:07:58 +0000 (12:07 +0100)
committerSerge Hallyn <serge@hallyn.com>
Fri, 12 Jul 2024 03:42:58 +0000 (22:42 -0500)
Link: <https://github.com/shadow-maint/shadow/commit/ff2baed5dbf81e8967b805889f565fedb48600df#r136635300>
Cc: Serge Hallyn <serge@hallyn.com>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
lib/idmapping.c

index 6bf7a4f93758f2ed4ffafca1bec89862b3dc4663..a4a4b6811a3caff08f79871225123b0f11019fe6 100644 (file)
@@ -15,7 +15,7 @@
 
 #include "alloc/calloc.h"
 #include "alloc/x/xmalloc.h"
-#include "atoi/str2i.h"
+#include "atoi/a2i.h"
 #include "prototypes.h"
 #include "string/sprintf/stpeprintf.h"
 #include "idmapping.h"
@@ -52,15 +52,27 @@ struct map_range *get_map_ranges(int ranges, int argc, char **argv)
        /* Gather up the ranges from the command line */
        m = mappings;
        for (idx = 0, argidx = 0; idx < ranges; idx++, argidx += 3, m++) {
-               if (str2ul(&m->upper, argv[argidx + 0]) == -1) {
+               if (a2ul(&m->upper, argv[argidx + 0], NULL, 0, 0, UINT_MAX) == -1) {
+                       if (errno == ERANGE) {
+                               fprintf(log_get_logfd(), _( "%s: subuid overflow detected.\n"), log_get_progname());
+                               exit(EXIT_FAILURE);
+                       }
                        free(mappings);
                        return NULL;
                }
-               if (str2ul(&m->lower, argv[argidx + 1]) == -1) {
+               if (a2ul(&m->lower, argv[argidx + 1], NULL, 0, 0, UINT_MAX) == -1) {
+                       if (errno == ERANGE) {
+                               fprintf(log_get_logfd(), _( "%s: subuid overflow detected.\n"), log_get_progname());
+                               exit(EXIT_FAILURE);
+                       }
                        free(mappings);
                        return NULL;
                }
-               if (str2ul(&m->count, argv[argidx + 2]) == -1) {
+               if (a2ul(&m->count, argv[argidx + 2], NULL, 0, 0, UINT_MAX) == -1) {
+                       if (errno == ERANGE) {
+                               fprintf(log_get_logfd(), _( "%s: subuid overflow detected.\n"), log_get_progname());
+                               exit(EXIT_FAILURE);
+                       }
                        free(mappings);
                        return NULL;
                }
@@ -68,10 +80,6 @@ struct map_range *get_map_ranges(int ranges, int argc, char **argv)
                        fprintf(log_get_logfd(), _( "%s: subuid overflow detected.\n"), log_get_progname());
                        exit(EXIT_FAILURE);
                }
-               if (m->upper > UINT_MAX || m->lower > UINT_MAX || m->count > UINT_MAX)  {
-                       fprintf(log_get_logfd(), _( "%s: subuid overflow detected.\n"), log_get_progname());
-                       exit(EXIT_FAILURE);
-               }
                if (m->lower + m->count > UINT_MAX || m->upper + m->count > UINT_MAX) {
                        fprintf(log_get_logfd(), _( "%s: subuid overflow detected.\n"), log_get_progname());
                        exit(EXIT_FAILURE);