You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

208 lines
7.6 KiB

##
## certbot.spec -- OpenPKG RPM Package Specification
## Copyright (c) 2000-2022 OpenPKG Project <http://openpkg.org/>
##
## Permission to use, copy, modify, and distribute this software for
## any purpose with or without fee is hereby granted, provided that
## the above copyright notice and this permission notice appear in all
## copies.
##
## THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED 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 AUTHORS AND COPYRIGHT HOLDERS AND THEIR
## CONTRIBUTORS 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.
##
# package version
%define V_opkg 1.21.0
%define V_dist 20211107
%define V_python 3.10
# package information
Name: certbot
Summary: Let's Encrypt Client
URL: https://certbot.eff.org/
Vendor: EFF
Packager: OpenPKG Project
Distribution: OpenPKG Community
Class: EVAL
Group: Cryptography
License: Apache
Version: %{V_opkg}
Release: 20211107
# list of sources
Source0: http://download.openpkg.org/components/versioned/certbot/certbot-%{V_dist}.tar.xz
Source1: certbot-issue.sh
Source2: certbot-issue.cf
Source3: certbot.c
Source4: certbot-apache.conf
Source5: certbot-nginx.conf
Source6: certbot-hook-pre-std.sh
Source7: certbot-hook-post-std.sh
Source8: rc.certbot
# build information
BuildPreReq: OpenPKG, openpkg >= 20160101, python
PreReq: OpenPKG, openpkg >= 20160101, python
BuildPreReq: python-setup, python-crypto
PreReq: python-setup, python-crypto
%description
Certbot, Let's Encrypt official client, is a fully-featured,
extensible client for the Let's Encrypt CA (or any other CA that
speaks the ACME protocol) that can automate the tasks of obtaining
certificates and configuring webservers to use them.
%track
prog certbot = {
version = %{V_dist}
url = https://github.com/certbot/certbot/releases
regex = v(\d+\.\d+\.\d+)\.tar\.gz
}
%prep
%setup -q -n certbot
%build
# build the setuid wrapper
cp %{SOURCE certbot.c} .
%{l_shtool} subst %{l_value -s -a} certbot.c
%{l_cc} %{l_cflags} %{l_ldflags} -o certbot.exe certbot.c
%install
# install package
export HOME=`pwd`
%{l_prefix}/bin/python -m pip \
install \
--root=$RPM_BUILD_ROOT \
--prefix=%{l_prefix} \
--isolated \
--ignore-installed \
--no-warn-script-location \
*.whl *.tar.gz
# post-adjust installation
( cd $RPM_BUILD_ROOT%{l_prefix}
# remove problematic files
rm -f lib/python*/site-packages/setuptools/script\ \(dev\).tmpl
rm -f lib/python*/site-packages/setuptools/command/launcher\ manifest.xml
rm -rf lib/python*/site-packages/cryptography
# relocate scripts
mkdir -p lib/certbot
mv lib/python*/site-packages/* lib/certbot/
rm -rf lib/python*
# configure default paths
%{l_shtool} subst \
-e 's;/etc/letsencrypt;%{l_prefix}/etc/letsencrypt;g' \
-e 's;/var/lib/letsencrypt;%{l_prefix}/var/letsencrypt/data;g' \
-e 's;/var/log/letsencrypt;%{l_prefix}/var/letsencrypt/log;g' \
lib/certbot/certbot/compat/misc.py
# relocate binaries
mkdir -p libexec/certbot
mv bin/* libexec/certbot/
for exe in `cd libexec/certbot && ls *`; do
( echo "#!/bin/sh"
echo "PYTHONPATH=\"%{l_prefix}/lib/certbot:%{l_prefix}/lib/python/site-packages\""
echo "export PYTHONPATH"
echo "exec %{l_prefix}/libexec/certbot/$exe \${1+\"\$@\"}"
) >bin/$exe
chmod a+x bin/$exe
done
) || exit $?
# create run-time directories
%{l_shtool} mkdir -f -p -m 755 \
$RPM_BUILD_ROOT%{l_prefix}/etc/apache/apache.d \
$RPM_BUILD_ROOT%{l_prefix}/etc/nginx/nginx.d \
$RPM_BUILD_ROOT%{l_prefix}/etc/certbot/renewal-hooks/pre \
$RPM_BUILD_ROOT%{l_prefix}/etc/certbot/renewal-hooks/post \
$RPM_BUILD_ROOT%{l_prefix}/var/certbot/root \
$RPM_BUILD_ROOT%{l_prefix}/var/certbot/data \
$RPM_BUILD_ROOT%{l_prefix}/var/certbot/log \
$RPM_BUILD_ROOT%{l_prefix}/var/certbot/run
# install wrapper binary
mv $RPM_BUILD_ROOT%{l_prefix}/bin/certbot \
$RPM_BUILD_ROOT%{l_prefix}/libexec/certbot/certbot.sh
%{l_shtool} install -c -s -m 755 \
certbot.exe $RPM_BUILD_ROOT%{l_prefix}/bin/certbot
# install pre/post hook scripts
%{l_shtool} install -c -m 755 %{l_value -s -a} \
%{SOURCE certbot-hook-pre-std.sh} \
$RPM_BUILD_ROOT%{l_prefix}/etc/certbot/renewal-hooks/pre/std.sh
%{l_shtool} install -c -m 755 %{l_value -s -a} \
%{SOURCE certbot-hook-post-std.sh} \
$RPM_BUILD_ROOT%{l_prefix}/etc/certbot/renewal-hooks/post/std.sh
# install helper script
%{l_shtool} install -c -m 755 %{l_value -s -a} \
%{SOURCE certbot-issue.sh} \
$RPM_BUILD_ROOT%{l_prefix}/bin/certbot-issue
%{l_shtool} install -c -m 644 %{l_value -s -a} \
%{SOURCE certbot-issue.cf} \
$RPM_BUILD_ROOT%{l_prefix}/etc/certbot/certbot-issue.cf
# install Apache config
%{l_shtool} install -c -m 644 %{l_value -s -a} \
%{SOURCE certbot-apache.conf} \
$RPM_BUILD_ROOT%{l_prefix}/etc/apache/apache.d/certbot.conf
# install NGINX config
%{l_shtool} install -c -m 644 %{l_value -s -a} \
%{SOURCE certbot-nginx.conf} \
$RPM_BUILD_ROOT%{l_prefix}/etc/nginx/nginx.d/certbot.conf
# install run-command script
%{l_shtool} install -c -m 755 %{l_value -s -a} \
%{SOURCE rc.certbot} $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d/
# determine installation paths
%{l_rpmtool} files -v -ofiles -r$RPM_BUILD_ROOT \
%{l_files_std} \
'%config %{l_prefix}/etc/certbot/*' \
'%attr(4755,%{l_rusr},%{l_rgrp}) %{l_prefix}/bin/certbot' \
'%attr(-,%{l_rusr},%{l_rgrp}) %{l_prefix}/var/certbot/*'
%files -f files
%clean
%post
if [ $1 -eq 1 ]; then
# after install, show hint
( echo "First configure the certbot-issue(8) configuration file:"
echo " \$ vi $RPM_INSTALL_PREFIX/etc/certbot/certbot-issue.cf"
echo "Then perform the initial setup with it:"
echo " \$ $RPM_INSTALL_PREFIX/bin/certbot-issue"
echo "The resulting certificate/private-key you can find under:"
echo " $RPM_INSTALL_PREFIX/var/certbot/data/live/example.com/cert"
echo " $RPM_INSTALL_PREFIX/var/certbot/data/live/example.com/chain"
echo " $RPM_INSTALL_PREFIX/var/certbot/data/live/example.com/privkey"
) | %{l_rpmtool} msg -b -t notice
fi
exit 0
%preun
# before erase, stop service and remove log files
if [ $1 -eq 0 ]; then
rm -rf $RPM_INSTALL_PREFIX/var/certbot/root/* >/dev/null 2>&1 || true
rm -rf $RPM_INSTALL_PREFIX/var/certbot/data/* >/dev/null 2>&1 || true
rm -rf $RPM_INSTALL_PREFIX/var/certbot/run/* >/dev/null 2>&1 || true
rm -rf $RPM_INSTALL_PREFIX/var/certbot/log/* >/dev/null 2>&1 || true
fi
exit 0