network/gui-ufw: Fix broken wrapper scripts.
Signed-off-by: B. Watson <yalhcru@gmail.com>
This commit is contained in:
parent
a68cb824c4
commit
8fbe0b1fd3
|
@ -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"
|
|
@ -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 \
|
||||||
|
|
|
@ -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:
|
||||||
|
|
Loading…
Reference in New Issue