X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=bacula.spec;h=f26d35e04aaaf1a2bb912dbbf17a0f73005dc057;hb=9a766d733dfb933614b85ce9501f805a40a088fe;hp=7c573f47bbcb77e7b8ec05fbe727cc36e227bfe7;hpb=8ba087a4d4f29638b267c46b2a6c4033ba132446;p=packages%2Fbacula.git diff --git a/bacula.spec b/bacula.spec index 7c573f4..f26d35e 100644 --- a/bacula.spec +++ b/bacula.spec @@ -1,86 +1,41 @@ # TODO: -# - update desktop files, think about su-wrappers for console -# - package web admin +# - update desktop files, think about su-wrappers for console (with .desktop files) # - fix log file permissions -# /usr/lib64/bacula/bacula-ctl-dir -# /usr/lib64/bacula/bacula-ctl-fd -# /usr/lib64/bacula/bacula-ctl-sd -# /usr/lib64/bacula/bacula_config -# /usr/lib64/bacula/update_sqlite_tables_10_to_11.in -# /usr/lib64/bacula/update_sqlite_tables_4_to_5 -# /usr/lib64/bacula/update_sqlite_tables_5_to_6 -# /usr/lib64/bacula/update_sqlite_tables_6_to_7 -# /usr/lib64/bacula/update_sqlite_tables_7_to_8 -# /usr/lib64/bacula/update_sqlite_tables_8_to_9 -# /usr/lib64/bacula/update_sqlite_tables_9_to_10.in -# /usr/lib64/bpipe-fd.so -# /usr/lib64/libbac.la -# /usr/lib64/libbac.so -# /usr/lib64/libbaccfg.la -# /usr/lib64/libbaccfg.so -# /usr/lib64/libbacfind.la -# /usr/lib64/libbacfind.so -# /usr/lib64/libbacpy.la -# /usr/lib64/libbacpy.so -# /usr/lib64/libbacsql.la -# /usr/lib64/libbacsql.so -# /usr/sbin/bacula -# /usr/share/man/man1/bat.1.gz -# +# - check on upgrade (5.0 and 5.2 databases are NOT compatible) # # Conditional build: %bcond_without console_wx # wx-console program +%if "%{pld_release}" == "ac" +%bcond_with bat # bat Qt4 GUI +%else %bcond_without bat # bat Qt4 GUI -%bcond_without dbi # use Database Independent Abstraction Layer (libdbi) -%bcond_with mysql # use MySQL -%bcond_with pgsql # use PostgreSQL -%bcond_with python +%endif +%bcond_without mysql # use MySQL +%bcond_without pgsql # use PostgreSQL +%bcond_without sqlite3 # use SQLite3 +%bcond_without python # Python Scripting support, http://www.bacula.org/3.0.x-manuals/en/concepts/concepts/Python_Scripting.html +%bcond_without nagios # build nagios plugin %bcond_with rescue -%bcond_with sqlite3 # use SQLite3 instead of SQLite 2 %bcond_with sqlite3_sync_off # makes SQLite3 backend much faster, but less reliable -%if %{with dbi} -%define database dbi -%undefine with_mysql -%undefine with_pgsql -%undefine with_sqlite3 -%endif -%if %{with sqlite3} -%define database sqlite3 -%undefine with_dbi -%undefine with_mysql -%undefine with_pgsql -%endif -%if %{with pgsql} -%define database postgresql -%undefine with_dbi -%undefine with_mysql -%undefine with_sqlite3 -%endif -%if %{with mysql} -%define database mysql -%undefine with_dbi -%undefine with_pgsql -%undefine with_sqlite3 -%endif %if %{without sqlite3} %undefine with_sqlite3_sync_off %endif -# + +%define qtver 4.6.2 Summary: Bacula - The Network Backup Solution Summary(pl.UTF-8): Bacula - rozwiązanie do wykonywania kopii zapasowych po sieci Name: bacula -Version: 5.0.1 -Release: 0.1 -Epoch: 0 -License: extended GPL v2 +Version: 5.2.12 +Release: 1 +License: AGPL v3 Group: Networking/Utilities Source0: http://downloads.sourceforge.net/bacula/%{name}-%{version}.tar.gz -# Source0-md5: beb9f8da196b3c9ffb0356f087dbdb99 +# Source0-md5: b04c22b128b73359e4bbc9de06652c38 Source1: http://downloads.sourceforge.net/bacula/%{name}-docs-%{version}.tar.bz2 -# Source1-md5: ce2ef0dca50ab916fd6701b53b7bb4df -Source2: http://downloads.sourceforge.net/bacula/%{name}-rescue-5.0.0.tar.gz -# Source2-md5: 349623581cfe0bcd798dd137abac959a +# Source1-md5: 909b85db6da2dbe6b1099688ad4ec7c3 +Source2: http://downloads.sourceforge.net/bacula/%{name}-rescue-5.0.1.tar.gz +# Source2-md5: bb194aed8e204f54bf2f61d7e721f257 Source10: %{name}-dir.init Source11: %{name}-fd.init Source12: %{name}-sd.init @@ -88,49 +43,65 @@ Source13: %{name}.logrotate Source14: %{name}-dir.sysconfig Source15: %{name}-fd.sysconfig Source16: %{name}-sd.sysconfig +Source17: %{name}-dir.service +Source18: %{name}-fd.service +Source19: %{name}-sd.service Patch0: %{name}-mtx-changer.patch -Patch1: %{name}-link.patch -Patch2: %{name}-tinfo-readline.patch -Patch3: %{name}-branding.patch -Patch4: %{name}-conf.patch -Patch5: %{name}-desktop.patch -Patch6: %{name}-64bitbuild_fix.patch -Patch7: %{name}-dbi_fixes.patch +Patch1: %{name}-branding.patch +Patch2: %{name}-conf.patch +Patch3: %{name}-desktop.patch +Patch4: make_catalog_backup-setup-home.patch +Patch5: %{name}-wx-console-build.patch URL: http://www.bacula.org/ +BuildRequires: acl-devel +BuildRequires: autoconf BuildRequires: automake -%{?with_dbi:BuildRequires: libdbi-devel >= 0.8.4} +BuildRequires: gettext-devel +%{?with_console_wx:BuildRequires: gtk+2-devel} +BuildRequires: libcap-devel +BuildRequires: libtool >= 2:2.2 %if %{with rescue} BuildRequires: fakeroot %endif BuildRequires: libwrap-devel -BuildRequires: mtx BuildRequires: ncurses-devel BuildRequires: openssl-devel BuildRequires: pkgconfig %if %{with python} -BuildRequires: python-static +BuildRequires: python-devel +BuildRequires: python-modules %endif %if %{with bat} BuildRequires: QtCore-devel BuildRequires: QtGui-devel -BuildRequires: qt4-build >= 4.3.3-3 -BuildRequires: qt4-qmake >= 4.3.3-3 -BuildRequires: qwt-devel >= 5.0.2-2 +BuildRequires: qt4-build >= %{qtver} +BuildRequires: qt4-qmake >= %{qtver} %endif %{?with_mysql:BuildRequires: mysql-devel} %{?with_pgsql:BuildRequires: postgresql-devel} BuildRequires: readline-devel -BuildRequires: rpmbuild(macros) >= 1.268 +BuildRequires: rpm >= 4.4.9-56 +BuildRequires: rpm-pythonprov +BuildRequires: rpmbuild(macros) >= 1.644 BuildRequires: sed >= 4.0 %{?with_sqlite3:BuildRequires: sqlite3-devel} +Requires: systemd-units >= 38 +BuildRequires: which %if %{with console_wx} BuildRequires: wxGTK2-unicode-devel >= 2.4.0 %endif BuildRequires: zlib-devel BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) -%define _sysconfdir /etc/%{name} +%define _sysconfdir /etc/%{name} %define _localstatedir /var/lib/%{name} +%define nagiosplugindir %{_libdir}/nagios/plugins + +# db packages contain duplicates +%define _duplicate_files_terminate_build 0 + +# from 'the worst' to 'the best' +%define databases %{?with_sqlite3:sqlite3} %{?with_mysql:mysql} %{?with_pgsql:postgresql} # dependency section is broken. ccache usage is instead to makefiles %undefine with_ccache @@ -174,6 +145,7 @@ Conflicts: bacula-console < 0:1.34.6 Conflicts: bacula-dir < 0:1.34.6 Conflicts: bacula-fd < 0:1.34.6 Conflicts: bacula-sd < 0:1.34.6 +Conflicts: logrotate < 3.8.0 %description common Bacula - It comes by night and sucks the vital essence from your @@ -204,7 +176,8 @@ Summary: Bacula Director and Catalog services Summary(pl.UTF-8): Usługi Bacula Director i Catalog Group: Networking/Utilities Requires(post): sed >= 4.0 -Requires: %{name}-common = %{epoch}:%{version}-%{release} +Requires: %{name}-common = %{version}-%{release} +Requires: bacula(db) = %{version}-%{release} Obsoletes: bacula-updatedb %description dir @@ -239,7 +212,7 @@ Summary: Bacula Console Summary(pl.UTF-8): Konsola Baculi Group: Networking/Utilities Requires(post): sed >= 4.0 -Requires: %{name}-common = %{epoch}:%{version}-%{release} +Requires: %{name}-common = %{version}-%{release} %description console Bacula - It comes by night and sucks the vital essence from your @@ -261,7 +234,7 @@ Summary: Bacula wxWidgets Console Summary(pl.UTF-8): Konsola Baculi oparta na wxWidgets Group: Networking/Utilities Requires(post): sed >= 4.0 -Requires: %{name}-common = %{epoch}:%{version}-%{release} +Requires: %{name}-common = %{version}-%{release} %description console-wx Bacula - It comes by night and sucks the vital essence from your @@ -283,7 +256,8 @@ Summary: Bacula Qt4 Console Summary(pl.UTF-8): Konsola Baculi oparta na Qt4 Group: Networking/Utilities Requires(post): sed >= 4.0 -Requires: %{name}-common = %{epoch}:%{version}-%{release} +Requires: %{name}-common = %{version}-%{release} +Requires: QtCore >= %{qtver} %description console-qt4 Bacula - It comes by night and sucks the vital essence from your @@ -303,7 +277,7 @@ interfejs graficzny oparty na Qt4. Summary: Bacula Tray Monitor Group: Networking/Utilities Requires(post): sed >= 4.0 -Requires: %{name}-common = %{epoch}:%{version}-%{release} +Requires: %{name}-common = %{version}-%{release} %description tray-monitor Bacula - It comes by night and sucks the vital essence from your @@ -320,7 +294,7 @@ Summary: Bacula File services (Client) Summary(pl.UTF-8): Usługi Bacula File (klient) Group: Networking/Utilities Requires(post): sed >= 4.0 -Requires: %{name}-common = %{epoch}:%{version}-%{release} +Requires: %{name}-common = %{version}-%{release} %description fd Bacula - It comes by night and sucks the vital essence from your @@ -355,7 +329,7 @@ Summary: Bacula Storage services Summary(pl.UTF-8): Usługi Bacula Storage Group: Networking/Utilities Requires(post): sed >= 4.0 -Requires: %{name}-common = %{epoch}:%{version}-%{release} +Requires: %{name}-common = %{version}-%{release} Conflicts: dvd+rw-tools <= 5.21.4.10.8-1 %description sd @@ -380,11 +354,56 @@ przechowywania danych, np. plików). Usługi Storage działają jako demon na maszynie, która zawiera urządzenie backupowe (zwykle napęd taśmowy). +%package db-postgresql +Summary: PostgreSQL database driver for Bacula +Summary(pl.UTF-8): Sterownik bazy PostgreSQL dla Baculi +Group: Networking/Utilities +Requires(post): /sbin/ldconfig +Requires: %{name}-common = %{version}-%{release} +Provides: bacula(db) = %{version}-%{release} +Obsoletes: bacula(db) + +%description db-postgresql +PostgreSQL database driver for Bacula. + +%description db-postgresql -l pl.UTF-8 +Sterownik bazy PostgreSQL dla Baculi. + +%package db-mysql +Summary: MySQL database driver for Bacula +Summary(pl.UTF-8): Sterownik bazy MySQL dla Baculi +Group: Networking/Utilities +Requires(post): /sbin/ldconfig +Requires: %{name}-common = %{version}-%{release} +Provides: bacula(db) = %{version}-%{release} +Obsoletes: bacula(db) + +%description db-mysql +MySQL database driver for Bacula. + +%description db-mysql -l pl.UTF-8 +Sterownik bazy MySQL dla Baculi. + +%package db-sqlite3 +Summary: SQLite database driver for Bacula +Summary(pl.UTF-8): Sterownik bazy SQLite dla Baculi +Group: Networking/Utilities +Requires(post): /sbin/ldconfig +Requires: %{name}-common = %{version}-%{release} +Provides: bacula(db) = %{version}-%{release} +Obsoletes: bacula(db) + +%description db-sqlite3 +SQLite database driver for Bacula. + +%description db-sqlite3 -l pl.UTF-8 +Sterownik bazy SQLite dla Baculi. + %package rescue Summary: Bacula - The Network Backup Solution Summary(pl.UTF-8): Bacula - rozwiązanie do wykonywania kopii zapasowych po sieci Group: Networking/Utilities -Requires: %{name}-fd = %{epoch}:%{version}-%{release} +Requires: %{name}-fd = %{version}-%{release} Requires: coreutils Requires: util-linux @@ -403,12 +422,6 @@ recover lost or damaged files. This package installs scripts for disaster recovery and builds rescue floppy disk for bare metal recovery. -To make the bacula rescue disk run "./make_rescue_disk ---copy-static-bacula -- --copy-etc-files" from the %{_sysconfdir}/rescue directory. To - recreate the rescue information for this system run ./getdiskinfo - again. - %description rescue -l pl.UTF-8 Bacula - przychodzi nocą i wysysa żywotny ekstrakt z komputerów. @@ -424,10 +437,16 @@ plików. Ten pakiet zawiera skrypty do odtwarzania po awarii i tworzy dyskietkę ratunkowe do odtwarzania systemu od zera. -Aby stworzyć dyskietkę ratunkową Baculi, należy uruchomić "./make_rescue_disk ---copy-static-bacula - --copy-etc-files" z katalogu -%{_sysconfdir}/rescue . Aby ponownie utworzyć informacje ratunkowe dla -danego systemu, należy ponownie uruchomić ./getdiskinfo . +%package -n nagios-plugin-check_bacula +Summary: Nagios plugin to check bacula +Group: Networking +Requires: nagios-common + +%description -n nagios-plugin-check_bacula +Nagios plugin to check bacula. + +# provided by various db libraries as a symlink +%define _noautoreq libbaccats-%{version}.so %prep %setup -q -a 1 @@ -437,8 +456,6 @@ danego systemu, należy ponownie uruchomić ./getdiskinfo . %patch3 -p1 %patch4 -p1 %patch5 -p1 -#%patch6 -p1 -%{?with_dbi:%patch7 -p1} tar -xf %{SOURCE2} && ln -s bacula-rescue-* rescue @@ -446,12 +463,7 @@ sed -i -e 's#bindir=.*#bindir=%{_bindir}#g' \ src/cats/create_* src/cats/delete_* src/cats/drop_* \ src/cats/grant_* src/cats/make_* src/cats/update_* sed -i -e 's/@hostname@/--hostname--/' src/*/*.conf.in - -%if %{with dbi} -for dbtype in bdb mysql postgresql sqlite3; do - sed -i -e "s,@DB_TYPE@,$dbtype,g" src/cats/*_${dbtype}_* -done -%endif +sed -i -e 's/@basename@/--hostname--/' src/*/*.conf.in %build cd autoconf @@ -462,7 +474,9 @@ cd .. %{__autoconf} --prepend-include=$(pwd)/autoconf autoconf/configure.in > configure CPPFLAGS="-I/usr/include/ncurses -I%{_includedir}/readline" + WXCONFIG=%{_bindir}/wx-gtk2-unicode-config \ +QMAKE=%{_bindir}/qmake-qt4 \ %configure \ --with-scriptdir=%{_libexecdir}/%{name} \ %{?with_bat:--enable-bat} \ @@ -479,8 +493,11 @@ WXCONFIG=%{_bindir}/wx-gtk2-unicode-config \ --with-smtp-host=localhost \ --with-pid-dir=/var/run \ --with-subsys-dir=/var/lock/subsys \ + --with-systemd=/lib/systemd/system \ --enable-batch-insert \ - --with-%{database} \ + %{?with_pgsql:--with-postgresql} \ + %{?with_mysql:--with-mysql} \ + %{?with_sqlite3:--with-sqlite3} \ %{?with_sqlite3_sync_off:--enable-extra-sqlite3-init="pragma synchronous=0;"} \ --with-dir-password="#FAKE-dir-password#" \ --with-fd-password="#FAKE-fd-password#" \ @@ -492,12 +509,18 @@ WXCONFIG=%{_bindir}/wx-gtk2-unicode-config \ %if %{with bat} cd src/qt-console -%{__libtoolize} qmake-qt4 bat.pro cd ../.. %endif -%{__make} +%{__make} 2>&1 | tee log +# check for build errors +grep "Error in" log && exit 1 + +%if %{with nagios} +# nagios plugin +%{__make} -C examples/nagios/check_bacula +%endif %if %{with rescue} cd rescue @@ -509,64 +532,90 @@ fakeroot %{__make} %install rm -rf $RPM_BUILD_ROOT - -install -d $RPM_BUILD_ROOT/etc/{rc.d/init.d,logrotate.d,pam.d,sysconfig} -install -d $RPM_BUILD_ROOT%{_sysconfdir}/rescue -install -d $RPM_BUILD_ROOT{%{_pixmapsdir},%{_desktopdir},%{_mandir},%{_bindir},/var/log/bacula} +install -d $RPM_BUILD_ROOT/etc/{rc.d/init.d,logrotate.d,pam.d,sysconfig} \ + $RPM_BUILD_ROOT%{_sysconfdir}/rescue \ + $RPM_BUILD_ROOT{%{_pixmapsdir},%{_desktopdir}} \ + $RPM_BUILD_ROOT{%{_mandir},%{_bindir},/var/log/bacula} \ + $RPM_BUILD_ROOT%{systemdunitdir} %{__make} install \ DESTDIR=$RPM_BUILD_ROOT -install %{SOURCE10} $RPM_BUILD_ROOT/etc/rc.d/init.d/bacula-dir -install %{SOURCE11} $RPM_BUILD_ROOT/etc/rc.d/init.d/bacula-fd -install %{SOURCE12} $RPM_BUILD_ROOT/etc/rc.d/init.d/bacula-sd -install %{SOURCE13} $RPM_BUILD_ROOT/etc/logrotate.d/%{name}-dir -install %{SOURCE14} $RPM_BUILD_ROOT/etc/sysconfig/bacula-dir -install %{SOURCE15} $RPM_BUILD_ROOT/etc/sysconfig/bacula-fd -install %{SOURCE16} $RPM_BUILD_ROOT/etc/sysconfig/bacula-sd +# create copies of make_catalog_backup for specific databases; zeore default one (will be ghost) +for database in %{databases}; do + sed -e "s#default_db_type=.*#default_db_type=${database}#g" \ + $RPM_BUILD_ROOT%{_libdir}/%{name}/make_catalog_backup \ + > $RPM_BUILD_ROOT%{_libdir}/%{name}/make_${database}_catalog_backup + chmod 755 $RPM_BUILD_ROOT%{_libdir}/%{name}/make_${database}_catalog_backup +done +:> $RPM_BUILD_ROOT%{_libdir}/%{name}/make_catalog_backup + +# we use db dependant (at compile time) shell script only +rm $RPM_BUILD_ROOT%{_libexecdir}/%{name}/make_catalog_backup.pl + +## replace with empty file, replaced by ldconfig from each db-* package on intsall +rm $RPM_BUILD_ROOT%{_libdir}/libbaccats-%{version}.so +touch $RPM_BUILD_ROOT%{_libdir}/libbaccats-%{version}.so + +install -p %{SOURCE10} $RPM_BUILD_ROOT/etc/rc.d/init.d/bacula-dir +install -p %{SOURCE11} $RPM_BUILD_ROOT/etc/rc.d/init.d/bacula-fd +install -p %{SOURCE12} $RPM_BUILD_ROOT/etc/rc.d/init.d/bacula-sd +cp -a %{SOURCE13} $RPM_BUILD_ROOT/etc/logrotate.d/%{name}-dir +cp -a %{SOURCE14} $RPM_BUILD_ROOT/etc/sysconfig/bacula-dir +cp -a %{SOURCE15} $RPM_BUILD_ROOT/etc/sysconfig/bacula-fd +cp -a %{SOURCE16} $RPM_BUILD_ROOT/etc/sysconfig/bacula-sd +cp -a %{SOURCE17} $RPM_BUILD_ROOT%{systemdunitdir}/bacula-dir.service +cp -a %{SOURCE18} $RPM_BUILD_ROOT%{systemdunitdir}/bacula-fd.service +cp -a %{SOURCE19} $RPM_BUILD_ROOT%{systemdunitdir}/bacula-sd.service %if %{with console_wx} # tray-monitor is for regular users #mv $RPM_BUILD_ROOT%{_sbindir}/bacula-tray-monitor $RPM_BUILD_ROOT%{_bindir} -install scripts/bacula.png $RPM_BUILD_ROOT%{_pixmapsdir}/bacula.png +cp -a scripts/bacula.png $RPM_BUILD_ROOT%{_pixmapsdir}/bacula.png #install src/tray-monitor/generic.xpm $RPM_BUILD_ROOT%{_pixmapsdir}/bacula-tray-monitor.xpm sed -e 's/gnome-console/wx-console/g;s/Console/Wx Console/g' \ - scripts/bacula.desktop.gnome2 > $RPM_BUILD_ROOT%{_desktopdir}/bacula-wx.desktop + scripts/wxconsole.desktop.consolehelper > $RPM_BUILD_ROOT%{_desktopdir}/bacula-wx.desktop #sed -e 's#%{_sbindir}#%{_bindir}#' \ # scripts/bacula-tray-monitor.desktop > $RPM_BUILD_ROOT%{_desktopdir}/bacula-tray-monitor.desktop %endif %if %{with bat} -install src/qt-console/.libs/bat $RPM_BUILD_ROOT%{_sbindir} -install scripts/bat.desktop $RPM_BUILD_ROOT%{_desktopdir} +# qmake somewhy does not always create install_bins target. install our own the bin +rm -f $RPM_BUILD_ROOT%{_sbindir}/bat +libtool --silent --mode=install install src/qt-console/bat $RPM_BUILD_ROOT%{_bindir} +cp -a scripts/bacula.png $RPM_BUILD_ROOT%{_pixmapsdir}/bacula.png +cp -a scripts/bat.desktop $RPM_BUILD_ROOT%{_desktopdir} %endif %if %{with rescue} # install the rescue stuff, these are the rescue scripts -install rescue/linux/floppy/backup.etc.list $RPM_BUILD_ROOT%{_sysconfdir}/rescue -install rescue/linux/floppy/*_* $RPM_BUILD_ROOT%{_sysconfdir}/rescue -install rescue/linux/floppy/getdiskinfo $RPM_BUILD_ROOT%{_sysconfdir}/rescue -install rescue/linux/floppy/sfdisk.bz2 $RPM_BUILD_ROOT%{_sysconfdir}/rescue +cp -a rescue/linux/floppy/backup.etc.list $RPM_BUILD_ROOT%{_sysconfdir}/rescue +cp -a rescue/linux/floppy/sfdisk.bz2 $RPM_BUILD_ROOT%{_sysconfdir}/rescue +install -p rescue/linux/floppy/*_* $RPM_BUILD_ROOT%{_sysconfdir}/rescue +install -p rescue/linux/floppy/getdiskinfo $RPM_BUILD_ROOT%{_sysconfdir}/rescue %endif touch $RPM_BUILD_ROOT/var/log/bacula/log -# install the updatedb scripts -install updatedb/update_sqlite* $RPM_BUILD_ROOT%{_libexecdir}/%{name} +# install the updatedb scripts for older versions that last full release +# 2.0 -> 3.0 : 10_to_11 +# 5.0 -> 5.2 : 12_to_14 +install -p updatedb/update_*_tables_10_to_11 $RPM_BUILD_ROOT%{_libexecdir}/%{name} +install -p updatedb/update_*_tables_11_to_12 $RPM_BUILD_ROOT%{_libexecdir}/%{name} +install -p updatedb/update_*_tables_12_to_14 $RPM_BUILD_ROOT%{_libexecdir}/%{name} # place for site passwords touch $RPM_BUILD_ROOT%{_sysconfdir}/{dir-password,fd-password,sd-password} touch $RPM_BUILD_ROOT%{_sysconfdir}/{mon-dir-password,mon-fd-password,mon-sd-password} -mv $RPM_BUILD_ROOT%{_libdir}/bacula/mtx-changer.conf $RPM_BUILD_ROOT/etc/bacula/mtx-changer.conf +mv $RPM_BUILD_ROOT%{_libexecdir}/%{name}/mtx-changer.conf $RPM_BUILD_ROOT%{_sysconfdir}/mtx-changer.conf # some file changes rm -f $RPM_BUILD_ROOT%{_libexecdir}/%{name}/{gconsole,startmysql,stopmysql,bacula,bconsole,fd} %if %{without console_wx} rm -f $RPM_BUILD_ROOT%{_desktopdir}/bacula-wx.desktop %endif -touch $RPM_BUILD_ROOT%{_sysconfdir}/.pw.sed rm $RPM_BUILD_ROOT%{_docdir}/bacula/ChangeLog rm $RPM_BUILD_ROOT%{_docdir}/bacula/INSTALL @@ -576,6 +625,28 @@ rm $RPM_BUILD_ROOT%{_docdir}/bacula/ReleaseNotes rm $RPM_BUILD_ROOT%{_docdir}/bacula/VERIFYING rm $RPM_BUILD_ROOT%{_docdir}/bacula/technotes +# startup scripts, those in /etc/rc.d/init.d are better +rm $RPM_BUILD_ROOT%{_sbindir}/bacula +rm $RPM_BUILD_ROOT%{_libexecdir}/%{name}/bacula-ctl-* + +# unsupported +rm $RPM_BUILD_ROOT%{_libexecdir}/%{name}/btraceback.mdb + +# rename to avoid possible conflicts +mv $RPM_BUILD_ROOT%{_sbindir}/{,bacula-}dbcheck +mv $RPM_BUILD_ROOT%{_mandir}/man8/{,bacula-}dbcheck.8.gz + +# no -devel files packaged, so this is also useless +rm $RPM_BUILD_ROOT%{_libdir}/libbac{,cfg,find,py,sql}.{so,la} + +%if %{with nagios} +install -d $RPM_BUILD_ROOT%{nagiosplugindir} +%{__make} -C examples/nagios/check_bacula install \ + sbindir=%{nagiosplugindir} \ + INSTALL_PROGRAM="libtool --mode=install install -p" \ + DESTDIR=$RPM_BUILD_ROOT +%endif + %clean rm -rf $RPM_BUILD_ROOT @@ -583,22 +654,25 @@ rm -rf $RPM_BUILD_ROOT %groupadd -P %{name}-common -g 136 -r -f bacula %useradd -P %{name}-common -u 136 -r -d /var/lib/bacula -s /bin/false -c "Bacula User" -g bacula bacula +%define update_configs \ +echo "Updating bacula passwords and names..." | %banner -a %{name} \ +cd %{_sysconfdir} \ +for f in *-password; do \ + if [ ! -s $f ]; then \ + openssl rand -base64 33 > $f \ + fi \ + p=$(cat $f) \ + for cf in *.conf *.conf.rpmnew; do \ + [ -f $cf ] && sed -i -e"s:#FAKE-$f#:$p:" "$cf" || : \ + done \ +done \ +for cf in *.conf *.conf.rpmnew; do \ + [ -f $cf ] && sed -i -e"s:--hostname--:`hostname`:" "$cf" || : \ +done + %post common /sbin/ldconfig -echo "Updating bacula passwords and names..." -cd /etc/bacula -for f in *-password ; do - if [ ! -s $f ] ; then - openssl rand -base64 33 > $f - fi - p=`cat $f` - for cf in *.conf *.conf.rpmnew ; do - [ -f $cf ] && sed -i -e"s:#FAKE-$f#:$p:" "$cf" || : - done -done -for cf in *.conf *.conf.rpmnew ; do - [ -f $cf ] && sed -i -e"s:--hostname--:`hostname`:" "$cf" || : -done +%update_configs %postun common /sbin/ldconfig @@ -607,98 +681,66 @@ if [ "$1" = "0" ]; then %groupremove bacula fi -%post dir -umask 077 - -# XXX: Most of this upgrade procedure is safe for sqlite only. Other databases would require knowledge -# about currently used version so we can't easily support these :( - -%if %{with sqlite3} -[ -s %{_localstatedir}/bacula.db ] && \ - DB_VER=`echo "select * from Version;" | \ - %{_bindir}/sqlite%{?with_sqlite3:3} %{_localstatedir}/bacula.db | tail -n 1 2>/dev/null` - -if [ -z "$DB_VER" ]; then -# grant privileges and create tables - %{_libexecdir}/%{name}/grant_bacula_privileges > dev/null - %{_libexecdir}/%{name}/create_bacula_database > dev/null - %{_libexecdir}/%{name}/make_bacula_tables > dev/null -else - echo "Backing up bacula tables" - echo ".dump" | sqlite%{?with_sqlite3:3} %{_localstatedir}/bacula.db | bzip2 > %{_localstatedir}/bacula_backup.sql.bz2 - - db_type="%{database}" - - next_ver=$(($DB_VER + 1)) - # support up to version 30; increase this if needed - for ver in $(seq $next_ver 30); do - prev_ver=$(($ver - 1)) - - if [ -x %{_libexecdir}/%{name}/update_${type}_tables_${prev_ver}_to_${ver} ]; then - echo "Upgrading bacula database: db=${db_type} from ${prev_ver} to ${ver}..." - %{_libexecdir}/%{name}/update_${type}_tables_${prev_ver}_to_${ver} - fi - done - - %{_libexecdir}/%{name}/update_bacula_tables - echo "If bacula works correctly you can remove the backup file %{_localstatedir}/bacula_backup.sql.bz2" -fi -chown -R bacula:bacula %{_localstatedir} -chmod -R u+rX,go-rwx %{_localstatedir}/* -%endif +%triggerpostun dir -- %{name}-dir < %{version}-0 +%banner bacula-dir -t3 </dev/null || : -done -sed -i -e"s:--hostname--:`hostname`:" *.conf *.conf.rpmnew 2>/dev/null || : +You will probably need to call %{_libexecdir}/%{name}/update_bacula_tables +script to upgrade the database. +Ensure you database partition has enough free space before you run the upgrade, +i.e check that there is enough room to rebuild 'File' table (it is the largest +in bacula db). + +EOF + +%post dir +%update_configs /sbin/chkconfig --add bacula-dir %service bacula-dir restart "Bacula Director daemon" +%systemd_post bacula-dir.service %preun dir if [ "$1" = "0" ]; then %service bacula-dir stop /sbin/chkconfig --del bacula-dir fi +%systemd_preun bacula-dir.service -%post fd -echo "Updating Bacula passwords and names..." -cd /etc/bacula -for f in *-password; do - p=`cat $f` - sed -i -e"s:#FAKE-$f#:$p:" *.conf *.conf.rpmnew 2>/dev/null || : -done -sed -i -e"s:--hostname--:`hostname`:" *.conf *.conf.rpmnew 2>/dev/null || : +%postun dir +%systemd_reload +%post fd +%update_configs /sbin/chkconfig --add bacula-fd %service bacula-fd restart "Bacula File daemon" +%systemd_post bacula-fd.service %preun fd if [ "$1" = "0" ]; then %service bacula-fd stop /sbin/chkconfig --del bacula-fd fi +%systemd_preun bacula-fd.service -%post sd -echo "Updating Bacula passwords and names..." -cd /etc/bacula -for f in *-password; do - p=`cat $f` - sed -i -e"s:#FAKE-$f#:$p:" *.conf *.conf.rpmnew 2>/dev/null || : -done -sed -i -e"s:--hostname--:`hostname`:" *.conf *.conf.rpmnew 2>/dev/null || : +%postun fd +%systemd_reload +%post sd +%update_configs /sbin/chkconfig --add bacula-sd %service bacula-sd restart "Bacula Storage daemon" +%systemd_post bacula-sd.service %preun sd if [ "$1" = "0" ]; then %service bacula-sd stop /sbin/chkconfig --del bacula-sd fi +%systemd_preun bacula-sd.service + +%postun sd +%systemd_reload %pre console if [ -e %{_sysconfdir}/console.conf -a ! -e %{_sysconfdir}/bconsole.conf ]; then @@ -706,40 +748,19 @@ if [ -e %{_sysconfdir}/console.conf -a ! -e %{_sysconfdir}/bconsole.conf ]; then fi %post console -echo "Updating Bacula passwords and names..." -cd /etc/bacula -for f in *-password; do - p=`cat $f` - sed -i -e"s:#FAKE-$f#:$p:" *.conf *.conf.rpmnew 2>/dev/null || : -done -sed -i -e"s:--hostname--:`hostname`:" *.conf *.conf.rpmnew 2>/dev/null || : +%update_configs %post console-wx -echo "Updating Bacula passwords and names..." -cd /etc/bacula -for f in *-password; do - p=`cat $f` - sed -i -e"s:#FAKE-$f#:$p:" *.conf *.conf.rpmnew 2>/dev/null || : -done -sed -i -e"s:--hostname--:`hostname`:" *.conf *.conf.rpmnew 2>/dev/null || : +%update_configs + +%triggerpostun common -- %{name}-common < 5.0.1-2 +find %{_sysconfdir}/bat.conf* -perm /007 -print0 2>/dev/null | xargs -0 -r chmod 600 || : %post console-qt4 -echo "Updating Bacula passwords and names..." -cd /etc/bacula -for f in *-password; do - p=`cat $f` - sed -i -e"s:#FAKE-$f#:$p:" *.conf *.conf.rpmnew 2>/dev/null || : -done -sed -i -e"s:--hostname--:`hostname`:" *.conf *.conf.rpmnew 2>/dev/null || : +%update_configs %post tray-monitor -echo "Updating Bacula passwords and names..." -cd /etc/bacula -for f in *-password; do - p=`cat $f` - sed -i -e"s:#FAKE-$f#:$p:" *.conf *.conf.rpmnew 2>/dev/null || : -done -sed -i -e"s:--hostname--:`hostname`:" *.conf *.conf.rpmnew 2>/dev/null || : +%update_configs %post rescue # link our current installed conf file to the rescue directory @@ -762,24 +783,53 @@ if [ "$1" = "0" ]; then rm -rf %{_sysconfdir}/rescue/diskinfo/* fi +%define db_post() \ +/sbin/ldconfig \ +for name in "create database" "drop tables" "drop database" "grant privileges" "make tables" "update tables"; do \ + prefix="${name%% *}" \ + suffix="${name#* }" \ + ln -sf "${prefix}_%{1}_${suffix}" %{_libexecdir}/%{name}/"${prefix}_bacula_${suffix}" || : \ +done \ +ln -sf "make_%{1}_catalog_backup" %{_libexecdir}/%{name}/make_catalog_backup || : \ +ln -sf libbaccats-%{1}-%{version}.so %{_libdir}/libbaccats-%{version}.so || : \ +%service bacula-dir restart "Bacula Director daemon" + +%post db-postgresql +%db_post postgresql + +%postun db-postgresql -p /sbin/ldconfig + +%post db-mysql +%db_post mysql + +%postun db-mysql -p /sbin/ldconfig + +%post db-sqlite3 +%db_post sqlite3 + +%postun db-sqlite3 -p /sbin/ldconfig + %files common %defattr(644,root,root,755) %doc LICENSE +%{?with_python:%doc examples/python} %dir %{_sysconfdir} %attr(600,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/*-password -#%attr(755,root,root) %{_sbindir}/bsmtp +# do not remove bsmtp from files. Fix build if it is not installed. +%attr(755,root,root) %{_sbindir}/bsmtp %attr(755,root,root) %{_sbindir}/btraceback -%attr(755,root,root) /%{_libdir}/libbac-%{version}.so -%attr(755,root,root) /%{_libdir}/libbaccfg-%{version}.so -%attr(755,root,root) /%{_libdir}/libbacfind-%{version}.so -%attr(755,root,root) /%{_libdir}/libbacpy-%{version}.so -%attr(755,root,root) /%{_libdir}/libbacsql-%{version}.so +%attr(755,root,root) %{_libdir}/libbac-5*.so +%attr(755,root,root) %{_libdir}/libbaccfg-5*.so +%attr(755,root,root) %{_libdir}/libbacfind-5*.so +%attr(755,root,root) %{_libdir}/libbacpy-5*.so +%attr(755,root,root) %{_libdir}/libbacsql-5*.so %{_mandir}/man8/bacula.8* %{_mandir}/man1/bsmtp.1* %{_mandir}/man8/btraceback.8* %dir %{_libexecdir}/%{name} %{_libexecdir}/%{name}/btraceback.dbx %{_libexecdir}/%{name}/btraceback.gdb +%{_libexecdir}/%{name}/bacula_config %attr(770,root,bacula) %dir %{_localstatedir} %attr(750,bacula,logs) %dir /var/log/bacula %attr(640,bacula,logs) %ghost /var/log/bacula/log @@ -789,76 +839,100 @@ fi %doc ChangeLog CheckList ReleaseNotes kernstodo LICENSE #%doc examples %{name}-docs-%{version}/manual/{*.pdf,bacula} %attr(640,root,bacula) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/bacula-dir.conf -%ghost %{_sysconfdir}/.pw.sed %attr(640,root,root) %config(noreplace) /etc/logrotate.d/bacula-dir %attr(754,root,root) /etc/rc.d/init.d/bacula-dir %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/bacula-dir +%{systemdunitdir}/bacula-dir.service %attr(755,root,root) %{_sbindir}/bacula-dir -#%attr(755,root,root) %{_sbindir}/bregex -#%attr(755,root,root) %{_sbindir}/bwild -#%attr(755,root,root) %{_sbindir}/dbcheck +%attr(755,root,root) %{_sbindir}/bregex +%attr(755,root,root) %{_sbindir}/bwild +%attr(755,root,root) %{_sbindir}/bacula-dbcheck %{_mandir}/man8/bacula-dir.8* -%{_mandir}/man8/dbcheck.8* +%{_mandir}/man8/bacula-dbcheck.8* +%{_mandir}/man8/bregex.8* +%{_mandir}/man8/bwild.8* %{_libexecdir}/%{name}/query.sql -%if %{with bdb} || %{with dbi} -%attr(755,root,root) %{_libexecdir}/%{name}/create_bdb_database -%attr(755,root,root) %{_libexecdir}/%{name}/drop_bdb_database -%attr(755,root,root) %{_libexecdir}/%{name}/drop_bdb_tables -%attr(755,root,root) %{_libexecdir}/%{name}/grant_bdb_privileges -%attr(755,root,root) %{_libexecdir}/%{name}/make_bdb_tables -%attr(755,root,root) %{_libexecdir}/%{name}/update_bdb_* -%endif -%if %{with sqlite3} || %{with dbi} -%attr(755,root,root) %{_libexecdir}/%{name}/create_sqlite3_database -%attr(755,root,root) %{_libexecdir}/%{name}/drop_sqlite3_database -%attr(755,root,root) %{_libexecdir}/%{name}/drop_sqlite3_tables -%attr(755,root,root) %{_libexecdir}/%{name}/grant_sqlite3_privileges -%attr(755,root,root) %{_libexecdir}/%{name}/make_sqlite3_tables -%attr(755,root,root) %{_libexecdir}/%{name}/update_sqlite3_* -%endif -%if %{with mysql} || %{with dbi} -%attr(755,root,root) %{_libexecdir}/%{name}/create_mysql_database -%attr(755,root,root) %{_libexecdir}/%{name}/drop_mysql_database -%attr(755,root,root) %{_libexecdir}/%{name}/drop_mysql_tables -%attr(755,root,root) %{_libexecdir}/%{name}/grant_mysql_privileges -%attr(755,root,root) %{_libexecdir}/%{name}/make_mysql_tables -%attr(755,root,root) %{_libexecdir}/%{name}/update_mysql_* -%endif -%if %{with pgsql} || %{with dbi} +%attr(755,root,root) %{_libexecdir}/%{name}/delete_catalog_backup + +%files db-postgresql +%defattr(644,root,root,755) %attr(755,root,root) %{_libexecdir}/%{name}/create_postgresql_database %attr(755,root,root) %{_libexecdir}/%{name}/drop_postgresql_database %attr(755,root,root) %{_libexecdir}/%{name}/drop_postgresql_tables %attr(755,root,root) %{_libexecdir}/%{name}/grant_postgresql_privileges %attr(755,root,root) %{_libexecdir}/%{name}/make_postgresql_tables %attr(755,root,root) %{_libexecdir}/%{name}/update_postgresql_* -%endif -%if %{without dbi} -%attr(755,root,root) %{_libexecdir}/%{name}/create_bacula_database -%attr(755,root,root) %{_libexecdir}/%{name}/drop_bacula_database -%attr(755,root,root) %{_libexecdir}/%{name}/drop_bacula_tables -%attr(755,root,root) %{_libexecdir}/%{name}/grant_bacula_privileges -%attr(755,root,root) %{_libexecdir}/%{name}/make_bacula_tables -%attr(755,root,root) %{_libexecdir}/%{name}/update_bacula_tables -%endif -#%attr(755,root,root) %{_libexecdir}/%{name}/make_catalog_backup -#%attr(755,root,root) %{_libexecdir}/%{name}/delete_catalog_backup +%attr(755,root,root) %{_libexecdir}/%{name}/make_postgresql_catalog_backup +%attr(755,root,root) %{_libdir}/libbaccats-postgresql-5*.so + +%ghost %attr(755,root,root) %{_libdir}/libbaccats-5*.so +%ghost %{_libexecdir}/%{name}/create_bacula_database +%ghost %{_libexecdir}/%{name}/drop_bacula_tables +%ghost %{_libexecdir}/%{name}/drop_bacula_database +%ghost %{_libexecdir}/%{name}/grant_bacula_privileges +%ghost %{_libexecdir}/%{name}/make_bacula_tables +%ghost %{_libexecdir}/%{name}/update_bacula_tables +%ghost %{_libexecdir}/%{name}/make_catalog_backup + +%files db-mysql +%defattr(644,root,root,755) +%attr(755,root,root) %{_libexecdir}/%{name}/create_mysql_database +%attr(755,root,root) %{_libexecdir}/%{name}/drop_mysql_database +%attr(755,root,root) %{_libexecdir}/%{name}/drop_mysql_tables +%attr(755,root,root) %{_libexecdir}/%{name}/grant_mysql_privileges +%attr(755,root,root) %{_libexecdir}/%{name}/make_mysql_tables +%attr(755,root,root) %{_libexecdir}/%{name}/update_mysql_* +%attr(755,root,root) %{_libexecdir}/%{name}/make_mysql_catalog_backup +%attr(755,root,root) %{_libdir}/libbaccats-mysql-5*.so + +%ghost %attr(755,root,root) %{_libdir}/libbaccats-5*.so +%ghost %{_libexecdir}/%{name}/create_bacula_database +%ghost %{_libexecdir}/%{name}/drop_bacula_tables +%ghost %{_libexecdir}/%{name}/drop_bacula_database +%ghost %{_libexecdir}/%{name}/grant_bacula_privileges +%ghost %{_libexecdir}/%{name}/make_bacula_tables +%ghost %{_libexecdir}/%{name}/update_bacula_tables +%ghost %{_libexecdir}/%{name}/make_catalog_backup + +%files db-sqlite3 +%defattr(644,root,root,755) +%attr(755,root,root) %{_libexecdir}/%{name}/create_sqlite3_database +%attr(755,root,root) %{_libexecdir}/%{name}/drop_sqlite3_database +%attr(755,root,root) %{_libexecdir}/%{name}/drop_sqlite3_tables +%attr(755,root,root) %{_libexecdir}/%{name}/grant_sqlite3_privileges +%attr(755,root,root) %{_libexecdir}/%{name}/make_sqlite3_tables +%attr(755,root,root) %{_libexecdir}/%{name}/update_sqlite3_* +%attr(755,root,root) %{_libexecdir}/%{name}/make_sqlite3_catalog_backup +%attr(755,root,root) %{_libdir}/libbaccats-sqlite3-5*.so + +%ghost %attr(755,root,root) %{_libdir}/libbaccats-5*.so +%ghost %{_libexecdir}/%{name}/create_bacula_database +%ghost %{_libexecdir}/%{name}/drop_bacula_tables +%ghost %{_libexecdir}/%{name}/drop_bacula_database +%ghost %{_libexecdir}/%{name}/grant_bacula_privileges +%ghost %{_libexecdir}/%{name}/make_bacula_tables +%ghost %{_libexecdir}/%{name}/update_bacula_tables +%ghost %{_libexecdir}/%{name}/make_catalog_backup %files fd %defattr(644,root,root,755) %doc LICENSE -%attr(600,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/bacula-fd.conf +%attr(640,root,bacula) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/bacula-fd.conf %attr(754,root,root) /etc/rc.d/init.d/bacula-fd %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/bacula-fd +%{systemdunitdir}/bacula-fd.service %attr(755,root,root) %{_sbindir}/bacula-fd +%attr(755,root,root) %{_libdir}/bpipe-fd.so %{_mandir}/man8/bacula-fd.8* %files sd %defattr(644,root,root,755) %doc LICENSE -%attr(600,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/bacula-sd.conf -%attr(600,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/mtx-changer.conf +%attr(640,root,bacula) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/bacula-sd.conf +%attr(640,root,bacula) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/mtx-changer.conf %attr(754,root,root) /etc/rc.d/init.d/bacula-sd %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/bacula-sd +%{systemdunitdir}/bacula-sd.service %attr(755,root,root) %{_sbindir}/bacula-sd %attr(755,root,root) %{_sbindir}/bcopy %attr(755,root,root) %{_sbindir}/bextract @@ -878,7 +952,7 @@ fi %files console %defattr(644,root,root,755) %doc LICENSE -%attr(600,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/bconsole.conf +%attr(640,root,bacula) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/bconsole.conf %attr(755,root,root) %{_sbindir}/bconsole %{_mandir}/man8/bconsole.8* @@ -888,7 +962,7 @@ fi %doc LICENSE %{_pixmapsdir}/%{name}.png %{_desktopdir}/bacula-wx.desktop -%attr(600,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/bwx-console.conf +%attr(640,root,bacula) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/bwx-console.conf %attr(755,root,root) %{_sbindir}/bwx-console %{_mandir}/man1/bacula-bwxconsole.1* %endif @@ -899,9 +973,12 @@ fi %doc LICENSE %{_pixmapsdir}/%{name}.png %{_desktopdir}/bat.desktop -%config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/bat.conf -%attr(755,root,root) %{_sbindir}/bat +# Do not make this file world-readable or any user will get full access to the +# backup system +%attr(640,root,bacula) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/bat.conf +%attr(755,root,root) %{_bindir}/bat %{_mandir}/man1/bat.1* +%{_docdir}/%{name} %endif %if %{with console_wx} @@ -931,3 +1008,9 @@ fi %attr(755,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/rescue/run_lilo %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/rescue/sfdisk.bz2 %endif + +%if %{with nagios} +%files -n nagios-plugin-check_bacula +%defattr(644,root,root,755) +%attr(755,root,root) %{nagiosplugindir}/check_bacula +%endif