2 changed files with 221 additions and 0 deletions
@ -0,0 +1,161 @@
|
||||
## |
||||
## keycloak.spec -- OpenPKG RPM Package Specification |
||||
## Copyright (c) 2000-2019 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 information |
||||
Name: keycloak |
||||
Summary: Authentication Server |
||||
URL: https://www.keycloak.org/ |
||||
Vendor: Red Hat |
||||
Packager: OpenPKG Project |
||||
Distribution: OpenPKG Community |
||||
Class: EVAL |
||||
Group: Database |
||||
License: LGPL |
||||
Version: 5.0.0 |
||||
Release: 20190407 |
||||
|
||||
# list of sources |
||||
Source0: http://downloads.jboss.org/keycloak/%{version}/keycloak-%{version}.tar.gz |
||||
Source1: rc.keycloak |
||||
|
||||
# build information |
||||
BuildPreReq: OpenPKG, openpkg >= 20160101 |
||||
PreReq: OpenPKG, openpkg >= 20160101, java, JAVA-JDK |
||||
|
||||
%description |
||||
Keycloak is an Identity and Access Management solution aimed at |
||||
modern applications and services. It makes it easy to secure |
||||
applications and services with little to no code. |
||||
|
||||
%track |
||||
prog keycloak = { |
||||
version = %{version} |
||||
url = https://www.keycloak.org/downloads.html |
||||
regex = keycloak-(__VER__)\.tar\.gz |
||||
} |
||||
|
||||
%prep |
||||
%setup -q |
||||
|
||||
%build |
||||
# strip down installation files |
||||
rm bin/*.bat bin/*.ps1 bin/*.cli |
||||
rm bin/domain* |
||||
rm -f LICENSE.txt License.html |
||||
rm -rf domain |
||||
rm -rf docs |
||||
rm -f standalone/configuration/standlone-ha.xml |
||||
|
||||
# remove problematic files |
||||
rm -f "themes/keycloak/common/resources/node_modules/rcue/dist/img/Logo_Horizontal_Reversed.svg alias" |
||||
|
||||
%install |
||||
# create installation hierarchy |
||||
%{l_shtool} mkdir -f -p -m 755 \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/sbin \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/etc/rc.d \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/etc/keycloak \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/libexec/keycloak \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/var/keycloak/run \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/var/keycloak/log \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/var/keycloak/tmp \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/var/keycloak/data |
||||
|
||||
# install program |
||||
cp -rp * \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/libexec/keycloak/ |
||||
|
||||
# redirect paths |
||||
( cd $RPM_BUILD_ROOT%{l_prefix}/libexec/keycloak/standalone |
||||
mv configuration/* \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/etc/keycloak/ |
||||
rm -rf configuration |
||||
ln -s ../../../etc/keycloak configuration |
||||
rm -rf data |
||||
ln -s ../../../var/keycloak/data data |
||||
rm -rf log |
||||
ln -s ../../../var/keycloak/log log |
||||
rm -rf tmp |
||||
ln -s ../../../var/keycloak/tmp tmp |
||||
) || exit $? |
||||
|
||||
# provide wrapper scripts |
||||
( echo "#!/bin/sh" |
||||
echo "cd %{l_prefix}/libexec/keycloak/bin" |
||||
echo "exec ./standalone.sh \${1+\"\$@\"}" |
||||
) >$RPM_BUILD_ROOT%{l_prefix}/sbin/keycloak |
||||
chmod 755 $RPM_BUILD_ROOT%{l_prefix}/sbin/keycloak |
||||
( echo "#!/bin/sh" |
||||
echo "cd %{l_prefix}/libexec/keycloak/bin" |
||||
echo "exec ./kcadm.sh \${1+\"\$@\"}" |
||||
) >$RPM_BUILD_ROOT%{l_prefix}/sbin/kcadm |
||||
chmod 755 $RPM_BUILD_ROOT%{l_prefix}/sbin/kcadm |
||||
( echo "#!/bin/sh" |
||||
echo "cd %{l_prefix}/libexec/keycloak/bin" |
||||
echo "exec ./kcreg.sh \${1+\"\$@\"}" |
||||
) >$RPM_BUILD_ROOT%{l_prefix}/sbin/kcreg |
||||
chmod 755 $RPM_BUILD_ROOT%{l_prefix}/sbin/kcreg |
||||
|
||||
# install run-command script |
||||
%{l_shtool} install -c -m 755 %{l_value -s -a} \ |
||||
%{SOURCE rc.keycloak} \ |
||||
$RPM_BUILD_ROOT%{l_prefix}/etc/rc.d/ |
||||
|
||||
# determine installation files |
||||
%{l_rpmtool} files -v -ofiles -r$RPM_BUILD_ROOT \ |
||||
%{l_files_std} \ |
||||
'%attr(-,%{l_rusr},%{l_rgrp}) %dir %{l_prefix}/etc/keycloak' \ |
||||
'%attr(-,%{l_rusr},%{l_rgrp}) %{l_prefix}/etc/keycloak/*' \ |
||||
'%attr(-,%{l_rusr},%{l_rgrp}) %{l_prefix}/var/keycloak/*' |
||||
|
||||
%files -f files |
||||
|
||||
%clean |
||||
|
||||
%post |
||||
if [ $1 -eq 1 ]; then |
||||
# on initial installation, give hints about next steps |
||||
( echo "To complete this installation of Keycloak please start it with" |
||||
echo " \$ $RPM_INSTALL_PREFIX/bin/openpkg rc keycloak start" |
||||
echo "and then visit" |
||||
echo " http://127.0.0.1:8080/" |
||||
echo "and set your admistrator username/password." |
||||
) | %{l_rpmtool} msg -b -t notice |
||||
elif [ $1 -eq 2 ]; then |
||||
# after upgrade, restart service |
||||
eval `%{l_rc} keycloak status 2>/dev/null` |
||||
[ ".$keycloak_active" = .yes ] && %{l_rc} keycloak restart |
||||
fi |
||||
exit 0 |
||||
|
||||
%preun |
||||
if [ $1 -eq 0 ]; then |
||||
# stop service and remove run-time files |
||||
%{l_rc} keycloak stop 2>/dev/null |
||||
rm -f $RPM_INSTALL_PREFIX/var/keycloak/run/* >/dev/null 2>&1 || true |
||||
rm -f $RPM_INSTALL_PREFIX/var/keycloak/log/* >/dev/null 2>&1 || true |
||||
rm -f $RPM_INSTALL_PREFIX/var/keycloak/tmp/* >/dev/null 2>&1 || true |
||||
rm -rf $RPM_INSTALL_PREFIX/var/keycloak/data/* >/dev/null 2>&1 || true |
||||
fi |
||||
exit 0 |
||||
|
@ -0,0 +1,60 @@
|
||||
#!@l_prefix@/bin/openpkg rc |
||||
## |
||||
## rc.keycloak -- Run-Commands |
||||
## |
||||
|
||||
%config |
||||
keycloak_enable="$openpkg_rc_def" |
||||
keycloak_flags="" |
||||
keycloak_log_prolog="true" |
||||
keycloak_log_epilog="true" |
||||
keycloak_log_numfiles="10" |
||||
keycloak_log_minsize="1M" |
||||
keycloak_log_complevel="9" |
||||
|
||||
%common |
||||
keycloak_cfgfile="@l_prefix@/etc/keycloak/keycloak.yaml" |
||||
keycloak_pidfile="@l_prefix@/var/keycloak/run/keycloak.pid" |
||||
keycloak_logfile="@l_prefix@/var/keycloak/log/keycloak.log" |
||||
keycloak_signal () { |
||||
[ -f $keycloak_pidfile ] && kill -$1 `cat $keycloak_pidfile` |
||||
} |
||||
|
||||
%status -u @l_rusr@ -o |
||||
keycloak_usable="unknown" |
||||
keycloak_active="no" |
||||
rcService keycloak enable yes && \ |
||||
keycloak_signal 0 && keycloak_active="yes" |
||||
echo "keycloak_enable=\"$keycloak_enable\"" |
||||
echo "keycloak_usable=\"$keycloak_usable\"" |
||||
echo "keycloak_active=\"$keycloak_active\"" |
||||
|
||||
%start -u @l_rusr@ |
||||
rcService keycloak enable yes || exit 0 |
||||
rcService keycloak active yes && exit 0 |
||||
( nohup @l_prefix@/sbin/keycloak $keycloak_flags \ |
||||
</dev/null >>$keycloak_logfile 2>&1 & |
||||
echo $! >$keycloak_pidfile |
||||
) >/dev/null 2>&1 |
||||
|
||||
%stop -u @l_rusr@ |
||||
rcService keycloak enable yes || exit 0 |
||||
rcService keycloak active no && exit 0 |
||||
keycloak_signal TERM |
||||
sleep 2 |
||||
rm -f $keycloak_pidfile >/dev/null 2>&1 || true |
||||
|
||||
%restart -u @l_rusr@ |
||||
rcService keycloak enable yes || exit 0 |
||||
rcService keycloak active no && exit 0 |
||||
rc keycloak stop start |
||||
|
||||
%daily -u @l_susr@ |
||||
rcService keycloak enable yes || exit 0 |
||||
shtool rotate -f \ |
||||
-n $keycloak_log_numfiles -s $keycloak_log_minsize -d \ |
||||
-z $keycloak_log_complevel -m 664 -o @l_rusr@ -g @l_rgrp@ \ |
||||
-P "$keycloak_log_prolog" \ |
||||
-E "$keycloak_log_epilog; rc keycloak reload" \ |
||||
$keycloak_logfile |
||||
|
Loading…
Reference in new issue