network/gui-ufw: Fix broken wrapper scripts.

Signed-off-by: B. Watson <yalhcru@gmail.com>
This commit is contained in:
B. Watson 2022-03-15 16:02:24 -04:00
parent a68cb824c4
commit 8fbe0b1fd3
3 changed files with 47 additions and 32 deletions

View File

@ -0,0 +1,18 @@
#!/bin/bash
# 20220315 bkw: replacement wrapper script for gui-ufw, part of the
# gui-ufw SlackBuilds.org build, by B. Watson. WTFPL licensed.
# find the path to the script, in a way that won't break if the
# python version gets upgraded, and works on either 32-bit or 64-bit
# Slackware.
PYVER="$( python3 --version | cut -d' ' -f2 | cut -d. -f1,2 )"
for i in lib64 lib; do
dir="/usr/$i/python$PYVER/site-packages/gufw"
[ -d "$dir" ] && break
done
# kdesu takes care of allowing access to the X server (no need for
# xhost commands) and works fine regardless of desktop environment or
# window manager. it doesn't rely on policykit, which is a nice bonus.
exec kdesu -c "python3 $dir/gufw.py"

View File

@ -22,11 +22,17 @@
# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF # OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
# 20220315 bkw: Modified by SlackBuilds.org, BUILD=2:
# - fix broken wrapper scripts that prevented the app from starting
# on 32-bit Slackware, or after a python3 upgrade, or if the user
# uses runlevel 3.
# - fix repeated builds (we were missing "rm -rf $PRGNAM-$VERSION").
cd $(dirname $0) ; CWD=$(pwd) cd $(dirname $0) ; CWD=$(pwd)
PRGNAM=gui-ufw PRGNAM=gui-ufw
VERSION=${VERSION:-19.10.0} VERSION=${VERSION:-19.10.0}
BUILD=${BUILD:-1} BUILD=${BUILD:-2}
TAG=${TAG:-_SBo} TAG=${TAG:-_SBo}
PKGTYPE=${PKGTYPE:-tgz} PKGTYPE=${PKGTYPE:-tgz}
@ -38,9 +44,6 @@ if [ -z "$ARCH" ]; then
esac esac
fi fi
# If the variable PRINT_PACKAGE_NAME is set, then this script will report what
# the name of the created package would be, and then exit. This information
# could be useful to other scripts.
if [ ! -z "${PRINT_PACKAGE_NAME}" ]; then if [ ! -z "${PRINT_PACKAGE_NAME}" ]; then
echo "$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE" echo "$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE"
exit 0 exit 0
@ -50,51 +53,45 @@ TMP=${TMP:-/tmp/SBo}
PKG=$TMP/package-$PRGNAM PKG=$TMP/package-$PRGNAM
OUTPUT=${OUTPUT:-/tmp} OUTPUT=${OUTPUT:-/tmp}
if [ "$ARCH" = "i586" ]; then # 20220315 bkw: No compiled code here, and setup.py knows about
SLKCFLAGS="-O2 -march=i586 -mtune=i686" # lib64 directories already.
LIBDIRSUFFIX=""
elif [ "$ARCH" = "i686" ]; then
SLKCFLAGS="-O2 -march=i686 -mtune=i686"
LIBDIRSUFFIX=""
elif [ "$ARCH" = "x86_64" ]; then
SLKCFLAGS="-O2 -fPIC"
LIBDIRSUFFIX="64"
else
SLKCFLAGS="-O2"
LIBDIRSUFFIX=""
fi
set -e set -e
rm -rf $PKG rm -rf $PKG
mkdir -p $TMP $PKG $OUTPUT mkdir -p $TMP $PKG $OUTPUT
cd $TMP cd $TMP
rm -rf $PRGNAM-$VERSION
mkdir $PRGNAM-$VERSION mkdir $PRGNAM-$VERSION
tar xvf $CWD/$PRGNAM-$VERSION.tar.gz tar xvf $CWD/$PRGNAM-$VERSION.tar.gz
cd $PRGNAM-$VERSION cd $PRGNAM-$VERSION
chown -R root:root . chown -R root:root .
find -L . \ find -L . \
\( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \ \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \
-o -perm 511 \) -exec chmod 755 {} \; -o \ -o -perm 511 \) -exec chmod 755 {} \+ -o \
\( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \ \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \
-o -perm 440 -o -perm 400 \) -exec chmod 644 {} \; -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \+
# Point gufw-pkexec to the correct python3 location and version.
sed -i "s|lib/python3.5|lib$LIBDIRSUFFIX/python3.7|g" bin/gufw-pkexec
python3 setup.py install --prefix=/usr --root=$PKG python3 setup.py install --prefix=/usr --root=$PKG
# 20220315 bkw: upstream's wrapper scripts are broken in multiple ways:
# - hardcoded (wrong) path to gufw.py
# - relies on loginctl, meaning it'll never work for users who
# use runlevel 3 (console login + startx)
# - the xhost stuff unconditionally removes localuser:root access
# when gufw exits, even if the user put it there before the
# script was run
# Replace gufw and gufw-pkexec with something that actually works.
rm -f $PKG/usr/bin/*
install -oroot -groot -m0755 $CWD/gufw.wrapper $PKG/usr/bin/gufw
# Move the manpage to a sane directory. # Move the manpage to a sane directory.
mv $PKG/usr/share/man $PKG/usr mv $PKG/usr/share/man $PKG/usr
# Clean up some duplicates # Clean up some duplicates
rm -rf $PKG/usr/share/doc rm -rf $PKG/usr/share/doc
find $PKG -print0 | xargs -0 file | grep -e "executable" -e "shared object" | grep ELF \ gzip -9 $PKG/usr/man/man*/*
| cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true
find $PKG/usr/man -type f -exec gzip -9 {} \;
for i in $( find $PKG/usr/man -type l ) ; do ln -s $( readlink $i ).gz $i.gz ; rm $i ; done
mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
cp -a COPYING* README \ cp -a COPYING* README \

View File

@ -10,10 +10,10 @@ gui-ufw: gui-ufw (GUI for Uncomplicated Firewall)
gui-ufw: gui-ufw:
gui-ufw: A very user-friendly and uncomplicated way to manage ufw. gui-ufw: A very user-friendly and uncomplicated way to manage ufw.
gui-ufw: gui-ufw:
gui-ufw:
gui-ufw:
gui-ufw:
gui-ufw:
gui-ufw:
gui-ufw: Homepage: https://gufw.org/ gui-ufw: Homepage: https://gufw.org/
gui-ufw: gui-ufw:
gui-ufw:
gui-ufw:
gui-ufw:
gui-ufw:
gui-ufw: