Skip to content

Commit 4993c88

Browse files
Sheetalpamechagluster-ant
authored andcommitted
libgfapi: return correct errno on invalid volume name
glfs_init when called with volume name prefixed by '/' sets errno to 0. Setting errno to EINVAL to resolve the issue. Also volname is a parameter to glfs_new. Thus, validating volname in glfs_new itself and returning EINVAL from that function fixes: bz#1507896 Change-Id: I0d4d2423e26cc07644d50ec8cce788ecc639203d Signed-off-by: Sheetal Pamecha <spamecha@redhat.com>
1 parent 3a56bca commit 4993c88

File tree

5 files changed

+115
-16
lines changed

5 files changed

+115
-16
lines changed

api/src/glfs.c

+14-1
Original file line numberDiff line numberDiff line change
@@ -817,17 +817,30 @@ struct glfs *
817817
pub_glfs_new(const char *volname)
818818
{
819819
struct glfs *fs = NULL;
820+
int i = 0;
820821
int ret = -1;
821822
glusterfs_ctx_t *ctx = NULL;
822823
xlator_t *old_THIS = NULL;
823824
char pname[16] = "";
824825
char msg[32] = "";
825826

826-
if (!volname) {
827+
if (!volname || volname[0] == '/' || volname[0] == '-') {
828+
if (strncmp(volname, "/snaps/", 7) == 0) {
829+
goto label;
830+
}
827831
errno = EINVAL;
828832
return NULL;
829833
}
830834

835+
for (i = 0; i < strlen(volname); i++) {
836+
if (!isalnum(volname[i]) && (volname[i] != '_') &&
837+
(volname[i] != '-')) {
838+
errno = EINVAL;
839+
return NULL;
840+
}
841+
}
842+
843+
label:
831844
/*
832845
* Do this as soon as possible in case something else depends on
833846
* pool allocations.

libglusterfs/src/graph.c

+6-7
Original file line numberDiff line numberDiff line change
@@ -568,14 +568,13 @@ glusterfs_graph_prepare(glusterfs_graph_t *graph, glusterfs_ctx_t *ctx,
568568
} else {
569569
ret = glusterfs_graph_settop(graph, volume_name, _gf_false);
570570
}
571-
if (!ret) {
572-
goto ok;
573-
}
574571

575-
gf_msg("graph", GF_LOG_ERROR, 0, LG_MSG_GRAPH_ERROR,
576-
"glusterfs graph settop failed");
577-
return -1;
578-
ok:
572+
if (ret) {
573+
gf_msg("graph", GF_LOG_ERROR, EINVAL, LG_MSG_GRAPH_ERROR,
574+
"glusterfs graph settop failed");
575+
errno = EINVAL;
576+
return -1;
577+
}
579578

580579
/* XXX: WORM VOLUME */
581580
ret = glusterfs_graph_worm(graph, ctx);

tests/basic/gfapi/bug-1507896.c

+49
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
1+
#include <stdio.h>
2+
#include <string.h>
3+
#include <errno.h>
4+
#include <glusterfs/api/glfs.h>
5+
#include <glusterfs/api/glfs-handles.h>
6+
7+
#define VALIDATE_AND_GOTO_LABEL_ON_ERROR(func, ret, label) \
8+
do { \
9+
if (ret < 0) { \
10+
fprintf(stderr, "%s : returned error %d (%s)\n", func, ret, \
11+
strerror(errno)); \
12+
goto label; \
13+
} \
14+
} while (0)
15+
16+
int
17+
main(int argc, char *argv[])
18+
{
19+
int ret = -1;
20+
glfs_t *fs = NULL;
21+
char *volname = NULL;
22+
char *logfile = NULL;
23+
char *hostname = NULL;
24+
25+
hostname = argv[1];
26+
volname = argv[2];
27+
logfile = argv[3];
28+
29+
fs = glfs_new(volname);
30+
if (!fs)
31+
VALIDATE_AND_GOTO_LABEL_ON_ERROR("glfs_new(fs)", ret, out);
32+
33+
ret = glfs_set_volfile_server(fs, "tcp", hostname, 24007);
34+
VALIDATE_AND_GOTO_LABEL_ON_ERROR("glfs_set_volfile_server(fs)", ret, out);
35+
36+
ret = glfs_set_logging(fs, logfile, 7);
37+
VALIDATE_AND_GOTO_LABEL_ON_ERROR("glfs_set_logging(fs)", ret, out);
38+
39+
ret = glfs_init(fs);
40+
VALIDATE_AND_GOTO_LABEL_ON_ERROR("glfs_init(fs)", ret, out);
41+
42+
out:
43+
if (fs) {
44+
ret = glfs_fini(fs);
45+
if (ret)
46+
fprintf(stderr, "glfs_fini(fs) returned %d\n", ret);
47+
}
48+
return ret;
49+
}

tests/basic/gfapi/bug-1507896.t

+33
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,33 @@
1+
#!/bin/bash
2+
3+
. $(dirname $0)/../../include.rc
4+
. $(dirname $0)/../../volume.rc
5+
6+
cleanup;
7+
8+
TEST glusterd
9+
10+
TEST $CLI volume create $V0 $H0:$B0/brick1;
11+
EXPECT 'Created' volinfo_field $V0 'Status';
12+
13+
TEST $CLI volume start $V0;
14+
EXPECT 'Started' volinfo_field $V0 'Status';
15+
16+
logdir=`gluster --print-logdir`
17+
18+
TEST build_tester $(dirname $0)/bug-1507896.c -lgfapi
19+
20+
TEST ./$(dirname $0)/bug-1507896 $H0 $V0 $logdir/bug-1507896.log
21+
22+
#volume name precedding with '/'
23+
TEST ! ./$(dirname $0)/bug-1507896 $H0 /$V0 $logdir/bug-1507896.log
24+
25+
#volume name passed with any special characters
26+
TEST ! ./$(dirname $0)/bug-1507896 $H0 test@_$V0 $logdir/bug-1507896.log
27+
28+
cleanup_tester $(dirname $0)/bug-1507896
29+
30+
TEST $CLI volume stop $V0
31+
TEST $CLI volume delete $V0
32+
33+
cleanup;

tests/basic/gfapi/glfsxmp-coverage.c

+13-8
Original file line numberDiff line numberDiff line change
@@ -1843,20 +1843,25 @@ main(int argc, char *argv[])
18431843

18441844
sleep(2);
18451845

1846-
fs2 = glfs_new(argv[1]);
1847-
if (!fs2) {
1848-
fprintf(stderr, "glfs_new: returned NULL\n");
1849-
return 1;
1850-
}
18511846
if (argc == 2) {
1847+
/* Generally glfs_new() requires volume name as an argument */
1848+
fs2 = glfs_new("test_only_volume");
1849+
if (!fs2) {
1850+
fprintf(stderr, "glfs_new(fs2): returned NULL\n");
1851+
return 1;
1852+
}
18521853
ret = glfs_set_volfile(fs2, argv[1]);
18531854
if (ret)
1854-
fprintf(stderr, "glfs_set_volfile failed\n");
1855+
fprintf(stderr, "glfs_set_volfile failed(fs2)\n");
18551856
} else {
1856-
// ret = glfs_set_volfile_server (fs2, "unix", "/tmp/gluster.sock", 0);
1857+
fs2 = glfs_new(argv[1]);
1858+
if (!fs2) {
1859+
fprintf(stderr, "glfs_new(fs2): returned NULL\n");
1860+
return 1;
1861+
}
18571862
ret = glfs_set_volfile_server(fs2, "tcp", argv[2], 24007);
18581863
if (ret)
1859-
fprintf(stderr, "glfs_set_volfile_server failed\n");
1864+
fprintf(stderr, "glfs_set_volfile_server failed(fs2)\n");
18601865
}
18611866

18621867
ret = glfs_set_statedump_path(fs2, "/tmp");

0 commit comments

Comments
 (0)