diff options
Diffstat (limited to 'eclass/webapp.eclass')
-rw-r--r-- | eclass/webapp.eclass | 177 |
1 files changed, 104 insertions, 73 deletions
diff --git a/eclass/webapp.eclass b/eclass/webapp.eclass index 574b461b6a01..c34803d608c8 100644 --- a/eclass/webapp.eclass +++ b/eclass/webapp.eclass @@ -1,6 +1,6 @@ -# Copyright 1999-2006 Gentoo Foundation +# Copyright 1999-2011 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/eclass/webapp.eclass,v 1.64 2010/05/09 22:32:16 darkside Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/webapp.eclass,v 1.65 2011/05/19 12:03:41 scarabeus Exp $ # @ECLASS: webapp.eclass # @MAINTAINER: @@ -10,26 +10,37 @@ # The webapp eclass contains functions to handle web applications with # webapp-config. Part of the implementation of GLEP #11 +# @ECLASS-VARIABLE: WABAPP_MINIMAL +# @DESCRIPTION: +# Minimal version of webapp-config the package requires for sucessfull install. +: ${WEBAPP_MINIMAL:=1.50.15} + # @ECLASS-VARIABLE: WEBAPP_DEPEND # @DESCRIPTION: # An ebuild should use WEBAPP_DEPEND if a custom DEPEND needs to be built, most # notably in combination with WEBAPP_OPTIONAL. -WEBAPP_DEPEND=">=app-admin/webapp-config-1.50.15" +: ${WEBAPP_DEPEND:=">=app-admin/webapp-config-${WEBAPP_MINIMAL}"} -# @ECLASS-VARIABLE: WEBAPP_NO_AUTO_INSTALL +# @ECLASS-VARIABLE: WEBAPP_AUTO_INSTALL # @DESCRIPTION: -# An ebuild sets this to `yes' if an automatic installation and/or upgrade is +# An ebuild sets this to `no' if an automatic installation and/or upgrade is # not possible. The ebuild should overwrite pkg_postinst() and explain the # reason for this BEFORE calling webapp_pkg_postinst(). +: ${WEBAPP_AUTO_INSTALL:=yes} +if [[ -n ${WEBAPP_NO_AUTO_INSTALL} ]]; then + WEBAPP_AUTO_INSTALL=no + ewarn "QA: using deprecated variable \"WEBAPP_NO_AUTO_INSTALL\"." + ewarn "QA: please migrate to WEBAPP_AUTO_INSTALL with inverse logic" + ewarn "QA: that defaults to yes." +fi # @ECLASS-VARIABLE: WEBAPP_OPTIONAL # @DESCRIPTION: # An ebuild sets this to `yes' to make webapp support optional, in which case # you also need to take care of USE-flags and dependencies. - -if [[ "${WEBAPP_OPTIONAL}" != "yes" ]]; then - [[ "${WEBAPP_NO_AUTO_INSTALL}" == "yes" ]] || IUSE="vhosts" - SLOT="${PVR}" +if [[ ${WEBAPP_OPTIONAL} != yes ]]; then + [[ ${WEBAPP_AUTO_INSTALL} == yes ]] && IUSE="vhosts" + : ${SLOT:=${PVR}} DEPEND="${WEBAPP_DEPEND}" RDEPEND="${DEPEND}" fi @@ -56,22 +67,18 @@ WEBAPP_CLEANER="${ROOT}usr/sbin/webapp-cleaner" webapp_read_config() { debug-print-function $FUNCNAME $* - if has_version '>=app-admin/webapp-config-1.50'; then - ENVVAR=$(${WEBAPP_CONFIG} --query ${PN} ${PVR}) || die "Could not read settings from webapp-config!" - eval ${ENVVAR} - else - . ${ETC_CONFIG} || die "Unable to read ${ETC_CONFIG}" - fi + ENVVAR=$(${WEBAPP_CONFIG} --query ${PN} ${PVR}) || die "Could not read settings from webapp-config!" + eval ${ENVVAR} || die } # Check whether a specified file exists in the given directory (`.' by default) webapp_checkfileexists() { debug-print-function $FUNCNAME $* - local my_prefix=${2:+${2}/} + local msg my_prefix=${2:+${2}/} if [[ ! -e "${my_prefix}${1}" ]]; then - msg="ebuild fault: file '${1}' not found" + msg="ebuild error: file '${1}' not found" eerror "$msg" eerror "Please report this as a bug at http://bugs.gentoo.org/" die "$msg" @@ -101,19 +108,20 @@ webapp_strip_cwd() { webapp_getinstalltype() { debug-print-function $FUNCNAME $* + local my_output my_pn my_pvr + if ! has vhosts ${IUSE} || use vhosts; then return fi - local my_output my_output="$(webapp_check_installedat)" if [[ $? -eq 0 ]]; then # something is already installed there # make sure it isn't the same version - local my_pn="$(echo ${my_output} | awk '{ print $1 }')" - local my_pvr="$(echo ${my_output} | awk '{ print $2 }')" + my_pn="$(echo ${my_output} | awk '{ print $1 }')" + my_pvr="$(echo ${my_output} | awk '{ print $2 }')" REMOVE_PKG="${my_pn}-${my_pvr}" @@ -133,6 +141,18 @@ webapp_getinstalltype() { fi } +# helper for webapp_serverowned() +_webapp_serverowned() { + debug-print-function $FUNCNAME $* + + webapp_checkfileexists "${1}" "${D}" + local my_file="$(webapp_strip_appdir "${1}")" + my_file="$(webapp_strip_cwd "${my_file}")" + + elog "(server owned) ${my_file}" + echo "${my_file}" >> "${D}/${WA_SOLIST}" +} + # ============================================================================== # PUBLIC FUNCTIONS # ============================================================================== @@ -171,6 +191,8 @@ need_httpd_fastcgi() { webapp_configfile() { debug-print-function $FUNCNAME $* + [[ $# -lt 1 ]] && die "${FUNCNAME}: I require at least 1 argument. Please read eclass documentation." + local m for m in "$@"; do webapp_checkfileexists "${m}" "${D}" @@ -178,62 +200,75 @@ webapp_configfile() { local my_file="$(webapp_strip_appdir "${m}")" my_file="$(webapp_strip_cwd "${my_file}")" - elog "(config) ${my_file}" + elog "[webapp-config] ${my_file}" echo "${my_file}" >> ${D}/${WA_CONFIGLIST} done } # @FUNCTION: webapp_hook_script -# @USAGE: <file> +# @USAGE: <file> [more files ...] # @DESCRIPTION: # Install a script that will run after a virtual copy is created, and # before a virtual copy has been removed. webapp_hook_script() { debug-print-function $FUNCNAME $* - webapp_checkfileexists "${1}" + [[ $# -lt 1 ]] && die "${FUNCNAME}: I require at least 1 argument. Please read eclass documentation." + + local m + for m in "$@"; do + webapp_checkfileexists "${m}" - elog "(hook) ${1}" - cp "${1}" "${D}/${MY_HOOKSCRIPTSDIR}/$(basename "${1}")" || die "Unable to install ${1} into ${D}/${MY_HOOKSCRIPTSDIR}/" - chmod 555 "${D}/${MY_HOOKSCRIPTSDIR}/$(basename "${1}")" + elog "[webapp-hook] ${m}" + cp "${1}" "${D}/${MY_HOOKSCRIPTSDIR}/$(basename "${1}")" || die "Unable to install ${1} into \"${D}/${MY_HOOKSCRIPTSDIR}/\"" + chmod 555 "${D}/${MY_HOOKSCRIPTSDIR}/$(basename "${1}")" + done } # @FUNCTION: webapp_postinst_txt -# @USAGE: <lang> <file> +# @USAGE: <lang> <file> [more files ...] # @DESCRIPTION: # Install a text file containing post-installation instructions. webapp_postinst_txt() { debug-print-function $FUNCNAME $* - webapp_checkfileexists "${2}" + local lang m - elog "(info) ${2} (lang: ${1})" - cp "${2}" "${D}/${MY_APPDIR}/postinst-${1}.txt" + [[ $# -lt 2 ]] && die "${FUNCNAME}: I require at least 2 arguments. Please read eclass documentation." + + lang=${1} + shift + + local m + for m in "$@"; do + webapp_checkfileexists "${m}" + + elog "[webapp-info] \"${m}\" (lang: ${lang})" + cp "${m}" "${D}/${MY_APPDIR}/${m}-postinst-${lang}.txt" || die + done } # @FUNCTION: webapp_postupgrade_txt -# @USAGE: <lang> <file> +# @USAGE: <lang> <file> [more files ...] # @DESCRIPTION: # Install a text file containing post-upgrade instructions. webapp_postupgrade_txt() { debug-print-function $FUNCNAME $* - webapp_checkfileexists "${2}" + local lang m - elog "(info) ${2} (lang: ${1})" - cp "${2}" "${D}/${MY_APPDIR}/postupgrade-${1}.txt" -} + [[ $# -lt 2 ]] && die "${FUNCNAME}: I require at least 2 arguments. Please read eclass documentation." -# helper for webapp_serverowned() -_webapp_serverowned() { - debug-print-function $FUNCNAME $* + lang=${1} + shift - webapp_checkfileexists "${1}" "${D}" - local my_file="$(webapp_strip_appdir "${1}")" - my_file="$(webapp_strip_cwd "${my_file}")" + local m + for m in "$@"; do + webapp_checkfileexists "${m}" - elog "(server owned) ${my_file}" - echo "${my_file}" >> "${D}/${WA_SOLIST}" + elog "[webapp-info] \"${m}\" (lang: ${lang})" + cp "${m}" "${D}/${MY_APPDIR}/${m}-postupgrade-${lang}.txt" || die + done } # @FUNCTION: webapp_serverowned @@ -271,6 +306,8 @@ webapp_serverowned() { webapp_server_configfile() { debug-print-function $FUNCNAME $* + [[ $# -lt 2 ]] && die "${FUNCNAME}: I require at least 2 arguments. Please read eclass documentation." + webapp_checkfileexists "${2}" # WARNING: @@ -280,7 +317,7 @@ webapp_server_configfile() { local my_file="${1}-${3:-$(basename "${2}")}" - elog "(${1}) config file '${my_file}'" + elog "[webapp] Server \"${1}\" config file \"${my_file}\"" cp "${2}" "${D}/${MY_SERVERCONFIGDIR}/${my_file}" } @@ -294,23 +331,23 @@ webapp_server_configfile() { webapp_sqlscript() { debug-print-function $FUNCNAME $* - webapp_checkfileexists "${2}" + [[ $# -lt 2 ]] && die "${FUNCNAME}: I require at least 2 arguments. Please read eclass documentation." - dodir "${MY_SQLSCRIPTSDIR}/${1}" + webapp_checkfileexists "${2}" # WARNING: # # do NOT change the naming convention used here without changing all # the other scripts that also rely upon these names - if [[ -n "${3}" ]]; then - elog "(${1}) upgrade script for ${PN}-${3} to ${PVR}" - cp "${2}" "${D}${MY_SQLSCRIPTSDIR}/${1}/${3}_to_${PVR}.sql" - chmod 600 "${D}${MY_SQLSCRIPTSDIR}/${1}/${3}_to_${PVR}.sql" + insinto "${MY_SQLSCRIPTSDIR}/${1}" + insopts -m0600 + if [[ -n ${3} ]]; then + elog "[webapp] DB: \"${1}\" upgrade script for ${PN}-${3} to ${PVR}" + newins "${2}" "${3}_to_${PVR}.sql" || die else - elog "(${1}) create script for ${PN}-${PVR}" - cp "${2}" "${D}/${MY_SQLSCRIPTSDIR}/${1}/${PVR}_create.sql" - chmod 600 "${D}/${MY_SQLSCRIPTSDIR}/${1}/${PVR}_create.sql" + elog "[webapp] DB: \"${1}\" create script for ${PN}-${PVR}" + newins "${2}" "${PVR}_create.sql" fi } @@ -322,7 +359,7 @@ webapp_src_preinst() { debug-print-function $FUNCNAME $* # sanity checks, to catch bugs in the ebuild - if [[ ! -f "${T}/${SETUP_CHECK_FILE}" ]]; then + if [[ ! -f ${T}/${SETUP_CHECK_FILE} ]]; then eerror eerror "This ebuild did not call webapp_pkg_setup() at the beginning" eerror "of the pkg_setup() function" @@ -371,9 +408,8 @@ webapp_pkg_setup() { touch "${T}/${SETUP_CHECK_FILE}" # special case - some ebuilds *do* need to overwride the SLOT - if [[ "${SLOT}+" != "${PVR}+" && "${WEBAPP_MANUAL_SLOT}" != "yes" ]]; then + [[ ${SLOT} != ${PVR} && ${WEBAPP_MANUAL_SLOT} != yes ]] && \ die "Set WEBAPP_MANUAL_SLOT=\"yes\" if you need to SLOT manually" - fi # pull in the shared configuration file G_HOSTNAME="localhost" @@ -391,17 +427,14 @@ webapp_pkg_setup() { if [[ $? -ne 0 ]]; then # okay, whatever is there, it isn't webapp-config-compatible - echo ewarn ewarn "You already have something installed in ${my_dir}" ewarn - ewarn "Whatever is in ${my_dir}, it's not" + ewarn "Whatever is in \"${my_dir}\", it's not" ewarn "compatible with webapp-config." ewarn ewarn "This ebuild may be overwriting important files." ewarn - echo - ebeep 10 elif [[ "$(echo ${my_output} | awk '{ print $1 }')" != "${PN}" ]]; then echo eerror "You already have ${my_output} installed in ${my_dir}" @@ -411,7 +444,6 @@ webapp_pkg_setup() { echo die "Cannot upgrade contents of ${my_dir}" fi - } # @FUNCTION: webapp_src_install @@ -479,23 +511,22 @@ webapp_pkg_postinst() { local my_mode=-I webapp_getinstalltype - if [[ "${IS_REPLACE}" == "1" ]]; then - elog "${PN}-${PVR} is already installed - replacing" - my_mode=-I - elif [[ "${IS_UPGRADE}" == "1" ]]; then - elog "${REMOVE_PKG} is already installed - upgrading" + if [[ ${IS_REPLACE} == 1 ]]; then + elog "[webapp] ${PN}-${PVR} is already installed - replacing" + elif [[ ${IS_UPGRADE} == 1 ]]; then + elog "[webapp] ${REMOVE_PKG} is already installed - upgrading" my_mode=-U else - elog "${PN}-${PVR} is not installed - using install mode" + elog "[webapp] ${PN}-${PVR} is not installed - using install mode" fi my_cmd="${WEBAPP_CONFIG} ${my_mode} -h localhost -u root -d ${INSTALL_DIR} ${PN} ${PVR}" - elog "Running ${my_cmd}" + elog "[webapp] Running ${my_cmd}" ${my_cmd} echo local cleaner="${WEBAPP_CLEANER} -p -C ${PN}" - einfo "Running ${cleaner}" + einfo "[webapp] Running ${cleaner}" ${cleaner} else elog @@ -544,10 +575,10 @@ webapp_pkg_prerm() { ${WEBAPP_CONFIG} -C -h ${WEB_HOSTNAME} -d ${WEB_INSTALLDIR} fi else - ewarn "Cannot find file ${x}/.webapp" + ewarn "[webapp] Cannot find file ${x}/.webapp" fi done - elif [[ "${my_output}" != "" ]]; then + elif [[ -n ${my_output} ]]; then echo ewarn ewarn "Don't forget to use webapp-config to remove any copies of" @@ -556,9 +587,9 @@ webapp_pkg_prerm() { echo "${my_output}" | while read x; do if [[ -f "${x}"/.webapp ]]; then - ewarn " ${x}" + ewarn "[webapp] ${x}" else - ewarn "Cannot find file ${x}/.webapp" + ewarn "[webapp] Cannot find file ${x}/.webapp" fi done |