1df6c8
From 8a8c508b529f7609fc5caa10bc79ba817f5d274a Mon Sep 17 00:00:00 2001
1df6c8
From: Milan Zink <mzink@redhat.com>
1df6c8
Date: Mon, 5 Feb 2018 15:04:37 +0100
1df6c8
Subject: [PATCH 343/344] extras/hooks: syntactical errors in SELinux hooks,
1df6c8
 scipt logic improved
1df6c8
1df6c8
Backport of https://review.gluster.org/c/glusterfs/+/19502
1df6c8
1df6c8
Change-Id: Ia5fa1df81bbaec3a84653d136a331c76b457f42c
1df6c8
BUG: 1686800
1df6c8
Signed-off-by: Anoop C S <anoopcs@redhat.com>
1df6c8
Reviewed-on: https://code.engineering.redhat.com/gerrit/187692
1df6c8
Tested-by: RHGS Build Bot <nigelb@redhat.com>
1df6c8
Reviewed-by: Niels de Vos <ndevos@redhat.com>
1df6c8
Reviewed-by: Sunil Kumar Heggodu Gopala Acharya <sheggodu@redhat.com>
1df6c8
---
1df6c8
 .../create/post/S10selinux-label-brick.sh          | 13 +++--
1df6c8
 .../delete/pre/S10selinux-del-fcontext.sh          | 60 +++++++++++++---------
1df6c8
 tests/bugs/glusterfs-server/bug-877992.t           |  4 +-
1df6c8
 3 files changed, 46 insertions(+), 31 deletions(-)
1df6c8
1df6c8
diff --git a/extras/hook-scripts/create/post/S10selinux-label-brick.sh b/extras/hook-scripts/create/post/S10selinux-label-brick.sh
1df6c8
index de242d2..f9b4b1a 100755
1df6c8
--- a/extras/hook-scripts/create/post/S10selinux-label-brick.sh
1df6c8
+++ b/extras/hook-scripts/create/post/S10selinux-label-brick.sh
1df6c8
@@ -34,18 +34,21 @@ parse_args () {
1df6c8
 
1df6c8
 set_brick_labels()
1df6c8
 {
1df6c8
-  volname=${1}
1df6c8
+  volname="${1}"
1df6c8
 
1df6c8
   # grab the path for each local brick
1df6c8
-  brickpath="/var/lib/glusterd/vols/${volname}/bricks/*"
1df6c8
-  brickdirs=$(grep '^path=' "${brickpath}" | cut -d= -f 2 | sort -u)
1df6c8
+  brickpath="/var/lib/glusterd/vols/${volname}/bricks/"
1df6c8
+  brickdirs=$(
1df6c8
+    find "${brickpath}" -type f -exec grep '^path=' {} \; | \
1df6c8
+    cut -d= -f 2 | \
1df6c8
+    sort -u
1df6c8
+  )
1df6c8
 
1df6c8
   for b in ${brickdirs}; do
1df6c8
     # Add a file context for each brick path and associate with the
1df6c8
     # glusterd_brick_t SELinux type.
1df6c8
-    pattern="${b}\(/.*\)?"
1df6c8
+    pattern="${b}(/.*)?"
1df6c8
     semanage fcontext --add -t glusterd_brick_t -r s0 "${pattern}"
1df6c8
-
1df6c8
     # Set the labels on the new brick path.
1df6c8
     restorecon -R "${b}"
1df6c8
   done
1df6c8
diff --git a/extras/hook-scripts/delete/pre/S10selinux-del-fcontext.sh b/extras/hook-scripts/delete/pre/S10selinux-del-fcontext.sh
1df6c8
index 6eba66f..e7f4e8f 100755
1df6c8
--- a/extras/hook-scripts/delete/pre/S10selinux-del-fcontext.sh
1df6c8
+++ b/extras/hook-scripts/delete/pre/S10selinux-del-fcontext.sh
1df6c8
@@ -15,45 +15,55 @@ OPTSPEC="volname:"
1df6c8
 VOL=
1df6c8
 
1df6c8
 function parse_args () {
1df6c8
-        ARGS=$(getopt -o '' -l $OPTSPEC -n $PROGNAME -- "$@")
1df6c8
-        eval set -- "$ARGS"
1df6c8
-
1df6c8
-        while true; do
1df6c8
-        case $1 in
1df6c8
-        --volname)
1df6c8
-         shift
1df6c8
-         VOL=$1
1df6c8
-         ;;
1df6c8
-        *)
1df6c8
-         shift
1df6c8
-         break
1df6c8
-         ;;
1df6c8
-        esac
1df6c8
+  ARGS=$(getopt -o '' -l ${OPTSPEC} -n ${PROGNAME} -- "$@")
1df6c8
+  eval set -- "${ARGS}"
1df6c8
+
1df6c8
+  while true; do
1df6c8
+    case ${1} in
1df6c8
+      --volname)
1df6c8
+        shift
1df6c8
+        VOL=${1}
1df6c8
+      ;;
1df6c8
+      *)
1df6c8
         shift
