diff --git a/ap/yubikey-manager/slack-desc b/ap/yubikey-manager/slack-desc new file mode 100644 index 00000000..e78e95f3 --- /dev/null +++ b/ap/yubikey-manager/slack-desc @@ -0,0 +1,12 @@ + |-----handy-ruler-----------------------------------------------------| +yubikey-manager: yubikey-manager (tool for managing a YubiKey device) +yubikey-manager: +yubikey-manager: This package provides a Python library and a command line tool for +yubikey-manager: configuring a yubiKey. +yubikey-manager: +yubikey-manager: +yubikey-manager: +yubikey-manager: +yubikey-manager: +yubikey-manager: +yubikey-manager: diff --git a/ap/yubikey-manager/yubikey-manager-3.1.1.tar.gz.sha256 b/ap/yubikey-manager/yubikey-manager-3.1.1.tar.gz.sha256 new file mode 100644 index 00000000..e85df653 --- /dev/null +++ b/ap/yubikey-manager/yubikey-manager-3.1.1.tar.gz.sha256 @@ -0,0 +1 @@ +68ef41ac3cd2e891019e755a492427ecdd63d8816525d05f2f32c37b8c440cfa yubikey-manager-3.1.1.tar.gz diff --git a/ap/yubikey-manager/yubikey-manager.SlackBuild b/ap/yubikey-manager/yubikey-manager.SlackBuild new file mode 100755 index 00000000..b0a37ab0 --- /dev/null +++ b/ap/yubikey-manager/yubikey-manager.SlackBuild @@ -0,0 +1,112 @@ +#!/bin/bash +# Build script for Slackware +# Copyright (C) 2020 Damien Goutte-Gattat +# +# Redistribution and use of this script, with or without modifications, +# is permitted provided that the following conditions are met: +# +# 1. Redistributions of this script must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AS IS'' AND ANY EXPRESS OR +# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +# DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, +# INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES +# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) +# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, +# STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING +# IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +# POSSIBILITY OF SUCH DAMAGE. +# +# Contact: Damien Goutte-Gattat +# +# Latest yubikey-manager sourcecode is available at: +# . +# +# [NOTES] +# +# Depends: l/pyopenssl, l/pyscard, l/python-click, l/python-fido2, l/pyusb + +# Source package infos +NAMESRC=${NAMESRC:-yubikey-manager} +VERSION=${VERSION:-3.1.1} +ARCHIVE=${ARCHIVE:-$NAMESRC-$VERSION.tar.gz} + +# Build infos +NAMEPKG=${NAMEPKG:-yubikey-manager} +BUILD=${BUILD:-1GGD} +ARCH=${ARCH:-$(uname -m | sed 's/^i.86$/i486/;s/^arm.*/arm/')} +JOBS=${JOBS:-1} +EXT=${EXT:-txz} + +# Directories +TMP=${TMP:-/tmp} +OUT=${OUT:-$TMP/build} +PKG=${PKG:-$OUT/$NAMEPKG} +CWD=$(pwd) + +set -e # Quit if a command returns non-zero + +# Sanity checks +if [ $UID -eq 0 ]; then + echo "You should NOT run this script as ROOT!" + exit 1 +fi +if [ ! -d $TMP ]; then + echo "$TMP does not exists or is not a directory!" + exit 1 +fi + +# Get and verify the source archive +if [ ! -r $ARCHIVE ]; then + pip3 download --no-binary :all: --no-deps $NAMESRC==$VERSION +fi +sha256sum -c $ARCHIVE.sha256 +NAME=$(tar ft $ARCHIVE | head -n 1 | cut -d / -f 1) + +# Compile +cd $TMP +echo "Building $ARCHIVE..." +tar xf $CWD/$ARCHIVE +cd $NAME +python2 setup.py build +python2 setup.py install --root=$PKG +python3 setup.py build +python3 setup.py install --root=$PKG + +# Install man page +install -D -m 644 man/ykman.1 $PKG/usr/man/man1/ykman.1 +gzip -9 $PKG/usr/man/man1/ykman.1 + +# Install the documentation +mkdir -p $PKG/usr/doc/$NAMEPKG-$VERSION +install -m 644 COPYING NEWS README.adoc $PKG/usr/doc/$NAMEPKG-$VERSION + +# Copy slack-desc file +install -D -m 644 $CWD/slack-desc $PKG/install/slack-desc + +# Add dependency infos +cat < $PKG/install/slack-required +pyopenssl +pyscard +python-click +python-fido2 +pyusb +EOF + +# Package the tree +cd $PKG +mkdir -p $OUT +PACKAGING=" +chown root:root . -R +/sbin/makepkg -l y -c n $OUT/$NAMEPKG-$VERSION-$ARCH-$BUILD.$EXT +rm -rf $PKG +rm -rf $TMP/$NAME +" +if type -p fakeroot ; then + echo "$PACKAGING" | fakeroot +else + su -c "$PACKAGING" +fi