From 2d3757155f464032e3b4a1b5b2544837aa2e0a4a Mon Sep 17 00:00:00 2001 From: Johannes Schoepfer Date: Mon, 25 Jul 2016 04:40:54 +0700 Subject: [PATCH] system/letsencrypt.sh: Added (letsencrypt client). Signed-off-by: Willy Sudiarto Raharjo --- system/letsencrypt.sh/README | 5 ++ system/letsencrypt.sh/doinst.sh | 25 ++++++ .../letsencrypt.sh/letsencrypt.sh.SlackBuild | 82 +++++++++++++++++++ system/letsencrypt.sh/letsencrypt.sh.info | 10 +++ system/letsencrypt.sh/slack-desc | 19 +++++ 5 files changed, 141 insertions(+) create mode 100644 system/letsencrypt.sh/README create mode 100644 system/letsencrypt.sh/doinst.sh create mode 100644 system/letsencrypt.sh/letsencrypt.sh.SlackBuild create mode 100644 system/letsencrypt.sh/letsencrypt.sh.info create mode 100644 system/letsencrypt.sh/slack-desc diff --git a/system/letsencrypt.sh/README b/system/letsencrypt.sh/README new file mode 100644 index 0000000000..e86b0cdf24 --- /dev/null +++ b/system/letsencrypt.sh/README @@ -0,0 +1,5 @@ +This is a client for signing ssl-certificates with an ACME-server. +-Signing of a list of domains +-Signing of a CSR +-Renewal if a certificate is about to expire or subdomains changed +-Certificate revocation diff --git a/system/letsencrypt.sh/doinst.sh b/system/letsencrypt.sh/doinst.sh new file mode 100644 index 0000000000..7e7aa33dc1 --- /dev/null +++ b/system/letsencrypt.sh/doinst.sh @@ -0,0 +1,25 @@ +config() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then + # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} + +preserve_perms() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + if [ -e $OLD ]; then + cp -a $OLD ${NEW}.incoming + cat $NEW > ${NEW}.incoming + mv ${NEW}.incoming $NEW + fi + config $NEW +} + +preserve_perms etc/letsencrypt.sh/config.sh.new diff --git a/system/letsencrypt.sh/letsencrypt.sh.SlackBuild b/system/letsencrypt.sh/letsencrypt.sh.SlackBuild new file mode 100644 index 0000000000..780d2192c2 --- /dev/null +++ b/system/letsencrypt.sh/letsencrypt.sh.SlackBuild @@ -0,0 +1,82 @@ +#!/bin/sh + +# Slackware build script for letsencrypt.sh + +# Copyright 2016 Johannes Schoepfer, +# 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=letsencrypt.sh +VERSION=${VERSION:-0.2.0} +BUILD=${BUILD:-1} +TAG=${TAG:-_SBo} +ARCH=noarch + +CWD=$(pwd) +TMP=${TMP:-/tmp/SBo} +PKG=$TMP/package-$PRGNAM +OUTPUT=${OUTPUT:-/tmp} + +set -e + +rm -rf $PKG +mkdir -p $TMP $PKG $OUTPUT +cd $TMP +rm -rf letsencrypt.sh-0.2.0 +tar vxf $CWD/v0.2.0.tar.gz +cd letsencrypt.sh-0.2.0 +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 {} \; + +mkdir -p $PKG/usr/bin/ +install -m 755 $PRGNAM $PKG/usr/bin/$PRGNAM +mkdir -p $PKG/etc/$PRGNAM +cp docs/examples/config.sh.example $PKG/etc/$PRGNAM/config.sh.new + +# cron +mkdir -p $PKG/etc/cron.d/ +echo '0 0 * * * /usr/bin/letsencrypt.sh -c 1>/dev/null' > $PKG/etc/cron.d/letsencrypt.sh + +# logrotate +mkdir $PKG/etc/logrotate.d +cat << EOF > $PKG/etc/logrotate.d/$PRGNAM +/var/log/$PRGNAM { + rotate 12 + notifempty + missingok + monthly + compress +} +EOF + +# Docs +mkdir -p $PKG/usr/doc/letsencrypt.sh-$VERSION +mv docs/* $PKG/usr/doc/letsencrypt.sh-$VERSION/ +mv CHANGELOG LICENSE README.md $PKG/usr/doc/letsencrypt.sh-$VERSION/ + +mkdir -p $PKG/install +cat $CWD/doinst.sh > $PKG/install/doinst.sh +cat $CWD/slack-desc > $PKG/install/slack-desc + +cd $PKG +/sbin/makepkg -p -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz} diff --git a/system/letsencrypt.sh/letsencrypt.sh.info b/system/letsencrypt.sh/letsencrypt.sh.info new file mode 100644 index 0000000000..e644042f15 --- /dev/null +++ b/system/letsencrypt.sh/letsencrypt.sh.info @@ -0,0 +1,10 @@ +PRGNAM="letsencrypt.sh" +VERSION="0.2.0" +HOMEPAGE="https://github.com/lukas2511/letsencrypt.sh/" +DOWNLOAD="https://github.com/lukas2511/letsencrypt.sh/archive/v0.2.0.tar.gz" +MD5SUM="74974ab79d6879b92ba353bbf3d1257e" +DOWNLOAD_x86_64="" +MD5SUM_x86_64="" +REQUIRES="" +MAINTAINER="Johannes Schoepfer" +EMAIL="" diff --git a/system/letsencrypt.sh/slack-desc b/system/letsencrypt.sh/slack-desc new file mode 100644 index 0000000000..f330e09c00 --- /dev/null +++ b/system/letsencrypt.sh/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------------------------------------------------------| +letsencrypt.sh: letsencrypt.sh (letsencrypt client implemented as a shell-script) +letsencrypt.sh: +letsencrypt.sh: This is a client for signing ssl-certificates with an ACME-server. +letsencrypt.sh: -Signing of a list of domains +letsencrypt.sh: -Signing of a CSR +letsencrypt.sh: -Renewal if a certificate is about to expire or subdomains changed +letsencrypt.sh: -Certificate revocation +letsencrypt.sh: +letsencrypt.sh: https://github.com/lukas2511/letsencrypt.sh/ +letsencrypt.sh: +letsencrypt.sh: