From 8b8776c4dc8ccc481fad29973875124ec034dc44 Mon Sep 17 00:00:00 2001 From: Mykyta Solomko Date: Wed, 30 Jan 2019 16:45:38 +0200 Subject: [PATCH] Added certbot --- certbot/README.md | 6 ++ certbot/certbot.SlackBuild | 123 +++++++++++++++++++++++++++++++++++++ certbot/certbot.info | 10 +++ certbot/slack-desc | 19 ++++++ certbot/slack-required | 1 + 5 files changed, 159 insertions(+) create mode 100644 certbot/README.md create mode 100755 certbot/certbot.SlackBuild create mode 100644 certbot/certbot.info create mode 100644 certbot/slack-desc create mode 100644 certbot/slack-required diff --git a/certbot/README.md b/certbot/README.md new file mode 100644 index 0000000..186e0d3 --- /dev/null +++ b/certbot/README.md @@ -0,0 +1,6 @@ +**Certbot** (previously, the Let's Encrypt client) is **BETA SOFTWARE**. It contains plenty of bugs and rough edges, and should be tested thoroughly in staging environments before use on production systems. + +- - - - + +For more information regarding the status of the project, please see https://letsencrypt.org. Be sure to checkout the +Frequently Asked Questions [(FAQ)] (https://community.letsencrypt.org/t/frequently-asked-questions-faq/26#topic-title). diff --git a/certbot/certbot.SlackBuild b/certbot/certbot.SlackBuild new file mode 100755 index 0000000..edd6569 --- /dev/null +++ b/certbot/certbot.SlackBuild @@ -0,0 +1,123 @@ +#!/bin/sh + +# Slackware build script for certbot + +# Copyright 2015, Mykyta Solomko , Kyiv, Ukraine +# All rights reserved. +# +# Redistribution and use of this script, with or without modification, 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. + +PRGNAM=certbot +VERSION=${VERSION:-0.8.1} +BUILD=${BUILD:-1} +TAG=${TAG:-sev} + +if [ -z "$ARCH" ]; then + case "$( uname -m )" in + i?86) ARCH=i486 ;; + arm*) ARCH=arm ;; + *) ARCH=$( uname -m ) ;; + esac +fi + +CWD=$(pwd) +TMP=${TMP:-/tmp/build/${ARCH}} +PKG=$TMP/package-$PRGNAM +OUTPUT=${OUTPUT:-/tmp} + +if [ "$ARCH" = "i486" ]; then + SLKCFLAGS="-O2 -march=i486 -mtune=i686" + 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 # Exit on most errors + +rm -rf $PKG +mkdir -p $TMP $PKG $OUTPUT +cd $TMP +rm -rf $PRGNAM-$VERSION +tar xvf $CWD/v$VERSION.tar.?z* +cd $PRGNAM-$VERSION +chown -R root:root . +find -L . \ + \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \ + -o -perm 511 \) -exec chmod 755 {} \; -o \ + \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \ + -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \; + +HOME=$TMP/$PRGNAM-$VERSION \ + virtualenv -p python2 venv +HOME=$TMP/$PRGNAM-$VERSION \ + ./venv/bin/pip install acme/ . certbot-apache/ certbot-nginx/ letshelp-certbot/ letshelp-letsencrypt/ +HOME=$TMP/$PRGNAM-$VERSION \ + virtualenv -p python2 --relocatable venv + +# Create directories +mkdir -p $PKG/opt/$PRGNAM \ + $PKG/usr/sbin \ + $PKG/{etc,var/lib}/certbot + +# Copy distribution +cp -dpr --no-preserve=ownership ./* \ + $PKG/opt/$PRGNAM + +# Create symlinks +pushd $PKG/usr/sbin +ln -sf ../../opt/certbot/venv/bin/certbot . +ln -sf ../../opt/certbot/certbot-auto . +ln -sf ../../opt/certbot/letsencrypt-auto . +popd + +# Remove git-related stuff +find $PKG/ -name '.git*' -delete + +# Strip binaries and libraries +find $PKG -print0 | xargs -0 file | grep -e "executable" -e "shared object" | grep ELF \ + | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true + +# Copy program documentation into the package +mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION +cp -a \ + README.rst LICENSE.txt CONTRIBUTING.md CHANGES.rst \ + $PKG/usr/doc/$PRGNAM-$VERSION +cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild + +# Copy the slack-desc (and a custom doinst.sh if necessary) into ./install +mkdir -p $PKG/install +for INSTFILE in 'doinst.sh' \ + 'slack-desc' \ + 'slack-required' \ + 'slack-suggests' \ + 'slack-conflicts' +do + [[ -f $CWD/$INSTFILE ]] \ + && cat $CWD/$INSTFILE > $PKG/install/$INSTFILE +done + +# Make the package +cd $PKG +/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-${VERSION//-/_}-$ARCH-$BUILD$TAG.${PKGTYPE:-txz} diff --git a/certbot/certbot.info b/certbot/certbot.info new file mode 100644 index 0000000..c7b1a84 --- /dev/null +++ b/certbot/certbot.info @@ -0,0 +1,10 @@ +PRGNAM="certbot" +VERSION="0.8.1" +HOMEPAGE="https://certbot.org" +DOWNLOAD="https://github.com/certbot/certbot/archive/v0.8.1.tar.gz" +MD5SUM="b7823e4c573b0e5884d5f034999511e3" +DOWNLOAD_x86_64="" +MD5SUM_x86_64="" +REQUIRES="virtualenv augeas" +MAINTAINER="Mykyta Solomko" +EMAIL="sev@nix.org.ua" diff --git a/certbot/slack-desc b/certbot/slack-desc new file mode 100644 index 0000000..0495d9d --- /dev/null +++ b/certbot/slack-desc @@ -0,0 +1,19 @@ +# HOW TO EDIT THIS FILE: +# The "handy ruler" below makes it easier to edit a package description. +# Line up the first '|' above the ':' following the base package name, and +# the '|' on the right side marks the last column you can put a character in. +# You must make exactly 11 lines for the formatting to be correct. It's also +# customary to leave one space after the ':' except on otherwise blank lines. + + |-----handy-ruler------------------------------------------------------| +certbot: certbot (Clinent for Let's Encrypt project) +certbot: +certbot: Certbot is a tool to automatically receive and install X.509 +certbot: certificates to enable TLS on servers. The client will +certbot: interoperate with the Let's Encrypt CA which will be issuing +certbot: browser-trusted certificates for free. +certbot: +certbot: Homepage: https://certbot.eff.org/ +certbot: +certbot: +certbot: diff --git a/certbot/slack-required b/certbot/slack-required new file mode 100644 index 0000000..6685d6c --- /dev/null +++ b/certbot/slack-required @@ -0,0 +1 @@ +python,virtualenv,augeas,ca-certificates,cxxlibs|gcc-g++,dialog,libffi,openssl