# Copyright 1999-2019 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 EAPI="6" PYTHON_COMPAT=( python2_7 ) PYTHON_REQ_USE="threads" CMAKE_WARN_UNUSED_CLI=yes #CMAKE_REMOVE_MODULES=yes inherit eutils multilib python-single-r1 systemd user cmake-utils DESCRIPTION="Featureful client/server network backup suite" HOMEPAGE="http://www.bareos.org/" SRC_URI="https://github.com/${PN}/${PN}/archive/Release/${PV}.tar.gz -> ${P}.tar.gz" RESTRICT="mirror" LICENSE="AGPL-3" SLOT="0" KEYWORDS="~amd64 ~x86" IUSE="X acl cephfs clientonly +director fastlz glusterfs gnutls ipv6 jansson lmdb libressl logwatch mysql ndmp +postgres python rados rados-striper readline scsi-crypto sql-pooling sqlite ssl static +storage-daemon tcpd vim-syntax" REQUIRED_USE="!clientonly? ( || ( mysql postgres sqlite ) )" DEPEND=" !app-backup/bacula cephfs? ( sys-cluster/ceph ) rados? ( sys-cluster/ceph ) rados-striper? ( >=sys-cluster/ceph-0.94.2 ) glusterfs? ( sys-cluster/glusterfs ) lmdb? ( dev-db/lmdb ) dev-libs/gmp:0 !clientonly? ( postgres? ( dev-db/postgresql:*[threads] ) mysql? ( virtual/mysql ) sqlite? ( dev-db/sqlite:3 ) director? ( virtual/mta jansson? ( dev-libs/jansson ) ) ) fastlz? ( dev-libs/bareos-fastlzlib ) logwatch? ( sys-apps/logwatch ) tcpd? ( sys-apps/tcp-wrappers ) readline? ( sys-libs/readline:0 ) static? ( acl? ( virtual/acl[static-libs] ) sys-libs/zlib[static-libs] dev-libs/lzo[static-libs] sys-libs/ncurses:=[static-libs] ssl? ( !gnutls? ( !libressl? ( dev-libs/openssl:0=[static-libs] ) libressl? ( dev-libs/libressl:0=[static-libs] ) ) gnutls? ( net-libs/gnutls[static-libs] ) ) ) !static? ( acl? ( virtual/acl ) dev-libs/lzo ssl? ( !gnutls? ( !libressl? ( dev-libs/openssl:0= ) libressl? ( dev-libs/libressl:0= ) ) gnutls? ( net-libs/gnutls ) ) sys-libs/ncurses:= sys-libs/zlib ) python? ( ${PYTHON_DEPS} ) " RDEPEND="${DEPEND} !clientonly? ( storage-daemon? ( sys-block/mtx app-arch/mt-st ) ) vim-syntax? ( || ( app-editors/vim app-editors/gvim ) )" REQUIRED_USE="static? ( clientonly ) python? ( ${PYTHON_REQUIRED_USE} )" S=${WORKDIR}/${PN}-Release-${PV} pkg_setup() { # create the daemon group and user if [ -z "$(egetent group bareos 2>/dev/null)" ]; then enewgroup bareos einfo einfo "The group 'bareos' has been created. Any users you add to this" einfo "group have access to files created by the daemons." einfo fi if ! use clientonly; then if [ -z "$(egetent passwd bareos 2>/dev/null)" ]; then enewuser bareos -1 -1 /var/lib/bareos bareos,tape,cdrom,cdrw einfo einfo "The user 'bareos' has been created. Please see the bareos manual" einfo "for information about running bareos as a non-root user." einfo fi fi use python && python-single-r1_pkg_setup } src_prepare() { use mysql && export mydbtypes+=( mysql ) use postgres && export mydbtypes+=( postgresql ) use sqlite && export mydbtypes+=( sqlite ) # enables default database driver in catalog pushd core/src/defaultconfigs >&/dev/null || die sed -i -e 's/#dbdriver/dbdriver/' -e '/XXX_REPLACE_WITH_DATABASE_DRIVER_XXX/d' $(grep -rl XXX_REPLACE_WITH_DATABASE_DRIVER_XXX) \ || die "sed on MyCatalog.conf.in failed" popd >&/dev/null || die epatch "${FILESDIR}/bareos-cmake-rados.patch" # fix gentoo version detection epatch "${FILESDIR}/bareos-cmake-gentoo.patch" # fix missing DESTDIR in symlink creation epatch "${FILESDIR}/bareos-cmake-symlink-default-db-backend.patch" eapply_user CMAKE_USE_DIR="$S/core" cmake-utils_src_prepare } src_configure() { local mycmakeargs=() CMAKE_USE_DIR="$S/core" pushd core/platforms >&/dev/null || die cmake_comment_add_subdirectory '${DISTNAME}' popd >&/dev/null || die if use clientonly; then mycmakeargs+=( -Dclient-only=YES -Dstatic-cons=$(usex static) -Dstatic-fd=$(usex static) ) fi for useflag in acl ipv6 ndmp readline scsi-crypto sql-pooling \ fastlz mysql python lmdb glusterfs rados \ rados-striper cephfs jansson; do mycmakeargs+=( -D$useflag=$(usex $useflag) ) done mycmakeargs+=( -DDEFAULT_DB_TYPE=${mydbtypes[0]} -Dx=$(usex X) -Dpostgresql=$(usex postgres) -Dmysql=$(usex mysql) -Dsqlite3=$(usex sqlite) -Dopenssl=$(usex ssl) -Dtcp-wrapper=$(usex tcpd) -Dlibdir=/usr/$(get_libdir) -Dsbindir=/usr/sbin -Dmandir=/usr/share/man -Ddocdir=/usr/share/doc/${PF} -Dhtmldir=/usr/share/doc/${PF}/html -Darchivedir=/var/lib/bareos/storage -Dbsrdir=/var/lib/bareos/bsr -Dpiddir=/run/bareos -Dsysconfdir=/etc -Dconfdir=/etc/bareos -Dsubsys-dir=/run/lock/subsys -Dworkingdir=/var/lib/bareos -Dlogdir=/var/log/bareos -Dscriptdir=/usr/libexec/bareos -Dplugindir=/usr/$(get_libdir)/${PN}/plugin -Dbackenddir=/usr/$(get_libdir)/${PN}/backend -Ddir-user=bareos -Ddir-group=bareos -Dsd-user=root -Dsd-group=bareos -Dfd-user=root -Dfd-group=bareos -Dsbin-perm=0755 -Dsystemd=yes -Ddb_password=`cat /dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 16 | head -n 1` -Ddynamic-cats-backends=yes -Ddynamic-storage-backends=yes -Dbatch-insert=yes -Dhost=${CHOST} -Dcoverage=yes -Dpython=yes -Dsmartalloc=yes -Ddir-password="`cat /dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 32 | head -n 1`" -Dfd-password="`cat /dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 32 | head -n 1`" -Dsd-password="`cat /dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 32 | head -n 1`" -Dmon-dir-password="`cat /dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 32 | head -n 1`" -Dmon-fd-password="`cat /dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 32 | head -n 1`" -Dmon-sd-password="`cat /dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 32 | head -n 1`" -Dbasename="`hostname -s`" -Dhostname="`hostname -s`" ) cmake-utils_src_configure } src_install() { #emake DESTDIR="${D}" install cmake-utils_src_install newicon core/src/images/bareos_logo_shadow.png bareos.png # remove some scripts we don't need at all rm -f "${D}"/usr/libexec/bareos/{bareos,bareos-ctl-dir,bareos-ctl-fd,bareos-ctl-sd,startmysql,stopmysql} rm -f "${D}"/usr/sbin/bareos # remove upstream init scripts rm -f "${D}"/etc/init.d/bareos-* # rename statically linked apps if use clientonly && use static ; then pushd "${D}"/usr/sbin || die mv static-bareos-fd bareos-fd || die mv static-bconsole bconsole || die popd || die fi # extra files which 'make install' doesn't cover if ! use clientonly; then # the logrotate configuration # (now unconditional wrt bug #258187) diropts -m0755 insinto /etc/logrotate.d insopts -m0644 newins "${S}"/core/scripts/logrotate bareos # the logwatch scripts if use logwatch; then diropts -m0750 dodir /etc/log.d/scripts/services dodir /etc/log.d/scripts/shared dodir /etc/log.d/conf/logfiles dodir /etc/log.d/conf/services pushd "${S}"/core/scripts/logwatch >&/dev/null || die into /etc/log.d/scripts/services dobin bareos into /etc/log.d/scripts/shared dobin applybareosdate insinto /etc/log.d/conf/logfiles newins logfile.bareos.conf bareos.conf insinto /etc/log.d/conf/services newins services.bareos.conf bareos.conf popd >&/dev/null || die fi fi rm -vf "${D}"/usr/share/man/man1/bareos-bwxconsole.1* if use clientonly || ! use director; then rm -vf "${D}"/lib/systemd/system/bareos-dir.service rm -vf "${D}"/usr/share/man/man8/bareos-dir.8* rm -vf "${D}"/usr/share/man/man8/bareos-dbcheck.8* rm -vf "${D}"/usr/share/man/man1/bsmtp.1* rm -vf "${D}"/usr/share/man/man8/bwild.8* rm -vf "${D}"/usr/share/man/man8/bregex.8* rm -vf "${D}"/usr/share/man/man8/bpluginfo.8* rm -vf "${D}"/usr/libexec/bareos/create_*_database rm -vf "${D}"/usr/libexec/bareos/drop_*_database rm -vf "${D}"/usr/libexec/bareos/make_*_tables rm -vf "${D}"/usr/libexec/bareos/update_*_tables rm -vf "${D}"/usr/libexec/bareos/drop_*_tables rm -vf "${D}"/usr/libexec/bareos/grant_*_privileges rm -vf "${D}"/usr/libexec/bareos/*_catalog_backup fi if use clientonly || ! use storage-daemon; then rm -vf "${D}"/lib/systemd/system/bareos-sd.service rm -vf "${D}"/usr/share/man/man8/bareos-sd.8* rm -vf "${D}"/usr/share/man/man8/bcopy.8* rm -vf "${D}"/usr/share/man/man8/bextract.8* rm -vf "${D}"/usr/share/man/man8/bls.8* rm -vf "${D}"/usr/share/man/man8/bscan.8* rm -vf "${D}"/usr/share/man/man8/btape.8* rm -vf "${D}"/usr/libexec/bareos/disk-changer rm -vf "${D}"/usr/libexec/bareos/mtx-changer rm -vf "${D}"/usr/libexec/bareos/dvd-handler rm -vf "${D}"/etc/bareos/mtx-changer.conf fi if ! use scsi-crypto; then rm -vf "${D}"/usr/share/man/man8/bscrypto.8* fi # documentation dodoc README.md dodoc core/README.configsubdirectories use glusterfs dodoc core/README.glusterfs use ndmp && dodoc core/README.NDMP use scsi-crypto && dodoc core/README.scsicrypto # vim-files if use vim-syntax; then insinto /usr/share/vim/vimfiles/syntax doins core/scripts/bareos.vim insinto /usr/share/vim/vimfiles/ftdetect newins core/scripts/filetype.vim bareos_ft.vim fi # setup init scripts myscripts="bareos-fd" if ! use clientonly; then if use director; then myscripts+=" bareos-dir" fi if use storage-daemon; then myscripts+=" bareos-sd" fi fi for script in ${myscripts}; do # copy over init script and config to a temporary location # so we can modify them as needed cp "${FILESDIR}/${script}".confd "${T}/${script}".confd || die "failed to copy ${script}.confd" cp "${FILESDIR}/${script}".initd "${T}/${script}".initd || die "failed to copy ${script}.initd" # now set the database dependency for the director init script case "${script}" in bareos-dir) sed -i -e "s:%databasetypes%:${mydbtypes[*]}:" "${T}/${script}".confd || die ;; *) ;; esac # install init script and config newinitd "${T}/${script}".initd "${script}" newconfd "${T}/${script}".confd "${script}" done # install systemd unit files if ! use clientonly; then use director && systemd_dounit core/platforms/systemd/bareos-dir.service use storage-daemon && systemd_dounit core/platforms/systemd/bareos-sd.service fi systemd_dounit core/platforms/systemd/bareos-fd.service # make sure the working directory exists diropts -m0750 keepdir /var/lib/bareos keepdir /var/lib/bareos/storage diropts -m0755 keepdir /var/log/bareos # make sure bareos group can execute bareos libexec scripts fowners -R root:bareos /usr/libexec/bareos } pkg_postinst() { if use clientonly; then fowners root:bareos /var/lib/bareos else fowners bareos:bareos /var/lib/bareos fi if ! use clientonly && use director; then einfo einfo "If this is a new install, you must create the database:" if use postgres; then einfo einfo "For postgresql:" einfo " su postgres -c '/usr/libexec/bareos/create_bareos_database postgresql'" einfo " su postgres -c '/usr/libexec/bareos/make_bareos_tables postgresql'" einfo " su postgres -c '/usr/libexec/bareos/grant_bareos_privileges postgresql'" fi if use mysql; then einfo einfo "For mysql:" einfo einfo " Make sure root has direct access to your mysql server. You may want to" einfo " create a /root/.my.cnf file with" einfo " [client]" einfo " user=root" einfo " password=YourPasswordForAccessingMysqlAsRoot" einfo " before running:" einfo " /usr/libexec/bareos/create_bareos_database mysql" einfo " /usr/libexec/bareos/make_bareos_tables mysql" einfo " /usr/libexec/bareos/grant_bareos_privileges mysql" fi einfo fi if use sqlite; then einfo einfo "Be aware that Bareos does not officially support SQLite database." einfo "Best use it only for a client-only installation. See Bug #445540." einfo einfo "It is strongly recommended to use either postgresql or mysql as" einfo "catalog database backend." einfo fi }