1df6c8
-        done
1df6c8
+        break
1df6c8
+      ;;
1df6c8
+    esac
1df6c8
+    shift
1df6c8
+  done
1df6c8
 }
1df6c8
 
1df6c8
 function delete_brick_fcontext()
1df6c8
 {
1df6c8
-        volname=$1
1df6c8
+  volname="${1}"
1df6c8
+
1df6c8
+  # grab the path for each local brick
1df6c8
+  brickpath="/var/lib/glusterd/vols/${volname}/bricks/"
1df6c8
+  brickdirs=$(
1df6c8
+    find "${brickpath}" -type f -exec grep '^path=' {} \; | \
1df6c8
+    cut -d= -f 2 | \
1df6c8
+    sort -u
1df6c8
+  )
1df6c8
+
1df6c8
+  for b in ${brickdirs}
1df6c8
+  do
1df6c8
+    # remove the file context associated with the brick path
1df6c8
+    pattern="${b}(/.*)?"
1df6c8
+    semanage fcontext --delete "${pattern}"
1df6c8
 
1df6c8
-        # grab the path for each local brick
1df6c8
-        brickdirs=$(grep '^path=' /var/lib/glusterd/vols/${volname}/bricks/* | cut -d= -f 2)
1df6c8
+    # remove the labels on brick path.
1df6c8
+    restorecon -R "${b}"
1df6c8
+ done
1df6c8
 
1df6c8
-        for b in $brickdirs
1df6c8
-        do
1df6c8
-                # remove the file context associated with the brick path
1df6c8
-                semanage fcontext --delete $b\(/.*\)?
1df6c8
-        done
1df6c8
 }
1df6c8
 
1df6c8
 SELINUX_STATE=$(which getenforce && getenforce)
1df6c8
 [ "${SELINUX_STATE}" = 'Disabled' ] && exit 0
1df6c8
 
1df6c8
 parse_args "$@"
1df6c8
-[ -z "$VOL" ] && exit 1
1df6c8
+[ -z "${VOL}" ] && exit 1
1df6c8
 
1df6c8
-delete_brick_fcontext $VOL
1df6c8
+delete_brick_fcontext "${VOL}"
1df6c8
 
1df6c8
 # failure to delete the fcontext is not fatal
1df6c8
 exit 0
1df6c8
diff --git a/tests/bugs/glusterfs-server/bug-877992.t b/tests/bugs/glusterfs-server/bug-877992.t
1df6c8
index aeb73ed..300000b 100755
1df6c8
--- a/tests/bugs/glusterfs-server/bug-877992.t
1df6c8
+++ b/tests/bugs/glusterfs-server/bug-877992.t
1df6c8
@@ -46,7 +46,9 @@ TEST $CLI volume create $V0 $H0:$B0/${V0}1;
1df6c8
 EXPECT "$V0" volinfo_field $V0 'Volume Name';
1df6c8
 EXPECT 'Created' volinfo_field $V0 'Status';
1df6c8
 EXPECT 'createPre' cat /tmp/pre.out;
1df6c8
-EXPECT 'createPost' cat /tmp/post.out;
1df6c8
+# Spost.sh comes after S10selinux-label-brick.sh under create post hook script
1df6c8
+# list. So consider the delay in setting SELinux context on bricks
1df6c8
+EXPECT_WITHIN 5 'createPost' cat /tmp/post.out;
1df6c8
 hooks_cleanup 'create'
1df6c8
 
1df6c8
 
1df6c8
-- 
1df6c8
1.8.3.1
1df6c8